

# **E-tile Hard IP User Guide**

# E-Tile Hard IP for Ethernet and E-Tile CPRI PHY Intel<sup>®</sup> FPGA IPs

Updated for Intel<sup>®</sup> Quartus<sup>®</sup> Prime Design Suite: **19.4** 





| About E-tile Hard IP User Guide                                             | 5    |
|-----------------------------------------------------------------------------|------|
| About the E-Tile Hard IP for Ethernet Intel FPGA IP Core                    | 6    |
| 2.1. E-Tile Hard IP for Ethernet Intel FPGA IP Supported Features           | 8    |
| 2.2. E-Tile Hard IP for Ethernet Intel FPGA IP Overview                     |      |
| 2.3. IP Core Device Family and Speed Grade Support                          |      |
| 2.3.1. E-Tile Hard IP for Ethernet Intel FPGA IP Device Family Support      | 16   |
| 2.3.2. E-Tile Hard IP for Ethernet Intel FPGA IP Device Speed Grade Support | 16   |
| 2.4. IP Core Verification                                                   | 17   |
| 2.4.1. Simulation Environment                                               | 17   |
| 2.4.2. Compilation Checking                                                 | 17   |
| 2.4.3. Hardware Testing                                                     | 17   |
| 2.5. Resource Utilization                                                   |      |
| 2.6. Release Information                                                    |      |
| 2.7. Getting Started                                                        |      |
| 2.7.1. Installing and Licensing Intel FPGA IP Cores                         |      |
| 2.7.2. Specifying the IP Core Parameters and Options                        |      |
| 2.7.3. Generated File Structure                                             |      |
| 2.7.4. Integrating Your IP Core in Your Design                              |      |
| 2.7.5. IP Core Testbenches                                                  |      |
| 2.7.6. Compiling the Full Design                                            |      |
| 2.8. E-Tile Hard IP for Ethernet Intel FPGA IP Parameters                   |      |
| 2.8.1. Parameter Editor Parameters                                          |      |
| 2.8.2. RTL Parameters                                                       |      |
| 2.9. Functional Description                                                 |      |
| 2.9.1. E-Tile Hard IP for Ethernet Intel FPGA IP MAC                        |      |
| 2.9.2. 1588 Precision Time Protocol Interfaces                              |      |
| 2.9.3. PCS, OTN, FlexE, and Custom PCS Modes                                |      |
| 2.9.4. Auto-Negotiation and Link Training<br>2.9.5. TX and RX RS-FEC        |      |
| 2.9.5. TX and KX RS-FEC                                                     |      |
| 2.9.6. PMA Direct Mode                                                      |      |
| 2.9.7. Dynamic Recomputation                                                | 94   |
| Reconfiguration Design Example                                              | 95   |
| 2.9.9. Ethernet Adaptation Flow with External AIB Clocking and PTP          |      |
| 2.9.10. Ethernet Adaptation Flow with Non-external AIB Clocking             |      |
| 2.10. Reset.                                                                |      |
| 2.10.1. Reset Sequence                                                      |      |
| 2.11. Interfaces and Signals                                                |      |
| 2.11.1. TX MAC Interface to User Logic                                      |      |
| 2.11.2. RX MAC Interface to User Logic                                      |      |
| 2.11.3. TX PCS Interface to User Logic                                      |      |
| 2.11.4. RX PCS Interface to User Logic                                      |      |
| 2.11.5. FlexE and OTN Mode TX Interface                                     |      |
| 2.11.6. FlexE and OTN Mode RX Interface                                     |      |
| 2.11.7. TX Custom PCS Interface to User Logic                               | .122 |
| 2.11.8. RX Custom PCS Interface to User Logic                               | 125  |





| 2.11.9. PMA Direct Interface                                                                                                                                                              |                                                                                                              |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|
| 2.11.10. Custom Rate Interface                                                                                                                                                            |                                                                                                              |
| 2.11.11. Deterministic Latency Interface                                                                                                                                                  | 128                                                                                                          |
| 2.11.12. 1588 PTP Interface                                                                                                                                                               | 129                                                                                                          |
| 2.11.13. Ethernet Link and Transceiver Signals                                                                                                                                            | 134                                                                                                          |
| 2.11.14. Reconfiguration Interfaces and Signals                                                                                                                                           | 135                                                                                                          |
| 2.11.15. Miscellaneous Status and Debug Signals                                                                                                                                           |                                                                                                              |
| 2.11.16. Reset Signals                                                                                                                                                                    |                                                                                                              |
| 2.11.17. Clocks                                                                                                                                                                           | 140                                                                                                          |
| 2.12. Reconfiguration and Status Register Descriptions                                                                                                                                    | 158                                                                                                          |
| 2.12.1. Auto Negotiation and Link Training Registers                                                                                                                                      |                                                                                                              |
| 2.12.2. PHY Registers                                                                                                                                                                     |                                                                                                              |
| 2.12.3. TX MAC Registers                                                                                                                                                                  |                                                                                                              |
| 2.12.4. RX MAC Registers                                                                                                                                                                  |                                                                                                              |
| 2.12.5. Pause and Priority- Based Flow Control Registers                                                                                                                                  |                                                                                                              |
| 2.12.6. TX Statistics Counter Registers                                                                                                                                                   |                                                                                                              |
| 2.12.7. RX Statistics Counter Registers                                                                                                                                                   |                                                                                                              |
| 2.12.8. 1588 PTP Registers                                                                                                                                                                |                                                                                                              |
| 2.12.9. RS-FEC Registers                                                                                                                                                                  |                                                                                                              |
| 2.12.10. PMA Registers                                                                                                                                                                    |                                                                                                              |
| 2.13. Document Revision History for the E-tile Hard IP for Ethernet Intel FPGA IP Co                                                                                                      |                                                                                                              |
|                                                                                                                                                                                           |                                                                                                              |
| 3. About the E-Tile CPRI PHY Intel FPGA IP                                                                                                                                                |                                                                                                              |
| 3.1. Supported Features                                                                                                                                                                   |                                                                                                              |
| 3.2. E-Tile CPRI PHY Intel FPGA IP Overview                                                                                                                                               |                                                                                                              |
|                                                                                                                                                                                           |                                                                                                              |
| 3.3. E-Tile CPRI PHY Device Family Support                                                                                                                                                |                                                                                                              |
| 3.4. Resource Utilization                                                                                                                                                                 |                                                                                                              |
| 3.4. Resource Utilization<br>3.5. Release Information                                                                                                                                     |                                                                                                              |
| <ul><li>3.4. Resource Utilization</li><li>3.5. Release Information</li><li>3.6. E-Tile CPRI PHY Intel FPGA IP Core Device Speed Grade Support</li></ul>                                   | 252<br>253<br>253                                                                                            |
| <ul> <li>3.4. Resource Utilization</li> <li>3.5. Release Information</li> <li>3.6. E-Tile CPRI PHY Intel FPGA IP Core Device Speed Grade Support</li> <li>3.7. Getting Started</li> </ul> | 252<br>253<br>253<br>254                                                                                     |
| <ul> <li>3.4. Resource Utilization</li></ul>                                                                                                                                              | 252<br>253<br>253<br>254<br>254                                                                              |
| <ul> <li>3.4. Resource Utilization</li></ul>                                                                                                                                              |                                                                                                              |
| <ul> <li>3.4. Resource Utilization</li></ul>                                                                                                                                              | 252<br>253<br>253<br>254<br>254<br>257<br>257<br>257<br>260<br>266<br>266<br>266<br>268<br>268<br>268<br>273 |
| <ul> <li>3.4. Resource Utilization</li></ul>                                                                                                                                              |                                                                                                              |



| 5. E-tile Hard IP User Guide Archives                                                                   | . 293 |
|---------------------------------------------------------------------------------------------------------|-------|
| 4.3. Document Revision History for the E-tile Channel Placement Tool and the Ethernet<br>Link Inspector | 292   |
| 4.2. Ethernet Link Inspector                                                                            |       |
| 4.1. E-Tile Channel Placement Tool                                                                      |       |
| 4. About the E-tile Channel Placement Tool and Ethernet Link Inspector                                  | . 291 |
| 3.12. Document Revision History for the E-tile CPRI PHY Intel FPGA IP                                   |       |
| 3.11.4. RS-FEC Registers                                                                                |       |
| 3.11.3. PMA Registers                                                                                   | 288   |
| 3.11.2. CPRI PHY Registers                                                                              | 286   |





# **1. About E-tile Hard IP User Guide**

This user guide consists of information for the following IP cores:

- E-Tile Hard IP for Ethernet Intel<sup>®</sup> FPGA IP
- E-Tile Ethernet IP for Intel Agilex FPGA
- E-Tile CPRI PHY Intel FPGA IP

For more information on specific IP release, refer to the Release Information sections.

#### **Related Information**

- E-Tile Hard IP for Ethernet Intel FPGA IP Core Release Information on page 19
- E-Tile Ethernet IP for Intel Agilex FPGA Core Release Information on page 19
- E-Tile CPRI PHY IP Core Release Information on page 253

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO 9001:2015 Registered



# 2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core

Intel Stratix<sup>®</sup> 10 and Intel Agilex<sup>m</sup> E-tile FPGA production devices include a configurable, hardened protocol stack for Ethernet that is compatible with the *IEEE* 802.3 High Speed Ethernet Standard and the 25G/50G Ethernet Specification, Draft 1.6 from the 25 Gigabit Ethernet Consortium.

#### Table 1. Ethernet IP Naming Convention

The table shows the Ethernet-based IPs available in IP Catalog.

| Supported Device Family | IP Catalog                                |
|-------------------------|-------------------------------------------|
| Intel Stratix 10        | E-Tile Hard IP for Ethernet Intel FPGA IP |
| Intel Agilex            | E-tile Ethernet IP for Intel Agilex FPGA  |

*Note:* Unless specified, the E-Tile Hard IP for Ethernet Intel FPGA IP applies to all supported device families.

The E-Tile Hard IP for Ethernet Intel FPGA IP provides access to this hard IP at Ethernet data rates of 10 Gbps, 25 Gbps, and 100 Gbps. The IP core is included in the Intel FPGA IP Library and is available from the Intel Quartus<sup>®</sup> Prime Pro Edition IP Catalog.

The IP core is available in the following variants, each providing a different combination of Ethernet channels and features:

- Single 10GE/25GE channel
- 1 to 4 10GE/25GE channels with optional Reed-Solomon Forward Error Correction (RS-FEC)
- 100GE channel with optional RS-FEC
- 100GE or 1 to 4 10GE/25GE channels with optional RS-FEC, and optional 1588 Precision Time Protocol (PTP)
- Custom PCS with optional RS-FEC

The 100GE or 1 to 4 10GE/25GE channels with optional RS-FEC, and optional 1588 Precision Time Protocol (PTP) variant contains a 100G Ethernet channel, and up to 4 single-lane channels that can run at 10G or 25G. However, the single-lane channels and the 100GE channel cannot run at the same time.

For any variant except the custom PCS with RS-FEC variant, you can choose a Media Access Control (MAC) + Physical Coding Sublayer(PCS) variation, a PCS-only variation, a custom PCS variation, a Flexible Ethernet (FlexE) variation, or an Optical Transport Network (OTN) variation.

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.





#### Figure 1. Variant Selection

For any variant, you can choose a MAC + PCS variation, a PCS-only variation, a FlexE variation, an OTN variation or a custom PCS variation.

| Ethernet IP Layers                     |     | Protocol Layers Included |                             |                       |                             |                        |                              | Variants                               |                                        |                            |     |     |                          |                                               |               |                                                                    |                                               |
|----------------------------------------|-----|--------------------------|-----------------------------|-----------------------|-----------------------------|------------------------|------------------------------|----------------------------------------|----------------------------------------|----------------------------|-----|-----|--------------------------|-----------------------------------------------|---------------|--------------------------------------------------------------------|-----------------------------------------------|
|                                        | MAC | Flow Control             | IEEE 1588 PTP 1-Step/2-Step | PCS Encoding/Decoding | PCS Scrambling/Descrambling | PCS Striping/Alignment | RS-FEC Transcode/Detranscode | RS-FEC (528,514) Encode/Decode/Correct | RS-FEC (544,514) Encode/Decode/Correct | RS-FEC Stripping/Alignment | PMA | PMD | Single 10GE/25GE Channel | 1 to 4 10GE/25GE Channels with optional RSFEC | 100G Channels | 100GE or 1 to 4 10GE/25GE Channels with<br>optional RS-FEC and PTP | Custom PCS with Optional RSFEC <sup>(3)</sup> |
| MAC + PCS                              | Yes | Yes                      | -                           | Yes                   | Yes                         | Yes                    | —                            | —                                      | —                                      | -                          | Yes | Yes | Yes                      | Yes                                           | Yes           | Yes                                                                | -                                             |
| MAC + 1588 PTP + PCS                   | Yes | Yes                      | Yes                         | Yes                   | Yes                         | Yes                    | -                            | —                                      | —                                      | —                          | Yes | Yes | _                        | —                                             | -             | Yes                                                                | _                                             |
| MAC + PCS + (528,514 RSFEC)            | Yes | Yes                      | _                           | Yes                   | Yes                         | _                      | Yes                          | Yes                                    | —                                      | Yes                        | Yes | Yes | Yes <sup>(1)</sup>       | Yes(1)                                        | Yes           | Yes <sup>(1)</sup>                                                 | —                                             |
| MAC + PCS + (544,514 RSFEC)            | Yes | Yes                      | _                           | Yes                   | Yes                         | _                      | Yes                          | -                                      | Yes                                    | Yes                        | Yes | Yes | —                        | _                                             | Yes           | Yes <sup>(2)</sup>                                                 | —                                             |
| MAC + 1588 PTP + PCS + (528,514 RSFEC) | Yes | Yes                      | Yes                         | Yes                   | Yes                         | _                      | Yes                          | Yes                                    | -                                      | Yes                        | Yes | Yes | _                        | _                                             | -             | Yes <sup>(1)</sup>                                                 | -                                             |
| PCS Only                               | —   | —                        | —                           | Yes                   | Yes                         | Yes                    | —                            | —                                      | —                                      | —                          | Yes | Yes | Yes                      | Yes                                           | Yes           | Yes                                                                | Yes                                           |
| OTN                                    | -   | -                        | _                           | -                     | Ι                           | Yes                    | -                            |                                        | -                                      | Ι                          | Yes | Yes | Yes                      | Yes                                           | Yes           | Yes                                                                | _                                             |
| FlexE                                  | —   | —                        | —                           | —                     | Yes                         | Yes                    | _                            | —                                      | —                                      | —                          | Yes | Yes | Yes                      | Yes                                           | Yes           | Yes                                                                | _                                             |
| PCS + (528,514 RSFEC)                  | —   | —                        | —                           | Yes                   | Yes                         | —                      | Yes                          | Yes                                    | —                                      | Yes                        | Yes | Yes | Yes                      | Yes                                           | Yes           | Yes <sup>(1)</sup>                                                 | Yes                                           |
| PCS + (544,514 RSFEC)                  | —   | —                        | —                           | Yes                   | Yes                         | _                      | Yes                          | -                                      | Yes                                    | Yes                        | Yes | Yes | —                        | —                                             | Yes           | Yes <sup>(2)</sup>                                                 | —                                             |
| OTN + (528,514 RSFEC)                  | —   | —                        | -                           | —                     | —                           | _                      | Yes                          | Yes                                    | —                                      | Yes                        | Yes | Yes | Yes <sup>(1)</sup>       | Yes <sup>(1)</sup>                            | Yes           | Yes <sup>(1)</sup>                                                 | —                                             |
| OTN + (544,514 RSFEC)                  | —   | —                        | _                           | —                     | _                           | _                      | Yes                          | -                                      | Yes                                    | Yes                        | Yes | Yes | _                        | -                                             | Yes           | Yes <sup>(2)</sup>                                                 | —                                             |
| FlexE + (528,514 RSFEC)                | -   | —                        | _                           | —                     | Yes                         | _                      | Yes                          | Yes                                    | -                                      | Yes                        | Yes | Yes | Yes                      | Yes <sup>(1)</sup>                            | Yes           | Yes <sup>(1)</sup>                                                 | —                                             |
| FlexE + (544,514 RSFEC)                | -   | —                        | -                           | —                     | Yes                         | _                      | Yes                          | -                                      | Yes                                    | Yes                        | Yes | Yes | —                        | -                                             | Yes           | Yes <sup>(2)</sup>                                                 | —                                             |
| Custom PCS Only                        | —   | —                        | -                           | Yes                   | Yes                         | Yes                    | -                            | -                                      | _                                      | —                          | Yes | Yes | _                        | _                                             | —             | _                                                                  | Yes                                           |
| Custom PCS + RSFEC                     | —   | —                        | -                           | Yes                   | Yes                         | —                      | Yes                          | Yes                                    | —                                      | Yes                        | Yes | Yes | —                        | -                                             | —             | -                                                                  | Yes                                           |

(1) 10G data rate does not support RSFEC.

(2) Only 100G data rate supports (544,514) RSFEC.
 (3) Customizable data rate PCS from 2.5 to 28 Gbps for protocols other than Ethernet...

#### Table 2.Client Interfaces for IP Core Variations

| IP Core Variation | Client Interface Type                     |
|-------------------|-------------------------------------------|
| MAC+PCS           | Avalon <sup>®</sup> Streaming (Avalon-ST) |
| PCS-only          | Media Independent Interface (MII)         |
| Custom PCS        | MII                                       |
| FlexE             | PCS66                                     |
| OTN               | PCS66                                     |

*Note:* The E-Tile Hard IP for Ethernet Intel FPGA IP provides preliminary support for the OTN feature. For further inquiries, contact your nearest Intel sales representative or file an Intel Premier Support (IPS) case at https://www.intel.com/content/www/us/en/programmable/my-intel/mal-home.html.

E-Tile Hard IP for Ethernet Intel FPGA IP core supports a variety of protocol implementations.



#### Table 3.Ethernet Protocols

| Ethernet Channel | Protocol                  | Number of Lanes and Line Rate                                                          |
|------------------|---------------------------|----------------------------------------------------------------------------------------|
| 100GE            | 100GBASE-KR4              | 4x25.78125 Gbps Non-Return-to-Zero (NRZ) for Copper<br>Backplane                       |
|                  | 100GBASE-CR4              | 4x25.78125 Gbps NRZ for Direct Attach Copper Cable                                     |
|                  | CAUI-4                    | 4x25.78125 Gbps NRZ lanes for Low Loss Links: Chip-to-<br>Chip or Chip-to-Module       |
|                  | CAUI-2                    | 2x53.125 Gbps PAM4 lanes for Low Loss Links: Chip-to-<br>Chip, Chip-to-Module, and DAC |
| 25GE             | 25GBASE-KR                | 1x25.78125 Gbps lane for Backplane                                                     |
|                  | 25GBASE-CR                | 1x25.78125 Gbps lane for Direct Attach Copper Cable                                    |
|                  | 25GBASE-R AUI             | 1x25.78125 Gbps lane for Low Loss Connections to External PHY Modules                  |
|                  | 25GBASE-R Consortium Link | 1x25.78125 Gbps lane based on the 25G/50G Consortium Specification                     |
| 10GE             | 10GBASE-KR                | 1x10.3125 Gbps lane for Backplane                                                      |
|                  | 10GBASE-CR                | 1x10.3125 Gbps lane for Direct Attach Copper Cable                                     |

#### **Related Information**

IEEE Website

٠

The IEEE 802.3-2015 High Speed Ethernet Standard is available on the IEEE website.

• 25G Ethernet Consortium

# **2.1. E-Tile Hard IP for Ethernet Intel FPGA IP Supported Features**

The IP core is designed to the *IEEE 802.3-2015 High Speed Ethernet Standard* available on the IEEE website (www.ieee.org) and the *25G/50G Ethernet Specification*, *Draft 1.6* available from the 25 Gigabit Ethernet Consortium. The MAC provides cut-through frame processing to optimize latency, and supports full wire line speed with a 64-byte frame length and back-to-back or mixed length traffic with no dropped packets. All E-Tile Hard IP for Ethernet Intel FPGA IP variations are in full-duplex mode.

#### Table 4. E-Tile Hard IP for Ethernet Intel FPGA IP Features

| Features | Description                                                                                                                 |
|----------|-----------------------------------------------------------------------------------------------------------------------------|
| PCS      | Hard IP logic that interfaces seamlessly to E-tile transceivers.                                                            |
|          | CAUI external interface consisting of four transceiver lanes operating at 25.78125 Gbps.                                    |
|          | CAUI-2 external interface with two transceiver lanes operating at 53.125 Gbps with PAM4 encoding                            |
|          | 25G AUI external interface with 1 transceiver lane operating at 25.78125 Gbps                                               |
|          | 10G AUI external interface with 1 transceiver lane operating at 10.3125 Gbps                                                |
|          | Supports CAUI-4 links based on 64B/66B encoding with data striping and alignment markers to align data from multiple lanes. |
|          | continued                                                                                                                   |





| Features                        | Description                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|                                 | Supports customizable data rate PCS from 2.5 to 28 Gbps for protocols other than Ethernet.                                                                                                                                                                                                                |  |  |  |  |  |  |  |
|                                 | Optional RS-FEC(528,514) or RS-FEC(544,514) for 25G and 100G variations.                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|                                 | Supports 10G, 25G, and 100G variations.                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
|                                 | • Auto-negotiation (AN) as defined in <i>IEEE Standard 802.3-2915 Clause 73</i> and the 25G Ethernet Consortium Schedule Draft 1.6, and                                                                                                                                                                   |  |  |  |  |  |  |  |
|                                 | • Link training (LT) as defined in <i>IEEE Standard 802.3-2915 Clauses 92 and 93</i> and the 25G Ethernet Consortium Schedule Draft 1.6                                                                                                                                                                   |  |  |  |  |  |  |  |
|                                 | RX Skew Variation tolerance that exceeds the <i>IEEE 802.3-2015 High Speed Ethernet Standard</i> Clause 80.5 requirements.                                                                                                                                                                                |  |  |  |  |  |  |  |
| OTN                             | Optional 25GE constant bit rate (CBR); with TX and RX PCS66 bit encoding/decoding and scrambling/descrambling disabled.                                                                                                                                                                                   |  |  |  |  |  |  |  |
|                                 | Note: The E-Tile Hard IP for Ethernet Intel FPGA IP provides preliminary support for<br>the OTN feature. For further inquiries, contact your nearest Intel sales<br>representative or file an Intel Premier Support (IPS) case at https://<br>www.intel.com/content/www/us/en/my-intel/fpga-sign-in.html. |  |  |  |  |  |  |  |
|                                 | Optional RS-FEC(528,514) or RS-FEC(544,514) for 25G and 100G variations.                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
| Flexible Ethernet (FlexE)       | Optional CBR; with TX and RX PCS66 bit encoding/decoding disabled and scrambling/ descrambling enabled.                                                                                                                                                                                                   |  |  |  |  |  |  |  |
|                                 | Optional RS-FEC(528,514) or RS-FEC(544,514) for 25G and 100G variations.                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
| PMA Direct Mode                 | Optional to switch from MAC+PCS to PMA only mode during run-time.                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
| Frame Structure Control         | Support for jumbo packets.                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |
|                                 | RX CRC pass-through control.                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|                                 | 1000 bits RX PCS lane skew tolerance for 100G links, which exceeds the <i>IEEE</i> 802.3-2015 High Speed Ethernet Standard Clause 82.2.12 requirements.                                                                                                                                                   |  |  |  |  |  |  |  |
|                                 | Optional per-packet TX CRC generation and insertion.                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|                                 | Optional Deficit Idle Counter (DIC) options to maintain a finely controlled 8-byte, 10-<br>byte, or 12-byte inter-packet gap (IPG) minimum average, or allow the user to drive<br>the IPG from the client interface                                                                                       |  |  |  |  |  |  |  |
|                                 | RX and TX preamble pass-through options for applications that require proprietary user management information transfer.                                                                                                                                                                                   |  |  |  |  |  |  |  |
|                                 | Optional TX MAC source address insertion.                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
|                                 | TX automatic frame padding to meet the 64-byte minimum Ethernet frame length on the Ethernet link. Optional per-packet disabling of this feature.                                                                                                                                                         |  |  |  |  |  |  |  |
|                                 | TX error insertion capability supports client invalidation of in-progress input to TX client interface.                                                                                                                                                                                                   |  |  |  |  |  |  |  |
| Frame Monitoring and Statistics | RX CRC checking and error reporting.                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|                                 | Optional RX strict Start Frame Delimiter (SFD) checking per IEEE specification.                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
|                                 | Optional RX strict preamble checking per IEEE specification.                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|                                 | RX malformed packet checking per IEEE specification.                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|                                 | Received control frame type indication.                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
|                                 | Statistics counters.                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|                                 | Snapshot feature for precisely timed capture of statistics counter values.                                                                                                                                                                                                                                |  |  |  |  |  |  |  |



| Features                      | Description                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|                               | Optional fault signaling: detects and reports local fault and generates remote fault, with support for unidirectional link fault as defined in <i>IEEE 802.3-2015 High Speed Ethernet Standard</i> Clause 66.                                                     |  |  |  |  |  |  |  |
| Flow Control                  | Optional <i>IEEE 802.3-2015 Ethernet Standard</i> Clause 31 Ethernet flow control operation using the pause registers or pause interface.                                                                                                                         |  |  |  |  |  |  |  |
|                               | Optional priority-based flow control that complies with the IEEE Standard 802.1Q-2014<br>—Amendment 17: Priority-based Flow Control.                                                                                                                              |  |  |  |  |  |  |  |
|                               | Pause frame filtering control.                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|                               | Software can dynamically toggle local TX MAC data flow to support selective input flow cut-off.                                                                                                                                                                   |  |  |  |  |  |  |  |
| Precision Time Protocol (PTP) | Optional support for the IEEE Standard 1588-2008 Precision Clock Synchronization Protocol (1588 PTP) (1588v2).                                                                                                                                                    |  |  |  |  |  |  |  |
|                               | 1-step (1588v1 and 1588v2) and 2-step TX timestamps.                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|                               | Support for PTP headers in a variety of frame formats, including Ethernet encapsulated, UDP in IPv4, and UDP in IPv6.                                                                                                                                             |  |  |  |  |  |  |  |
|                               | Support for Checksum Zero and Checksum extension byte calculations.                                                                                                                                                                                               |  |  |  |  |  |  |  |
|                               | Support for Correction field operations.                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|                               | Programmable extra latency.                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
| Debug and testability         | Optional serial PMA loopback (TX to RX) at the serial transceiver for self-diagnostic testing.                                                                                                                                                                    |  |  |  |  |  |  |  |
|                               | Optional parallel loopback (TX to RX) at the MAC or at the PCS for self-diagnostic testing.                                                                                                                                                                       |  |  |  |  |  |  |  |
|                               | Bit-interleaved parity error counters to monitor bit errors per PCS lane.                                                                                                                                                                                         |  |  |  |  |  |  |  |
|                               | RX PCS error block counters to monitor errors during and between frames.                                                                                                                                                                                          |  |  |  |  |  |  |  |
|                               | Malformed and dropped packet counters.                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|                               | High BER detection to monitor link bit error rates over all PCS lanes.                                                                                                                                                                                            |  |  |  |  |  |  |  |
|                               | Optional scrambled Idle test pattern generation and checking.                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|                               | Snapshot feature for precisely timed capture of statistics counter values.                                                                                                                                                                                        |  |  |  |  |  |  |  |
|                               | TX error insertion capability supports test and debug.                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|                               | Support for Ethernet Link Inspector (ELI) tool to monitor an Ethernet link.                                                                                                                                                                                       |  |  |  |  |  |  |  |
| User System Interface         | Avalon memory-mapped interface (Avalon-MM) to access the IP core control and status registers.                                                                                                                                                                    |  |  |  |  |  |  |  |
|                               | Avalon streaming interface (Avalon-ST) connects the MAC to client logic with the start of frame in the most significant byte (MSB) in MAC+PCS variations. Interface for 100G channel has 512 bits; the 10/25G channels use 64 bits when the MAC layer is enabled. |  |  |  |  |  |  |  |
|                               | MII data path interface connects the PCS to client logic in PCS-only variations.<br>Interface for 100G variants has 256 bits of data and 32 bits of control; interface for 10G/25G variants has 64 bits of data and 8 bits of control.                            |  |  |  |  |  |  |  |
|                               | Hardware and software reset control.                                                                                                                                                                                                                              |  |  |  |  |  |  |  |
|                               | Supports Synchronous Ethernet (SyncE) by providing a CDR recovered clock output signal to the device fabric.                                                                                                                                                      |  |  |  |  |  |  |  |
|                               | Supports external source clock for EMIB interface for applications that requires switching transceiver line rate.                                                                                                                                                 |  |  |  |  |  |  |  |





For a detailed specification of the Ethernet protocol refer to the *IEEE 802.3-2015 High Speed Ethernet Standard*.

#### **Related Information**

- IEEE Website
  - The IEEE 802.3-2015 High Speed Ethernet Standard is available on the IEEE website.
- 25G Ethernet Consortium

## 2.2. E-Tile Hard IP for Ethernet Intel FPGA IP Overview

The E-Tile Hard IP for Ethernet Intel FPGA IP block diagrams show the main blocks, and internal and external connections for each variant.

For these block diagrams, the reconfiguration and soft reset sequencer implement the reconfiguration interfaces and resets for the core, respectively. The auto-negotiation and link training (AN/LT) soft logic is only inserted when you select **Enable AN/LT**.

#### Figure 2. Single 10G/25G Channel



This variant supports only single channel 10G/25G Ethernet without RS-FEC and PTP features.





#### Figure 3. 1 to 4 10G/25G Channels with Optional RS-FEC

- This variant of the IP core includes up to four channels. Each channel has its own ٠ set of adapters, reconfiguration logic, AN/LT and reset sequencer logic.
- RS-FEC is optional for this variant. •





#### Figure 4. 100G Channel with Optional RS-FEC



- This variant of the IP core includes a single 100G channel that has its own set of adapters, reconfiguration logic, AN/LT and reset sequencer logic.
- The deskew logic corrects for possible skew over the EMIB interfaces between the main die and the E-tile.
- RS-FEC is optional for this variant. You can select RS-FEC(528,514) or RS-FEC(544,514) for this variant.





#### Figure 5. 100G Channel with 1 to 4 10G/25G Channels, RS-FEC, and Precision Time **Protocol (PTP)**



- This variant of the IP core includes a 100G channel or between 1 to 4 10G/25G • channels.
- Because the 100G channel uses the same transceivers as the 10G/25G channels, ٠ you cannot use the 100G channel when any of the 10G/25G channels are running. You can switch the reconfiguration interfaces on the core between channels at run time.
- For this variant, each channel has its own set of adapters, reconfiguration logic, . AN/LT and reset sequencer logic.





- The deskew logic corrects for possible skew over the EMIB interfaces between the main die and the E-tile. The EMIB deskew logic is always used for 100G channels. For 10G/25G channels, the deskew logic is used when you enable PTP, to ensure the PTP commands to each channel are synchronized to data. The deskew logic is not required for single 10G/25G channel.
- The PTP soft component logic block provides the user PTP interface, performs the soft logic operations required for the E-tile timestamp system, and interacts with the TOD module (the Time-of-Day clock) that you provide.
- RS-FEC and PTP are optional for this variant. This variant only supports RS-FEC(528,514) with PTP enabled.



#### Figure 6. Custom PCS with Optional RS-FEC

- This variant of IP core supports customizable line rate PCS up to four channels. Each channel has its own set of adapters, reconfiguration logic, and reset sequencer logic. This variant does not include an Ethernet MAC.
- This variant supports transceiver line rates ranges from 2.5 to 28 Gbps used in other protocols.
- RS-FEC is optional for this variant and it supports RS-FEC for Ethernet and Fibre Channel modes.



# 2.3. IP Core Device Family and Speed Grade Support

The following sections list the device family and device speed grade support offered by the E-Tile Hard IP for Ethernet Intel FPGA IP:

E-Tile Hard IP for Ethernet Intel FPGA IP Device Family Support on page 16 E-Tile Hard IP for Ethernet Intel FPGA IP Device Speed Grade Support on page 16

### 2.3.1. E-Tile Hard IP for Ethernet Intel FPGA IP Device Family Support

#### Table 5. **Intel FPGA IP Core Device Support Levels**

| Device Support<br>Level | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Advance                 | The IP core is available for simulation and compilation for this device family. Timing models include initial engineering estimates of delays based on early post-layout information. The timing models are subject to change as silicon testing improves the correlation between the actual silicon and the timing models. You can use this IP core for system architecture and resource utilization studies, simulation, pinout, system latency assessments, basic timing assessments (pipeline budgeting), and I/O transfer strategy (datapath width, burst depth, I/O standards tradeoffs). |
| Preliminary             | The IP core is verified with preliminary timing models for this device family. The IP core meets all functional requirements, but might still be undergoing timing analysis for the device family. It can be used in production designs with caution.                                                                                                                                                                                                                                                                                                                                           |
| Final                   | The IP core is verified with final timing models for this device family. The IP core meets all functional and timing requirements for the device family and can be used in production designs.                                                                                                                                                                                                                                                                                                                                                                                                  |

#### Table 6. E-Tile Hard IP for Ethernet Intel FPGA IP Device Family Support

Shows the level of support offered by the E-Tile Hard IP for Ethernet Intel FPGA IP for each Intel FPGA device family.

| Device Family    | Support                            |
|------------------|------------------------------------|
| Intel Stratix 10 | Preliminary<br>E-tile devices only |
| Intel Agilex     | Advance                            |

#### **Related Information**

**Timing and Power Models** 

Reports the default device support levels in the current version of the Intel Quartus Prime Pro Edition software.

### 2.3.2. E-Tile Hard IP for Ethernet Intel FPGA IP Device Speed Grade Support

The E-Tile Hard IP for Ethernet Intel FPGA IP supports the following speed grades for Intel Stratix 10 and Intel Agilex E-tile devices:

- Transceiver speed grade: -1, -2 or -3<sup>(1)</sup> ٠
- Core speed grade: -1 or -2

For information about the applicable device speed grades based on the target data rates, refer to the Device Data Sheet.



<sup>&</sup>lt;sup>(1)</sup> This speed grade only supports the 10G data rate.



#### **Related Information**

- Intel Stratix 10 Device Datasheet
- Intel Agilex Device Data Sheet

# **2.4. IP Core Verification**

To ensure functional correctness of the E-Tile Hard IP for Ethernet Intel FPGA IP, Intel performs extensive validation through both simulation and hardware testing. Before releasing a version of the E-Tile Hard IP for Ethernet Intel FPGA IP, Intel runs comprehensive regression tests in the current version of the Intel Quartus Prime Pro Edition software.

Intel verifies that the current version of the Intel Quartus Prime Pro Edition software compiles the previous version of each IP core. Intel does not verify compilation with IP core versions older than the previous release.

### 2.4.1. Simulation Environment

Intel performs the following tests on the E-Tile Hard IP for Ethernet Intel FPGA IP in the simulation environment using internal and third party standard bus functional models (BFM):

- · Constrained random tests that cover randomized frame size and contents
- Randomized error injection tests that inject Frame Check Sequence (FCS) field errors, runt packets, and corrupt control characters, and then check for the proper response from the IP core
- Assertion based tests to confirm proper behavior of the IP core with respect to the specification
- Extensive coverage of our runtime configuration space and proper behavior in all possible modes of operation

### 2.4.2. Compilation Checking

Intel performs compilation testing on an extensive set of E-Tile Hard IP for Ethernet Intel FPGA IP variations and designs that target different devices, to ensure the Intel Quartus Prime Pro Edition software places and routes the IP core ports correctly.

### 2.4.3. Hardware Testing

Intel performs hardware testing of the key functions of the E-Tile Hard IP for Ethernet Intel FPGA IP on available FPGA devices using standard 10/25, and 100 Gbps Ethernet network test equipment and optical modules. The Intel hardware tests of the E-Tile Hard IP for Ethernet Intel FPGA IP also ensure reliable solution coverage for hardware related areas such as performance, link synchronization, and reset recovery.

### 2.5. Resource Utilization

The resources for the E-Tile Hard IP for Ethernet Intel FPGA IP were obtained from the Intel Quartus Prime Pro Edition software version 19.1





| Table 7. | Resource   | Utilization f    | or Selected | Variations          |
|----------|------------|------------------|-------------|---------------------|
|          | itebouitee | o the deliver is |             | <b>v</b> ariaciónio |

| Ethernet Rate | IP Core Variation                                    | ALMs   | Dedicated Logic<br>Registers | Memory 20K |  |
|---------------|------------------------------------------------------|--------|------------------------------|------------|--|
| 10G           | MAC+PCS                                              | 2,100  | 2,900                        | 6          |  |
|               | MAC+PCS with IEEE<br>1588/PTP                        | 5,500  | 11,700                       | 11         |  |
|               | PCS Only                                             | 1,918  | 2,484                        | 4          |  |
|               | OTN                                                  | 1,936  | 2,505                        | 4          |  |
|               | FlexE                                                | 1,950  | 5,539                        | 4          |  |
| 25G           | MAC+PCS                                              | 2,100  | 2,900                        | 6          |  |
|               | MAC+PCS with RS-<br>FEC                              | 2,400  | 3,400                        | 6          |  |
|               | MAC+PCS IEEE<br>1588/PTP                             | 5,500  | 11,700                       | 11         |  |
|               | MAC+PCS with RS-<br>FEC and IEEE<br>1588/PTP         | 5,500  | 11,700                       | 11         |  |
|               | PCS Only                                             | 1,929  | 2,486                        | 4          |  |
|               | PCS with RS-FEC                                      | 2,308  | 3,073                        | 4          |  |
|               | OTN                                                  | 1,922  | 2,537                        | 4          |  |
|               | OTN with RS-FEC                                      | 2,292  | 3,064                        | 4          |  |
|               | FlexE                                                | 1,915  | 2,475                        | 4          |  |
|               | FlexE with RS-FEC                                    | 2,281  | 3,057                        | 4          |  |
| 100G          | MAC+PCS                                              | 5,777  | 8,443                        | 6          |  |
|               | MAC + 1588PTP +<br>PCS                               | 14,966 | 28,687                       | 9          |  |
|               | MAC+PCS with<br>(528,514)RS-FEC                      | 6,016  | 8,739                        | 6          |  |
|               | MAC+PCS with<br>(528,514)RS-FEC and<br>IEEE 1588/PTP | 9,147  | 14,234                       | 21         |  |
|               | MAC+PCS with<br>(544,514) RS-FEC                     | 6,029  | 8,827                        | 6          |  |
|               | PCS Only                                             | 2,412  | 2,913                        | 4          |  |
|               | PCS with (528,514)<br>RS-FEC                         | 2,668  | 3,217                        | 4          |  |
|               | PCS with (544,514)<br>RS-FEC                         | 2,682  | 3,251                        | 4          |  |
|               | OTN                                                  | 2,401  | 2,905                        | 4          |  |
|               | OTN with (528,514)<br>RS-FEC                         | 2,647  | 3,178                        | 4          |  |
|               | OTN with (544,514)<br>RS-FEC                         | 2,648  | 3,200                        | 4          |  |
|               | FlexE                                                | 2,400  | 2,929                        | 4          |  |





| Ethernet Rate | IP Core Variation              | ALMs   | Dedicated Logic<br>Registers | Memory 20K |
|---------------|--------------------------------|--------|------------------------------|------------|
|               | FlexE with<br>(528,514)RS-FEC  | 2,645  | 3,178                        | 4          |
|               | FlexE with (544,514)<br>RS-FEC | 2,649  | 3,232                        | 4          |
|               | KR with AN/LT                  | 10,362 | 15,843                       | 28         |
|               | KR FEC with AN/LT              | 10,386 | 15,542                       | 28         |

*Note:* The E-Tile Hard IP for Ethernet Intel FPGA IP provides preliminary support for the OTN feature. For further inquiries, contact your nearest Intel sales representative or file an Intel Premier Support (IPS) case at https://www.intel.com/content/www/us/en/my-intel/fpga-sign-in.html.

#### Table 8. Resource Utilization for Custom PCS Variations

| Data Rate | Variant         | ALMs | Dedicated Logic<br>Registers | Memory 20K |
|-----------|-----------------|------|------------------------------|------------|
| 10G       | RS-FEC disabled | 853  | 1,228                        | 0          |
| 24G       | RS-FEC enabled  | 856  | 1,114                        | 0          |
|           | RS-FEC disabled | 824  | 1,168                        | 0          |

## **2.6. Release Information**

IP versions are the same as the Intel Quartus Prime Design Suite software versions up to v19.1. From Intel Quartus Prime Design Suite software version 19.2 or later, IP cores have a new IP versioning scheme. If an IP core version is not listed, the user guide for the previous IP core version applies.

The IP versioning scheme (X.Y.Z) number changes from one software version to another. A change in:

- X indicates a major revision of the IP. If you update your Intel Quartus Prime software, you must regenerate the IP.
- Y indicates the IP includes new features. Regenerate your IP to include these new features.
- Z indicates the IP includes minor changes. Regenerate your IP to include these changes.

#### Table 9. E-Tile Hard IP for Ethernet Intel FPGA IP Core Release Information

| Item                        | Description     |
|-----------------------------|-----------------|
| IP Version                  | 19.4.0          |
| Intel Quartus Prime Version | 19.4            |
| Release Date                | 2019.12.16      |
| Ordering Code               | IP-ETH-ETILEHIP |







#### Table 10. E-Tile Ethernet IP for Intel Agilex FPGA Core Release Information

| Item                        | Description |
|-----------------------------|-------------|
| IP Version                  | 19.4.0      |
| Intel Quartus Prime Version | 19.4        |
| Release Date                | 2019.12.16  |

# 2.7. Getting Started

The following sections explain how to install, parameterize, simulate, and initialize the E-Tile Hard IP for Ethernet Intel FPGA IP:

Installing and Licensing Intel FPGA IP Cores on page 20

Specifying the IP Core Parameters and Options on page 23

Generated File Structure on page 23

Integrating Your IP Core in Your Design on page 26

IP Core Testbenches on page 50

Compiling the Full Design on page 50

#### **Related Information**

- Introduction to Intel FPGA IP Cores Provides general information about all Intel FPGA IP cores, including parameterizing, generating, upgrading, and simulating IP cores.
- Creating Version-Independent IP and Osys Simulation Scripts Create simulation scripts that do not require manual updates for software or IP version upgrades.
- **Project Management Best Practices** Guidelines for efficient management and portability of your project and IP files.

### 2.7.1. Installing and Licensing Intel FPGA IP Cores

The Intel Quartus Prime Pro Edition software installation includes the Intel FPGA IP library. This library provides many useful IP cores for your production use without the need for an additional license. Some Intel FPGA IP cores require purchase of a separate license for production use. The Intel FPGA IP Evaluation Mode allows you to evaluate these licensed Intel FPGA IP cores in simulation and hardware, before deciding to purchase a full production IP core license. You only need to purchase a full production license for licensed Intel IP cores after you complete hardware testing and are ready to use the IP in production.

The Intel Quartus Prime software installs IP cores in the following locations by default:

#### Figure 7. **IP Core Installation Path**

#### intelFPGA( pro)

Guartus - Contains the Intel Ouartus Prime software

**ip** - Contains the Intel FPGA IP library and third-party IP cores

altera - Contains the Intel FPGA IP library source code

</p





#### Table 11.IP Core Installation Locations

| Location                                                    | Software                        | Platform |
|-------------------------------------------------------------|---------------------------------|----------|
| <pre><drive>:\intelFPGA_pro\quartus\ip\altera</drive></pre> | Intel Quartus Prime Pro Edition | Windows* |
| <home directory="">:/intelFPGA_pro/quartus/ip/altera</home> | Intel Quartus Prime Pro Edition | Linux*   |

### 2.7.1.1. Intel FPGA IP Evaluation Mode

The free Intel FPGA IP Evaluation Mode allows you to evaluate licensed Intel FPGA IP cores in simulation and hardware before purchase. Intel FPGA IP Evaluation Mode supports the following evaluations without additional license:

- Simulate the behavior of a licensed Intel FPGA IP core in your system.
- Verify the functionality, size, and speed of the IP core quickly and easily.
- Generate time-limited device programming files for designs that include IP cores.
- Program a device with your IP core and verify your design in hardware.

Intel FPGA IP Evaluation Mode supports the following operation modes:

- **Tethered**—Allows running the design containing the licensed Intel FPGA IP indefinitely with a connection between your board and the host computer. Tethered mode requires a serial joint test action group (JTAG) cable connected between the JTAG port on your board and the host computer, which is running the Intel Quartus Prime Programmer for the duration of the hardware evaluation period. The Programmer only requires a minimum installation of the Intel Quartus Prime software, and requires no Intel Quartus Prime license. The host computer controls the evaluation time by sending a periodic signal to the device via the JTAG port. If all licensed IP cores in the design support tethered mode, the evaluation time runs until any IP core evaluation expires. If all of the IP cores support unlimited evaluation time, the device does not time-out.
- **Untethered**—Allows running the design containing the licensed IP for a limited time. The IP core reverts to untethered mode if the device disconnects from the host computer running the Intel Quartus Prime software. The IP core also reverts to untethered mode if any other licensed IP core in the design does not support tethered mode.

When the evaluation time expires for any licensed Intel FPGA IP in the design, the design stops functioning. All IP cores that use the Intel FPGA IP Evaluation Mode time out simultaneously when any IP core in the design times out. When the evaluation time expires, you must reprogram the FPGA device before continuing hardware verification. To extend use of the IP core for production, purchase a full production license for the IP core.

You must purchase the license and generate a full production license key before you can generate an unrestricted device programming file. During Intel FPGA IP Evaluation Mode, the Compiler only generates a time-limited device programming file (*<project name>\_\_time\_\_limited.sof*) that expires at the time limit.



#### Figure 8. **Intel FPGA IP Evaluation Mode Flow**



Note: Refer to each IP core's user guide for parameterization steps and implementation details.

> Intel licenses IP cores on a per-seat, perpetual basis. The license fee includes firstyear maintenance and support. You must renew the maintenance contract to receive updates, bug fixes, and technical support beyond the first year. You must purchase a full production license for Intel FPGA IP cores that require a production license, before generating programming files that you may use for an unlimited time. During Intel FPGA IP Evaluation Mode, the Compiler only generates a time-limited device programming file (<project name>\_time\_limited.sof) that expires at the time limit. To obtain your production license keys, visit the Self-Service Licensing Center.

> The Intel FPGA Software License Agreements govern the installation and use of licensed IP cores, the Intel Quartus Prime design software, and all unlicensed IP cores.





#### **Related Information**

- Intel Quartus Prime Licensing Site
- Introduction to Intel FPGA Software Installation and Licensing

### 2.7.2. Specifying the IP Core Parameters and Options

The E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor allows you to quickly configure your custom IP variation. Use the following steps to specify IP core options and parameters in the Intel Quartus Prime Pro Edition software.

- 1. If you do not already have an Intel Quartus Prime Pro Edition project in which to integrate your E-Tile Hard IP for Ethernet Intel FPGA IP, you must create one.
  - a. In the Intel Quartus Prime Pro Edition, click File ➤ New Project Wizard to create a new Quartus Prime project, or File ➤ Open Project to open an existing Quartus Prime project. The wizard prompts you to specify a device.
  - b. Specify the device family and select a production E-tile device that meets the speed grade requirements for the IP core.
  - c. Click Finish.
- 2. In the IP Catalog, locate and select **E-tile Hard IP for Ethernet Intel FPGA IP**. The **New IP Variation** window appears.
- 3. Specify a top-level name for your new custom IP variation. The parameter editor saves the IP variation settings in a file named <*your\_ip*>.ip.
- 4. Click **OK**. The parameter editor appears.
- 5. Specify the parameters for your IP core variation. Refer to Parameter Editor Parameters on page 51 for information about specific IP core parameters.
- 6. Optionally, to generate a simulation testbench or compilation and hardware design example, follow the instructions in the *E-tile Hard IP for Ethernet Design Example User Guide*.
- 7. Click Generate HDL. The Generation dialog box appears.
- 8. Specify output file generation options, and then click **Generate**. The IP variation files generate according to your specifications.
- Click Close. The parameter editor adds the top-level .ip file to the current project automatically. If you are prompted to manually add the .ip file to the project, click Project ➤ Add/Remove Files in Project to add the file.
- 10. After generating and instantiating your IP variation, make appropriate pin assignments to connect ports and set any appropriate per-instance RTL parameters.

#### **Related Information**

- E-Tile Hard IP for Ethernet Intel Stratix 10 FPGA IP Design Example User Guide
- E-Tile Hard IP for Ethernet Intel Agilex FPGA IP Design Example User Guide

### 2.7.3. Generated File Structure

The Intel Quartus Prime Pro Edition software generates the following IP core output file structure.





For information about the file structure of the design example, refer to the *E*-*Tile* Hard *IP* for Ethernet Intel FPGA IP Design Example User Guide.

### Figure 9. E-Tile Hard IP for Ethernet Intel FPGA IP Generated Files



#### Table 12. IP Core Generated Files

| File Name                                     | Description                                                                                                                                                                          |  |  |  |  |  |  |
|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| <your_ip>.ip</your_ip>                        | The Platform Designer system or top-level IP variation file. < your_ip> is the name that you give your IP variation.                                                                 |  |  |  |  |  |  |
| <your_ip>.cmp</your_ip>                       | The VHDL Component Declaration ( $. cmp$ ) file is a text file that contains local generic and port definitions that you can use in VHDL design files.                               |  |  |  |  |  |  |
| <your_ip>.html</your_ip>                      | A report that contains connection information, a memory map showing the<br>address of each slave with respect to each master to which it is connected, and<br>parameter assignments. |  |  |  |  |  |  |
| <pre><your_ip>_generation.rpt</your_ip></pre> | IP or Platform Designer generation log file. A summary of the messages during IP generation.                                                                                         |  |  |  |  |  |  |
| <your_ip>.qgsimc</your_ip>                    | Lists simulation parameters to support incremental regeneration.                                                                                                                     |  |  |  |  |  |  |
| <your_ip>.qgsynthc</your_ip>                  | Lists synthesis parameters to support incremental regeneration.                                                                                                                      |  |  |  |  |  |  |
|                                               | continued                                                                                                                                                                            |  |  |  |  |  |  |



#### 2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



| File Name                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <your_ip>.qip</your_ip>                            | Contains all the required information about the IP component to integrate and compile the IP component in the Intel Quartus Prime software.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <your_ip>.sopcinfo</your_ip>                       | Describes the connections and IP component parameterizations in your<br>Platform Designer system. You can parse its contents to get requirements<br>when you develop software drivers for IP components.<br>Downstream tools such as the Nios <sup>®</sup> II tool chain use this file. The .sopcinfo<br>file and the system.h file generated for the Nios II tool chain include address<br>map information for each slave relative to each master that accesses the slave.<br>Different masters may have a different address map to access a particular<br>slave component. |
| <your_ip>.csv</your_ip>                            | Contains information about the upgrade status of the IP component.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <your_ip>.spd</your_ip>                            | Required input file for ip-make-simscript to generate simulation scripts for supported simulators. The .spd file contains a list of files generated for simulation, along with information about memories that you can initialize.                                                                                                                                                                                                                                                                                                                                           |
| <your_ip>_bb.v</your_ip>                           | You can use the Verilog black-box $(\_bb.v)$ file as an empty module declaration for use as a black box.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <pre><your_ip>_inst.v or _inst.vhd</your_ip></pre> | HDL example instantiation template. You can copy and paste the contents of this file into your HDL file to instantiate the IP variation.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <your_ip>.regmap</your_ip>                         | If IP contains register information, .regmap file generates. The .regmap file describes the register map information of master and slave interfaces. This file complements the .sopcinfo file by providing more detailed register information about the system. This enables register display views and user customizable statistics in the System Console.                                                                                                                                                                                                                  |
| <your_ip>.svd</your_ip>                            | Allows hard processor system (HPS) System Debug tools to view the register<br>maps of peripherals connected to HPS in a Platform Designer system.<br>During synthesis, the .svd files for slave interfaces visible to System Console<br>masters are stored in the .sof file in the debug section. System Console reads<br>this section, which Platform Designer can query for register map information.<br>For system slaves, Platform Designer can access the registers by name.                                                                                            |
| <your_ip>.v or <your_ip>.vhd</your_ip></your_ip>   | HDL files that instantiate each submodule or child IP core for synthesis or simulation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| mentor/                                            | Contains a ModelSim* script ${\tt msim\_setup.tcl}$ to set up and run a simulation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| synopsys/vcs/<br>synopsys/vcsmx/                   | Contains a shell script vcs_setup.sh to set up and run a VCS* simulation.<br>Contains a shell script vcsmx_setup.sh and synopsys_ sim.setup file to<br>set up and run a VCS MX* simulation.                                                                                                                                                                                                                                                                                                                                                                                  |
| cadence/                                           | Contains a shell script $\tt ncsim\_setup.sh$ and other setup files to set up and run an NCSIM* simulation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| submodules/                                        | Contains HDL files for the IP core submodules.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <child cores="" ip="">/</child>                    | For each generated child IP core directory, Platform Designer generates synth/ andsim/ sub-directories.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### **Related Information**

- E-Tile Hard IP for Ethernet Intel Stratix 10 FPGA IP Design Example User Guide
- E-Tile Hard IP for Ethernet Intel Agilex FPGA IP Design Example User Guide





# 2.7.4. Integrating Your IP Core in Your Design

When you integrate your IP core instance in your design, you must pay attention to the following items:

Channel Placement on page 26

Pin Assignments on page 48

**Clock Requirements on page 49** 

External Time-of-Day Module for Variations with 1588 PTP Feature on page 49

#### 2.7.4.1. Channel Placement

Depending on the number of bonded PMA channels, the Channel Placement tool supports two E-tile variants, 24-channel placement and 16-channel placement variant.

In Intel Stratix 10 devices, each E-tile provides Hard IP for up to 4 100G Ethernet channels, and up to 24 10G/25G Ethernet channels. In Intel Agilex devices, each E-tile provides Hard IP for up to 4 100G Ethernet channels, and either up to 24 10G/25G Ethernet channels in 24-channel bonding configuration, or up to 16 10G/24G Ethernet channels in 16-channel bonding configuration.

#### Figure 10. **Ethernet Hard IP Overview**

The figure shows an example placement of the channels using the E-tile Channel Placement Tool.



RS-FEC is configurable for single-lane 10G/25G and multi-lane 100G Ethernet interfaces.







#### Figure 11. Ethernet Cores Position on an E-tile Device

You can place the core by constraining a serial pin from the core to one of the transceiver pins on the selected E-tile device. For example, if you constrain the serial pins from a Variant A core to transceiver pin 10, the core will be placed in Variant A position 10.

#### **Related Information**

- E-Tile Transceiver PHY User Guide For information about constraints on transceiver configuration for Hard IP for Ethernet in E-Tile devices.
- E-Tile Channel Placement Tool

#### 2.7.4.1.1. Guidelines and Restrictions for 24-bonded Channels Variant

The E-tile transceiver requires the channel placement to be contiguous when RS-FEC is enabled. The following are the allowed channel placements for different number of channels.

#### Single Channel 10GE/25GE with RS-FEC Variant

- Select Core Variant: 1 to 4 10GE/25GE with optional RSFEC
- Number of Channels of 10GE/25GE: Single Channel
- Enable RSFEC: Selected
- First RSFEC Lane: first\_lane0(channel\_0), first\_lane1(channel\_5), first\_lane2(channel\_10), or first\_lane3(channel\_15)
- The FEC mode is set to fractured mode.





|             | Intel <sup>®</sup> Stratix 10 <sup>®</sup> E-tile Floor Plan |               |             |                   | Channel Settings |       |        |             |          |
|-------------|--------------------------------------------------------------|---------------|-------------|-------------------|------------------|-------|--------|-------------|----------|
| XCVR<br>PMA | RSFEC                                                        | EHIP          | _TOP        | Core<br>Interface | Protocol         | Level | Rate   | FEC<br>mode | RSFEC    |
| Channel_23  |                                                              |               | EHIPLANE_23 | Interface_23      | None             | None  | None   |             | Off      |
| Channel_22  | RESPEC 5                                                     |               | EHIPLANE_22 | Interface_22      | None             | None  | None   | Off         | (Dff     |
| Channel_21  | neenee_v                                                     | EHIP CORE 3   | EHIPLANE_21 | Interface_21      | None             | None  | None   | ] "         | Off      |
| Channel_20  |                                                              | Enir_Conc_3   | EHIPLANE_20 | Interface_20      | None             | None  | None   | - Off       | Off      |
| Channel_19  |                                                              |               | EHIPLANE_19 | Interface_19      | None             | None  | None   |             | Off      |
| Channel_18  | RESPEC 4                                                     |               | EHIPLANE_18 | Interface_18      | None             | Norie | Norse  |             | Off      |
| Channel_17  | INE OF EIL_4                                                 | EHIP_CORE_2   | EHIPLANE_17 | Interface_17      | None             | None  | None   |             | Off      |
| Channel_16  |                                                              |               | EHIPLANE_16 | Interface_15      | Norie            | None  | None   | 1           | Off      |
| Channel_15  |                                                              |               | EHIPLANE_15 | Interface_15      | Ethernet         | NRZ   | 25.78G |             | 528, 514 |
| Channel_14  | RESFEC 3                                                     |               | EHIPLANE_14 | Interface_14      | None             | None  | None   | - Fractured | Off      |
| Channel_13  | neoreu_o                                                     |               | EHIPLANE_13 | Interface_13      | None             | None  | Norie  |             | Off      |
| Channel_12  |                                                              |               | EHIPLANE_12 | Interface_12      | None             | None  | None   |             | Off      |
| Channel_11  |                                                              |               | EHIPLANE_11 | Interface_11      | None             | None  | None   | - Fractured | Off      |
| Channel_10  | RESPEC 2                                                     |               | EHIPLANE_10 | Interface_10      | Ethernet         | NRZ   | 25.78G |             | 528, 514 |
| Channel_9   | HEBPEL_2                                                     | EHP CORE 1    | EHIPLANE_9  | Interface_9       | None             | None  | None   |             | Off      |
| Channel_8   |                                                              | Enim_CONE_1   | EHIPLANE_8  | Interface_8       | Norse            | None  | None   | 1           | Off      |
| Channel_7   |                                                              |               | EHIPLANE_7  | Interface_7       | None             | None  | None   |             | Off      |
| Channel_6   | -                                                            |               | EHIPLANE_6  | Interface_6       | None             | None  | None   | 1           | Off      |
| Channel_5   | RESFEC_I                                                     |               | EHIPLANE_5  | Interface_5       | Ethernet         | NRZ   | 25.78G | - Fractured | 528, 514 |
| Channel_4   |                                                              |               | EHIPLANE_4  | Interface_4       | None             | None  | None   | 1           | Off      |
| Channel_3   |                                                              | multi ecentra | EHIPLANE_3  | Interface_3       | None             | None  | None   |             | Dff      |
| Channel_2   |                                                              | H             | EHIPLANE_2  | Interface_2       | None             | None  | None   | 1           | Off      |
| Channel_1   | RESFEC_0                                                     |               | EHIPLANE_1  | Interface_1       | None             | Norie | Norie  | - Fractured | Off      |
| Channel_0   |                                                              |               | EHIPLANE_0  | Interface_0       | Ethernet         | NRZ   | 25.78G | 1           | 528, 514 |

### Two Channels 10GE/25GE with RS-FEC Variant

- Select Core Variant: 1 to 4 10GE/25GE with optional RSFEC
- Number of Channels of 10GE/25GE: 2 Channels ٠
- Enable RSFEC: Selected ٠
- First RSFEC Lane: first\_lane0(channel\_0), first\_lane1(channel\_5), or ٠ first\_lane2(channel\_10)
- The FEC mode is set to fractured mode. ٠





|                   | Intel® Stratix 10® E-tile Floor Plan |                            |             |              |          | Chan     | nel Sett | ings      |             |       |
|-------------------|--------------------------------------|----------------------------|-------------|--------------|----------|----------|----------|-----------|-------------|-------|
| XCVR<br>PMA RSFEC |                                      | EHIP_TOP Core<br>Interface |             |              |          | Protocol | Level    | Rate      | FEC<br>mode | RSFEC |
| Channel_23        |                                      | Interface_23               | None        |              |          | None     | None     |           | Off         |       |
| Channel_22        | RESFEC_5                             |                            | EHIPLANE_22 | Interface_22 | None     | None     | None     | Off       | 0ff         |       |
| Channel_21        | nconcu_o                             | EHIP_CORE_3                | EHIPLANE_21 | Interface_21 | None     | None     | None     |           | Off         |       |
| Channel_20        |                                      | EULTERNE                   | EHIPLANE_20 | Interface_20 | None     | None     | None     |           | Off         |       |
| Channel_19        |                                      | 1                          | EHIPLANE_19 | Interface_19 | None     | None     | None     |           | Off         |       |
| Channel_18        | RESFEC_4                             |                            | EHIPLANE_18 | Interface_18 | None     | None     | None     |           | Qff         |       |
| Channel_17        | HEOREU_4                             |                            | EHIPLANE_17 | Interface_17 | None     | None     | None     |           | Off         |       |
| Channel_16        |                                      |                            | EHIPLANE_16 | Interface_16 | None     | None     | Nona     | 1         | Off         |       |
| Channel_15        |                                      | EHIP CORE 2                | EHIPLANE_15 | Interface_15 | None     | None     | None     | - Off     | CIFF        |       |
| Channel_14        | RESPEC 3                             | ENIF_CURE_2                | EHIPLANE_14 | Interface_14 | None     | None     | None     |           | 口仔          |       |
| Channel_13        | neonet_s                             |                            | EHIPLANE_13 | Interface_13 | None     | None     | None     |           | CIFF        |       |
| Channel_12        |                                      |                            | EHIPLANE_12 | Interface_12 | None     | None     | None     |           | Off         |       |
| Channel_11        |                                      |                            | EHIPLANE_11 | Interface_11 | Ethernet | NRZ      | 25.78G   | -         | 528, 514    |       |
| Channel_10        | RESFEC 2                             |                            | EHIPLANE_10 | Interface_10 | Ethernet | NRZ      | 25.78G   |           | 528, 514    |       |
| Channel_9         | neoreu_e                             |                            | EHIPLANE_9  | Interface_9  | None     | None     | None     |           | Off         |       |
| Channel_8         |                                      | EHIP_CORE_1                | EHIPLANE_8  | Interface_8  | None     | None     | None     | 1         | Off         |       |
| Channel_7         |                                      |                            | EHIPLANE_7  | Interface_7  | None     | None     | None     |           | Off         |       |
| Channel_6         | RESPEC 1                             |                            | EHIPLANE_6  | Interface_6  | Ethernet | NRZ      | 25.78G   | 1         | 528, 514    |       |
| Channel_5         | MESPEL_I                             |                            | EHIPLANE_5  | Interface_5  | Ethernet | NRZ      | 25.78G   | Fractured | 528, 514    |       |
| Channel_4         |                                      |                            | EHIPLANE_4  | Interface_4  | None     | None     | None     | 1         | Off         |       |
| Channel_3         |                                      | C) 40 0000                 | EHIPLANE_3  | Interface_3  | None     | None     | None     |           | Off         |       |
| Channel_2         |                                      | EHIP_CORE_0                | EHIPLANE_2  | Interface_2  | None     | None     | None     | 1         | Óff         |       |
| Channel_1         | RESPEC_0                             |                            | EHIPLANE_1  | Interface_1  | Ethernet | NRZ      | 25.78G   | Fractured | 528, 514    |       |
| Channel_0         |                                      |                            | EHIPLANE_0  | Interface_0  | Ethernet | NRZ      | 25.78G   | 1         | 528, 514    |       |

### Three Channels 10GE/25GE with RS-FEC

- Select Core Variant: 1 to 4 10GE/25GE with optional RSFEC
- Number of Channels of 10GE/25GE: 3 Channels
- Enable RSFEC: Selected
- First RSFEC Lane: first\_lane0(channel\_0) or first\_lane1(channel\_5)
- The FEC mode is set to fractured mode.





|             | Intel® Stratix 10® E-tile Floor Plan |                     |             |                            |          | Channel Settings |        |             |          |  |
|-------------|--------------------------------------|---------------------|-------------|----------------------------|----------|------------------|--------|-------------|----------|--|
| XCVR<br>PMA | RSFEC                                | EHIP_TOP            |             | EHIP_TOP Core<br>Interface |          | Level            | Rate   | FEC<br>mode | RSFEC    |  |
| Channel_23  | EHIPLANE_2                           |                     | EHIPLANE_23 | Interface_23               | None     | None             | None   |             | Off      |  |
| Channel_22  | RESPEC 5                             |                     | EHIPLANE_22 | Interface_22               | None     | None             | None   | Off         | Off      |  |
| Channel_21  | nconce_v                             | EHP.CORE:3          | EHIPLANE_21 | Interface_2                | None     | None             | None   |             | Off      |  |
| Channel_20  |                                      | (chin_conc_a        | EHIPLANE_20 | Interface_20               | None     | None             | None   | ]           | Off      |  |
| Channel_19  |                                      |                     | EHIPLANE_19 | Interface_19               | None     | None             | None   |             | Dff      |  |
| Channel_18  | RESPEC 4                             |                     | EHIPLANE_18 | Interface_18               | None     | None             | None   | Off         | Off      |  |
| Channel_17  | DESELU_*                             |                     | EHIPLANE_17 | Interface_17               | None     | None             | None   |             | Off      |  |
| Channel_16  |                                      |                     | EHIPLANE_16 | Interface_16               | None     | None             | None   | 1           | Dff      |  |
| Channel_15  |                                      | EHIP CORE 2         | EHIPLANE_15 | Interface_15               | None     | None             | None   |             | CIFF     |  |
| Channel_14  | RESPEC 3                             | Carrier Contraction | EHIPLANE_14 | Interface_14               | None     | None             | None   | Off         | Off      |  |
| Channel_13  | neoree_o                             |                     | EHIPLANE_13 | Interface_13               | None     | None             | None   |             | Dff.     |  |
| Channel_12  |                                      |                     | EHIPLANE_12 | Interface_12               | None     | None             | None   |             | Off      |  |
| Channel_11  |                                      |                     | EHIPLANE_1  | Interface_11               | None     | None             | None   | - Off       | Off      |  |
| Channel_10  | RESPEC 2                             |                     | EHIPLANE_10 | Interface_10               | None     | None             | None   |             | Off      |  |
| Channel_9   | INCOLC_4                             | EHIP CORE 1         | EHIPLANE_9  | Interface_9                | None     | None             | None   |             | Off      |  |
| Channel_8   |                                      | EDIC_CODE_1         | EHIPLANE_8  | Interface_8                | None     | None             | None   |             | 10ff     |  |
| Channel_7   |                                      |                     | EHIPLANE_7  | Interface_7                | Ethernet | NRZ              | 25.78G |             | 528, 514 |  |
| Channel_6   | RESPEC 1                             |                     | EHIPLANE_6  | Interface_6                | Ethernet | NRZ              | 25.78G | Fractured   | 528, 514 |  |
| Channel_5   | ncorec_i                             |                     | EHIPLANE_5  | Interface_5                | Ethernet | NRZ              | 25.78G | Fractured   | 528, 514 |  |
| Channel_4   |                                      |                     | EHIPLANE_4  | Interface_4                | None     | None             | None   |             | Off      |  |
| Channel_3   |                                      | EHIP CORE 0         | EHIPLANE_3  | Interface_3                | None     | None             | None   |             | CIFF     |  |
| Channel_2   | RESPEC 0                             | EHIP_CUME_U         | EHIPLANE_2  | Interface_2                | Ethernet | NRZ              | 25.78G | 1           | 528, 514 |  |
| Channel_1   | ncorcu_U                             |                     | EHIPLANE_1  | Interface_1                | Ethernet | NRZ              | 25.78G | Fractured   | 528, 514 |  |
| Channel_0   |                                      |                     | EHIPLANE_0  | Interface_0                | Ethernet | NRZ              | 25.78G | 1           | 528, 514 |  |

#### Four Channels 10GE/25GE with RS-FEC Variant

- Select Core Variant: 1 to 4 10GE/25GE with optional RSFEC ٠
- Number of Channels of 10GE/25GE: 4 Channels •
- Enable RSFEC: Selected ٠
- First RSFEC Lane: first\_lane0(channel\_0) ٠
- The FEC mode is set to fractured mode. •





|             | Intel <sup>®</sup> Stra                      | atix 10° E-tile | Floor Plan  |                   |          | Chan  | nel Sett | ings        |          |
|-------------|----------------------------------------------|-----------------|-------------|-------------------|----------|-------|----------|-------------|----------|
| XCVR<br>PMA | RSFEC                                        | EHIP_           | TOP         | Core<br>Interface | Protocol | Level | Rate     | FEC<br>mode | RSFEC    |
| Channel_23  |                                              |                 | EHIPLANE_23 | Interface_23      | None     | None  | None     |             | Off      |
| Channel_22  | RESPEC 5                                     |                 | EHIPLANE_22 | Interface_22      | None     | None  | None     | - Off       | Off      |
| Channel_21  | HEOREU_0                                     |                 | EHIPLANE_21 | Interface_21      | None     | None  | Norie    |             | Off      |
| Channel_20  |                                              | EHIP_CORE_3     | EHIPLANE_20 | Interface_20      | None     | None  | None     |             | Off      |
| Channel_19  |                                              |                 | EHIPLANE_19 | Interface_19      | None     | None  | None     |             | Off      |
| Channel_18  | DECEEC.                                      |                 | EHIPLANE_18 | Interface_18      | None     | None  | None     | Off         | Off      |
| Channel_17  | HEOREU_4                                     |                 | EHIPLANE_17 | Interface_17      | None     | None  | Norie    |             | Off      |
| Channel_16  |                                              | 6               | EHIPLANE_16 | Interface_16      | None     | None  | None     | ]           | Off      |
| Channel_15  |                                              | EHIP CORE 2     | EHIPLANE_15 | Interface_15      | None     | None  | None     | - Off       | Off      |
| Channel_14  |                                              | Enir_Conc_4     | EHIPLANE_14 | Interface_14      | None     | None  | None     |             | Off      |
| Channel_13  | HEOREU_3                                     |                 | EHIPLANE_13 | Interface_13      | None     | None  | Norie    |             | Off      |
| Channel_12  |                                              |                 | EHIPLANE_12 | Interface_12      | None     | None  | None     |             | Off      |
| Channel_11  |                                              |                 | EHIPLANE_11 | Interface_11      | None     | None  | None     | Off         | Off      |
| Channel_10  | presse a                                     |                 | EHIPLANE_10 | Interface_10      | None     | None  | None     |             | Off      |
| Channel_9   | RESPEC_4<br>RESPEC_3<br>RESPEC_2<br>RESPEC_1 | EHIP_CORE_1     | EHIPLANE_9  | Interface_9       | None     | None  | None     |             | Off      |
| Channel_8   |                                              |                 | EHIPLANE_8  | Interface_8       | None     | None  | None     |             | Off      |
| Channel_7   |                                              |                 | EHIPLANE_7  | Interface_7       | None     | None  | None     |             | Off      |
| Channel_6   | DECECT 1                                     |                 | EHIPLANE_6  | Interface_6       | None     | None  | None     |             | Off      |
| Channel_5   | HESPEL_1                                     |                 | EHIPLANE_5  | Interface_5       | None     | None  | None     | Off         | Off      |
| Channel_4   |                                              | 6               | EHIPLANE_4  | Interface_4       | None     | None  | None     |             | Off      |
| Channel_3   |                                              | EHIP_CORE_0     | EHIPLANE_3  | Interface_3       | Ethernet | NRZ   | 25.78G   |             | 528, 514 |
| Channel_2   | RESFEC 0                                     | EHIT_CONE_0     | EHIPLANE_2  | Interface_2       | Ethernet | NRZ   | 25.78G   | Fractured   | 528, 514 |
| Channel_1   | ncorcu_0                                     |                 | EHIPLANE_1  | Interface_1       | Ethernet | NRZ   | 25.78G   | Fractured   | 528, 514 |
| Channel_0   |                                              |                 | EHIPLANE_0  | Interface_0       | Ethernet | NRZ   | 25.78G   |             | 528, 514 |

#### **100GE with RS-FEC Variant**

You can use the following channel placements for a four-channel Native PHY with single RS-FEC block without PTP variant.

In 100GE tab, Select Ethernet IP Layers: MAC+PCS+RSFEC.

- Select Core Variant: Single 100GE with optional RSFEC •
- Enable RSFEC: Selected •
- The FEC mode is set to aggregate mode. ٠





|             | Intel® Stra | atix 10® E-tile | Channel Settings |                   |          |       |        |                |          |
|-------------|-------------|-----------------|------------------|-------------------|----------|-------|--------|----------------|----------|
| XCVR<br>PMA | RSFEC       | EHIP_TOP        |                  | Core<br>Interface | Protocol | Level | Rate   | FEC<br>mode    | RSFEC    |
| Channel_23  |             |                 | EHIPLANE_23      | Interface_23      | Ethernet | NRZ   | 25.78G | Aggregate      | 528, 514 |
| Channel_22  | RESFEC 5    |                 | EHIPLANE_22      | Interface_22      | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_21  | NEGREC_S    | EHIP_CORE_3     | EHIPLANE_21      | Interface_21      | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_20  |             | EHIF_CONE_3     | EHIPLANE_20      | Interface_20      | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_19  |             |                 | EHIPLANE_19      | Interface_19      | None     | None  | None   |                | Off      |
| Channel_18  | RECERC A    |                 | EHIPLANE_18      | Interface_18      | None     | None  | None   | Off            | Off      |
| Channel_17  | RESFEC_4    |                 | EHIPLANE_17      | Interface_17      | None     | None  | None   | - Urr          | Off      |
| Channel_16  |             |                 | EHIPLANE_16      | Interface_16      | None     | None  | None   |                | Off      |
| Channel_15  |             | EHIP CORE 2     | EHIPLANE_15      | Interface_15      | Ethernet | NRZ   | 25.78G | -<br>Aggregate | 528, 514 |
| Channel_14  | RESFEC 3    |                 | EHIPLANE_14      | Interface_14      | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_13  | NEGREC_3    |                 | EHIPLANE_13      | Interface_13      | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_12  |             |                 | EHIPLANE_12      | Interface_12      | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_11  |             | EHIP_CORE_1     | EHIPLANE_11      | Interface_11      | Ethernet | NRZ   | 25.78G | – Aggregate    | 528, 514 |
| Channel_10  | RESFEC 2    |                 | EHIPLANE_10      | Interface_10      | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_9   | neoreu_2    |                 | EHIPLANE_9       | Interface_9       | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_8   |             |                 | EHIPLANE_8       | Interface_8       | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_7   |             |                 | EHIPLANE_7       | Interface_7       | None     | None  | None   |                | Off      |
| Channel_6   | RESFEC 1    |                 | EHIPLANE_6       | Interface_6       | None     | None  | None   | Off            | Off      |
| Channel_5   | ncorcu_1    |                 | EHIPLANE_5       | Interface_5       | None     | None  | None   |                | Off      |
| Channel_4   |             |                 | EHIPLANE_4       | Interface_4       | None     | None  | None   |                | Off      |
| Channel_3   |             | EHIP_CORE_0     | EHIPLANE_3       | Interface_3       | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_2   | RESFEC 0    |                 | EHIPLANE_2       | Interface_2       | Ethernet | NRZ   | 25.78G | - Aggregate    | 528, 514 |
| Channel_1   | HEBREC_U    |                 | EHIPLANE_1       | Interface_1       | Ethernet | NRZ   | 25.78G |                | 528, 514 |
| Channel_0   |             |                 | EHIPLANE_0       | Interface_0       | Ethernet | NRZ   | 25.78G |                | 528, 514 |

### Single Channel 10GE/25GE with RS-FEC and PTP Variant

When RS-FEC and PTP are enabled, place the RS-FEC channel next to the PTP channels. The supported PTP channel locations for this variant are:

- Channel\_4/5 when using EHIP\_CORE0 •
- Channel 6/7 when using EHIP\_CORE1 ٠
- Channel 16/17 when using EHIP\_CORE2 ٠
- Channel 18/19 when using EHIP\_CORE3 ٠

- Select Core Variant: 100GE or 1 to 4 10GE/25GE with optional RSFEC and • 1588 PTP
- Number of Channels of 10GE/25GE: Single Channel ٠
- Active Channel(s) at startup: 10G/25GE Channel(s) ٠
- Enable IEEE 1588 PTP: Selected ٠





- Enable RSFEC: Selected
- When IEEE1588/PTP channel placement restriction is set to EHIP0/2(EHIP\_CORE\_0/EHIP\_CORE2), the First RSFEC Lane should set to first\_lane3(channel\_3 or channel\_15).
- When IEEE1588/PTP channel placement restriction is set to EHIP1/3(EHIP\_CORE\_1/EHIP\_CORE3), the First RSFEC Lane should set to first\_lane0(channel\_8 or channel\_20).
- The FEC mode is set to fractured mode.

|             | Intel <sup>®</sup> Stra | atix 10® E-tile | Channel Settings |                   |          |       |        |             |          |
|-------------|-------------------------|-----------------|------------------|-------------------|----------|-------|--------|-------------|----------|
| XCVR<br>PMA | RSFEC                   | EHIP_TOP        |                  | Core<br>Interface | Protocol | Level | Rate   | FEC<br>mode | RSFEC    |
| Channel_23  |                         |                 | EHIPLANE_23      | Interface_23      | None     | None  | None   | Fractured   | Off      |
| Channel_22  | RESFEC 5                |                 | EHIPLANE_22      | Interface_22      | None     | None  | None   |             | Off      |
| Channel_21  |                         | FHIP CORE 3     | EHIPLANE_21      | Interface_21      | None     | None  | None   |             | Off      |
| Channel_20  |                         | EHIP_CORE_2     | EHIPLANE_20      | Interface_20      | Ethernet | NRZ   | 25.78G |             | 528, 514 |
| Channel_19  |                         |                 | EHIPLANE_19      | Interface_19      | PTP      | None  | None   |             | Off      |
| Channel_18  | RESFEC 4                |                 | EHIPLANE_18      | Interface_18      | PTP      | None  | None   |             | Off      |
| Channel_17  |                         |                 | EHIPLANE_17      | Interface_17      | PTP      | None  | None   |             | Off      |
| Channel_16  |                         |                 | EHIPLANE_16      | Interface_16      | PTP      | None  | None   |             | Off      |
| Channel_15  |                         |                 | EHIPLANE_15      | Interface_15      | Ethernet | NRZ   | 25.78G | - Fractured | 528, 514 |
| Channel_14  | RESFEC 3                |                 | EHIPLANE_14      | Interface_14      | None     | None  | None   |             | Off      |
| Channel_13  |                         |                 | EHIPLANE_13      | Interface_13      | None     | None  | None   |             | Off      |
| Channel_12  |                         |                 | EHIPLANE_12      | Interface_12      | None     | None  | None   |             | Off      |
| Channel_11  |                         |                 | EHIPLANE_11      | Interface_11      | None     | None  | None   | - Fractured | Off      |
| Channel_10  | RESFEC 2                |                 | EHIPLANE_10      | Interface_10      | None     | None  | None   |             | Off      |
| Channel_9   |                         | EHIP_CORE_1     | EHIPLANE_9       | Interface_9       | None     | None  | None   |             | Off      |
| Channel_8   |                         |                 | EHIPLANE_8       | Interface_8       | Ethernet | NRZ   | 25.78G |             | 528, 514 |
| Channel_7   |                         |                 | EHIPLANE_7       | Interface_7       | PTP      | None  | None   |             | Off      |
| Channel_6   | RESFEC 1                |                 | EHIPLANE_6       | Interface_6       | PTP      | None  | None   | Off         | Off      |
| Channel_5   |                         |                 | EHIPLANE_5       | Interface_5       | PTP      | None  | None   |             | Off      |
| Channel_4   |                         |                 | EHIPLANE_4       | Interface_4       | PTP      | None  | None   |             | Off      |
| Channel_3   |                         | EHIP_CORE_0     | EHIPLANE_3       | Interface_3       | Ethernet | NRZ   | 25.78G | - Fractured | 528, 514 |
| Channel_2   | RESEC 0                 |                 | EHIPLANE_2       | Interface_2       | None     | None  | None   |             | Off      |
| Channel_1   |                         |                 | EHIPLANE_1       | Interface_1       | None     | None  | None   |             | Off      |
| Channel_0   |                         |                 | EHIPLANE_0       | Interface_0       | None     | None  | None   |             | Off      |

#### Two Channels 10GE/25GE with RS-FEC and PTP Variant

When RS-FEC and PTP are enabled, place the RS-FEC channel next to the PTP channels. The supported PTP channel locations for this variant are:

- Channel\_4/5 when using EHIP\_CORE0
- Channel 6/7 when using EHIP\_CORE1
- Channel 16/17 when using EHIP\_CORE2
- Channel 18/19 when using EHIP\_CORE3



Following are the parameter settings for these channel placements:

- Select Core Variant: 100GE or 1 to 4 10GE/25GE with optional RSFEC and 1588 PTP
- Number of Channels of 10GE/25GE: 2 Channels
- Active Channel(s) at startup: 10G/25GE Channel(s)
- Enable IEEE 1588 PTP: Selected
- Enable RSFEC: Selected
- When IEEE1588/PTP channel placement restriction is set to EHIP0/2(EHIP\_CORE\_0/EHIP\_CORE2), the First RSFEC Lane should set to first\_lane2.
- When IEEE1588/PTP channel placement restriction is set to EHIP1/3(EHIP\_CORE\_1/EHIP\_CORE3), the First RSFEC Lane should set to first\_lane0(channel\_8 or channel\_20).

| Intel® Stratix 10® E-tile Floor Plan |          |             |             |                 |          | Channel Settings |         |             |          |  |  |
|--------------------------------------|----------|-------------|-------------|-----------------|----------|------------------|---------|-------------|----------|--|--|
| XCVR PMA                             | RSFEC    | EHIP_TOP    |             | Core Interface  | Protocol | Level            | Bate    | FEC mode    | RSFEC    |  |  |
| Overel_23                            |          |             | EHPLANE_21  | irinface_22     | None     | Nore             | Norm    |             | DY       |  |  |
| Channel_22                           |          |             | EHPLANE_22  | linterface_22   | Norie I  | Norm             | None: 1 | - Fractured | Off.     |  |  |
| Channel_21                           | RESFEC_5 |             | EHIPLANE_21 | Interface_21    | Ethernet | NRZ              | 25.786  |             | 528, 514 |  |  |
| Channel_20                           |          | EHIP_CORE_3 | EHIPLANE_20 | Interface_20    | Ethernet | NRZ              | 25.786  |             | 528, 51  |  |  |
| Darred_S                             |          |             | EHPLANE_0   | Interface_10    | PTP      | None             | None    |             | Off      |  |  |
| Cherrol_1                            |          |             | EHIPLANE_11 | Interface_10    | PTP      | None             | None    |             | Off      |  |  |
| Channel_07                           | RESPEC_4 | EHP_COPE_2  | ERPLANE_17  | interfection, W | PTP      | None             | None    | Off         | Off      |  |  |
| Grand_E                              |          |             | EHPLANE_T   | Interface_N     | PTP      | None             | None    |             | Off      |  |  |
| Channel_15                           |          |             | EHIPLANE_15 | Interface_15    | Ethernet | NRZ              | 25.786  | Fractured   | 528, 51  |  |  |
| Channel_14                           |          |             | EHIPLANE_14 | Interface_14    | Ethernet | NRZ              | 25.79G  |             | 528, 51  |  |  |
| Chinoid_S                            | RESPEC_3 |             | EEIPCANE_13 | . Robin ana_10  | Norie    | Nonic            | Nizeun. |             | :00      |  |  |
| Dwnd_2                               |          |             | EHPLANE_2   | Interlane_2     | None     | None             | Norm    |             | 0)       |  |  |
| Charcel_II                           |          |             | EHIPLANE_T  | htterface_R     | Norse    | Nore             | None    |             | D†       |  |  |
| Disriel_10                           |          |             | EHPLANE_0   | Interface_10    | None     | Note             | Nove    |             | OF       |  |  |
| Channel_9                            | RESPEC_2 | EHIP_CORE_1 | EHIPLANE_9  | Interface_9     | Ethernet | NRZ              | 25.786  |             | 528, 51  |  |  |
| Channel_8                            |          | ENP_CONE_1  | EHIPLANE_8  | Interface_8     | Ethernet | NRZ              | 25.78G  |             | 528, 51  |  |  |
| Channel,7                            |          |             | EHPLANE,7   | leiterface_7    | PTP      | None             | None    |             | Off      |  |  |
| Daniel, E                            |          |             | EHPLANE_0   | interface_6     | PTP      | None             | None    | 06          | Off      |  |  |
| Channel_5                            |          |             | EHPLANE_5   | Interface_5     | PTP      | None             | None    | - Dff       | Off      |  |  |
| Demisi                               |          |             | EHPLINE_(   | Interface_4     | PTP      | None             | None    |             | Off      |  |  |
| Channel_3                            |          | EHP CORE A  | EHIPLANE_3  | Interface_3     | Ethernet | NRZ              | 25.786  |             | 528, 51  |  |  |
| Channel_2                            | RESPEC_0 | EHIP_CORE_0 | EHIPLANE_2  | Interface_2     | Ethernet | NRZ              | 25.79G  |             | 528, 51  |  |  |
| Control 21                           | neares_0 |             | EHIPLANE_1  | trinchica_1     | Norie    | 2Normit:         | Norw.   | Fractured   | :00      |  |  |
| Channel_0                            |          |             | EHPLANE_0   | interface_0     | None     | Note             | Norm    |             | Di       |  |  |

• The FEC mode is set to fractured mode.





#### Three Channels 10GE/25GE with RS-FEC and PTP Variant

When RS-FEC and PTP are enabled, place the RS-FEC channel next to the PTP channels. The supported PTP channel locations for this variant are:

- Channel\_4/5 when using EHIP\_CORE0
- Channel 6/7 when using EHIP\_CORE1
- Channel 16/17 when using EHIP\_CORE2
- Channel 18/19 when using EHIP\_CORE3

- Select Core Variant: 100GE or 1 to 4 10GE/25GE with optional RSFEC and 1588 PTP
- Number of Channels of 10GE/25GE: 3 Channels
- Active Channel(s) at startup: 10G/25GE Channel(s)
- Enable IEEE 1588 PTP: Selected
- Enable RSFEC: Selected
- When IEEE1588/PTP channel placement restriction is set to EHIP0/2(EHIP\_CORE\_0/EHIP\_CORE2), the First RSFEC Lane should set to first\_lane1(channel\_3 or channel\_15).
- When IEEE1588/PTP channel placement restriction is set to EHIP1/3(EHIP\_CORE\_1/EHIP\_CORE3), the First RSFEC Lane should set to first\_lane0(channel\_8 or channel\_20).
- The FEC mode is set to fractured mode.







|              | Intel <sup>®</sup> Str | atix 10® E-tile | Floor Plan   |                | Channel Settings |         |        |           |          |  |  |
|--------------|------------------------|-----------------|--------------|----------------|------------------|---------|--------|-----------|----------|--|--|
| XCVR PMA     | RSFEC                  | EHIP_           | тор          | Core Interface | Protocol         | Level   | Bate   | FEC mode  | RSFEC    |  |  |
| Charrent, 20 |                        |                 | EHPLANE_2)   | Interface_21   | Norm             | Norei   | New    |           | CH.      |  |  |
| Channel_22   |                        |                 | EHIPLANE_22  | Interface_22   | Ethernet         | NFIZ    | 25.78G | Fractured | 528, 514 |  |  |
| Channel_21   | RESFEC_5               |                 | EHIPLANE_21  | Interface_21   | Ethernet         | NRZ     | 25.78G |           | 528, 514 |  |  |
| Channel_20   |                        | EHIP_COHE_3     | EHIPLANE_20  | Interface_20   | Ethernet         | NFIZ    | 25.786 |           | 528, 514 |  |  |
| Channel_15   | 3                      |                 | EHPLANE_10   | Interface_13   | PTP              | None    | None   |           | Off      |  |  |
| Chernel_3    |                        |                 | EHPLANE_10   | inverture_10   | PTP              | None    | None   |           | Off      |  |  |
| Channel_17   | RESPEC_4               | EHPLANE_0       | interface_17 | PTP            | None             | None    | Uff    | Off       |          |  |  |
| Channel_%    |                        | EHP_COPE_2      | EHPLANE_E    | instant, N     | PTP              | None    | None   |           | Off      |  |  |
| Channel_15   |                        |                 | EHIPLANE_15  | Interface_15   | Ethernet         | NFI2    | 25.786 | Fractured | 528, 514 |  |  |
| Channel_14   |                        | EHIP_COHE_2     | EHIPLANE_14  | Interface_14   | Ethernet         | NRZ     | 25.785 |           | 528, 514 |  |  |
| Channel_13   | RESPEC_3               |                 | EHIPLANE_13  | Interface_13   | Ethernet         | NRZ     | 25.78G |           | 528, 514 |  |  |
| Diamel_12    |                        |                 | EHPLANE_12   | interface_D    | Norm             | Norse ! | None   |           | 01       |  |  |
| Charriel_11  |                        |                 | EHIPLANE_1   | Interface_11   | Norm             | Noor :  | Norm   | Fractured | Of       |  |  |
| Channel_10   |                        |                 | EHIPLANE_10  | Interface_10   | Ethernet         | NRZ     | 25.786 |           | 528, 514 |  |  |
| Channel_9    | RESPEC_2               |                 | EHPLANE_9    | Interface_9    | Ethernet         | NFIZ    | 25.785 |           | 528, 514 |  |  |
| Channel_8    |                        | EHIP_COHE_1     | EHPLANE_8    | Interface_8    | Ethernet         | NFIZ    | 25.78G |           | 528, 514 |  |  |
| Durnel,7     |                        |                 | EHPLANE_7    | Interface_7    | PTP              | None    | None   |           | Off      |  |  |
| (Durinel_E)  |                        |                 | EHPLANE, I   | Interface, R   | PTP              | None    | None   |           | Off      |  |  |
| Charvel_5    | PESFEC_1               |                 | EHPLANE_5    | Interface_5    | PTP              | None    | None   | Uff       | Off      |  |  |
| Chinnel_4    | 5                      |                 | EHPLANE_4    | Interface_4    | PTP              | None    | None   | 1         | Off      |  |  |
| Channel_3    |                        | 5140 comp -     | EHPLANE_3    | Interface_3    | Ethernet         | NFIZ    | 25.785 | _         | 528, 514 |  |  |
| Channel_2    | DECERC A               | EHP_COPE_0      | EHPLANE_2    | Interface_2    | Ethernet         | NRZ     | 25.79G |           | 528, 514 |  |  |
| Channel_1    | RESFEC_0               |                 | EHIPLANE_1   | Interface_1    | Ethernet         | NRZ     | 25.78G |           | 528, 514 |  |  |
| Channel_0    |                        |                 | EHPLANE_0    | . Interface_0  | Nore             | Nore    | None   |           | CIII     |  |  |

#### Four Channels 10GE/25GE with RS-FEC and PTP Variant

When RS-FEC and PTP are enabled, place the RS-FEC channel next to the PTP channels. The supported PTP channel locations for this variant are:

- Channel\_4/5 when using EHIP\_CORE0
- Channel 6/7 when using EHIP\_CORE1 ٠
- Channel 16/17 when using EHIP\_CORE2 ٠
- Channel 18/19 when using EHIP\_CORE3 ٠

- Select Core Variant: 100GE or 1 to 4 10GE/25GE with optional RSFEC and • 1588 PTP
- Number of Channels of 10GE/25GE: 4 Channels
- Active Channel(s) at startup: 10G/25GE Channel(s) •
- Enable IEEE 1588 PTP: Selected •
- Enable RSFEC: Selected





- **IEEE1588/PTP** channel placement restriction: **EHIP0/2**(EHIP\_CORE\_0/ EHIP\_CORE2) or **EHIP1/3**(EHIP\_CORE\_1/EHIP\_CORE3)
- First RSFEC Lane: first\_lane0
- The FEC mode is set to fractured mode.

|            | Intel® Stra | atix 10® E-tile | e Floor Plan |                   |          | Chan  | nel Sett | ings      |          |
|------------|-------------|-----------------|--------------|-------------------|----------|-------|----------|-----------|----------|
| XCVR PMA   | RSFEC       | EHIP_           | ТОР          | Core<br>Interface | Protocol | Level | Rate     | FEC mode  | RSFEC    |
| Channel_23 |             |                 | EHIPLANE_23  | Interface_23      | Ethernet | NRZ   | 25.78G   |           | 528, 514 |
| Channel_22 | RESPEC 5    |                 | EHIPLANE_22  | Interface_22      | Ethernet | NRZ   | 25.78G   | Fractured | 528, 514 |
| Channel_21 | ALGILO D    | EHIP CORE 3     | EHIPLANE_21  | Interface_21      | Ethernet | NRZ   | 25.78G   |           | 528, 514 |
| Channel_20 |             | LINF_CORL_3     | EHIPLANE_20  | Interface_20      | Ethernet | NRZ   | 25.78G   |           | 528, 514 |
| Channel_19 |             |                 | EHIPLANE_19  | Interface_19      | РТР      | None  | None     |           | Off      |
| Channel_18 | RESFEC_4    |                 | EHIPLANE_18  | Interface_18      | РТР      | None  | None     | Off       | Off      |
| Channel_17 | KEGFEC_4    |                 | EHIPLANE_17  | Interface_17      | РТР      | None  | None     |           | Off      |
| Channel_16 |             |                 | EHIPLANE_16  | Interface_16      | РТР      | None  | None     |           | Off      |
| Channel_15 |             | EHIP_CORE_2     | EHIPLANE_15  | Interface_15      | Ethernet | NRZ   | 25.78G   |           | 528, 514 |
| Channel_14 |             | EHIP_CORE_2     | EHIPLANE_14  | Interface_14      | Ethernet | NRZ   | 25.78G   | Fractured | 528, 514 |
| Channel_13 | REOFEL O    |                 | EHIPLANE_13  | Interface_13      | Ethernet | NRZ   | 25.78G   | Fractured | 528, 514 |
| Channel_12 |             |                 | EHIPLANE_12  | Interface_12      | Ethernet | NRZ   | 25.78G   |           | 528, 514 |
| Channel_11 |             |                 | EHIPLANE_11  | Interface_11      | Ethernet | NRZ   | 25.78G   |           | 528, 514 |
| Channel_10 | RESFEC 2    |                 | EHIPLANE_10  | Interface_10      | Ethernet | NRZ   | 25.78G   | Fractured | 528, 514 |
| Channel_9  | REOFEU 2    | EHIP_CORE_1     | EHIPLANE_9   | Interface_9       | Ethernet | NRZ   | 25.78G   | riactured | 528, 514 |
| Channel_8  |             | EHIP_CORE_I     | EHIPLANE_8   | Interface_8       | Ethernet | NRZ   | 25.78G   | ]         | 528, 514 |
| Channel_7  |             |                 | EHIPLANE_7   | Interface_7       | PTP      | None  | None     |           | Off      |
| Channel_6  | DECECC 1    |                 | EHIPLANE_6   | Interface_6       | PTP      | None  | None     |           | Off      |
| Channel_5  | RESFEC_1    |                 | EHIPLANE_5   | Interface_5       | PTP      | None  | None     | Off       | Off      |
| Channel_4  |             |                 | EHIPLANE_4   | Interface_4       | PTP      | None  | None     | ]         | Off      |
| Channel_3  |             | EHIP CORE 0     | EHIPLANE_3   | Interface_3       | Ethernet | NRZ   | 25.78G   |           | 528, 514 |
| Channel_2  | 055557 A    | LINE_CORE_U     | EHIPLANE_2   | Interface_2       | Ethernet | NRZ   | 25.78G   | Fractured | 528, 514 |
| Channel_1  | RESFEC 0    | E               | EHIPLANE_1   | Interface_1       | Ethernet | NRZ   | 25.78G   | Fractured | 528, 514 |
| Channel_0  |             |                 | EHIPLANE_0   | Interface_0       | Ethernet | NRZ   | 25.78G   |           | 528, 514 |
|            |             |                 | •            |                   |          |       |          |           |          |

### 2.7.4.1.2. Guidelines and Restrictions for 16-bonded Channels Variant

The E-tile transceiver requires the channel placement to be contiguous when RS-FEC is enabled. The following are the allowed channel placements for different number of channels.

### Single Channel 10GE/25GE with RS-FEC Variant in Intel Agilex Devices



- Select Core Variant: 1 to 4 10GE/25GE with optional RSFEC •
- Number of Channels of 10GE/25GE: Single Channel
- Enable RSFEC: Selected
- First RSFEC Lane: first\_lane0(channel\_0), first\_lane1(channel\_9), first\_lane2(channel\_14), or first\_lane3(channel\_23) ٠
- The FEC mode is set to fractured mode. •

|            | Inte     | l® E-tile Floo | r Plan      |                   |          | Chai  | nnel Setti | ngs       |          |
|------------|----------|----------------|-------------|-------------------|----------|-------|------------|-----------|----------|
| XCVR PMA   | RSFEC    | EHIP_          | ТОР         | Core<br>Interface | Protocol | Level | Rate       | FEC mode  | RSFEC    |
| Channel_23 |          |                | EHIPLANE_23 | Interface_23      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_22 | RESPEC 5 |                | EHIPLANE_22 | Interface_22      | None     | None  | None       | Fractured | Off      |
| Channel_21 | KEOFEC_5 |                | EHIPLANE_21 | Interface_21      | None     | None  | None       | riactured | Off      |
| Channel_20 |          | EHIP_CORE_3    | EHIPLANE_20 | Interface_20      | None     | None  | None       | ]         | Off      |
| Channel_19 |          |                | EHIPLANE_19 | Interface_19      | None     | None  | None       |           | Off      |
| Channel_18 | 050550 4 |                | EHIPLANE_18 | Interface_18      | None     | None  | None       |           | Off      |
| Channel_17 | RESFEC_4 |                | EHIPLANE_17 | Interface_17      | None     | None  | None       | Off       | Off      |
| Channel_16 |          |                | EHIPLANE_16 | Interface_16      | None     | None  | None       |           | Off      |
| Channel_15 |          | 5100 0005 0    | EHIPLANE_15 | Interface_15      | None     | None  | None       |           | Off      |
| Channel_14 |          | EHIP_CORE_2    | EHIPLANE_14 | Interface_14      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_13 | RESFEC 3 |                | EHIPLANE_13 | Interface_13      | None     | None  | None       | Fractured | Off      |
| Channel_12 |          |                | EHIPLANE_12 | Interface_12      | None     | None  | None       |           | Off      |
| Channel_11 |          |                | EHIPLANE_11 | Interface_11      | None     | None  | None       |           | Off      |
| Channel_10 |          |                | EHIPLANE_10 | Interface_10      | None     | None  | None       |           | Off      |
| Channel_9  | RESFEC 2 |                | EHIPLANE_9  | Interface_9       | Ethernet | NRZ   | 25.78G     | Fractured | 528, 514 |
| Channel_8  |          | EHIP_CORE_1    | EHIPLANE_8  | Interface_8       | None     | None  | None       | 1         | Off      |
| Channel_7  |          |                | EHIPLANE_7  | Interface_7       | None     | None  | None       |           | Off      |
| Channel_6  | DE0550 4 |                | EHIPLANE_6  | Interface_6       | None     | None  | None       |           | Off      |
| Channel_5  | RESFEC_1 |                | EHIPLANE_5  | Interface_5       | None     | None  | None       | Off       | Off      |
| Channel_4  |          |                | EHIPLANE_4  | Interface_4       | None     | None  | None       | 1         | Off      |
| Channel_3  |          | 5100 0005 5    | EHIPLANE_3  | Interface_3       | None     | None  | None       |           | Off      |
| Channel_2  | RESEEC 0 |                | EHIPLANE_2  | Interface_2       | None     | None  | None       |           | Off      |
| Channel_1  | RESPEC_0 |                | EHIPLANE_1  | Interface_1       | None     | None  | None       |           | Off      |
| Channel_0  |          |                | EHIPLANE_0  | Interface_0       | Ethernet | NRZ   | 25.78G     | 1         | 528, 514 |
|            |          |                | •           |                   |          |       |            |           |          |

### Two Channels 10GE/25GE with RS-FEC Variant in Agilex Devices





- Select Core Variant: 1 to 4 10GE/25GE with optional RSFEC ٠
- Number of Channels of 10GE/25GE: 2 Channels ٠
- Enable RSFEC: Selected •
- First RSFEC Lane: first\_lane0(channel\_0), first\_lane1(channel\_9), or • first\_lane2(channel\_14)
- The FEC mode is set to fractured mode. •

|            | Inte     | l® E-tile Floo | r Plan      |                   |          | Char  | nnel Setti | ngs       |          |
|------------|----------|----------------|-------------|-------------------|----------|-------|------------|-----------|----------|
| XCVR PMA   | RSFEC    | EHIP_          | ТОР         | Core<br>Interface | Protocol | Level | Rate       | FEC mode  | RSFEC    |
| Channel_23 |          |                | EHIPLANE_23 | Interface_23      | None     | None  | None       |           | Off      |
| Channel_22 | 252552 5 |                | EHIPLANE_22 | Interface_22      | None     | None  | None       |           | Off      |
| Channel_21 | RESFEC_5 |                | EHIPLANE_21 | Interface_21      | None     | None  | None       | Off       | Off      |
| Channel_20 |          | EHIP_CORE_3    | EHIPLANE_20 | Interface_20      | None     | None  | None       | 1         | Off      |
| Channel_19 |          |                | EHIPLANE_19 | Interface_19      | None     | None  | None       |           | Off      |
| Channel_18 | 050550 4 |                | EHIPLANE_18 | Interface_18      | None     | None  | None       |           | Off      |
| Channel_17 | RESFEC_4 |                | EHIPLANE_17 | Interface_17      | None     | None  | None       | Off       | Off      |
| Channel_16 |          |                | EHIPLANE_16 | Interface_16      | None     | None  | None       | 1         | Off      |
| Channel_15 |          |                | EHIPLANE_15 | Interface_15      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_14 |          | EHIP_CORE_2    | EHIPLANE_14 | Interface_14      | Ethernet | NRZ   | 25.78G     | 1         | 528, 514 |
| Channel_13 | RESFEC 3 |                | EHIPLANE_13 | Interface_13      | None     | None  | None       | Fractured | Off      |
| Channel_12 |          |                | EHIPLANE_12 | Interface_12      | None     | None  | None       |           | Off      |
| Channel_11 |          |                | EHIPLANE_11 | Interface_11      | None     | None  | None       |           | Off      |
| Channel_10 |          |                | EHIPLANE_10 | Interface_10      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_9  | RESFEC 2 |                | EHIPLANE_9  | Interface_9       | Ethernet | NRZ   | 25.78G     | Fractured | 528, 514 |
| Channel_8  |          | EHIP_CORE_1    | EHIPLANE_8  | Interface_8       | None     | None  | None       | 1         | Off      |
| Channel_7  |          |                | EHIPLANE_7  | Interface_7       | None     | None  | None       |           | Off      |
| Channel_6  |          |                | EHIPLANE_6  | Interface_6       | None     | None  | None       | 1         | Off      |
| Channel_5  | RESFEC_1 |                | EHIPLANE_5  | Interface_5       | None     | None  | None       | Off       | Off      |
| Channel_4  |          |                | EHIPLANE_4  | Interface_4       | None     | None  | None       | 1         | Off      |
| Channel_3  |          |                | EHIPLANE_3  | Interface_3       | None     | None  | None       |           | Off      |
| Channel_2  |          | EHIP_CORE_0    | EHIPLANE_2  | Interface_2       | None     | None  | None       | 1         | Off      |
| Channel_1  | RESFEC_0 |                | EHIPLANE_1  | Interface_1       | Ethernet | NRZ   | 25.78G     | Fractured | 528, 514 |
| Channel_0  |          |                | EHIPLANE_0  | Interface_0       | Ethernet | NRZ   | 25.78G     | 1         | 528, 514 |

### Three Channels 10GE/25GE with RS-FEC in Intel Agilex Devices

Following are the parameter settings for these channel placements:

Send Feedback

39



- Select Core Variant: 1 to 4 10GE/25GE with optional RSFEC •
- Number of Channels of 10GE/25GE: 3 Channels
- Enable RSFEC: Selected
- First RSFEC Lane: first\_lane0(channel\_0) or first\_lane1(channel\_9) ٠
- The FEC mode is set to fractured mode. •

|            | Inte      | l® E-tile Floo | r Plan      |                   |          | Char  | nnel Setti | ings      |          |
|------------|-----------|----------------|-------------|-------------------|----------|-------|------------|-----------|----------|
| XCVR PMA   | RSFEC     | EHIP_          | тор         | Core<br>Interface | Protocol | Level | Rate       | FEC mode  | RSFEC    |
| Channel_23 |           |                | EHIPLANE_23 | Interface_23      | None     | None  | None       |           | Off      |
| Channel_22 | RESFEC_5  |                | EHIPLANE_22 | Interface_22      | None     | None  | None       | Off       | Off      |
| Channel_21 | RESPEC_5  | 5100 0005 0    | EHIPLANE_21 | Interface_21      | None     | None  | None       | Uff       | Off      |
| Channel_20 |           | EHIP_CORE_3    | EHIPLANE_20 | Interface_20      | None     | None  | None       | 1         | Off      |
| Channel_19 |           |                | EHIPLANE_19 | Interface_19      | None     | None  | None       |           | Off      |
| Channel_18 | 0.50550 4 |                | EHIPLANE_18 | Interface_18      | None     | None  | None       | 1         | Off      |
| Channel_17 | RESFEC_4  |                | EHIPLANE_17 | Interface_17      | None     | None  | None       | Off       | Off      |
| Channel_16 |           |                | EHIPLANE_16 | Interface_16      | None     | None  | None       | 1         | Off      |
| Channel_15 |           | 5100 0005 0    | EHIPLANE_15 | Interface_15      | None     | None  | None       |           | Off      |
| Channel_14 |           | EHIP_CORE_2    | EHIPLANE_14 | Interface_14      | None     | None  | None       | 1         | Off      |
| Channel_13 | RESFEC_3  |                | EHIPLANE_13 | Interface_13      | None     | None  | None       | Off       | Off      |
| Channel_12 |           |                | EHIPLANE_12 | Interface_12      | None     | None  | None       | 1         | Off      |
| Channel_11 |           |                | EHIPLANE_11 | Interface_11      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_10 |           |                | EHIPLANE_10 | Interface_10      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_9  | RESFEC 2  | 5100 0005 4    | EHIPLANE_9  | Interface_9       | Ethernet | NRZ   | 25.78G     | Fractured | 528, 514 |
| Channel_8  |           | EHIP_CORE_1    | EHIPLANE_8  | Interface_8       | None     | None  | None       |           | Off      |
| Channel_7  |           |                | EHIPLANE_7  | Interface_7       | None     | None  | None       |           | Off      |
| Channel_6  | DECECC 1  |                | EHIPLANE_6  | Interface_6       | None     | None  | None       | 0"        | Off      |
| Channel_5  | RESFEC_1  |                | EHIPLANE_5  | Interface_5       | None     | None  | None       | Off       | Off      |
| Channel_4  |           |                | EHIPLANE_4  | Interface_4       | None     | None  | None       | ]         | Off      |
| Channel_3  |           |                | EHIPLANE_3  | Interface_3       | None     | None  | None       |           | Off      |
| Channel_2  | RESERC 0  | EHIP_CORE_0    | EHIPLANE_2  | Interface_2       | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_1  | KESPEL_U  | E              | EHIPLANE_1  | Interface_1       | Ethernet | NRZ   | 25.78G     | Fractured | 528, 514 |
| Channel_0  |           |                | EHIPLANE_0  | Interface_0       | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
|            |           |                |             |                   |          |       |            |           |          |

### Four Channels 10GE/25GE with RS-FEC Variant in Intel Agilex Devices





- Select Core Variant: 1 to 4 10GE/25GE with optional RSFEC
- Number of Channels of 10GE/25GE: 4 Channels
- Enable RSFEC: Selected
- First RSFEC Lane: first\_lane0 (channel\_0)
- The FEC mode is set to fractured mode.

|            | Inte     | el® E-tile Floor | r Plan      |                   |          | Char  | nnel Setti | ngs         |          |
|------------|----------|------------------|-------------|-------------------|----------|-------|------------|-------------|----------|
| XCVR PMA   | RSFEC    | EHIP_            | TOP         | Core<br>Interface | Protocol | Level | Rate       | FEC mode    | RSFEC    |
| Channel_23 |          |                  | EHIPLANE_23 | Interface_23      | None     | None  | None       |             | Off      |
| Channel_22 | RESFEC 5 |                  | EHIPLANE_22 | Interface_22      | None     | None  | None       |             | Off      |
| Channel_21 | RESPEC_5 | EHIP_CORE_3      | EHIPLANE_21 | Interface_21      | None     | None  | None       | - Off       | Off      |
| Channel_20 |          |                  | EHIPLANE_20 | Interface_20      | None     | None  | None       |             | Off      |
| Channel_19 |          |                  | EHIPLANE_19 | Interface_19      | None     | None  | None       |             | Off      |
| Channel_18 | 252552 4 |                  | EHIPLANE_18 | Interface_18      | None     | None  | None       | 04          | Off      |
| Channel_17 | RESFEC_4 |                  | EHIPLANE_17 | Interface_17      | None     | None  | None       | Off         | Off      |
| Channel_16 |          |                  | EHIPLANE_16 | Interface_16      | None     | None  | None       |             | Off      |
| Channel_15 |          |                  | EHIPLANE_15 | Interface_15      | None     | None  | None       |             | Off      |
| Channel_14 |          | EHIP_CORE_2      | EHIPLANE_14 | Interface_14      | None     | None  | None       |             | Off      |
| Channel_13 | RESFEC_3 |                  | EHIPLANE_13 | Interface_13      | None     | None  | None       | Off         | Off      |
| Channel_12 |          |                  | EHIPLANE_12 | Interface_12      | None     | None  | None       |             | Off      |
| Channel_11 |          |                  | EHIPLANE_11 | Interface_11      | None     | None  | None       |             | Off      |
| Channel_10 |          |                  | EHIPLANE_10 | Interface_10      | None     | None  | None       |             | Off      |
| Channel_9  | RESFEC_2 |                  | EHIPLANE_9  | Interface_9       | None     | None  | None       | Off         | Off      |
| Channel_8  |          | EHIP_CORE_1      | EHIPLANE_8  | Interface_8       | None     | None  | None       |             | Off      |
| Channel_7  |          |                  | EHIPLANE_7  | Interface_7       | None     | None  | None       |             | Off      |
| Channel_6  |          |                  | EHIPLANE_6  | Interface_6       | None     | None  | None       |             | Off      |
| Channel_5  | RESFEC_1 |                  | EHIPLANE_5  | Interface_5       | None     | None  | None       | Off         | Off      |
| Channel_4  |          |                  | EHIPLANE_4  | Interface_4       | None     | None  | None       |             | Off      |
| Channel_3  |          |                  | EHIPLANE_3  | Interface_3       | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_2  |          | EHIP_CORE_0      | EHIPLANE_2  | Interface_2       | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_1  | RESFEC_0 |                  | EHIPLANE_1  | Interface_1       | Ethernet | NRZ   | 25.78G     | - Fractured | 528, 514 |
| Channel_0  |          |                  | EHIPLANE_0  | Interface_0       | Ethernet | NRZ   | 25.78G     | _           | 528, 514 |

### **100GE with RS-FEC Variant in Intel Agilex Devices**

You can use the following channel placements for a four-channel Native PHY with single RS-FEC block without PTP variant.

In 100GE tab, Select Ethernet IP Layers: MAC+PCS+RSFEC.



Following are the **IP** tab parameter settings for these channel placements:

- Select Core Variant: Single 100GE with optional RSFEC ٠
- Enable RSFEC: Selected
- The FEC mode is set to aggregate mode.

|            | Inte     | l® E-tile Floo | r Plan      |                   |          | Char  | nnel Setti | ngs         |          |
|------------|----------|----------------|-------------|-------------------|----------|-------|------------|-------------|----------|
| XCVR PMA   | RSFEC    | EHIP_          | ТОР         | Core<br>Interface | Protocol | Level | Rate       | FEC mode    | RSFEC    |
| Channel_23 |          |                | EHIPLANE_23 | Interface_23      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_22 | 050550 5 |                | EHIPLANE_22 | Interface_22      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_21 | RESFEC_5 | EHIP_CORE_3    | EHIPLANE_21 | Interface_21      | Ethernet | NRZ   | 25.78G     | Aggregate   | 528, 514 |
| Channel_20 |          |                | EHIPLANE_20 | Interface_20      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_19 |          |                | EHIPLANE_19 | Interface_19      | None     | None  | None       |             | Off      |
| Channel_18 | RESFEC 4 |                | EHIPLANE_18 | Interface_18      | None     | None  | None       | Off         | Off      |
| Channel_17 | KESFEU_4 |                | EHIPLANE_17 | Interface_17      | None     | None  | None       |             | Off      |
| Channel_16 |          |                | EHIPLANE_16 | Interface_16      | None     | None  |            |             | Off      |
| Channel_15 |          | EHIP_CORE_2    | EHIPLANE_15 | Interface_15      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_14 | RESFEC 3 | EHIP_CORE_2    | EHIPLANE_14 | Interface_14      | Ethernet | NRZ   | 25.78G     | Aggrogato   | 528, 514 |
| Channel_13 | RESPEC_5 |                | EHIPLANE_13 | Interface_13      | Ethernet | NRZ   | 25.78G     | Aggregate   | 528, 514 |
| Channel_12 |          |                | EHIPLANE_12 | Interface_12      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_11 |          |                | EHIPLANE_11 | Interface_11      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_10 | RESFEC_2 |                | EHIPLANE_10 | Interface_10      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_9  | RESPEC_2 | EHIP_CORE_1    | EHIPLANE_9  | Interface_9       | Ethernet | NRZ   | 25.78G     | Aggregate   | 528, 514 |
| Channel_8  |          | EHIP_CORE_1    | EHIPLANE_8  | Interface_8       | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_7  |          |                | EHIPLANE_7  | Interface_7       | None     | None  | None       |             | Off      |
| Channel_6  | RESFEC_1 |                | EHIPLANE_6  | Interface_6       | None     | None  | None       | Off         | Off      |
| Channel_5  | KESTEG_1 |                | EHIPLANE_5  | Interface_5       | None     | None  | None       |             | Off      |
| Channel_4  |          |                | EHIPLANE_4  | Interface_4       | None     | None  | None       |             | Off      |
| Channel_3  |          |                | EHIPLANE_3  | Interface_3       | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_2  | RESFEC_0 | FEC_0          | EHIPLANE_2  | Interface_2       | Ethernet | NRZ   | 25.78G     | Aggrogate   | 528, 514 |
| Channel_1  | RESILC_0 |                | EHIPLANE_1  | Interface_1       | Ethernet | NRZ   | 25.78G     | — Aggregate | 528, 514 |
| Channel_0  |          |                | EHIPLANE_0  | Interface_0       | Ethernet | NRZ   | 25.78G     | 1           | 528, 514 |
|            |          |                |             |                   |          |       |            |             |          |

### Single Channel 10GE/25GE with RS-FEC and PTP Variant in Intel Agilex Devices

When RS-FEC and PTP are enabled, place the RS-FEC channel next to the PTP channels. The supported PTP channel locations for this variant are:

- Channel\_4/5 when using EHIP\_CORE0 ٠
- Channel 6/7 when using EHIP\_CORE1 ٠
- Channel 16/17 when using EHIP\_CORE2 ٠
- Channel 18/19 when using EHIP\_CORE3 ٠





- Select Core Variant: 100GE or 1 to 4 10GE/25GE with optional RSFEC and 1588 PTP
- Number of Channels of 10GE/25GE: Single Channel
- Active Channel(s) at startup: 10G/25GE Channel(s)
- Enable IEEE 1588 PTP: Selected
- Enable RSFEC: Selected
- When IEEE1588/PTP channel placement restriction is set to EHIP0/2(EHIP\_CORE\_0/EHIP\_CORE2), the First RSFEC Lane should set to first\_lane3(channel\_3 or channel\_15).
- When IEEE1588/PTP channel placement restriction is set to EHIP1/3(EHIP\_CORE\_1/EHIP\_CORE3), the First RSFEC Lane should set to first\_lane0(channel\_8 or channel\_20).
- The FEC mode is set to fractured mode.





|            | Inte     | l® E-tile Floo | r Plan      |                   |          | Char  | nnel Setti | ngs         |          |
|------------|----------|----------------|-------------|-------------------|----------|-------|------------|-------------|----------|
| XCVR PMA   | RSFEC    | EHIP_          | ТОР         | Core<br>Interface | Protocol | Level | Rate       | FEC mode    | RSFEC    |
| Channel_23 |          |                | EHIPLANE_23 | Interface_23      | None     | None  | None       |             | Off      |
| Channel_22 |          |                | EHIPLANE_22 | Interface_22      | None     | None  | None       | ]           | Off      |
| Channel_21 | RESPEC_5 | EHIP_CORE_3    | EHIPLANE_21 | Interface_21      | None     | None  | None       | Fractured   | Off      |
| Channel_20 |          |                | EHIPLANE_20 | Interface_20      | Ethernet | NRZ   | 25.78G     | 1           | 528, 514 |
| Channel_19 |          |                | EHIPLANE_19 | Interface_19      | РТР      | None  | None       |             | Off      |
| Channel_18 |          |                | EHIPLANE_18 | Interface_18      | РТР      | None  | None       | ]           | Off      |
| Channel_17 | RESFEC_4 |                | EHIPLANE_17 | Interface_17      | РТР      | None  | None       | Off         | Off      |
| Channel_16 |          |                | EHIPLANE_16 | Interface_16      | РТР      | None  | None       | ]           | Off      |
| Channel_15 |          |                | EHIPLANE_15 | Interface_15      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_14 |          | EHIP_CORE_2    | EHIPLANE_14 | Interface_14      | None     | None  | None       | [           | Off      |
| Channel_13 | RESFEC 3 |                | EHIPLANE_13 | Interface_13      | None     | None  | None       | Fractured   | Off      |
| Channel_12 |          |                | EHIPLANE_12 | Interface_12      | None     | None  | None       | 1           | Off      |
| Channel_11 |          |                | EHIPLANE_11 | Interface_11      | None     | None  | None       |             | Off      |
| Channel_10 |          |                | EHIPLANE_10 | Interface_10      | None     | None  | None       | - Fractured | Off      |
| Channel_9  | RESFEC 2 |                | EHIPLANE_9  | Interface_9       | None     | None  | None       |             | Off      |
| Channel_8  |          | EHIP_CORE_1    | EHIPLANE_8  | Interface_8       | Ethernet | NRZ   | 25.78G     | ]           | 528, 514 |
| Channel_7  |          |                | EHIPLANE_7  | Interface_7       | РТР      | None  | None       |             | Off      |
| Channel_6  | RESFEC 1 |                | EHIPLANE_6  | Interface_6       | РТР      | None  | None       | Off         | Off      |
| Channel_5  | RESPEC_1 |                | EHIPLANE_5  | Interface_5       | РТР      | None  | None       |             | Off      |
| Channel_4  |          |                | EHIPLANE_4  | Interface_4       | РТР      | None  | None       |             | Off      |
| Channel_3  |          | EHIP_CORE_0    | EHIPLANE_3  | Interface_3       | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_2  | RESEEC 0 | LINP_CORE_U    | EHIPLANE_2  | Interface_2       | None     | None  | None       | - Fractured | Off      |
| Channel_1  | ACOFCL_U | E              | EHIPLANE_1  | Interface_1       | None     | None  | None       |             | Off      |
| Channel_0  |          |                | EHIPLANE_0  | Interface_0       | None     | None  | None       |             | Off      |
|            |          |                |             |                   |          |       |            |             |          |

### Two Channels 10GE/25GE with RS-FEC and PTP Variant in Intel Agilex Devices

When RS-FEC and PTP are enabled, place the RS-FEC channel next to the PTP channels. The supported PTP channel locations for this variant are:

- Channel\_4/5 when using EHIP\_CORE0 •
- Channel 6/7 when using EHIP\_CORE1
- Channel 16/17 when using EHIP\_CORE2 •
- Channel 18/19 when using EHIP\_CORE3 •





- Select Core Variant: 100GE or 1 to 4 10GE/25GE with optional RSFEC and 1588 PTP
- Number of Channels of 10GE/25GE: 2 Channels
- Active Channel(s) at startup: 10G/25GE Channel(s)
- Enable IEEE 1588 PTP: Selected
- Enable RSFEC: Selected
- When IEEE1588/PTP channel placement restriction is set to EHIP0/2(EHIP\_CORE\_0/EHIP\_CORE2), the First RSFEC Lane should set to first\_lane2.
- When IEEE1588/PTP channel placement restriction is set to EHIP1/3(EHIP\_CORE\_1/EHIP\_CORE3), the First RSFEC Lane should set to first\_lane0(channel\_8 or channel\_20).

|            | Inte     | l® E-tile Floo | r Plan      |                   |          | Char  | nnel Setti | ngs         |          |
|------------|----------|----------------|-------------|-------------------|----------|-------|------------|-------------|----------|
| XCVR PMA   | RSFEC    | EHIP_          | ТОР         | Core<br>Interface | Protocol | Level | Rate       | FEC mode    | RSFEC    |
| Channel_23 |          |                | EHIPLANE_23 | Interface_23      | None     | None  | None       |             | Off      |
| Channel_22 |          |                | EHIPLANE_22 | Interface_22      | None     | None  | None       | <br>        | Off      |
| Channel_21 | RESPEC_5 |                | EHIPLANE_21 | Interface_21      | Ethernet | NRZ   | 25.78G     | Fractured   | 528, 514 |
| Channel_20 |          | EHIP_CORE_3    | EHIPLANE_20 | Interface_20      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_19 |          |                | EHIPLANE_19 | Interface_19      | РТР      | None  | None       |             | Off      |
| Channel_18 | 050550 4 |                | EHIPLANE_18 | Interface_18      | РТР      | None  | None       |             | Off      |
| Channel_17 | RESFEC_4 |                | EHIPLANE_17 | Interface_17      | РТР      | None  | None       | Off         | Off      |
| Channel_16 |          |                | EHIPLANE_16 | Interface_16      | РТР      | None  | None       | ]           | Off      |
| Channel_15 |          | 5,000 0005 0   | EHIPLANE_15 | Interface_15      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_14 |          | EHIP_CORE_2    | EHIPLANE_14 | Interface_14      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_13 | RESFEC 3 |                | EHIPLANE_13 | Interface_13      | None     | None  | None       | Fractured   | Off      |
| Channel_12 |          |                | EHIPLANE_12 | Interface_12      | None     | None  | None       | 1           | Off      |
| Channel_11 |          |                | EHIPLANE_11 | Interface_11      | None     | None  | None       | Fractured   | Off      |
| Channel_10 |          |                | EHIPLANE_10 | Interface_10      | None     | None  | None       |             | Off      |
| Channel_9  | RESFEC 2 | 5100 0005 4    | EHIPLANE_9  | Interface_9       | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_8  |          | EHIP_CORE_1    | EHIPLANE_8  | Interface_8       | Ethernet | NRZ   | 25.78G     | ]           | 528, 514 |
| Channel_7  |          |                | EHIPLANE_7  | Interface_7       | РТР      | None  | None       |             | Off      |
| Channel_6  | DECEEC 1 |                | EHIPLANE_6  | Interface_6       | РТР      | None  | None       | Off         | Off      |
| Channel_5  | RESFEC_1 |                | EHIPLANE_5  | Interface_5       | РТР      | None  | None       |             | Off      |
| Channel_4  |          |                | EHIPLANE_4  | Interface_4       | РТР      | None  | None       |             | Off      |
| Channel_3  |          |                | EHIPLANE_3  | Interface_3       | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_2  | RESFEC 0 |                | EHIPLANE_2  | Interface_2       | Ethernet | NRZ   | 25.78G     | Fractured   | 528, 514 |
| Channel_1  | KENTEL_U |                | EHIPLANE_1  | Interface_1       | None     | None  | None       | - Fractured | Off      |
| Channel_0  |          |                | EHIPLANE_0  | Interface_0       | None     | None  | None       |             | Off      |
|            |          |                |             |                   |          |       |            |             |          |

• The FEC mode is set to fractured mode.







### Three Channels 10GE/25GE with RS-FEC and PTP Variant in Intel Agilex Devices

When RS-FEC and PTP are enabled, place the RS-FEC channel next to the PTP channels. The supported PTP channel locations for this variant are:

- Channel\_4/5 when using EHIP\_CORE0 •
- Channel 6/7 when using EHIP\_CORE1 ٠
- Channel 16/17 when using EHIP\_CORE2 .
- Channel 18/19 when using EHIP\_CORE3 ٠

- Select Core Variant: 100GE or 1 to 4 10GE/25GE with optional RSFEC and 1588 PTP
- Number of Channels of 10GE/25GE: 3 Channels
- Active Channel(s) at startup: 10G/25GE Channel(s)
- Enable IEEE 1588 PTP: Selected
- Enable RSFEC: Selected
- When IEEE1588/PTP channel placement restriction is set to EHIP0/2(EHIP\_CORE\_0/EHIP\_CORE2), the First RSFEC Lane should set to first\_lane1(channel\_3 or channel\_15).
- When IEEE1588/PTP channel placement restriction is set to ٠ EHIP1/3(EHIP\_CORE\_1/EHIP\_CORE3), the First RSFEC Lane should set to first\_lane0(channel\_8 or channel\_20).
- The FEC mode is set to fractured mode. ٠





|            | Inte     | l® E-tile Floo | r Plan      |                   |          | Char  | nnel Setti | ngs         |          |
|------------|----------|----------------|-------------|-------------------|----------|-------|------------|-------------|----------|
| XCVR PMA   | RSFEC    | EHIP_          | тор         | Core<br>Interface | Protocol | Level | Rate       | FEC mode    | RSFEC    |
| Channel_23 |          |                | EHIPLANE_23 | Interface_23      | None     | None  | None       |             | Off      |
| Channel_22 |          |                | EHIPLANE_22 | Interface_22      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_21 | RESPEC_5 | 5100 0005 0    | EHIPLANE_21 | Interface_21      | Ethernet | NRZ   | 25.78G     | Fractured   | 528, 514 |
| Channel_20 |          | EHIP_CORE_3    | EHIPLANE_20 | Interface_20      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_19 |          |                | EHIPLANE_19 | Interface_19      | РТР      | None  | None       |             | Off      |
| Channel_18 | 050550 4 |                | EHIPLANE_18 | Interface_18      | РТР      | None  | None       | Off         | Off      |
| Channel_17 | RESFEC_4 |                | EHIPLANE_17 | Interface_17      | РТР      | None  | None       | Uff         | Off      |
| Channel_16 |          |                | EHIPLANE_16 | Interface_16      | РТР      | None  | None       |             | Off      |
| Channel_15 |          |                | EHIPLANE_15 | Interface_15      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_14 | RESFEC 3 | EHIP_CORE_2    | EHIPLANE_14 | Interface_14      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_13 | KESFEL S |                | EHIPLANE_13 | Interface_13      | Ethernet | NRZ   | 25.78G     | Fractured   | 528, 514 |
| Channel_12 |          |                | EHIPLANE_12 | Interface_12      | None     | None  | None       | 1           | Off      |
| Channel_11 |          |                | EHIPLANE_11 | Interface_11      | None     | None  | None       |             | Off      |
| Channel_10 |          |                | EHIPLANE_10 | Interface_10      | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_9  | RESFEC 2 |                | EHIPLANE_9  | Interface_9       | Ethernet | NRZ   | 25.78G     | Fractured   | 528, 514 |
| Channel_8  |          | EHIP_CORE_1    | EHIPLANE_8  | Interface_8       | Ethernet | NRZ   | 25.78G     | ]           | 528, 514 |
| Channel_7  |          |                | EHIPLANE_7  | Interface_7       | РТР      | None  | None       |             | Off      |
| Channel_6  | DECECC 1 |                | EHIPLANE_6  | Interface_6       | РТР      | None  | None       | Off         | Off      |
| Channel_5  | RESFEC_1 |                | EHIPLANE_5  | Interface_5       | РТР      | None  | None       |             | Off      |
| Channel_4  |          |                | EHIPLANE_4  | Interface_4       | РТР      | None  | None       |             | Off      |
| Channel_3  |          |                | EHIPLANE_3  | Interface_3       | Ethernet | NRZ   | 25.78G     |             | 528, 514 |
| Channel_2  | RESEEC 0 |                | EHIPLANE_2  | Interface_2       | Ethernet | NRZ   | 25.78G     | Frantiured  | 528, 514 |
| Channel_1  | KCOFEL_U |                | EHIPLANE_1  | Interface_1       | Ethernet | NRZ   | 25.78G     | - Fractured | 528, 514 |
| Channel_0  |          |                | EHIPLANE_0  | Interface_0       | None     | None  | None       |             | Off      |

### Four Channels 10GE/25GE with RS-FEC and PTP Variant

When RS-FEC and PTP are enabled, place the RS-FEC channel next to the PTP channels. The supported PTP channel locations for this variant are:

- Channel\_4/5 when using EHIP\_CORE0
- Channel 6/7 when using EHIP\_CORE1
- Channel 16/17 when using EHIP\_CORE2
- Channel 18/19 when using EHIP\_CORE3

- Select Core Variant: 100GE or 1 to 4 10GE/25GE with optional RSFEC and 1588 PTP
- Number of Channels of 10GE/25GE: 4 Channels
- Active Channel(s) at startup: 10G/25GE Channel(s)



- Enable IEEE 1588 PTP: Selected
- Enable RSFEC: Selected
- **IEEE1588/PTP** channel placement restriction: EHIP0/2(EHIP\_CORE\_0/ EHIP\_CORE2) or EHIP1/3(EHIP\_CORE\_1/EHIP\_CORE3)
- First RSFEC Lane: first\_lane0
- The FEC mode is set to fractured mode.

|            | Inte     | l® E-tile Floo | r Plan      |                   |          | Char  | nnel Setti | ngs       |          |
|------------|----------|----------------|-------------|-------------------|----------|-------|------------|-----------|----------|
| XCVR PMA   | RSFEC    | EHIP_          | ТОР         | Core<br>Interface | Protocol | Level | Rate       | FEC mode  | RSFEC    |
| Channel_23 |          |                | EHIPLANE_23 | Interface_23      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_22 |          |                | EHIPLANE_22 | Interface_22      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_21 | RESPEC_5 |                | EHIPLANE_21 | Interface_21      | Ethernet | NRZ   | 25.78G     | Fractured | 528, 514 |
| Channel_20 |          | EHIP_CORE_3    | EHIPLANE_20 | Interface_20      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_19 |          |                | EHIPLANE_19 | Interface_19      | РТР      | None  | None       |           | Off      |
| Channel_18 |          |                | EHIPLANE_18 | Interface_18      | РТР      | None  | None       |           | Off      |
| Channel_17 | RESFEC_4 |                | EHIPLANE_17 | Interface_17      | РТР      | None  | None       | Off       | Off      |
| Channel_16 |          |                | EHIPLANE_16 | Interface_16      | РТР      | None  | None       |           | Off      |
| Channel_15 |          |                | EHIPLANE_15 | Interface_15      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_14 |          | EHIP_CORE_2    | EHIPLANE_14 | Interface_14      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_13 | RESFEC 3 |                | EHIPLANE_13 | Interface_13      | Ethernet | NRZ   | 25.78G     | Fractured | 528, 514 |
| Channel_12 |          |                | EHIPLANE_12 | Interface_12      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_11 |          |                | EHIPLANE_11 | Interface_11      | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_10 |          |                | EHIPLANE_10 | Interface_10      | Ethernet | NRZ   | 25.78G     | 1         | 528, 514 |
| Channel_9  | RESPEC 2 |                | EHIPLANE_9  | Interface_9       | Ethernet | NRZ   | 25.78G     | Fractured | 528, 514 |
| Channel_8  |          | EHIP_CORE_1    | EHIPLANE_8  | Interface_8       | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_7  |          |                | EHIPLANE_7  | Interface_7       | РТР      | None  | None       |           | Off      |
| Channel_6  | 000000 4 |                | EHIPLANE_6  | Interface_6       | РТР      | None  | None       |           | Off      |
| Channel_5  | RESFEC_1 |                | EHIPLANE_5  | Interface_5       | РТР      | None  | None       | Off       | Off      |
| Channel_4  |          |                | EHIPLANE_4  | Interface_4       | РТР      | None  | None       |           | Off      |
| Channel_3  |          | 5111D CODE -   | EHIPLANE_3  | Interface_3       | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_2  |          |                | EHIPLANE_2  | Interface_2       | Ethernet | NRZ   | 25.78G     |           | 528, 514 |
| Channel_1  | RESPEC_0 |                | EHIPLANE_1  | Interface_1       | Ethernet | NRZ   | 25.78G     | Fractured | 528, 514 |
| Channel_0  |          |                | EHIPLANE_0  | Interface_0       | Ethernet | NRZ   | 25.78G     | 1         | 528, 514 |
|            |          |                |             |                   |          |       |            |           | ·        |

### 2.7.4.2. Pin Assignments

When you integrate your E-Tile Hard IP for Ethernet Intel FPGA IP core instance in your design, you must make appropriate pin assignments. You can create a virtual pin to avoid making specific pin assignments for top-level signals until you are ready to map the design to hardware.





Intel Stratix 10 E-tile devices offer four instances of the hard IP on each E-tile. Each instance offers one 100G channel and six 10G/25G channels. Your design must not include pin assignments that conflict with its location. In devices with multiple E-tiles, you can specify the E-tile to which the Ethernet link serial pins should map.

### **Related Information**

### Quartus Prime Help

For information about the Quartus Prime software, including virtual pins and the IP Catalog.

### 2.7.4.3. Clock Requirements

The E-Tile Hard IP for Ethernet Intel FPGA IP provides locally generated PLL clocks used for RX and TX datapath, and recovered clocks to enable Synchronous Ethernet (SyncE).

For synchronized-mode operation, ensure that the output clock, o\_clk\_pll\_div64, drives both the i\_clk\_rx and the i\_clk\_tx input clocks. If you generate multiple IP core instances, each channel connects to its clock output (o\_clk\_pll\_div64).

For any PTP variants, Intel recommends using the clock output from PTP channel adjacent to the data channel. For example, in a three-channel 25G design for EHIP\_CORE0/2, your design must use the clock output from the PTP channel adjacent to channel 3. Similarly, for EHIP\_CORE1/3, use clock output from the PTP channel next to channel 0.

### **Related Information**

Clocks on page 140

### 2.7.4.4. External Time-of-Day Module for Variations with 1588 PTP Feature

E-Tile Hard IP for Ethernet Intel FPGA IP configurations that include the 1588 PTP module require an external time-of-day (TOD) module to provide a continuous flow of current time-of-day information. You need to instantiate the TOD module from the IP Catalog and add it to your design. The TOD module must update the time-of-day output value on every clock cycle, and must provide the TOD value in the V2 format (96 bits) or the 64-bit TOD format, or both.

The design example you can generate for your IP core PTP variation includes a TOD module, implemented as two distinct, TOD modules, one connected to the TX MAC and one connected to the RX MAC.





#### Table 13. **TOD Module Required Connections**

Required connections for TOD module, listed using signal names for TOD modules that provide both a 96-bit TOD and a 64-bit TOD. If you create your own TOD module it must have the output signals required by the E-Tile Hard IP for Ethernet Intel FPGA IP. However, its signal names could be different than the TOD module signal names in the table. The signals that the IP core includes depend on the Enable 96b Time of Day Format and Enable 64b Time of Day Format parameters. For example, an RX TOD module might require only a 96-bit TOD out signal.

| TOD Module Signal                        | E-Tile Hard IP for Ethernet Intel FPGA IP Design Example Signal                                                          |
|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| rst_txmac (input)                        | Drive this signal from the same source as the reset_async input signal to the E-Tile Hard IP for Ethernet Intel FPGA IP. |
| rst_rxmac (input)                        | Drive this signal from the same source as the reset_async input signal to the E-Tile Hard IP for Ethernet Intel FPGA IP. |
| <pre>tod_txmclk_96b[95:0] (output)</pre> | <pre>tx_time_of_day_96b_data[95:0] (input)</pre>                                                                         |
| <pre>tod_txmclk_64b[63:0] (output)</pre> | <pre>tx_time_of_day_64b_data[63:0] (input)</pre>                                                                         |
| <pre>tod_rxmclk_96b[95:0] (output)</pre> | <pre>rx_time_of_day_96b_data[95:0] (input)</pre>                                                                         |
| tod_rxmclk_64b[63:0] (output)            | <pre>rx_time_of_day_64b_data[63:0] (input)</pre>                                                                         |
| clk_txmac (input)                        | clk_txmac (output)                                                                                                       |
| clk_rxmac (input)                        | clk_rxmac (output)                                                                                                       |

### **Related Information**

- E-Tile Hard IP for Ethernet Intel Stratix 10 FPGA IP Design Example User Guide
- E-Tile Hard IP for Ethernet Intel Agilex FPGA IP Design Example User Guide
- Ethernet Design Example Components User Guide Information about the Ethernet IEEE 1588 Time of Day Clock Intel FPGA IP.

## 2.7.5. IP Core Testbenches

Intel provides a compilation-only design example and a testbench that you can generate for the E-Tile Hard IP for Ethernet Intel FPGA IP.

To generate the testbench, in the E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor, you must first set the parameter values for the IP core variation you intend to generate in your end product. If you do not set the parameter values for your DUT to match the parameter values in your end product, the testbench you generate does not exercise the IP core variation you intend.

The testbench demonstrates a basic test of the IP core. It is not intended to be a substitute for a full verification environment.

### **Related Information**

- E-Tile Hard IP for Ethernet Intel Stratix 10 FPGA IP Design Example User Guide
- E-Tile Hard IP for Ethernet Intel Agilex FPGA IP Design Example User Guide

## 2.7.6. Compiling the Full Design

You can use the Start Compilation command on the Processing menu in the Intel Quartus Prime Pro Edition software to compile your design.





### **Related Information**

- Block-Based Design Flows
- Programming Intel FPGA Devices

## 2.8. E-Tile Hard IP for Ethernet Intel FPGA IP Parameters

### **Related Information**

- E-Tile Hard IP for Ethernet Intel Stratix 10 FPGA IP Design Example User Guide
- E-Tile Hard IP for Ethernet Intel Agilex FPGA IP Design Example User Guide

### 2.8.1. Parameter Editor Parameters

The E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor provides the parameters you can set to configure your E-Tile Hard IP for Ethernet Intel FPGA IP variation and simulation and hardware design examples.

The E-Tile Hard IP for Ethernet Intel FPGA IP parameter has three tabs, an **IP** tab, 10GE/25GE and/or 100GE Tab, and an **Example Design** tab. For information about the **Example Design** tab, refer to the *E-Tile Hard IP for Ethernet Intel FPGA IP Design Example User Guide*.

### Table 14. E-Tile Hard IP for Ethernet Intel FPGA IP Parameters: IP Tab

This table does not provide information about invalid parameter value combinations. If you make selections that create a conflict, the parameter editor generates error messages in the **System Messages** pane.

| Parameter                          | Range                                                                                                                                                                                                                                                                | Default Setting         | Parameter Description                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Core Options                       |                                                                                                                                                                                                                                                                      |                         |                                                                                                                                                                                                                                                                                                                                                                                                  |
| Select Core Variant                | <ul> <li>Single 10GE/25GE</li> <li>1 to 4 10GE/25GE<br/>with optional<br/>RSFEC</li> <li>Single 100GE with<br/>optional RSFEC</li> <li>100GE or 1 to 4<br/>10GE/25GE with<br/>optional RSFEC<br/>and 1588 PTP</li> <li>Custom PCS with<br/>optional RSFEC</li> </ul> | Single 10GE/25GE        | Select a variant of the E-tile Ethernet core with<br>the types of channels required.<br>If you choose the <b>100GE or 1 to 4 10GE/</b><br><b>25GE with optional RS-FEC and 1588 PTP</b><br>variant, you can select to use a 100GE channel<br>or 1 to 4 10GE/25GE channels with or without<br>RS-FEC and/or IEEE 1588 timestamps. These<br>options are switchable at compile time or run<br>time. |
| Number of Channels<br>of 10GE/25GE | <ul><li>Single Channel</li><li>2 Channels</li><li>3 Channels</li><li>4 Channels</li></ul>                                                                                                                                                                            | Single Channel          | Set the number of channels when you select<br>variants that allow 1 to 4 channels.<br>Resources such as RS-FEC and PTP are more<br>efficient if shared. If your design requires<br>multiple 10GE/25GE channels, consider<br>increasing the number of channels in the core<br>to share resources more efficiently.                                                                                |
| Active Channel(s) at<br>startup    | <ul> <li>10GE/25GE<br/>Channel(s)</li> <li>100GE Channel</li> </ul>                                                                                                                                                                                                  | 10GE/25GE<br>Channel(s) | If you choose the <b>100GE or 1 to 4 10GE/</b><br><b>25GE with optional RS-FEC and 1588 PTP</b> ,<br>select the channel (100GE or 10GE/25GE) to be<br>connected to the transceivers at start-up.                                                                                                                                                                                                 |
| Enable IEEE 1588<br>PTP            | <ul><li>On</li><li>Off</li></ul>                                                                                                                                                                                                                                     | Off                     | Turn on this parameter to add IEEE 1588 PTP<br>Timestamp offload functions to the core. The<br>core can generate 1-step or 2-step TX<br>timestamps and RX timestamps.                                                                                                                                                                                                                            |
|                                    |                                                                                                                                                                                                                                                                      |                         | continued                                                                                                                                                                                                                                                                                                                                                                                        |



| Parameter                                        | Range                                                                                                                  | Default Setting   | Parameter Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                  |                                                                                                                        |                   | This option supports 10/25G and 100G with<br>RS-FEC(528,514) variants.<br><i>Note:</i> For 10/25G variants, user transmitted<br>PTP packets must be more than 32<br>bytes, or else it may break the                                                                                                                                                                                                                                                                                                                                                       |
|                                                  |                                                                                                                        |                   | functionality of the IP core.<br>Note: 25G with PTP supports only single<br>channel variants if you enable auto-<br>negotiation and link training feature.<br>Note: Timestamps require some soft logic. To<br>enable the soft logic. Connect the core<br>to a PTP Time-of-Day module that<br>produces TOD values using the 96b                                                                                                                                                                                                                            |
| IEEE1588/PTP<br>channel placement<br>restriction | <ul> <li>EHIP0/2</li> <li>EHIP1/3</li> </ul>                                                                           | EHIP0/2           | IEEE 1588v2 time format.<br>Selects the Ethernet Hard IP core to be used<br>when PTP is enabled. This selection determines<br>the PTP channel placement within an E-tile<br>transceiver:<br>• EHIP0/2 uses PTP channel 4,5,16, and 17<br>• EHIP1/3 uses PTP channel 6,7,18, and 19                                                                                                                                                                                                                                                                        |
| Enable RS-FEC                                    | • On<br>• Off                                                                                                          | Off               | Turn on this parameter to include additional<br>hard logic to perform Reed-Solomon Forward<br>Error Correction (RS-FEC).<br><i>Note:</i> 25G with RS-FEC supports only single<br>channel variants when you enable auto-<br>negotiation and link training feature<br>unless <b>Enable external AIB clocking</b><br>is enabled. This feature is not supported<br>for 10G variants.                                                                                                                                                                          |
| First RSFEC Lane                                 | <ul><li>first_lane0</li><li>first_lane1</li><li>first_lane2</li><li>first_lane3</li></ul>                              | first_lane0       | Selects the first RS-FEC lane to be used. There<br>are four lanes in the RS-FEC block. When the<br>RS-FEC block is in fractured mode, any of the<br>four lanes may be selected as the first lane. For<br>multiple channel Native PHY IP core instances<br>with the RS-FEC block enabled, the RS-FEC<br>lanes used must be contiguous and must fit<br>within a single four-channel RS-FEC block.                                                                                                                                                           |
| RSFEC Clocking<br>Mode                           | <ul> <li>fec_dir_adp_clk_0</li> <li>fec_dir_adp_clk_1</li> <li>fec_dir_adp_clk_2</li> <li>fec_dir_adp_clk_3</li> </ul> | fec_dir_adp_clk_0 | Sets the clocking mode for the RS-FEC block.<br>For RS-FEC with PTP enabled topologies, the<br>clock selection is fixed. In all other cases, this<br>control selects the TX adapter clock used to<br>clock the RS-FEC block.                                                                                                                                                                                                                                                                                                                              |
| Enable AN/LT                                     | • On<br>• Off                                                                                                          | Off               | Turn on this parameter to enable the IP core to<br>support auto-negotiation as defined in <i>IEEE</i><br><i>Standard 802.3-2015</i> Clause 73 and the<br><i>25G/50G Ethernet Consortium Schedule Draft</i><br><i>1-6</i> , and link training as defined in <i>IEEE</i><br><i>Standard 802.3-2015</i> Clauses 92 and 93 and<br>the <i>25G/50G Ethernet Consortium Schedule</i><br><i>Draft 1-6</i> .<br><i>Note:</i> Multi-channel 25GE with RS-FEC with<br><b>Enable AN/LT</b> is supported only if<br><b>Enable external AIB clocking</b> is<br>enabled. |
| Enable external AIB<br>clocking                  | • On<br>• Off                                                                                                          | Off               | Turn on this parameter to enable additional<br>i_clk_aib and i_clk_aib_2x signals to<br>allow external clock sources to drive the<br>datapath in the EHIP core and the EMIB block.<br>Enables this option for the multi-channel 25G<br>with RS-FEC when <b>Enable AN/LT</b> is set.                                                                                                                                                                                                                                                                       |
|                                                  |                                                                                                                        |                   | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                  |                                                                                                                        |                   | continucum                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |





| Parameter                               | Range                                                                      | Default Setting | Parameter Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------|----------------------------------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                         |                                                                            |                 | Important: When you enable this parameter in<br>multi channels 25G variants,<br>triggering a reset to the master<br>channel's EMIB interface impacts<br>the slave channels operation.                                                                                                                                                                                                                                                                                                                                                                                     |
| AN/LT Options                           |                                                                            |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Auto-Negotiation                        |                                                                            |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Enable Auto-<br>Negotiation on<br>Reset | • On<br>• Off                                                              | On              | If this parameter is turned on, the IP core is<br>configured after reset to implement auto-<br>negotiation as defined in Clause 73 of <i>IEEE Std</i><br><i>802.3–2015</i> . If this parameter is turned off, the<br>IP core does not perform the auto-negotiation<br>after reset. Instead, the auto-negotiation can<br>be re-enabled by control and status register<br>(CSR) setting.                                                                                                                                                                                    |
| Link Fail Inhibit<br>Time               | 100-4000 ms                                                                | 504 ms          | Specifies the time before link status is set to<br>FAIL or OK. A link fails if the time duration<br>specified by this parameter expires before link<br>status is set to OK. For more information, refer<br>to <i>Clause 73 Auto-Negotiation for Backplane</i><br><i>Ethernet</i> in <i>IEEE Standard 802.3–2015</i> .<br>The IP core asserts the o_rx_pcs_ready<br>signal to indicate link status is OK.<br>In simulation, the default value is 504<br>corresponds to 1.6 ms.<br>In hardware, the default value for variants with<br>RS-FEC(544,514) is set to 3 seconds. |
| Advertise CR<br>Technology Ability      | • On<br>• Off                                                              | On              | If this parameter is turned on, the IP core<br>advertises CR capability by default. If this<br>parameter is turned off, but auto-negotiation is<br>turned on, the IP core advertises KR capability<br>by default.                                                                                                                                                                                                                                                                                                                                                         |
| Request RSFEC                           | • On<br>• Off                                                              | On              | Turn on this parameter to request RSFEC from<br>remote link partner during auto-negotiation.<br>This parameter must be turned on when<br><b>Enable RSFEC</b> is on in order to use KR<br>functionality.                                                                                                                                                                                                                                                                                                                                                                   |
| Enable Dynamic<br>RSFEC for KR          | • On<br>• Off                                                              | Off             | When selected, IP enables the ability to switch from RS-FEC Enabled Mode to RS-FEC Disabled Mode.         Note: Only available if Enable RSFEC is selected. In 25G variants, First RSFEC Lane must be set to first_lane0.                                                                                                                                                                                                                                                                                                                                                 |
| Auto-Negotiation<br>Master              | <ul> <li>Lane 0</li> <li>Lane 1</li> <li>Lane 2</li> <li>Lane 3</li> </ul> | Lane 0          | Selects the master channel for auto-<br>negotiation.<br>The IP core allows you to change the master<br>channel dynamically by configuring the CSR<br>setting. Available in 100G modes.<br>In 100G PAM4 mode, the valid selections are<br>Lane0 and Lane2.                                                                                                                                                                                                                                                                                                                 |
| Advertise both 10G<br>and 25G during AN | On     Off                                                                 | Off             | Turn on this parameter to advertise 10 and 25<br>Gbps data rate during auto-negotiation. When<br>this parameter is turned off, the IP core<br>advertises only the data rate specified in the<br><b>Select Ethernet Rate</b> parameter in the 10GE/<br>25GE tab.                                                                                                                                                                                                                                                                                                           |
|                                         |                                                                            | ·               | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |



| Parameter                                     | Range                            | Default Setting | Parameter Description                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------------------------------|----------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                               |                                  |                 | This parameter is not available with Single<br>100GE with optional RSFEC variant or when<br>100GE Channel is selected as Active<br>Channel(s) at startup.<br>This feature is not compatible with the PTP, RS-<br>FEC, or external AIB clocking.                                                                                                                                                                                |
| Advertise Pause<br>ability                    | • On<br>• Off                    | On              | If this parameter is turned on, the IP core<br>indicates on the Ethernet link that it supports<br>symmetric pauses as defined in <i>Annex 28B</i> of<br>Section 2 of <i>IEEE Std 802.3–2015</i> .                                                                                                                                                                                                                              |
| Advertise Pause<br>ASM_DIR ability            | <ul><li>On</li><li>Off</li></ul> | On              | If this parameter is turned on, the IP core indicates on the Ethernet link that it supports asymmetric pauses as defined in <i>Annex 28B</i> of Section 2 of <i>IEEE Std 802.3–2015</i> .                                                                                                                                                                                                                                      |
| Link Training: Genera                         | l                                |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Enable Link Training<br>on Reset              | On     Off                       | On              | If this parameter is turned on, the IP core is configured after reset to perform link training, which configures the remote link partner TX PMD for the lowest Bit Error Rate (BER). LT is defined in Clause 92 of <i>IEEE Std 802.3–2015</i> .                                                                                                                                                                                |
| Configuration, Debug                          | and Extension Options            | 5               |                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Enable Native PHY<br>Debug Master<br>Endpoint | • On<br>• Off                    | On              | If this parameter is turned on, the Transceiver<br>Native PHY IP includes an embedded Native<br>PHY Debug Master Endpoint that connects<br>internally to the Avalon memory-mapped slave<br>interface for dynamic reconfiguration. The<br>Native PHY Debug Master Endpoint can access<br>the reconfiguration space of the transceiver. It<br>can perform certain test and debug functions<br>via JTAG using the System Console. |
| Enable JTAG to<br>Avalon Master<br>Bridge     | • On<br>• Off                    | Off             | Turn on this parameter to enable an internal<br>JTAG connection to the Avalon memory-<br>mapped Master Bridge for register<br>reconfigurations. This connection allows the<br>System Console to run the Ethernet Link<br>Inspector.                                                                                                                                                                                            |

#### Table 15. E-Tile Hard IP for Ethernet Intel FPGA IP Parameters: 10GE/25GE Tab

This table does not provide information about invalid parameter value combinations. If you make selections that create a conflict, the parameter editor generates error messages in the **System Messages** pane.

| Parameter                    | Range                                                                                                    | Default Setting | Parameter Description                                                                                                             |
|------------------------------|----------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------|
| General Options 10G          | E/25GE                                                                                                   |                 |                                                                                                                                   |
| Select Ethernet<br>Rate      | • 10G<br>• 25G                                                                                           | 25G             | Selects the IP core Ethernet data rate.                                                                                           |
| Select Ethernet IP<br>Layers | When Enable RSFEC<br>and Enable IEEE<br>1588 PTP are off:<br>• MAC+PCS<br>• PCS Only<br>• OTN<br>• FlexE | MAC+PCS         | Selects the Ethernet Protocol layers provided<br>by the channel.<br><i>Note:</i> RS-FEC is not supported in the 10G data<br>rate. |
|                              | <u>.</u>                                                                                                 |                 | continued                                                                                                                         |





| Parameter                                           | Range                                                                                                                                                        | Default Setting        | Parameter Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                     | When Enable RSFEC<br>is ON and Enable<br>IEEE 1588 PTP is<br>OFF:<br>• MAC+PCS+RS-FEC<br>• PCS+RS-FEC<br>• OTN+RS-FEC<br>• FlexE+RS-FEC<br>When Enable RSFEC | MAC+PCS+RS-FEC         | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                     | and Enable IEEE<br>1588 PTP are on:<br>• MAC+PTP+PCS<br>+RS-FEC                                                                                              | +RSFEC                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Include alternate<br>ports                          | • On<br>• Off                                                                                                                                                | Off                    | This is an advanced option for applications that<br>need to change the active Ethernet IP layers at<br>run-time. When you turn on this option, all<br>possible datapath interfaces are included in the<br>core, and the active interface depends on the<br>control and status register (CSR) setting.                                                                                                                                                                                               |
| MAC Options: Basic 10<br>Note: In PCS Only, OTN,    | <b>DGE/25GE</b><br>, and FlexE variations, the                                                                                                               | ese parameters have no | effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| TX Maximum Frame<br>Size                            | 65-65535                                                                                                                                                     | 1518                   | Maximum packet size (in bytes) the IP core can<br>transmit on the Ethernet link without reporting<br>an oversized packet in the TX statistics<br>counters.<br>In variations without MAC, this parameter has<br>no effect and remains at the default value of<br>1518.                                                                                                                                                                                                                               |
| RX Maximum Frame<br>Size                            | 65-65535                                                                                                                                                     | 1518                   | Maximum packet size (in bytes) the IP core can<br>receive on the Ethernet link without reporting<br>an oversized packet in the RX statistics<br>counters. If you turn on the <b>Enforce</b><br><b>Maximum Frame Size</b> parameter, the IP core<br>truncates incoming Ethernet packets that<br>exceed this size.<br>In variations without MAC, this parameter has<br>no effect and remains at the default value of<br>1518.                                                                         |
| Enforce Maximum<br>Frame Size                       | • On<br>• Off                                                                                                                                                | Off                    | Specifies whether the IP core is able to receive an oversized packet or truncates these packets.                                                                                                                                                                                                                                                                                                                                                                                                    |
| Choose Link Fault<br>Generation Mode                | <ul> <li>OFF</li> <li>Unidirectional</li> <li>Bidirectional</li> </ul>                                                                                       | Bidirectional          | Specifies the IP core response to link fault<br>events.<br>Bidirectional link fault handling complies with<br>the Ethernet specification, specifically IEEE<br>802.3 Figure 81-11. Unidirectional link fault<br>handling implements IEEE 802.3 Clause 66: in<br>response to local faults, the IP core transmits<br>Remote Fault ordered sets in interpacket gaps<br>but does not respond to incoming Remote Fault<br>ordered sets. The <b>OFF</b> option is provided for<br>backward compatibility. |
| Stop TX traffic when<br>link partner sends<br>pause | <ul> <li>Yes</li> <li>No</li> <li>Disable Flow<br/>Control</li> </ul>                                                                                        | No                     | Selects whether the IP core responds to PAUSE<br>frames from the Ethernet link by stopping TX<br>traffic, or not. This parameter has no effect if<br>flow control is disabled. If you disable flow<br>control, the IP core neither responds to<br>incoming PAUSE and PFC frames nor generates<br>outgoing PAUSE and PFC frames.                                                                                                                                                                     |
|                                                     |                                                                                                                                                              |                        | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |



| Parameter                         | Range                                                                                    | Default Setting  | Parameter Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------|------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                   |                                                                                          |                  | If this parameter has the value of $No$ , you can<br>use the i_tx_pause signal on the TX client<br>interface to force the TX MAC to stop TX traffic.<br>Bytes to remove from RX frames                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bytes to remove<br>from RX frames | <ul> <li>None</li> <li>Remove CRC bytes</li> <li>Remove CRC and<br/>PAD bytes</li> </ul> | Remove CRC bytes | You can set for the RX MAC to remove CRC<br>and/or PAD bytes from incoming RX frames<br>before passing the bytes to the RX MAC Client.<br>If the PAD and CRC bytes are not needed<br>downstream, the remove option can reduce the<br>need for downstream packet processing logic.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Forward RX Pause<br>Requests      | • On<br>• Off                                                                            | Off              | Selects whether the RX MAC forwards incoming<br>PAUSE and PFC frames on the RX client<br>interface, or drops them after internal<br>processing.<br><i>Note:</i> If flow control is turned off, the IP core<br>forwards all incoming PAUSE and PFC<br>frames directly to the RX client interface<br>and performs no internal processing. In<br>that case this parameter has no effect.                                                                                                                                                                                                                                                                                                                         |
| Use Source Address<br>Insertion   | • On<br>• Off                                                                            | Off              | Selects whether the IP core supports<br>overwriting the source address in an outgoing<br>Ethernet packet with the value in the<br>TXMAC_SADDR registers at offsets 0x40C and<br>0x40D. If the parameter is turned on, the IP<br>core overwrites the packet source address from<br>the register if i_tx_skip_crc has the value<br>of 0. If the parameter is turned off, the IP core<br>does not overwrite the source address.<br>Source address insertion applies to PAUSE and<br>PFC packets provided on the TX MAC client<br>interface, but does not apply to PAUSE and PFC<br>packets the IP core transmits in response to<br>the assertion of i_tx_pause or i_tx_pfc[n]<br>on the TX MAC client interface. |
| Enable TX VLAN<br>Detection       | • On<br>• Off                                                                            | On               | Specifies whether the IP core TX statistics block<br>treats TX VLAN and Stacked VLAN Ethernet<br>frames as regular control frames, or performs<br>Length/Type field decoding, includes these<br>frame in VLAN statistics, and counts the<br>payload bytes instead of the full Ethernet frame<br>in the TxFrameOctetsOK counter at offsets<br>0x862 and 0x863. If turned on, the IP core<br>identifies these frames in TX statistics as VLAN<br>or Stacked VLAN frames. If turned off, the IP<br>core treats these frames as regular control<br>frames.                                                                                                                                                        |
| Enable RX VLAN<br>Detection       | • On<br>• Off                                                                            | On               | Specifies whether the IP core RX statistics block<br>treats RX VLAN and Stacked VLAN Ethernet<br>frames as regular control frames, or performs<br>Length/Type field decoding, includes these<br>frame in VLAN statistics, and counts the<br>payload bytes instead of the full Ethernet frame<br>in the RxFrameOctetsOK counter at offsets<br>0x962 and 0x963. If turned on, the IP core<br>identifies these frames in RX statistics as VLAN<br>or Stacked VLAN frames. If turned off, the IP<br>core treats these frames as regular control<br>frames.                                                                                                                                                        |
| Ready latency                     | 0-3                                                                                      | 0                | Selects the readyLatency value on the TX client<br>interface. readyLatency is an Avalon streaming<br>interface property that defines the number of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                   |                                                                                          | I                | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |





| inspreciation       • Off       i_sl_async_clk_trx and i_sl_async_clk_trx and i_sl_async_clk_trx clocks from different clock sources.         AC Options: Specialized 10GE/25GE       • On       • Off       If turned on, the IP core is in RX and TX preamble pass-through mode, the IP core passes the preamble and SFD to the client instead of stripping them out of the Ethernet packet. In TX preamble pass-through mode, the IP core passes the preamble and SFD to the client instead of stripping them out of the Ethernet packet. In TX preamble pass-through mode, the IP core passes the preamble and SFD to the client instead of stripping them out of the Ethernet packet. In TX preamble pass-through mode, the IP core rejects RX packets whose preamble is not the standard Ethernet preamble closes 555_55_55_55_55_55_55_55_55_55_55_55_55                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Parameter                                  | Range                       | Default Setting        | Parameter Description                                                                                                                                                                                                                                                                                                      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-----------------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| able strict     • On     Off     If turned on, the IP core is in RX and TX preamble to be sent in the Ethernet preamble is not the standard Ethernet preamble is soft through mode, the client specifies the superase that the standard Ethernet transe that the standard Ethernet the standard Ethernet transe that the standard Ethernet trans           |                                            |                             |                        | asserts the o_sl_tx_ready signal to the clock<br>cycle in which the IP core can accept data on<br>the TX client interface. Refer to the Avalon                                                                                                                                                                             |
| able       • On       Off       Turn on if you want to drive         increased latency for the TX datapath in MAC         +PCS variations.       • Off       Turn on if you want to drive         i_sel_async_clk_tx and       i_sel_async_clk_tx and         i_sel_async_clk_tx clocks from different       clock sources.         AC Options: Specialized 10GE/25GE       •         tet: In PCS Only, OTN, and FlexE variations, these parameters have no effect.       •         able preamble       • On       Off       If turned on, the IP core is in RX and TX preamble pass-through mode. In RX preamble pass-through mode. In RX preamble pass-through mode. In RX preamble pass-through mode, the client specifies the preamble apas-through mode. In RX preamble pass-through mode, the client specifies the preamble to be sent in the ethernet frame.         able strict       • On       Off       If turned on, the IP core rejects RX packets whose preamble is not the standard Ethernet preamble (NS5, 55, 55, 55, 55, 55, 55, 55, 55, 55,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                            |                             |                        | parameter has no effect.                                                                                                                                                                                                                                                                                                   |
| inspression       • Off       i_sl_asymc_clk_tx and i_sl_asymc_clk_tx clocks from different clock sources.         AC Options: Specialized 10GE/25GE       • On       • Off       If turned on, the IP core is in RX and TX preamble pass-through mode. In RX preamble pass-through mode, the IP core passes the preamble and SFD to the client instead of stripping them out of the Ethernet packet. In TX preamble pass-through mode, the IP core rejects RX packets whose preamble and SFD to the client instead of stripping them out of the Ethernet packet. In TX preamble pass-through mode, the IP core rejects RX packets whose preamble and SFD to the client instead of stripping them out of the Ethernet packet. In TX preamble pass-through mode, the IP core rejects RX packets whose preamble is not the standard Ethernet preamble (NS5 55, 55 55, 55).         nable strict       • On       Off       If turned on, the IP core rejects RX packets whose SFD type is not the standard Ethernet preamble (NS5 55, 55 55, 55).         nable strict SFD       • On       Off       If turned on, the IP core rejects RX packets whose SFD type is not the standard Ethernet SFD (ND5).         nable strict SFD       • On       Off       If turned on, the IP core rejects RX packets whose SFD type is not the standard Ethernet SFD (ND5).         reage Inter-tcket Gap       • 1       12       Specifies the average minimum inter-packet gap (IPG) the IP core maintains on the TX ethernet Ithm. The default value of 12 comples with the Ethernet standard. The remaining values support increased throughput. The value of 1 specifies the involute minimum IPG.         diditional IPG moved per AM period increases throughput. The value of                                                                                                                                                                                                                                                                                                                   |                                            |                             |                        | eases timing closure at the expense of increased latency for the TX datapath in MAC                                                                                                                                                                                                                                        |
| the:       In PCS Only, OTN, and FlexE variations, these parameters have no effect.         hable preamble<br>sesthrough       • On<br>• Off       Off       If turned on, the IP core is in RX and TX<br>preamble pass-through mode, the IP core passes the<br>preamble and SFD to the client instead of<br>stripping them out of the Ethernet packet. In<br>TX preamble pass-through mode, the client<br>specifies the preamble to be sent in the<br>Ethernet frame.         hable strict<br>eamble check       • On<br>• Off       Off       If turned on, the IP core rejects RX packets<br>whose preamble is not the standard Ethernet<br>preamble is not the standard Ethernet<br>preamble is not the standard Ethernet<br>preamble is purchasses that<br>can occur at startup or when bit errors occur.         hable strict SFD<br>teeck       • On<br>• Off       Off       If turned on, the IP core rejects RX packets<br>whose SFD byte is not the standard Ethernet<br>SFD (0xD5).         thetes<br>tecked Gap       • On<br>• Off       Off       If turned on, the IP core rejects RX packets<br>whose SFD byte is not the standard Ethernet<br>SFD (0xD5).         thetes<br>tecket Gap       • 1       12       Specifies the average minimum inter-packet<br>gap (IPG) the IP core maintains on the TX<br>Ethernet link. The default value of 12 complies<br>with the Ethernet standard. The remaining<br>values support increased throughput. The value<br>of 1 specifies that the IP core does not attempt<br>to control the minimum IPG.         tditional IPG<br>moved per AM<br>priod       Integer       0       Specifies the number of inter-packet gaps the<br>IP core removes per alignment marker period,<br>in addition to the default number required for<br>protocol compliance.       Each increment of 1 in the value                                                                                                                                                                                                                                     | Enable<br>asynchronous<br>adapter clocks   |                             | Off                    | i_sl_async_clk_rx and<br>i_sl_async_clk_tx clocks from different                                                                                                                                                                                                                                                           |
| hable preamble<br>issthrough• On<br>OffOffIf turned on, the IP core is in RX and TX<br>preamble pass-through mode. In RX preamble<br>pass-through mode. In RX preamble<br>pass-through mode. In RX preamble<br>pass-through mode. The VP core passes the<br>preamble pass-through mode, the IP core passes the<br>preamble pass-through mode, the IP core passes the<br>preamble pass-through mode, the IP core passes through<br>through the VP core passes through mode, the client<br>specifies the preamble to be sent in the<br>Ethernet frame.hable strict<br>eamble check• On<br>• OffOffIf turned on, the IP core rejects RX packets<br>whose preamble is not the standard Ethernet<br>preamble (0X55_55_55_55_5).<br>This option provides an additional layer of<br>protection against spurious Start frames that<br>can occur at startup or when bit errors occur.hable strict SFD<br>teck• On<br>• OffOffIf turned on, the IP core rejects RX packets<br>whose SFD byte is not the standard Ethernet<br>SFD (0x5)5.<br>This option provides an additional layer of<br>protection against spurious Start frames that<br>can occur at startup or when bit errors occur.verage Inter-<br>teck• I<br>8<br>8<br>• 10<br>• 121212Specifies the average minimum inter-packet<br>gap (IPG) the IP core maintains on the TX<br>Ethernet Ink. The default value of 12 complies<br>with the Ethernet standard. The remaining<br>values support increased throughput. The value<br>of a specifies that the IP core does not attempt<br>to control the minimum IPG.iditional IPG<br>moved per AM<br>erriodInteger0Specifies the number of inter-packet gaps the<br>IP core removes per alignment marker preiod,<br>in addition to the default number required for<br>protocil compliance.<br>Each increment of 1 in the value of Additional <b< td=""><td>• •</td><td>-</td><td></td><td></td></b<>                                                                                                                                                                                            | • •                                        | -                           |                        |                                                                                                                                                                                                                                                                                                                            |
| assthrough<br>issthrough• OffPreamble pass-through mode. In RX preamble<br>pass-through mode, the IP core passes the<br>pass-through mode, the IP core passes the<br>pass-through mode, the IP core passes the<br>ispecifies the preamble and SFD to the client instead of<br>stripping them out of the Ethernet packet. In<br>TX preamble pass-through mode, the client<br>specifies the preamble to be sent in the<br>Ethernet frame.able strict<br>reamble check• On<br>• OffOffIf turned on, the IP core rejects RX packets<br>whose preamble is not the standard Ethernet<br>preamble (x055_55_55_55_55).<br>This option provides an additional layer of<br>protection against spurious Start frames that<br>can occur at startup or when bit errors occur.able strict SFD<br>reck• On<br>• OffOffIf turned on, the IP core rejects RX packets<br>whose SFD byte is not the standard Ethernet<br>SFD (XDS).<br>This option provides an additional layer of<br>protection against spurious Start frames that<br>can occur at startup or when bit errors occur.verage Inter-<br>teck• 1<br>• 1<br>• 1<br>• 1212Specifies the average minimum inter-packet<br>gap (IPG) the IP core maintains on the TX<br>Ethernet link. The default value of 12 complies<br>with the Ethernet standard. The remaining<br>values support increased throughput. The value<br>of 1 specifies that the IP core does not attempt<br>to control the minimum IPG.iditional IPG<br>moved per AM<br>periodInteger0Specifies the information on the TX<br>Ethernet invest period, increases<br>throughput toreases, use the<br>Average Inter-packet Gap parameter.                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Note: In PCS Only, OTN                     | I, and FlexE variations, th | ese parameters have no | effect.                                                                                                                                                                                                                                                                                                                    |
| reamble check• OffImage: Second | Enable preamble<br>passthrough             |                             | Off                    | preamble pass-through mode. In RX preamble<br>pass-through mode, the IP core passes the<br>preamble and SFD to the client instead of<br>stripping them out of the Ethernet packet. In<br>TX preamble pass-through mode, the client<br>specifies the preamble to be sent in the                                             |
| neck• Offwhose SFD byte is not the standard Ethernet<br>SFD (0xD5).<br>This option provides an additional layer of<br>protection against spurious Start frames that<br>can occur at startup or when bit errors occur.verage Inter-<br>necket Gap• 1<br>8<br>• 10<br>• 1212Specifies the average minimum inter-packet<br>gap (IPG) the IP core maintains on the TX<br>Ethernet link. The default value of 12 complies<br>with the Ethernet standard. The remaining<br>values support increased throughput. The value<br>of 1 specifies that the IP core does not attempt<br>to control the minimum IPG.dditional IPG<br>imoved per AM<br>erriodInteger0Specifies the number of inter-packet gaps the<br>IP core removes per alignment marker period,<br>in addition to the default number required for<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Enable strict<br>preamble check            |                             | Off                    | whose preamble is not the standard Ethernet<br>preamble (0x55_55_55_55_55_55).<br>This option provides an additional layer of<br>protection against spurious Start frames that                                                                                                                                             |
| acket Gap• 8<br>• 10<br>• 12gap (IPG) the IP core maintains on the TX<br>Ethernet link. The default value of 12 complies<br>with the Ethernet standard. The remaining<br>values support increased throughput. The value<br>of 1 specifies that the IP core does not attempt<br>to control the minimum IPG.dditional IPG<br>imoved per AM<br>erriodInteger0Specifies the number of inter-packet gaps the<br>IP core removes per alignment marker period,<br>in addition to the default number required for<br>protocol compliance.<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Enable strict SFD<br>check                 |                             | Off                    | <ul><li>whose SFD byte is not the standard Ethernet<br/>SFD (0xD5).</li><li>This option provides an additional layer of<br/>protection against spurious Start frames that</li></ul>                                                                                                                                        |
| IP core removes per alignment marker period,<br>in addition to the default number required for<br>protocol compliance.<br>Each increment of 1 in the value of Additional<br>IPG removed per AM period increases<br>throughput by 3ppm in 100G variations. To<br>specify larger throughput increases, use the<br>Average Inter-packet Gap parameter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Average Inter-<br>packet Gap               | • 8<br>• 10                 | 12                     | gap (IPG) the IP core maintains on the TX<br>Ethernet link. The default value of 12 complies<br>with the Ethernet standard. The remaining<br>values support increased throughput. The value<br>of 1 specifies that the IP core does not attempt                                                                            |
| VA Ontions 10GF/25F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Additional IPG<br>removed per AM<br>period | Integer                     | 0                      | IP core removes per alignment marker period,<br>in addition to the default number required for<br>protocol compliance.<br>Each increment of 1 in the value of <b>Additional</b><br><b>IPG removed per AM period</b> increases<br>throughput by 3ppm in 100G variations. To<br>specify larger throughput increases, use the |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | PMA Options 10GE/25                        | 5E                          |                        |                                                                                                                                                                                                                                                                                                                            |

continued...



| Parameter                                                       | Range                                                                                            | Default Setting | Parameter Description                                                                                                                                             |
|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PHY Reference<br>Frequency                                      | <ul> <li>156.25 MHz</li> <li>322.265625 MHz</li> <li>312.5 MHz</li> <li>644.53125 MHz</li> </ul> | 322.265625 MHz  | Sets the expected incoming PHY i_clk_ref reference frequency. The input clock frequency must match the frequency you specify for this parameter ( $\pm 100$ ppm). |
|                                                                 |                                                                                                  |                 | <i>Note:</i> If you turn on <b>Enable AN/LT</b> , the required input clock frequency are 156.25 or 312.5 MHz.                                                     |
| Enable custom rate                                              | • On<br>• Off                                                                                    | Off             | Turn on to enable custom rate.                                                                                                                                    |
| Include<br>deterministic<br>latency<br>measurement<br>interface | • On<br>• Off                                                                                    | Off             | Turn on to add deterministic latency interface to the channel.                                                                                                    |

#### Table 16. E-Tile Hard IP for Ethernet Intel FPGA IP Parameters: 100GE Tab

This table does not provide information about invalid parameter value combinations. If you make selections that create a conflict, the parameter editor generates error messages in the **System Messages** pane.

| Parameter                                                                                                  | Range                                                                                                                                                  | Default Setting | Parameter Description                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| General Options                                                                                            | General Options                                                                                                                                        |                 |                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| Select Ethernet<br>Rate                                                                                    | 100G                                                                                                                                                   | 100G            | Selects the IP core Ethernet data rate.                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| Select Ethernet IP<br>Layers                                                                               | <ul> <li>MAC+PCS</li> <li>MAC+PTP+PCS</li> <li>MAC+PCS         <ul> <li>+(528,514) RS-FEC</li> </ul> </li> <li>MAC+PCS             <ul></ul></li></ul> | MAC+PCS         | Selects the Ethernet Protocol layers provided<br>by the channel.<br><i>Note:</i> The E-Tile Hard IP for Ethernet Intel<br>FPGA IP provides preliminary support<br>for the OTN feature. For further<br>inquiries, contact your nearest Intel<br>sales representative or file an Intel<br>Premier Support (IPS) case at https://<br>www.intel.com/content/www/us/en/my-<br>intel/fpga-sign-in.html. |  |  |  |  |
| MAC Options: Basic 100GE<br>Note: In PCS Only, OTN, and FlexE variations, these parameters have no effect. |                                                                                                                                                        |                 |                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| TX Maximum Frame<br>Size                                                                                   | 65–65535                                                                                                                                               | 1518            | Maximum packet size (in bytes) the IP core can<br>transmit on the Ethernet link without reporting<br>an oversized packet in the TX statistics<br>counters.                                                                                                                                                                                                                                        |  |  |  |  |
|                                                                                                            |                                                                                                                                                        |                 | continued                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |





| Parameter                                           | Range                                                                                    | Default Setting  | Parameter Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------------------|------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                     |                                                                                          |                  | In variations without MAC, this parameter has<br>no effect and remains at the default value of<br>1518.                                                                                                                                                                                                                                                                                                                                                                                             |
| RX Maximum Frame<br>Size                            | 65-65535                                                                                 | 1518             | Maximum packet size (in bytes) the IP core can<br>receive on the Ethernet link without reporting<br>an oversized packet in the RX statistics<br>counters. If you turn on the <b>Enforce</b><br><b>Maximum Frame Size</b> parameter, the IP core<br>truncates incoming Ethernet packets that<br>exceed this size.<br>In variations without MAC, this parameter has                                                                                                                                   |
| Enforce Maximum                                     | • On                                                                                     | Off              | no effect and remains at the default value of 1518.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Frame Size                                          | Off                                                                                      |                  | Specifies whether the IP core is able to receive<br>an oversized packet or truncates these packets.                                                                                                                                                                                                                                                                                                                                                                                                 |
| Choose Link Fault<br>Generation Mode                | <ul> <li>OFF</li> <li>Unidirectional</li> <li>Bidirectional</li> </ul>                   | Bidirectional    | Specifies the IP core response to link fault<br>events.<br>Bidirectional link fault handling complies with<br>the Ethernet specification, specifically IEEE<br>802.3 Figure 81-11. Unidirectional link fault<br>handling implements IEEE 802.3 Clause 66: in<br>response to local faults, the IP core transmits<br>Remote Fault ordered sets in interpacket gaps<br>but does not respond to incoming Remote Fault<br>ordered sets. The <b>OFF</b> option is provided for<br>backward compatibility. |
| Stop TX traffic when<br>link partner sends<br>pause | <ul> <li>Yes</li> <li>No</li> <li>Disable Flow<br/>Control</li> </ul>                    | No               | Selects whether the IP core responds to PAUSE frames from the Ethernet link by stopping TX traffic, or not. This parameter has no effect if flow control is disabled. If you disable flow control, the IP core neither responds to incoming PAUSE and PFC frames nor generates outgoing PAUSE and PFC frames.<br>If this parameter has the value of <b>No</b> , you can use the i_tx_pause signal on the TX client interface to force the TX MAC to stop TX traffic.                                |
| Bytes to remove<br>from RX frames                   | <ul> <li>None</li> <li>Remove CRC bytes</li> <li>Remove CRC and<br/>PAD bytes</li> </ul> | Remove CRC bytes | You can set for the RX MAC to remove CRC<br>and/or PAD bytes from incoming RX frames<br>before passing the bytes to the RX MAC Client.<br>If the PAD and CRC bytes are not needed<br>downstream, the remove option can reduce the<br>need for downstream packet processing logic.                                                                                                                                                                                                                   |
| Forward RX Pause<br>Requests                        | • On<br>• Off                                                                            | Off              | Selects whether the RX MAC forwards incoming<br>PAUSE and PFC frames on the RX client<br>interface, or drops them after internal<br>processing.<br><i>Note:</i> If flow control is turned off, the IP core<br>forwards all incoming PAUSE and PFC<br>frames directly to the RX client interface<br>and performs no internal processing. In<br>that case this parameter has no effect.                                                                                                               |
| Use Source Address<br>Insertion                     | • On<br>• Off                                                                            | Off              | Selects whether the IP core supports<br>overwriting the source address in an outgoing<br>Ethernet packet with the value in the<br>TXMAC_SADDR registers at offsets 0x40C and<br>0x40D. If the parameter is turned on, the IP<br>core overwrites the packet source address from<br>the register if i_tx_skip_crc has the value<br>of 0. If the parameter is turned off, the IP core<br>does not overwrite the source address.                                                                        |



| Parameter                                      | Range                                              | Default Setting          | Parameter Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------------|----------------------------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                |                                                    |                          | Source address insertion applies to PAUSE and<br>PFC packets provided on the TX MAC client<br>interface, but does not apply to PAUSE and PFC<br>packets the IP core transmits in response to<br>the assertion of i_tx_pause or i_tx_pfc[n]<br>on the TX MAC client interface.                                                                                                                                                                                                                                                                                                                                         |
| Enable TX VLAN<br>Detection                    | • On<br>• Off                                      | On                       | Specifies whether the IP core TX statistics block<br>treats TX VLAN and Stacked VLAN Ethernet<br>frames as regular control frames, or performs<br>Length/Type field decoding, includes these<br>frame in VLAN statistics, and counts the<br>payload bytes instead of the full Ethernet frame<br>in the TxFrameOctetsOK counter at offsets<br>0x862 and 0x863. If turned on, the IP core<br>identifies these frames in TX statistics as VLAN<br>or Stacked VLAN frames. If turned off, the IP<br>core treats these frames as regular control<br>frames.                                                                |
| Enable RX VLAN<br>Detection                    | • On<br>• Off                                      | On                       | Specifies whether the IP core RX statistics block<br>treats RX VLAN and Stacked VLAN Ethernet<br>frames as regular control frames, or performs<br>Length/Type field decoding, includes these<br>frame in VLAN statistics, and counts the<br>payload bytes instead of the full Ethernet frame<br>in the RxFrameOctetsOK counter at offsets<br>0x962 and 0x963. If turned on, the IP core<br>identifies these frames in RX statistics as VLAN<br>or Stacked VLAN frames. If turned off, the IP<br>core treats these frames as regular control<br>frames.                                                                |
| Enable<br>asynchronous<br>adapter clocks       | • On<br>• Off                                      | Off                      | Turn on if you want to drive i_clk_rx and i_clk_tx clocks from different clock sources.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Ready latency                                  | 0-3                                                | 0                        | Selects the readyLatency value on the TX client<br>interface. readyLatency is an Avalon streaming<br>interface property that defines the number of<br>clock cycles of delay from when the IP core<br>asserts the o_tx_ready signal to the clock<br>cycle in which the IP core can accept data on<br>the TX client interface. Refer to the Avalon<br>Interface Specifications.<br>In PCS Only, OTN, and FlexE variations, this<br>parameter has no effect.<br>Selecting a longer latency (higher number)<br>eases timing closure at the expense of<br>increased latency for the TX datapath in MAC<br>+PCS variations. |
| MAC Options: Special<br>Note: In PCS Only, OTN | I <b>ized 100GE</b><br>I, and FlexE variations, th | ese parameters have no e | effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Enable preamble<br>passthrough                 | On     Off                                         | Off                      | If turned on, the IP core is in RX and TX<br>preamble pass-through mode. In RX preamble<br>pass-through mode, the IP core passes the<br>preamble and SFD to the client instead of<br>stripping them out of the Ethernet packet. In<br>TX preamble pass-through mode, the client<br>specifies the preamble to be sent in the<br>Ethernet frame.                                                                                                                                                                                                                                                                        |
| Enable strict<br>preamble check                | • On<br>• Off                                      | Off                      | If turned on, the IP core rejects RX packets whose preamble is not the standard Ethernet preamble (0x55_55_55_55_55_55).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                |                                                    |                          | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |





| Parameter                                  | Range                                                                                            | Default Setting | Parameter Description                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------|--------------------------------------------------------------------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                            |                                                                                                  |                 | This option provides an additional layer of protection against spurious Start frames that can occur at startup or when bit errors occur.                                                                                                                                                                                                                                                                                                                                   |
| Enable strict SFD<br>check                 | • On<br>• Off                                                                                    | Off             | If turned on, the IP core rejects RX packets<br>whose SFD byte is not the standard Ethernet<br>SFD (0xD5).<br>This option provides an additional layer of<br>protection against spurious Start frames that<br>can occur at startup or when bit errors occur.                                                                                                                                                                                                               |
| Average Inter-<br>packet Gap               | • 1<br>• 8<br>• 10<br>• 12                                                                       | 12              | Specifies the average minimum inter-packet<br>gap (IPG) the IP core maintains on the TX<br>Ethernet link. The default value of 12 complies<br>with the Ethernet standard. The remaining<br>values support increased throughput. The value<br>of 1 specifies that the IP core does not attempt<br>to control the minimum IPG.                                                                                                                                               |
| Additional IPG<br>removed per AM<br>period | Integer                                                                                          | 0               | Specifies the number of inter-packet gaps the<br>IP core removes per alignment marker period,<br>in addition to the default number required for<br>protocol compliance. In 100G variations, the<br>default number is 20.<br>Each increment of 1 in the value of <b>Additional</b><br><b>IPG removed per AM period</b> increases<br>throughput by 3ppm in 100G variations. To<br>specify larger throughput increases, use the<br><b>Average Inter-packet Gap</b> parameter. |
| PMA Options 100GE                          |                                                                                                  |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PHY Reference<br>Frequency                 | <ul> <li>156.25 MHz</li> <li>322.265625 MHz</li> <li>312.5 MHz</li> <li>644.53125 MHz</li> </ul> | 156.25 MHz      | Sets the expected incoming PHY i_clk_ref<br>reference frequency. The input clock frequency<br>must match the frequency you specify for this<br>parameter (±100 ppm).<br>Variants with (544,514) RS-FEC option only<br>support 156.25 MHz and 312.5 MHz PHY<br>i_clk_ref reference frequency.<br><i>Note:</i> If you turn on <b>Enable AN/LT</b> , the<br>required input clock frequency are<br>156.25 or 312.5 MHz.                                                        |

# Table 17.E-Tile Hard IP for Ethernet Intel FPGA IP Parameters: Custom PCS Channel(s)<br/>Tab

Т

This table does not provide information about invalid parameter value combinations. If you make selections that create a conflict, the parameter editor generates error messages in the **System Messages** pane.

| Parameter                         | Range             | Default Setting | Parameter Description                                                                                                                                                                                                      |
|-----------------------------------|-------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCS Core Options                  |                   |                 |                                                                                                                                                                                                                            |
| Number of PCS Channels<br>in core | • 1<br>• 2<br>• 3 | 1               | Set the number of PCS channels you want to implement.                                                                                                                                                                      |
|                                   | • 4               |                 | Resources such as RS-FEC<br>and PTP are more efficient if<br>shared. If your design<br>requires multiple channels,<br>consider increasing the<br>number of channels in the<br>core to share resources<br>more efficiently. |
| PCS General Options               |                   |                 |                                                                                                                                                                                                                            |
|                                   |                   |                 | continued                                                                                                                                                                                                                  |





| Parameter                        | Range                                                                                                                                                                                                                                                                                      | Default Setting | Parameter Description                                                                                                                                           |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Custom PCS mode                  | <ul><li>PCS_Only</li><li>PCS+RS-FEC</li></ul>                                                                                                                                                                                                                                              | PCS_Only        | Selects the Ethernet Protocol layers provided by the channel.                                                                                                   |
| RSFEC Fibre Channel(s)<br>mode   | <ul><li>Disable</li><li>Enable</li></ul>                                                                                                                                                                                                                                                   | Disable         | To enable or disable RS-FEC<br>Fibre Channel mode for<br>custom PCS.                                                                                            |
| Custom PCS Rate                  | 2500 to 28000 Mbps                                                                                                                                                                                                                                                                         | 2500 Mbps       | Specifies the transceiver TX data rate in megabits per second (Mbps) unit.                                                                                      |
| PMA Options                      |                                                                                                                                                                                                                                                                                            |                 |                                                                                                                                                                 |
| PMA modulation type              | NRZ                                                                                                                                                                                                                                                                                        | NRZ             | Specifies the type of modulation for TX serial data.                                                                                                            |
| PMA reference clock<br>frequency | <ul> <li>500.00000</li> <li>312.50000</li> <li>277.77777</li> <li>250.00000</li> <li>227.27277</li> <li>208.33333</li> <li>192.307692</li> <li>178.571428</li> <li>166.66666</li> <li>156.250000</li> <li>147.058823</li> <li>138.88888</li> <li>131.578947</li> <li>125.000000</li> </ul> | 250.00000       | Sets the custom PCS<br>reference clock frequency.                                                                                                               |
| Enable custom rate<br>regulation | • On<br>• Off                                                                                                                                                                                                                                                                              |                 | Turn on this option to add<br>the custom rate ports to<br>your design. You are<br>required to drive the ports<br>with an appropriate flow<br>regulation signal. |

For parameters in the **PMA Adaptation** tab, refer to the *PMA Adaptation* topic in the Intel Stratix 10 E-Tile Transceiver PHY User Guide.

### **Related Information**

- E-Tile Transceiver PHY User Guide: PMA Parameters • Information about PMA Adaptation parameters.
- E-Tile Transceiver PHY User Guide: Dynamic Reconfiguration Examples • Information about configuring PMA parameters.

## 2.8.2. RTL Parameters

The E-Tile Hard IP for Ethernet Intel FPGA IP provides parameters in the generated RTL that you can modify for your IP core instance. Generating an IP core variation from the parameter editor creates an RTL module. Your design might instantiate multiple instances of this module. You can specify RTL parameter values for each instance. Each RTL parameter determines the initial and reset value of one or more register fields in the IP core.





RTL parameters allow you to customize your IP core instance to vary from the defaults you selected for your IP core variation and from other instances of the same IP core variation. This capability allows you to fine-tune your design without regenerating and without reading and writing registers following power-up. In addition, you can specify parameter values that should not be identical for multiple instances. For example, you can specify a different TX source address for each instance, without having to write to the relevant registers.

### Table 18. E-Tile Hard IP for Ethernet Intel FPGA IP RTL Parameters

| Parameter                                       | Parameter Description                                                                                                                                                                                                                                                 |  |  |  |  |  |
|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Parameters Available for all IP Core Variations |                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| sim_mode                                        | Specifies whether the IP core is in simulation mode, in which alignment marker periods are shortened to decrease the time to RX PCS alignment.                                                                                                                        |  |  |  |  |  |
|                                                 | • Value disable (default value): The IP core MAC implements standard alignment marker periods as specified in the <i>IEEE Standard 802.3–2015</i> . Before compiling for synthesis, ensure this parameter has this value.                                             |  |  |  |  |  |
|                                                 | • Value enable: The IP core implements shorter alignment marker periods to accelerate RX PCS alignment in simulation. The simulation link partner must have the same alignment marker periods. This mode is intended for simulation only.                             |  |  |  |  |  |
|                                                 | The value of this parameter determines the initial and reset values of these register fields:                                                                                                                                                                         |  |  |  |  |  |
|                                                 | • am_interval[13:0] field (bits [13:0]) of the RXPCS_CONF register at Offset 0x360.                                                                                                                                                                                   |  |  |  |  |  |
|                                                 | • am_period[15:0] field (bits [31:16]) of the TXMAC_EHIP_CFG register at Offset 0x40B.                                                                                                                                                                                |  |  |  |  |  |
| Parameters Available for M                      | AC+PCS IP Core Variations Only                                                                                                                                                                                                                                        |  |  |  |  |  |
| rx_pause_daddr                                  | Sets the destination addresses for PAUSE and PFC frames. The RX MAC uses this address to filter whether incoming PAUSE and PFC frames apply to the current IP core.                                                                                                   |  |  |  |  |  |
|                                                 | • Default value is 0x01_80_C2_00_00_01, the Ethernet standard multicast address for PAUSE and PFC.                                                                                                                                                                    |  |  |  |  |  |
|                                                 | Range is 0 through 2 <sup>48</sup> -1.                                                                                                                                                                                                                                |  |  |  |  |  |
|                                                 | Value can be a unicast or multicast address.                                                                                                                                                                                                                          |  |  |  |  |  |
|                                                 | • The RX MAC processes PAUSE and PFC frames only if their destination address matches this address (actually, the address in the RX_PAUSE_DADDR registers).                                                                                                           |  |  |  |  |  |
|                                                 | The value of this parameter determines the initial and reset values of the RX_PAUSE_DADDR registers at offsets 0x707 and 0x708.                                                                                                                                       |  |  |  |  |  |
| source_address_inserti on                       | Selects whether the IP core supports overwriting the source address in an outgoing packet it receives on the TX MAC interface, with the value in the TXMAC_SADDR registers at offsets 0x40C and 0x40D.                                                                |  |  |  |  |  |
|                                                 | <ul> <li>The default value is the value of the parameter editor Use Source Address Insertion<br/>parameter.</li> </ul>                                                                                                                                                |  |  |  |  |  |
|                                                 | <ul> <li>Value enable: If i_tx_skip_crc has the value of 0, in packets the IP core receives<br/>on the TX MAC client interface, the TX MAC overwrites the source address field with the<br/>value in the TXMAC_SADDR registers at offsets 0x40C and 0x40D.</li> </ul> |  |  |  |  |  |
|                                                 | Note: The IP core does not overwrite the source address in Ethernet PAUSE and PFC packets it generates on the Ethernet link in response to assertion of the<br>i_tx_pause signal or an i_tx_pfc[n] signal on the TX MAC client interface.                             |  |  |  |  |  |
|                                                 | • Value disable: The TX MAC does not overwrite the source address field in packets it receives on the TX MAC client interface.                                                                                                                                        |  |  |  |  |  |
|                                                 | The value of this parameter determines the initial and reset values of the en_saddr_insert field (bit [3]) of the TXMAC_CONTROL register at Offset 0x40A.                                                                                                             |  |  |  |  |  |
| tx_pause_daddr                                  | Sets the destination addresses that the TX MAC inserts in PAUSE and PFC frames that the IP core transmits on the Ethernet link in response to assertion of the $i_tx_pause$ signal or an $i_tx_pfc[n]$ signal on the TX MAC client interface.                         |  |  |  |  |  |
|                                                 | continued                                                                                                                                                                                                                                                             |  |  |  |  |  |



| Parameter      | Parameter Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                | <ul> <li>Default value is 0x01_80_C2_00_00_01, the Ethernet standard multicast address for PAUSE and PFC.</li> <li>Range is 0 through 2<sup>48</sup>-1.</li> <li>Value can be a unicast or multicast address.</li> <li>The value of this parameter determines the initial and reset values of the TX_PFC_DADDR registers at offsets 0x60D and 0x60E.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| tx_pause_saddr | <ul> <li>Sets the source addresses that the TX MAC inserts in PAUSE and PFC frames that the IP core transmits on the Ethernet link in response to assertion of the i_tx_pause signal or an i_tx_pfc[n] signal on the TX MAC client interface.</li> <li>Default value is the value of the RTL parameter txmac_saddr, which is the initial source address the IP core inserts in all TX packets written to the TX MAC client interface when source MAC address insertion is enabled.</li> <li>Range is 0 through 2<sup>48</sup>-1.</li> <li>Value should be a unicast address.</li> <li>The value of this parameter determines the initial and reset values of the TX_PFC_SADDR registers at offsets 0x60F and 0x610.</li> </ul> |  |  |  |
| txmac_saddr    | <ul> <li>Sets the source addresses that the TX MAC inserts in packets written to the TX MAC client interface when source MAC address insertion is enabled.</li> <li>Default value is the value you specify for the parameter editor <b>TX MAC Source</b> Address parameter.</li> <li>Range is 0 through 2<sup>48</sup>-1.</li> <li>The Intel FPGA team recommends you program each IP core instance with a unique unicast MAC address.</li> <li>The value of this parameter determines the initial and reset values of the TXMAC_SADDR registers at offsets 0x40C and 0x40D.</li> </ul>                                                                                                                                        |  |  |  |

## **2.9. Functional Description**

The E-Tile Hard IP for Ethernet Intel FPGA IP MAC+PCS variations implement an Ethernet MAC in accordance with the *IEEE 802.3 Ethernet Standard*. The IP core handles the frame encapsulation and flow of data between client logic and an Ethernet network through a 10-Gbps, 25-Gbps, and 100-Gbps Ethernet PHY implemented in hard IP, with optional Reed Solomon Forward Error Correction (RS-FEC).

In the transmit direction, the MAC accepts client frames, and inserts inter-packet gap (IPG), preamble, start of frame delimiter (SFD), padding, and CRC bits before passing them to the PHY. You can configure the MAC to accept some of the additions with the client frame. The MAC also updates the TX statistics counters. The PHY encodes the MAC frame as required for reliable transmission over the media to the remote end.

In the receive direction, the PHY passes frames to the MAC. The MAC accepts frames from the PHY, performs checks, updates statistics counters, strips out the CRC, preamble, and SFD, and passes the rest of the frame to the client. In RX preamble pass-through mode, the MAC passes on the preamble and SFD to the client instead of stripping them out. You can configure the MAC to provide the full RX frame at the client interface, the frame with CRC bytes removed, or the frame with CRC and RX PAD bytes removed.

The E-Tile Hard IP for Ethernet Intel FPGA IP also supports PCS Only, FlexE, and OTN variations. The PCS Only variations provide an MII interface to the client and transmit and receive Ethernet packets through a 10-Gbps, 25-Gbps, and 100-Gbps Ethernet PHY implemented in hard IP. The FlexE and OTN variations use PCS66 interface for transmitting and receiving 66b blocks, bypassing the MAC. The PCS Only, OTN , and FlexE variations support optional KR-FEC(528,514) or KP-FEC(544,514) for 25G and 100G Ethernet rate.







### Figure 12. E-tile Architecture and Datapath Overview

Notes:

1. Not all datapath combinations are available.

2. Datapath enablement depends on the configuration you are implementing. Refer to the E-Tile Channel Placement tool for possible configurations.

3. This FEC block can only be used in aggregate mode with FEC direct application (e.g. 1286FC Fibre-Channel). This FEC block cannot be used in in aggregate mode with EHIP\_CORE because there is no EHIP\_CORE in this location. Refer to Intel Stratix 10 E-Tile Transceiver User Guide for more information on FEC direct application.





#### **EMIB** Adapters tx\_pld\_conf. **RX** Core TX Core MII tx\_ehip\_mode[2:0] Interface Interface MAC PCS66 Client TX MAC Reset Distribution RX MAC TX MAC bypass or loopback to RX MAC Clock Distribution RX MAC bypass TX MAC loopback \* \* \* phy\_ehip\_mode\_muxes to RX core interface PCS66 .txpcsmux\_sel[2:0] 🔶 MII RX PCS TX MAC loopback to RX PLD TX PCS **RX PCS loopback to TX PCS** PCS66 TX PCS to RX PCS loopback TX core interface to RX PCS loopback Transceiver

#### Figure 13. E-Tile Hard IP for Ethernet Intel FPGA IP Instance and Bypass Modes

The E-Tile Hard IP for Ethernet Intel FPGA IP provides preliminary support for the OTN Note: feature. For further inquiries, contact your nearest Intel sales representative or file an Intel Premier Support (IPS) case at https://www.intel.com/content/www/us/en/myintel/fpga-sign-in.html.

## 2.9.1. E-Tile Hard IP for Ethernet Intel FPGA IP MAC

### 2.9.1.1. MAC TX Datapath

When the TX MAC module in a channel is enabled, it receives the client payload data with the destination and source addresses and then adds, appends, or updates various header fields in accordance with the configuration specified. The MAC does not modify the destination address or the payload received from the client. However, the TX MAC module adds a preamble (if the IP core is not configured to receive the preamble from user logic), pads the payload of frames greater than eight bytes to satisfy the minimum Ethernet frame payload of 46 bytes, and if you enable source address insertion, replaces the bytes in the source address field position of your data with a stored source address you provide as a parameter.

Note: The TX MAC interface does not support non-contiguous transfer. The i\_sl\_tx\_valid/i\_tx\_valid must be continuously asserted between the assertions of the start of packet and end of packet signals for the same packet. You must implement store and forward packet mechanism when transferring non-contiguous packets.





The client interface includes a port named i\_skip\_crc, which when asserted during a frame, makes the MAC skip the insertion of source address, padding, and CRC.

- When CRC insertion is skipped, the client must provide a CRC for the frame data it writes in the last 4 bytes of the frame.
- When padding is skipped, the frame data must be large enough to include a fully formed frame header (at least 14 bytes long) or the MAC will automatically mark it as an error frame.

The TX MAC module always inserts IDLE bytes to maintain an average IPG.

The E-Tile Hard IP for Ethernet Intel FPGA IP drops incoming frames of less than nine bytes.

#### Figure 14. Typical Client Frame at the Transmit Interface

The figure illustrates the changes that the TX MAC makes to the client frame when **Enable preamble passthrough** is turned off. This figure uses the following notational conventions:

- $\langle p \rangle$  = payload size, which is arbitrarily large.
- < s > = number of padding bits (0-46 bytes)
- <*g>* = number of IPG bits (full bytes)

MAC Frame

| Added by MAC for TX packets |                    | Payload Data from Client |                           |                      | Added by MAC for TX packets |                   |                       |               |                       |                       |
|-----------------------------|--------------------|--------------------------|---------------------------|----------------------|-----------------------------|-------------------|-----------------------|---------------|-----------------------|-----------------------|
|                             |                    | ļ                        | 1                         |                      |                             |                   |                       |               |                       |                       |
| Start Control               | Preamble<br>[47:0] | SFD<br>[7:0]             | Destination<br>Addr[47:0] | Source<br>Addr[47:0] | Type/<br>Length[15:0]       | Payload<br>[-1:0] | PAD<br>[ <s>-1:0]</s> | FCS<br>[31:0] | Term Control<br>[7:0] | IPG<br>[ <g>-1:0]</g> |

The following sections describe the functions performed by the TX MAC:

TX Preamble, Start, and SFD Insertion on page 67

Source Address Insertion on page 68

Length/Type Field Processing on page 68

Frame Padding on page 68

Frame Check Sequence (CRC-32) Insertion on page 68

Inter-Packet Gap Generation and Insertion on page 68

#### 2.9.1.1.1. TX Preamble, Start, and SFD Insertion

In the TX datapath the MAC appends an eight-byte preamble that begins with a Start byte (0xFB) to the client frame.

The source of the preamble depends on whether you enable the preamble passthrough feature by turning on **Enable preamble passthrough** in the E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor.

If the preamble pass-through feature is turned on, the client must provide 8 preamble bytes (including an SFD byte) on the data bus. The MAC will automatically replace the Start Control byte.





### 2.9.1.1.2. Source Address Insertion

If you configure the IP core to use source address insertion, the MAC replaces the bytes in the Source Addr field provided by the client interface with the source address given by the txmac\_saddr parameter.

To enable source address insertion, turn on **Use Source Address Insertion** in the E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor.

### 2.9.1.1.3. Length/Type Field Processing

This two-byte header field represents either the length of the payload or the type of MAC frame. When the value of this field is equal to or greater than 1536 (0x600) it indicates a type field. Otherwise, this field provides the length of the payload data that ranges from 0–1500 bytes. The TX MAC does not modify this field before forwarding it to the network; it uses this field to generate TX Statistics.

### 2.9.1.1.4. Frame Padding

When the length of client frame is less than 64 bytes and greater than eight bytes, the TX MAC module inserts pad bytes after the payload to create a frame length equal to the minimum size of 64 bytes. If the i\_skip\_crc signal is asserted while writing frame data, the core does not insert PAD bytes even if the frame is shorter than 64 bytes long.

**Caution:** The E-Tile Hard IP for Ethernet Intel FPGA IP drops client frames of less than nine bytes because it cannot transfer the frames to the E-tile. You must ensure such frames do not reach the TX client interface.

### 2.9.1.1.5. Frame Check Sequence (CRC-32) Insertion

As long as the i\_skip\_crc signal on the TX client interface is not asserted, the TX MAC computes and inserts a frame check sequence (FCS) in the transmitted MAC frame. The FCS field contains a 32-bit Cyclic Redundancy Check (CRC32) value. The MAC computes the CRC32 over the frame bytes that include the source address, destination address, length/type field, data, and pad (if applicable). The FCS computation excludes the preamble and SFD. The encoding is defined by the following generating polynomial:

FCS(X) = X32 +X26 +X23 +X22 +X16 +X12 +X11 +X10 +X8 +X7 +X5 +X4 +X2 +X1 +1

CRC bits are transmitted with MSB (X32) first.

If i\_skip\_crc is asserted while writing frame data, the TX MAC will not append an FCS to the end of the frame. This will cause the resulting packet to be invalid unless the last 4 bytes of frame data are a correctly computed FCS value.

### **Related Information**

Order of Ethernet Transmission on page 75

### 2.9.1.1.6. Inter-Packet Gap Generation and Insertion

If you set **Average Inter-packet Gap** to **12** in the E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor, the TX MAC maintains the minimum inter-packet gap (IPG) between transmitted frames required by the IEEE 802.3 Ethernet standard. The





standard requires an average minimum IPG of 96 bit times (or 12 byte times). The MAC uses a deficit idle counter to allow the actual gap between frames to vary as needed to meet the maximum throughput requirements of the link.

If you set **Average Inter-packet Gap** to **10** or **8**, the TX MAC maintains a minimum average IPG of 10 or 8 bytes accordingly. This option is provided as an intermediate option to allow you to enforce an IPG that does not conform to the Ethernet standard, but which increases the throughput of your IP core.

If you set **Average Inter-packet Gap** to **1**, the IP core transmits Ethernet packets as soon as the data is available, without inserting any extra idle Control words to maintain IPG at a specified average. In this case the IPG depends on the space you leave between frame data as you write it to the core. If you select this parameter value, the core will no longer comply with the Ethernet standard, but your application will have control over the average gap and throughput can be maximized.

*Note:* Even when you set the Average Inter-packet Gap to 1, the 10G/25G channels will still enforce an effective IPG of 5. This is because the protocol specifically prohibits IPG lower than 5 for 10G/25G links to prevent MACs from producing packets that cannot be encoded using 64B/66B encoders.

### 2.9.1.2. MAC RX Datapath

When the RX MAC in the channel is enable, it receives Ethernet frames from the PHY and forwards it to the client with framing information together with the results of header and error checking functions.

You can configure whether to include or remove the PAD bytes and FCS using the **Bytes to remove from RX frames** parameter.

### Figure 15. Flow of Frame Through the MAC RX Without Preamble Pass-Through

The figure illustrates the typical flow of frame through the MAC RX when the preamble pass-through feature is turned off. In this figure,  $\langle p \rangle$  is payload size, and  $\langle s \rangle$  is the number of pad bytes (0–46 bytes).



### Figure 16. Flow of Frame Through the MAC RX With Preamble Pass-Through

The figure illustrates the typical flow of frame through the MAC RX when the preamble pass-through feature is turned on. In this figure,  $\langle p \rangle$  is payload size, and  $\langle s \rangle$  is the number of pad bytes (0–46 bytes)..

If CRC forwarding is turned on







The following sections describe the functions performed by the RX MAC:

RX Preamble Processing on page 70 RX Strict SFD Checking on page 70 RX FCS Checking on page 71 RX Malformed Packet Handling on page 71 Removing PAD Bytes and FCS Bytes from RX Frames on page 71 RX Undersized Frames, Oversized Frames, and Frames with Length Errors on page 71 Inter-Packet Gap on page 71

### 2.9.1.2.1. RX Preamble Processing

The preamble sequence is Start, six preamble bytes, and SFD. The Start byte must be on receive lane 0 of the MII, which means byte [7:0] of the data decoded from a 66b block. The IP core uses the Start Control byte (0xFB, with the corresponding MII control bit set to 1) to identify the start of the Ethernet packet, and the location of the preamble.

By default, the MAC RX removes all Start, SFD, preamble, and IPG bytes from accepted frames. However, if you turn on **Enable preamble passthrough** in the E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor, the MAC RX does not remove the eight-byte preamble sequence.

### 2.9.1.2.2. RX Strict SFD Checking

The E-Tile Hard IP for Ethernet Intel FPGA IP RX MAC checks all incoming packets for a correct Start byte (0xFB).

If you turn on **Enable strict preamble check** in the E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor, the RX MAC requires all RX packets to have an Ethernet standard preamble (0x55\_55\_55\_55\_55\_55). If you turn on **Enable strict SFD check**, the RX MAC requires all RX packets to have an Ethernet standard Start Frame Delimiter (0xD5).

Strict checking reduces the incidence of runt packets caused by bit errors on the line. However, do not use strict checking in applications where custom preamble values or SFD values are needed.

### Table 19. Strict SFD Checking Configuration

| Enable Strict SFD<br>Check | 0x50A[4]: Preamble<br>Check | 0x50A[3]: SFD Check | Fields Checked                  | Behavior if Check<br>Fails                             |  |
|----------------------------|-----------------------------|---------------------|---------------------------------|--------------------------------------------------------|--|
| Off                        | Don't Care                  | Don't Care          | Start byte                      | IP core does not                                       |  |
| On                         | 0                           | 0                   | Start byte                      | recognize a<br>malformed Start byte<br>as a Start byte |  |
|                            | 0                           | 1                   | Start byte and SFD              | IP Core drops the                                      |  |
|                            | 1                           | 0                   | Start byte and preamble         | packet                                                 |  |
|                            | 1                           | 1                   | Start byte and preamble and SFD |                                                        |  |





### 2.9.1.2.3. RX FCS Checking

The RX MAC checks the FCS of all incoming packets that are minimum sized or larger. If the RX MAC detects an FCS error, it marks the frame invalid by asserting o\_rx\_error[1]. FCS errors are also indicated for arriving packets containing an Error control block.

### 2.9.1.2.4. RX Malformed Packet Handling

While receiving an incoming packet from the Ethernet link, the RX MAC expects packets to end with a Terminate Control byte. Packets that contain Error bytes or a control byte other than Terminate are malformed packets. The RX MAC asserts o\_rx\_error[0] when the frame ends to indicate that it was a malformed packet.

### 2.9.1.2.5. Removing PAD Bytes and FCS Bytes from RX Frames

The **Bytes to remove from RX frames** parameter in the parameter editor offers the option of removing bytes from the end of RX frames. You can program the RX MAC to present all the bytes that arrive at the end of an RX frame, remove the RX FCS bytes only, or remove the RX FCS bytes and any RX PAD bytes that were added to the frame.

### 2.9.1.2.6. RX Undersized Frames, Oversized Frames, and Frames with Length Errors

The RX MAC flags RX frames that arrive with fewer than 64 bytes as undersized, and are not checked for FCS. The RX MAC marks undersized frames by asserting o\_rx\_error[2] when the frame ends.

The RX MAC marks RX frames that arrive with more bytes than the **RX Maximum Frame Size** value you specify in the parameter editor as oversized. The RX MAC marks oversized frames by asserting o\_rx\_error[3] when the frame ends.

If you turn on **Enforce Maximum Frame Size** in the parameter editor, oversized frames are not allowed through the RX client interface. When the frame reaches the maximum size, it is ended, and the RX MAC asserts botho\_rx\_error[3] and o\_rx\_error[1] to indicate the frame was truncated.

RX Frames that arrive with a valid Length field (Length/Type  $\leq$  1500) are checked for length errors. If the length of the packet advertised in the Length/Type field is larger than the length of the frame that actually arrived, the RX MAC asserts o\_rx\_error[4] to indicate that there was a length error.

### 2.9.1.2.7. Inter-Packet Gap

The MAC RX removes all IPG octets received, and does not forward them to the client interface. It can tolerate a sustained stream of packets with an IPG of 1.





## 2.9.1.3. Congestion and Flow Control Using PAUSE or Priority Flow Control (PFC)

If you do not select **Disable Flow Control** in the **Stop TX traffic when link partner** sends pause parameter, the E-Tile Hard IP for Ethernet Intel FPGA IP provides flow control to reduce congestion at the local or remote link partner. When either link partner experiences congestion, the respective TX MAC can be instructed to send PAUSE or PFC frames to regulate the flow of data from the other side of the link.

- PAUSE frames instruct the remote transmitter to stop sending data for the duration that the congested receiver specified in an incoming XOFF frame.
- PFC frames instruct the receiver to halt the flow of packets assigned to a specific Priority Queue for a specified duration.

### 2.9.1.3.1. Conditions Triggering XOFF Frame Transmission

The E-Tile Hard IP for Ethernet Intel FPGA IP supports retransmission. In retransmission, the IP core retransmits a XOFF frame periodically, extending the pause time, based on signal values.

The TX MAC transmits PAUSE XOFF frames when one of the following conditions occurs:

- Client requests XOFF transmission—A client can explicitly request that XOFF frames be sent using the i\_tx\_pause and i\_tx\_pfc[7:0] signals. When i tx pause is asserted, a PAUSE XOFF frame is sent to the Ethernet network when the current frame transmission completes. When i tx pfc is asserted, a PFC XOFF packet is transmitted with XOFF requests for each of the Queues that has a bit high in the signal. For example, setting i tx pfc to 0x03 sends XOFF requests for Queues 0 and 1.
- Host (software) requests PAUSE XOFF transmission—Setting the pause request register triggers a request that a PAUSE XOFF frame be sent. Similarly, setting the PFC request register triggers PFC XOFF frame requests for the selected Priority Oueues.
- Retransmission mode—If the retransmit hold-off enable bit has the value of 1, and the i\_tx\_pause signal remains asserted or the pause request register value remains high, when the time duration specified in the hold-off quanta register has lapsed after the previous PAUSE XOFF transmission, the TX MAC sends another PAUSE XOFF frame to the Ethernet network. The same mechanism applies to PFC. While the IP core is paused in retransmission mode, you cannot use either of the other two methods to trigger a new XOFF frame: the signal or register value is already high.
- Intel recommends that you use the flow control ports to backpressure the remote Note: Ethernet node.





#### 2.9.1.3.2. Conditions Triggering XON Frame Transmission

The TX MAC transmits PAUSE or PFC XON frames when one of the following conditions occurs:

- Client requests XON transmission—A client can explicitly request that XON frames be sent using the pause control interface signal. When  $i_tx_pause$  is deasserted, a PAUSE XON frame is sent to the Ethernet network when the current frame transmission completes. Similarly, when i tx pfc[n] is deasserted, a PFC frame is sent with a PFC XON message for queue *n*. If multiple PFC queues are deasserted, the TX MAC will pack the requests into the same PFC packet if possible.
- Host (software) requests XON transmission—Resetting the pause request register triggers a request that an XON frame be sent.

## 2.9.1.4. Pause Control and Generation Interface

The flow control interface implements PAUSE as specified by the IEEE 802.3ba 2010 High Speed Ethernet Standard, PFC as specified by the IEEE Standard 802.1Qbb.

You can configure the PAUSE logic to automatically stop local packet transmission when the link partner sends a PAUSE XOFF packet. The PAUSE logic can pass the PAUSE packets through as normal packets or drop the packets before they reach the RX client.

As for PFC frames, you can configure the PFC logic to pass the PFC packets through as normal packets or drop them before they reach the RX client. However, you don't have an option to stop traffic automatically when a PFC XOFF frame arrives.

#### Table 20. **Pause Control and Generation Signals**

Describes the signals that implement pause control. These signals are available only if you turn on flow control in the E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor.

Note: **Signal Name** Direction Description Level signal which directs the IP core to insert a PAUSE or PFC frame for i\_tx\_pause (PAUSE) Input priority traffic class [n] on the Ethernet link. If bit [n] of the TX\_PAUSE\_EN i\_tx\_pfc (PFC) register has the value of 1, the IP core transmits an XOFF frame when this signal is first asserted. If you enable retransmission, the IP core continues to transmit XOFF frames periodically until the signal is de-asserted. When the signal is deasserted, the IP core inserts an XON frame. Asserted to indicate an RX a PAUSE or PFC signal match. The IP core o\_rx\_pause (PAUSE) Output asserts bit [n] of this signal when it receives a pause request with an o\_rx\_pfc (PFC) address match, to signal the TX MAC to throttle its transmissions from priority queue [n] on the Ethernet link.

The signal names may have slight variance depending on the variant you select.

#### 2.9.1.5. Pause Control Frame Filtering

The E-Tile Hard IP for Ethernet Intel FPGA IP supports options to enable or disable the following features for incoming pause control frames. These options are available as long as you do not set the Stop TX traffic when link partner sends pause parameter to Disable Flow Control.





For filtering, the PAUSE and PFC packets are only processed if their destination address matches the address given by the rx pause daddr parameter.

- If you turn on **Forward RX Pause Requests** in the parameter editor, the RX PAUSE and PFC frames are always passed along the RX client, even if they are processed.
- If you turn off Forward RX Pause Requests in the parameter editor, the RX PAUSE and PFC packets are processed internally, and not presented to the RX client as valid packets.

A PAUSE or PFC packet must have a destination address that matches the rx\_pause\_daddr parameter, a Length/Type field that is set to 0x8808, and the first 2 bytes of the packet set to 0x0001 or 0x0101.

To actually trigger PAUSE or PFC, you must also ensure that the packets are of the correct length and have no FCS error. Because these conditions are not known until the whole packet has arrived, if you turn off Forward RX Pause Requests, you may have packets that are filtered because they look like PAUSE or PFC packets, but not processed because they are of the wrong size or have an error.

# 2.9.1.6. Link Fault Signaling

If you enable **Choose Link Fault Generation Mode** in the E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor, the IP core provides link fault signaling as defined in the IEEE 802.3ba-2010 High Speed Ethernet Standard and Clause 66 of the IEEE 802.3-2012 Ethernet Standard, based on the LINK FAULT CONFIG register settings.

The Ethernet MAC includes a Reconciliation Sublayer (RS) located between the MAC and the MII to manage local and remote faults. Link fault signaling on the Ethernet link is disabled by default but can be enabled by bit [0] of the link fault config register. When the link fault config register bits [1:0] have the value of 2'b01. link fault signaling is enabled in normal bidirectional mode. In this mode, the local RS TX logic transmits remote fault sequences in case of a local fault and transmits IDLE control words in case of a remote fault.

If you turn on bit [1] of the link\_fault\_config register, the IP core conforms to Clause 66 of the IEEE 802.3-2012 Ethernet Standard. When link fault config[1:0] has the value of 2'b11, the IP core transmits the fault sequence ordered sets in the interpacket gaps according to the clause requirements.

The RS RX logic sets remote\_fault\_status or local\_fault\_status to 1 when the RS RX block receives remote fault or local fault sequence ordered sets. When valid data is received in more than 127 columns, the RS RX logic resets the relevant fault status (remote\_fault\_status or local\_fault\_status) to 0.

The IEEE standard specifies RS monitoring of RXC<7:0> and RXD<63:0> for Sequence ordered sets. For more information, refer to Figure 81-9-Link Fault Signaling state diagram and Table 81-5—Sequence ordered\_sets in the IEEE 802.3ba 2010 High Speed Ethernet Standard. The variable link\_fault is set to indicate the value of an RX Sequence ordered set when four fault sequences containing the same fault value are received with fault sequences separated by less than 128 columns and with no intervening fault\_sequences of different fault values. The variable link fault is set to OK following any interval of 128 columns not containing a remote fault or local fault Sequence ordered set.





- IEEE Website The IEEE 802.3ba –2010 High Speed Ethernet Standard and the IEEE 802.3 – 2012 Ethernet Standard are available on the IEEE website.
- Link Fault Configuration on page 199

#### **2.9.1.6.1.** Determining Link Fault Condition

In Intel Quartus Prime v18.1.1, the E-Tile Hard IP for Ethernet Intel FPGA IP provides the o\_sl\_rx\_pcs\_fully aligned/o\_rx\_pcs\_fully aligned signal to determine link fault condition. Implement the following pseudo-code on the RX MII port:

#### **Related Information**

How do I use the "o\_rx\_pcs\_fully\_aligned" signal to tell the difference between a local fault condition and valid RX data when using the Intel<sup>®</sup> Stratix<sup>®</sup> 10 E-tile Hard IP for Ethernet Intel<sup>®</sup> FPGA IP configured in PCS+FEC status without the MAC?

#### 2.9.1.7. Order of Ethernet Transmission

The TX MAC transmits bytes on the Ethernet link starting with the preamble and ending with the FCS in accordance with the IEEE 802.3 standard. On the transmit client interface, the IP core expects the client to send the most significant bytes of the frame first, and to send each byte in big-endian format. Similarly, on the receive client interface, the IP core sends the client the most significant bytes of the frame first, and orders each byte in big-endian format.

#### Figure 17. Byte Order on the Client Interface Lanes Without Preamble Pass-Through

The figure describes the byte order on the Avalon streaming interface when the preamble pass-through feature is turned off. Destination Address[40] is the broadcast/multicast bit (a type bit), and Destination Address[41] is a locally administered address bit.

|       | ۵       | ) estina | tion Ac | ldress ( | DA)    |       |         | Sourc   | e Add   | ress (S | A)     |       | Typ<br>Lengt |       |          | Data (D) |          |
|-------|---------|----------|---------|----------|--------|-------|---------|---------|---------|---------|--------|-------|--------------|-------|----------|----------|----------|
| Octet | 5       | 4        | 3       | 2        | 1      | 0     | 5       | 4       | 3       | 2       | 1      | 0     | 1            | 0     | 00       |          | NN       |
| Bit   | [47:40] | [39:32]  | [31:24] | [23:16]  | [15:8] | [7:0] | [47:40] | [39:32] | [31:24] | [23:16] | [15:8] | [7:0] | [15:8]       | [0:2] | MSB[7:0] |          | LSB[7:0] |





For example, the destination MAC address includes the following six octets AC-DE-48-00-00-80. The first octet transmitted (octet 0 of the MAC address described in the 802.3 standard) is AC and the last octet transmitted (octet 7 of the MAC address) is 80. The first bit transmitted is the low-order bit of AC, a zero. The last bit transmitted is the high order bit of 80, a one.

The preceding table and the following figure show that in this example, 0xAC is driven on DA5 (DA[47:40]) and 0x80 is driven on DA0 (DA[7:0]).

#### Figure 18. Octet Transmission on the Avalon Streaming Interface Signals Without Preamble Pass-Through

The figure illustrates how the octets of the client frame are transferred over the TX datapath when preamble pass-through is turned off.

| i_clk_tx           |     |      |         |           |       |        | _\\_ |      |     |        |
|--------------------|-----|------|---------|-----------|-------|--------|------|------|-----|--------|
| i_tx_data[511:504] | DA5 | D50  | D114    |           | DA5   | D50    |      | D242 | DA5 | D50    |
| i_tx_data[503:496] | DA4 | D51  | D115    |           | DA4   | D51    |      | D243 | DA4 | D51    |
| i_tx_data[495:488] | DA3 | D52  | D116    |           | DA3   | D52    |      | D244 | DA3 | D52    |
| i_tx_data[487:480] | DA2 | D53  | D117    |           | DA2   | D53    |      | D245 | DA2 | D53    |
| i_tx_data[479:472] | DA1 | D54  | D118    |           | DA1   | D54    |      | D246 | DA1 | D54    |
| i_tx_data[471:464] | DAO | D55  | D119    | X <b></b> | ) DAO | D55    |      | D247 | DA0 | D55    |
| i_tx_data[463:456] | SA5 | D56  | D120    | X         | SA5   | D56    |      | D248 | SA5 | D56    |
| i_tx_data[455:448] | SA4 | D57  | D121    |           | SA4   | D57    |      | D249 | SA4 | D57    |
| i_tx_data[447:440] | SA3 | D58  | D122    |           | SA3   | D58    |      | D250 | SA3 | D58    |
| i_tx_data[439:432] | SA2 | D59  |         |           | SA2   | D59    |      | D251 | SA2 | D59    |
| i_tx_data[431:424] | SA1 | D60  |         |           | SA1   | D60    |      | D252 | SA1 | D60    |
| i_tx_data[423:416] | SA0 | D61  |         |           | SA0   | D61    |      | D253 | SA0 | D61    |
| i_tx_data[415:408] | TL1 | D62  |         |           | TL1   | D62    |      | D254 | TL1 | D62    |
| i_tx_data[407:400] | TLO | D63  |         |           | ) TLO | D63    |      | D255 | TLO | D63    |
| i_tx_data[399:392] | DO  | D64  |         |           | DO    | D64    |      |      | DO  | D64    |
| i_tx_data[391:384] | D1  | D65  |         |           | D1    | D65    |      |      | D1  | D65    |
| •                  |     |      |         |           |       |        |      |      |     |        |
| i_tx_data[23:16]   | D47 | D111 |         |           | D47   | ) D111 |      | X I  | D47 | ) D111 |
| i_tx_data[15:8]    | D48 | D112 | X       |           | D48   | D112   |      | X    | D48 | D112   |
| i_tx_data[7:0]     | D49 | D113 | X       |           | D49   | D113   |      | X    | D49 | D113   |
| i_tx_startofpacket |     |      |         |           |       |        |      |      |     |        |
| i_tx_endofpacket   |     |      | <u></u> |           |       |        |      |      |     |        |
| i_tx_empty[5:0]    |     |      | 55      | X         |       |        |      | 50   | 1   | X      |





#### Figure 19. Byte Order on the Avalon Streaming Interface Lanes With Preamble Pass-Through

The figure describes the byte order on the Avalon streaming interface when the preamble pass-through feature is turned on.

Destination Address[40] is the broadcast/multicast bit (a type bit), and Destination Address[41] is a locally administered address bit.

|    |      | SFD     |         |         | Prean   | nble    |         |        | Start | D       | estin   | ation<br>(D |         | ess    |       | So      | urce    | Addr    | ess (   | SA)    |       | Typ<br>Len |       |          | Data (D) |          |
|----|------|---------|---------|---------|---------|---------|---------|--------|-------|---------|---------|-------------|---------|--------|-------|---------|---------|---------|---------|--------|-------|------------|-------|----------|----------|----------|
| 0  | ctet | 7       | 6       | 5       | 4       | 3       | 2       | 1      | 0     | 5       | 4       | 3           | 2       | 1      | 0     | 5       | 4       | 3       | 2       | 1      | 0     | 1          | 0     | 00       |          | NN       |
| Bi | it   | [63:56] | [55:48] | [47:40] | [39:32] | [31:24] | [23:16] | [15:8] | [0:2] | [47:40] | [39:32] | [31:24]     | [23:16] | [15:8] | [2:0] | [47:40] | [39:32] | [31:24] | [23:16] | [15:8] | [2:0] | [15:8]     | [7:0] | MSB[7:0] |          | LSB[7:0] |





#### Figure 20. **Octet Transmission on the Avalon Streaming Interface Signals With Preamble Pass-Through**

The figure illustrates how the octets of the client frame are transferred over the TX datapath when preamble pass-through is turned on. The eight preamble bytes precede the destination address bytes. The preamble bytes are reversed: the application must drive the SFD byte on  $i_tx_data[455:448]$  and the START byte on i\_tx\_data[511:504].

The destination address and source address bytes follow the preamble pass-through in the same order as in the case without preamble pass-through.

| i_clk_tx           |       |      |           |              |       |      |         |      |        |      |
|--------------------|-------|------|-----------|--------------|-------|------|---------|------|--------|------|
| i_tx_data[511:504] | START | D42  | D106      |              | START | D42  |         | D234 | START  | D42  |
| i_tx_data[503:496] | P6    | D43  | D107      |              | ) P6  | D43  |         | D235 | P6     | D43  |
| i_tx_data[495:488] | P5    | D44  | D108      |              | P5    | D44  |         | D236 | P5     | D44  |
| i_tx_data[487:480] | P4    | D45  | D109      |              | ) P4  | D45  |         | D237 | P4     | D45  |
| i_tx_data[479:472] | P3    | D46  | D110      |              | (Р3   | D46  |         | D238 | P3     | D46  |
| i_tx_data[471:464] | P2    | D47  | D111      |              | ) P2  | D47  |         | D239 | P2     | D47  |
| i_tx_data[463:456] | P1    | D48  | D112      |              | ) P1  | D48  |         | D240 | P1     | D48  |
| i_tx_data[455:448] | SFD   | D49  | D113      |              | SFD   | D49  |         | D241 | SFD    | D49  |
| i_tx_data[447:440] | DA5   | D50  | D114      |              | DA5   | D50  |         | D242 | DA5    | D50  |
| i_tx_data[439:432] | DA4   | D51  | D115      |              | DA4   | D51  |         | D243 | DA4    | D51  |
| i_tx_data[431:424] | DA3   | D52  | D116      |              | DA3   | D52  |         | D244 | DA3    | D52  |
| i_tx_data[423:416] | DA2   | D53  | D117      |              | DA2   | D53  |         | D245 | DA2    | D53  |
| i_tx_data[415:408] | DA1   | D54  | D118      |              | DA1   | D54  |         | D246 | DA1    | D54  |
| i_tx_data[407:400] | DAO   | D55  | D119      |              | ) DAO | D55  |         | D247 | DAO    | D55  |
| i_tx_data[399:392] | SA5   | D56  | D120      |              | SA5   | D56  |         | D248 | SA5    | D56  |
| i_tx_data[391:384] | SA4   | D57  | D121      |              | SA4   | D57  |         | D249 | SA4    | D57  |
| i_tx_data[383:376] | SA3   | D58  | D122      | X <b></b> \$ | SA3   | D58  |         | D250 | SA3    | D58  |
| i_tx_data[375:368] | SA2   | D59  | X         |              | SA2   | D59  |         | D251 | SA2    | D59  |
| i_tx_data[7:0]     | D41   | D105 | γ         | ((_          | D41   | D105 | v-((    | V    | D41    | D105 |
|                    | ודע   |      | λ         | ))           |       | 1    | )<br>\( | Λ    |        |      |
| i_tx_startofpacket |       | L    | [         | ))_<br>] ((  | J     | L    | )       |      | )<br>\ | ·    |
| i_tx_endofpacket   |       |      | ]<br>\ 47 | \))_<br>\((  |       |      |         | 42   | V      |      |
| i_tx_empty[5:0]    |       |      | 4/        |              |       |      |         | 42   | ۸      |      |

# 2.9.2. 1588 Precision Time Protocol Interfaces

If you turn on Enable IEEE 1588 PTP, the E-Tile Hard IP for Ethernet Intel FPGA IP processes and provides 1588 Precision Time Protocol (PTP) timestamp information as defined in the IEEE 1588-2008 Precision Clock Synchronization Protocol for Networked Measurement and Control Systems Standard. This feature supports PHY operating speed with a constant timestamp accuracy of  $\pm$  3 ns.





1588 PTP packets carry timestamp information. The E-Tile Hard IP for Ethernet Intel FPGA IP updates the incoming timestamp information in a 1588 PTP packet to transmit a correct updated timestamp with the data it transmits on the Ethernet link, using a one-step or two-step clock.

A fingerprint can accompany a 1588 PTP packet. You can use this information for client identification and other client uses. If provided fingerprint information, the IP core passes it through unchanged.

The IP core connects to a time-of-day (TOD) module that continuously provides the current time of day based on the input clock frequency. Because the module is outside the E-Tile Hard IP for Ethernet Intel FPGA IP, you can use the same module to provide the current time of day for multiple modules in your system.

#### **Related Information**

#### **IEEE** website

The *IEEE 1588-2008 Precision Clock Synchronization Protocol for Networked Measurement and Control Systems Standard* is available on the IEEE website.

# 2.9.2.1. Implementing a 1588 System That Includes a E-Tile Hard IP for Ethernet Intel FPGA IP

The 1588 specification in *IEEE 1588-2008 Precision Clock Synchronization Protocol for Networked Measurement and Control Systems Standard* describes various systems you can implement in hardware and software to synchronize clocks in a distributed system by communicating time offset and frequency correction information between master and slave clocks in arbitrarily complex systems. A 1588 system that includes the E-Tile Hard IP for Ethernet Intel FPGA IP with 1588 PTP functionality uses the incoming and outgoing timestamp information from the IP core and the other modules in the system to synchronize clocks across the system.

The E-Tile Hard IP for Ethernet Intel FPGA IP with 1588 PTP functionality provides the timestamp manipulation and basic update capabilities required to integrate your IP core in a 1588 system. You can specify that packets are PTP packets, and how the IP core should update incoming timestamps from the client interface before transmitting them on the Ethernet link. The IP core does not implement the event messaging layers of the protocol, but rather provides the basic hardware capabilities that support a system in implementing the full 1588 protocol.

#### Table 21. PTP Timestamp Accuracy per Ethernet Data Rate

| Ethernet Data Rate | RS-FEC Support | PTP Timestamp Accuracy | Parallel Clock Frequency |
|--------------------|----------------|------------------------|--------------------------|
| 10GE               | No             | ±3 ns                  | 161.132 MHz              |
| 25GE               | No             | ±3 ns                  | 402.83 MHz               |
| 25GE               | Yes            | ±3 ns                  | 402.83 MHz               |
| 100GE              | No             | ±8 ns                  | 402.83 MHz               |
| 100GE              | Yes            | ±8 ns                  | 402.83 MHz               |

#### **Related Information**

#### **IEEE** website

The *IEEE 1588-2008 Precision Clock Synchronization Protocol for Networked Measurement and Control Systems Standard* is available on the IEEE website.







# 2.9.2.2. PTP Transmit Functionality

When you send a 1588 PTP packet to a E-Tile Hard IP for Ethernet Intel FPGA IP with **Enable IEEE 1588 PTP** turned on in the parameter editor, you must assert one and only one of the following input signals with the TX SOP signal to tell the IP core the incoming packet is a 1588 PTP packet:

- i\_sl\_ptp\_ts\_req: assert this signal to tell the IP core to process the current packet in two-step processing mode.
- i\_sl\_ptp\_ins\_ets: assert this signal to tell the IP core to process the current packet in one-step processing mode and to insert the exit timestamp for the packet in the packet (insertion mode).
- i\_sl\_ptp\_ins\_cf: assert this signal to tell the IP core to process the current packet in one-step processing mode and to update the timestamp in the packet by adding the latency through the IP core (the residence time in the IP core) to the cumulative delay field maintained in the packet (correction mode). This mode supports transparent clock systems.

All TX PTP operations assume the <code>o\_sl\_tx\_ptp\_ready</code> signal was asserted and is held high.



#### Figure 21. Example Waveform for 2-step TX Timestamp using i\_sl\_ptp\_ts\_req Signal





#### Figure 22. Example Waveform for 1-step TX Timestamp using i\_sl\_ptp\_ins\_ets Signal



## Figure 23. Example Waveform for 1-step TX Timestamp using i\_sl\_ptp\_ins\_cf Signal



The IP core transmits the 1588 PTP packet in an Ethernet frame after PTP processing.









In one-step mode, the IP core either overwrites the timestamp information provided at the user-specified offset with the packet exit timestamp (insertion mode), or adds the residence time in this system to the value at the specified offset (correction mode). You tell the IP core how to process the timestamp by asserting the appropriate signal with the TX SOP signal. You must specify the offset of the timestamp in the packet (i\_ptp\_ts\_offset) in insertion mode, or the offset of the correction field in the packet (i\_ptp\_cf\_offset) in correction mode. In addition, the IP core zeroes out or updates the UDP checksum, or leaves the UDP checksum as is, depending on the mutually exclusive i\_ptp\_zero\_csum and i\_ptp\_update\_eb signals.

*Note:* If the PTP packet resides in the system for more than 4ns, the correction field will show a mismatched in the correction field with a very large number. In this condition, the PTP module takes only the last 2 LSB bits in the packet for calculation.

Two-step PTP processing ignores the values on the one-step processing signals. In two-step processing mode, the IP core does not modify the current timestamp in the packet. Instead, the IP core transmits a two-step derived timestamp on the separate o\_ptp\_ets[95:0] bus, when it begins transmitting the Ethernet frame. The value on the o\_ptp\_ets bus is the packet exit timestamp. The o\_ptp\_ets bus holds a valid value when the corresponding o\_ptp\_ets\_valid signal is asserted.

In addition, to help the client to identify the packet, you can specify a fingerprint to be passed by the IP core in the same clock cycle with the timestamp. The E-Tile Hard IP for Ethernet Intel FPGA IP has a fixed 8 bit width for fingerprint. You provide the fingerprint value to the IP core in the i\_ptp\_fp signal. The IP core then drives the fingerprint on the appropriate o\_ptp\_ets\_fp port with the corresponding output timestamp, when it asserts the o\_ptp\_ets\_valid signal.





The IP core calculates the packet exit timestamp using reference block timing. The egress time of blocks which marked as references, are measured directly at the serializer, and are used to calculate the egress times of all other bits.

#### **Related Information**

#### **IEEE** website

The IEEE 1588-2008 Precision Clock Synchronization Protocol for Networked Measurement and Control Systems Standard is available on the IEEE website.

# 2.9.2.3. PTP Receive Functionality

If you turn on Enable IEEE 1588 PTP in the E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor, the IP core provides a 96-bit (V2 format) or 64-bit timestamp with every packet on the RX client interface, whether it is a 1588 PTP packet or not. The value on the timestamp bus o\_ptp\_rx\_its is valid in the same clock cycle as the RX SOP signal. The value on the timestamp bus is not the current timestamp; instead, it is the timestamp from the time when the IP core received the packet on the Ethernet link. The IP core captures the time-of-day from the TOD module on i ptp tod at the time it receives the packet on the Ethernet link, and sends that timestamp to the client on the RX SOP cycle on the timestamp bus o ptp rx its. User logic can use this timestamp or ignore it.

The RX PTP operation assumes the o\_sl\_rx\_ptp\_ready signal was asserted and is held high.



#### Figure 25. **PTP Receive Block Diagram**





#### Figure 26. Example Waveform PTP Timestamp on RX PTP Interface



## **Related Information**

#### **IEEE** website

The IEEE 1588-2008 Precision Clock Synchronization Protocol for Networked Measurement and Control Systems Standard is available on the IEEE website.

## 2.9.2.4. External Time-of-Day Module for 1588 PTP Variations

E-Tile Hard IP for Ethernet Intel FPGA IP that include the 1588 PTP module require an external time-of-day (TOD) module to provide the current time-of-day in each clock cycle, based on the incoming clock. The TOD module must update the time-of-day output value on every clock cycle, and must provide the TOD value in the V2 format (96 bits) or the 64-bit TOD format, or both.

Note: You will observe a difference of 2 alignment marker period between the timestamp of the external ToD and TAM in the E-Tile Hard IP for Ethernet Intel FPGA IP when the external ToD module is set to use 16 bits fractional nanoseconds. However, the TAM module has a 24 bit fns representation to do the drift correction and does not rely on the external ToD timestamp.

## 2.9.2.5. PTP Timestamp and TOD Formats

The E-Tile Hard IP for Ethernet Intel FPGA IP supports a 96-bit timestamp (V2 format) or a 64-bit timestamp (correction-field format) in PTP packets. The 64-bit timestamp and TOD signals of the IP core are in an Intel-defined 64-bit format that is distinct from the  $V_1$  format, for improved efficiency in one-step processing correction mode.

The IP core completes all internal processing in the V2 format. However, if you specify V1 format for a particular PTP packet in one-step insertion mode, the IP core inserts the appropriate V1-format timestamp in the outgoing packet on the Ethernet link.





### V2 Format

The IP core maintains the time-of-day (TOD) in V2 format according to the IEEE specification::

- Bits [95:48]: Seconds (48 bits).
- Bits [47:16]: Nanoseconds (32 bits). This field overflows at 1 billion.
- Bits [15:0]: Fractions of nanosecond (16 bits). This field is a true fraction; it overflows at 0xFFFF.

#### V1 Format

V1 timestamp format is specified in the IEEE specification:

- Bits [63:32]: Seconds (32 bits).
- Bits [31:0]: Nanoseconds (32 bits). This field overflows at 1 billion.

#### **Intel 64-Bit TOD Format**

The Intel 64-bit TOD format is distinct from the V1 format and supports a longer time delay. It is intended for use in transparent clock systems, in which each node adds its own residence time to a running total latency through the system. This format matches the format of the correction field in the packet, as used in transparent clock mode.

- Bits [63:16]: Nanoseconds (48 bits). This field can specify a value greater than 4 seconds.
- Bits [15:0]: Fractions of nanosecond (16 bits). This field is a true fraction; it overflows at 0xFFFF.

The TOD module provides 64-bit TOD information to the IP core in this 64-bit TOD format. The expected format of all 64-bit input timestamp and TOD signals to the IP core is the Intel 64-bit TOD format. The format of all 64-bit output timestamp and TOD signals from the IP core is the Intel 64-bit TOD format. If you build your own TOD module that provides 64-bit TOD information to the IP core, you must ensure it provides TOD information in the Intel 64-bit TOD format.

#### **Related Information**

#### **IEEE** website

The *IEEE 1588-2008 Precision Clock Synchronization Protocol for Networked Measurement and Control Systems Standard* is available on the IEEE website.

#### 2.9.2.6. TX and RX Unit Interval Adjustment

The accuracy drift occurs when there is a PPM difference between the MAC layer clock and the Master TOD clock. To correct the drift, you may use the RX and TX Unit Interval (UI) adjustment method. IEEE 802.3 standards permit the Ethernet clocks frequency to vary within  $\pm 100$  PPM.

For the system with PPM, you are required to do at least one UI adjustment once out of reset. Any timestamp before the UI adjustment is invalid. The UI adjustment shall be performed after the  $rx/tx_ptp_ready$  is asserted and before starting any PTP operation. The UI adjustment applies to the system independent of PPM as long as the PPM is within the Ethernet specification. Once UI adjustment is completed, it takes two Alignment marker periods for UI to adjust and produce an accurate timestamp.



The UI adjustment is a software flow, implemented by user software, utilizing 10G/25G PTP PPM UI Adjustment registers in the 1588 PTP Registers on page 237 section to compute the new UI. Once determined, the UI register updates the UI value.

## **UI Adjustment Calculation**

The UI Adjustment Calculation applies to both, TX and RX paths. The software must take at least two snapshots of the 10G/25G PTP PPM UI Adjustment registers within 1s time frame. The new UI value is computed from the difference between the two snapshots. The longer the interval between the first and the next snapshot, the better accuracy the new UI value provides.<sup>(2)</sup> The accuracy can also be improved by taking multiple snapshots within 1s time frame. If two compared snapshots are taken outside of the 1s time frame, they shall be discarded.

*Note:* The UI adjustment shall not be performed when TOD changes are in progress or during reset.

User software performs the following steps to calculate the new UI value.

- Set TAM\_SNAPSHOT to 1 to take the first snapshot of the Time of Alignment Marker (TAM) and the Alignment Marker Count (AM\_Count) values. The user software snapshots the TAM and AM\_Count values into the TX/RX\_TAM\_H/L and TX/RX\_COUNT registers located in the 1588 PTP Registers on page 237.
- 2. Read TX/RX\_TAM\_H/L and TX/RX\_COUNT registers and save values from the first snapshot as:
  - TX\_TAM\_0 = {TX\_TAM\_H, TX\_TAM\_L}
  - TX\_Count\_0 = TX\_COUNT
  - RX\_TAM\_0 = {RX\_TAM\_H, RX\_TAM\_L}
  - RX\_Count\_0 = RX\_COUNT
- 3. Clear TAM\_SNAPSHOT to 0 to complete the first snapshot.
- 4. Set TAM\_SNAPSHOT to 1 again to take the N<sup>th</sup> snapshot of the TAM and AM\_Count values where N represents the number of taken snapshots.
- 5. Read TX/RX\_TAM\_H/L and TX/RX\_COUNT registers and save values from the  $N^{th}$  snapshot:
  - TX\_TAM\_N = {TX\_TAM\_H, TX\_TAM\_L}
  - TX\_Count\_N = TX\_COUNT
  - RX\_TAM\_N = {RX\_TAM\_H, RX\_TAM\_L}
  - RX\_Count\_N = RX\_COUNT
- Ensure the interval between the 1<sup>th</sup> snapshot and the N<sup>th</sup> snapshot is within 1s else the snapshots are invalid for use and the user software needs to restart from step 1.
- 7. Calculate the new UI value:



<sup>(2)</sup> Comparing the first snapshot with a third snapshot taken at a later time will give a more accurate UI than comparing the first snapshot with the second snapshot taken at an earlier time.



UI = TAM\_Interval / (AM\_Count \* Reference\_Time\_Load\_Interval).

Refer steps below to calculate TAM\_Interval, AM\_Count, and est\_AM\_Count.

*Note:* For more information on Reference Time Load Interval, refer to the Table 22 on page 87.

- 8. Compute the TAM\_Interval value. TAM is a time value in nanosecond (ns). Once the TAM value reaches 1 billion ns, it rolls over to 1s creating a rollover condition. When TAM value rolls over, the subsequent TAM\_N value will appear smaller than the first TAM\_0 value.
  - If (TAM\_N > TAM\_0): TAM\_Interval (ns) = (TAM\_N TAM-\_0)
  - If  $(TAM_N \le TAM_0)$ : TAM\_Interval  $(ns) = ((1s + TAM_N) TAM_0)$

To calculate the TX\_TAM\_Interval, replace TAM\_N with TX\_TAM\_N value and TAM\_0 with TX\_TAM\_0 value. Same steps apply to calculate the RX\_TAM\_Interval.

9. Calculate the estimated AM Count (est\_AM\_Count). The est\_AM\_Count value is used to ensure that AM\_Count, calculated in next step, is valid.

est\_AM\_Count = INT (TAM\_Interval / (Reference\_Time\_Load\_Interval \* 0ppm\_UI)

where INT() is a round up function to the nearest integer, the value of 0ppm\_UI for 10GE variant is 96.969696 ps and the value of 0ppm\_UI for 25GE variant is 38.787878 ps. Compare the est\_AM\_Count with 64,000, which is the maximum AM\_Count with offset. If est\_AM\_count exceeds 64,000, discard the snapshot and start from step 1.

- 10. Calculate the AM\_Count value. AM\_Count can reach a rollover condition when reaching maximum value. Use the appropriate equation to calculate the AM\_Count.
  - If (Count\_N > Count\_0): AM\_Count = (Count\_N Count\_0)
  - If (Count\_N  $\leq$  Count\_0): AM\_Count = ((65,535 Count\_0) + Count\_N)
- 11. Write the calculated TX and RX UI values to  $\texttt{TX\_UI\_REG}$  and <code>RX\\_UI\\_REG</code> registers.

#### Table 22.Reference Time Load Interval

This table shows the Reference time load interval values for PPM UI adjustment calculation.

| Configuration                     | Data Path | Reference_Time_Load_Interval value in bits                                                    |
|-----------------------------------|-----------|-----------------------------------------------------------------------------------------------|
| 25G variant with RS-FEC           | тх        | 81,920*66=5,406,720                                                                           |
|                                   |           | Note: 81,920 is a 66-bit value of alignment<br>marker interval (in terms of block<br>numbers) |
|                                   | RX        | 81,920*66=5,406,720                                                                           |
| 10GE/25GE variants without RS-FEC | тх        | 81,920*66=5,406,720                                                                           |
|                                   | RX        | 6,336                                                                                         |

# 2.9.2.7. TX and RX PTP Extra Latency

TX\_PTP\_EXTRA\_LATENCY and RX\_PTP\_EXTRA\_LATENCY signals define extra latency that IP core adds to the outgoing TX and the incoming RX timestamps. This time offset applies to all time values processed by the TX and RX PTP logic. It can be used to account for known errors on the PCB, or in other parts of the system.



#### **TX and RX PMA Delay** Table 23.

The table specifies transmitter and receiver PMA delay.

| Configuration                   | Datapath | PMA Delay<br>(in Hardware) | PMA Delay<br>(in Simulation) |
|---------------------------------|----------|----------------------------|------------------------------|
| 10G                             | ТХ       | 105                        | 105                          |
| 10G                             | RX       | 89                         | 91                           |
| 25G with and without RS-<br>FEC | ТХ       | 105                        | 107                          |
| 25G with and without RS-<br>FEC | RX       | 89                         | 94                           |

#### Steps to Calculate TX PTP Extra Latency

- 1. Determine TX PMA delay from the TX and RX PMA Delay table.
- 2. Calculate the TX PTP Extra Latency:
  - TX\_PTP Extra Latency = TX PMA Delay \* UI period (in ns)

## Steps to Calculate RX PTP Extra Latency

- 1. Determine RX PMA delay from the TX and RX PMA Delay table.
- 2. Calculate the RX PTP Extra Latency:

RxCWPos represents a number of bit slips required to achieve RS-FEC alignment. Read PMA AVMM register 0x29[4:0] to obtain this value.

RxBitSlip represents the number of bit slips required to achieve a block alignment.

- RX PTP Extra Latency = -((RX PMA Delay + RxCWPos) \* UI period (in ns)) for 25G with RS-FEC.
- RX PTP Extra Latency = -((RX PMA Delay + RxBitSlip 66) \* UI period (in ns)) for 10G/25G without RS-FEC when RxBitSlip is greater than 62.
- RX PTP Extra Latency = -((RX PMA Delay + RxBitSlip) \* UI period (in ns)) for • 10G and 25G without RS-FEC when RxBitSlip is smaller than 62.

# 2.9.2.8. PTP System Considerations

This section provides list of generic guidelines required when using PTP IP.

- You need to wait for the o\_tx\_ptp\_ready to be asserted before sending the PTP packet in TX direction.
- You shall ignore the RX timestamp when o\_rx\_ptp\_ready is deasserted.
- Training sequence (of any packet type) is required on the RX direction to complete RX PTP deskew process and only then o\_rx\_ptp\_ready can be asserted. Therefore, the o rx ptp ready signal can be asserted at a much later time than the o tx ptp ready signal, depending on whether the link partner is sending any packet.
- The o tx ptp ready is deasserted when triggering i sl tx rsn n or i\_sl\_csr\_rst\_n resets.





- The o\_rx\_ptp\_ready is deasserted when triggering i\_sl\_tx\_rsn\_n, i\_sl\_rx\_rsn\_n, or i\_sl\_csr\_rst\_n. In the TX reset case, even though the o\_rx\_ptp\_ready is deasserted, it doesn't reset RX PTP deskew logic and there is no need for training sequence to assert o\_rx\_ptp\_ready again.
- The o\_rx\_ptp\_ready signal is deasserted if the Ethernet link disconnects.
- If you run a PMA adaptation after the Ethernet link is established, the Ethernet link goes down again and come back once the PMA calibration is completed.
- During the reset or a major TOD update, you must wait for at most 2 Alignment Marker (AM) periods before sending a PTP packet in the TX direction. This provides sufficient time to load the new TAM value into the IP. You may observe a timestamp inaccuracy within these 2 AM periods. You can assume this AM period = (81.920 \* 66 \* 97 ps) = 524,451,840 ps for overall speed. You can ignore the RX timestamp within this period.

# 2.9.3. PCS, OTN, FlexE, and Custom PCS Modes

Each E-Tile Hard IP for Ethernet Intel FPGA IP instance contains a full featured multilane PCS layer, which offers a number of interfacing options from the FPGA fabric.

The IP offers the following PCS options:

- PCS Only This mode uses the MII interface to transmit and receive Ethernet packets for data rate of 10/25/100 Gbps.
- OTN and FlexE This mode uses the PCS66 interface to read and write 66 bit blocks data, from and to the PMA block.
- Custom PCS This mode uses the MII interface to transmit and receive packets from non-Ethernet protocols with data rates with 2.5 to 28 Gbps.







#### Figure 27. **TX PCS Datapath with and without RS-FEC**





#### RX PCS/PCS66 Datapath without RSFEC **RX PCS/PCS66 Datapath with RSFEC** MII (to RX MAC or soft logic) MII (to RX MAC or soft logic) **RX PCS** PCS66 (to soft logic) **RX PCS** PCS66 (to soft logic) RX 64/66B Decoder RX 64/66B Decoder **RS-FEC** PCS66 **RX** Descrambler PCS66 **RX** Descrambler PCS66 (Descrambled) PCS66 (Descrambled) PCS66 PCS66 Aligner Aligner PCS Only FlexE OTN PCS Only FlexE OTN /Custom PCS /Custom PCS PCS66 (From RX PMA Input) PCS66 (From RX PMA Input)

#### Figure 28. RX PCS Datapath with and without RS-FEC

2.9.3.1. PCS Only Mode

The E-Tile Hard IP for Ethernet Intel FPGA IP supports PCS only mode in 10/25G and 100G variants with optional RSFEC feature. It can support up to four PCS channels in 10/25G variant. This mode bypassed the Ethernet MAC and uses MII interface to read and write to the PMA block.

The PCS TX datapath consists of:

- TX PCS encoder—encodes the data from the PMA interface.
- TX PCS scrambler—enables the data to be scrambled. Channels will not lock correctly if the data is not scrambled.
- Alignment insertion—the TX PCS interface inserts alignment markers.
- Striper—enables logically sequential data to be segmented to increase data throughput.

The PCS RX datapath consists of:

- Aligner—enables the alignment of incoming data.
- RX PCS descrambler—enables the incoming scrambled data to be descrambled.
- RX PCS decoder—decodes the incoming encoded data from the PMA interface.





# 2.9.3.2. OTN Mode

The E-Tile Hard IP for Ethernet Intel FPGA IP supports OTN mode in 10/25G and 100G variants with optional RSFEC feature. It can support up to four OTN channels in 10/25G variant. This mode bypassed the Ethernet MAC and uses PCS66 interface to read and write to the PMA block.

The OTN TX datapath consists of:

- Alignment insertion—the TX PCS interface inserts alignment markers.
- Striper-enables logically sequential data to be segmented to increase data • throughput.
- Note: In OTN mode, scrambler is bypassed because the input data is expected to be scrambled.

The OTN RX datapath consists of an aligner block that enables the alignment of the incoming data.

## 2.9.3.3. FlexE Mode

The E-Tile Hard IP for Ethernet Intel FPGA IP supports FlexE mode in 10/25G and 100G variants with optional RSFEC feature. It can support up to four FlexE channels in 10/25G variant. This mode bypassed the Ethernet MAC and uses PCS66 interface to read and write to the PMA block.

The FlexE TX datapath consists of:

- TX PCS scrambler-enables the data to be scrambled. Channels will not lock correctly if the data is not scrambled.
- Alignment insertion—the TX PCS interface inserts alignment markers
- Striper—enables logically sequential data to be segmented to increase data throughput.

The FlexE RX datapath consists of:

- Aligner-enables the alignment of incoming data.
- RX PCS descrambler—enables the incoming scrambled data to be descrambled.

#### 2.9.3.4. Custom PCS Mode

The E-Tile Hard IP for Ethernet Intel FPGA IP supports up to four custom PCS channels with RSFEC feature. This mode bypasses the Ethernet MAC and uses MII interface to transmit and receive packets with data rate between 2.5 to 28 Gbps.

Note: The custom PCS mode does not support auto-negotiation and link training features in the Intel Quartus Prime version 19.1.

The custom PCS TX datapath consists of:





- TX PCS encoder—encodes the data from the PMA interface.
- TX PCS scrambler—enables the data to be scrambled. Channels will not lock correctly if the data is not scrambled.
- Alignment insertion—the TX PCS interface inserts alignment markers.
- Striper—enables logically sequential data to be segmented to increase data throughput.

The PCS RX datapath consists of:

- Aligner—enables the alignment of incoming data.
- RX PCS descrambler—enables the incoming scrambled data to be descrambled.
- RX PCS decoder—decodes the incoming encoded data from the PMA interface.

# 2.9.4. Auto-Negotiation and Link Training

The E-Tile Hard IP for Ethernet Intel FPGA IP variations with auto-negotiation and link training implement the *IEEE Backplane Ethernet Standard* 802.3-2012.

The IP core includes the option to implement the following features:

- Auto-negotiation provides a process to explore coordination with a link partner on a variety of different common features. Turn on the Enable AN/LT and parameter to configure support for auto-negotiation. Turn on the Enable Auto-Negotiation on Reset parameter to enable auto-negotiation by default after reset.
- Link training provides a process for the IP core to train the link to the data frequency of incoming data while compensating for variations in process, voltage, and temperature. Turn on the Enable AN/LT parameter to configure support for link training. Turn on the Enable Link Training on Reset parameter to enable link training by default after reset. When enabled, link training performs the initial and continuous adaptation. For more details on adaptation modes, refer to the E-Tile Transceiver PHY User Guide.

The E-Tile Hard IP for Ethernet Intel FPGA IP includes separate auto-negotiation and link training modules for each of the 10G/25G channels. For 100G, the IP provides auto-negotiation functionality on a single channel specified by the **Auto-Negotiation Master** parameter and separate link training modules for each channel.

#### **Related Information**

- Auto Negotiation and Link Training Registers on page 159
- E-Tile Transceiver PHY User Guide

# 2.9.5. TX and RX RS-FEC

If you turn on **Enable RS-FEC** in the E-Tile Hard IP for Ethernet Intel FPGA IP parameter editor, the IP core includes Reed-Solomon forward error correction (FEC) in both the receive and transmit datapaths. This feature is only available in 25G and 100G variants.

The IP core implements Reed-Solomon FEC per Clause 91 of the IEEE Standard 802.3bj. The Reed-Solomon FEC algorithm includes the following modules:





- TX RS-FEC
  - 64b/66b to 256b/257b transcoding
  - High-Speed Reed-Solomon encoder
- **RX RS-FEC** 
  - Alignment marker lock
  - 256b/257b to 64b/66b transcoding
  - High-Speed Reed-Solomon decoder

#### E-Tile Transceiver PHY User Guide

More information about RS-FEC architecture.

# 2.9.6. PMA Direct Mode

The E-Tile Hard IP for Ethernet Intel FPGA IP provides an option to switch from 10G/25G MAC+PCS variant to use PMA only mode during run-time. In this mode, only the reconfiguration and PMA interfaces are enabled. The MAC interface to user logic connection is disabled. The additional interface when you enabled this mode are:

- i\_sl\_tx\_pma[ch-1:0]
- o sl rx pma[ch-1:0]

Enable the **Include alternate ports** in the parameter editor to expose the PMA direct signals. Set tx ehip mode[2:0] of register Configuration Fields for TX PLD (address 0x350) to 3'h7 to enable the PMA direct mode. This feature is supported only in 100GE or 1 to 4 10GE/25GE with optional RSFEC and 1588 PTP variant.

#### **Related Information**

PMA Direct Interface on page 127

# 2.9.7. Dynamic Reconfiguration

You can dynamically reconfigure the settings in the E-Tile Hard IP for Ethernet Intel FPGA IP to run your design in different data rates and features.

In Intel Quartus Prime software, you can dynamically reconfigure the E-Tile Hard IP for Ethernet Intel FPGA IP to the following variants:

#### Table 24. List of Supported Dynamic Reconfiguration Design Example Variants

| Dynamic Reconfiguration Protocol | Variant                              |
|----------------------------------|--------------------------------------|
| 10G/25G Ethernet Protocol        | 10G/25G with PTP and optional RS-FEC |
|                                  | 10G/25G with optional RS-FEC         |
| CPRI                             | 10G/24G CPRI with optional RS-FEC    |
| 25G Ethernet to CPRI Protocol    | 25G with PTP and optional RS-FEC     |

For more information on the steps and guidelines to use the dynamic reconfiguration feature, refer to the E-tile Hard IP Intel Stratix 10 Design Examples User Guide: Ethernet, CPRI PHY, and Dynamic Reconfiguration.





E-tile Dynamic Reconfiguration Design Example

# **2.9.8. Ethernet Adaptation Flow for 10G/25G and 100G/4x25G Dynamic Reconfiguration Design Example**

Refer to *Loading a PMA Configuration* and *PMA Registers 0x200 to 0x203 Usage* sections in the *E-tile Transceiver PHY User Guide* for more details on the adaptation flow and how to get started.

This adaptation flow assumes a valid Ethernet traffic. 10GE/25GE variant uses the external AIB clocking. 100GE/4x25G variant is using a non-external AIB clocking.

- 1. Assert i\_sl\_tx\_rst\_n/i\_tx\_rst\_n and i\_sl\_rx\_rst\_n/i\_rx\_rst\_n signals.
- 2. Disable the  $PMA^{(3)}$ .
- 3. Trigger PMA analog reset. Don't call the interrupt sequencer.
- 4. Perform dynamic reconfiguration sequence:
  - a. Switch reference clock.
  - b. Change reference clock ratio.
  - c. Apply RX phase slip.
  - d. Reconfigure AIB, EHIP, PCS, and enable/disable RS-FEC registers.
- 5. In 100GE/4x25GE variants, perform the dynamic reconfiguration reset. Dynamic Reconfiguration requires a staggered reset. For more information, refer to the reset sequence information in the *E-tile Hard IP Intel Stratix 10 Design Example User Guide: Ethernet, CPRI PHY, and Dynamic Reconfiguration*.
- 6. Enable the PMA<sup>(3)</sup>.
- 7. Deassert the i\_sl\_tx\_rst\_n/i\_tx\_rst\_n signal.
- If using a PMA configuration, load the PMA configuration using control status registers (CSR). This is loaded to the registers using PMA registers 0x200 to 0x203<sup>(5)</sup>.
  - a. Write 0x40143 = 0x80.
  - b. Read 0x40144[0] until it changes to 1.
- 9. Enable internal serial loopback<sup>(6)</sup> and run initial adaptation. Verify that the initial adaptation status is complete using interrupt code 0x0126 and data 0x0B00.
- 10. Enable mission mode and disable internal serial loopback (skip this step if using internal serial loopback)<sup>(6)</sup>.
- 11. Wait for valid data traffic on RX and then proceed to the next step.

<sup>(3)</sup> Refer to 0x0001: PMA Enable/Disable.

- <sup>(4)</sup> Refer to *PMA Analog Reset*.
- <sup>(5)</sup> Refer to Loading a PMA Configuration and PMA Registers 0x200 to 0x203 Usage.
- <sup>(6)</sup> For how to enable and disable internal serial loopback, refer to *0x0008: Internal Serial Loopback and Reverse Parallel Loopback Control.*





- 12. Run initial adaptation. Verify that the initial adaptation status is complete using interrupt code 0x0126 and data 0x0B00 (skip this step if using internal serial loopback).
- 13. Run continuous adaptation<sup>(7)</sup>.
- 14. Deassert the i\_sl\_rx\_rst\_n/i\_rx\_rst\_n signal.
- 15. Optional: Verify that the link status signal rx\_aligned transitions high.
- 16. Send packets.

- E-Tile Hard IP for Ethernet Intel Agilex FPGA IP Design Example User Guide: Testing the 100G Ethernet Dynamic Reconfiguration Hardware Design Example More information about resetting sequence.
- E-Tile Transceiver PHY User Guide: Loading a PMA Configuration More information about loading a PMA configuration.
- E-Tile Transceiver PHY User Guide: PMA Registers 0x200 to 0x203 Usage More information about PMA registers usage.
- E-Tile Transceiver PHY User Guide: PMA Attribute Codes More information about RX phase slip usage.

# 2.9.9. Ethernet Adaptation Flow with External AIB Clocking and PTP

This adaptation flow applies to single and multilane 10GE/25GE variants.

Refer to Loading a PMA Configuration and PMA Registers 0x200 to 0x203 Usage sections in the E-tile Transceiver PHY User Guide for more details on the adaptation flow and how to get started.

This adaptation flow assumes a valid Ethernet traffic.

- 1. Assert i sl tx rst n and i sl rx rst n signals.
- 2. Trigger PMA analog reset.
- 3. Reload PMA settings (call the PMA attribute sequencer) using  $0x91[0] = 1^{(8)}$ .
- 4. Deassert the i\_sl\_tx\_rst\_n signal.
- 5. If using a PMA configuration, load the PMA configuration using control status registers (CSR). This is loaded to the registers using PMA registers 0x200 to 0x203<sup>(9)</sup>.
  - a. Write 0x40143 = 0x80.
  - b. Read 0x40144[0] until it changes to 1.
- 6. Enable internal serial loopback<sup>(10)</sup> and run initial adaptation. Verify that the initial adaptation status is complete using interrupt code 0x0126 and data 0x0B00.



<sup>(7)</sup> During the continuous adaptation, the link partner must keep sending the data. If link goes down, the entire sequence must be repeated.

<sup>&</sup>lt;sup>(8)</sup> Refer to PMA Analog Reset.

<sup>&</sup>lt;sup>(9)</sup> Refer to Loading a PMA Configuration and PMA Registers 0x200 to 0x203 Usage.



- Enable mission mode and disable internal serial loopback (skip this step if using internal serial loopback)<sup>(10)</sup>.
- 8. Wait for valid data traffic on RX and then proceed to the next step.
- Run initial adaptation. Verify that the initial adaptation status is complete using interrupt code 0x0126 and data 0x0B00 (skip this step if using internal serial loopback).
- 10. Run continuous adaptation<sup>(11)</sup>.
- 11. Deassert the i\_sl\_rx\_rst\_n signal.
- 12. Optional: Verify that the link status signal rx\_aligned transitions high.
- 13. Send packets.

- E-Tile Transceiver PHY User Guide: Loading a PMA Configuration More information about loading a PMA configuration.
- E-Tile Transceiver PHY User Guide: PMA Registers 0x200 to 0x203 Usage More information about PMA registers usage.

# 2.9.10. Ethernet Adaptation Flow with Non-external AIB Clocking

This adaptation flow applies to single 10GE/25GE/100GE and multilane 10GE/25GE variants.

Refer to *Loading a PMA Configuration* and *PMA Registers 0x200 to 0x203 Usage* sections in the *E-tile Transceiver PHY User Guide* for more details on the adaptation flow and how to get started.

This adaptation flow assumes a valid Ethernet traffic.

- 1. Assert i\_sl\_tx\_rst\_n/i\_tx\_rst\_n and i\_sl\_rx\_rst\_n/i\_rx\_rst\_n signals.
- 2. Trigger PMA analog reset.
- 3. Reload PMA settings (call the PMA attribute sequencer) on all lanes.
- 4. Apply control status registers (CSR) reset.
  - a. For 100GE/25GE/10GE single instance, cycle control status registers (CSR) reset.
  - b. For 25GE/10GE multilane instance, hold CSR reset on slave channels, cycle master channel CSR reset, then release CSR reset on slave channels as indicated in the below figure.

- <sup>(11)</sup> During the continuous adaptation, the link partner must keep sending the data. If link goes down, the entire sequence must be repeated.
- <sup>(12)</sup> Refer to *PMA Analog Reset*.



<sup>&</sup>lt;sup>(10)</sup> For how to enable and disable internal serial loopback, refer to *0x0008: Internal Serial Loopback and Reverse Parallel Loopback Control.* 



# Figure 29. Reset Sequence in 10G/25G Multilane Mode



- 5. Deassert the i\_sl\_rx\_rst\_n/i\_rx\_rst\_n signal.
- 6. If using a PMA configuration, load the PMA configuration using control status registers (CSR). This is loaded to the registers using PMA registers 0x200 to  $0x203^{(13)}$ .
  - a. Write 0x40143 = 0x80.
  - b. Read 0x40144[0] until it changes to 1.
- 7. Enable internal serial loopback<sup>(14)</sup> and run initial adaptation. Verify that the initial adaptation status is complete using interrupt code 0x0126 and data 0x0B00.
- 8. Enable mission mode and disable internal serial loopback (skip this step if using internal serial loopback)<sup>(14)</sup>.
- 9. Wait for valid data traffic on RX and then proceed to the next step.
- Run initial adaptation. Verify that the initial adaptation status is complete using interrupt code 0x0126 and data 0x0B00 (skip this step if using internal serial loopback).
- 11. Run continuous adaptation<sup>(15)</sup>.
- 12. Deassert the i\_sl\_rx\_rst\_n/i\_rx\_rst\_n signal.
- 13. Optional: Verify that the link status signal  $rx_aligned$  transitions high.
- 14. Send packets.

<sup>(15)</sup> During the continuous adaptation, the link partner must keep sending the data. If link goes down, the entire sequence must be repeated.



<sup>&</sup>lt;sup>(13)</sup> Refer to Loading a PMA Configuration and PMA Registers 0x200 to 0x203 Usage.

<sup>&</sup>lt;sup>(14)</sup> For how to enable and disable internal serial loopback, refer to *0x0008: Internal Serial Loopback and Reverse Parallel Loopback Control.* 



- E-Tile Transceiver PHY User Guide: Loading a PMA Configuration More information about loading a PMA configuration.
- E-Tile Transceiver PHY User Guide: PMA Registers 0x200 to 0x203 Usage More information about PMA registers usage.

# 2.10. Reset

Ethernet registers control three distinct soft resets:

- eio\_sys\_rst
- soft\_tx\_rst
- soft\_rx\_rst

These soft resets are not self-clearing. The reconfig port clears the soft resets by writing to the appropriate register. The IP core also has three hard reset signals, which are active low:

- i\_csr\_rst\_n (100G)/i\_sl\_csr\_rst\_n (10G/25G)
- i\_tx\_rst\_n (100G)/i\_sl\_tx\_rst\_n (10G/25G)
- i\_rx\_rst\_n (100G)/i\_sl\_rx\_rst\_n (10G/25G)

#### Figure 30. Conceptual Overview of General IP Core Reset Logic





Asserting the external hard reset <code>i\_csr\_rst\_n/i\_sl\_csr\_rst\_n</code> or the soft reset eio\_sys\_rst returns all Ethernet registers to their original values, including the statistics counters. An additional dedicated reset signal, i\_reconfig\_reset, resets the transceiver reconfiguration, Ethernet reconfiguration interfaces, and some Ethernet soft registers.

#### Table 25. **Reset Signal Functions**

In this table, a tick (v) represents the block is reset by the specified reset signal. A dash (–) represents the block is not impacted by the specified reset signal.

| Reset Signal                |                      | Block        |              |              |                     |                  |                      |              |              |              |                     |                  |
|-----------------------------|----------------------|--------------|--------------|--------------|---------------------|------------------|----------------------|--------------|--------------|--------------|---------------------|------------------|
|                             | TX EMIB<br>Interface | TX<br>MAC    | TX<br>PCS    | TX<br>FEC    | TX PMA<br>Interface | TX<br>Statistics | RX EMIB<br>Interface | RX<br>MAC    | RX<br>PCS    | RX<br>FEC    | RX PMA<br>Interface | RX<br>Statistics |
| i_sl_csr_rst_n              | $\checkmark$         | $\checkmark$ | $\checkmark$ | _            | $\checkmark$        | $\checkmark$     | $\checkmark$         | $\checkmark$ | $\checkmark$ | -            | $\checkmark$        | $\checkmark$     |
| i_csr_rst_n<br>soft_sys_rst | V                    | V            | $\checkmark$ | V            | $\checkmark$        | $\checkmark$     | $\checkmark$         | V            | V            | V            | $\checkmark$        | V                |
| i_sl_tx_rst_n               | -                    | $\checkmark$ | $\checkmark$ | -            | $\checkmark$        | _                | -                    | -            | -            | -            | -                   | -                |
| i_tx_rst_n<br>soft_tx_rst   | -                    | V            | V            | V            | $\checkmark$        | _                | _                    | -            | _            | _            | _                   | -                |
| i_rsfec_tx_rst_n            | -                    | -            | _            | $\checkmark$ | -                   | _                | _                    | -            | -            | -            | -                   | _                |
| i_sl_rx_rst_n               | -                    | -            | _            | -            | -                   | _                | -                    | $\checkmark$ | $\checkmark$ | -            | -                   | -                |
| i_rx_rst_n<br>soft_rx_rst   | -                    | -            | -            | _            | _                   | -                | -                    | V            | V            | V            | -                   | -                |
| i_rsfec_rx_rst_n            | -                    | -            | _            | -            | -                   | _                | -                    | -            | -            | $\checkmark$ | -                   | -                |
| soft_clear_tx_stats         | -                    | -            | —            | —            | -                   | $\checkmark$     | -                    | -            | -            | -            | -                   | -                |
| soft_clear_rx_stats         | -                    | —            | —            | -            | _                   | _                | _                    | —            | -            | -            | -                   | $\checkmark$     |





The general reset signals reset the following functions:

- soft\_tx\_rst, i\_tx\_rst\_n/i\_sl\_tx\_rst\_n:
  - Resets the IP core in the TX direction.
  - Resets TX PCS, TX MAC, and TX PMA interface.
  - This reset leads to deassertion of the o\_tx\_lanes\_stable output signal.
- soft\_rx\_rst, i\_rx\_rst\_n/i\_sl\_rx\_rst\_n:
  - Resets the IP core in the RX direction.
  - Resets RX PCS, and RX MAC.
  - This reset leads to deassertion of the o\_rx\_pcs\_ready output signal.
- eio\_sys\_rst, i\_csr\_rst\_n/i\_sl\_csr\_rst\_n:
  - Resets the IP core. i\_csr\_rst\_n signal is edge sensitive. Perform the reset assertion and deassertion sequence at the i\_csr\_rst\_n 0->1 edge.
  - Resets the TX and RX MAC, TX and RX EMIB interface, Ethernet reconfiguration registers, PCS, and TX and RX PMA interfaces.
  - This reset leads to deassertion of the o\_tx\_lanes\_stable and o\_rx\_pcs\_ready output signals.
- i\_rsfec\_tx\_rst\_n:
  - Resets the RS-FEC TX datapath for all RS-FEC channels.
  - This signal is shared across all RS-FEC channels, therefore asserting this signal resets all the RS-FEC channels.
- i\_rsfec\_rx\_rst\_n:
  - Resets the RS-FEC RX datapath for all RS-FEC channels.
  - This signal is shared across all RS-FEC channels, therefore asserting this signal resets all the RS-FEC channels.

In addition, the synchronous i\_reconfig\_reset signal resets the IP core transceiver reconfiguration interface, Ethernet reconfiguration interfaces, and some Ethernet soft registers. i\_reconfig\_reset signal is synchronous to the i\_reconfig\_clk and is positive edge triggered.

PMA reset is only required when you are change PMA settings. For PMA reset information, refer to *PMA Reset* and *PMA Analog Reset* in the *Intel Stratix 10 E-Tile Transceiver PHY User Guide*.

#### **System Considerations**

You should perform a system reset before beginning IP core operation, preferably by asserting and deasserting the i\_csr\_rst\_n/i\_sl\_csr\_rst\_n and i\_reconfig\_reset signals together. To assert i\_csr\_rst\_n/i\_sl\_csr\_rst\_n, drive the signal to 0. To deassert i\_csr\_rst\_n/i\_sl\_csr\_rst\_n, drive the signal to 1. To assert i\_reconfig\_reset, drive the signal to 1. To deassert i\_reconfig\_reset, drive the signal to 0. The IP core implements the correct reset sequence to reset the entire IP core.





If you assert the transmit reset when the downstream receiver is already aligned, the receiver loses alignment. Before the downstream receiver loses lock, it might receive some malformed frames.

If you assert the receive reset while the upstream transmitter is sending packets, the packets in transit are corrupted.

#### **Related Information**

- Reset Signals on page 139
- Reconfiguration and Status Register Descriptions on page 158
- PMA Reset
   More information about resetting PMA channels.
- PMA Analog Reset
   More information about resetting PMA internal controller.

# 2.10.1. Reset Sequence

The following waveforms shows the reset sequence using the i\_csr\_rst\_n (100G)/ i\_sl\_csr\_rst\_n (10G/25G), i\_tx\_rst\_n (100G)/i\_sl\_tx\_rst\_n (10G/25G), and i\_rx\_rst\_n (100G)/i\_sl\_rx\_rst\_n (10G/25G) signals.

#### Figure 31. External Hard Reset Sequence



#### Figure 32. TX Datapath Reset Sequence



#### Figure 33. RX Datapath Reset Sequence







## 2.10.1.1. Reset Sequence with External AIB Clocking

Below table shows the reset recommendation when the external AIB signal is used to reset the E-Tile Hard IP for Ethernet Intel FPGA IP data channels.

For details on general reset signals used during the reset, refer to *Reset* and *Reset Signals* sections.

#### Table 26. External AIB Clocking Reset Signal Functions

This table is a reset sequence recommendation when external AIB clock is enabled. Signals marked by a tick  $(\sqrt{})$  must be reset in the specified mode. Signals marked by a dash (-) don't required reset in the specified mode.

| Modes                                          |                          | Signals      |              |  |  |  |  |  |  |
|------------------------------------------------|--------------------------|--------------|--------------|--|--|--|--|--|--|
|                                                | i_csr_rst_n              | i_tx_rst_n   | i_rx_rst_n   |  |  |  |  |  |  |
| External AIB clock enable —<br>Master Channel  | _(16)                    | $\checkmark$ | $\checkmark$ |  |  |  |  |  |  |
| External AIB clock enable —<br>Slave Channel   | _(16)                    | $\checkmark$ | $\checkmark$ |  |  |  |  |  |  |
| External AIB clock disable —<br>Master Channel | <b>√</b> <sup>(17)</sup> | $\checkmark$ | $\checkmark$ |  |  |  |  |  |  |
| External AIB clock disable —<br>Slave Channel  | √(17)                    | $\checkmark$ | $\checkmark$ |  |  |  |  |  |  |

Use case example with 10G Master Ethernet channel and three 25G Slave Ethernet channels is shown in the *Master-Slave Configuration: Option 3- Dynamic Reconfiguration* clock network use case section.

For more information on PMA Analog Reset user cases, refer to the *E-tile Transceiver PHY User Guide*.

For more information on the dynamic reconfiguration, refer to the *Dynamic Reconfiguration Design Example User Guide*.

#### **Related Information**

- Master-Slave Configuration: Option 3 Dynamic Reconfiguration on page 150
- Reset on page 99
- Reset Signals on page 139
- E-Tile Transceiver PHY User Guide Information about the Native PHY IP Core.
- E-Tile Hard IP Intel Stratix 10 Design Example User Guide Information about the Dynamic Reconfiguration.
- E-Tile Hard IP Intel Agilex Design Example User Guide Information about the Dynamic Reconfiguration.

<sup>&</sup>lt;sup>(17)</sup> This case has a limitation. i\_csr\_rst\_n reset on the master channel will bring down the slave channel.



<sup>&</sup>lt;sup>(16)</sup> If the External AIB clock is enabled, there is no need to assert i\_csr\_rst\_n reset. If you assert this reset on the master channel after power on, it will bring down slave channels.



# 2.11. Interfaces and Signals

All input signal names begin with  $i_{-}$  and all output signal names begin with  $o_{-}$ .

# 2.11.1. TX MAC Interface to User Logic

The E-Tile Hard IP for Ethernet Intel FPGA IP TX client interface in MAC+PCS variations employs the Avalon streaming interface protocol. The Avalon streaming interface protocol is a synchronous point-to-point, unidirectional interface that connects the producer of a data stream (source) to a consumer of data (sink). The key properties of this interface include:

- Start of packet (SOP) and end of packet (EOP) signals delimit frame transfers.
- The SOP must always be in the MSB, simplifying the interpretation and processing of incoming data.
- A valid signal qualifies signals from source to sink.
- The sink applies backpressure to the source by using the ready signal. The source typically responds to the deassertion of the ready signal from the sink by driving the same data until the sink can accept it. The **Ready latency** defines the relationship between assertion and deassertion of the ready signal, and cycles which are considered to be ready for data transfer.

The client acts as a source and the TX MAC acts as a sink in the transmit direction.

#### Table 27. Signals of the AvalonStreaming TX Client Interface

All interface signals are clocked by the TX clock. The signal names are standard Avalon streaming interface signals with slight differences to indicate the variations. For example:

- For variants with single 10GE/25GE channel: <code>i\_sl\_tx\_data</code>
- For variants with more than 1 channel: i\_sl\_tx\_data[n-1:0]
- For variants with single 100GE channel: i\_tx\_data

| Signal Name                                         | Width                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>i_sl_clk_tx i_sl_clk_tx[n-1:0] i_clk_tx</pre>  | 1 bit for each channel               | The TX clock for the IP core that drives the channel.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| i_sl_tx_data<br>i_sl_tx_data[n-1:0]<br>i_tx_data    | 64 bits (10G/25G)<br>512 bits (100G) | TX data.<br>The E-Tile Hard IP for Ethernet Intel FPGA IP does<br>not process incoming packets of less than nine bytes.<br>You must ensure such frames do not reach the TX<br>client interface. The IP core marks incoming packets<br>of 9 to 13 bytes as errored, by adding Error Control<br>bytes to the packet upon transmission.<br>You must send each TX data packet without<br>intermediate IDLE cycles. Therefore, you must<br>ensure your application can provide the data for a<br>single packet in consecutive clock cycles. If data<br>might not be available otherwise, you must buffer<br>the data in your design and wait to assert the SOP<br>signal when you are assured the packet data to send<br>on the TX data is available or will be available on<br>time. |
| i_sl_tx_valid<br>i_sl_tx_valid[n-1:0]<br>i_tx_valid | 1 bit for each channel               | When asserted, the TX data signal is valid. This<br>signal must be continuously asserted between the<br>assertions of the start of packet and end of packet<br>signals for the same packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                     |                                      | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |



#### 2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



| i_sl_tx_empty<br>i_sl_tx_empty3 bits for each channel<br>(106/250)<br>6 bits (1006)Indicates the number of empty bytes on the TX data<br>when the EOP signal is asserted.i_sl_tx_empty1 bit for each channel<br>i_sl_tx_startofpacket [n-1:0]<br>i_tx_startofpacket [n-1:0]When asserted, indicates that the TX data holds the<br>first clock cycle of data in a packet (start of packet).<br>kast drives the start of packeti_sl_tx_startofpacket<br>i_sl_tx_endofpacket<br>i_sl_tx_endofpacket<br>i_sl_tx_endofpacket1 bit for each channel<br>first clock cycle of data in a packet (end) of packet.i_sl_tx_endofpacket<br>i_sl_tx_endofpacket<br>i_sl_tx_endofpacket1 bit for each channel<br>o_sl_tx_readyWhen asserted, indicates that the TX data holds the<br>first clock cycle of a bit of packet.o_sl_tx_ready<br>o_sl_tx_ready<br>i_sl_tx_ready(n-1:0)1 bit for each channel<br>o_tx_readyWhen asserted, indicates that the MAC can accept<br>the data Ready latency clock cycles. The the correct cycle s. The P core asserts the ready signal on<br>clock cycle s. The P core asserts the ready signal on<br>clock cycle s. The P core asserts the ready signal on<br>clock cycle s. The ready signal indicates that that clock cycle s. The ready signal indicates the MAC is ready to<br>ready uning a packet transfer on the TX data.i_sl_tx_error<br>i_sl_tx_error<br>i_sl_tx_error1 bit for each channel<br>i_sl_tx_errori_sl_tx_error<br>i_sl_tx_error1 bit for each channel<br>i_sl_tx_errori_sl_tx_error<br>i_sl_tx_error1 bit for each channel<br>i_sl_tx_errori_sl_tx_error<br>i_sl_tx_error1 bit for each channel<br>i_sl_tx_errori_sl_tx_error<br>i_sl_tx_error1 bit for each channel<br>i_sl_tx_errori_sl_tx_error1 bi                                                                                                                                              | Signal Name                  | Width                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_gl_tx_startofpacket[n-1:0]       i_set (start of packet).         i_set for only a single clock cycle for each packet. When the SOP signal is asserted, the MSB of the TX data drives the start of packet.         i_sl_tx_endofpacket       i_bit for each channel         i_set for only a single clock cycle for each packet.         i_tx_endofpacket[n-1:0]       i_set for only a single clock cycle for each packet.         i_tx_endofpacket[n-1:0]       i_set for only a single clock cycle for each packet.         o_sl_tx_ready       i_bit for each channel         when asserted, indicates that the MAC can accept the data Ready latency clock cycle of a clock cycle.         o_sl_tx_ready       i_bit for each channel         when asserted, indicates that the MAC can accept the data Ready latency clock cycles after the current cycle. The liP core asserts the ready signal on clock cycle <n> to indicate that clock cycle on the ready signal on clock cycle.         o_tx_ready       i bit for each channel       When asserted in anomal operational mode. However, the ready signal on clock cycle <n> to indicate that clock cycle on the ready signal on clock cycle. If the lP core dassers the ready signal on clock cycle <n> to indicate that the signal table signal indicates the MAC is ready to receive data in normal operational mode. However, the ready signal might not dees not send packet. The ready signal and packet in a sect end packet.         i_sl_tx_error       i bit for each channel       When asserted in an EOP cycle (while the EOP signal is asserted), directs the lP core to sisent an error in the rady signal signal sected in</n></n></n>                                                                                                                                                                           | i_sl_tx_empty[n-1:0]         | (10G/25G)              |                                                                                                                                                                                                                                                                                                                                                                                                                            |
| i_sl_tx_endofpacket[n-1:0]i_sl_tx_endofpacket[n-1:0]i_tx_endofpacketAssert for only a single clock cycle or each packet.<br>For some legitimate packets, the SOP and EOP<br>signals are asserted on the same clock cycle.o_sl_tx_ready<br>o_sl_tx_ready[n-1:0]1 bit for each channelWhen asserted, indicates that the MAC can accept<br>the data Ready latency clock cycles after the<br>current cycle. The IP core asserts the ready signal on<br>clock cycle. The client may<br>only transfer data during ready cycles. IT the IP core<br>deaserts the ready during a packet transfer on the<br>TX MAC client interface, the client may<br>only transfer data during ready cycles. IT the IP core<br>deaserts the ready signal indicates the MAC is ready to<br>receive data in normal operational mode. However,<br>the ready signal indicates the IP core to send a packet soft the<br>tau on the TX data.<br>The ready signal indicates the MAC is ready to<br>receive data in an EOP cycle (while the EOP signal<br>isal_tx_error[n-1:0]i_sl_tx_pause1 bit for each channelWhen asserted in an EOP cycle (while the EOP signal<br>is asserted), directs the IP core to send a packet.<br>This signal supports the client in selectively<br>invalidating a packet. It is also a test and debug<br>feature. In loopback mode, the IP core recognizes<br>the packet upon return as a malformed packet.i_sl_tx_pause1 bit for each channelWhen asserted, infects the IP core to end a PAUSE<br>XOFF firme on the Ethernet link.<br>This signal supports the client in selectively<br>invalidating a packet. It is also a test and debug<br>feature. In loopback mode, the IP core recognizes<br>the packet upon return as a malformed packet.i_sl_tx_pause1 bit for each channelWhen asserted, infects the IP core to end the<br>PAUSE period. The IP core sends a PAUSE XOFF<br>firme on t | i_sl_tx_startofpacket[n-1:0] | 1 bit for each channel | first clock cycle of data in a packet (start of packet).<br>Assert for only a single clock cycle for each packet.<br>When the SOP signal is asserted, the MSB of the TX                                                                                                                                                                                                                                                    |
| o_sl_tx_ready[n-1:0]o_tx_readyo_tx_readyo_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx_readyb_tx                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | i_sl_tx_endofpacket[n-1:0]   | 1 bit for each channel | final clock cycle of data in a packet (end of packet).<br>Assert for only a single clock cycle for each packet.<br>For some legitimate packets, the SOP and EOP                                                                                                                                                                                                                                                            |
| receive data in normal operational mode. However,<br>the ready signal might not be an adequate indication<br>following reset. To avoid sending packets before the<br>Ethernet link is able to transmit them reliably, you<br>should ensure that the application does not send<br>packets on the TX client interface until after the<br>o_tx_lanes_stable signal is asserted.i_sl_tx_error<br>i_tx_error1 bit for each channelWhen asserted in an EOP cycle (while the EOP signal<br>is asserted), directs the IP core to insert an error in<br>the packet before sending it on the Ethernet link.<br>This signal supports the client in selectively<br>invalidating a packet. It is also a test and debug<br>feature. In loopback mode, the IP core to send a PAUSE<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | o_sl_tx_ready[n-1:0]         | 1 bit for each channel | the data <b>Ready latency</b> clock cycles after the current cycle. The IP core asserts the ready signal on clock cycle $\langle n \rangle$ to indicate that clock cycle $\langle n \rangle$ <b>Ready latency</b> is a ready cycle. The client may only transfer data during ready cycles. If the IP core deasserts the ready during a packet transfer on the TX MAC client interface, the client must stall the data      |
| i_sl_tx_error[n-1:0]i_sl_tx_errori_i_tx_errori_tx_errori_sl_tx_errori_sl_tx_errori_sl_tx_pausei_sl_tx_pause[n-1:0]i_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pausei_tx_pau                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                              |                        | receive data in normal operational mode. However,<br>the ready signal might not be an adequate indication<br>following reset. To avoid sending packets before the<br>Ethernet link is able to transmit them reliably, you<br>should ensure that the application does not send<br>packets on the TX client interface until after the                                                                                        |
| XOFF frame on the Ethernet link. The rising edge<br>triggers the request. You must maintain this signal at<br>the value of 1 until you wish the IP core to end the<br>PAUSE period. The IP core sends a PAUSE XOFF<br>frame after it completes processing of the current in-<br>flight TX packet, and periodically thereafter, until you<br>deassert the i_tx_pause signal. When you deassert<br>the i_tx_pause signal, the IP core sends a PAUSE<br>XON frame on the Ethernet link.<br><i>Note:</i> For 10G/25G channels, you should hold the<br>i_sl_tx_pause signal more than 205 ns to<br>get the request captured by the MAC.<br>This signal is functional only if standard Ethernet flow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | i_sl_tx_error[n-1:0]         | 1 bit for each channel | is asserted), directs the IP core to insert an error in<br>the packet before sending it on the Ethernet link.<br>This signal supports the client in selectively<br>invalidating a packet. It is also a test and debug<br>feature. In loopback mode, the IP core recognizes                                                                                                                                                 |
| i_s1_tx_pause signal more than 205 ns to<br>get the request captured by the MAC.<br>This signal is functional only if standard Ethernet flow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | i_sl_tx_pause[n-1:0]         | 1 bit for each channel | XOFF frame on the Ethernet link. The rising edge triggers the request. You must maintain this signal at the value of 1 until you wish the IP core to end the PAUSE period. The IP core sends a PAUSE XOFF frame after it completes processing of the current inflight TX packet, and periodically thereafter, until you deassert the i_tx_pause signal. When you deassert the i_tx_pause signal, the IP core sends a PAUSE |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                              |                        | i_sl_tx_pause signal more than 205 ns to get the request captured by the MAC.                                                                                                                                                                                                                                                                                                                                              |
| continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                              |                        | control is enabled.                                                                                                                                                                                                                                                                                                                                                                                                        |



| Signal Name                                                       | Width                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                   |                         | Note: Standard Ethernet flow control is enabled if<br>the value of the RTL parameter<br>flow_control is one of sfc,<br>sfc_no_xoff, both, or both_no_xoff. If<br>you do not specify the value of the RTL<br>parameter in your IP core instance, but you<br>generate the IP core variation with the value<br>of the <b>Stop TX traffic when link partner</b><br><b>sends pause</b> set to <b>Yes</b> or <b>No</b> , pause flow<br>control is also enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <pre>i_sl_tx_pfc<br/>i_sl_tx_pfc[n-1:0<br/>i_tx_pfc</pre>         | 8 bits for each channel | <pre>When a bit is asserted, directs the IP core to send a<br/>PFC XOFF frame on the Ethernet link for the<br/>corresponding priority queue. The rising edge<br/>triggers the request. You must maintain this signal at<br/>the value of 1 until you wish the IP core to end the<br/>pause period. The IP core sends a PFC XOFF frame<br/>after it completes processing of the current in-flight<br/>TX packet, and periodically thereafter, until you<br/>deassert the i_tx_pfc bit. When you deassert the<br/>bit, the IP core sends a PFC XON frame on the<br/>Ethernet link for the corresponding priority queue.<br/><i>Note:</i> For 10G/25G channels, you should hold the<br/>i_sl_tx_pfc signal more than 205 ns to get<br/>the request captured by the MAC.<br/>This signal is functional only if priority flow control is<br/>enabled.<br/><i>Note:</i> Priority flow control is enabled if the value of<br/>the RTL parameter flow_control is one of<br/>pfc, pfc_no_xoff. If you do not specify the<br/>value of the RTL parameter in your IP core<br/>instance, but you generate the IP core<br/>variation with the value of the <b>Stop TX</b><br/><b>traffic when link partner sends pause</b> set<br/>to <b>Yes</b> or <b>No</b>, priority flow control is also<br/>enabled.</pre> |
| <pre>i_sl_tx_skip_crc i_sl_tx_skip_crc[n-1:0] i_tx_skip_crc</pre> | 1 bit for each channel  | Specifies how the TX MAC should process the current<br>TX MAC client interface packet. Use this signal to<br>temporarily turn off source insertion for a specific<br>packet and to override the default behaviors of<br>padding to minimum packet size and inserting CRC.<br>If this signal is asserted, directs the TX MAC to not<br>insert CRC, not add padding bytes, and not<br>implement source address insertion. You can use this<br>signal to indicate the data on the TX data signal<br>includes CRC, padding bytes (if relevant), and the<br>correct source address.<br>If this signal is not asserted, and source address<br>insertion is enabled, directs the TX MAC to overwrite<br>the source address. The MAC copies the new source<br>address from the TXMAC_SADDR register.<br>If this signal is not asserted, whether or not source<br>address insertion is enabled, the TX MAC inserts<br>padding bytes if needed and inserts CRC in the<br>packet.<br>The client must maintain the same value on this<br>signal for the duration of the packet (from the cycle<br>in which it asserts the SOP signal through the cycle<br>in which it asserts the EOP signal, inclusive).                                                                                                      |





#### Figure 34. Transmitting Data Using the TX Avalon Streaming MAC Client Interface

Note:

The transmit operations for the single lane ports (i\_sl\_\*) are equivalent to the multi-lane ports.



The figure above shows how to transmit data using the TX MAC client interface. The interface complies with the Avalon streaming interface specification.

- Data valid (i\_sl\_tx\_valid) must be held high from the start to end of a packet, and must be low outside of a packet.
- Packets always start on the leftmost of the byte of i\_tx\_data (SOP aligned).
- You can set the **Ready latency** through the parameter editor.
  - When o\_tx\_ready deasserts, i\_tx\_data must be paused for as many cycles as o\_tx\_ready is deasserted, starting **Ready latency** cycles later. In this example, **Ready latency** is 1. So the cycle after o\_tx\_ready deasserts for 1 cycle, i\_tx\_data is paused for 1 cycle.
- When the frame ends, i\_tx\_empty is set to the number of unused bytes in i\_tx\_data, starting from the right (byte 0).
  - In this example, i\_tx\_data on the last cycle of the packet has 3 empty bytes.
  - The minimum number of bytes on the last cycle is 1.

#### Figure 35. Fields and Frame Boundaries in an Ethernet Packet

When you turn off **Preamble Passthrough** in the parameter editor,  $i\_tx\_data$  must be written as shown below for the first cycle of data presented to the MAC.

*Note:* For 10G/25G channels, multiple cycles are required to write the header data.





#### Table 28. TX MAC Field Positions in i\_tx\_data with Preamble Passthrough Disabled

10G/25G requires multiple transfer cycle for header data. The (') symbol in the **10G/25G i\_sl\_tx\_data** column represents transfer on the subsequent cycle.

| 100G<br>i_tx_data | 10G/25G<br>i_sl_tx_data | MAC Field         | Note                                                                                                                                    |
|-------------------|-------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| [511:504]         | [63:56]                 | Dest Addr[47:40]  | The first octet of the<br>Destination Address, follows<br>Start Frame Delimiter (SFD).                                                  |
| [503:496]         | [55:48]                 | Dest Addr[39:32]  |                                                                                                                                         |
| [495:488]         | [47:40]                 | Dest Addr[31:24]  |                                                                                                                                         |
| [495:480]         | [39:32]                 | Dest Addr[23:16]  |                                                                                                                                         |
| [479:472]         | [31:24]                 | Dest Addr[15:8]   |                                                                                                                                         |
| [471:464]         | [23:16]                 | Dest Addr[7:0]    |                                                                                                                                         |
| [463:456]         | [15:8]                  | Src Addr[47:40]   | When you turn on <b>Source</b><br>Address Insertion,<br>contents are replaced by<br><b>txmac_saddr</b> unless<br>i_tx_skip_crc is high. |
| [455:448]         | [7:0]                   | Src Addr[39:32]   |                                                                                                                                         |
| [447:440]         | [63:56]'                | Src Addr[31:24]   |                                                                                                                                         |
| [439:432]         | [55:48]'                | Src Addr[23:16]   |                                                                                                                                         |
| [431:424]         | [47:40]'                | Src Addr[15:8]    |                                                                                                                                         |
| [423:416]         | [39:32]'                | Src Addr[7:0]     |                                                                                                                                         |
| [415:408]         | [31:24]'                | Length/Type[15:0] |                                                                                                                                         |
| [407:400]         | [23:16]'                | Length/Type[7:0]  |                                                                                                                                         |
| [399:0]           | [15:0]'                 |                   |                                                                                                                                         |

The <code>i\_tx\_error</code> or <code>i\_sl\_tx\_error</code> port allows packets to be marked as errored when they are complete.

#### Figure 36. Using i\_tx\_error



Because the core uses a cut-through interface, the core starts transmitting the packet data it is given as soon as possible. If the core discovers an error after the packet starts, e.g. in a bridging system where the receiver also uses a cut-through interface, you can use  $i_tx_error$  to invalidate the packet. You can also use  $i_tx_error$  for testing, to generate errored packets, and confirm that the other end of the link is able to reject the errored packets.

To invalidate an errored frame, end it with i\_tx\_endofpacket and assert i\_tx\_error. If the frame is good, deassert i\_tx\_error.





*Note:* Using i\_tx\_error will not provide a robust test of the remote CRC, because it uses MII Error Control bytes to indicate error, rather than relying on corrupted CRC bits.

#### **Related Information**

Avalon Interface Specifications

# 2.11.2. RX MAC Interface to User Logic

The E-Tile Hard IP for Ethernet Intel FPGA IP RX client interface in MAC+PCS variations employs the Avalon streaming interface protocol. The Avalon streaming interface protocol is a synchronous point-to-point, unidirectional interface that connects the producer of a data stream (source) to a consumer of data (sink). The key properties of this interface include:

- Start of packet (SOP) and end of packet (EOP) signals delimit frame transfers.
- The SOP must always be in the MSB, simplifying the interpretation and processing of data you receive on this interface.
- A valid signal qualifies signals from source to sink.

The RX MAC acts as a source and the client acts as a sink in the receive direction.

#### Table 29. Signals of the Avalon Streaming RX Client Interface

All interface signals are clocked by the RX clock. The signal names are standard Avalon streaming interface signals with slight differences to indicate the variations. For example:

- For variants with single 10GE/25GE channel: i\_sl\_rx\_data
- For variants with more than 1 channel: i\_sl\_rx\_data[n-1:0]
- For variants with single 100GE channel:i\_rx\_data

| Name                                                                             | Width                                                                     | Description                                                                                                                                                                                                                                                                                                  |  |  |
|----------------------------------------------------------------------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| i_sl_clk_rx<br>i_sl_clk_rx[n-1:0]<br>i_clk_rx                                    | 1 bit for each channel                                                    | The RX clock for the IP core that drives the channel.                                                                                                                                                                                                                                                        |  |  |
| o_sl_rx_data<br>o_sl_rx_data[n-1:0]<br>o_rx_data                                 | 64 bits for each channel<br>(10G/25G)<br>512 bits (100G)                  | RX data. The highest order bit is the MSB and bit 0 is<br>the LSB. Bytes are read in the usual left to right<br>order. The IP core reverses the byte order to meet<br>the requirements of the Ethernet standard.                                                                                             |  |  |
| o_sl_rx_valid<br>o_sl_rx_valid[n-1:0]<br>o_rx_valid                              | 1 bit for each channel                                                    | When asserted, indicates that RX data is valid. Only valid between the SOP and EOP signals.<br>This signal might be deasserted between the assertion of the SOP and EOP signals.                                                                                                                             |  |  |
| <pre>o_sl_rx_empty o_sl_rx_empty[n-1:0] o_rx_empty</pre>                         | 3 bits for each channel<br>(10G/25G)<br>6 bits for each channel<br>(100G) | Indicates the number of empty bytes on the RX data signal when EOP signal is asserted, starting from the least significant byte (LSB).                                                                                                                                                                       |  |  |
| <pre>o_sl_rx_startofpacket o_sl_rx_startofpacket[n-1:0] o_rx_startofpacket</pre> | 1 bit for each channel                                                    | When asserted, indicates that the RX data signal<br>holds the first clock cycle of data in a packet (start of<br>packet). The IP core asserts this signal for only a<br>single clock cycle for each packet.<br>When the SOP signal is asserted, the MSB of the RX<br>data signal drives the start of packet. |  |  |
| continued                                                                        |                                                                           |                                                                                                                                                                                                                                                                                                              |  |  |



| Name                                                                  | Width                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_sl_rx_endofpacket<br>o_sl_rx_endofpacket[n-1:0]<br>o_rx_endofpacket | 1 bit for each channel   | When asserted, indicates that the RX data signal<br>holds the final clock cycle of data in a packet (end of<br>packet). The IP core asserts this signal for only a<br>single clock cycle for each packet.<br>In the case of an undersized frame or in the case of<br>a frame that is exactly 64 bytes long, the SOP and<br>EOP signals might be asserted in the same clock<br>cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| o_sl_rx_error<br>o_sl_rx_error[n-1:0]<br>o_rx_error                   | 6 bits for each channel  | <ul> <li>Reports certain types of errors in the Ethernet frame whose contents are currently being transmitted on the client interface. This signal is valid in EOP cycles only.</li> <li>The individual bits report different types of errors: <ul> <li>Bit [0]: Malformed packet error. If this bit has the value of 1, the packet is malformed. The IP core identifies a malformed packet when it receives a control character that is not a terminate character.</li> <li>Bit [1]: CRC error. If this bit has the value of 1, the IP core detected a CRC error or an Error character in the frame.</li> <li>Bit [2]: undersized frame. If this bit has the value of 1, the frame size is between nine and 63 bytes, inclusive. In this case the IP core also sets o_rx_error[1] to signal a CRC error.</li> <li>The IP core does not recognize an incoming frame of size eight bytes or less as a frame, and those cases are not reported here. If the preamble-passthrough and CRC forwarding settings cause the RX MAC to strip out bytes such that only eight bytes or less remain in the frame, the IP core also does not recognize the frame, and those cases are not reported here.</li> </ul> </li> <li>Bit [3]: oversized frame. If this bit has the value of 1, the frame size is greater than the maximum frame size you specified as the value of the parameter or overwrote with the rx_max_frame_size RTL parameter.</li> <li>If the frame is malformed, the case is not reported here.</li> <li>Bit [4]: payload length error. If this bit has the value of 1, the payload received in the frame is shorter than the length field value, and the value in the length field value, and the value of 1, the frame is oversized or undersized, the case is not reported here.</li> </ul> |
| o_sl_rxstatus_valid<br>o_sl_rxstatus_valid[n-1:0]<br>o_rxstatus_valid | 1 bit for each channel   | When asserted, indicates that o_rxstatus_data is driving valid data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| o_sl_rxstatus_data<br>o_sl_rxstatus_data[n-1:0]<br>o_rxstatus_data    | 40 bits for each channel | <ul> <li>Specifies information about the received frame. The following fields are defined:</li> <li>[Bit 39]: When asserted, indicates a PFC frame</li> <li>[Bits 38:36]: Reserved</li> <li>Bit[35]: When asserted, indicates a PAUSE frame</li> <li>Bit[34]: When asserted, indicates a Control (Type is 0x8808) frame</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |





| Name                                                | Width                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                     |                         | <ul> <li>Bit[33]: When asserted, indicates a VLAN frame</li> <li>Bit[32]: When asserted, indicates a stacked VLAN frame</li> <li>Bits[31:0]: Reserved</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| o_sl_rx_pause<br>o_sl_rx_pause[n-1:0]<br>o_rx_pause | 1 bit for each channel  | When asserted, indicates the IP core received a<br>PAUSE XOFF frame on the Ethernet link. The IP core<br>deasserts this signal when the quanta count from the<br>PAUSE XOFF request expires.<br>If you set the parameter editor <b>Stop TX traffic</b><br><b>when link partner sends pause</b> parameter to the<br>value of <b>Yes</b> , or overwrite it with the sfc or both<br>value for the flow_control RTL parameter, the TX<br>MAC stops traffic in response to the PAUSE XOFF<br>frame. In this case, the quanta count decrements<br>while the IP core stops traffic.<br>If the settings direct the TX MAC to not stop traffic in<br>response to the PAUSE XOFF frame, the quanta<br>counter decrements on every valid cycle on the TX<br>MAC client interface. Each quanta represents 512<br>bits. Therefore, the counter decrements by one half |
| <pre>o_sl_rx_pfc o_sl_rx_pfc[n-1:0] o_rx_pfc</pre>  | 8 bits for each channel | in every valid clock cycle in 100G variations.<br>When a bit is asserted, indicates the IP core received<br>a PFC XOFF frame on the Ethernet link for the<br>corresponding priority queue. The IP core deasserts<br>each bit when the XOFF frame's quanta count<br>expires. The PFC quanta counters decrement on<br>every valid cycle on the TX MAC client interface. Each<br>quanta represents 512 bits. Therefore, the counter<br>decrements by one half in every valid clock cycle in<br>100G variations. In summary, the width of the pulse<br>indicates the length of the requested pause in traffic<br>for the queue.                                                                                                                                                                                                                              |

### Figure 37. Receiving Data Using the RX MAC Client Interface



The figure above shows how to receive data using the RX MAC client interface. The interface complies with the Avalon streaming interface specification.

- Packets always start on the leftmost of the byte of o\_rx\_data (SOP aligned).
- When the frame ends, o\_rx\_empty is set to the number of unused bytes in o\_rx\_data, starting from the right (byte 0).
  - In this example, o\_rx\_data on the last cycle of the packet has 5 empty bytes.
  - The minimum number of bytes on the last cycle is 1.
- The framing and data ports are only valid when o\_rx\_data is high.

*Note:* The interface does not take direct backpressure





| 100G<br>i_tx_data | 10G/25G<br>i_sl_tx_data | MAC Field         | Note                                                                                   |
|-------------------|-------------------------|-------------------|----------------------------------------------------------------------------------------|
| [511:504]         | [63:56]′                | Dest Addr[47:40]  | The first octet of the<br>Destination Address, follows<br>Start Frame Delimiter (SFD). |
| [503:496]         | [55:48]′                | Dest Addr[39:32]  |                                                                                        |
| [495:488]         | [47:40]′                | Dest Addr[31:24]  |                                                                                        |
| [495:480]         | [39:32]′                | Dest Addr[23:16]  |                                                                                        |
| [479:472]         | [31:24]′                | Dest Addr[15:8]   |                                                                                        |
| [471:464]         | [23:16]′                | Dest Addr[7:0]    |                                                                                        |
| [463:456]         | [15:8]′                 | Src Addr[47:40]   |                                                                                        |
| [455:448]         | [7:0]′                  | Src Addr[39:32]   |                                                                                        |
| [447:440]         | [63:56]                 | Src Addr[31:24]   |                                                                                        |
| [439:432]         | [55:48]                 | Src Addr[23:16]   |                                                                                        |
| [431:424]         | [47:40]                 | Src Addr[15:8]    |                                                                                        |
| [423:416]         | [39:32]                 | Src Addr[7:0]     |                                                                                        |
| [415:408]         | [31:24]                 | Length/Type[15:0] |                                                                                        |
| [407:400]         | [23:16]                 | Length/Type[7:0]  |                                                                                        |
| [399:0]           | [15:0]                  |                   |                                                                                        |

### Table 30. RX MAC Field Positions in o\_rx\_data with Preamble Passthrough Disabled

### Figure 38. RX MAC Status and Errors





The status valid port is provided for backward compatibility, but always asserts when  $o_rx_endofpacket$  is asserted and valid.

#### **Related Information**

Avalon Interface Specifications

# 2.11.3. TX PCS Interface to User Logic

The E-Tile Hard IP for Ethernet Intel FPGA IP TX client interface in PCS Only variations employs the Media Independent Interface (MII) protocol.

The client acts as a source and the TX PCS acts as a sink in the transmit direction.







#### Table 31. Signals of the MII TX Client Interface

All interface signals are clocked by the TX clock. The signal names are standard Avalon streaming interface signals with slight differences to indicate the variations. For example:

- For variants with single 10GE/25GE channel: i\_sl\_tx\_data
- For variants with more than 1 channel: i\_sl\_tx\_data[n-1:0]
- For variants with single 100GE channel: i\_tx\_data

| <pre>i_sl_clk_tx[n-1:0] i_clk_tx i_sl_tx_mii_d[n-1:0] i_tx_mii_d[n-1:0] i_tx_mii_d[n-1:0] i_tx_mii_d[n-1:0] i_tx_mii_d[n-1:0] i_tx_mii_c d bits for each channel i_sl_tx_mii_c[n-1:0] i_tx_mii_c[n-1:0] i_tx_mii_x[n] i_nt_x[n] i_nt_x</pre> | Signal Name              | Width                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i=l_tx_mii_d(1-1:0)i_tx_mii_d(7:0) holds the first byte the IP core<br>transmits on the Ethernet link. itx_mii_d(0)<br>holds the first bit the IP core transmits on the<br>Ethernet link. Itx_mii_d(0)<br>holds the first bit the IP core transmits on the<br>Ethernet link. Itx_mii_d(0)<br>holds the first bit the IP core transmits on the<br>Ethernet link. While the TX MII valid signal has the value of 0 or<br>the alignment marker insertion bit signal has the<br>value of 1, and for one additional clock cycle, you<br>must hold the value of this signal table. We refer to<br>this behavior as freezing the signal value.i_sl_tx_mii_c8 bits for each channel<br>(10G/25G)<br>32 bits (100G)TX MII control bits. Each bit corresponds to a jtx_mii_d(17:0), i_tx_mii_d(1] corresponds to<br>i_tx_mii_d(17:0), i_tx_mii_d(1] corresponds to<br>i_tx_mii_d(1), itx_mii_d(1) corresponds to<br>i_tx_mii_d(1), itx_mii_d(1) corresponds to<br>i_tx_mii_d(1) bytes, but the order promodes to<br>i_tx_mii_d(1) bytes (0xD), and error byte (0xFE), and<br>corresponding data byte is data.<br>The Start of Packet byte (0xFE), and error byte (0xFE) and<br>corresponding data bytes.<br>While the TX MII data signal is valid.<br>You must assert the signal a fixed number of clock<br>cycles after the P core raises ready signal, and mus<br>deassert the signal a fixed number of clock cycles.<br>While we use of obstin SMII data signal as valid.<br>You must assert the signal a fixed number of clock cycles.<br>While you hold the value of this signal a fixed number of clock cycles.<br>While you hold the value of this signal a fixed number of clock cycles.<br>The value of a bit signal a fixed number of clock cycles.<br>While the TX MII data and TX MII<br>control bits signal a fixed number of clock cycles.<br>While you hold the value of this signal a fixed number of clock cycles.<br>While you hold the value of this signal a<br>the value of o this signal a fixed number of clock c                                                                                                       | i_sl_clk_tx[n-1:0]       | 1 bit for each channel | The TX clock for the IP core that drives the channel.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <ul> <li>isl_tx_mii_c[n-1:0]</li> <li>i_tx_mii_c</li> <li>(10G/25G)</li> <li>2bits (100G)</li> <li>2bits (100G)</li> <li>bits (100G)</li> <li>i_tx_mii_c[1] corresponds to i_tx_mii_c[1] corres</li></ul>                         | i_sl_tx_mii_d[n-1:0]     | (10G/25G)              | <pre>i_tx_mii_d[7:0] holds the first byte the IP core<br/>transmits on the Ethernet link. i_tx_mii_d[0]<br/>holds the first bit the IP core transmits on the<br/>Ethernet link.<br/>While the TX MII valid signal has the value of 0 or<br/>the alignment marker insertion bit signal has the<br/>value of 1, and for one additional clock cycle, you<br/>must hold the value of this signal stable. We refer to</pre>                                                                                                                                                                                                                              |
| i_sl_tx_mii_valid[n-1:0]i_sl_tx_mii_validi_tx_mii_validvou must assert this signal a fixed number of clock cycles<br>after the IP core raises ready signal, and must<br>deassert this signal the same number of clock cycles<br>after the IP core deasserts the ready signal. The<br>number must be in the range of 1-10 clock cycles.<br>While you hold the value of this signal at 0, you must<br>freeze the values of both TX MII data and TX MII<br>control bits signals stable.o_sl_tx_mii_ready<br>o_sl_tx_mii_ready1 bit for each channeli_sl_tx_mii_ama<br>i_sl_tx_mii_am1 bit for each channeli_st_tx_mii_am1 bit for each channeli_st_tx_mii_am1 bit for each channeli_st_tx_mii_am1 bit for each channeli_notGo variations, you must hold this signal<br>asserted for 5 consecutive clock cycles.i_notGo variations, you must hold this signal<br>asserted for 4 consecutive clock cycles.i_notGo variations, you must RS-FEC variations,<br>this signal asserted for 4 consecutive clock cycles.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | i_sl_tx_mii_c[n-1:0]     | (10G/25G)              | <pre>i_tx_mii_c[0] corresponds to<br/>i_tx_mii_d[7:0], i_tx_mii_c[1] corresponds<br/>to i_tx_mii_d[15:8], and so on.<br/>If the value of a bit is 1, the corresponding data byte<br/>is a control byte. If the value of a bit is 0, the<br/>corresponding data byte is data.<br/>The Start of Packet byte (0xFB), End of Packet byte<br/>(0xFD), Idle bytes (0xO7), and error byte (0xFE) are<br/>control bytes, but the preamble bytes, Start of<br/>Frame (SFD) byte (0xD5), CRC bytes, and payload<br/>bytes are data bytes.<br/>While the TX MII valid signal has the value of 0 or<br/>the alignment marker insertion bit signal has the</pre> |
| <pre>o_sl_tx_mii_ready[n-1:0] o_tx_mii_ready i_sl_tx_mii_am i_sl_tx_mii_am i_tx_mii_am</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | i_sl_tx_mii_valid[n-1:0] | 1 bit for each channel | You must assert this signal a fixed number of clock<br>cycles after the IP core raises ready signal, and must<br>deassert this signal the same number of clock cycles<br>after the IP core deasserts the ready signal. The<br>number must be in the range of 1–10 clock cycles.<br>While you hold the value of this signal at 0, you must<br>freeze the values of both TX MII data and TX MII                                                                                                                                                                                                                                                       |
| <ul> <li>i_sl_tx_mii_am[n-1:0]</li> <li>In 100G variations, you must hold this signal asserted for 5 consecutive clock cycles.</li> <li>In 25Gx1 with RS-FEC variations, you must hold this signal asserted for 4 consecutive clock cycles.</li> <li>In 10Gx1 or 25Gx1 without RS-FEC variations,</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | o_sl_tx_mii_ready[n-1:0] | 1 bit for each channel | Indicates the PCS is ready to receive new data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | i_sl_tx_mii_am[n-1:0]    | 1 bit for each channel | <ul> <li>In 100G variations, you must hold this signal asserted for 5 consecutive clock cycles.</li> <li>In 25Gx1 with RS-FEC variations, you must hold this signal asserted for 4 consecutive clock cycles.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                             |



| Signal Name | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |       | The number of valid clock cycles from deassertion of<br>the alignment marker insertion bit signal to<br>reassertion of the alignment marker insertion bit<br>signal is the am_period.<br>For an example that handles this setting for<br>simulation and drives the i_tx_mii_am signal<br>appropriately for simulation, refer to the IP core<br>design example for PCS Only variations. For<br>information about how to generate the IP core design<br>example, refer to the <i>Design Example User Guide</i> .<br>For information about the sim_mode RTL parameter,<br>refer to the <i>RTL Parameters</i> section of this user<br>guide.<br>While you hold the value of this signal at 1, you must |
|             |       | freeze the values of both TX MII data and TX MII control bits signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

#### Figure 39. **Transmitting Data Using the PCS Mode TX Interface**



The figure above shows how to write packets directly to the PCS mode TX interface.

- The packets are written using MII.
  - Each byte in i\_tx\_mii\_d has a corresponding bit in i\_tx\_mii\_c that indicates whether the byte is a control byte or a data byte; for example, i tx mii c[1] is the control bit for i tx mii d[15:8].
- i tx mii valid should conform to these conditions:
  - Assert the valid signal only when the ready signal is asserted, and deassert only when the ready signal is deasserted.
  - The two signals can be spaced by a fixed latency between 1 and 10 cycles.
  - When the valid signal deasserts, i\_tx\_mii\_d and i\_tx\_mii\_c must be paused.
- The byte order for the PCS mode TX interface is opposite of the byte order for the . MAC client. Bytes flow from right to left; the first byte to be transmitted from the interface is i\_tx\_mii\_d[7:0].
- The bit order for the PCS mode TX interface is the same as the bit order of the MAC client. The first bit to be transmitted from the interface is i\_tx\_mii\_d[0].
- The PCS mode TX interface is not SOP aligned. Any legal ordering of packets in MII Note: format is accepted.





| MII Data          |      | MII Control   |   | Ethernet Packet Byte |
|-------------------|------|---------------|---|----------------------|
| i_tx_mii_d[7:0]   | 0xFB | i_tx_mii_c[0] | 1 | Start of Packet      |
| i_tx_mii_d[15:8]  | 0x55 | i_tx_mii_c[1] | 0 | Preamble             |
| i_tx_mii_d[23:16] | 0x55 | i_tx_mii_c[2] | 0 | Preamble             |
| i_tx_mii_d[31:24] | 0x55 | i_tx_mii_c[3] | 0 | Preamble             |
| i_tx_mii_d[39:32] | 0x55 | i_tx_mii_c[4] | 0 | Preamble             |
| i_tx_mii_d[47:40] | 0x55 | i_tx_mii_c[5] | 0 | Preamble             |
| i_tx_mii_d[55:48] | 0x55 | i_tx_mii_c[6] | 0 | Preamble             |
| i_tx_mii_d[63:56] | 0xD5 | i_tx_mii_c[7] | 0 | SFD                  |

### Table 32. Writing a Start Packet Block with Preamble to the PCS Mode TX Interface

### Figure 40. Inserting Alignment Markers



The timing of alignment marker insertion is very rigid. Alignment markers cannot be delayed without disrupting the Ethernet link. Use valid cycles to count the alignment markers. When i\_tx\_mii\_valid is low, the alignment marker counters and input must freeze.

The number of cycles for <code>i\_tx\_mii\_am</code> to remain high depends on the rate of the interface:

- 100G: 5 cycles
- 25Gx1 with RS-FEC: 4 cycles
- 10Gx1 or 25x1 without PTP or RS-FEC: 0 cycle (tie low)

The number of cycles for am period depends on the rate of the interface and whether in simulation or hardware:

- In simulation, it is common to use a reduced am period for both sides of the link to increase lock-time speed.
  - 100G link: 315
  - 25Gx1 link with RS-FEC: 5119
- In hardware.
  - 100G link: 81915
  - 25Gx1 link with RS-FEC: 81916

# 2.11.4. RX PCS Interface to User Logic

The E-Tile Hard IP for Ethernet Intel FPGA IP RX client interface in PCS Only variations employs the Media Independent Interface (MII) protocol.





The RX PCS acts as a source and the client acts as a sink in the receive direction.

#### Table 33. Signals of the MII RX Client Interface

All interface signals are clocked by the RX clock. The signal names are standard Avalon streaming interface signals with slight differences to indicate the variations. For example:

- For variants with single 10GE/25GE channel: i\_sl\_rx\_data •
- For variants with more than 1 channels: i\_sl\_rx\_data[n-1:0] .
- For variants with single 100E channel:i\_rx\_data ٠

| Signal Name                                                                                               | Width                                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_clk_rx<br>i_sl_clk_rx[n-1:0]<br>i_clk_rx                                                             | 1 bit for each channel                                   | The RX clock for the IP core that drives the channel.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| o_sl_rx_mii_d<br>o_sl_rx_mii_d[n-1:0]<br>o_rx_mii_d                                                       | 64 bits for each channel<br>(10G/25G)<br>256 bits (100G) | RX MII data. Data is in MII encoding.<br>o_rx_mii_d[7:0] holds the first byte the IP core<br>received on the Ethernet link. o_rx_mii_d[0] holds<br>the first bit the IP core received on the Ethernet link.<br>When RX MII valid signal has the value of 0 or the<br>RX valid alignment marker signal has the value of 1,<br>the value on this signal is invalid.                                                                                                                                                                                                                                                                                                                                                                             |
| o_sl_rx_mii_c<br>o_sl_rx_mii_c[n-1:0]<br>o_rx_mii_c                                                       | 8 bits for each channel<br>(10G/25G)<br>32 bits (100G    | RX MII control bits. Each bit corresponds to a byte of<br>RX MII data. o_rx_mii_c[0] corresponds to<br>o_rx_mii_d[7:0], o_rx_mii_c[1] corresponds<br>to o_rx_mii_d[15:8], and so on.<br>If the value of a bit is 1, the corresponding data byte<br>is a control byte. If the value of a bit is 0, the<br>corresponding data byte is data.<br>The Start of Packet byte (0xFB), End of Packet byte<br>(0xFD), Idle bytes (0x07), and error byte (0xFE) are<br>control bytes, but the preamble bytes, Start of<br>Frame (SFD) byte (0xD5), CRC bytes, and payload<br>bytes are data bytes.<br>When RX MII valid signal has the value of 0 or the<br>RX valid alignment marker signal has the value of 1,<br>the value on this signal is invalid. |
| o_sl_rx_mii_valid<br>o_sl_rx_mii_valid[n-1:0]<br>o_rx_mii_valid                                           | 1 bit for each channel                                   | Indicates that the RX MII data, RX MII control bits,<br>and the RX valid alignment marker signals are valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| o_sl_rx_mii_am_valid<br>o_sl_rx_mii_am_valid[n-1:0]<br>o_rx_mii_am_valid                                  | 1 bit for each channel                                   | Indicates the IP core received a valid alignment<br>marker on the Ethernet link.<br>When the RX MII valid signal has the value of 0, the<br>value on this signal is invalid. The value of the RX<br>MII valid signal may fall while the IP core is asserting<br>this signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <pre>o_sl_rx_pcs_fully_aligned<br/>o_sl_rx_pcs_fully_aligned[n-1<br/>:0]<br/>o_rx_pcs_fully_aligned</pre> | 1 bit for each channel                                   | Asserts when RX PCS is ready to receive data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |





# i\_clk\_rx o\_rx\_mii\_d o\_rx\_mii\_c o\_rx\_mii\_valid

Figure 41. Receiving Data Using the PCS Mode RX Interface

The figure above shows how to read packets from the RX PCS using the PCS mode RX interface.

- The packets are MII encoded.
  - Each byte in o\_rx\_mii\_d has a corresponding bit in o\_rx\_mii\_c that indicates whether the byte is a control byte or a data byte; for example, o\_rx\_mii\_c[2] is the control bit for o\_rx\_mii\_d[23:16].
- The data is only valid when o\_rx\_mii\_valid is high. The contents of the o\_rx\_mii\_d and o\_rx\_mii\_c buses are not defined when o\_rx\_mii\_valid is low.
- The byte order for the PCS mode RX interface is opposite of the byte order for the MAC client. Bytes flow from right to left; the first byte that the core receives is o\_rx\_mii\_d[7:0].
- The bit order for the PCS mode RX interface is the same as the bit order of the MAC client. The first bit that the core receives is o\_rx\_mii\_d[0].
- *Note:* The PCS mode RX interface is not SOP aligned. New packets can begin on any byte position that is divisible by 8 (PCS data is transferred in 8-byte blocks).

| Table 34. | Reading a Start Packet Block | with Preamble from | a PCS Mode TX Interface |
|-----------|------------------------------|--------------------|-------------------------|
|-----------|------------------------------|--------------------|-------------------------|

| MII Data          |      | MII Control   |   | Ethernet Packet Byte |
|-------------------|------|---------------|---|----------------------|
| o_rx_mii_d[7:0]   | 0xFB | o_rx_mii_c[0] | 1 | Start of Packet      |
| o_rx_mii_d[15:8]  | 0x55 | o_rx_mii_c[1] | 0 | Preamble             |
| o_rx_mii_d[23:16] | 0x55 | o_rx_mii_c[2] | 0 | Preamble             |
| o_rx_mii_d[31:24] | 0x55 | o_rx_mii_c[3] | 0 | Preamble             |
| o_rx_mii_d[39:32] | 0x55 | o_rx_mii_c[4] | 0 | Preamble             |
| o_rx_mii_d[47:40] | 0x55 | o_rx_mii_c[5] | 0 | Preamble             |
| o_rx_mii_d[55:48] | 0x55 | o_rx_mii_c[6] | 0 | Preamble             |
| o_rx_mii_d[63:56] | 0xD5 | o_rx_mii_c[7] | 0 | SFD                  |



#### Figure 42. **Receiving Alignment Markers**



o\_rx\_mii\_am\_valid indicates the arrival of the alignment markers from the RX PCS. The alignment markers also depend on o\_rx\_mii\_valid. When o\_rx\_mii\_valid is low, o rx mii am valid is not valid.

The contents of the o\_rx\_mii\_d and o\_rx\_mii\_c buses are not defined when o rx mii valid is low. This is because alignment markers are not part of the 64b/66b encoding, and do not have an MII equivalent.

# 2.11.5. FlexE and OTN Mode TX Interface

The E-Tile Hard IP for Ethernet Intel FPGA IP TX client interface in FlexE and OTN variations employs the PCS66 interface protocol.

The FlexE and OTN variations allow the application to write 66b blocks to the TX PCS, bypassing the TX MAC.

- In FlexE mode, the TX encoder in the PCS is also bypassed.
- In OTN mode, both the TX encoder and the scrambler are bypassed.

The client acts as a source and the TX PCS acts as a sink in the transmit direction.

The E-Tile Hard IP for Ethernet Intel FPGA IP provides preliminary support for the OTN Note: feature. For further inquiries, contact your nearest Intel sales representative or file an Intel Premier Support (IPS) case at https://www.intel.com/content/www/us/en/myintel/fpga-sign-in.html.

#### Table 35. Signals of the PCS66 TX Interface

All interface signals are clocked by the TX clock. The signal names are standard Avalon streaming interface signals with slight differences to indicate the variations. For example:

- For variants with single 10GE/25GE channel: i\_sl\_tx\_pcs66\_d
- For variants with more than 1 channel: i\_sl\_tx\_pcs66\_d[ch-1:0]
- For variants with single 100GE channel: i\_tx\_pcs66\_d

| Signal Name                                                     | Width                                           | Description                                                                                                                                                              |
|-----------------------------------------------------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>i_sl_tx_pcs66_d i_sl_tx_pcs66_d[ch-1:0] i_tx_pcs66_d</pre> | 66 bits<br>for each<br>channel<br>(10G/<br>25G) | <ul><li>TX PCS 66b data for 1 block.</li><li>In FlexE mode, the data presented is scrambled.</li><li>In OTN mode, the data goes directly to the RS-FEC or PMA.</li></ul> |
|                                                                 |                                                 | continued                                                                                                                                                                |



2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



| Signal Name                                                                              | Width                        | Description                                                                                                                                                                                                                                                                                                    |
|------------------------------------------------------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                          | 264 bits<br>(100G)           |                                                                                                                                                                                                                                                                                                                |
| <pre>i_sl_tx_pcs66_valid<br/>i_sl_tx_pcs66_valid[ch-1:0<br/>]<br/>i_tx_pcs66_valid</pre> | 1 bit for<br>each<br>channel | When asserted, indicates that the TX PCS 66b data is valid.<br>Must be asserted when the TX PCS 66b ready signal is asserted.                                                                                                                                                                                  |
| <pre>o_sl_tx_pcs66_ready<br/>o_sl_tx_pcs66_ready[ch-1:0]<br/>o_tx_pcs66_ready</pre>      | 1 bit for<br>each<br>channel | TX PCS 66b ready signal.<br>When asserted, indicates the PCS is ready to receive new data.                                                                                                                                                                                                                     |
| <pre>i_sl_tx_pcs66_am i_sl_tx_pcs66_am[ch-1:0] i_tx_pcs66_am</pre>                       | 1 bit for<br>each<br>channel | Alignment marker insertion bit.<br>In FlexE and OTN modes, asserting this signal causes the PCS to allow<br>gaps for the alignment markers in place of the data presented on the TX<br>PCS data signal. The application marks the block as an alignment<br>marker and the scrambler does not process the data. |

#### Figure 43. Transmitting Data Using the PCS66 TX Interface

The figure shows how to write the 66b blocks directly to the TX PCS in FlexE and OTN mode using the PCS66 TX Interface.



TX data is written as 66b blocks. The blocks are expected to be 66b encoded, with the sync header bits in the rightmost bit positions (bits 1 and 0).

- In FlexE mode, the PCS scrambles and stripes the blocks for transmission.
- In OTN mode, the PCS only stripes the blocks for transmission. The input data is expected to be already scrambled.

i\_tx\_pcs66\_valid should conform to these conditions:

- Assert the valid signal only when the ready signal is asserted, and deassert only when the ready signal is deasserted.
- The two signals can be spaced by a fixed latency between 1 and 10 cycles.
- When the valid signal deasserts, i\_tx\_pcs66\_d must be paused.

The block order for the PCS66 mode TX interface is the same as the TX PCS interface. Blocks are transmitted from right to left; the first block to be transmitted from the interface is  $i_tx_pcs66_d[65:0]$ .

The bit order for the PCS66 mode TX interface is the same as the TX PCS interface. Bits are transmitted from right to left; the first bit to be transmitted from the interface is  $i_tx_pcs66_d[0]$ .



#### **Inserting Alignment Markers** Figure 44.



When PCS66 TX interface is used for FlexE mode, the timing of alignment marker insertion can be controlled from the fabric. The same operations can be performed on \* sl\* versions of the ports, with slight variance:

- For 100G channels, the signal causes the alignment markers to be inserted.
- For 10G/25G channels, the signal causes the cycle to be treated as invalid for PCS processing (no changes to scramble).

In FlexE mode, the timing of alignment marker insertion is very rigid. Alignment markers cannot be delayed without disrupting the Ethernet link. Use valid cycles to count the alignment markers. When i tx pcs66 valid is low, the alignment marker counters and input must freeze.

- The number of cycles for i\_tx\_pcs66\_am to remain high for a 100G link is 5 cycles.
- The number of cycles for am period for a 100G link is typically 315 in simulation and 81915 in hardware.

OTN streams are expected to include their own alignment markers. In OTN mode with FEC, you must assert i\_tx\_pcs66\_am to indicate the position of the alignment markers. In OTN mode without FEC, i tx pcs66 am is optional and you can tie the signal low.

#### Alignment Markers Insertion for PCS Direct, FlexE, and OTN Modes Table 36.

| Mode       | AM Insertion Bit | AM Date<br>Insertion | TX Data on AM<br>Cycles | Scrambler | 64b/66b<br>Encoding/<br>Decoding |
|------------|------------------|----------------------|-------------------------|-----------|----------------------------------|
| PCS Direct | User-driven      | Done by PCS          | Ignored                 | Enabled   | Enabled                          |
| FlexE      | User-driven      | Done by PCS          | Ignored                 | Enabled   | Disabled                         |
| OTN        | User-driven      | Done by user         | AM data                 | Bypassed  | Disabled                         |

# 2.11.6. FlexE and OTN Mode RX Interface

The E-Tile Hard IP for Ethernet Intel FPGA IP RX client interface in FlexE and OTN variations employs the PCS66 interface protocol.

The FlexE and OTN variations allow the application to read 66b blocks from the RX PCS, bypassing the RX MAC.

The RX PCS acts as a source and the client acts as a sink in the receive direction.

The E-Tile Hard IP for Ethernet Intel FPGA IP provides preliminary support for the OTN Note: feature. For further inquiries, contact your nearest Intel sales representative or file an Intel Premier Support (IPS) case at https://www.intel.com/content/www/us/en/myintel/fpga-sign-in.html.





#### Table 37. Signals of the PCS66 RX Interface

All interface signals are clocked by the RX clock. The signal names are standard Avalon-ST signals with slight differences to indicate the variations. For example:

- For variants with single 10GE/25GE channel: o\_sl\_rx\_pcs66\_d
- For variants with more than 1 channel: o\_sl\_rx\_pcs66\_d[ch-1:0]
- For variants with single 100GE channel: o\_rx\_pcs66\_d

| Name                                                                                          | Width                          | Description                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_sl_rx_pcs66_d<br>o_sl_rx_pcs66_d[ch-1:0]<br>o_rx_pcs66_d                                    | 66 (10G/<br>25G)<br>264 (100G) | <ul><li>RX PCS 66b data for 1 block.</li><li>In FlexE mode, the RX PCS 66b data is aligned and descrambled but not decoded.</li><li>In OTN mode, the RX PCS 66b data is only aligned.</li></ul> |
| <pre>o_sl_rx_pcs66_valid o_sl_rx_pcs66_valid[ch-1:0] o_rx_pcs66_valid</pre>                   | 1                              | When asserted, indicates that the RX PCS 66b data is valid.                                                                                                                                     |
| o_sl_rx_pcs66_am_valid<br>o_sl_rx_pcs66_am_valid[ch-1:0<br>]<br>o_rx_pcs66_am_valid           | 1                              | Alignment marker indicator.<br>When asserted, Indicates the blocks on the RX PCS 66b data signal<br>are identified as RS-FEC codeword markers.                                                  |
| <pre>o_sl_rx_pcs_fully_aligned[n-1 :0] o_rx_pcs_fully_aligned o_sl_rx_pcs_fully_aligned</pre> | 1 bit for<br>each<br>channel   | Asserts when RX PCS is ready to receive data.                                                                                                                                                   |

#### Figure 45. Receiving Data Using the PCS66 RX Interface

The figure shows how to read the 66b blocks directly from the RX PCS using the PCS mode RX Interface.



The 66b blocks follow Ethernet 64b/66b convention. The rightmost 2 bits of each 66 block is a 2b sync header and the remaining 64b are data.

- In FlexE mode, the data is aligned and descrambled..
- In OTN mode, the data is only aligned.

The data is only valid when o\_rx\_pcs66\_valid is high. The contents of the o\_rx\_pcs66\_d bus are not defined when o\_rx\_pcs66\_valid is low.

The block order for the PCS66 mode RX interface is the same as the RX PCS interface. Blocks flow from right to left; the first block that the core receives is  $o_rx_pcs66_d[65:0]$ .

The bit order for the PCS66 mode RX interface is the same as the RX PCS interface. Bits flow from right to left; the first bit that the core receives is  $o_{rx_pcs66_d[0]}$ .



o\_rx\_pcs66\_am\_valid indicates the arrival of the alignment markers from the RX PCS. The alignment markers also depend on o\_rx\_pcs66\_valid. When o\_rx\_pcs66\_valid is low, o\_rx\_pcs66\_am\_valid is not valid.

- In FlexE mode, when o\_rx\_pcs66\_am\_valid is high, o\_rx\_pcs66\_d is undefined because the alignment markers do not get descrambled.
- . In OTN mode, when o rx pcs66 am valid is high, o rx pcs66 d presents the received alignment markers.

#### Figure 46. **Receiving Alignment Markers for FlexE Mode**



#### Figure 47. **Receiving Alignment Markers for OTN Mode**



# 2.11.7. TX Custom PCS Interface to User Logic

The E-Tile Hard IP for Ethernet Intel FPGA IP TX client interface in custom PCS variation employs the Media Independent Interface (MII) protocol.

The client acts as a source and the TX PCS acts as a sink in the transmit direction.

#### Table 38. Signals of the MII TX Client Interface

All interface signals are clocked by the TX clock. The signal names are standard Avalon streaming interface signals with slight differences to indicate the variations. The letter n in the signal name is referring to the number of channel. For example, the name of the MII TX data for channel 1 is i\_sl\_tx\_mii\_d[(n\*width)-1:0].

| Signal Name                  | Width                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|------------------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| i_sl_clk_tx[n-1:0]           | 1 bit for each channel   | The TX clock for the IP core that drives the channel.                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| i_sl_tx_mii_d[(n*width)-1:0] | 64 bits for each channel | TX MII data. Data must be in MII encoding.<br>i_tx_mii_d[7:0] holds the first byte the IP core<br>transmits on the Ethernet link. i_tx_mii_d[0]<br>holds the first bit the IP core transmits on the<br>Ethernet link.<br>While the TX MII valid signal has the value of 0 or<br>the alignment marker insertion bit signal has the<br>value of 1, and for one additional clock cycle, you<br>must hold the value of this signal stable. We refer to<br>this behavior as freezing the signal value. |  |  |
| continued                    |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |





| Signal Name                             | Width                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_tx_mii_c[(n*width):0]              | 8 bits for each channel | <pre>TX MII control bits. Each bit corresponds to a byte of<br/>the TX MII data signal. For example,<br/>i_tx_mii_c[0] corresponds to<br/>i_tx_mii_d[7:0], i_tx_mii_c[1] corresponds<br/>to i_tx_mii_d[15:8], and so on.<br/>If the value of a bit is 1, the corresponding data byte<br/>is a control byte. If the value of a bit is 0, the<br/>corresponding data byte is data.<br/>The Start of Packet byte (0xFB), End of Packet byte<br/>(0xFD), Idle bytes (0x07), and error byte (0xFE) are<br/>control bytes, but the preamble bytes, Start of<br/>Frame (SFD) byte (0xD5), CRC bytes, and payload<br/>bytes are data bytes.<br/>While the TX MII valid signal has the value of 0 or<br/>the alignment marker insertion bit signal.</pre>                                                                                                                                                                                                                       |
| i_sl_tx_mii_valid[n-1:0]                | 1 bit for each channel  | Indicates that the TX MII data signal is valid.<br>You must assert this signal a fixed number of clock<br>cycles after the IP core raises ready signal, and must<br>deassert this signal the same number of clock cycles<br>after the IP core deasserts the ready signal. The<br>number must be in the range of 1–10 clock cycles.<br>While you hold the value of this signal at 0, you must<br>freeze the values of both TX MII data and TX MII<br>control bits signals stable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| o_sl_tx_mii_ready[n-1:0]                | 1 bit for each channel  | Indicates the PCS is ready to receive new data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| i_sl_tx_mii_am<br>i_sl_tx_mii_am[n-1:0] | 1 bit for each channel  | <ul> <li>Alignment marker insertion bit.</li> <li>In 25Gx1 with RS-FEC variations, you must hold this signal asserted for 4 consecutive clock cycles.</li> <li>In 10Gx1 or 25Gx1 without RS-FEC variations, you must tie this signal low.</li> <li>The number of valid clock cycles from deassertion of the alignment marker insertion bit signal to reassertion of the alignment marker insertion bit signal is the am_period.</li> <li>For an example that handles this setting for simulation and drives the i_tx_mii_am signal appropriately for simulation, refer to the IP core design example for PCS Only variations. For information about how to generate the IP core design example User Guide. For information about the sim_mode RTL parameter, refer to the RTL Parameters section of this user guide.</li> <li>While you hold the value of this signal at 1, you must freeze the values of both TX MII data and TX MII control bits signals.</li> </ul> |

#### Figure 48. Transmitting Data Using the PCS Mode TX Interface







The figure above shows how to write packets directly to the PCS mode TX interface.

- The packets are written using MII.
  - Each byte in i\_tx\_mii\_d has a corresponding bit in i\_tx\_mii\_c that indicates whether the byte is a control byte or a data byte; for example, i\_tx\_mii\_c[1] is the control bit for i\_tx\_mii\_d[15:8].
- i tx mii valid should conform to these conditions:
  - Assert the valid signal only when the ready signal is asserted, and deassert only when the ready signal is deasserted.
  - The two signals can be spaced by a fixed latency between 1 and 10 cycles.
  - When the valid signal deasserts, i\_tx\_mii\_d and i\_tx\_mii\_c must be \_ paused.
- The byte order for the PCS mode TX interface is opposite of the byte order for the . MAC client. Bytes flow from right to left; the first byte to be transmitted from the interface is i tx mii d[7:0].
- The bit order for the PCS mode TX interface is the same as the bit order of the ٠ MAC client. The first bit to be transmitted from the interface is i tx mii d[0].
- The PCS mode TX interface is not SOP aligned. Any legal ordering of packets in MII Note: format is accepted.

#### Table 39. Writing a Start Packet Block with Preamble to the PCS Mode TX Interface

| MII Data          |      | MII Control   |   | Ethernet Packet Byte |
|-------------------|------|---------------|---|----------------------|
| i_tx_mii_d[7:0]   | 0xFB | i_tx_mii_c[0] | 1 | Start of Packet      |
| i_tx_mii_d[15:8]  | 0x55 | i_tx_mii_c[1] | 0 | Preamble             |
| i_tx_mii_d[23:16] | 0x55 | i_tx_mii_c[2] | 0 | Preamble             |
| i_tx_mii_d[31:24] | 0x55 | i_tx_mii_c[3] | 0 | Preamble             |
| i_tx_mii_d[39:32] | 0x55 | i_tx_mii_c[4] | 0 | Preamble             |
| i_tx_mii_d[47:40] | 0x55 | i_tx_mii_c[5] | 0 | Preamble             |
| i_tx_mii_d[55:48] | 0x55 | i_tx_mii_c[6] | 0 | Preamble             |
| i_tx_mii_d[63:56] | 0xD5 | i_tx_mii_c[7] | 0 | SFD                  |

#### Figure 49. **Inserting Alignment Markers**



The timing of alignment marker insertion is very rigid. Alignment markers cannot be delayed without disrupting the Ethernet link. Use valid cycles to count the alignment markers. When i\_tx\_mii\_valid is low, the alignment marker counters and input must freeze.





The number of cycles for  $i_tx_mii_am$  to remain high depends on the rate of the interface:

- Links with RS-FEC: 4 cycles
- Links without RS-FEC: 0 cycle (tie low)

The number of cycles for am period depends on the rate of the interface and whether in simulation or hardware:

- In simulation, it is common to use a reduced am period for both sides of the link to increase lock-time speed. The am period for link with RSFEC enabled is set to 5119.
- In hardware, the am period for link with RSFEC enabled is set to 81916.

# 2.11.8. RX Custom PCS Interface to User Logic

The E-Tile Hard IP for Ethernet Intel FPGA IP RX client interface in custom PCS variations employs the MII protocol.

The RX PCS acts as a source and the client acts as a sink in the receive direction.

#### Table 40. Signals of the MII RX Client Interface

All interface signals are clocked by the RX clock. The signal names are standard Avalon streaming interface signals with slight differences to indicate the variations. The letter n in the signal name is referring to the number of channel. For example, the name of the MII TX data for channel 1 is  $i\_s1\_tx\_mii\_d[(n*width)-1:0]$ .

| Signal Name                       | Width                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_clk_rx<br>i_sl_clk_rx[n-1:0] | 1 bit for each channel   | The RX clock for the IP core that drives the channel.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| o_sl_rx_mii_d[(n*width)-1:0]      | 64 bits for each channel | RX MII data. Data is in MII encoding.<br>o_rx_mii_d[7:0] holds the first byte the IP core<br>received on the Ethernet link. o_rx_mii_d[0] holds<br>the first bit the IP core received on the Ethernet link.<br>When RX MII valid signal has the value of 0 or the<br>RX valid alignment marker signal has the value of 1,<br>the value on this signal is invalid.                                                                                                                                                                                                                                                                                                                                                                             |
| o_sl_rx_mii_c[(n*width)-1:0]      | 8 bits for each channel  | RX MII control bits. Each bit corresponds to a byte of<br>RX MII data. o_rx_mii_c[0] corresponds to<br>o_rx_mii_d[7:0], o_rx_mii_c[1] corresponds<br>to o_rx_mii_d[15:8], and so on.<br>If the value of a bit is 1, the corresponding data byte<br>is a control byte. If the value of a bit is 0, the<br>corresponding data byte is data.<br>The Start of Packet byte (0xFB), End of Packet byte<br>(0xFD), Idle bytes (0x07), and error byte (0xFE) are<br>control bytes, but the preamble bytes, Start of<br>Frame (SFD) byte (0xD5), CRC bytes, and payload<br>bytes are data bytes.<br>When RX MII valid signal has the value of 0 or the<br>RX valid alignment marker signal has the value of 1,<br>the value on this signal is invalid. |
| o_sl_rx_mii_valid[n-1:0]          | 1 bit for each channel   | Indicates that the RX MII data, RX MII control bits, and the RX valid alignment marker signals are valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| o_sl_rx_mii_am_valid[n-1:0]       | 1 bit for each channel   | Indicates the IP core received a valid alignment marker on the Ethernet link.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                   |                          | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



| Signal Name | Width | Description                                                                                                                                                                     |
|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |       | When the RX MII valid signal has the value of 0, the value on this signal is invalid. The value of the RX MII valid signal may fall while the IP core is asserting this signal. |

#### Figure 50. **Receiving Data Using the PCS Mode RX Interface**



The figure above shows how to read packets from the RX PCS using the PCS mode RX interface.

- The packets are MII encoded.
  - Each byte in o\_rx\_mii\_d has a corresponding bit in o\_rx\_mii\_c that indicates whether the byte is a control byte or a data byte; for example, o\_rx\_mii\_c[2] is the control bit for o\_rx\_mii\_d[23:16].
- The data is only valid when o\_rx\_mii\_valid is high. The contents of the o\_rx\_mii\_d and o\_rx\_mii\_c buses are not defined when o\_rx\_mii\_valid is low.
- The byte order for the PCS mode RX interface is opposite of the byte order for the MAC client. Bytes flow from right to left; the first byte that the core receives is o\_rx\_mii\_d[7:0].
- The bit order for the PCS mode RX interface is the same as the bit order of the MAC client. The first bit that the core receives is o\_rx\_mii\_d[0].
- Note: The PCS mode RX interface is not SOP aligned. New packets can begin on any byte position that is divisible by 8 (PCS data is transferred in 8-byte blocks).

#### Table 41. Reading a Start Packet Block with Preamble from a PCS Mode TX Interface

| MII Data          |      | MII Control   |   | Ethernet Packet Byte |
|-------------------|------|---------------|---|----------------------|
| o_rx_mii_d[7:0]   | 0xFB | o_rx_mii_c[0] | 1 | Start of Packet      |
| o_rx_mii_d[15:8]  | 0x55 | o_rx_mii_c[1] | 0 | Preamble             |
| o_rx_mii_d[23:16] | 0x55 | o_rx_mii_c[2] | 0 | Preamble             |
| o_rx_mii_d[31:24] | 0x55 | o_rx_mii_c[3] | 0 | Preamble             |
| o_rx_mii_d[39:32] | 0x55 | o_rx_mii_c[4] | 0 | Preamble             |
| o_rx_mii_d[47:40] | 0x55 | o_rx_mii_c[5] | 0 | Preamble             |
| o_rx_mii_d[55:48] | 0x55 | o_rx_mii_c[6] | 0 | Preamble             |
| o_rx_mii_d[63:56] | 0xD5 | o_rx_mii_c[7] | 0 | SFD                  |





#### Figure 51. Receiving Alignment Markers



o\_rx\_mii\_am\_valid indicates the arrival of the alignment markers from the RX PCS. The alignment markers also depend on o\_rx\_mii\_valid. When o\_rx\_mii\_valid is low, o\_rx\_mii\_am\_valid is not valid.

The contents of the o\_rx\_mii\_d and o\_rx\_mii\_c buses are not defined when o\_rx\_mii\_valid is low. This is because alignment markers are not part of the 64b/66b encoding, and do not have an MII equivalent.

# 2.11.9. PMA Direct Interface

The E-Tile Hard IP for Ethernet Intel FPGA IP PMA Direct TX and RX Interfaces are available when you turn on **Include alternate ports** for 10G/25G channels in **100GE** or **1 to 4 10GE/25GE with optional RS-FEC and 1588 PTP** variation.

These signals are never connected to the Ethernet hard logic. They are available when you need to switch at run time to PMA modes.

#### Table 42. Signals of the PMA Direct Interface

| Signal Name            | Width | Description                                                                                                                                                                   |
|------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_tx_pma[ch-1:0] 80 |       | PMA Direct TX datapath for corresponding transceiver.<br>For all Ethernet cores, this signal does nothing until core is reconfigured<br>at run-time to enter PMA Direct mode. |
| o_sl_rx_pma[ch-1:0]    | 80    | PMA Direct RX datapath for corresponding transceiver.<br>For all Ethernet cores, this signal does nothing until core is reconfigured<br>at run-time to enter PMA Direct mode. |

# 2.11.10. Custom Rate Interface

The E-Tile Hard IP for Ethernet Intel FPGA IP Custom Rate Interface is available when you turn on **Enable custom rate** for 10G/25G channels in **100GE or 1 to 4 10GE/25GE with optional RS-FEC and 1588 PTP** variation.

- *Note:* Exposing custom rate cadence interface does not change the Ethernet operation. Ethernet protocol does not use this interface.
- *Note:* Enabling this feature exposes the interface from Stratix 10 E-Tile Transceiver Native PHY to the user. It does not enable a custom cadence feature within the E-Tile Hard IP for Ethernet. To enable the custom cadence feature in the Stratix 10 E-Tile Transceiver Native PHY, you must set flowreg\_rate register in the EHIP TX MAC Feature Configuration on page 201 to 0x7.

*Note:* Refer to the E-Tile CPRI PHY IP for an example of the interface usage.



### Table 43.Signals of the Custom Rate Interface

All of the Custom Rate Interface signals except the <code>i\_sl\_custom\_cadence[ch-1:0]</code> signal are asynchronous.

| Signal Name                   | Width | Description                                                                                                                                                                                                                                                                                                                          |
|-------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_custom_cadence[ch-1:0]   | 1     | Custom data valid signal.<br>Connect this signal either to a counter that produces a steady data valid<br>cadence that corresponds to the ratio between the clock rate used and<br>the clock rate required, or a system that increases or decreases the data<br>valid cadence based on the current occupancy of transceiver TX FIFO. |
| o_sl_txfifo_pfull[ch-1:0]     | 1     | When asserted, indicates that the transceiver TX FIFO is partially full. At this point, the transceiver FIFO exceeds the programmed <i>Partially Full</i> watermark.                                                                                                                                                                 |
| o_sl_txfifo_pempty[ch-1:0]    | 1     | When asserted, indicates that the transceiver TX FIFO is partially empty. At this point, the transceiver FIFO is below the programmed <i>Partially Full</i> watermark.                                                                                                                                                               |
| o_sl_txfifo_overflow[ch-1:0]  | 1     | When asserted, indicates that the transceiver TX FIFO has overflowed, and should be reset.                                                                                                                                                                                                                                           |
| o_sl_txfifo_underflow[ch-1:0] | 1     | When asserted, indicates that the transceiver TX FIFO has underflowed, and should be reset.                                                                                                                                                                                                                                          |

# **2.11.11. Deterministic Latency Interface**

The E-Tile Hard IP for Ethernet Intel FPGA IP Deterministic Latency Interface is available when you turn on **Include deterministic latency measurement interface** for 10G/25G channels in **100GE or 1 to 4 10GE/25GE with optional RS-FEC and 1588 PTP** variation.

When setting is turned on, you can view the deterministic latency interface directly from the Stratix 10 E-Tile Transceiver Native PHY. Use the deterministic latency interface if you want to measure the latency of the datapath when running a stack that does not include MAC.

- *Note:* Exposing deterministic latency interface does not change the Ethernet operation. Ethernet protocol does not use this interface. Enabling this feature exposes the interface from Stratix 10 E-Tile Transceiver Native PHY to the user.
- *Note:* Refer to the E-Tile CPRI PHY IP in Deterministic Latency Calculation on page 271 for an example of the interface usage.

# Table 44. Signals of the Deterministic Latency Interface

All of the Deterministic Latency Interface signals are asynchronous.

| Signal Name                        | Width | Description                                                                                                                                                               |
|------------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_tx_dl_async_pulse[ch-1:0]        | 1     | Asynchronous output pulse signal for the transmitter latency measurement $^{\rm (18)}$ of the deterministic latency application. There is a start pulse and a stop pulse. |
| o_sl_rx_dl_async_pulse[ch-<br>1:0] | 1     | Asynchronous output pulse signal for the receiver latency measurement $^{(18)}$ of the deterministic latency application. There is a start pulse and a stop pulse.        |
|                                    |       | continued                                                                                                                                                                 |

<sup>&</sup>lt;sup>(18)</sup> For more information, review the *Latency Measurement* section.



2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



| Signal Name                        | Width | Description                                                                                                                                     |
|------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_latency_sclk[ch-1:0] 1        |       | Clock signal for latency measurement $^{(18)}$ of the deterministic latency application.                                                        |
| i_sl_tx_dl_measure_sel[ch-<br>1:0] | 1     | Mux select signal for the transmitter latency measurement. <sup><math>(18)</math></sup> 1 is for the datapath latency. 0 is for the wire delay. |
| i_sl_rx_dl_measure_sel[ch-<br>1:0] | 1     | Mux select signal for the receiver latency measurement. $^{(18)}$ 1 is for the datapath latency. 0 is for the wire delay.                       |

# 2.11.12. 1588 PTP Interface

The E-Tile Hard IP for Ethernet Intel FPGA IP 1588 PTP Interface is available for 10G/25G designs when you turn on **Enable IEEE 1588 PTP** for 10G/25G channels in **100GE or 1 to 4 10GE/25GE with optional RS-FEC and 1588 PTP** variation. The 1588 Precision Time Protocol (PTP) timestamp information provided is as defined in the *IEEE 1588-2008 Precision Clock Synchronization Protocol for Networked Measurement and Control Systems Standard*.

These signals are active only when your selected channel is configured to provide a MAC+PTP+PCS stack.

All interface signals are clocked by the TX or RX clock. The signal names are standard Avalon streaming interface signals with slight differences to indicate the variations. For example:

- For 100GE channel or single channel 10GE/25GE: i\_ptp\_ins\_ets
- For selected 10GE/25GE channel: i\_sl\_ptp\_ins\_ets[(n\*width)-1:0]

All 1-step and 2-step TX/RX Timestamp Interface signals are synchronized with i\_sl\_async\_clk\_tx/rx.

The shared ToD signal i\_ptp\_tod remains synchronized with i\_ptp\_clk.

### Table 45.Signals of the 1-Step TX Timestamp Interface

| Signal Name                              | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_ptp_ins_ets<br>i_sl_ptp_ins_ets[n-1:0] | 1     | <ul> <li>Egress timestamp into the current TX Packet on the respective channel.</li> <li>Valid only when the TX valid and TX SOP signals are asserted.</li> <li>Do not use when the TX skip CRC signal (e.g. i_tx_skip_crc) is asserted. The CRC for the TX packet must be recalculated after the egress timestamp is written.</li> <li>Do not use when the residence time timestamp signal (e.g. i_ptp_ins_cf) is asserted. You cannot update residence time and insert an egress timestamp on the same packet.</li> </ul> |
|                                          |       | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



| Signal Name                                  | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                              |       | <ul> <li>Set the position of the PTP timestamp field in the TX packet (e.g. i_ptp_ts_offset) to the byte position of the start of the timestamp field in the PTP header.</li> <li>Set the format for the PTP 1-step operation (e.g. i_ptp_ts_format) to the desired timestamp format.</li> <li>If the selected timestamp format requires a 96b timestamp, set the PTP correction field in the TX packet (e.g. i_ptp_cf_offset) to the byte position of the start of the correction field in the PTP header.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| i_ptp_ins_cf<br>i_sl_ptp_ins_cf[n-1:0]       | 1     | <ul> <li>Residence time timestamp into the correction field in the current TX packet on the respective channel.</li> <li>Valid only when the TX valid and TX SOP signals are asserted.</li> <li>Do not use when the TX skip CRC signal (e.g. i_tx_skip_crc) is asserted. The CRC for the TX packet must be recalculated after the residence time is written.</li> <li>Do not use when the egress time timestamp signal (e.g. i_ptp_ins_ets) is asserted. You cannot update residence time and insert an egress timestamp of the current packet (e.g. assert i_ptp_tx_its) when it entered the system, so that a residence time can be calculated.</li> <li>Set the position of the PTP correction field in the TX packet (e.g. i_ptp_cf_offset) to the byte position of the start of the correction field in the correction field will show a mismatched in the correction field will show a mismatched in the correction field will show a mismatched in the PTP 1-step operation (e.g. i_ptp_ts_format) to the desired timestamp format.</li> </ul> |
| i_ptp_zero_csum<br>i_sl_ptp_zero_csum[n-1:0] | 1     | <ul> <li>Overwrites the checksum in a UDP packet carried inside the current TX packet with zeros.</li> <li>Valid only when the TX valid and TX SOP signals are asserted.</li> <li>Do not use when the TX skip CRC signal (e.g. i_tx_skip_crc) is asserted. The CRC for the TX packet must be recalculated after the checksum is changed.</li> <li>Do not use when the update extended bytes field signal (e.g i_ptp_update_eb) is asserted. You cannot set a UDP checksum to 0, and update an extension field to cancel out checksum changes on the same packet.</li> <li>Set the position of the UDP checksum field in the TX packet (e.g. i_ptp_csum_offset) to the byte position of the start of the UDP checksum in the TX packet.</li> </ul>                                                                                                                                                                                                                                                                                                     |



#### 2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



| Signal Name                                               | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_ptp_update_eb<br>i_sl_ptp_update_eb[n-1:0]              | 1     | <ul> <li>Overwrites the extended bytes field in an IPv6 packet carried inside the current TX packet with a value that cancels out changes to the checksum due to changes to the UDP packet.</li> <li>Valid only when the TX valid and TX SOP signals are asserted.</li> <li>Do not use when the TX skip CRC signal (e.g. i_tx_skip_crc) is asserted. The CRC for the TX packet must be recalculated after the checksum is changed.</li> <li>Do not use when the overwrite a UDP checksum with zeros signal (e.g. i_ptp_zero_csum) is asserted. You cannot set a UDP checksum to 0, and update an extension field to cancel out checksum changes on the same packet.</li> <li>Set the position of the first byte of the extended bytes field in the TX packet (e.g. i_ptp_eb_offset) to the byte position of the start of the UDP checksum in the TX packet.</li> </ul> |
| <pre>i_ptp_ts_format i_sl_ptp_ts_format[n-1:0]</pre>      | 1     | <ul> <li>Format of the PTP 1-step operation on the respective channel.</li> <li>0: Use IEEE 1588v2 timestamp and correction field formats (96 bits)</li> <li>1: Use IEEE 1588v1 timestamp and correction field formats (64 bits)</li> <li>Valid only when either the egress time timestamp signal (i_ptp_ins_ets) or the residence time timestamp signal ( i_ptp_ins_cf), and the TX valid signal, and SOP signal are asserted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <pre>i_ptp_ts_offset i_sl_ptp_ts_offset[(n*16)-1:0]</pre> | 16    | <ul> <li>Position of the PTP timestamp field in the current TX packet.</li> <li>Valid only when the TX valid and TX SOP signals are asserted.</li> <li>It is the offset of the first octet of the field from the start of the frame, where the first byte of the frame (the first destination MAC address octet) is position 0.</li> <li>The IEEE 1588v2 PTP timestamp field is 10 octets long (80 bits), and the IEEE 1588v1 timestamp is 8 octets long (64bits), starting from the position given by the offset. Because the IEEE 1588v2 timestamps are actually 96 bits long, the lower 16 bits of the timestamp are placed in the lower 2 octets of the orrection field.</li> <li>Caution: You must set the offset to a position within the TX packet, or the PTP insertion operation will fail. You must not also overlap the PTP fields.</li> </ul>              |
| <pre>i_ptp_cf_offset i_sl_ptp_cf_offset[(n*16)-1:0]</pre> | 16    | <ul> <li>Position of the PTP correction field in the current TX packet.</li> <li>Valid only when the TX valid and TX SOP signals are asserted.</li> <li>It is the offset of the first octet of the field from the start of the frame, where the first byte of the frame (the first destination MAC address octet) is position 0.</li> <li>The PTP correction field is 8 octets long, starting from the position given by the offset. When 96-bit timestamps are used, the MAC places the lower 16 bits of the timestamp in the lower 2 octets of the orrection field.</li> <li>Caution: You must set the offset to a position within the TX packet, or the PTP insertion operation will fail. You must not also overlap the PTP fields.</li> </ul>                                                                                                                     |



| Signal Name                                           | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_ptp_csum_offset<br>i_sl_ptp_csum_offset[(n*16)-1:0] | 16    | <ul> <li>Position of the first byte of a UDP checksum field in the current TX packet.</li> <li>Valid only when the checksum overwrite in a UDP packet (e.g. i_ptp_zero_csum), TX valid, TX SOP signals are asserted.</li> <li>It is the offset of the first octet of the field from the start of the frame, where the first byte of the frame (the first destination MAC address octet) is position 0.</li> <li>Caution: You must set the offset to a position within the TX packet, or the PTP insertion operation will fail. You must not also overlap the PTP fields.</li> </ul>                |
| i_ptp_eb_offset<br>i_sl_ptp_eb_offset[(n*16)-1:0]     | 16    | <ul> <li>Position of the first byte of extended bytes field in the current TX packet.</li> <li>Valid only when the extended bytes overwrite in an IPv6 packet (e.g. i_ptp_update_eb), TX valid, TX SOP signals are asserted.</li> <li>It is the offset of the first octet of the field from the start of the frame, where the first byte of the frame (the first destination MAC address octet) is position 0.</li> <li><i>Caution:</i> You must set the offset to a position within the TX packet, or the PTP insertion operation will fail. You must not also overlap the PTP fields.</li> </ul> |
| i_ptp_tx_its<br>i_sl_ptp_tx_its[(n*96)-1:0]           | 96    | Ingress timestamp for a TX packet that requires a residence<br>time calculation (e.g. i_ptp_ins_cf = 1).<br>This timestamp is the time at which the packet arrives in the<br>system. The TX MAC compares this time to the time at which<br>the packet leaves the system to generate a residence time.<br>The PTP 1-step operation (e.g. i_ptp_ts_format)<br>determines the timestamp format to be used.<br>Valid only when the TX valid and TX SOP signals are asserted.                                                                                                                           |

#### Table 46. Signals of the 2-Step TX Timestamp Interface

Use the 2-step TX Timestamp to request for 2-step TX Timestamps when a packet is transmitted.

| Signal Name                                    | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>i_ptp_ts_req i_sl_ptp_ts_req[n-1:0]</pre> | 1     | Request a 2-step timestamp signal for the current TX packet.<br>When asserted, generates a TX timestamp for the current<br>packet.<br>Valid only when the TX valid and TX SOP signals are asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| i_ptp_fp<br>i_sl_ptp_fp[(n*8)-1:0]             | 8     | <ul> <li>Fingerprint signal for current TX packet.</li> <li>Assigns an 8-bit fingerprint to a TX packet that is being transmitted, so that the 2-step or 1-step PTP timestamp associated with the TX packet can be identified. The timestamp returns with the same fingerprint.</li> <li>Use a range of fingerprints from 031 or larger, to avoid the possibility of assigning the same fingerprint to 2 TX packets that are being processed.</li> <li>Choose an easy-to-decode null fingerprint for any packets that do not require an egress timestamp. For example, if you use a range of 031, make 32 the null fingerprint.</li> <li>Valid only when the TX valid and TX SOP signals are asserted.</li> </ul> |
| o_ptp_ets_valid<br>o_sl_ptp_ets_valid[n-1:0]   | 1     | 2-step egress timestamp valid signal.<br>When asserted, the fingerprint and egress timestamp signals<br>present valid output on this cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| o_ptp_ets<br>o_sl_ptp_ets[(n*96)-1:0]          | 96    | 2-step or 1-step egress timestamp signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                |       | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |





| Signal Name                                        | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                    |       | <ul> <li>When asserted, presents an egress timestamp for the TX<br/>Packet that was transmitted with the fingerprint given by<br/>o_ptp_ets_fp.</li> <li>Before asserting this signal, consider the following: <ul> <li>Valid only when the egress timestamp valid<br/>(o_ptp_ets_valid) signal is asserted.</li> <li>The timestamp is in 1588v2 format (96b).</li> <li>The timestamp is for the packet whose fingerprint matches<br/>the fingerprint with the egress timestamp.</li> <li>All timestamps are referenced to the copy of the Time-of-<br/>Day provided to the IP core through the i_ptp_tod port.</li> </ul> </li> </ul> |
| <pre>o_ptp_ets_fp o_sl_ptp_ets_fp[(n*8)-1:0]</pre> | 8     | Fingerprint for the current 2-step or 1-step egress timestamp.<br>You can use the fingerprint to determine which TX packet the<br>timestamp belongs to.<br>Valid only when the egress timestamp valid signal<br>( o_ptp_ets_valid) is asserted.                                                                                                                                                                                                                                                                                                                                                                                        |

### Table 47. Signals of the Shared Time of Day Interface

The shared time of day interface allows the core to reference all of its timestamps to the time of day as it is known locally. All 10G/25G and 100G channels share this port.

| Signal Name | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_ptp_tod   | 96    | <ul> <li>Time of Day according to the local clock.</li> <li>Presents the current time of day (according to the local clock) to the Ethernet core. All the channels in the core share this TOD port.</li> <li>The timestamp is in 1588v2 format (96b).</li> <li>Bits [95:48]: Seconds (48 bits).</li> <li>Bits [47:16]: Nanoseconds (32 bits). This field overflows at 1 billion.</li> <li>Bits [15:0]: Fractions of nanosecond (16 bits). This field is a true fraction; it overflows at 0xFFF.</li> </ul> |

### Table 48. Signals of the RX Timestamp Interface

The RX Timestamp interface allows each channel to provide RX timestamps when packets arrive.

| Signal Name                                 | Width | Description                                                                                                                                                                                                                          |
|---------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_ptp_rx_its<br>o_sl_ptp_rx_its[(n*96)-1:0] | 96    | Ingress RX timestamp signal.<br>Presents the ingress timestamp for the incoming RX packet on<br>the respective channel.<br>Valid only when the RX valid and RX SOP signals are asserted.<br>The timestamp is in 1588v2 format (96b). |

### Table 49. Signals of the PTP Status Interface

The PTP Status interface lets applications using PTP functions know when the PTP timestamp logic is ready for use.

| Signal Name                                | Width | Description                                                                                                                                                                                                                                        |
|--------------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_tx_ptp_ready<br>o_sl_tx_ptp_ready[n-1:0] | 1     | TX PTP ready signal.<br>When asserted, the core to ready to request for TX PTP<br>functions on the respective channel.<br>When Asynchronous mode is enabled,<br>o_sl_tx_ptp_ready[n-1:0] signal is asynchronous to the<br>i_sl_async_clk_tx clock. |
| o_rx_ptp_ready                             | 1     | RX PTP ready signal.                                                                                                                                                                                                                               |
|                                            |       | continued                                                                                                                                                                                                                                          |





| Signal Name              | Width | Description                                                                                                                                                                                                                                                                                                    |
|--------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_sl_rx_ptp_ready[n-1:0] |       | When asserted, the RX PTP logic ready for use on the respective channel. After reset and PMA adaptation, the signal gets asserted after link partner sends up to 20 Ethernet packets.<br>When Asynchronous mode is enabled,<br>o_sl_rx_ptp_ready[n-1:0] signal is asynchronous to the i_sl_async_clk_rx clock. |

# 2.11.13. Ethernet Link and Transceiver Signals

The E-Tile Hard IP for Ethernet Intel FPGA IP includes transceivers that implement two or four physical lanes at the line rates required for Ethernet channels.

#### Table 50. **Transceiver Signals**

Note:

| Signal                                                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>o_tx_serial[n-1:0] (10GE/25GE) o_tx_serial[3:0] (100GE)</pre> | TX transceiver data. Each <code>o_tx_serial</code> bit becomes two physical pins that form a differential pair.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| i_rx_serial[n-1:0] (10GE/25GE)<br>i_rx_serial[3:0] (100GE)         | RX transceiver data. Each <code>i_rx_serial</code> bit becomes two physical pins that form a differential pair.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <pre>i_clk_ref[n-1:0](10GE/25GE) i_clk_ref(100GE)</pre>            | The input clock i_clk_ref is the reference clock for the high-speed serial clocks.<br>This clock must have the same frequency as specified in <b>PHY Reference</b><br><b>Frequency</b> parameter with a ±100 ppm accuracy per the <i>IEEE 802.3-2015</i><br><i>Ethernet Standard</i> .<br>This signal supports the following frequencies:<br>• 156.25 MHz<br>• 322.265625 MHz<br>• 312.5 MHz<br>• 644.53125 MHz<br>In addition, this clock must meet the jitter specification of the <i>IEEE 802.3-2015</i><br><i>Ethernet Standard</i> .<br>The PLL and clock generation logic use this reference clock to derive the<br>transceiver and PCS clocks. The input clock should be a high quality signal on the<br>appropriate dedicated clock pin. Refer to the <i>Intel Stratix 10 Device Data Sheet</i> for<br>transceiver reference clock phase noise specifications. |
| o_tx_pll_locked[n-1:0]                                             | The o_tx_pll_locked[n-1:0] signal indicates when the transceiver PLL output clocks are locked.<br>The o_clk_pll_div64 and o_clk_pll_div66 clocks are reliable only after this signal bits are all high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

## **Related Information**

- Intel Stratix 10 Device Data Sheet ٠
- E-Tile Transceiver PHY User Guide ٠ Information about the Intel Stratix 10 Native PHY IP core.





# 2.11.14. Reconfiguration Interfaces and Signals

### 2.11.14.1. Ethernet Reconfiguration Interfaces

You access Ethernet control and status registers of the E-Tile Hard IP for Ethernet Intel FPGA IP during normal operation using an Avalon memory-mapped interface. The interface responds regardless of the link status. It also responds when the IP core is in a reset state driven by any reset signal or soft reset other than the i\_csr\_rst\_n signal.

Asserting the i\_csr\_rst\_n signal resets all Ethernet control and status registers, including the statistics counters; while this reset is in process, reads or writes to addresses in the Ethernet Hard IP will be delayed.

#### Table 51. Ethernet Reconfiguration Interface

The signals in this interface are clocked by the i\_reconfig\_clk clock and reset by the i\_reconfig\_reset signal. This clock and reset are used for all the reconfiguration interfaces in the IP core. However, the two interfaces access disjoint sets of registers. The signal names are standard Avalon streaming interface signals with slight differences to indicate the variations. For example:

- For variants with single 10GE/25GE channel: i\_sl\_eth\_reconfig\_addr
- For variants with more than 1 channel: i\_sl\_eth\_reconfig\_addr[n-1:0]
- For variants with single 100GE channel: i\_eth\_reconfig\_addr

| Port Name                                                                                            | Width                            | Description                                                                               |
|------------------------------------------------------------------------------------------------------|----------------------------------|-------------------------------------------------------------------------------------------|
| <pre>i_sl_eth_reconfig_addr<br/>i_sl_eth_reconfig_addr[n<br/>-1:0]<br/>i_eth_reconfig_addr</pre>     | 21 (100GE)<br>19 (10GE/<br>25GE) | Address bus for Ethernet control and status registers in the respective channel.          |
| <pre>i_sl_eth_reconfig_write<br/>i_sl_eth_reconfig_write[<br/>n-1:0]<br/>i_eth_reconfig_write</pre>  | 1                                | Write request signal for Ethernet control and status registers in the respective channel. |
| <pre>i_sl_eth_reconfig_read<br/>i_sl_eth_reconfig_read[n<br/>-1:0]<br/>i_eth_reconfig_read</pre>     | 1                                | Read request signal for Ethernet control and status registers in the respective channel.  |
| <pre>i_sl_eth_reconfig_writed ata i_sl_eth_reconfig_writed ata[n-1:0] i_eth_reconfig_writedata</pre> | 32                               | Write data for Ethernet control and status registers in the respective channel.           |
| <pre>i_sl_eth_reconfig_readda ta i_sl_eth_reconfig_readda ta[n-1:0] i_eth_reconfig_readdata</pre>    | 32                               | Read data from reads to Ethernet control and status registers in the respective channel.  |
| o_sl_eth_reconfig_readda<br>ta_valid<br>o_sl_eth_reconfig_readda<br>ta_valid[n-1:0]                  | 1                                | Read data from Ethernet control and status registers is valid in the respective channel.  |
|                                                                                                      |                                  | continued                                                                                 |



| Port Name                                        | Width | Description                                                                                                                       |
|--------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------|
| o_eth_reconfig_readdata_<br>valid                |       |                                                                                                                                   |
| i_sl_eth_reconfig_waitre<br>quest                | 1     | Avalon memory-mapped interface stalling signal for operations on Ethernet control and status registers in the respective channel. |
| <pre>i_sl_eth_reconfig_waitre quest[n-1:0]</pre> |       |                                                                                                                                   |
| i_eth_reconfig_waitreque<br>st                   |       |                                                                                                                                   |

#### **Related Information**

#### E-Tile Transceiver PHY User Guide

Provides more information about the transceiver reconfiguration interface in E-tile devices, including timing diagrams for reads and writes.

#### 2.11.14.2. Transceiver Reconfiguration Interfaces

You access the control and status registers of the Intel Stratix 10 E-tile transceivers during normal operation using an Avalon memory-mapped interface. The interface responds regardless of the link status.

Asserting the i\_csr\_rst\_n signal resets all Ethernet control and status registers, including the statistics counters; while this reset is in process, the Ethernet reconfiguration interface does not respond.

# Table 52. Transceiver Reconfiguration Interface Ports to Native PHY Reconfiguration Interfaces Interfaces

The signals in this interface are clocked by the i\_reconfig\_clk clock and reset by the i\_reconfig\_reset signal. All interface signals are clocked by the RX clock. The signal names are standard Avalon memory-mapped interface signals with slight differences for different variations. For example:

- For single 10GE/25GE channel variant: i\_xcvr\_reconfig\_address
- For 1-4 10GE/25GE channels variant: i\_xcvr\_reconfig\_address[n-1:0]
- For single 100GE channel variant:i\_xcvr\_reconfig\_address[19\*w-1:0]; each lane = 19 bit, w = 4
- For single 100GE or 1-4 10GE/25GE channels variant: i\_xcvr\_reconfig\_address[ch-1:0]; ch = number of transceivers

| Port Name                       | Width            | Description                                                                                                                         |
|---------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| i_xcvr_reconfig_address         | 19               | Address bus for transceiver control and status registers.                                                                           |
| i_xcvr_reconfig_write           | 1                | Transceiver write signal.<br>When asserted, writes data on the reconfiguration write data bus.                                      |
| i_xcvr_reconfig_read            | 1                | Transceiver read signal.<br>When asserted, starts a read cycle.                                                                     |
| i_xcvr_reconfig_writedat<br>a   | 8 bits each lane | Transceiver write data bus.<br>When asserted, presents transceiver data written on a write cycle.                                   |
| o_xcvr_reconfig_readdata        | 8 bits each lane | Transceiver read data bus.<br>When asserted, presents transceiver data read on a read cycle.                                        |
| o_xcvr_reconfig_waitrequ<br>est | 1                | Indicates the Avalon memory-mapped interface interface is busy. The read or write cycle is only complete when this signal goes low. |





### **Related Information**

#### E-Tile Transceiver PHY User Guide

Provides more information about the transceiver reconfiguration interface in E-tile devices, including timing diagrams for reads and writes.

#### 2.11.14.3. RS-FEC Reconfiguration Interfaces

You access RS-FEC control and status registers of the E-Tile Hard IP for Ethernet Intel FPGA IP during normal operation using an Avalon-MM interface.

### Table 53. RS-FEC Reconfiguration Interface

The signals in this interface are clocked by the i\_reconfig\_clk clock and reset by i\_reconfig\_reset.

| Port Name                        | Width | Description                                                                                                |
|----------------------------------|-------|------------------------------------------------------------------------------------------------------------|
| i_rsfec_reconfig_addr            | 11    | Address bus for RS-FEC control and status registers in the respective channel.                             |
| i_rsfec_reconfig_write           | 1     | Write request signal for RS-FEC control and status registers in the respective channel.                    |
| i_rsfec_reconfig_read            | 1     | Read request signal for RS-FEC control and status registers in the respective channel.                     |
| i_rsfec_reconfig_writeda<br>ta   | 8     | Write data for RS-FEC control and status registers in the respective channel.                              |
| o_rsfec_reconfig_readdat<br>a    | 8     | Read data from reads to RS-FEC control and status registers in the respective channel.                     |
| o_rsfec_reconfig_waitreq<br>uest | 1     | Avalon-MM stalling signal for operations on RS-FEC control and status registers in the respective channel. |

### **Related Information**

#### Intel Stratix 10 E-Tile Transceiver PHY User Guide

Provides more information about the transceiver reconfiguration interface in E-tile devices, including timing diagrams for reads and writes.

### 2.11.14.4. PTP Reconfiguration Interfaces

When PTP is used, you access the control and status registers controlling the transceiver channels used for the PTP interface of the E-Tile Hard IP for Ethernet Intel FPGA IP during normal operation using an Avalon memory-mapped interface.

The PTP reconfiguration interfaces are available when you use the 100G channel with 1 to 4 10G/25G channels, RS-FEC, and PTP variant.





#### Table 54. **PTP Reconfiguration Interface**

The signals in this interface are clocked by the <code>i\_reconfig\_clk</code> clock and reset by <code>i\_reconfig\_reset</code>. Use the default AIB and transceiver configurations for PTP channels..

Note: Ports with a width including p are allocated 1 per PTP EMIB instance in the module.

| Port Name                             | Width             | Description                                                                                                                                                                                            |
|---------------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_ptp_reconfig_address[p*1-9:<br>10]  | 19 bits each lane | Control and status register address bus for PTP channel.                                                                                                                                               |
| i_ptp_reconfig_write[p-1:0]           | 1                 | PTP channel write signal asserted to write data on reconfiguration write data bus.                                                                                                                     |
| i_ptp_reconfig_read[p-1:0]            | 1                 | PTP channel read signal asserted to start a read cycle.                                                                                                                                                |
| i_ptp_reconfig_writedata[p*8-<br>1:0] | 8                 | PTP channel data to be written on a write cycle.                                                                                                                                                       |
| o_ptp_reconfig_readdata[p*8-1<br>:0]  | 8                 | PTP channel data that was read by a read cycle.                                                                                                                                                        |
| o_ptp_reconfig_waitrequest[p-<br>1:0] | 1                 | Avalon memory-mapped interface stalling signal for<br>operations on PTP control and status registers in the<br>respective channel. The read/write cycle is only<br>complete when this signal goes low. |

#### **Related Information**

Intel Stratix 10 E-Tile Transceiver PHY User Guide

Provides more information about the transceiver reconfiguration interface in E-tile devices, including timing diagrams for reads and writes.

# 2.11.15. Miscellaneous Status and Debug Signals

The E-Tile Hard IP for Ethernet Intel FPGA IP provides a handful of status and debug signals to support visibility into the actions of the IP core and the stability of IP core output clocks.

#### Table 55. **Miscellaneous Status and Debug Signals**

All of the miscellaneous output status and debug signals except the i\_stats\_snapshot signal are asynchronous and must be synchronized before they are used. The signal names are standard with slight differences to indicate the variations. For example:

- For variants with single 10GE/25GE channel: o\_sl\_tx\_lanes\_stable
- For variants with more than 1 channel: o\_sl\_tx\_lanes\_stable[ch-1:0]
- For variants with single 100GE channel: o\_tx\_lanes\_stable

| Signal                                                                         | Width   | Description                                                                                                                                                           |
|--------------------------------------------------------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>o_cdr_lock[n-1:0] (n is the number of transceivers)</pre>                 | [n-1:0] | Indicates that the recovered clocks are locked to data.<br>The o_clk_rec_div64[n] and o_clk_rec_div66[n] clocks are<br>reliable only after o_cdr_lock[n] is asserted. |
| <pre>o_sl_tx_lanes_stable o_sl_tx_lanes_stable[n-1 :0] o_tx_lanes_stable</pre> | 1       | Asserted when all physical TX lanes are stable and ready to transmit data for the corresponding Ethernet channel. Each channel has its own o_tx_lanes_stable.         |
|                                                                                |         | continued                                                                                                                                                             |



#### 2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



| Signal                                                                                     | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------------------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>o_sl_rx_block_lock o_sl_rx_block_lock[n-1:0] </pre>                                   | 1     | Asserted when the corresponding Ethernet channel completes 66-bit<br>block boundary alignment on all PCS lanes. Each channel has its own<br>block lock signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| o_rx_block_lock                                                                            |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| o_sl_rx_am_lock<br>o_sl_rx_am_lock[n-1:0]<br>o_rx_am_lock                                  | 1     | Asserted when the RX PCS completes detection of alignment markers<br>and deskew of the virtual PCS lanes in the corresponding Ethernet<br>100G channel.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <pre>o_sl_rx_pcs_ready o_sl_rx_pcs_ready[n-1:0] o_rx_pcs_ready</pre>                       | 1     | Asserted when the RX lanes of the corresponding Ethernet channel are fully aligned and ready to receive data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| o_sl_local_fault_status<br>o_sl_local_fault_status[<br>n-1:0]<br>o_local_fault_status      | 1     | Asserted when the RX MAC of the corresponding Ethernet channel detects a local fault: the RX PCS detected a problem that prevents it from receiving data. This signal is functional only if you set the <b>Choose Link Fault generation option</b> parameter to the value of <b>Bidirectional</b> or <b>Unidirectional</b> in the parameter editor or if you overwrite the parameter editor parameter by setting the link_fault_mode RTL parameter to the value of lf_bidir or lf_unidir.                                                                                                                                                                                                                                                        |
| <pre>o_sl_remote_fault_status o_sl_remote_fault_statu s[n-1:0] o_remote_fault_status</pre> | 1     | Asserted when the RX MAC of the corresponding Ethernet channel detects a remote fault: the remote link partner sent remote fault ordered sets indicating that it is unable to receive data. This signal is functional only if you set the <b>Choose Link Fault generation option</b> parameter to the value of <b>Bidirectional</b> in the parameter editor or if you overwrite the parameter editor parameter by setting the link_fault_mode RTL parameter to the value of lf_bidir.                                                                                                                                                                                                                                                            |
| <pre>i_sl_stats_snapshot i_sl_stats_snapshot[n-1: 0] i_stats_snapshot</pre>                | 1     | Directs the IP core to record a snapshot of the current state of the statistics registers. Assert this signal to perform the function of both the TX and RX statistics register shadow request fields at the same time, or to perform that function for multiple instances of the IP core simultaneously. Refer to <i>TX Statistics Counters</i> and <i>RX Statistics Counters</i> . Assert the signal for the desired duration of the freeze of read values in the statistics counters. The rising edge sets the tx_shadow_on field (bit [1]) of the CNTR_TX_STATUS register at offset 0x846 and the rx_shadow_on field (bit [1]) of the value of 1 and the falling edge resets these bits. This signal is synchronous with the i_clk_tx clock. |
| o_sl_rx_hi_ber<br>o_sl_rx_hi_ber[n-1:0]<br>o_rx_hi_ber                                     | 1     | Asserted to indicate the RX PCS of the corresponding Ethernet channel is in a HI BER state according to Figure 82-15 in the <i>IEEE 802.3-2015 Standard</i> . The IP core uses this signal in autonegotiation and link training.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| o_sl_ehip_ready<br>o_sl_ehip_ready[n-1:0]<br>o_ehip_ready                                  | 1     | The Ethernet channel deasserts this signal in response to an<br>i_csr_rst_n or i_tx_rst_n reset, or either of the corresponding<br>soft resets. After the reset process completes, the channel reasserts<br>this signal to indicate that the Hard IP for Ethernet block has<br>completed initialization and is ready to interoperate with the main<br>Intel Stratix 10 die. While the o_ehip_ready signal is low, the<br>channel's datapath is not ready for data on the client interface nor<br>ready for register accesses on the Ethernet reconfiguration interface.                                                                                                                                                                          |

# 2.11.16. Reset Signals

The IP core has three external hard reset inputs. These resets are asynchronous and are internally synchronized. In addition the IP core supports a dedicated reset signal that resets the transceiver and Ethernet reconfiguration interfaces but not the registers they control.



Assert the asynchronous resets for ten i\_reconfig\_clk cycles or until you observe the effect of their specific reset. Asserting the external hard reset i\_csr\_rst\_n returns all Ethernet reconfiguration registers to their original values. o\_rx\_pcs\_ready and o\_tx\_lanes\_stable are asserted when the core has exited reset successfully.

#### Table 56. **Reset Signals**

All of the IP core reset signals except the i\_reconfig\_reset signal are asynchronous. The signal names are standard with slight differences to indicate the variations. For example:

- For variants with single 10GE/25GE channel: i\_sl\_tx\_rst\_n
- For variants with more than 1 channel: i\_sl\_tx\_rst\_n[n-1:0]
- For variants with single 100E channel: i\_tx\_rst\_n

| Signal                                                      | Description                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_tx_rst_n<br>i_sl_tx_rst_n[n-1:0]<br>i_tx_rst_n         | Active-low hard reset signal. Resets the TX interface, including the TX PCS and TX MAC. This reset leads to the deassertion of the <code>o_tx_lanes_stable</code> output signal.                                                                                                                                             |
| i_sl_rx_rst_n<br>i_sl_rx_rst_n[n-1:0]<br>i_rx_rst_n         | Active-low hard reset signal. Resets the RX interface, including the RX PCS and RX MAC. This reset leads to the deassertion of the <code>o_rx_pcs_ready</code> output signal.                                                                                                                                                |
| <pre>i_sl_csr_rst_n i_sl_csr_rst_n[n-1:0] i_csr_rst_n</pre> | Active-low hard global reset.<br>Resets the full IP core.<br>Resets the TX MAC, RX MAC, TX PCS, RX PCS, transceivers (transceiver<br>reconfiguration registers and interface), and Ethernet reconfiguration registers.<br>This reset leads to the deassertion of the o_tx_lanes_stable and<br>o_rx_pcs_ready output signals. |
| i_reconfig_reset                                            | Resets the E-Tile Hard IP for Ethernet Intel FPGA IP core Avalon memory-mapped interfaces, both the transceiver reconfiguration interface and the Ethernet reconfiguration interface.<br>This signal is synchronous with the i_reconfig_clk clock.                                                                           |

# 2.11.17. Clocks

You must set the transceiver reference clock (i\_clk\_ref) frequency to a value that the IP supports.

The Synchronous Ethernet standard, described in the ITU-T G.8261, G.8262, and G.8264 recommendations, requires that the TX clock be filtered to maintain synchronization with the RX reference clock through a sequence of nodes. The expected usage is that user logic drives the transceiver reference clocks with a filtered version of the RX recovered clock signal, to ensure the receive and transmit functions remain synchronized. In this usage model, a design component outside the E-Tile Hard IP for Ethernet Intel FPGA IP performs the filtering.

An alternate clocking arrangement for i\_clk\_ref can be used to enable the Synchronous Ethernet (SyncE) operation. Two or more channels can share the Off-chip Cleanup PLL clock output. The Primary SyncE clock and the Backup SyncE clock come from the recovered clock output pins of channels connected to the same SyncE network while i clk ref connects to the cleanup PLL. SyncE clocking can be also combined with the data path clocking.





# Figure 52. Clock Connection in SyncE Operation



### Table 57.Clock Inputs

Describes the input clocks that you must provide.

| Signal Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_clk_tx    | <ul> <li>This clock drives both, the TX datapath and TX interface, for 10G/25G channel.</li> <li>Frequency of 402.83203125 MHz for all modes on a 25G channel. Also applicable for 10G channels when overclocked.</li> <li>Frequency of 161.1328125 MHz for all modes on a 10G channel.</li> <li>This clock must be active during dynamic reconfiguration.</li> <li><i>Note:</i> Applicable only when you select <b>Single 10GE/25GE</b>.</li> </ul>                                                                                                                                                                                                                                                                         |
| i_sl_clk_rx    | <ul> <li>This clock drives both, the RX datapath and TX interface, for 10/25G channel.</li> <li>Frequency of 402.83203125 MHz for all modes on a 25G channel. Also applicable for 10G channels when overclocked.</li> <li>Frequency of 161.1328125 MHz for all modes on a 10G channel.</li> <li>This clock must be active during dynamic reconfiguration.</li> <li><i>Note:</i> Applicable only when you select <b>Single 10GE/25GE</b>.</li> </ul>                                                                                                                                                                                                                                                                          |
| i_sl_clk_tx[n] | <ul> <li>These clocks drive the active TX datapath for 10/25G channel when Asynchronous mode is disabled.</li> <li>These clocks drive the active TX datapath and TX interface for 10/25G channel when Asynchronous mode is enabled.</li> <li>Each channel has its own clock input.</li> <li>Frequency of 402.83203125 MHz for all modes on a 25G channel. Also applicable for 10G channels when overclocked.</li> <li>Frequency of 161.1328125 MHz for all modes on a 10G channel.</li> <li>This clock must be active during dynamic reconfiguration.</li> <li><i>Note:</i> Applicable only when you select 1 to 4 10GE/25GE with optional RS-FEC or 100GE or 1 to 4 10GE/25GE with optional RS-FEC and 1588 PTP.</li> </ul> |



| Signal Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_clk_rx[n] | <ul> <li>These clocks drive the active RX datapath for 10/25G channel when Asynchronous mode is disabled.</li> <li>These clocks drive the active RX datapath and RX interface for 10/25G channel when Asynchronous mode is enabled.</li> <li>Each channel has its own clock input.</li> <li>Frequency of 402.83203125 MHz for all modes on a 25G channel. Also applicable for 10G channels when overclocked.</li> <li>Frequency of 161.1328125 MHz for all modes on a 10G channel.</li> <li>This clock must be active during dynamic reconfiguration.</li> <li><i>Note:</i> Applicable only when you select 1 to 4 10GE/25GE with optional RS-FEC or 100GE or 1 to 4 10GE/25GE with optional RS-FEC and 1588 PTP.</li> <li>This clock drives the TX interface for 100G channel.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                      |
|                | The frequency of this clock is 402.83203125 MHz for all modes on a 100G channel RS-FEC(544,514) modes, where the frequency is 415.0390625 MHz.<br><i>Note:</i> Applicable only when you select <b>Single 100GE with optional RS-FEC</b> or <b>100GE or 1 to 4 10GE/25GE with optional RS-FEC and 1588 PTP</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| i_clk_rx       | This clock drives the RX interface for 100G channel.<br>The frequency of this clock is 402.83203125 MHz for all modes on a 100G channel<br>RS-FEC(544,514) modes, where the frequency is 415.0390625 MHz.<br><i>Note:</i> Applicable only when you select <b>Single 100GE with optional RS-FEC</b> or<br><b>100GE or 1 to 4 10GE/25GE with optional RS-FEC and 1588 PTP</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| i_clk_ref      | The input clock i_clk_ref is the reference clock for the high-speed serial clocks<br>and the datapath parallel clocks.This clock must have the following frequencies with a ±100 ppm accuracy per the<br><i>IEEE 802.3-2015 Ethernet Standard</i> :1 156.25 MHz (10G/25G/100G)322.265625 MHz (10G/25G/100G)322.265625 MHz (10G/25G/100G)312.500000 MHz (100G)6 44.531250 MHz (100G)Variants with (544,514) RSFEC option only support 156.25 MHz and 312.5 MHz PHY<br>i_clk_ref reference frequency.The reference clock must be at 156.25 MHz frequency to support Auto Negotiation<br>and Link Training.In addition, i_clk_ref must meet the jitter specification of the <i>IEEE 802.3-2015</i><br><i>Ethernet Standard</i> The PLL and clock generation logic use this reference clock to derive the transceiver<br>and PCS clocks. The input clock should be a high quality signal on the appropriate<br>dedicated clock pin. Refer to the <i>Intel Stratix 10 Device Data Sheet</i> for transceiver<br>reference clock phase noise specifications.Note: Applicable only when you select Single 100GE with optional RS-FEC or<br>100GE or 1 to 4 10GE/25GE with optional RS-FEC and 1588 PTP. |
| i_reconfig_clk | Avalon clock for the E-Tile Hard IP for Ethernet Intel FPGA IP transceiver reconfiguration interface, RS-FEC reconfiguration interface, PTP reconfiguration interface, and Ethernet reconfiguration interface. The clock frequency is 100-125 MHz. All reconfiguration interface signals are synchronous to i_reconfig_clk.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| i_aib_clk      | This clock is used for all internal datapath provided externally by user.<br>This clock must be driven by a clock running at the fastest line rate in the design<br>divided by 64 and must be frequency locked to i_aib_2x_clk clock. Phase offset<br>between these two clocks are allowed.<br><i>Note:</i> Applicable only when you select <b>Enable external AIB clocking</b> parameter<br>in 10/25GE variants.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| i_aib_2x_clk   | This clock must have double the frequency of i_aib_clk clock and is provided<br>externally by user. It is used for clock crossing handling in EMIB interface.<br>This clock must be frequency locked to i_aib_clk clock. Phase offset between<br>these two clocks are allowed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |



2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



| Signal Name          | Description                                                                                                                                                  |  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                      | <i>Note:</i> Applicable only when you select <b>Enable external AIB clocking</b> parameter in 10/25GE variants.                                              |  |
| i_sl_async_clk_tx[n] | This clock drives the TX interface for 25G channel when Asynchronous mode is enabled.<br>The clock frequency must be within 390.625 MHz to 402.83203125 MHz. |  |
| i_sl_async_clk_rx[n] | This clock drives the RX interface for 25G channel when Asynchronous mode is enabled.<br>The clock frequency must be within 390.625 MHz to 402.83203125 MHz. |  |

### Table 58. Clock Outputs

Describes the output clocks that the IP core provides. In most cases these clocks participate in internal clocking of the IP core as well.

| Signal Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_clk_pll_div64[n]  | <ul> <li>Hard IP for Ethernet block clock.</li> <li>Supports the following clock frequencies:</li> <li>402.83203125 MHz for 25G and 100G with optional RS-FEC(528,514) channels</li> <li>415.0390625 MHz for 100G with RS-FEC(544,514) channel</li> <li>161.1328125 MHz for 10G channels</li> <li>This clock is reliable only after o_tx_pll_locked is asserted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| o_clk_pll_div66[n]  | <ul> <li>Hard IP for Ethernet block clock times 64/66.</li> <li>Supports the following clock frequencies:</li> <li>390.625 MHz for 25G and 100G with optional RS-FEC(528,514) channels</li> <li>402.4621 MHz for 100G with RS-FEC(544,514)</li> <li>156.25 MHz for 10G channels</li> <li>805.66 MHz for 25G PTP channels</li> <li>322.265625 MHz for 10G PTP channels</li> <li>This clock is reliable only after o_tx_pll_locked is asserted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| o_clk_rec_div64[n]  | <ul> <li>Derived from RX recovered clock. This clock supports the SyncE standard.<br/>The RX recovered clock frequency is:</li> <li>161.1328125 MHz ±100 ppm for 10G channels</li> <li>402.83203125 MHz ±100 ppm for 25G channels</li> <li>402.83203125 MHz ±100 ppm for 100G with optional RS-FEC(528,514) channels</li> <li>415.0390625 MHz ±100 ppm for 100G with RS-FEC(544,514) channels</li> <li>This clock is reliable only after o_cdr_lock[n] is asserted.</li> <li>When using this clock for Synchronous Ethernet, the expected usage is that you drive the TX transceiver reference clock with a filtered and divided version of o_clk_rec_div64 or o_clk_rec_div66, to ensure the receive and transmit functions remain synchronized. To do so you must include an additional component on your board. The IP core does not provide filtering.</li> <li>Note: The RX recovered clock is not available for PTP channels when PTP enabled.</li> </ul>              |
| o_clk_rec_div66[ch] | <ul> <li>Derived from RX recovered clock. This clock supports the Synchronous Ethernet standard.<br/>The RX recovered clock frequency is: <ul> <li>156.25 MHz ±100 ppm for 10G channels</li> <li>390.625 MHz ±100 ppm for 25G channels</li> <li>390.625 MHz ±100 ppm for 100G with optional RS-FEC(528,514) channels</li> <li>402.4621 MHz ±100 ppm for 100G with optional RS-FEC(528,514) channels</li> </ul> </li> <li>This clock is reliable only after o_cdr_lock[n] is asserted.<br/>When using this clock for Synchronous Ethernet, the expected usage is that you drive the TX transceiver PLL reference clock with a filtered and divided version of o_clk_rec_div64 or o_cclk_rec_div66, to ensure the receive and transmit functions remain synchronized. To do so you must include an additional component on your board. The IP core does not provide filtering.<br/>Note: The RX recovered clock is not available for PTP channels when PTP enabled.</li> </ul> |



# **Related Information**

- Intel Stratix 10 Device Data Sheet
   Provides transceiver reference clock phase noise specifications.
- Intel Agilex Device Data Sheet

# 2.11.17.1. Asynchronous Adapter Clock in 25G Mode

When enabling asynchronous adapter clocks, you may clock the TX/RX interface in TX MAC Interface to User Logic on page 104 using the <code>i\_sl\_async\_clk\_tx/rx</code> clock asynchronous to the <code>i\_sl\_sync\_clk\_tx/rx</code> signals used in the internal IP datapath.

### Figure 53. Clock Connection in Asynchronous FIFO Operation





 $<sup>^{(19)}</sup>$  When Asynchronous mode is disabled, <code>i\_sl\_clk\_tx/rx</code> signals drive both, TX/RX interface and TX/RX datapath in 25G mode.



# Table 59.Supported Clock Rates for MAC Client Asynchronous FIFO Operation in 25G<br/>Mode

The below rates assume 1 byte IPG and disabled preamble-pass-through.

| Rate | Clock Rate               |                          |                          |                          |
|------|--------------------------|--------------------------|--------------------------|--------------------------|
|      | Min<br>i_sl_async_clk_tx | Max<br>i_sl_async_clk_tx | Min<br>i_sl_async_clk_rx | Max<br>i_sl_async_clk_rx |
| 25G  | 390.625 MHz              | 402.83203215 MHz         | 390.625 MHz              | 402.83203215 MHz         |

# 2.11.17.2. Asynchronous Adapter Clock in 100G Mode

When **Enable asynchronous adapter clocks** is enabled,  $i\_clk\_rx$  and  $i\_clk\_tx$  can be asynchronous from each other and from  $o\_clk\_pll\_div64$  clock as long as the clocks are fast enough to ensure all data is processed by a channel.

#### Figure 54. Clock Connection in Asynchronous FIFO Operation



Below table summarizes minimum and maximum frequencies required for  $i\_clk\_rx$  and  $i\_clk\_tx$  during the Asynchronous mode.

# Table 60.Supported Clock Rates for MAC Client Asynchronous FIFO Operation in 100G<br/>Mode

The below rates assume 1 byte IPG and disabled preamble-pass-through.

| Rate | Clock Rate   |              |                   |                   |
|------|--------------|--------------|-------------------|-------------------|
|      | Min i_clk_tx | Max i_clk_tx | Min i_clk_rx      | Max i_clk_rx      |
| 100G | 340 MHz      | 420 MHz      | 340 MHz + 200 ppm | 420 MHz + 200 ppm |





# 2.11.17.3. Clock Network Use Cases

These use cases provide guidance about how you can connect various clocks through the GUI for different use cases.

# 2.11.17.3.1. Single 25G Ethernet Channel (with FEC)

#### Table 61. **Use Case Configuration**

| Data Rate     | Core Interface |
|---------------|----------------|
| 25.78125 Gbps | 64 bits        |

Connect o\_clk\_pll\_div64 (402.83MHz) to the i\_sl\_clk\_tx and i\_sl\_clk\_rx. If you use any other source for i sl clk tx or i sl clk rx, make sure that i\_sl\_clk\_tx and i\_sl\_clk\_rx have 0 PPM difference with respect to o\_clk\_pll\_div64.

#### Figure 55. Ethernet 25G x 1

RX FEC is also clocked by the TX PMA generated clock.



# 2.11.17.3.2. Single 10G Ethernet Channel (without FEC)

#### **Use Case Configuration** Table 62.

| Data Rate    | Core Interface |
|--------------|----------------|
| 10.3125 Gbps | 64 bits        |

Connect o\_clk\_pll\_div64 (161.13MHz) to the i\_sl\_clk\_tx and i\_sl\_clk\_rx. If you use any other source for i\_sl\_clk\_tx or i\_sl\_clk\_rx, make sure i\_sl\_clk\_tx and i\_sl\_clk\_rx have 0 PPM difference with respect to o\_clk\_pll\_div64.





#### Figure 56. Ethernet 10G x 1



#### 2.11.17.3.3. Four 25G Ethernet Channels (with FEC) within a Single FEC Block

#### Table 63.Use Case Configuration

| Data Rate per Channel | Number of Channels | Core Interface |
|-----------------------|--------------------|----------------|
| 25.78125 Gbps         | 4                  | 64 bits        |

#### **Master-Slave Configuration: Option 1**

All four channels use a common FEC block but FEC will use only one clock from the 4 available channels. The channel that provides the FEC clock is considered as a master. The other 3 channels use that same clock for clocking their TX and RX data path, and are considered as slave channels. Any interruption on master channel PMA, a PMA reset, for example, impacts the slave channels. This creates a dependency between the master and the slave channels.

Connect o\_clk\_pll\_div64 (402.83MHz) to the i\_sl\_clk\_tx and i\_sl\_clk\_rx. If you use any other source for i\_sl\_clk\_tx or i\_sl\_clk\_rx, make sure i\_sl\_clk\_tx and i\_sl\_clk\_rx have 0 PPM difference with the o\_clk\_pll\_div64.





# Figure 57.Ethernet 25G x 4 (FEC On) Master-Slave Configuration Option 1

RX FEC is also clocked by the TX PMA generated clock.



# Master-Slave Configuration: Option 2 - External AIB Clocking Scheme

In this configuration, you can select to import the TX and RX datapath clocks and EMIB clock from an external source outside of the targeted transceiver channels. Enable this by selecting the checkbox **Enable External AIB Clocking** from IP Parameter Editor. An extra input port is exposed in the transceiver channel core interface to drive the individual EMIB clock for each 25 Gbps channel. The FEC clock is still provided by the Master channel. The Stratix 10 E-Tile Transceiver Native PHY Intel





FPGA IP in PLL mode acts as the external source to provide clock to transceiver channel. Before resetting the transceiver channel, you must read the o\_tx\_pll\_locked output from the PLL channel:

- Wait until o\_tx\_pll\_locked output from the PLL channel is asserted before deasserting the transceiver channel reset at power-up.
- If o\_tx\_pll\_locked from the PLL channel is deasserted at any time, hold the respective transceiver channel in reset until o\_tx\_pll\_locked is reasserted.

The PLL Channel and the Ethernet channel should have the same reference clock source.

The following figure shows one master 25 Gbps channel providing the datapath clock to other three slave 25 Gbps channels. This method removes the dependency of a PMA reset between the Master and Slave channels.





#### Ethernet 25G x 4 (FEC On) Master-Slave Configuration: External AIB Clocking Figure 58. pll\_clkout2 = 402.83 MHz Native PHY pll\_clkout1 = 805.66 MHz (PLI Mode) E-tile Hard IP for Ethernet Core Interface tx\_coreclkin2 = 805.66 MH E-tile Hard IP for Ethernet 25.78125 Gbps tx clkout = 402.83 MHz /2 tx coreclkin = 402.83 MH; ₩ E-Tile eHIP E-Tile FIFO TX PMA XCVR IF FEC CH3 Slave XCVR IF E-Tile eHIP **RX PMA** E-Tile FIFO rx\_coreclkin ▶/2 rx clkout = 402.83 MHz tx coreclkin2 = 805.66 MH E-tile Hard IP for Ethernet 25.78125 Gbps tx\_clkout = 402.83 MHz /2tx coreclkin = 402.83 MHz TX PMA E-Tile eHIP FEC **F-Tile FIF** CH2 Slave XCVR IF E-Tile eHI **RX PMA** FEC E-Tile FIFO rx\_coreclkin ▶/2 rx clkout = 402.83 MHz tx coreclkin2 = 805.66 MH E-tile Hard IP for Ethernet 25.78125 Gbps tx\_clkout = 402.83 MHz ▶ 72 tx coreclkin = 402.83 MHz ₩ ТХ РМА XCVR IF FEC E-Tile eHIP E-Tile FIFO CH1 Slave **RX PMA** XCVR F-Tile eHIP E-Tile FIFO rx\_coreclkin ▶/2 rx clkout = 402.83 MHz tx\_coreclkin2 = 805.66 MH E-tile Hard IP for Ethernet 25.78125 Gbp tx\_clkout = 402.83 MHz ▶ /2 tx\_coreclkin = 402.83 MHz /2 1 🛨 TX PMA XCVR E-Tile eHI E-Tile FIFO CHO Master XCVR E-Tile eHIP RX PMA FFC E-Tile FIFO rx\_coreclkin ▶/2 rx\_clkout = 402.83 MHz Legend: TX PMA generated parallel clock (line rate / PMA interface width) TX PMA generated parallel clock div by 2 RX PMA generated parallel clock div by 2 RX PMA generated parallel clock (line rate / PMA interface width) High frequency External AIB clock High frequency External AIB clock div by 2 Low frequency External AIB clock

# Master-Slave Configuration: Option 3 - Dynamic Reconfiguration

In this configuration, you can dynamically reconfigure the Master Channel 0 from 25G to 10G. This configuration uses four 25G Ethernet channels with RS-FEC enabled at power on. Channel 0 is considered the Master channel and channel 1  $\sim$  channel 3 are considered Slave channels. After power on, the 25G Master Channel with RS-FEC enable reconfigures from 25.78125 Gbps to 10.3125 Gbps.





Below figure is an example of possible dynamic reconfiguration on Master channel. You can reconfigure the master channel to any mode without bringing down the slave channel functionality with the exception of the direct PMA.





For more information on the dynamic reconfiguration examples, refer to the *Dynamic Reconfiguration Design Example User Guide*.



# **Related Information**

- E-Tile Hard IP Intel Stratix 10 Design Example User Guide ٠ Information about the Dynamic Reconfiguration.
- E-Tile Hard IP Intel Agilex Design Example User Guide • Information about the Dynamic Reconfiguration.

# 2.11.17.3.4. Ethernet 25G x 4 (FEC Off)

This use case does not include FEC; therefore, there is no need for clock sharing between the four 25G Ethernet channels. Connect o\_clk\_pll\_div64 (402.83 MHz) to i sl clk tx and i sl clk rx. Due to the timing constraint, i sl clk tx and i\_sl\_clk\_rx channels can only be assigned to channel 0, channel 1, or channel 2.

Note: Due to the clock assignment dependency, if clock arrives from other than a master channel, the clock's appropriate channel impacts all other channels.

> If you use any other source for i\_sl\_clk\_tx or i\_sl\_clk\_rx, make sure i\_sl\_clk\_tx and i\_sl\_clk\_rx have 0 PPM difference with the o\_clk\_pll\_div64.







# Figure 60. Ethernet 25G x 4 (FEC Off)

#### 2.11.17.3.5. 10/25G Ethernet Channel (with PTP and without External AIB Clocking)

TX PMA generated parallel clock div by 2
 RX PMA generated parallel clock div by 2
 RX PMA generated parallel clock (line rate / PMA interface width)

#### Table 64.Use Case Configuration

| Number of Ethernet<br>Channels | Data Rate     | Core Interface | External AIB Clocking |
|--------------------------------|---------------|----------------|-----------------------|
| 2                              | 25.78125 Gbps | 64 bits        | Disabled              |





If PTP is enabled, a PTP channel and its source clock becomes the master channel regardless of FEC configuration.

Connect o\_clk\_pll\_div64[number of channel] (402.83MHz) to the <code>i\_sl\_clk\_tx</code> and <code>i\_sl\_clk\_rx</code> of each Ethernet channel based on the following guidelines:

| Number of Channels of 10G/25G | Clock Connection Guideline                                           |
|-------------------------------|----------------------------------------------------------------------|
| Single channel                | Connect o_clk_pll_div64[1] to i_sl_clk_tx and i_sl_clk_rx.           |
| 2 channels                    | Connect o_clk_pll_div64[2] to i_sl_clk_tx[1:0] and i_sl_clk_rx[1:0]. |
| 3 channels                    | Connect o_clk_pll_div64[3] to i_sl_clk_tx[2:0] and i_sl_clk_rx[2:0]. |
| 4 channels                    | Connect o_clk_pll_div64[4] to i_sl_clk_tx[3:0] and i_sl_clk_rx[3:0]. |





#### Figure 61. Ethernet 10/25G with PTP



Legend:

TX/RX PMA generated parallel clock (line rate / PMA interface width)

TVRR May generated parallel clock dir by 2
 (1) Connect the o\_dk\_pll\_div64 and i\_sl\_dk\_rx based on guidelines in the Clock Connection Guidelines for 10/256E with PTP table.
 (2) Connect the o\_dk\_pll\_div64 and i\_sl\_dk\_rx based on guidelines in the Clock Connection Guidelines for 10/256E with PTP table.

# 2.11.17.3.6. 25G Ethernet Channel (with PTP and External AIB Clocking)

#### Table 65. **Use Case Configuration**

| Number of Ethernet<br>Channels | Data Rate     | Core Interface | External AIB Clocking |
|--------------------------------|---------------|----------------|-----------------------|
| 2                              | 25.78125 Gbps | 64 bits        | Enabled               |





In this configuration, resetting a master channel always impacts all channels due to the AIB. When external AIB clock is enabled, any slave channel can reset without impacting other channels.

When PTP is enabled, the external AIB clock always arrives from the PTP channel.

Note: When PTP is disabled, the external AIB clock is driven by a PLL clock selected from any transceiver channel.

> Connect o\_clk\_pll\_div64(number of channel] (402.83MHz) and o\_clk\_pll\_div66[number of channel] (805.66 MHz) to the i\_aib\_clk and  $i_aib_2x_clk$  respectively based on the following guidelines:

#### Table 66. Clock Connection Guidelines for 25GE with PTP with External AIB Clocking

| Number of Channels of 10G/25G | Clock Connection Guideline                                                                                         |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------|
| Single channel                | <ul> <li>Connect o_clk_pll_div64[1] to i_aib_clk.</li> <li>Connect o_clk_pll_div66[1] to i_aib_2x_clk.</li> </ul>  |
| 2 channels                    | <ul> <li>Connect o_clk_pll_div64[2] to i_aib_clk.</li> <li>Connect o_clk_pll_div66[2] to i_aib_2x_clk.</li> </ul>  |
| 3 channels                    | <ul> <li>Connect o_clk_pll_div64[3] to i_aib_clk.</li> <li>Connect o_clk_pll_div66[31] to i_aib_2x_clk.</li> </ul> |
| 4 channels                    | <ul> <li>Connect o_clk_pll_div64[4] to i_aib_clk.</li> <li>Connect o_clk_pll_div66[4] to i_aib_2x_clk.</li> </ul>  |







#### **Ethernet 25G with PTP and External AIB Clocking** Figure 62.

TX/RX PMA generated parallel clock (line rate / PMA interface width)
 TX/RX PMA generated parallel clock dir by 2
 (1) concert che o\_{kL} pl. divs6at in b\_X clk based on guidelines in the Clock Connection Guidelines for 25GE with PTP with External AIB Clocking table.
 (2) connect che o\_{clk} pl. divs64 and i\_aib\_clk based on guidelines in the Clock Connection Guidelines for 25GE with PTP with External AIB Clocking table.

# 2.11.17.3.7. 100G Ethernet with Aggregated FEC

This use case is implemented in the case of multi-lane protocols like 100GbE, for example. This uses four transceiver lanes of 25 Gbps each, where all four lanes use the same FEC block. There is an inherent dependency between channels in this configuration as described in Master-Slave Configuration: Option 1 section. However, for applications like 100 GbE, dependency is acceptable and sometimes required.





#### EMIB E-Tile Hard IP for Ethernet 25.78125 Gbps o clk pll div64 /2 402.83MHz i dk tx XCVR Interfac E-Tile eHIP TX PMA FEC E-Tile FIFO CH3 XCVR E-Tile eHIP **RX PMA** E-Tile FIFO i\_dk\_rx ▶ /2 → o\_clk\_rec\_div64 402.83 MHz EMIB E-Tile Hard IP for Ethernet o clk pll div64 25.78125 Gbps ▶/2 402.83 MHz i\_clk\_tx TX PMA XCVR Interfac E-Tile eHIP E-Tile FIFO CH2 E-Tile eHIP **RX PMA** XCVR Interfa E-Tile FIFO i dk rx ▶/2 o\_clk\_rec\_div64 402.83 MHz T EMIB **E-Tile Hard IP for Ethernet** o clk pll div64 25.78125 Gbps ▶/2 402.83 MHz i\_clk\_tx E-Tile eHIP TX PMA XCVR Interfac E-Tile FIFO CH1 T E-Tile eHIP XCVR nterfa **RX PMA** E-Tile FIFO rx coreclkin o\_clk\_rec\_div64 ▶/2 402 83 MHz ÷ EMIB **E-Tile Hard IP for Ethernet** o clk pll div64 25.78125 Gbps ▶/2 402 83 MHz 1/2 i\_dk\_tx XCVR Interfac TX PMA E-Tile eHIP E-Tile FIFO CHO Maste E-Tile eHIP **RX PMA** XCVR nterface E-Tile FIFO i\_dk\_rx ▶/2 o clk rec div64 402 83 MHz Legend: TX PMA generated parallel clock (line rate / PMA interface width) TX PMA generated parallel clock div by 2 RX PMA generated parallel clock div by 2 RX PMA generated parallel clock (line rate / PMA interface width)

#### **100G Ethernet with Aggregated FEC** Figure 63.

# 2.12. Reconfiguration and Status Register Descriptions

You access the Ethernet registers for the E-Tile Hard IP for Ethernet Intel FPGA IP using the Avalon memory-mapped Ethernet reconfiguration interface on each channel. The TX and RX RS-FEC registers are accessible through the RS-FEC reconfiguration interface.





Write operations to a read-only register field have no effect. Read operations that address a Reserved register return an unspecified result. Write operations to Reserved registers have no effect. Accesses to registers that do not exist in your IP core variation, or to register bits that are not defined in your IP core variation, have an unspecified result. You should consider these registers and register bits Reserved. Although you can only access registers in 32-bit read and write operations, you should not attempt to write or ascribe meaning to values in undefined register bits.

These registers use 32-bit addresses; they are not byte addressable.

#### Table 67. Ethernet Reconfiguration Interface Register Base Addresses

| Word Offset | Register Type                                    |
|-------------|--------------------------------------------------|
| 0x0B0-0x0E8 | Auto Negotiation and Link Training registers     |
| 0x300-0x3FF | PHY registers                                    |
| 0x310-0x310 | Reset Controller registers                       |
| 0x400-0x4FF | TX MAC registers                                 |
| 0x500-0x5FF | RX MAC registers                                 |
| 0x600-0x7FF | Pause and Priority- Based Flow Control registers |
| 0x800-0x8FF | TX Statistics Counter registers                  |
| 0x900-0x9FF | RX Statistics Counter registers                  |
| 0xA00-0xAFF | TX 1588 PTP registers                            |
| 0xB00-0xBFF | RX 1588 PTP registers                            |

# Table 68. RS-FEC Reconfiguration Interface Register Base Addresses

| Word Offset | Register Type              |
|-------------|----------------------------|
| 0x000-0x2FF | TX and RX RS-FEC registers |

#### Table 69. Transceiver Reconfiguration Interface Register Base Addresses

PTP transceiver channel register is accessed through the PTP reconfiguration interface. Data transceiver channel register is accessed through the Transceiver reconfiguration interface.

| Word Offset     | Register Type            |
|-----------------|--------------------------|
| 0x40000-0x40144 | PMA Capability registers |
| 0x000-0x207     | PMA AVMM registers       |

*Note:* Do not attempt to access any register address that is Reserved or undefined. Accesses to registers that do not exist in your IP core variation have unspecified results.

# 2.12.1. Auto Negotiation and Link Training Registers

# 2.12.1.1. ANLT Sequencer Config

Offset: 0xB0





# **ANLT Sequencer Config Fields**

| Bit   | Name                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       | Access | Reset |
|-------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 31    | kr_pause              | <ul> <li>Pauses ANLT Function</li> <li>1: Pauses ANLT function when kr_paused bit is high.</li> <li>0: Normal ANLT function</li> <li>Set this bit before accessing PMA registers via the transceiver reconfiguration interface to ensure no conflict with the ANLT function.</li> </ul>                                                                                                                                                           | RW     | 0x0   |
| 29:26 | anlt_seq_cfg_rxinv    | <ul> <li>RX Polarity Inversion for Lane 0 to Lane 3</li> <li>Sets RX Polarity Inversion on lanes 3:0 (for 100G NRZ), lanes 2 and 0 (for 100G PAM4) or current lane (for 25/10G).</li> <li>[29] = Inverts RX PMA polarity on lane 3</li> <li>[28] = Inverts RX PMA polarity on lane 2</li> <li>[27] = Inverts RX PMA polarity on lane 1</li> <li>[26] = Inverts RX PMA polarity on lane 0</li> </ul>                                               | RW     | 0x0   |
| 25:22 | anlt_seq_cfg_txinv    | <ul> <li>TX Polarity Inversion for Lane 0 to Lane 3</li> <li>Sets TX Polarity Inversion on lanes 3:0 (for 100G NRZ), lanes 2 and 0 (for 100G PAM4) or current lane (for 25/10G).</li> <li>[25] = Inverts TX PMA polarity on lane 3</li> <li>[24] = Inverts TX PMA polarity on lane 2</li> <li>[23] = Inverts TX PMA polarity on lane 1</li> <li>[22] = Inverts TX PMA polarity on lane 0</li> <li>Setting takes effect upon KR restart</li> </ul> | RW     | 0x0   |
| 21    | rsfec_request         | Request RS-FEC mode during AN         1: Request RS-FEC mode during AN         0: Do not request RS-FEC during AN         • Defaults to 1 if parameter REQUEST_RSFEC is set to 1         • This feature is new in E-Tile                                                                                                                                                                                                                          | RW     | 0x0   |
| 20    | rsfec_capable         | Enables RS-FEC Negotiation<br>1: Enable RS-FEC negotiation<br>0: Do not negotiate for RS-FEC<br>Defaults to 1 if parameter ENABLE_RSFEC is set to 1                                                                                                                                                                                                                                                                                               | RW     | 0x0   |
| 19:16 | anlt_seq_cfg_ilpbk    | <pre>Internal Loopback for Lane 0 to Lane 3 Sets internal loopback mode on lanes 3:0 (for 100G NRZ), lanes 0 and 2 (for 100G PAM4) or current lane (for 25/10G). • [16] = Internal loopback for lane 0 • [17] = Internal loopback for lane 1 • [18] = Internal loopback for lane 2 • [19] = Internal loopback for lane 3 Loopback takes effect upon KR restart.</pre>                                                                             | RW     | 0x0   |
| 14    | skip_lt_on_an_timeout | <ul> <li>Skip Link Training on AutoNegotiation Timeout</li> <li>1: If AN times out skip LT before attempting data mode, and use the previous LT settings</li> <li>0: Use the normal ANLT sequence, even if link_fail_if_hiber = 0</li> <li>This option is provided to speed up re-lock times when the link is known not to be resetting due to problems with link integrity</li> </ul>                                                            | RW     | 0x0   |
| 13    | link_fail_if_hiber    | Link Fail if HiBER                                                                                                                                                                                                                                                                                                                                                                                                                                | RW     | 0x1   |
|       | 1                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1      | 1     |





#### 2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09

| Bit | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Access | Reset |
|-----|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |                     | 1: Trigger a link failure if a HiBER condition is detected in the PCS during data mode (default)<br>0: Ignore HiBER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |        |       |
| 12  | lt_failure_response | Link Training Failure Response<br>1: Upon LT failure, PHY will go to data mode<br>0: Upon LT failure, PHY will restart AN, or if AN is disabled,<br>skip AN and restart LT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW     | 0x0   |
| 7:4 | seq_force_mode      | <ul> <li>Force the sequencer into a specific protocol, ignoring autonegotiation result</li> <li>[6:4] = 3'b000: None</li> <li>[6:4] = 3'b001: 25G-R1</li> <li>[6:4] = 3'b010: Reserved</li> <li>[6:4] = 3'b101: 100G-R4</li> <li>[6:4] = 3'b101: 10G-R1</li> <li>[6:4] = 3'b110: Reserved</li> <li>[6:4] = 3'b111: 100G-P2</li> <li>[7] = 1'b11: Force RS-FEC on if capable (never for 10G, always for 100G-P2)</li> <li>Forces the ANLT Sequencer into a specific protocol, ignoring the AN result</li> <li>ANLT will still be cycled if enabled; configure AN and LT using their respective CFG registers</li> <li>Note: Not all protocols are available in all configurations. You must enable the protocols when generating the IP to be functional at run-time.</li> </ul> | RW     | 0x0   |
| 2   | disable_lf_timer    | <ul> <li>Disable Link Fail Inhibit Timer</li> <li>1: Disable the link fail inhibit timer</li> <li>0: If PCS link fails, then AN will restart</li> <li>The most common reason to disable the link fail inhibit timer is to characterize the link's behavior with link training</li> <li>Turning off the link fail inhibit timer prevents link training from cycling, allowing each failure to be examined individually</li> <li>Disabling the LFI Timer also disable transitioning from data mode to auto-negotiation phase when the link status goes down, even if the LFI timer would have expired. Effectively the system stays in Data Mode state until reset or user intervention.</li> </ul>                                                                               | RW     | 0x0   |
| 1   | disable_an_timer    | <ul> <li>Disable Auto-Negotiation Timer</li> <li>Enable this bit to allow operation with link partners that do not support auto-negotiation.</li> <li>1: AN will wait for valid partner without timing out (default). Auto-negotiation timeout is set to approximately 1 second.</li> <li>0: If AN fails, the Sequencer will try a different protocol</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                | RW     | 0x1   |
| 0   | reset_seq           | Reset ANLT Sequencer<br>1: Reset only the ANLT Sequencer. Initiates a PCS<br>reconfiguration and/or ANLT reset<br>0: Normal operation<br>This bit is self-cleared when the ANLT sequence restarts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW     | 0x0   |

# 2.12.1.2. ANLT Sequencer Status

Offset: 0xB1





| Bit  | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Access | Reset |
|------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 31   | kr_paused         | Indicates ANLT Function is paused due to kr_pause<br>bit<br>1: ANLT Function Paused<br>0: Normal ANLT Function                                                                                                                                                                                                                                                                                                                                                                                                          |        |       |
| 18   | rsfec_ability     | Indicates local RS-FEC support<br>1: RS-FEC supported<br>0: RS-FEC not supported<br>Defaults to 1 if parameter ENABLE_RSFEC is set to 1                                                                                                                                                                                                                                                                                                                                                                                 | RO     | 0x0   |
| 15:8 | seq_reconfig_mode | Sequencer mode for PCS reconfiguration         [8] = AN mode         [9] = LT mode (Clause 93)         [10] = 10G data mode         [11] = 25G data mode         [12] = Reserved         [13] = 100G-R4 data mode         [14] = Reserved         [15] = 100G-P2 data mode         All other settings reserved.         • The sequencer modifies the datapath as required to move through the stages of ANLT         • This status register lets you know which step is in progress, and how the datapath is configured | RO     | 0x0   |
| 2    | seq_lt_timeout    | Sequencer Link Training Timeout<br>1: Sequencer had LT Timeout<br>0: No timeout occurred<br>This status bit is sticky, and stays high until the next time<br>LT restarts.                                                                                                                                                                                                                                                                                                                                               | RO     | 0x0   |
| 1    | seq_an_timeout    | Sequencer AutoNegotiation Timeout<br>1: Sequencer had AN Timeout<br>0: No timeout occurred<br>This status bit is sticky, and stays high until the next time<br>AN restarts.                                                                                                                                                                                                                                                                                                                                             | RO     | 0x0   |
| 0    | seq_link_ready    | Sequencer Link Ready<br>1: Link is ready for data mode<br>0: Link not ready                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO     | 0x0   |

# **ANLT Sequencer Status Fields**

# 2.12.1.3. Auto Negotiation Config Register 1

# Offset: 0xC0

# **Auto Negotiation Config Register 1 Fields**

| Bit   | Name                                                  | Description                                                                                                                                                                                | Access | Reset  |  |
|-------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|--|
| 31:16 | consortium_oui                                        | Consortium Organizationally Unique Identifier<br>(OUI) (lower 16 bits)<br>Sets the lower bits of the OUI (as defined in IEEE 802.3<br>Annex 73A) used in sending and receiving Next Pages. | RW     | 0x737D |  |
| 11    | ignore_consortium_nex<br>t_page_tech_ability_c<br>ode | Ignore Consortium NextPage Tech Ability Code                                                                                                                                               | RW     | 0x0    |  |
|       | continued                                             |                                                                                                                                                                                            |        |        |  |



2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



|    | Name                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Access | Reset |
|----|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|    |                                          | <ol> <li>1: AN function accepts any unformatted Next Page after a<br/>formatted Next Page tagged with the proper OUI for<br/>resolving Consortium AN modes</li> <li>0: The AN function only accepts an unformatted Next<br/>Page with the code 0x003 in bits D8:D0</li> </ol>                                                                                                                                                                                                                                                                                            |        |       |
| 10 | enable_consortium_nex<br>t_page_override | Enable Consortium Next Page override<br>1: Data sent to the consortium Next Page comes from the<br><i>Consortium Next Page Override</i> Register (0xCD) instead<br>of being set automatically<br>0: Data is filled based on supported IP modes                                                                                                                                                                                                                                                                                                                           | RW     | 0x0   |
| 9  | enable_consortium_nex<br>t_page_receive  | Enable Consortium Next Page receive<br>1: Enable decoding received Consortium Next Pages for<br>purpose of resolving AN<br>0: The AN function ignores the received next pages                                                                                                                                                                                                                                                                                                                                                                                            | RW     | 0x1   |
| 8  | enable_consortium_nex<br>t_page_send     | <b>Enable Consortium Next Page send</b><br>Send Consortium-standard next pages immediately after<br>the base page. If User next pages are enabled,<br>consortium pages is sent after the last user next page.                                                                                                                                                                                                                                                                                                                                                            | RW     | 0x0   |
| 7  | ignore_nonce_field                       | <ul> <li>Ignore Nonce Field</li> <li>1: Ignore the Nonce field during AN</li> <li>0: Normal operation</li> <li>AN will normally fail in loopback due to the Nonce field</li> <li>To use AN with loopback, disable Nonce bit checking using this feature</li> <li>The default value for this bit in synthesis is 0 and in simulation is 1.</li> </ul>                                                                                                                                                                                                                     | RW     | 0x0   |
| 6  | override_an_chan_enab<br>le              | Override AN Master Channel (as set by AN_CHAN)<br>1: Use AN Master channel selection from 0xCC[1:0]<br>0: Use AN Master channel specified via generation<br>parameter                                                                                                                                                                                                                                                                                                                                                                                                    | RW     | 0x0   |
| 5  | override_an_parameter<br>s_enable        | Override AN Parameters<br>1: Use the bits from parameter override CSRs to compose<br>the default base page<br>0: Normal operation                                                                                                                                                                                                                                                                                                                                                                                                                                        | RW     | 0x0   |
| 3  | local_device_remote_f<br>ault            | Force Local device remote fault<br>1: Signal a remote fault using appropriate bit in the AN<br>pages<br>0: Normal operation                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW     | 0x0   |
| 2  | an_next_pages_ctrl                       | <ul> <li>Enable User Controlled AN Next Pages</li> <li>1: User-controlled next pages are enabled. You can send any arbitrary data via the User next page high/low bits (0xC6[31:0]/0xC5[15:0]). The IP pauses on each next page transaction until you set 0xC1[8].</li> <li>0: User-controlled next page control is disabled. The IP generates the null message to send as next pages, and does not pause on next page transactions.</li> <li>Set this bit before AN begins, and clear this bit once your next page activity completes to allow AN to finish.</li> </ul> | RW     | 0x0   |
| 1  | an_base_pages_ctrl                       | Enable User Controlled AN Base Pages<br>To ensure proper HCD resolution when changing the Tech<br>Ability and FEC fields, set the equivalent bits in the<br>parameter override CSR through                                                                                                                                                                                                                                                                                                                                                                               | RW     | 0x0   |





#### 2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09

| Bit | Name      | Description                                                                                                          | Access | Reset |
|-----|-----------|----------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |           | 1: User controlled base pages are enabled; the User Base page CSRs control the base page used for AN                 |        |       |
|     |           | 0: The AN logic will automatically generate base pages based on the Ethernet Core Variant and its parameters         |        |       |
|     |           | <ul> <li>Enable this feature if you need to control the content<br/>of the AN Base page</li> </ul>                   |        |       |
|     |           | <ul> <li>Leave this feature disabled if you want the core to<br/>perform default negotiation for its type</li> </ul> |        |       |
| 0   | enable_an | Enable AutoNegotiation                                                                                               | RW     | 0x1   |
|     |           | 1: Enable AutoNegotiation (default)                                                                                  |        |       |
|     |           | 0: Disable AutoNegotiation                                                                                           |        |       |
|     |           | • Equivalent to state variable mr_autoneg_enable in IEEE 802.3 CL73.10.1                                             |        |       |

# 2.12.1.4. Auto Negotiation Config Register 2

#### Offset: 0xC1

# **Auto Negotiation Config Register 2 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit   | Name                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Access | Reset |
|-------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 23:16 | consortium_oui_upper | Consortium Organizationally Unique Identifier (OUI)<br>(upper 8b)<br>Sets the upper bits of the OUI (as defined in IEEE 802.3<br>Annex 73A) used in sending and receiving Next Pages.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW     | 0x6A  |
| 8     | an_next_page         | AN Next Page<br>1: New user Next Page data to send is loaded in 0xC5-0xC6<br>and finished reading LP next page data from 0xC9-0xCA.<br>Only available if 0xC0[2] is set to 1.<br>If there are no more Next Pages to send, but you still<br>wishes to read LP Next Pages, you must set 0xC5-0xC6 to<br>the IEEE null message as defined in 73A.1 (bit D0=1, all<br>other bits=0) before setting this bit.<br>To determine if the LP has more Next Pages to send, view<br>the NP bit (D15) of the LP base page or previous LP Next<br>Page.<br>After the IP has sent the user Next Page data and loaded<br>the new LP Next Page data to 0xC9-0xCA (if available), this<br>bit will self-clear (0 = LP next page data ready to read) | RW     | 0x0   |
| 0     | reset_an             | Reset all AN state machines<br>1: Reset all the AN state machines<br>0: Normal operation<br>Maps to state variable mr_main_reset in IEEE 802.3 CL<br>73.10.1.<br>This bit is self-cleared when auto-negotiation restarts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RW     | 0x0   |

# 2.12.1.5. Auto Negotiation Status Register

Offset: 0xC2





# **Auto Negotiation Status Register Fields**

| Bit   | Name                                | Description                                                                                                                                                                                                                                                                                                                                                                        | Access | Reset |
|-------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 30    | rs_fec_negotiated                   | <b>RS-FEC Negotiated</b><br>Indicates AN negotiated RS-FEC operation.<br>1: Link uses RS-FEC<br>0: Link doesn't use RS-FEC                                                                                                                                                                                                                                                         | RO     | 0x0   |
| 27:24 | consortium_negotiated<br>_port_type | Consortium negotiated Port Type<br>Indicates the negotiated HCD port type for Consortium<br>modes.<br>[24] = 25GBASE-KR1<br>[25] = 25GBASE-CR1<br>[26] = 50GBASE-KR2<br>[27] = 50GBASE-CR2                                                                                                                                                                                         | RO     | 0x0   |
| 23:12 | ieee_negotiated_port_<br>type       | <b>IEEE Negotiated Port Type</b><br>Indicates the negotiated HCD port type for IEEE modes.<br>[12] = 1000BASE-KX<br>[13] = 10GBASE-KX4<br>[14] = 10GBASE-KR4<br>[15] = 40GBASE-KR4<br>[16] = 40GBASE-CR4<br>[17] = 100GBASE-CR4<br>[17] = 100GBASE-CR4<br>[19] =100GBASE-KR4<br>[20] = 100GBASE-KR4<br>[21] = 25GBASE-KR-S/CR-S<br>[22] = 25GBASE-KR/CR<br>[23] = 100GBASE-KR2/CR2 | RO     | 0x0   |
| 11    | negotiation_failure                 | AN complete, but unable to resolve PHY<br>1: AN completed, but was unable to find a Highest Common<br>Denominator rate, or a common FEC<br>0: Normal operation                                                                                                                                                                                                                     | RO     | 0x0   |
| 10    | consortium_next_page_<br>received   | <b>Consortium Next Page received</b><br>1: Consortium Next Page identified from a link partner<br>0: No Consortium Next page found                                                                                                                                                                                                                                                 | RO     | 0x0   |
| 7     | an_lp_ability                       | Link Partner Auto Negotiation Ability<br>1: Link Partner is able to perform AN<br>0: Link Partner is not able to perform AN                                                                                                                                                                                                                                                        | RO     | 0x0   |
| 6     | an_status                           | Auto Negotiation Status<br>1: Link is up<br>0: Link is down                                                                                                                                                                                                                                                                                                                        | RO     | 0x0   |
| 5     | an_ability                          | <ul> <li>PHY Auto Negotiation Ability</li> <li>1: PHY is able to perform AN</li> <li>0: PHY is not able to perform AN</li> <li>This bit is tied high when AN module is included in the Ethernet core, low otherwise</li> </ul>                                                                                                                                                     | RO     | 0x0   |
| 3     | an_adv_remote_fault                 | Auto Negotiation ADV Remote Fault<br>1: Fault information sent to link partner                                                                                                                                                                                                                                                                                                     | RO     | 0x0   |
|       |                                     |                                                                                                                                                                                                                                                                                                                                                                                    | contin | ued   |



| Bit | Name             | Description                                                                                                                                                                                                    | Access | Reset |
|-----|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |                  | <ul> <li>0: Normal operation</li> <li>Remote Fault is encoded in bit D13 of the Base link codeword</li> <li>See IEEE 802.3 CL 73.6.7 for more information</li> <li>See mr_adv_ability in CL 73.10.1</li> </ul> |        |       |
| 2   | an_complete      | <ul> <li>Auto Negotiation Complete</li> <li>1: AN Complete</li> <li>0: AN in progress</li> <li>Corresponds to state variable mr_autoneg_complete<br/>in CL 73.10.1</li> </ul>                                  | RO     | 0x0   |
| 1   | an_page_received | <ul> <li>AN Page Received</li> <li>1: A page has been received</li> <li>0: No page received</li> <li>Corresponds to state variable mr_page_rx in IEEE 802.3 Cl 73.10.1</li> </ul>                              | RO     | 0x0   |

# 2.12.1.6. Auto Negotiation Config Register 3

# Offset: 0xC3

# **Auto Negotiation Config Register 3 Fields**

| 30:28override_an_pauseAN_PAUSE Override Value<br>When Override AN Parameters is enabled<br>(override_an_parameters_enable=1), this register<br>controls the value of AN_PAUSE used in the AN Base page<br>[0]: Pause Ability<br>[1]: Asymmetric Direction<br>[2]: ReservedRW0x027:24override_an_fecAN_FEC Override Value<br>When Override AN Parameters is enabled<br>(override_an_parameters_enable=1), this register<br>controls the value of AN_FEC used in the AN Base page<br>[24] = 10G BASE-R RS-FEC Capability<br>[25] = 10G BASE-R RS-FEC Capability<br>[25] = 10G BASE-R RS-FEC Request<br>[26] = 25G IEEE RS-FEC Request<br>[27] = 25G IEEE BASE-R RS-FEC RequestRW0x023:16override_an_techAN_TECH Override Value, bits [7:0]<br>When Override AN Parameters_enable=1), this register<br>controls the value of AN_TECH used in the AN Base page<br>[16] = Reserved<br>[27] = 25G IEEE BASE-R RS-FEC RequestRW0x023:16override_an_techAN_TECH Override Value, bits [7:0]<br>When Override AN Parameters is enabled<br>(override_an_parameters_enable=1), this register<br>controls the value of AN_TECH used in the AN Base page<br>[16] = Reserved<br>[17] = 10GBASE-KX4 (XAUI)<br>[18] = 10GBASE-KX4 (XAUI)<br>[18] = 10GBASE-KX4<br>[20] = Reserved<br>[21] = Reserved<br>[22] = 100GBASE-KR4RW0x015:0user_base_page_lowUser Controlled AN Base page (lower bits)RW0x0 | Bit   | Name               | Description                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 23:16       override_an_tech       AN_TECH Override AN Parameters is enabled<br>(override_an_parameters_enable=1), this register<br>controls the value of AN_FEC used in the AN Base page<br>[24] = 10G BASE-R RS-FEC Capability<br>[25] = 10G BASE-R RS-FEC Request<br>[26] = 25G IEEE RS-FEC Request<br>[27] = 25G IEEE BASE-R RS-FEC Request         23:16       override_an_tech       AN_TECH Override Value, bits [7:0]<br>When Override AN Parameters is enabled<br>(override_an_parameters_enable=1), this register<br>controls the value of AN_TECH used in the AN Base page<br>[16] = Reserved<br>[17] = 10GBASE-KX4 (XAUI)<br>[18] = 10GBASE-KX4 (XAUI)<br>[18] = 10GBASE-KR<br>[19] = Reserved<br>[20] = Reserved<br>[21] = Reserved<br>[22] = 100GBASE-KR4<br>[23] = 100GBASE-KR4       RW       0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 30:28 | override_an_pause  | When Override AN Parameters is enabled<br>(override_an_parameters_enable=1), this register<br>controls the value of AN_PAUSE used in the AN Base page<br>[0]: Pause Ability<br>[1]: Asymmetric Direction                                                                                                                      | RW     | 0x0   |
| When Override AN Parameters is enabled<br>(override_an_parameters_enable=1), this register<br>controls the value of AN_TECH used in the AN Base page<br>[16] = Reserved<br>[17] = 10GBASE-KX4 (XAUI)<br>[18] = 10GBASE-KR<br>[19] = Reserved<br>[20] = Reserved<br>[21] = Reserved<br>[22] = 100GBASE-KP4<br>[23] = 100GBASE-KR4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 27:24 | override_an_fec    | When Override AN Parameters is enabled<br>(override_an_parameters_enable=1), this register<br>controls the value of AN_FEC used in the AN Base page<br>[24] = 10G BASE-R RS-FEC Capability<br>[25] = 10G BASE-R RS-FEC Request<br>[26] = 25G IEEE RS-FEC Request                                                              | RW     | 0x0   |
| 15:0 user_base_page_low User Controlled AN Base page (lower bits) RW 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 23:16 | override_an_tech   | <pre>When Override AN Parameters is enabled<br/>(override_an_parameters_enable=1), this register<br/>controls the value of AN_TECH used in the AN Base page<br/>[16] = Reserved<br/>[17] = 10GBASE-KX4 (XAUI)<br/>[18] = 10GBASE-KR<br/>[19] = Reserved<br/>[20] = Reserved<br/>[21] = Reserved<br/>[22] = 100GBASE-KP4</pre> | RW     | 0x0   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 15:0  | user_base_page_low | User Controlled AN Base page (lower bits)                                                                                                                                                                                                                                                                                     | RW     | 0x0   |



2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



| Bit | Name | Description                                                                                                                                                                         | Access | Reset |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | When User Controlled Base pages are turned on<br>(an_base_pages_ctrl=1), this register provides the<br>lower bits of the User base page that is used instead of the<br>default page |        |       |
|     |      | [15] = Next page bit                                                                                                                                                                |        |       |
|     |      | <ul><li>[14] = ACK bit (controlled by State Machine)</li><li>[13] = Remote Fault bit [12:10]: Pause bits</li></ul>                                                                  |        |       |
|     |      | [9:5] = Echoed Nonce (set by SM)                                                                                                                                                    |        |       |
|     |      | [4:0] = Selector                                                                                                                                                                    |        |       |
|     |      | <i>Note:</i> Bit 49 (the PRBS bit of the AN BASE page) is generated by the SM.                                                                                                      |        |       |

# 2.12.1.7. Auto Negotiation Config Register 4

Offset: 0xC4

# **Auto Negotiation Config Register 4 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name                | Description                                                                                                                  | Access | Reset |
|------|---------------------|------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 31:0 | user_base_page_high | User Controlled AN Base page (upper bits)<br>[31:30] = FEC bits<br>[29:5] = Technology Ability bits<br>[4:0] = TX Nonce bits | RW     | 0x0   |

# 2.12.1.8. Auto Negotiation Config Register 5

# Offset: 0xC5

# **Auto Negotiation Config Register Fields**

| Bit   | Name                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                               | Access | Reset |
|-------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 30:16 | override_an_tech_22_8 | AN_TECH Override Value, bits [22:8]<br>When Override AN Parameters is enabled<br>(override_an_parameters_enable=1), this register<br>controls the lower bits of AN_TECH used in the AN Base<br>page.<br>[16] = 100GBASE-CR4<br>[17] = 25GBASE-KR-S/CR-S<br>[18] = 25GBASE-KR/CR<br>[19] = 2.5GBASE-KR/CR<br>[20] = 5GBASE-KR<br>[21] = 50GBASE-KR/CR<br>[22] = 100GBASE-KR2/CR2<br>[23] = 200GBASE-KR4/CR4<br>All other settings Reserved | RW     | 0x0   |
| 15:0  | user_next_page_low    | User Controlled AN Next Page (lower bits)<br>The AN TX state machine uses these bits when user<br>controlled Next Page is set (an_next_pages_ctrl=1).<br>[15]: Next Page bit<br>[14]: ACK bit (controlled by the state machine)<br>[13]: MP bit<br>[12]: ACK2 bits                                                                                                                                                                        | RW     | 0x0   |
|       | •                     | •                                                                                                                                                                                                                                                                                                                                                                                                                                         | contin | ued   |



| Bit | Name | Description                                                                                                                                                                                                                                                                                                  | Access | Reset |
|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <pre>[11]: Toggle bit (controlled by the state machine) [10:0]: Message code field [10:0]/Unformatted code field[10:0] Note: When Consortium Next Page send is enabled         (consortium_next_page_send=1), the         Consortium Next Page sequence is sent after the         last user Next Page.</pre> |        |       |

# 2.12.1.9. Auto Negotiation Config Register 6

Offset: 0xC6

# **Auto Negotiation Config Register 6 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name                | Description                                                                                                                                                                                                                                                                                                 | Access | Reset |
|------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 31:0 | user_next_page_high | User Controlled AN Next page (upper bits)<br>[31:0]: Unformatted Code Field (or [47:16] when MP bit is<br>low)<br>Note: When Consortium Next Page Send is enabled<br>(consortium_next_page_send=1), the first two<br>User Next Pages will be ignored and replaced with<br>the Consortium Next Page sequence | RW     | 0x0   |

# 2.12.1.10. Auto Negotiation Status Register 1

Offset = 0xC7

# **Auto Negotiation Status Register 1 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name             | Description                                                                                                                                                                                                                                            | Access | Reset |  |
|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|--|
| 15:0 | lp_base_page_low | Link Partner Base Page (lower bits)<br>[15] = Link partner next page bit<br>[14] = Link partner ACK<br>[13] = Link partner RF bit<br>[12:10] = Link partner PAUSE bits<br>[9:5] = Link partner Echoed Nonce bits<br>[4:0] = Link partner Selector bits | RO     | 0x0   |  |

# 2.12.1.11. Auto Negotiation Status Register 2

Offset: 0xC8

# Auto Negotiation Status Register 2 Fields

| Bit  | Name              | Description                                                                                                                                        | Access | Reset |
|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 31:0 | lp_base_page_high | Link Partner Base Page (upper bits) [<br>[31:30] = Link partner FEC bits<br>[29:5] = Link partner Technology Ability bits<br>[4:0] = TX Nonce bits | RO     | 0x0   |





# 2.12.1.12. Auto Negotiation Status Register 3

#### Offset: 0xC9

# **Auto Negotiation Status Register 3 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name             | Description                                                                                                                                                                                                                                           | Access | Reset |
|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | lp_next_page_low | Link Partner Next Page (lower bits)<br>[15] = Link partner next page bit<br>[14] = Link partner ACK<br>[13] = Link partner MP bit<br>[12] = Link partner ACK2 bit<br>[11] = Link partner Toggle bit<br>[10:0] = Link partner Message/Unformatted bits | RO     | 0x0   |

# 2.12.1.13. Auto Negotiation Status Register 4

#### Offset: 0xCA

#### an\_status4 Fields

The reset values in this table represents register values after a reset has completed.

| Bit  | Name              | Description                                                                  | Access | Reset |  |
|------|-------------------|------------------------------------------------------------------------------|--------|-------|--|
| 31:0 | lp_next_page_high | Link Partner Next Page (upper bits)<br>[31:0]: Link partner Unformatted bits | RO     | 0x0   |  |

# 2.12.1.14. Auto Negotiation Status Register 5

# Offset: 0xCB

#### **Auto Negotiation Status Register 5 Fields**

| Bit   | Name                       | Description                                                                                                                                                          | Access | Reset |  |  |  |
|-------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|--|--|--|
| 30:28 | an_lp_adv_pause            | Link Partner PAUSE Ability bits<br>[28] = PAUSE as defined in Annex 28B<br>[29] = ASM_DIR as defined in Annex 28B<br>[30] = Reserved                                 | RO     | 0x0   |  |  |  |
| 27    | an_lp_adv_remote_faul<br>t | Link Partner Remote Fault<br>Remote fault bit from Link Partner                                                                                                      | RO     | 0x0   |  |  |  |
| 26:23 | an_lp_adv_fec_f            | Link Partner FEC Ability Field<br>[23] = 25G RS-FEC requested<br>[24] = 25G BASE-R FEC (CL 74 Firecode) requested<br>[25] = FEC Ability<br>[26] = FEC Requested      | RO     | 0x0   |  |  |  |
| 22:0  | an_lp_adv_tech_a           | Link Partner Technology Ability Field<br>[0] = 1000BASE-KX<br>[1] = 10GBASE-KX4<br>[2] = 10GBASE-KR<br>[3] = 40GBASE-KR4<br>[4] = 40GBASE-CR4<br>[5] = 100GBASE-CR10 | RO     | 0x0   |  |  |  |
|       | continued                  |                                                                                                                                                                      |        |       |  |  |  |



| Bit | Name | Description             | Access | Reset |
|-----|------|-------------------------|--------|-------|
|     |      | [6] = 100GBASE-KP4      |        |       |
|     |      | [7] = 100GBASE-KR4      |        |       |
|     |      | [8] = 100GBASE-CR4      |        |       |
|     |      | [9] = 25GBASE-KR-S/CR-S |        |       |
|     |      | [10] = 25GBASE-KR/CR    |        |       |
|     |      | [11] = 2.5GBASE-KX      |        |       |
|     |      | [12] = 5GBASE-KR        |        |       |
|     |      | [13] = 50GBASE-KR/CR    |        |       |
|     |      | [14] = 100GBASE-KR2/CR2 |        |       |
|     |      | [15] = 200GBASE-KR4/CR4 |        |       |
|     |      | [22:16] = Reserved      |        |       |

# 2.12.1.15. AN Channel Override

Offset: 0xCC

#### **AN Channel Override Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name                | Description                                                                               | Access | Reset |
|-----|---------------------|-------------------------------------------------------------------------------------------|--------|-------|
| 1:0 | override_an_channel | AN Channel Override                                                                       | RW     | 0x0   |
|     |                     | When override_an_chan_enable (0xC0[6]) is 1, this register selects AN channel, range 0-3. |        |       |

# 2.12.1.16. Consortium Next Page Override

#### Offset: 0xCD

# **Consortium Next Page Override Fields**

| Bit   | Name                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Access | Reset |
|-------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 27:24 | override_consortium_n<br>ext_page_fec_control | <b>Override Consortium Next PAGE FEC Control</b><br>When Enable Consortium Next Page override is enabled<br>(enable_consortium_next_page_override=1), this<br>register overrides bits D27:D24 in the Unformatted Next<br>Page with the following bits defined by the consortium:.<br>[24] = F1- CL91 RS-FEC ability<br>[25] = F2- CL74 RS-FEC ability<br>[26] = F3- CL91 RS-FEC request<br>[27] = F4- CL74 RS-FEC request                                                                                                                                              | RW     | 0x0   |
| 19:0  | override_consortium_n<br>ext_page_tech        | <ul> <li>Override Consortium Next Page Technology Ability <ul> <li>[8:0] = Override bits D8:D0 in the Unformatted Next Page from default of 0x003 to indicate extended technology abilities.</li> <li>[19:9] = Override bits D26:D16 in the Unformatted Next Page with the following bits defined by the consortium:</li> <li>[12:9] = Reserved, set to 0</li> <li>[13] = 25GBASE-KR1 ability</li> <li>[14] = 25GBASE-CR1 ability</li> <li>[16:15] = Reserved, set to 0</li> <li>[17] = 50GBASE-KR2 ability</li> <li>[18] = 50GBASE-CR2 ability</li> </ul> </li> </ul> | RW     | 0x3   |





# 2.12.1.17. Consortium Next Page Link Partner Status

Offset: 0xCE

# **Consortium Next Page Link Partner Status Fields**

The reset values in this table represents register values after a reset has completed.

| Bit   | Name                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Access | Reset |
|-------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 27:24 | lp_consortium_next_pa<br>ge_fec  | Link Partner Consortium Next Page FEC Ability<br>Contain bits D27:D24 from the decoded consortium<br>Unformatted Next Page with the following bits defined by<br>the consortium:<br>[24]: F1- CL91 RS-FEC ability<br>[25]: F2- CL74 RS-FEC ability<br>[26]: F3- CL91 RS-FEC request<br>[27]: F4- CL74 RS-FEC request                                                                                                                                                                                                                               | RO     | 0x0   |
| 19:0  | lp_consortium_next_pa<br>ge_tech | Link Partner Consortium Next Page Technology<br>Ability<br>[8:0]: Contain bits D8:D0 from the decoded consortium<br>Unformatted Next Page (default of 0x003) to indicate<br>extended technology abilities.<br>[19:9]: Contain bits D26:D16 from the decoded consortium<br>Unformatted Next Page with the following bits defined by<br>the consortium:<br>• [12:9]: Reserved<br>• [13]: 25GBASE-KR1 ability<br>• [14]: 25GBASE-CR1 ability<br>• [16:15]: Reserved<br>• [17]: 50GBASE-KR2 ability<br>• [18]: 50GBASE-CR2 ability<br>• [19]: Reserved | RO     | 0x0   |

# 2.12.1.18. Link Training Config Register 1

Offset: 0xD0

# Link Training Config Register 1 Fields

The reset values in this table represents register values after a reset has completed. Set bits [19:17] to 1 for internal loopback (ILB) or very short connections to disable LT optimizations.

| 31:28       lt_cfgl_ovrd_bw       CTLE-BW Override<br>When train_start_initpre set to 1, use this value for<br>serdes CTLE-BW initial setting.       RW         27:24       lt_cfgl_ovrd_hf       CTLE-HF Override<br>When train_start_initpre set to 1, use this value for<br>serdes CTLE-HF initial setting.       RW         23:20       lt_cfgl_ovrd_lf       CTLE-LF Override<br>When train_start_initpre set to 1, use this value for<br>serdes CTLE-LF initial setting.       RW         19       lt_cfgl_disable post1       Disables Post-LT optimized serdes settings       RW | Reset |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 23:20       lt_cfg1_ovrd_lf       CTLE-LF Override<br>When train_start_initpre set to 1, use this value for<br>serdes CTLE-LF initial setting.       RW                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x0   |
| Ite_orgr_orrd_if       When train_start_initpre set to 1, use this value for serdes CTLE-LF initial setting.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0   |
| 19 It afai disable post Disables Post Tontimized serves settings RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0   |
| t<br>1: Disables optimizing serdes settings for KR post-LT and<br>use default settings.<br>May be required for internal loopback (ILB) or very short<br>connections.                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0   |



| Bit  | Name                       | Description                                                                                                                                                                                                                                                | Access | Reset       |
|------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------|
| 18   | lt_cfg1_disable_prelt      | <b>Disables Pre-LT optimized serdes settings</b><br>1: Disables optimizing serdes settings for KR pre-LT and<br>use default settings.<br>May be required for internal loopback (ILB) or very short<br>connections.                                         | RW     | 0x0         |
| 17   | lt_cfg1_disable_prxca<br>l | <b>Disables Periodic RX Adaptation during Data Mode</b><br>1: Disables Periodic RX Adaptation during Data Mode<br>May be required for internal loopback (ILB) or very short<br>connections                                                                 | RW     | 0x0         |
| 16   | lt_cfg1_disable_rxcal      | <b>Disables Initial RX Adaptation during LT</b><br>1: Disables Initial RX Adaptation during LT                                                                                                                                                             | RW     | 0x0         |
| 15:4 | lt_mw_time                 | Sets LT Max_wait_timer timeout value<br>Each step is ~419.4us for NRZ, 2516.4us for PAM4.<br>Default value is 1192, or ~500ms for NRZ, ~3s for PAM4.                                                                                                       | RW     | 12'h<br>4a8 |
| 3    | train_start_initpre        | Enable serdes initial RX setting override<br>1: Override initial serdes RX settings via 0xD0[31:20]<br>0: Use default serdes RX settings for Link Training (default)<br>Pre-LT optimized settings must be enabled for this to take<br>effect (0xD0[18]==0) | RW     | 0x0         |
| 2    | high_effort_train          | Use high-effort training<br>1: LT will use higher effort for RX train (may take more<br>than 500ms)<br>0: LT will use standard effort for RX train (500ms)                                                                                                 | RW     | 0x0         |
| 1    | dis_max_wait_tmr           | <b>Disable Max Wait Timer</b><br>1: Disable Max Wait Timer<br>0: Use Max Wait Timer (default)                                                                                                                                                              | RW     | 0x0         |
| 0    | enable_link_training       | <b>Enable Link Training</b><br>1: Enable link training<br>0: Disable link training                                                                                                                                                                         | RW     | 0x1         |

# 2.12.1.19. Link Training Status Register 1

Offset: 0xD2

# **Link Training Status Register 1 Fields**

| Bit | Name                          | Description                                                                                                                                              | Access | Reset |
|-----|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 27  | link_training_failure ln3     | Link Training Failure on Lane 3 (only applicable to 100G NRZ)                                                                                            | RO     | 0x0   |
|     | _                             | 1: Link Training Failed on Lane 3                                                                                                                        |        |       |
|     |                               | 0: Normal operation                                                                                                                                      |        |       |
|     |                               | <ul> <li>Corresponds to state variable training_failure as defined<br/>in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid only for links with 4 lanes</li> </ul> |        |       |
| 26  | link_training_startup<br>_ln3 | Link Training Startup up Protocol in Progress on Lane<br>3 (only applicable to 100G NRZ)<br>1: Start-up protocol in progress                             | RO     | 0x0   |
|     | •                             |                                                                                                                                                          | contin | ued   |



2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



| Bit | Name                             | Description                                                                                                                                                                                                                                                                                                                           | Access | Reset |
|-----|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |                                  | <ul> <li>0: Start-up protocol complete</li> <li>Corresponds to state variable training as defined in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid only for links with 4 lanes</li> </ul>                                                                                                                                                   |        |       |
| 25  |                                  | ,                                                                                                                                                                                                                                                                                                                                     |        |       |
| 25  | link_training_frame_l<br>ock_ln3 | <ul> <li>Link Training Frame Lock Achieved on Lane 3 (only applicable to 100G NRZ)</li> <li>1: Training frame delineation detected</li> <li>0: Searching for training frame boundaries</li> <li>Corresponds to state variable frame_lock as defined in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid only for links with 4 lanes</li> </ul> | RO     | 0x0   |
| 24  | link_trained_ln3                 | <ul> <li>Receiver Trained on Lane 3 (only applicable to 100G NRZ)</li> <li>1: Receiver training completed</li> <li>0: Training in progress</li> <li>Corresponds to state variable rx_trained as defined in IEEE 802.3 CL72.6.10.3.1</li> </ul>                                                                                        | RO     | 0x0   |
|     |                                  | Valid only on links with 4 lanes                                                                                                                                                                                                                                                                                                      |        |       |
| 19  | link_training_failure<br>_ln2    | <ul> <li>Link Training Failure on Lane 2 (only applicable to 100G NRZ)</li> <li>1: Link Training Failed on Lane 2</li> <li>0: Normal operation</li> <li>Corresponds to state variable training_failure as defined in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid and when links with 4 langes</li> </ul>                                  | RO     | 0x0   |
|     |                                  | Valid only for links with 4 lanes                                                                                                                                                                                                                                                                                                     |        |       |
| 18  | link_training_startup<br>_ln2    | <ul> <li>Link Training Startup up Protocol in Progress on Lane</li> <li>2 (only applicable to 100G NRZ)</li> <li>1: Start-up protocol in progress</li> <li>0: Start-up protocol complete</li> <li>Corresponds to state variable training as defined in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid only for links with 4 lanes</li> </ul> | RO     | 0x0   |
| 17  | link_training_frame_l<br>ock_ln2 | <ul> <li>Link Training Frame Lock Achieved on Lane 2 (only applicable to 100G NRZ)</li> <li>1: Training frame delineation detected</li> <li>0: Searching for training frame boundaries</li> <li>Corresponds to state variable frame_lock as defined in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid only for links with 4 lanes</li> </ul> | RO     | 0x0   |
| 16  | link_trained_ln2                 | <ul> <li>Receiver Trained on Lane 2 (only applicable to 100G NRZ)</li> <li>1: Receiver training completed</li> <li>0: Training in progress</li> <li>Corresponds to state variable rx_trained as defined in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid only on links with 4 lanes</li> </ul>                                              | RO     | 0x0   |
| 11  | link_training_failure<br>_ln1    | <ul> <li>Link Training Failure on Lane 1</li> <li>1: Link Training Failed on Lane 1</li> <li>0: Normal operation</li> <li>Corresponds to state variable training_failure as defined in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid only for links with 2 or 4 lanes</li> </ul>                                                            | RO     | 0x0   |
|     | •                                | •                                                                                                                                                                                                                                                                                                                                     | contin | ued   |



| Bit | Name                             | Description                                                                                                                                                                                                                                                                                                  | Access | Reset |
|-----|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 10  | link_training_startup<br>_ln1    | <ul> <li>Link Training Startup up Protocol in Progress on Lane</li> <li>1: Start-up protocol in progress</li> <li>0: Start-up protocol complete</li> <li>Corresponds to state variable training as defined in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid only for links with 2 or 4 lanes</li> </ul>            | RO     | 0x0   |
| 9   | link_training_frame_l<br>ock_ln1 | <ul> <li>Link Training Frame Lock Achieved on Lane 1</li> <li>1: Training frame delineation detected</li> <li>0: Searching for training frame boundaries</li> <li>Corresponds to state variable frame_lock as defined in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid only for links with 2 or 4 lanes</li> </ul> | RO     | 0x0   |
| 8   | link_trained_ln1                 | <ul> <li>Receiver Trained on Lane 1</li> <li>1: Receiver training completed</li> <li>0: Training in progress</li> <li>Corresponds to state variable rx_trained as defined in IEEE 802.3 CL72.6.10.3.1</li> <li>Valid only for links with 2 or 4 lanes</li> </ul>                                             | RO     | 0x0   |
| 3   | link_training_failure<br>_ln0    | <ul> <li>Link Training Failure on Lane 0</li> <li>1: Link Training Failed on Lane 0</li> <li>0: Normal operation</li> <li>Corresponds to state variable training_failure as defined in IEEE 802.3 CL72.6.10.3.1</li> </ul>                                                                                   | RO     | 0x0   |
| 2   | link_training_startup<br>_ln0    | <ul> <li>Link Training Startup up Protocol in Progress on Lane</li> <li>0</li> <li>1: Start-up protocol in progress</li> <li>0: Start-up protocol complete</li> <li>Corresponds to state variable training as defined in IEEE 802.3 CL72.6.10.3.1</li> </ul>                                                 | RO     | 0x0   |
| 1   | link_training_frame_l<br>ock_ln0 | <ul> <li>Link Training Frame Lock Achieved on Lane 0</li> <li>1: Training frame delineation detected</li> <li>0: Searching for training frame boundaries</li> <li>Corresponds to state variable frame_lock as defined in IEEE 802.3 CL72.6.10.3.1</li> </ul>                                                 | RO     | 0x0   |
| 0   | link_trained_ln0                 | <ul> <li>Receiver Trained on Lane 0</li> <li>1: Receiver training completed</li> <li>0: Training in progress</li> <li>Corresponds to state variable rx_trained as defined in IEEE 802.3 CL72.6.10.3.1</li> </ul>                                                                                             | RO     | 0x0   |

# 2.12.1.20. Link Training Config Register for Lane 0

Offset: 0xD3

# Link Training Config Register for Lane 0 Fields

| Bit   | Name             | Description                                                              | Access | Reset     |
|-------|------------------|--------------------------------------------------------------------------|--------|-----------|
| 26:16 | lt_prbs_seed_ln0 | Link Training PRBS Seed for Lane 0 (only applicable to 100G and 25G NRZ) | RW     | 0x57<br>E |
|       |                  |                                                                          |        |           |



2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09



| Bit | Name                           | Description                                                                        | Access | Reset |
|-----|--------------------------------|------------------------------------------------------------------------------------|--------|-------|
|     |                                | Sets the initial seed for PRBS. Default value is 11'h57e                           |        |       |
| 2:0 | lt_prbs_pattern_selec<br>t ln0 | Link Training PRBS Pattern Select for Lane 0 (only applicable to 100G and 25G NRZ) | RW     | 0x0   |
|     |                                | 0: Use Clause 92 Polynomial 0                                                      |        |       |
|     |                                | 1: Use Clause 92 Polynomial 1                                                      |        |       |
|     |                                | 2: Use Clause 92 Polynomial 2                                                      |        |       |
|     |                                | 3: Use Clause 92 Polynomial 3                                                      |        |       |
|     |                                | 4: Use Clause 72 Polynomial (if CL72 PRBS parameter is enabled)                    |        |       |
|     |                                | All other settings reserved                                                        |        |       |
|     |                                | Default value for lane 0 is 0                                                      |        |       |

# 2.12.1.21. Link Training Config Register for Lane 1

#### Offset: 0xE0

# Link Training Config Register for Lane 1 Fields

The reset values in this table represents register values after a reset has completed.

| Bit   | Name                           | Description                                                            | Access | Reset     |
|-------|--------------------------------|------------------------------------------------------------------------|--------|-----------|
| 26:16 | lt_prbs_seed_ln1               | Link Training PRBS Seed for Lane 1 (only applicable to 100G)           | RW     | 0x64<br>5 |
|       |                                | Sets the initial seed for PRBS. Default value is 11'h645               |        |           |
| 2:0   | lt_prbs_pattern_selec<br>t_ln1 | Link Training PRBS Pattern Select for Lane 1 (only applicable to 100G) | RW     | 0x1       |
|       |                                | 0: Use Clause 92 Polynomial 0                                          |        |           |
|       |                                | 1: Use Clause 92 Polynomial 1                                          |        |           |
|       |                                | 2: Use Clause 92 Polynomial 2                                          |        |           |
|       |                                | 3: Use Clause 92 Polynomial 3                                          |        |           |
|       |                                | 4: Use Clause 72 Polynomial (if CL72 PRBS parameter is enabled)        |        |           |
|       |                                | All other settings reserved                                            |        |           |
|       |                                | Default value for lane 1 is 1                                          |        |           |

# 2.12.1.22. Link Training Config Register for Lane 2

Offset: 0xE4

# Link Training Config Register for Lane 2 Fields

| Bit   | Name                           | Description                                                                | Access | Reset     |  |
|-------|--------------------------------|----------------------------------------------------------------------------|--------|-----------|--|
| 26:16 | lt_prbs_seed_ln2               | Link Training PRBS Seed for Lane 2 (only applicable to 100G NRZ)           | RW     | 0x72<br>D |  |
|       |                                | Sets the initial seed for PRBS. Default value is 11'h72d                   |        |           |  |
| 2:0   | lt_prbs_pattern_selec<br>t_ln2 | Link Training PRBS Pattern Select for Lane 2 (only applicable to 100G NRZ) | RW     | 0x2       |  |
|       |                                | 0: Use Clause 92 Polynomial 0                                              |        |           |  |
|       |                                | 1: Use Clause 92 Polynomial 1                                              |        |           |  |
|       |                                | 2: Use Clause 92 Polynomial 2                                              |        |           |  |
|       |                                | 3: Use Clause 92 Polynomial 3                                              |        |           |  |
|       |                                | 4: Use Clause 72 Polynomial (if CL72 PRBS parameter is enabled)            |        |           |  |
|       | continued                      |                                                                            |        |           |  |



| Bit | Name | Description                                                                         | Access | Reset |
|-----|------|-------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul><li>All other settings reserved</li><li>Default value for lane 2 is 2</li></ul> |        |       |

# 2.12.1.23. Link Training Config Register for Lane 3

#### Offset: 0xE8

# Link Training Config Register for Lane 3 Fields

The reset values in this table represents register values after a reset has completed.

| Bit   | Name                           | Description                                                                | Access | Reset     |
|-------|--------------------------------|----------------------------------------------------------------------------|--------|-----------|
| 26:16 | lt_prbs_seed_ln3               | Link Training PRBS Seed for Lane 3 (only applicable to 100G NRZ)           | RW     | 0x7B<br>6 |
|       |                                | Sets the initial seed for PRBS. Default value is 11'h7b6                   |        |           |
| 2:0   | lt_prbs_pattern_selec<br>t_ln3 | Link Training PRBS Pattern Select for Lane 3 (only applicable to 100G NRZ) | RW     | 0x3       |
|       |                                | 0: Use Clause 92 Polynomial 0                                              |        |           |
|       |                                | 1: Use Clause 92 Polynomial 1                                              |        |           |
|       |                                | 2: Use Clause 92 Polynomial 2                                              |        |           |
|       |                                | 3: Use Clause 92 Polynomial 3                                              |        |           |
|       |                                | 4: Use Clause 72 Polynomial (if CL72 PRBS parameter is enabled)            |        |           |
|       |                                | All other settings reserved                                                |        |           |
|       |                                | Default value for lane 3 is 3                                              |        |           |

# **2.12.2. PHY Registers**

# 2.12.2.1. PHY Module Revision ID

Offset: 0x300

# **PHY Module Revision ID Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name | Description                                           | Access | Reset              |
|------|------|-------------------------------------------------------|--------|--------------------|
| 31:0 | id   | <b>Revision ID</b><br>32b Revision ID for the module. | RO     | 0x11<br>1120<br>15 |

# 2.12.2.2. PHY Scratch Register

Offset: 0x301

# **PHY Scratch Register Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name    | Description | Access | Reset |
|------|---------|-------------|--------|-------|
| 31:0 | scratch |             | RW     | 0x0   |

# 2.12.2.3. PHY Configuration

Offset: 0x310





#### **PHY Configuration Fields**

| Bit | Name          | Description                                                                                                                       | Access | Reset |
|-----|---------------|-----------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 5   | set_data_lock | Set data lock<br>1: Force PLL to lock to data                                                                                     | RW     | 0x0   |
| 4   | set_ref_lock  | Set ref lock<br>1: Force PLL to lock to reference                                                                                 | RW     | 0x0   |
| 2   | soft_rx_rst   | Soft RXP Reset<br>1: Resets the RX PCS and RX MAC.                                                                                | RW     | 0x0   |
| 1   | soft_tx_rst   | Soft TXP Reset<br>1: Resets the TX PCS and TX MAC.                                                                                | RW     | 0x0   |
| 0   | eio_sys_rst   | Ethernet IO System Reset<br>1: Resets the IP core (TX and RX MACs, Ethernet<br>reconfiguration registers, PCS, and transceivers). | RW     | 0x0   |

The reset values in this table represents register values after a reset has completed.

# 2.12.2.4. RX CDR PLL Locked

#### Offset: 0x321

#### **RX CDR PLL Locked Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name          | Description                                                                                                          | Access | Reset |
|-----|---------------|----------------------------------------------------------------------------------------------------------------------|--------|-------|
| 3:0 | eio_freq_lock | <b>CDR PLL locked</b><br>1: Corresponding physical lane's CDR has locked to<br>reference for 10, 25, and 100G links. | RO     | 0x0   |

# 2.12.2.5. TX Datapath Ready

Offset: 0x322

# **TX Datapath Ready Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name         | Description                                                                   | Access | Reset |
|-----|--------------|-------------------------------------------------------------------------------|--------|-------|
| 0   | tx_pcs_ready | <b>TX Ready</b><br>1: TX Datapath is out of reset, stable, and ready for use. | RO     | 0x0   |

# 2.12.2.6. Frame Errors Detected

Offset: 0x323

#### **Frame Errors Detected Fields**

| Bit  | Name   | Description             | Access | Reset |  |
|------|--------|-------------------------|--------|-------|--|
| 19:0 | frmerr | Frame error(s) detected | RO     | 0x0   |  |





#### 2. About the E-Tile Hard IP for Ethernet Intel FPGA IP Core UG-20160 | 2020.03.09

| Bit | Name | Description                                                                                                                                                                                                                                                                              | Access | Reset |
|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>1: A frame error was detected on corresponding lane</li> <li>For single lanes, only bit 0 is used</li> <li>For 100G links, bits 19:0 are used, corresponding to Virtual lanes 0 to 19</li> <li>This bit is sticky, and must be cleared by asserting sclr_frame_error</li> </ul> |        |       |

# 2.12.2.7. Clear Frame Errors

Offset: 0x324

# **Clear Frame Errors Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name       | Description                                                              | Access | Reset |
|-----|------------|--------------------------------------------------------------------------|--------|-------|
| 0   | clr_frmerr | Clear PHY frame error(s).<br>1: Return all sticky frame error bits to 0. | RW     | 0x0   |

# 2.12.2.8. RX PCS Status for AN/LT

Offset: 0x326

# **RX PCS Status for AN/LT Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name       | Description                                                                                                    | Access | Reset |
|-----|------------|----------------------------------------------------------------------------------------------------------------|--------|-------|
| 1   | hi_ber     | <b>Hi-BER</b><br>1: One or more virtual lanes are in the Hi-BER state defined<br>in the Ethernet specification | RO     | 0x0   |
| 0   | rx_aligned | <b>RX PCS fully aligned</b><br>1: The RX PCS is fully aligned and ready to start decoding data                 | RO     | 0x0   |

# 2.12.2.9. PCS Error Injection

Offset: 0x327

# **PCS Error Injection Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name    | Description                                                                                                                                                                                                                                        | Access | Reset |
|------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 19:0 | inj_err | Inject Error                                                                                                                                                                                                                                       | RW     | 0x0   |
|      |         | <ul> <li>0-&gt;1: Flip bits to inject encoding errors in corresponding virtual lane</li> <li>0 :Clear all error injection settings</li> <li>For EHIP with rate set to 100G, bits 0 to 19 are valid, and correspond to virtual lanes 019</li> </ul> |        |       |

# 2.12.2.10. Alignment Marker Lock

Offset: 0x328





#### **Alignment Marker Lock Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name    | Description                                                                                            | Access | Reset |
|-----|---------|--------------------------------------------------------------------------------------------------------|--------|-------|
| 0   | am_lock | AM Lock<br>1: RX PCS has achieved Alignment Marker lock<br><i>Note:</i> Not valid for single-lane EHIP | RO     | 0x0   |

# 2.12.2.11. Change in RX PCS Deskew Status

Offset: 0x329

#### lanes\_deskewed Fields

The reset values in this table represents register values after a reset has completed.

| Bit | Name         | Description                                                                                                                                                             | Access | Reset |
|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 1   | dskew_chng   | Change in deskewed status                                                                                                                                               | RO     | 0x0   |
|     |              | 1: RX PCS went from deskewed to not deskewed, or from not deskewed to deskewed                                                                                          |        |       |
|     |              | <ul> <li>Not valid for single lane channels (10G/25G)</li> </ul>                                                                                                        |        |       |
|     |              | • This bit is sticky. Use clr_frmerr to set this bit back to 0.                                                                                                         |        |       |
|     |              | <ul> <li>Resetting the RX datapath, or the entire core will also<br/>clear the bit</li> </ul>                                                                           |        |       |
| 0   | dskew_status | Deskewed status                                                                                                                                                         | RO     | 0x0   |
|     |              | 1: RX PCS is deskewed                                                                                                                                                   |        |       |
|     |              | 0: RX PCS is not currently deskewed.                                                                                                                                    |        |       |
|     |              | Note: There is some latency between this status bit and the actual state.                                                                                               |        |       |
|     |              | Not valid for single lane channels (10G/25G)                                                                                                                            |        |       |
|     |              | <ul> <li>This bit is not sticky. Intel recommends that you replace<br/>this bit with a soft logic that can be made sticky based<br/>on the deskew_done port.</li> </ul> |        |       |

# 2.12.2.12. BER Count

Offset: 0x32A

#### ber\_count Fields

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                                                                         | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 31:0 | count | <ul> <li>BER Count</li> <li>32b count that increments each time the BER_BAS_SH state is entered</li> <li>Rolls over when maximum count is reached</li> <li>Clears when the channel is reset</li> <li>Can be captured using snapshot or RX shadow request</li> </ul> | RO     | 0x0   |

# 2.12.2.13. Transfer Ready (AIB reset) Status for EHIP, ELANE, and PTP Channels

Offset: 0x32B





#### aib\_transfer\_ready\_status Fields

The reset values in this table represents register values after a reset has completed.

| Bit   | Name                       | Description                                                                    | Access | Reset |
|-------|----------------------------|--------------------------------------------------------------------------------|--------|-------|
| 21:20 | ptp_rx_transfer_ready      | <b>PTP TX Channels Transfer Ready Status</b><br>1: transfer_ready is 1.        | RO     | 0x0   |
| 19:16 | ehip_rx_transfer_read<br>Y | <b>EHIP/ELANE RX Channels Transfer Ready Status</b><br>1: transfer_ready is 1. | RO     | 0x0   |
| 5:4   | ptp_tx_transfer_ready      | <b>PTP TX Channels Transfer Ready Status</b><br>1: transfer_ready is 1.        | RO     | 0x0   |
| 3:0   | ehip_tx_transfer_read<br>Y | <b>EHIP/ELANE TX Channels Transfer Ready Status</b><br>1: transfer_ready is 1. | RO     | 0x0   |

# 2.12.2.14. EHIP, ELANE, and RS-FEC Reset Status

#### Offset: 0x32C

#### soft\_rc\_reset\_status Fields

The reset values in this table represents register values after a reset has completed.

| Bit | Name                | Description                                   | Access | Reset |
|-----|---------------------|-----------------------------------------------|--------|-------|
| 5   | ehip_rsfec_rx_reset | EHIP rsfec RX reset from the reset controller | RO     | 0x0   |
| 4   | ehip_rsfec_tx_reset | EHIP rsfec TX reset from the reset controller | RO     | 0x0   |
| 3   | ehip_rsfec_reset    | EHIP rsfec reset from the reset controller    | RO     | 0x0   |
| 2   | ehip_rx_reset       | EHIP RX reset from the reset controller       | RO     | 0x0   |
| 1   | ehip_tx_reset       | EHIP TX reset from the reset controller       | RO     | 0x0   |
| 0   | ehip_reset          | EHIP reset from the reset controller          | RO     | 0x0   |

# 2.12.2.15. PCS Virtual Lane 0

Offset: 0x330

# **PCS Virtual Lane 0 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit   | Name   | Description                                                                                                                                                                                                                                                                                                                                     | Access | Reset |
|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 29:25 | vlane5 | Virtual lane mapping<br>Original virtual lane position of the data mapped to the PCS<br>lane with this index.<br>For example, if you read the value 5 from vlane 12, it<br>means the virtual lane data that the link partner<br>transmitted on virtual lane 5 is being received on virtual<br>lane 12. EHIP will reorder the data automatically | RO     | 0x1F  |
| 24:20 | vlane4 |                                                                                                                                                                                                                                                                                                                                                 |        |       |
| 19:15 | vlane3 |                                                                                                                                                                                                                                                                                                                                                 |        |       |
| 14:10 | vlane2 |                                                                                                                                                                                                                                                                                                                                                 |        |       |
| 9:5   | vlanel |                                                                                                                                                                                                                                                                                                                                                 |        |       |
| 4:0   | vlane0 |                                                                                                                                                                                                                                                                                                                                                 |        |       |

# 2.12.2.16. PCS Virtual Lane 1

Offset: 0x331





### **PCS Virtual Lane 1 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit   | Name    | Description                                                                                                  | Access | Reset |
|-------|---------|--------------------------------------------------------------------------------------------------------------|--------|-------|
| 29:25 | vlane11 | Virtual lane mapping                                                                                         | RO     | 0x1F  |
| 24:20 | vlane10 | Original virtual lane position of the data mapped to the PCS lane with this index.                           |        |       |
| 19:15 | vlane9  | For example, if you read the value 5 from vlane12, it means the virtual lane data that the link partner      |        |       |
| 14:10 | vlane8  | transmitted on virtual lane 5 is being received on virtual lane 12. EHIP will reorder the data automatically |        |       |
| 9:5   | vlane7  |                                                                                                              |        |       |
| 4:0   | vlane6  |                                                                                                              |        |       |

# 2.12.2.17. PCS Virtual Lane 2

### Offset: 0x332

### **PCS Virtual Lane 2 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit   | Name    | Description                                                                                                  | Access | Reset |  |
|-------|---------|--------------------------------------------------------------------------------------------------------------|--------|-------|--|
| 29:25 | vlane17 | Virtual lane mapping                                                                                         | RO     | 0x1F  |  |
| 24:20 | vlane16 | Original virtual lane position of the data mapped to the PCS lane with this index.                           |        |       |  |
| 19:15 | vlane15 | For example, if you read the value 5 from vlane 12, it means the virtual lane data that the link partner     |        |       |  |
| 14:10 | vlane14 | transmitted on virtual lane 5 is being received on virtual lane 12. EHIP will reorder the data automatically |        |       |  |
| 9:5   | vlane13 |                                                                                                              |        |       |  |
| 4:0   | vlane12 |                                                                                                              |        |       |  |

## 2.12.2.18. PCS Virtual Lane 3

Offset: 0x333

#### **PCS Virtual Lane 3 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name    | Description                                                                                                                                                                                                           | Access | Reset |
|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 9:5 | vlane19 | Virtual lane mapping                                                                                                                                                                                                  | RO     | 0x1F  |
| 4:0 | vlane18 | Original virtual lane position of the data mapped to the PCS lane with this index.                                                                                                                                    |        |       |
|     |         | For example, if you read the value 5 from vlane 12, it means the virtual lane data that the link partner transmitted on virtual lane 5 is being received on virtual lane 12. EHIP will reorder the data automatically |        |       |

## 2.12.2.19. Recovered Clock Frequency in KHz





### **Recovered Clock Frequency in KHz Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name   | Description                                                         | Access | Reset |
|------|--------|---------------------------------------------------------------------|--------|-------|
| 31:0 | khz_rx | Recovered clock frequency<br>Recovered clock frequency/100, in KHz. | RO     | 0x0   |

# 2.12.2.20. TX Clock Frequency in KHz

Offset: 0x342

## **TX Clock Frequency in KHz Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name   | Description                                                  | Access | Reset |
|------|--------|--------------------------------------------------------------|--------|-------|
| 31:0 | khz_tx | <b>TX clock frequency</b><br>TX clock frequency/100, in KHz. | RO     | 0x0   |

# 2.12.2.21. Configuration Fields for TX PLD

Offset: 0x350

### **Configuration Fields for TX PLD Fields**

| Bit   | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                | Access | Reset |
|-------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 23    | sel_50gx2          | <pre>Select 100G mode Selects whether EHIP receives EMIB data from 2 or 4 lanes 0: Use 4 EMIB channels for data input 1: Use 2 EMIB channels for data input The TX datapath must be reset after changing this field Not used for single lane channels (10G/25G) Defaults to 0 after power up After i_csr_rst_n, default value depends on the what you selected in the Select Ethernet Rate parameter When Select Ethernet Rate = 100G, sel_50gx2 = 0</pre> | RW     | 0x0   |
| 22    | tx_deskew_clear    | <ul> <li>EMIB Deskew clear</li> <li>Reset signal for the TX PLD deskew logic.</li> <li>0: Normal deskew operation</li> <li>1: TX EMIB deskew circuit in reset</li> <li>Defaults to 0 after power up and i_csr_rst_n</li> </ul>                                                                                                                                                                                                                             | RW     | 0x0   |
| 21:16 | tx_deskew_chan_sel | Deskew channel select                                                                                                                                                                                                                                                                                                                                                                                                                                      | RW     | 0x0   |
|       |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                            | contin | nued  |





| Bit  | Name          | Description                                                                                                     | Access | Reset |
|------|---------------|-----------------------------------------------------------------------------------------------------------------|--------|-------|
|      |               | Specifies which channels participate in the deskew procedure                                                    |        |       |
|      |               | <ul> <li>For single lane channels (10G/25G)</li> <li>— Only used when single lane is in EHIP MAC PTP</li> </ul> |        |       |
|      |               | mode                                                                                                            |        |       |
|      |               | <ul> <li>[0]=1: include EHIP lane datapath EMIB in deskew;<br/>defaults to 1</li> </ul>                         |        |       |
|      |               | <ul> <li>[4]=1: include PTP EMIB from EHIP core in deskew;<br/>defaults to 1</li> </ul>                         |        |       |
|      |               | After reset, defaults to 0                                                                                      |        |       |
|      |               | <ul> <li>After i_csr_rst_n, default value depends on the<br/>Select Ethernet Rate parameter</li> </ul>          |        |       |
|      |               | For 100Gx4 channels                                                                                             |        |       |
|      |               | <ul> <li>[0]=1: include EMIB0 in deskew; defaults to 1</li> </ul>                                               |        |       |
|      |               | <ul> <li>[1]=1: include EMIB1 in deskew; defaults to 1</li> </ul>                                               |        |       |
|      |               | <ul> <li>[2]=1: include EMIB2 in deskew; defaults to 1</li> </ul>                                               |        |       |
|      |               | <ul> <li>[3]=1: include EMIB3 in deskew; defaults to 1</li> </ul>                                               |        |       |
|      |               | <ul> <li>[4]=1: include EMIB4 in deskew; defaults to 1, only<br/>available in PTP mode</li> </ul>               |        |       |
|      |               | <ul> <li>[5]=1: include EMIB5 in deskew; defaults to 1, only<br/>available in PTP mode</li> </ul>               |        |       |
|      |               | The TX datapath must be reset after changing values in this field.                                              |        |       |
| 12:8 | tx_fifo_afull | TX FIFO almost full level                                                                                       | RW     | 0x0   |
|      |               | This is a debug feature that has been deprecated.                                                               |        |       |
| 2:0  | tx_ehip_mode  | Portmap select                                                                                                  | RW     | 0x0   |
|      |               | Selects how the synchronous input to the EHIP will be mapped.                                                   |        |       |
|      |               | 3h0: MAC interface                                                                                              |        |       |
|      |               | 3h1: MAC interface with PTP                                                                                     |        |       |
|      |               | 3h2: PCS (MII) interface                                                                                        |        |       |
|      |               | <ul> <li>3h3: PCS66 interface with forced encoder and scrambler<br/>by page</li> </ul>                          |        |       |
|      |               | <ul><li>bypass</li><li>3h4: PCS66 interface</li></ul>                                                           |        |       |
|      |               | <ul> <li>3'h5: Reserved</li> </ul>                                                                              |        |       |
|      |               | <ul> <li>3'h6: Reserved</li> </ul>                                                                              |        |       |
|      |               | • 3'h7: PMA direct interface                                                                                    |        |       |
|      |               | After power up, defaults to 0                                                                                   |        |       |
|      |               | • After i_csr_rst_n, default depends on the <b>Select</b>                                                       |        |       |
|      |               | Ethernet IP Layers parameter                                                                                    |        |       |
|      |               | — When Select Ethernet IP Layers = MAC+PCS,<br>tx_ehip_mode = 3'd0                                              |        |       |
|      |               | — When Select Ethernet IP Layers = PCS-only,<br>tx_ehip_mode = 3'd2                                             |        |       |
|      |               | — When Select Ethernet IP Layers = FlexE PHY,<br>tx_ehip_mode = 3'd4                                            |        |       |
|      |               | <ul> <li>When Select Ethernet IP Layers = OTN PHY,</li> </ul>                                                   |        |       |
|      |               | tx ehip mode = $3'd3$                                                                                           |        |       |

## 2.12.2.22. Status for TX PLDs

Offset: 0x351

### **Status for TX PLDs Fields**

\_



| Bit   | Name                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Access | Reset |
|-------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 24    | err_tx_avst_fifo_over<br>flow  | <ul> <li>TX AVST FIFO Overflow</li> <li>Indicates that the FIFO was written while full</li> <li>Overflow would never happen—if it does, this indicates a problem with the way i_valid is being driven</li> <li>Once asserted this bit will hold value until the i_clear_internal_error port is asserted to clear it</li> <li>This bit doesn't need to be polled—o_internal_err will be asserted if this signal goes high.</li> </ul>                                                                                                                     | RO     | 0x0   |
| 23    | err_tx_avst_fifo_empt<br>y     | <ul> <li>TX AVST FIFO ran empty unexpectedly</li> <li>Asserts when the TX FIFO runs empty (regardless of read enable)</li> <li>Does not apply when in MAC Mode</li> <li>Empty should never happen—if it does, this indicates a problem with the way i_valid is being driven</li> </ul>                                                                                                                                                                                                                                                                   | RO     | 0x1   |
| 22    | err_tx_avst_fifo_unde<br>rflow | <ul> <li>TX AVST FIFO Underflow</li> <li>Indicates that the FIFO was read when empty after steady state reading was established</li> <li>Underflow should never happen—if it does, this indicates a problem with the way i_valid is being driven</li> <li>Once asserted this bit will hold value until the i_clear_internal_error port is asserted to clear it, or the TX datapath is reset</li> <li>This bit doesn't need to be polled—o_internal_err will be asserted if this signal goes high.</li> </ul>                                             | RO     | 0x0   |
| 21:16 | tx_dsk_active_chans            | <ul> <li>Active Channels.</li> <li>[n]=1: Corresponding channel is part of the deskew set and has received a deskew marker since reset</li> <li>This is a sticky bit that clears on reset and dsk_clear</li> <li>Use this set of status bits to confirm that channels are receiving deskew markers</li> <li>Remember that single lane channels will only use this when PTP is active, and in that case, will use bits 0 and 4 only</li> <li>Note: This status is for TX EMIB deskew, and has nothing to do with RX skew from the serial line.</li> </ul> | RO     | 0x0   |
| 13:8  | tx_dsk_monitor_err             | <pre>Skew Monitor Error Detected [n]=1: An out-of-alignment EMIB deskew marker was detected on EMIB channel n after deskew • In single lane mode, channels 0 and 4 are used when PTP is active, where channel 4 is the PTP channel • Valid only when tx_dsk_eval_done = 1 • . Note: This status is for TX EMIB deskew, and has nothing to do with RX skew from the serial line.</pre>                                                                                                                                                                    | RO     | 0x0   |
| 3:1   | tx_dsk_status                  | <ul> <li>EMIB Deskew Status</li> <li>0: 0 cycles of delay added to remove TX EMIB skew</li> <li>1: 1 cycle of delay added to remove TX EMIB skew</li> <li>2: 2 cycles of delay added to remove TX EMIB skew</li> <li>3: 3 cycles of delay added to remove TX EMIB skew</li> <li>4: 4 cycles of delay added to remove TX EMIB skew</li> <li>5: 5 cycles of delay added to remove TX EMIB skew</li> <li>6: Reserved</li> </ul>                                                                                                                             | RO     | 0x0   |





| Bit | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Access | Reset |
|-----|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |                  | <ul> <li>7: Deskew Error—too much EMIB skew was detected</li> <li>Valid only when tx_dsk_eval_done = 1</li> <li>When an error is detected, deskew_clear can be used to restart the deskew state machine</li> <li>Note: This status is for TX EMIB deskew, and has nothing to do with RX skew from the serial line.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                            |        |       |
| 0   | tx_dsk_eval_done | <ul> <li>Deskew evaluation is complete <ol> <li>The TX PLD has finished attempting to deskew the EMIB channels connected to EHIP</li> <li>TX PLD is still waiting for enough TX deskew markers to evaluate deskew</li> </ol> </li> <li>Note: Evaluation complete does not mean that deskew was successful; it just means that the deskew state machine has come to a conclusion.</li> <li>This signal is always required for hip_ready for multilane channels unless EMIB channels are deliberately excluded from deskew</li> <li>For single lane channels, this signal is only needed when using PTP</li> <li>Note: This deskew is has nothing to do with RX PCS deskew or the serial input.</li> </ul> | RO     | 0x0   |

# 2.12.2.23. Status for Dynamic Deskew Buffer

Offset: 0x354

## **Status for Dynamic Deskew Buffer Fields**

| Bit   | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Access | Reset |
|-------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 16    | err_skew     | <ul> <li>Dynamic Deskew Buffer overflow <ol> <li>At least one lane of the Dynamic Deskew Buffer overflowed sometime in the past since the last time it was reset</li> <li>Once asserted, the value will hold until the you clears it using the i_clear_internal_err port, or by resetting the RX datapath</li> <li>The dynamic deskew buffer should be cleared by deasserting i_signal_ok, or by resetting the RX datapath</li> <li>When a dynamic deskew buffer overflows, RX data is lost, which can cause packets to be lost, and frame errors</li> <li>Even if no packets are lost, and the channel maintains integrity, an overflow should never happen, and is a sign that something in the channel did not follow the specification</li> </ol></li></ul> | RO     | 0x0   |
| 15:12 | err_overflow | <b>Per lane Dynamic Deskew Buffer overflow indicator</b> [n]=1: The dynamic deskew buffer for lane n overflowed sometime in the past since the last time it was reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RO     | 0x0   |
|       |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | contin | ued   |



| Bit  | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Access | Reset |
|------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|      |            | <ul> <li>Once asserted, the value will hold until you clear it using the i_clear_internal_err port, or by resetting the RX datapath</li> <li>The dynamic deskew buffer should be cleared by deasserting i_signal_ok, or by resetting the RX datapath</li> <li>When a dynamic deskew buffer overflows, RX data is lost, which can cause packets to be lost, and frame errors</li> <li>Even if no packets are lost, and the channel maintains integrity, an overflow should never happen, and is a sign that something in the channel did not follow the specification</li> </ul> |        |       |
| 11:8 | rd_numdata | <ul> <li>Per lane Dynamic Deskew Buffer Almost Full [n]=1: The occupancy of the dynamic deskew buffer in lane n has exceeded the watermark set by rxpma_max_skew</li> <li>Valid only for lanes actually in used by a multi-lane EHIP core</li> <li>Exceeding the watermark doesn't indicate an error, but may be a sign that the a problem in the past is now limiting the amount of skew variation the core can tolerate</li> </ul>                                                                                                                                            | RO     | 0x0   |

# 2.12.2.24. Configuration for RX PLD Block

## Offset: 0x355

## **Configuration for RX PLD Block Fields**

| 4 s   | sel_50gx2    | Select 50Gx2 mode<br>• 0: Use 4 EMIB channels for data output                                                                                                                                                                                                                                                                                                                                     | RW | 0x0 |
|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
|       |              | <ul> <li>1: Use 2 EMIB channels for data output</li> <li>The RX datapath must be reset after changing this field.</li> <li>Defaults to 0 after power up</li> <li>After i_csr_rst_n, default value depends on the Select Ethernet Rate parameter <ul> <li>When Select Ethernet Rate = 100G, sel_50gx2 = 0</li> </ul> </li> <li>The RX datapath must be reset after changing this field.</li> </ul> |    |     |
| 3 v   | use_lane_ptp | <ul> <li>Select the input for the PTP channels</li> <li>Valid for multilane EHIP (ehip_core) only</li> <li>0: PTP RX data comes from EHIP core</li> <li>1: PTP RX data comes from connected EHIP lanes</li> <li>Default value after power up and i_csr_rst is 0</li> </ul>                                                                                                                        | RW | 0x0 |
| 2:0 r | rx_ehip_mode | <ul> <li>Select RX Port map</li> <li>Selects how data from the EHIP is presented through the EMIB</li> <li>3h0: MAC interface</li> <li>3h1: MAC interface with PTP</li> <li>3h2: PCS (MII) interface</li> <li>3h3: PCS66 interface for OTN (forced descrambler bypass)</li> <li>3h4: PCS66 interface (descrambler optional)</li> </ul>                                                            | RW | 0x0 |





| Bit | Name | Description                                                                                                                                  | Access | Reset |
|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>After power up, defaults to 0</li> <li>After i_csr_rst_n, default depends on the Select<br/>Ethernet IP Layers parameter</li> </ul> |        |       |
|     |      | <ul> <li>When eSelect Ethernet IP Layers = MAC+PCS,<br/>rx_ehip_mode = 3'd0</li> </ul>                                                       |        |       |
|     |      | <ul> <li>When Select Ethernet IP Layers = PCS-only,<br/>rx_ehip_mode = 3'd2</li> </ul>                                                       |        |       |
|     |      | <ul> <li>When Select Ethernet IP Layers = FlexE PHY,<br/>rx_ehip_mode = 3'd4</li> </ul>                                                      |        |       |
|     |      | <ul> <li>When eSelect Ethernet IP Layers = OTN PHY,<br/>rx_ehip_mode = 3'd3</li> </ul>                                                       |        |       |

# 2.12.2.25. Configuration for RX PCS

Offset: 0x360

# **Configuration for RX PCS Fields**

| Bit   | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Access       | Reset      |
|-------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------|
| 20    | use_hi_ber_monitor | <ul> <li>Enable Hi-BER Monitor</li> <li>0: Turn off Hi-BER monitor</li> <li>1: Turn on Hi-BER monitor</li> <li>The Hi-BER monitor is turned on by default because it is used for standard compliance</li> <li>Hi-BER is needed to support Auto-Negotiation, and is generally used to report poor link conditions</li> <li>When the Hi-BER monitor is turned on, if a Hi-BER condition is detected, the PCS will replace incoming data with Local Fault blocks</li> <li>Disable the Hi-BER monitor if you need to monitor RX data while in a Hi-BER state</li> <li>At power-on, this register defaults to 0</li> <li>After i_csr_rst_n is asserted, the register is set to the value given by the hi_ber_monitor module parameter</li> </ul> | RW           | 0x0        |
| 19:14 | rx_pcs_max_skew    | <ul> <li>Sets the maximum skew allowed by the RX PCS deskew logic</li> <li>This parameter is set by default to the maximum safe limit for RX PCS deskew, which is higher than the value required by the Ethernet Standard</li> <li>The max skew can be lowered for testing</li> <li>Raising the max skew beyond the default can be dangerous, since some of the margin left by the limit is used to absorb dynamically changing induced skews due to the operation of the internal PCS logic</li> <li>At power-on, this register defaults to 6'h3F</li> <li>When i_csr_rst_n is asserted, this register is set to the value given by the rx_pcs_max_skew module parameter</li> </ul>                                                        | RW           | 0x3F       |
| 13:0  | am_interval        | Expected interval between Alignment markers per<br>Virtual lane                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RW<br>contin | 0x3F<br>FF |





| Bit | Name | Description                                                                                                                                                                                      | Access | Reset |
|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>This register is used only for multilane RX alignment. It<br/>is not used when RS-FEC is active, or for single lane<br/>channels</li> </ul>                                             |        |       |
|     |      | <ul> <li>The interval is set by default to the number of valid<br/>blocks per virtual lane between alignment marker blocks<br/>required by the Ethernet Standard</li> </ul>                      |        |       |
|     |      | <ul> <li>For 100G links, RX alignment interval is TX alignment<br/>period/5</li> </ul>                                                                                                           |        |       |
|     |      | <ul> <li>Alignment interval can be reduced to the time required<br/>to link (especially in simulation), but it is critical that<br/>both sides of the link have compatible AM spacing</li> </ul> |        |       |
|     |      | <ul> <li>The RX PCS must be reset using i_signal_ok, RX<br/>datapath reset, or RX PCS reset, after changing this<br/>register</li> </ul>                                                         |        |       |
|     |      | <ul> <li>At power-on, this is set to 14'h3FFF;</li> </ul>                                                                                                                                        |        |       |
|     |      | <ul> <li>After i_csr_rst_n, if the module parameter<br/>sim_mode is enabled, this parameter is set to a sim<br/>mode value appropriate for the selected rate</li> </ul>                          |        |       |
|     |      | <ul> <li>After i_csr_rst_n, if the module parameter<br/>sim_mode is disabled, this parameter is set to mission<br/>mode value appropriate for the selected rate</li> </ul>                       |        |       |

# 2.12.2.26. BIP Counter 0

Offset: 0x361

### **BIP Error Count from RX Virtual Lane 0 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                         | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                                                                                                                                                                                         | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane.                                                                                                                                                                 |        |       |
|      |       | <ul> <li>Used only for multilane Ethernet links</li> </ul>                                                                                                                                                          |        |       |
|      |       | <ul> <li>Increments for a given virtual lane when the BIP<br/>calculated over all the data received since the last<br/>alignment marker does not match the BIP value in the<br/>current Alignment Marker</li> </ul> |        |       |
|      |       | Valid only after Alignment Marker lock                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> </ul>                                                                                                                                                       |        |       |
|      |       | Can be captured by snapshot or RX Shadow request                                                                                                                                                                    |        |       |
|      |       | <ul> <li>Resets on RX datapath reset (i_rx_rst_n)</li> <li>RX Stats Reset CSR does not reset this counter</li> </ul>                                                                                                |        |       |

# 2.12.2.27. BIP Counter 1

Offset: 0x362

### **BIP Error Count from RX Virtual Lane 1 Fields**

| Bit  | Name  | Description | Access | Reset |
|------|-------|-------------|--------|-------|
| 15:0 | count | BIP Counter | RO     | 0x0   |





| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> <li>Valid only after Alignment Marker lock</li> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> <li>RX Stats Reset CSR does not reset this counter</li> </ul> |        |       |

## 2.12.2.28. BIP Counter 2

### Offset: 0x363

### **BIP Counter 2 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Access | Reset |
|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | <ul> <li>BIP Counter</li> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multi-lane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> <li>Valid only after Alignment Marker lock</li> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX Datapath Reset (i_rx_rst_n)</li> <li>RX Stats Reset CSR does not reset this counter</li> </ul> | RO     | 0x0   |

## 2.12.2.29. BIP Counter 3

Offset: 0x364

#### **BIP Counter 3 Fields**

| Bit  | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Access | Reset |
|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | <ul> <li>BIP Counter</li> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> <li>Valid only after Alignment Marker lock</li> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul> | RO     | 0x0   |
|      |       | RX Stats Reset CSR does not reset this counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |       |



# 2.12.2.30. BIP Counter 4

Offset: 0x365

### **BIP Counter 4 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                         | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                                                                                                                                                                                         | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane.                                                                                                                                                                 |        |       |
|      |       | Used only for multilane Ethernet links                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Increments for a given virtual lane when the BIP<br/>calculated over all the data received since the last<br/>alignment marker does not match the BIP value in the<br/>current Alignment Marker</li> </ul> |        |       |
|      |       | Valid only after Alignment Marker lock                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> </ul>                                                                                                                                                       |        |       |
|      |       | Can be captured by snapshot or RX Shadow request                                                                                                                                                                    |        |       |
|      |       | <ul> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul>                                                                                                                                                        |        |       |
|      |       | RX Stats Reset CSR does not reset this counter                                                                                                                                                                      |        |       |

## 2.12.2.31. BIP Counter 5

Offset: 0x366

## **BIP Counter 5 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                         | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                                                                                                                                                                                         | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane.                                                                                                                                                                 |        |       |
|      |       | <ul> <li>Used only for multilane Ethernet links</li> </ul>                                                                                                                                                          |        |       |
|      |       | <ul> <li>Increments for a given virtual lane when the BIP<br/>calculated over all the data received since the last<br/>alignment marker does not match the BIP value in the<br/>current Alignment Marker</li> </ul> |        |       |
|      |       | Valid only after Alignment Marker lock                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> </ul>                                                                                                                                                       |        |       |
|      |       | Can be captured by snapshot or RX Shadow request                                                                                                                                                                    |        |       |
|      |       | <ul><li>Resets on RX datapath reset (i_rx_rst_n)</li><li>RX Stats Reset CSR does not reset this counter</li></ul>                                                                                                   |        |       |

## 2.12.2.32. BIP Counter 6

Offset: 0x367

#### **BIP Counter 6 Fields**

| Bit  | Name  | Description                                         | Access | Reset |
|------|-------|-----------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                         | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane. |        |       |





| Bit | Name | Description                                                                                                                                                                                                                                                                                             | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> <li>Valid only after Alignment Marker lock</li> </ul> |        |       |
|     |      | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> <li>RX Stats Reset CSR does not reset this counter</li> </ul>                                                                       |        |       |

## 2.12.2.33. BIP Counter 7

Offset: 0x368

### **BIP Counter 7 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                         | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                                                                                                                                                                                         | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane.<br>• Used only for multilane Ethernet links                                                                                                                     |        |       |
|      |       | <ul> <li>Increments for a given virtual lane when the BIP<br/>calculated over all the data received since the last<br/>alignment marker does not match the BIP value in the<br/>current Alignment Marker</li> </ul> |        |       |
|      |       | Valid only after Alignment Marker lock                                                                                                                                                                              |        |       |
|      |       | Rolls over at max count (2^16 BIP errors)                                                                                                                                                                           |        |       |
|      |       | <ul> <li>Can be captured by snapshot or RX Shadow request</li> </ul>                                                                                                                                                |        |       |
|      |       | <ul> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul>                                                                                                                                                        |        |       |
|      |       | RX Stats Reset CSR does not reset this counter                                                                                                                                                                      |        |       |

## 2.12.2.34. BIP Counter 8

Offset: 0x369

## **BIP Counter 8 Fields**

| Bit  | Name  | Description                                                                                                                                                                                                         | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                                                                                                                                                                                         | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane.                                                                                                                                                                 |        |       |
|      |       | Used only for multilane Ethernet links                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Increments for a given virtual lane when the BIP<br/>calculated over all the data received since the last<br/>alignment marker does not match the BIP value in the<br/>current Alignment Marker</li> </ul> |        |       |
|      |       | Valid only after Alignment Marker lock                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> </ul>                                                                                                                                                       |        |       |
|      |       | Can be captured by snapshot or RX Shadow request                                                                                                                                                                    |        |       |
|      |       | <ul> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul>                                                                                                                                                        |        |       |
|      |       | RX Stats Reset CSR does not reset this counter                                                                                                                                                                      |        |       |



# 2.12.2.35. BIP Counter 9

Offset: 0x36A

### **BIP Counter 9 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                           | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                                                                                                                                                           | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane.                                                                                                                                   |        |       |
|      |       | <ul> <li>Used only for multilane Ethernet links</li> </ul>                                                                                                                            |        |       |
|      |       | • Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker |        |       |
|      |       | Valid only after Alignment Marker lock                                                                                                                                                |        |       |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> </ul>                                                                                                                         |        |       |
|      |       | Can be captured by snapshot or RX Shadow request                                                                                                                                      |        |       |
|      |       | <ul> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul>                                                                                                                          |        |       |
|      |       | RX Stats Reset CSR does not reset this counter                                                                                                                                        |        |       |

## 2.12.2.36. BIP Counter 10

Offset: 0x36B

## **BIP Counter 10 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                         | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                                                                                                                                                                                         | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane.                                                                                                                                                                 |        |       |
|      |       | <ul> <li>Used only for multilane Ethernet links</li> </ul>                                                                                                                                                          |        |       |
|      |       | <ul> <li>Increments for a given virtual lane when the BIP<br/>calculated over all the data received since the last<br/>alignment marker does not match the BIP value in the<br/>current Alignment Marker</li> </ul> |        |       |
|      |       | Valid only after Alignment Marker lock                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> </ul>                                                                                                                                                       |        |       |
|      |       | Can be captured by snapshot or RX Shadow request                                                                                                                                                                    |        |       |
|      |       | <ul> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul>                                                                                                                                                        |        |       |
|      |       | RX Stats Reset CSR does not reset this counter                                                                                                                                                                      |        |       |

## 2.12.2.37. BIP Counter 11

Offset: 0x36C

#### **BIP Counter 11 Fields**

| Bit  | Name  | Description | Access | Reset |   |
|------|-------|-------------|--------|-------|---|
| 15:0 | count | BIP Counter | RO     | 0x0   | ĺ |





| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> <li>Valid only after Alignment Marker lock</li> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> <li>RX Stats Reset CSR does not reset this counter</li> </ul> |        |       |

## 2.12.2.38. BIP Counter 12

Offset: 0x36D

## **BIP Counter 12 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                                                                                                                                                                                               | Access | Reset |
|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | <ul> <li>BIP Counter</li> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> <li>Valid only after Alignment Marker lock</li> </ul> | RO     | 0x0   |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> <li>RX Stats Reset CSR does not reset this counter</li> </ul>                                                                                                                                                         |        |       |

# 2.12.2.39. BIP Counter 13

Offset: 0x36E

### **BIP Counter 13 Fields**

| <ul> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> </ul> | Bit  | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Access | Reset |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| <ul> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> <li>RX Stats Reset CSR does not reset this counter</li> </ul>                                                                                    | 15:0 | count | <ul> <li>BIP Counter</li> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> <li>Valid only after Alignment Marker lock</li> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul> |        | 0x0   |



# 2.12.2.40. BIP Counter 14

Offset: 0x36F

### **BIP Counter 14 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                         | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                                                                                                                                                                                         | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane.                                                                                                                                                                 |        |       |
|      |       | Used only for multilane Ethernet links                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Increments for a given virtual lane when the BIP<br/>calculated over all the data received since the last<br/>alignment marker does not match the BIP value in the<br/>current Alignment Marker</li> </ul> |        |       |
|      |       | Valid only after Alignment Marker lock                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> </ul>                                                                                                                                                       |        |       |
|      |       | Can be captured by snapshot or RX Shadow request                                                                                                                                                                    |        |       |
|      |       | <ul> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul>                                                                                                                                                        |        |       |
|      |       | RX Stats Reset CSR does not reset this counter                                                                                                                                                                      |        |       |

## 2.12.2.41. BIP Counter 15

Offset: 0x370

## **BIP Counter 15 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                         | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                                                                                                                                                                                         | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane.                                                                                                                                                                 |        |       |
|      |       | <ul> <li>Used only for multilane Ethernet links</li> </ul>                                                                                                                                                          |        |       |
|      |       | <ul> <li>Increments for a given virtual lane when the BIP<br/>calculated over all the data received since the last<br/>alignment marker does not match the BIP value in the<br/>current Alignment Marker</li> </ul> |        |       |
|      |       | Valid only after Alignment Marker lock                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> </ul>                                                                                                                                                       |        |       |
|      |       | Can be captured by snapshot or RX Shadow request                                                                                                                                                                    |        |       |
|      |       | <ul> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul>                                                                                                                                                        |        |       |
|      |       | RX Stats Reset CSR does not reset this counter                                                                                                                                                                      |        |       |

## 2.12.2.42. BIP Counter 16

Offset: 0x371

#### **BIP Counter 16 Fields**

| Bit  | Name  | Description | Access | Reset |   |
|------|-------|-------------|--------|-------|---|
| 15:0 | count | BIP Counter | RO     | 0x0   | ĺ |





| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> <li>Valid only after Alignment Marker lock</li> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> <li>RX Stats Reset CSR does not reset this counter</li> </ul> |        |       |

## 2.12.2.43. BIP Counter 17

Offset: 0x372

## **BIP Counter 17 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                                                                                                                                                                                               | Access | Reset |
|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | <ul> <li>BIP Counter</li> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> <li>Valid only after Alignment Marker lock</li> </ul> | RO     | 0x0   |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> <li>RX Stats Reset CSR does not reset this counter</li> </ul>                                                                                                                                                         |        |       |

# 2.12.2.44. BIP Counter 18

Offset: 0x373

### **BIP Counter 18 Fields**

| <ul> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> </ul> | Bit  | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Access | Reset |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| <ul> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> <li>RX Stats Reset CSR does not reset this counter</li> </ul>                                                                                    | 15:0 | count | <ul> <li>BIP Counter</li> <li>Shows current BIP count for corresponding PCS lane.</li> <li>Used only for multilane Ethernet links</li> <li>Increments for a given virtual lane when the BIP calculated over all the data received since the last alignment marker does not match the BIP value in the current Alignment Marker</li> <li>Valid only after Alignment Marker lock</li> <li>Rolls over at max count (2^16 BIP errors)</li> <li>Can be captured by snapshot or RX Shadow request</li> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul> |        | 0x0   |



# 2.12.2.45. BIP Counter 19

Offset: 0x374

### **BIP Counter 19 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                         | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | count | BIP Counter                                                                                                                                                                                                         | RO     | 0x0   |
|      |       | Shows current BIP count for corresponding PCS lane.                                                                                                                                                                 |        |       |
|      |       | <ul> <li>Used only for multilane Ethernet links</li> </ul>                                                                                                                                                          |        |       |
|      |       | <ul> <li>Increments for a given virtual lane when the BIP<br/>calculated over all the data received since the last<br/>alignment marker does not match the BIP value in the<br/>current Alignment Marker</li> </ul> |        |       |
|      |       | Valid only after Alignment Marker lock                                                                                                                                                                              |        |       |
|      |       | <ul> <li>Rolls over at max count (2^16 BIP errors)</li> </ul>                                                                                                                                                       |        |       |
|      |       | Can be captured by snapshot or RX Shadow request                                                                                                                                                                    |        |       |
|      |       | <ul> <li>Resets on RX datapath reset (i_rx_rst_n)</li> </ul>                                                                                                                                                        |        |       |
|      |       | RX Stats Reset CSR does not reset this counter                                                                                                                                                                      |        |       |

# 2.12.2.50. Timer Window for Hi-BER Checks

## Offset: 0x37A

## **Timer Window for Hi-BER Checks Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name   | Description                                                                                                                                                                                                        | Access | Reset       |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------|
| 20:0 | cycles | Timer window for BER measurements<br>Sets the timer window for BER measurements in clock                                                                                                                           | RW     | 0x31<br>2C7 |
|      |        | cycles.                                                                                                                                                                                                            |        | 207         |
|      |        | The Ethernet Standard (IEEE 802.3) defines the required times for Hi-BER measurements for each rate. These times must be converted to clock cycles with accurate within $+1\%$ and $-25\%$ of the specified times. |        |             |
|      |        | <i>Note:</i> The clock rate you are using is different from the clock rate used to calculate the cycle count, you will need to scale the cycle count.                                                              |        |             |
|      |        | • 100GBASE-R4: 21'd201415 (from Clause 82, 0.5ms<br>+1%,-25% at 402.3 MHz                                                                                                                                          |        |             |
|      |        | • 25GBASE-R1: 21'd806451 (from Clause 107, 2.0 ms<br>+1%, -25% at 402.3 MHz                                                                                                                                        |        |             |
|      |        | • 10GBASE-R1: 21'd20141 (from Clause 49, 0.125ms<br>+1%, -25% at 161.13 MHz                                                                                                                                        |        |             |
|      |        | • 10GBASE-R1: 21'd50403 (from Clause 49, 0.125ms<br>+1%, -25% at 402.83 MHz                                                                                                                                        |        |             |
|      |        | The RX PCS must be reset after changing this value.                                                                                                                                                                |        |             |

### 2.12.2.51. Hi-BER Frame Errors

Offset: 0x37B





### **Hi-BER Frame Errors Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name  | Description                                                                                                                                                                                                                                                                                                                                                | Access | Reset |
|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 6:0 | count | <pre>Hi-BER Frame Errors Sets the BER count that triggers hi_ber. The Ethernet Standard (IEEE 802.3) defines the appropriate setting for ber_invalid_count based on rate.     100GBASE-R4: 7'd97 (from Clause 82)     25GBASE-R1: 7'd97 (from Clause 107)     10GBASE-R1: 7'd16 (from Clause 49) The RX PCS must be reset after changing this value.</pre> | RW     | 0x61  |

## 2.12.2.52. Error Block Count

Offset: 0x37C

### **Error Block Count Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Access | Reset |
|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 31:0 | count | <ul> <li>Error block count</li> <li>Counts the number of Error blocks produced by the RX PCS Decoder</li> <li>Valid only when the RX PCS Decoder is used and either alignment is achieved or alignment is not used and i_signal_ok = 1</li> <li>Error blocks can be received from the remote link, or generated by violations of the Ethernet Standard 64B66B encoding specification</li> <li>The counter is 32b wide and rolls over when the max count is reached</li> <li>The counter's output can be frozen while still incrementing using i_snapshot or rx_shadow_req. Snapshot/rx_shadow_req is recommended for all reads, since the counter is wider than 1 byte</li> <li>The counter is reset when i_signal_ok = 0, the RX datapath is reset, or the RX PCS is reset</li> </ul> | RO     | 0x0   |

## 2.12.2.53. Deskew Depth 0

Offset: 0x37F

### **Deskew Depth 0 Fields**

| Bit   | Name   | Description                                   | Access | Reset |
|-------|--------|-----------------------------------------------|--------|-------|
| 29:24 | depth4 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 23:18 | depth3 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 17:12 | depth2 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 11:6  | depth1 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 5:0   | depth0 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |





# 2.12.2.54. Deskew Depth 1

### Offset: 0x380

### **Deskew Depth 1 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit   | Name   | Description                                   | Access | Reset |
|-------|--------|-----------------------------------------------|--------|-------|
| 29:24 | depth4 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 23:18 | depth3 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 17:12 | depth2 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 11:6  | depth1 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 5:0   | depth0 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |

## 2.12.2.55. Deskew Depth 2

### Offset: 0x381

### **Deskew Depth 2 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit   | Name   | Description                                   | Access | Reset |
|-------|--------|-----------------------------------------------|--------|-------|
| 29:24 | depth4 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 23:18 | depth3 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 17:12 | depth2 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 11:6  | depth1 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 5:0   | depth0 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |

## 2.12.2.56. Deskew Depth 3

Offset: 0x382

### **Deskew Depth 3 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit   | Name   | Description                                   | Access | Reset |
|-------|--------|-----------------------------------------------|--------|-------|
| 29:24 | depth4 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 23:18 | depth3 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 17:12 | depth2 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 11:6  | depth1 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |
| 5:0   | depth0 | Deskew depth for one of the PCS Virtual lanes | RO     | 0x0   |

# 2.12.2.57. RX PCS Test Error Count





#### **RX PCS Test Error Count Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name  | Description                                                                           | Access | Reset |
|------|-------|---------------------------------------------------------------------------------------|--------|-------|
| 31:0 | count | <b>RX PCS Test Error Count</b><br>The register is reset by resetting the RX datapath. | RO     | 0x0   |

# 2.12.3. TX MAC Registers

## 2.12.3.1. TX MAC Module Revision ID

Offset: 0x400

### **TX MAC Module Revision ID Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name | Description                                                   | Access | Reset |
|------|------|---------------------------------------------------------------|--------|-------|
| 31:0 | id   | Revision ID                                                   | RO     | 0x11  |
|      |      | 32b Revision ID for the module                                |        | 1120  |
|      |      | Returns a 4 byte value indicating the revision of this design |        | 15    |

# 2.12.3.2. TX MAC Scratch Register

Offset: 0x401

#### **TX MAC Scratch Register Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name    | Description                                   | Access | Reset |
|------|---------|-----------------------------------------------|--------|-------|
| 31:0 | scratch | 32 bits of scratch register space for testing | RW     | 0x0   |

## 2.12.3.3. Link Fault Configuration

Offset: 0x405

#### **Link Fault Configuration Fields**

| Bit | Name       | Description                                                                                                                                                                                                                                                                            | Access | Reset |
|-----|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 3   | force_rf   | Force the TX MAC to transmit Remote Faults when<br>link fault signaling is on<br>1: TX MAC transmits Remote Faults<br>0: TX MAC operates normally                                                                                                                                      | RW     | 0x0   |
| 2   | disable_rf | <ul> <li>Send idles instead of remote faults for local faults in unidirectional mode</li> <li>1: In unidirectional mode, local faults cause the TX to transmit Idles</li> <li>0: In unidirectional mode, local faults cause the TX to transmit Remote Faults (spec default)</li> </ul> | RW     | 0x0   |
| 1   | en_unidir  | Enable Unidirectional Link Fault                                                                                                                                                                                                                                                       | RW     | 0x0   |
|     |            | '                                                                                                                                                                                                                                                                                      | contin | ued   |



| Bit | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                           | Access | Reset |
|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |       | <ol> <li>EHIP enables support for unidirectional link fault<br/>signaling as described in Clause 66 Remote faults will have<br/>no impact on TX data, and Local faults will cause the TX to<br/>transmit Remote fault Ordered sets between frames</li> <li>After power-on, en_unidir is set to 0</li> <li>After i_csr_rst_n, en_unidir is set according to the<br/>module parameter <u>link_fault_mode</u></li> </ol> |        |       |
| 0   | en_lf | <ul> <li>Enable Link Fault Reporting</li> <li>1: The TX PCS will transmit link fault messages based on link faults detected by the RX</li> <li>After power-on, en_If is set to 1'b1</li> <li>After i_csr_rst_n, en_If is set according to the module parameter link fault mode</li> </ul>                                                                                                                             | RW     | 0x1   |
|     |       | parameter link fault mode<br>0: The TX PCS will not respond to link faults                                                                                                                                                                                                                                                                                                                                            |        |       |

# 2.12.3.4. IPG Words to remove per Alignment Marker Period

## Offset: 0x406

### **IPG Words to remove per Alignment Marker Period Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | ipg_col_rem | <ul> <li>IPG_COL_REM</li> <li>16b value that sets the number of IPG words that will be removed during an alignment marker period for a fully occupied link to make space for alignment markers. This parameter can also be used to scale IPG in ppm increments for rate balance.</li> <li>After power-on, ipg_col_rem is set to 16'd20</li> <li>After i_cfg_rst_n, ipg_col_rem is set to the standard value required for the selected line rate, plus the value of the module parameter ipg_removed_per_am_period.</li> </ul> | RW     | 0x14  |

# 2.12.3.5. Maximum TX Frame Size

Offset: 0x407

### **Maximum TX Frame Size Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name   | Description                                                                                                                                                                                                                                                                                                                                             | Access | Reset      |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | max_tx | <ul> <li>MAX_TX_SIZE_CONFIG</li> <li>16 bits value that sets the maximum TX frame size. When TX frames exceed this size, the CNTR_TX_OVERSIZE statistic is incremented</li> <li>After power-up, max_tx is set to 16'd9600</li> <li>After i_csr_rst_n is asserted, max_tx is set to the value given by the module parameter tx max frame size</li> </ul> | RW     | 0x25<br>80 |

## 2.12.3.6. TX MAC Configuration

Offset: 0x40A





### **TX MAC Configuration Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name            | Description                                                                                                                                                                                                                                                                                                                                                                                | Access | Reset |
|-----|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 3   | en_saddr_insert | <pre>Enable Source Address Insertion 0: Client provides Source Address 1: TX MAC inserts source addresses stored in CSRs • At power-up, en_saddr_insert is set to 0 • After i_csr_rst_n, en_saddr_insert is set to the value given by source_address_insertion</pre>                                                                                                                       | RW     | 0x0   |
| 2   | disable_txmac   | <b>Disable TX MAC</b><br>0: TX MAC operates normally<br>1: TX MAX is disabled - it behaves as though it has been<br>PAUSED by the remote link until disable is turned off                                                                                                                                                                                                                  | RW     | 0x0   |
| 1   | disable_txvlan  | <ul> <li>Disable VLAN detection for TX Stats</li> <li>0: TX frames with VLAN headers will be counted as VLAN frames in the TX stats</li> <li>1: VLAN headers will not be considered by the TX stats block</li> <li>At power-on, disable_txvlan is set to 1</li> <li>After i_csr_rst_n is asserted, disable_vlan is set to the value given by module parameter tx_vlan_detection</li> </ul> | RW     | 0x0   |

## 2.12.3.7. EHIP TX MAC Feature Configuration

#### Offset: 0x40B

## **EHIP TX MAC Feature Configuration Fields**

| Bit   | Name                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Access | Reset       |
|-------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------|
| 31:15 | am_period             | <ul> <li>TX Alignment Marker Period</li> <li>Sets the number of TX clock cycles that are used to send regular data between Alignment Markers</li> <li>At power-on, this is set to 17'd81915</li> <li>After i_csr_rst_n, if the module parameter sim_mode is enabled, this parameter is set to a simulation mode value appropriate for the selected rate</li> <li>After i_csr_rst_n, if the module parameter sim_mode is disabled, this parameter is set to mission mode value appropriate for the selected rate</li> </ul> | RW     | 0x13<br>FFB |
| 9     | txcrc_covers_preamble | <ul> <li>Enable CRC over preamble</li> <li>0: TX CRC calculated over Ethernet Frame (default)</li> <li>1: TX CRC calculated over frame plus preamble</li> <li>At power-on, txcrc_covers_preamble is set to 0</li> <li>After i_csr_rst_n is asserted,<br/>txcrc_covers_preamble is set to the value given by<br/>module parameter txcrc_covers_preamble</li> </ul>                                                                                                                                                          | RW     | 0x0         |
| 8:6   | flowreg_rate          | Sets the valid toggle rate of the TX MAC flow<br>regulator<br>0: 100G<br>1: Reserved<br>2: Reserved<br>3:25G                                                                                                                                                                                                                                                                                                                                                                                                               | RW     | 0x0         |
|       | •                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | contin | ued         |



| Bit | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |          | 4:10G<br>5: Reserved<br>6: Reserved<br>7: Use custom cadence                                                                                                                                                                                                                                                                                                                                                                  |        |       |
| 5:3 | am_width | <ul> <li>Sets the number of cycles for each AM pulse</li> <li>Sets the number of TX clock cycle that the AM pulse is held high</li> <li>After power-up, am_width is set to 5</li> <li>After i_csr_rst_n is asserted, am_width is set according to the rate of the channel</li> <li>Set to 5 for 100G channels</li> <li>Set to 4 for 25G channels that use RS-FEC</li> <li>Set to 1 for all other types of channels</li> </ul> | RW     | 0x5   |
| 2:1 | ipg      | <ul> <li>DIC Average Min IPG</li> <li>Sets the average minimum IPG enforced by the Deficit Idle Counter: <ul> <li>2'd0: 12 bytes (default)</li> <li>2'd1:10 bytes</li> <li>2'd2:8 bytes</li> <li>2'd3:1 byte</li> <li>After power-up, ipg is set to 0 (12 bytes)</li> </ul> </li> <li>After i_csr_rst_n is asserted, ipg is set to the value given by the module parameter tx_ipg_size</li> </ul>                             | RW     | 0x0   |
| 0   | en_pp    | <ul> <li>Enable TX Preamble Passthrough</li> <li>1: Preamble-passthrough mode enabled - bytes 1 to 7 of each SOP word will be used as preamble bytes at the start of the Ethernet packet</li> <li>0: A standard Ethernet preamble will be used for TX packets</li> </ul>                                                                                                                                                      | RW     | 0x0   |

# 2.12.3.8. TX MAC Source Address Lower Bytes

Offset: 0x40C

### **TX MAC Source Address Lower Bytes Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name   | Description                                                                                                              | Access | Reset      |
|------|--------|--------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 31:0 | saddrl | Source Address Insertion Source Address lower bytes                                                                      | RW     | 0x22       |
|      |        | Lower 4 bytes of the 6 byte source address that is inserted<br>by the TX MAC when TX source address insertion is enabled |        | 3344<br>55 |
|      |        | • At power-on, saddrl is set to 1                                                                                        |        |            |
|      |        | • After i_csr_rst_n is asserted, saddrl is set to the value given by module parameter txmac_saddr[31:0]                  |        |            |

# 2.12.3.9. TX MAC Source Address Higher Bytes

Offset: 0x40D





### **TX MAC Source Address Higher Bytes Fields**

| The reset values in this table represents register values after a reset has completed. |  |
|----------------------------------------------------------------------------------------|--|
|----------------------------------------------------------------------------------------|--|

| Bit  | Name   | Description                                                                                                                                                                                                                                                                                                                                                                 | Access | Reset |
|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | saddrh | <ul> <li>Source Address Insertion Source Address upper bytes</li> <li>Upper 2 bytes of the 6 byte source address that is inserted<br/>by the TX MAC when TX source address insertion is enabled</li> <li>At power-on, saddrh is set to 1</li> <li>After i_csr_rst_n is asserted, saddrh is set to the<br/>value given by module parameter<br/>txmac_saddr[47:32]</li> </ul> | RW     | 0x11  |

# **2.12.4. RX MAC Registers**

## 2.12.4.1. RX MAC Module Revision ID

### Offset: 0x500

#### **RX MAC Module Revision ID Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name | Description                                                                                     | Access | Reset      |
|------|------|-------------------------------------------------------------------------------------------------|--------|------------|
| 31:0 | id   | Revision ID                                                                                     | RO     | 0x11       |
|      |      | 32b Revision ID for the module<br>Returns a 4 byte value indicating the revision of this design |        | 1120<br>15 |

## 2.12.4.2. RX MAC Scratch Register

Offset: 0x501

#### **RX MAC Scratch Register Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name    | Description                                   | Access | Reset |
|------|---------|-----------------------------------------------|--------|-------|
| 31:0 | scratch | 32 bits of scratch register space for testing | RW     | 0x0   |

### 2.12.4.3. Maximum RX Frame Size

Offset: 0x506

### **Maximum RX Frame Size Fields**

| Bit  | Name   | Description                                                                                                                                                                                                                                                                                                                                                              | Access | Reset      |  |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|--|
| 15:0 | max_rx | MAX_RX_SIZE_CONFIG<br>16b value that sets the maximum RX frame size. When RX<br>frames exceed this size, the CNTR_RX_OVERSIZE statistic<br>is incremented, and the appropriate rx_error bit is<br>asserted with EOP on the frame to indicate the frame is<br>oversize<br>Sets the maximum size of a RX frame in octets before it will<br>be counted as an oversize frame | RW     | 0x25<br>80 |  |





| Bit | Name | Description                                                                                                                                                           | Access | Reset |
|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>When enforce_max_frame_size is enabled, frames<br/>longer than max_rx will be truncated on arrival, and<br/>marked as oversize, with an FCS error</li> </ul> |        |       |
|     |      | <ul> <li>After power-up, max_rx is set to 16'd9600</li> </ul>                                                                                                         |        |       |
|     |      | <ul> <li>After i_csr_rst_n, max_rx is set to the value given<br/>by the module parameter RX maximum frame size</li> </ul>                                             |        |       |

# 2.12.4.4. RX CRC Forwarding

Offset: 0x507

## **RX CRC Forwarding Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name           | Description                                                 | Access | Reset |
|-----|----------------|-------------------------------------------------------------|--------|-------|
| 0   | forward_rx_crc | Forward RX CRC values 0: Remove CRC from RX frames          | RW     | 0x0   |
|     |                | 1: Leave CRC in RX frames and forward it to RX Client logic |        |       |

# 2.12.4.5. Link Fault Status

Offset: 0x508

### **Link Fault Status Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name   | Description                                              | Access | Reset |
|-----|--------|----------------------------------------------------------|--------|-------|
| 1   | rfault | Remote Fault detected<br>1: EHIP detected a remote fault | RO     | 0x0   |
| 0   | lfault | Local Fault detected<br>1: EHIP detected a local fault   | RO     | 0x0   |

# 2.12.4.6. RX MAC Configuration

Offset: 0x50A

### **RX MAC Configuration Fields**

| Bit | Name           | Description                                                                                                                                                                  | Access | Reset |
|-----|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 8   | remove_rx_pad  | Remove PADs from padded frames         0: Padded frames are not altered         1: Pads are removed from padded frames         • After power-on, remove_rx_pad defaults to 0 | RW     | 0x0   |
|     |                | • Afteri_csr_rst_n, remove_rx_pad is set to the value given by the parameter <b>Bytes to remove from RX frames</b> in the parameter editor.                                  |        |       |
| 7   | enforce_max_rx | Enforce Maximum frame size on RX packets<br>0: Oversized frames are not altered<br>1: Frames are ended with FCS error if they exceed the<br>programmed RX maximum frame size | RW     | 0x0   |
|     |                | •                                                                                                                                                                            | contin | ued   |





| Bit | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                               | Access | Reset |
|-----|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |                    | <ul> <li>After power on, this register defaults to 0</li> <li>After i_csr_rst_n, this register is set to value of the parameter Enforce Maximum Frame Size in the parameter editor.</li> </ul>                                                                                                                                                                                                                            |        |       |
| 4   | en_strict_preamble | <pre>Enable Strict Preamble Checking 0: Custom Preamble bytes are allowed between SOP and SFD 1: Packets will be dropped if they do not have standard preamble bytes • After power-up, en_strict_preamble is set to 0 • After i_csr_rst_n is asserted,     en_strict_preamble is set to the value given by the     parameter Enable strict preamble check in the     parameter editor.</pre>                              | RW     | 0x0   |
| 3   | en_check_sfd       | <ul> <li>Enable Start Frame Delimiter Checking</li> <li>0:Custom SFD bytes are allowed in preambles</li> <li>1:Packets will be dropped if they do not have a standard Start Frame Delimiter</li> <li>After power-up, en_check_sfd is set to 0</li> <li>After i_csr_rst_n is asserted, en_check_sfd is set to the value given by the parameter Enable strict SFD checking in the parameter editor.</li> </ul>              | RW     | 0x0   |
| 1   | disable_rxvlan     | <ul> <li>Disable RX VLAN detection</li> <li>0: EHIP detects VLAN frames, counts them separately in stats, and marks them at EOP</li> <li>1:EHIP ignores VLAN in RX data, and treats VLAN headers as payload bytes</li> <li>At power-on, this register defaults to 0</li> <li>When i_csr_rst_n is asserted, this register is set to the value given by the parameter RX VLAN detection in the parameter editor.</li> </ul> | RW     | 0x0   |
| 0   | en_plen            | <ul> <li>Enable Packet Length Checking</li> <li>1: EHIP will assert the length error bit of rx_error at EOP for Frames where the Type/Length field is a length, and the length advertised is greater than the length of the frame that was received</li> <li>After power-on, en_plen is set to 1</li> <li>After i_csr_rst_n,en_plen is set according to the module parameter rx_length_checking</li> </ul>                | RW     | 0x1   |

# 2.12.4.7. EHIP RX MAC Feature Configuration

### Offset: 0x50B

#### **EHIP RX MAC Feature Configuration Fields**

| Bit       | Name                  | Description                                                                                                                     | Access | Reset |  |
|-----------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------|--------|-------|--|
| 1         | rxcrc_covers_preamble | Enable CRC over preamble<br>0: RX CRC calculated over Ethernet Frame (default)<br>1: RX CRC calculated over frame plus preamble | RW     | 0x0   |  |
| continued |                       |                                                                                                                                 |        |       |  |





| Bit | Name  | Description                                                                                                                                                                                    | Access | Reset |
|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |       | <ul> <li>At power-on, this register is set to 0</li> <li>When i_csr_rst_n is asserted, this register is set to the value given by the module <u>rxcr_covers_preamble</u></li> </ul>            |        |       |
| 0   | en_pp | Enable RX Preamble Passthrough<br>1: Preamble-passthrough mode enabled - the preamble<br>received with each packet will be passed to the user<br>0: RX preamble will not be passed to the user | RW     | 0x0   |

# 2.12.5. Pause and Priority- Based Flow Control Registers

# 2.12.5.1. TXSFC Module Revision ID

#### Offset: 0x600

## **TXSFC Module Revision ID Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name | Description                                                                                                           | Access | Reset              |
|------|------|-----------------------------------------------------------------------------------------------------------------------|--------|--------------------|
| 31:0 | id   | <b>Revision ID</b><br>32b Revision ID for the module<br>Returns a 4 byte value indicating the revision of this design | RO     | 0x11<br>1120<br>15 |

# 2.12.5.2. TX SFC Scratch Register

#### Offset: 0x601

### **TX SFC Scratch Register Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name    | Description                                   | Access | Reset |
|------|---------|-----------------------------------------------|--------|-------|
| 31:0 | scratch | 32 bits of scratch register space for testing | RW     | 0x0   |

# 2.12.5.3. Enable TX Pause Ports

#### Offset: 0x605

### **Enable TX Pause Ports Fields**

| Bit | Name        | Description                                                                                                                                                                                                                                                                                                                 | Access | Reset |
|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 8:0 | en_pfc_port | <pre>Enable TX PAUSE or TX PFC port. Bits [7:0]: For PFC Bit [8]: For PAUSE 1: Corresponding tx_pfc_pause port can be used to trigger TX PFC frames • After power on, bit 8 defaults to 1 • After i_csr_rst_n, the value of bit 8 is set based on the module parameter Stop TX traffic when link partner sends PAUSE?</pre> | RO     | 0x1   |





# 2.12.5.4. TX Pause Request

## Offset: 0x606

### TX Pause Request Fields

The reset values in this table represents register values after a reset has completed.

| Bit | Name      | Description                                                                                                                                                                                               | Access | Reset |
|-----|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 8:0 | req_pause | Request TX PAUSE or TX PFC.<br>Bits [7:0]: For PFC<br>Bit [8]: For PAUSE<br>Set to request the transmission of TX Pause frames<br>Works the same way as the corresponding tx_pause port<br>or tx_pfc port | RW     | 0x0   |

# 2.12.5.5. Enable Automatic TX Pause Retransmission

### Offset: 0x607

### **Enable Automatic TX Pause Retransmission Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name       | Description                                                                                                                                                                                                                                                                                                                                                              | Access | Reset |
|-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 8:0 | en_holdoff | Enable Holdoff timer.         Turns on automatic XOFF pause frame retransmission using a holdoff timer for the corresponding tx_pfc_pause port         Bits [7:0]: For PFC         Bit [8]: For PAUSE         1: Holdoff timer enabled.         • EHIP will transmit a new set of XOFF frames whenever                                                                   | RW     | 0x1   |
|     |            | <ul> <li>EHIP will transmit a new set of XOFF frames whenever<br/>the holdoff timer expires while a port or CSR request is<br/>still high for the corresponding queue</li> <li>At power up this register defaults to 1</li> <li>After i_csr_rst_n is asserted, this register value is<br/>set according to the module parameter<br/>flow_control_holdoff_mode</li> </ul> |        |       |

## 2.12.5.6. Retransmit Holdoff Quanta

#### Offset: 0x608

### **Retransmit Holdoff Quanta Fields**

| Bit  | Name           | Description                                                                                                                                                                                      | Access | Reset      |  |
|------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|--|
| 15:0 | holdoff_quanta | <b>Retransmit Holdoff Quanta</b><br>16b value specifying holdoff time before another XOFF is<br>transmitted when the corresponding Enable Automatic TX<br>Pause Retransmission register bit is 1 | RW     | 0xff<br>Ff |  |

Send Feedback



| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Times are programmed in holdoff quanta         <ul> <li>For 10G and 25G links, 1 Holdoff Quanta = 8 clock cycles</li> <li>For 100G links, 1 Holdoff Quanta = 2 clock cycles</li> </ul> </li> <li>Min value is 1, but to minimize wasted bandwidth, holdoff should be set as large as possible without exceeding the recommended max value</li> </ul> |        |       |
|     |      | <ul> <li>Max value for correct operation where holdoff<br/>retransmits PFC requests before the previously<br/>transmitted Quanta expires is:         <ul> <li>For 10G and 25G links: corresponding pause/pfc<br/>quanta - (60 + Maximum TX Frame Size register<br/>value/8)</li> </ul> </li> </ul>                                                            |        |       |
|     |      | <ul> <li>For example, if the corresponding pause quanta<br/>is 1000, and the max tx frame size is 880 bytes,<br/>the max holdoff quanta is 1000-(60+110) = 830</li> <li>These values are based on the max overrun limits<br/>defined in IEEE 802.3 2015 Annex 31B</li> </ul>                                                                                  |        |       |
|     |      | <ul> <li>For 100Gx4 links: corresponding pause/pfc quanta -<br/>(50 + Maximum TX Frame Size register value/32)</li> </ul>                                                                                                                                                                                                                                     |        |       |
|     |      | <ul> <li>After power-on, holdoff_quanta defaults to 16'hFFFF</li> <li>After i_cfg_rst_n, holdoff_quanta defaults to the value in the module parameter holdoff_quanta for pause, and pfc_holdoff_quanta_n for PFC</li> </ul>                                                                                                                                   |        |       |

# 2.12.5.7. Retransmit Pause Quanta

### Offset: 0x609

## **Retransmit Pause Quanta Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name         | Description                                                                                                                                                                                                                                           | Access | Reset      |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | pause_quanta | <b>Retransmit Pause quanta</b><br>16b value specifying the Quanta value transmitted in XOFF<br>frames                                                                                                                                                 | RW     | 0xFF<br>FF |
|      |              | <ul> <li>The Quanta value indicates to the remote link partner<br/>the amount of time to apply flow control</li> </ul>                                                                                                                                |        |            |
|      |              | <ul> <li>1 Quanta corresponds to 512 bit times.</li> </ul>                                                                                                                                                                                            |        |            |
|      |              | <ul> <li>On a 10Gx1 or 25Gx1 link, 512 bit times is 8 valid<br/>clock cycles</li> </ul>                                                                                                                                                               |        |            |
|      |              | <ul> <li>On a 100Gx4 link, 512 bit times is 2 valid clock<br/>cycles</li> </ul>                                                                                                                                                                       |        |            |
|      |              | Minimum allowed value: 1                                                                                                                                                                                                                              |        |            |
|      |              | Maximum value: 16'hFFFF                                                                                                                                                                                                                               |        |            |
|      |              | <ul> <li>The default value for quanta is 16'hFFF. Using the max<br/>value simplifies the use of flow control by making it<br/>directly controlled by XON and XOFF, and reduces the<br/>bandwidth required for retransmitted control frames</li> </ul> |        |            |
|      |              | <ul> <li>After power-up, pause_quanta is set to the default<br/>value (16'hFFFF)</li> </ul>                                                                                                                                                           |        |            |
|      |              | <ul> <li>After i_csr_rst_n, pause_quanta is set to the value<br/>given by the module parameter pause_quanta for<br/>PAUSE, and pfc_pause_quanta_n for PFC</li> </ul>                                                                                  |        |            |

# 2.12.5.8. Enable TX XOFF

Offset: 0x60A





### **Enable TX XOFF Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                 | Access | Reset |
|-----|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 2:0 | en_xoff_qnum_sel | <ul> <li>Enable XOFF</li> <li>Activates automatic TX response to XOFF requests from the link partner n standard flow control mode,</li> <li>1=EHIP responds to XO</li> <li>FF requests it receives by stopping the flow of TX data</li> <li>After power on, this register defaults to 0</li> <li>After i_csr_rst_n, this register is set to the value based on the module parameter flow_control</li> </ul> | RW     | 0x0   |

# 2.12.5.9. Enable Uniform Holdoff

Offset: 0x60B

### **Enable Uniform Holdoff Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name           | Description                                                                                                                                                                                                                                                                                                                                     | Access | Reset |
|-----|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 0   | en_holdoff_all | <ul> <li>Enable uniform holdoff</li> <li>All queues must use a holdoff at least as long as the holdoff programmed into Set Uniform Holdoff register.</li> <li>At power up this register defaults to 0</li> <li>After i_csr_rst_n is asserted, this register value is set according to the module parameter flow_control_holdoff_mode</li> </ul> | RW     | 0x0   |

## 2.12.5.10. Set Uniform Holdoff

Offset: 0x60C

#### **Set Uniform Holdoff Fields**

| Bit  | Name               | Description                                                                                                   | Access | Reset |
|------|--------------------|---------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | holdoff_all_quanta | <b>Uniform holdoff time</b><br>16b minimum holdoff time required of all PFC queues<br>whenen_holdoff_all = 1. | RW     | 0x0   |



| Bit | Name | Description                                                                                                                                                                               | Access | Reset |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Times are programmed in holdoff quanta</li> <li>For 10G and 25G links, 1 Holdoff Quanta = 8 clock cycles</li> </ul>                                                              |        |       |
|     |      | <ul> <li>Minimum value is 1, but to minimize wasted bandwidth,<br/>holdoff should be set as large as possible without<br/>exceeding the recommended max value</li> </ul>                  |        |       |
|     |      | Maximum value for correct operation where holdoff<br>retransmits PFC requests before the previously<br>transmitted Quanta expires is:                                                     |        |       |
|     |      | <ul> <li>For 10G and 25G links: min (Pause Quanta register<br/>value) - (60 + Maximum TX Frame Size register<br/>value/8)</li> </ul>                                                      |        |       |
|     |      | <ul> <li>For example, if the minimum pfc pause quanta<br/>over all queues is 500, and the max tx frame size<br/>is 800 bytes, the max holdoff quanta is<br/>500-(60+100) = 340</li> </ul> |        |       |
|     |      | <ul> <li>These values are based on the maximum overrun<br/>limits defined in IEEE 802.3 2015 Annex 31B</li> </ul>                                                                         |        |       |
|     |      | <ul> <li>For 100Gx4 links: min(Pause Quanta register value)</li> <li>- (50 + Maximum TX Frame Size register value/32)</li> </ul>                                                          |        |       |
|     |      | <ul> <li>At power up this register defaults to 0</li> </ul>                                                                                                                               |        |       |
|     |      | <ul> <li>After i_csr_rst_n is asserted, this register value is<br/>set according to the module parameter<br/>uniform_holdoff_quanta</li> </ul>                                            |        |       |

# 2.12.5.11. Lower 4 bytes of the Destination address for Flow Control

### Offset: 0x60D

## Lower 4 bytes of the Destination address for Flow Control Fields

The reset values in this table represents register values after a reset has completed.

| Bit  | Name   | Description                                                                                                                                                                                                                                                                                                     | Access | Reset              |
|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|
| 31:0 | daddrl | <ul> <li>Flow control Destination Address</li> <li>Lower 4 bytes of the 6 byte destination address used for SFC and PFC frames</li> <li>At power-on, daddrl is set to 32'hC2000001</li> <li>After i_csr_rst_n is asserted, daddrl is set to the value given by module parameter tx_pause_daddr[31:0]</li> </ul> | RW     | 0xC2<br>0000<br>01 |

## 2.12.5.12. Higher 2 bytes of the Destination address for Flow Control

#### Offset: 0x60E

#### Higher 2 bytes of the Destination address for Flow Control Fields

| Bit  | Name   | Description                                                                                                                           | Access | Reset |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 15:0 | daddrh | Flow control Destination Address                                                                                                      | RW     | 0x18  |
|      |        | Upper 2 bytes of the 6 byte destination address used for SFC and PFC frames                                                           |        | 0     |
|      |        | • At power-on, daddrh is set to 16'h0180                                                                                              |        |       |
|      |        | <ul> <li>After i_csr_rst_n is asserted, daddrh is set to the<br/>value given by module parameter<br/>tx_pause_daddr[47:32]</li> </ul> |        |       |





# 2.12.5.13. Lower 4 bytes of the Source address for Flow Control frames

### Offset: 0x60F

## Lower 4 bytes of the Source address for Flow Control frames Fields

The reset values in this table represents register values after a reset has completed.

| Bit  | Name   | Description                                                                                                                          | Access | Reset      |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 31:0 | saddrl | Lower 4 bytes of the Flow control Source Address                                                                                     | RW     | 0xCB       |
|      |        | Lower 4 bytes of the 6 byte source address used for SFC and PFC frames                                                               |        | FC5A<br>DD |
|      |        | • At power-on, saddrl is set to 32'hCBFC5ADD                                                                                         |        |            |
|      |        | <ul> <li>After i_csr_rst_n is asserted, saddrl is set to the<br/>value given by module parameter<br/>tx_pause_saddr[31:0]</li> </ul> |        |            |

## 2.12.5.14. Higher 2 bytes of the Source address for Flow Control frames

## Offset: 0x610

### Higher 2 bytes of the Source address for Flow Control frames Fields

The reset values in this table represents register values after a reset has completed.

| Bit  | Name   | Description                                                                                                                                                                                                                                                                                                               | Access | Reset      |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | saddrh | <ul> <li>Higher 2 bytes of the Flow control Source Address</li> <li>Higher 2 bytes of the 6 byte source address used for SFC and PFC frames</li> <li>At power-on, saddrh is set to 16'hE100</li> <li>After i_csr_rst_n is asserted, saddrh is set to the value given by module parameter tx_pause_saddr[47:32]</li> </ul> | RW     | 0xE1<br>00 |

## 2.12.5.15. TX Flow Control Feature Configuration

Offset: 0x611

### txsfc\_ehip\_cfg Fields

| 1 e |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Access       | Reset |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------|
|     | en_pfc | <ul> <li>Enable Priority Flow Control TX</li> <li>1: Enable Priority Flow Control</li> <li>This feature requires the TX MAC</li> <li>Enabling this feature allows the TX MAC to transmit PFC frames when requested, even if the flow of data through the datapath is inhibited</li> <li>The TX datapath must be reset after changing this field</li> <li>To shut off TX PFC without resetting the datapath, use tx_pause_en</li> <li>To request the transmission of PFC frames through AVMM, use tx_pause_request</li> <li>After power-on, this reset is set to 0</li> <li>After i_csr_rst_n, this register is set to a value given by the module parameter flow_control</li> </ul> | RW           | 0x0   |
| 0 e | en_sfc | Enable Standard Flow Control TX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RW<br>contin | 0x0   |



| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Access | Reset |
|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>1:Enable Standard Flow Control (link PAUSE)</li> <li>This feature requires the TX MAC</li> <li>Enabling this feature allows the TX MAC to transmit<br/>PAUSE frames when requested, even if the flow of data<br/>through the datapath is inhibited</li> <li>The TX datapath must be reset after changing this field</li> <li>To shut off TX PAUSE without resetting the datapath,<br/>use tx_pause_en</li> <li>To request the transmission of PAUSE frames through<br/>AVMM, use tx_pause_request</li> <li>After power-on, this reset is set to 0</li> <li>After i_csr_rst_n, this register is set to a value given<br/>by the module parameter flow_control</li> </ul> |        |       |

# 2.12.5.16. Pause Quanta 0

### Offset: 0x620

## **Pause Quanta 0 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Access | Reset      |
|------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | pause_quanta | <ul> <li>Pause quanta</li> <li>16b value specifying the Quanta value transmitted in XOFF frames</li> <li>The Quanta value indicates to the remote link partner the amount of time to apply flow control</li> <li>1 Quanta corresponds to 512 bit times. <ul> <li>On a 10Gx1 or 25Gx1 link, 512 bit times is 8 valid clock cycles</li> <li>On a 100Gx4 link, 512 bit times is 2 valid clock cycles</li> </ul> </li> <li>Minimum allowed value: 1</li> <li>Maximum value: 16'hFFFF</li> <li>The default value for quanta is 16'hFFFF. Using the max value simplifies the use of flow control by making it directly controlled by XON and XOFF, and reduces the bandwidth required for retransmitted control frames</li> </ul> | RW     | 0xFF<br>FF |
|      |              | <ul> <li>After power-up, pause_quanta is set to the default value (16'hFFFF)</li> <li>After i_csr_rst_n, pause_quanta is set to the value given by the module parameter pause_quanta for PAUSE, and pfc_pause_quanta_n for PFC</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |        |            |

## 2.12.5.17. Pause Quanta 1

Offset: 0x621

#### **Pause Quanta Fields**

| Bit  | Name         | Description                                                                                | Access | Reset      |
|------|--------------|--------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | pause_quanta | <b>Pause quanta</b><br>16b value specifying the Quanta value transmitted in XOFF<br>frames | RW     | 0xFF<br>FF |





| Bit | Name | Description                                                                                                                                                                                                              | Access | Reset |
|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | The Quanta value indicates to the remote link partner<br>the amount of time to apply flow control                                                                                                                        |        |       |
|     |      | • 1 Quanta corresponds to 512 bit times.                                                                                                                                                                                 |        |       |
|     |      | <ul> <li>On a 10Gx1 or 25Gx1 link, 512 bit times is 8 valid<br/>clock cycles</li> </ul>                                                                                                                                  |        |       |
|     |      | <ul> <li>On a 100Gx4 link, 512 bit times is 2 valid clock cycles</li> </ul>                                                                                                                                              |        |       |
|     |      | Minimum allowed value: 1                                                                                                                                                                                                 |        |       |
|     |      | Maximum value: 16'hFFFF                                                                                                                                                                                                  |        |       |
|     |      | • The default value for quanta is 16'hFFFF. Using the max value simplifies the use of flow control by making it directly controlled by XON and XOFF, and reduces the bandwidth required for retransmitted control frames |        |       |
|     |      | <ul> <li>After power-up, pause_quanta is set to the default<br/>value (16'hFFFF)</li> </ul>                                                                                                                              |        |       |
|     |      | • After i_csr_rst_n, pause_quanta is set to the value given by the module parameter pause_quanta for PAUSE, and pfc_pause_quanta_n for PFC                                                                               |        |       |

## 2.12.5.18. Pause Quanta 2

Offset: 0x622

### **Pause Quanta 2 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Access | Reset      |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | pause_quanta | <ul> <li>Pause quanta</li> <li>16b value specifying the Quanta value transmitted in XOFF frames</li> <li>The Quanta value indicates to the remote link partner the amount of time to apply flow control</li> <li>1 Quanta corresponds to 512 bit times. <ul> <li>On a 10Gx1 or 25Gx1 link, 512 bit times is 8 valid clock cycles</li> <li>On a 100Gx4 link, 512 bit times is 2 valid clock cycles</li> </ul> </li> <li>Minimum allowed value: 1</li> <li>Maximum value: 16'hFFFF</li> <li>The default value for quanta is 16'hFFFF. Using the max value simplifies the use of flow control by making it directly controlled by XON and XOFF, and reduces the bandwidth required for retransmitted control frames</li> <li>After power-up, pause_quanta is set to the default value (16'hFFFF)</li> <li>After i_csr_rst_n, pause_quanta is set to the value given by the module parameter pause_quanta for PAUSE, and pfc_pause_quanta_n for PFC</li> </ul> | RW     | 0xFF<br>FF |

## 2.12.5.19. Pause Quanta 3





### **Pause Quanta 3 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Access | Reset      |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | pause_quanta | <ul> <li>Pause quanta</li> <li>16b value specifying the Quanta value transmitted in XOFF frames</li> <li>The Quanta value indicates to the remote link partner the amount of time to apply flow control</li> <li>1 Quanta corresponds to 512 bit times. <ul> <li>On a 10Gx1 or 25Gx1 link, 512 bit times is 8 valid clock cycles</li> <li>On a 100Gx4 link, 512 bit times is 2 valid clock cycles</li> </ul> </li> <li>Minimum allowed value: 1</li> <li>Maximum value: 16'hFFFF</li> <li>The default value for quanta is 16'hFFFF. Using the max value simplifies the use of flow control by making it directly controlled by XON and XOFF, and reduces the bandwidth required for retransmitted control frames</li> <li>After power-up, pause_quanta is set to the default value (16'hFFFF)</li> </ul> <li>After i_csr_rst_n, pause_quanta is set to the value given by the module parameter pause_quanta for PAUSE, and pfc_pause_quanta_n for PFC</li> | RW     | 0xFF<br>FF |

## 2.12.5.20. Pause Quanta 4

Offset: 0x624

## **Pause Quanta 4 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Access | Reset      |
|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | pause_quanta | <ul> <li>Pause quanta 16b value specifying the Quanta value transmitted in XOFF frames The Quanta value indicates to the remote link partner the amount of time to apply flow control 1 Quanta corresponds to 512 bit times. — On a 10Gx1 or 25Gx1 link, 512 bit times is 8 valid clock cycles — On a 100Gx4 link, 512 bit times is 2 valid clock cycles Minimum allowed value: 1 Maximum value: 16'hFFFF The default value for quanta is 16'hFFFF. Using the max value simplifies the use of flow control by making it directly controlled by XON and XOFF, and reduces the bandwidth required for retransmitted control frames After power-up, pause_quanta is set to the default value (16'hFFFF) </li> <li>After i_csr_rst_n, pause_quanta is set to the value given by the module parameter pause_quanta for PAUSE, and pfc_pause_quanta_n for PFC</li></ul> | RW     | 0xFF<br>FF |

## 2.12.5.21. Pause Quanta 5





### **Pause Quanta 5 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Access | Reset      |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | pause_quanta | <ul> <li>Pause quanta <ul> <li>16b value specifying the Quanta value transmitted in XOFF</li> <li>frames</li> </ul> </li> <li>The Quanta value indicates to the remote link partner the amount of time to apply flow control <ul> <li>1 Quanta corresponds to 512 bit times.</li> <li>On a 10Gx1 or 25Gx1 link, 512 bit times is 8 valid clock cycles</li> <li>On a 100Gx4 link, 512 bit times is 2 valid clock cycles</li> </ul> </li> <li>Minimum allowed value: 1 <ul> <li>Maximum value: 16'hFFFF</li> <li>The default value for quanta is 16'hFFFF. Using the max value simplifies the use of flow control by making it directly controlled by XON and XOFF, and reduces the bandwidth required for retransmitted control frames</li> <li>After power-up, pause_quanta is set to the default value (16'hFFFF)</li> </ul> </li> <li>After i_csr_rst_n, pause_quanta is set to the value given by the module parameter pause_quanta for PAUSE, and pfc pause quanta n for PFC</li> </ul> | RW     | 0xFF<br>FF |

# 2.12.5.22. Pause Quanta 6

Offset: 0x626

## Pause Quanta 6 Fields

The reset values in this table represents register values after a reset has completed.

| Bit  | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Access | Reset      |
|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | pause_quanta | <ul> <li>Pause quanta</li> <li>16b value specifying the Quanta value transmitted in XOFF frames</li> <li>The Quanta value indicates to the remote link partner the amount of time to apply flow control</li> <li>1 Quanta corresponds to 512 bit times. <ul> <li>On a 10Gx1 or 25Gx1 link, 512 bit times is 8 valid clock cycles</li> <li>On a 100Gx4 link, 512 bit times is 2 valid clock cycles</li> </ul> </li> <li>Minimum allowed value: 1</li> <li>Maximum value: 16'hFFFF</li> <li>The default value for quanta is 16'hFFFF. Using the max value simplifies the use of flow control by making it directly controlled by XON and XOFF, and reduces the bandwidth required for retransmitted control frames</li> <li>After power-up, pause_quanta is set to the default value (16'hFFFF)</li> <li>After i_csr_rst_n, pause_quanta is set to the value given by the module parameter pause_quanta for PAUSE, and pfc_pause_quanta_n for PFC</li> </ul> | RW     | 0xFF<br>FF |

## 2.12.5.23. Pause Quanta 7



### **Pause Quanta 7 Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Access | Reset      |
|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | pause_quanta | <ul> <li>Pause quanta</li> <li>16b value specifying the Quanta value transmitted in XOFF frames</li> <li>The Quanta value indicates to the remote link partner the amount of time to apply flow control</li> <li>1 Quanta corresponds to 512 bit times.</li> <li>On a 10Gx1 or 25Gx1 link, 512 bit times is 8 valid clock cycles</li> <li>On a 100Gx4 link, 512 bit times is 2 valid clock cycles</li> </ul>                                                                                                                                 | RW     | 0xFF<br>FF |
|      |              | <ul> <li>Minimum allowed value: 1</li> <li>Maximum value: 16'hFFFF</li> <li>The default value for quanta is 16'hFFFF. Using the max value simplifies the use of flow control by making it directly controlled by XON and XOFF, and reduces the bandwidth required for retransmitted control frames</li> <li>After power-up, pause_quanta is set to the default value (16'hFFFF)</li> <li>After i_csr_rst_n, pause_quanta is set to the value given by the module parameter pause_quanta for PAUSE, and pfc_pause_quanta_n for PFC</li> </ul> |        |            |

# 2.12.5.24. PFC Holdoff Quanta 0

Offset: 0x628

## **PFC Holdoff Quanta 0 Fields**

| Bit  | Name           | Description                                                                                                                                                                               | Access | Reset      |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | holdoff_quanta | <b>PFC Holdoff Quanta</b><br>16b value specifying holdoff time before another XOFF is<br>transmitted when the corresponding Enable Automatic TX<br>Pause Retransmission register bit is 1 | RW     | 0xFF<br>FF |





| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Times are programmed in holdoff quanta         <ul> <li>For 10G and 25G links, 1 Holdoff Quanta = 8 clock cycles</li> <li>For 100G links, 1 Holdoff Quanta = 2 clock cycles</li> </ul> </li> <li>Min value is 1, but to minimize wasted bandwidth, holdoff should be set as large as possible without exceeding the recommended max value</li> </ul> |        |       |
|     |      | <ul> <li>Max value for correct operation where holdoff<br/>retransmits PFC requests before the previously<br/>transmitted Quanta expires is:         <ul> <li>For 10G and 25G links: corresponding pause/pfc<br/>quanta - (60 + Maximum TX Frame Size register<br/>value/8)</li> </ul> </li> </ul>                                                            |        |       |
|     |      | <ul> <li>For example, if the corresponding pause quanta is 1000, and the max tx frame size is 880 bytes, the max holdoff quanta is 1000-(60+110) = 830</li> <li>These values are based on the max overrun limits defined in IEEE 802.3 2015 Annex 31B</li> </ul>                                                                                              |        |       |
|     |      | <ul> <li>For 100Gx4 links: corresponding pause/pfc quanta -<br/>(50 + Maximum TX Frame Size register value/32)</li> <li>After power-on, holdoff_quanta defaults to 16'hFFFF</li> </ul>                                                                                                                                                                        |        |       |
|     |      | <ul> <li>After i_cfg_rst_n, holdoff_quanta defaults to the<br/>value in the module parameter holdoff_quanta for<br/>pause, and pfc_holdoff_quanta_n for PFC</li> </ul>                                                                                                                                                                                        |        |       |

### 2.12.5.25. PFC Holdoff Quanta 1

Offset: 0x629

### **PFC Holdoff Quanta 1 Fields**

| Bit  | Name           | Description                                                                                                                                                                               | Access | Reset      |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | holdoff_quanta | <b>PFC Holdoff Quanta</b><br>16b value specifying holdoff time before another XOFF is<br>transmitted when the corresponding Enable Automatic TX<br>Pause Retransmission register bit is 1 | RW     | 0xFF<br>FF |



| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Times are programmed in holdoff quanta         <ul> <li>For 10G and 25G links, 1 Holdoff Quanta = 8 clock cycles</li> <li>For 100G links, 1 Holdoff Quanta = 2 clock cycles</li> </ul> </li> <li>Min value is 1, but to minimize wasted bandwidth, holdoff should be set as large as possible without exceeding the recommended max value</li> </ul> |        |       |
|     |      | <ul> <li>Max value for correct operation where holdoff<br/>retransmits PFC requests before the previously<br/>transmitted Quanta expires is:         <ul> <li>For 10G and 25G links: corresponding pause/pfc<br/>quanta - (60 + Maximum TX Frame Size register<br/>value/8)</li> </ul> </li> </ul>                                                            |        |       |
|     |      | <ul> <li>For example, if the corresponding pause quanta is 1000, and the max tx frame size is 880 bytes, the max holdoff quanta is 1000-(60+110) = 830</li> <li>These values are based on the max overrun limits defined in IEEE 802.3 2015 Annex 31B</li> </ul>                                                                                              |        |       |
|     |      | <ul> <li>For 100Gx4 links: corresponding pause/pfc quanta -<br/>(50 + Maximum TX Frame Size register value/32)</li> <li>After power-on, holdoff guanta defaults to 16'hFFFF</li> </ul>                                                                                                                                                                        |        |       |
|     |      | <ul> <li>After i_cfg_rst_n, holdoff_quanta defaults to the<br/>value in the module parameter holdoff_quanta for<br/>pause, and pfc_holdoff_quanta_n for PFC</li> </ul>                                                                                                                                                                                        |        |       |

### 2.12.5.26. PFC Holdoff Quanta 2

#### Offset: 0x62A

### **PFC Holdoff Quanta 2 Fields**

| Bit  | Name           | Description                                                                                                                                                                               | Access | Reset      |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | holdoff_quanta | <b>PFC Holdoff Quanta</b><br>16b value specifying holdoff time before another XOFF is<br>transmitted when the corresponding Enable Automatic TX<br>Pause Retransmission register bit is 1 | RW     | 0xFF<br>FF |





| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Times are programmed in holdoff quanta         <ul> <li>For 10G and 25G links, 1 Holdoff Quanta = 8 clock cycles</li> <li>For 100G links, 1 Holdoff Quanta = 2 clock cycles</li> </ul> </li> <li>Min value is 1, but to minimize wasted bandwidth, holdoff should be set as large as possible without exceeding the recommended max value</li> </ul> |        |       |
|     |      | <ul> <li>Max value for correct operation where holdoff<br/>retransmits PFC requests before the previously<br/>transmitted Quanta expires is:         <ul> <li>For 10G and 25G links: corresponding pause/pfc<br/>quanta - (60 + Maximum TX Frame Size register<br/>value/8)</li> </ul> </li> </ul>                                                            |        |       |
|     |      | <ul> <li>For example, if the corresponding pause quanta is 1000, and the max tx frame size is 880 bytes, the max holdoff quanta is 1000-(60+110) = 830</li> <li>These values are based on the max overrun limits defined in IEEE 802.3 2015 Annex 31B</li> </ul>                                                                                              |        |       |
|     |      | <ul> <li>For 100Gx4 links: corresponding pause/pfc quanta -<br/>(50 + Maximum TX Frame Size register value/32)</li> <li>After power-on, holdoff_quanta defaults to 16'hFFFF</li> </ul>                                                                                                                                                                        |        |       |
|     |      | <ul> <li>After i_cfg_rst_n, holdoff_quanta defaults to the<br/>value in the module parameter holdoff_quanta for<br/>pause, and pfc_holdoff_quanta_n for PFC</li> </ul>                                                                                                                                                                                        |        |       |

### 2.12.5.27. PFC Holdoff Quanta 3

#### Offset: 0x62B

### **PFC Holdoff Quanta 3 Fields**

| Bit  | Name           | Description                                                                                                                                                                               | Access | Reset      |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | holdoff_quanta | <b>PFC Holdoff Quanta</b><br>16b value specifying holdoff time before another XOFF is<br>transmitted when the corresponding Enable Automatic TX<br>Pause Retransmission register bit is 1 | RW     | 0xFF<br>FF |



| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Times are programmed in holdoff quanta         <ul> <li>For 10G and 25G links, 1 Holdoff Quanta = 8 clock cycles</li> <li>For 100G links, 1 Holdoff Quanta = 2 clock cycles</li> </ul> </li> <li>Min value is 1, but to minimize wasted bandwidth, holdoff should be set as large as possible without exceeding the recommended max value</li> </ul> |        |       |
|     |      | <ul> <li>Max value for correct operation where holdoff<br/>retransmits PFC requests before the previously<br/>transmitted Quanta expires is:         <ul> <li>For 10G and 25G links: corresponding pause/pfc<br/>quanta - (60 + Maximum TX Frame Size register<br/>value/8)</li> </ul> </li> </ul>                                                            |        |       |
|     |      | <ul> <li>For example, if the corresponding pause quanta<br/>is 1000, and the max tx frame size is 880 bytes,<br/>the max holdoff quanta is 1000-(60+110) = 830</li> <li>These values are based on the max overrun limits<br/>defined in IEEE 802.3 2015 Annex 31B</li> </ul>                                                                                  |        |       |
|     |      | <ul> <li>For 100Gx4 links: corresponding pause/pfc quanta -<br/>(50 + Maximum TX Frame Size register value/32)</li> </ul>                                                                                                                                                                                                                                     |        |       |
|     |      | <ul> <li>After power-on, holdoff_quanta defaults to 16'hFFFF</li> <li>After i_cfg_rst_n, holdoff_quanta defaults to the value in the module parameter holdoff_quanta for pause, and pfc_holdoff_quanta_n for PFC</li> </ul>                                                                                                                                   |        |       |

### 2.12.5.28. PFC Holdoff Quanta 4

#### Offset: 0x62C

### **PFC Holdoff Quanta 4 Fields**

| Bit  | Name           | Description                                                                                                                                                                               | Access | Reset      |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | holdoff_quanta | <b>PFC Holdoff Quanta</b><br>16b value specifying holdoff time before another XOFF is<br>transmitted when the corresponding Enable Automatic TX<br>Pause Retransmission register bit is 1 | RW     | 0xFF<br>FF |





| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Times are programmed in holdoff quanta         <ul> <li>For 10G and 25G links, 1 Holdoff Quanta = 8 clock cycles</li> <li>For 100G links, 1 Holdoff Quanta = 2 clock cycles</li> </ul> </li> <li>Min value is 1, but to minimize wasted bandwidth, holdoff should be set as large as possible without exceeding the recommended max value</li> </ul> |        |       |
|     |      | <ul> <li>Max value for correct operation where holdoff<br/>retransmits PFC requests before the previously<br/>transmitted Quanta expires is:         <ul> <li>For 10G and 25G links: corresponding pause/pfc<br/>quanta - (60 + Maximum TX Frame Size register<br/>value/8)</li> </ul> </li> </ul>                                                            |        |       |
|     |      | <ul> <li>For example, if the corresponding pause quanta<br/>is 1000, and the max tx frame size is 880 bytes,<br/>the max holdoff quanta is 1000-(60+110) = 830</li> <li>These values are based on the max overrun limits<br/>defined in IEEE 802.3 2015 Annex 31B</li> </ul>                                                                                  |        |       |
|     |      | <ul> <li>For 100Gx4 links: corresponding pause/pfc quanta -<br/>(50 + Maximum TX Frame Size register value/32)</li> <li>After power-on, holdoff_quanta defaults to 16'hFFFF</li> </ul>                                                                                                                                                                        |        |       |
|     |      | <ul> <li>After i_cfg_rst_n, holdoff_quanta defaults to the<br/>value in the module parameter holdoff_quanta for<br/>pause, and pfc_holdoff_quanta_n for PFC</li> </ul>                                                                                                                                                                                        |        |       |

### 2.12.5.29. PFC Holdoff Quanta 5

Offset: 0x62D

### **PFC Holdoff Quanta 5 Fields**

| Bit  | Name           | Description                                                                                                                                                                               | Access | Reset      |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | holdoff_quanta | <b>PFC Holdoff Quanta</b><br>16b value specifying holdoff time before another XOFF is<br>transmitted when the corresponding Enable Automatic TX<br>Pause Retransmission register bit is 1 | RW     | 0xFF<br>FF |



| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Times are programmed in holdoff quanta         <ul> <li>For 10G and 25G links, 1 Holdoff Quanta = 8 clock cycles</li> <li>For 100G links, 1 Holdoff Quanta = 2 clock cycles</li> </ul> </li> <li>Min value is 1, but to minimize wasted bandwidth, holdoff should be set as large as possible without exceeding the recommended max value</li> </ul> |        |       |
|     |      | <ul> <li>Max value for correct operation where holdoff<br/>retransmits PFC requests before the previously<br/>transmitted Quanta expires is:         <ul> <li>For 10G and 25G links: corresponding pause/pfc<br/>quanta - (60 + Maximum TX Frame Size register<br/>value/8)</li> </ul> </li> </ul>                                                            |        |       |
|     |      | <ul> <li>For example, if the corresponding pause quanta<br/>is 1000, and the max tx frame size is 880 bytes,<br/>the max holdoff quanta is 1000-(60+110) = 830</li> <li>These values are based on the max overrun limits<br/>defined in IEEE 802.3 2015 Annex 31B</li> </ul>                                                                                  |        |       |
|     |      | <ul> <li>For 100Gx4 links: corresponding pause/pfc quanta -<br/>(50 + Maximum TX Frame Size register value/32)</li> </ul>                                                                                                                                                                                                                                     |        |       |
|     |      | <ul> <li>After power-on, holdoff_quanta defaults to 16'hFFFF</li> <li>After i_cfg_rst_n, holdoff_quanta defaults to the value in the module parameter holdoff_quanta for pause, and pfc_holdoff_quanta_n for PFC</li> </ul>                                                                                                                                   |        |       |

### 2.12.5.30. PFC Holdoff Quanta 6

#### Offset: 0x62E

### **PFC Holdoff Quanta 6 Fields**

| Bit  | Name           | Description                                                                                                                                                                               | Access | Reset      |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | holdoff_quanta | <b>PFC Holdoff Quanta</b><br>16b value specifying holdoff time before another XOFF is<br>transmitted when the corresponding Enable Automatic TX<br>Pause Retransmission register bit is 1 | RW     | 0xFF<br>FF |





| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                  | Access | Reset |
|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Times are programmed in holdoff quanta <ul> <li>For 10G and 25G links, 1 Holdoff Quanta = 8 clock cycles</li> <li>For 100G links, 1 Holdoff Quanta = 2 clock cycles</li> </ul> </li> <li>Min value is 1, but to minimize wasted bandwidth, holdoff should be set as large as possible without exceeding the recommended max value</li> <li>Max value for correct operation where holdoff</li> </ul> |        |       |
|     |      | retransmits PFC requests before the previously<br>transmitted Quanta expires is:<br>— For 10G and 25G links: corresponding pause/pfc<br>quanta - (60 + Maximum TX Frame Size register<br>value/8)                                                                                                                                                                                                            |        |       |
|     |      | <ul> <li>For example, if the corresponding pause quanta<br/>is 1000, and the max tx frame size is 880 bytes,<br/>the max holdoff quanta is 1000-(60+110) = 830</li> <li>These values are based on the max overrun limits<br/>defined in IEEE 802.3 2015 Annex 31B</li> </ul>                                                                                                                                 |        |       |
|     |      | <ul> <li>For 100Gx4 links: corresponding pause/pfc quanta -<br/>(50 + Maximum TX Frame Size register value/32)</li> </ul>                                                                                                                                                                                                                                                                                    |        |       |
|     |      | • After power-on, holdoff_quanta defaults to 16'hFFFF                                                                                                                                                                                                                                                                                                                                                        |        |       |
|     |      | <ul> <li>After i_cfg_rst_n, holdoff_quanta defaults to the<br/>value in the module parameter holdoff_quanta for<br/>pause, and pfc_holdoff_quanta_n for PFC</li> </ul>                                                                                                                                                                                                                                       |        |       |

### 2.12.5.31. PFC Holdoff Quanta 7

Offset: 0x62F

### **PFC Holdoff Quanta 7 Fields**

| Bit  | Name           | Description                                                                                                                                                                               | Access | Reset      |
|------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|
| 15:0 | holdoff_quanta | <b>PFC Holdoff Quanta</b><br>16b value specifying holdoff time before another XOFF is<br>transmitted when the corresponding Enable Automatic TX<br>Pause Retransmission register bit is 1 | RW     | 0xFF<br>FF |



| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                                   | Access | Reset |
|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>Times are programmed in holdoff quanta         <ul> <li>For 10G and 25G links, 1 Holdoff Quanta = 8 clock cycles</li> <li>For 100G links, 1 Holdoff Quanta = 2 clock cycles</li> </ul> </li> <li>Min value is 1, but to minimize wasted bandwidth, holdoff should be set as large as possible without exceeding the recommended max value</li> </ul> |        |       |
|     |      | <ul> <li>Max value for correct operation where holdoff<br/>retransmits PFC requests before the previously<br/>transmitted Quanta expires is:         <ul> <li>For 10G and 25G links: corresponding pause/pfc<br/>quanta - (60 + Maximum TX Frame Size register<br/>value/8)</li> </ul> </li> </ul>                                                            |        |       |
|     |      | <ul> <li>For example, if the corresponding pause quanta<br/>is 1000, and the max tx frame size is 880 bytes,<br/>the max holdoff quanta is 1000-(60+110) = 830</li> <li>These values are based on the max overrun limits<br/>defined in IEEE 802.3 2015 Annex 31B</li> </ul>                                                                                  |        |       |
|     |      | <ul> <li>For 100Gx4 links: corresponding pause/pfc quanta -<br/>(50 + Maximum TX Frame Size register value/32)</li> </ul>                                                                                                                                                                                                                                     |        |       |
|     |      | <ul> <li>After power-on, holdoff_quanta defaults to 16'hFFFF</li> <li>After i_cfg_rst_n, holdoff_quanta defaults to the value in the module parameter holdoff_quanta for pause, and pfc_holdoff_quanta_n for PFC</li> </ul>                                                                                                                                   |        |       |

### 2.12.5.32. RXSFC Module Revision ID

#### Offset: 0x700

### **RXSFC Module Revision ID Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name | Description                                                   | Access | Reset |
|------|------|---------------------------------------------------------------|--------|-------|
| 31:0 | id   | Revision ID                                                   | RO     | 0x11  |
|      |      | 32b Revision ID for the module                                |        | 1120  |
|      |      | Returns a 4 byte value indicating the revision of this design |        | 15    |

### 2.12.5.33. RXSFC Scratch Register

Offset: 0x701

#### **RXSFC Scratch Register Fields**

The reset values in this table represents register values after a reset has completed.

| Bit  | Name    | Description                                   | Access | Reset |
|------|---------|-----------------------------------------------|--------|-------|
| 31:0 | scratch | 32 bits of scratch register space for testing | RW     | 0x0   |

### 2.12.5.34. Enable RX Pause Frame Processing

Offset: 0x705





#### **Enable RX Pause Frame Processing Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name        | Description                                                                                                                                                                                              | Access | Reset |
|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 7:0 | en_rx_pause | <pre>Enable Rx Pause 1:Enable PFC port for selected queue • After power-on, this reset is set to 0 • After i_csr_rst_n, this register is set to a value given by the module parameter flow_control</pre> | RW     | 0x1   |

### 2.12.5.35. Forward Flow Control Frames

Offset: 0x706

#### **Forward Flow Control Frames Fields**

The reset values in this table represents register values after a reset has completed.

| Bit | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Access | Reset |
|-----|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 0   | rx_pause_fwd | <ul> <li>Forward Flow Control Frames</li> <li>Sets whether PAUSE and PFC frames are send to the MAC Client Interface</li> <li>1: Forwards all flow control frames to the application</li> <li>0: Does not forward flow control frames that match the RX destination address for flow control to the application</li> <li>Be careful when turning off Flow Control frame forwarding</li> <li>This feature requires EHIP to be in a mode with the MAC turned on</li> <li>When flow control forwarding is turned off, flow control frames will be dropped regardless of whether flow control processing is turned on</li> <li>Packets are considered to be flow control if they have T/L = 16'h8808, MAC Control opcode =0x0001 (PAUSE) or 0x0101 (PFC) and their destination address matches rx_pause_daddr</li> <li>Flow Control packets are only processed by the MAC if they are also exactly 72 bytes long (including Preamble) and are error free</li> <li>When Flow Control forwarding is turned off, Flow control packets will be dropped and not processed</li> <li>When this setting is changed, the RX MAC must be reset</li> <li>At power-on, this register defaults to 0</li> <li>When i_csr_rst_n is asserted, this register is set to the value given by the module parameter forward_rx_pause_requests</li> </ul> | RW     | 0x0   |

### 2.12.5.36. Lower 4 bytes of the Destination address for RX Pause Frames

Offset: 0x707

#### Lower 4 bytes of the Destination address for RX Pause Frames Fields

| Bit  | Name            | Description                                                                                        | Access | Reset        |
|------|-----------------|----------------------------------------------------------------------------------------------------|--------|--------------|
| 31:0 | rx_pause_daddrl | Lower bytes of the RX Flow Control Destination<br>Address                                          | RW     | 0xC2<br>0000 |
|      |                 | Lower 4 bytes of the 6 byte destination address that must be found in incoming SFC and PFC frames. |        | 01           |





| Bit | Name | Description                                                                                                                                                                                                                                                                                                                                    | Access | Reset |
|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|     |      | <ul> <li>This feature requires EHIP to be in a mode with the MAC turned on</li> <li>When this setting is changed, the RX MAC must be reset</li> <li>At power-on, this register defaults to 32'hC2000001</li> <li>When i_csr_rst_n is asserted, this register is set to the value given by the module parameter rx_pause_daddr[31:0]</li> </ul> |        |       |

### 2.12.5.37. Higher 2 bytes of the Destination address for RX Pause Frames

Offset: 0x708

### Higher 2 bytes of the Destination address for RX Pause Frames Fields

The reset values in this table represents register values after a reset has completed.

| Bit  | Name            | Description                                                                                                                                     | Access | Reset     |  |
|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|--|
| 15:0 | rx_pause_daddrh | Higher bytes of the RX Flow Control Destination<br>Address                                                                                      | RW     | 0x18<br>0 |  |
|      |                 | Higher 2 bytes of the 6 byte destination address that must be found in incoming SFC and PFC frames                                              |        |           |  |
|      |                 | • This feature requires EHIP to be in a mode with the MAC turned on                                                                             |        |           |  |
|      |                 | • When this setting is changed, the RX MAC must be reset                                                                                        |        |           |  |
|      |                 | <ul> <li>At power-on, this register defaults to 16'h0180</li> </ul>                                                                             |        |           |  |
|      |                 | <ul> <li>When i_csr_rst_n is asserted, this register is set to<br/>the value given by the module parameter<br/>rx_pause_daddr[47:32]</li> </ul> |        |           |  |

### 2.12.5.38. RX Flow Control Feature Configuration

### Offset: 0x709

### **RX Flow Control Feature Configuration Fields**

| Bit | Name   | Description                                                                                                                                                                                                                                                      | Access | Reset |
|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 1   | en_pfc | <ul> <li>Enable Priority Flow Control RX</li> <li>1: Enable Priority Flow Control</li> <li>After power-on, this reset is set to 0</li> <li>After i_csr_rst_n, this register is set to a value given by the module parameter flow_control</li> </ul>              | RW     | 0x0   |
| 0   | en_sfc | <ul> <li>Enable Standard Flow Control RX</li> <li>1: Enable Standard Flow Control (link PAUSE)</li> <li>After power-on, this reset is set to 0</li> <li>After i_csr_rst_n, this register is set to a value given by the module parameter flow_control</li> </ul> | RW     | 0x0   |





### **2.12.6. TX Statistics Counter Registers**

### 2.12.6.1. TX Statistics Registers

### Table 70. Transmit Side Statistics Registers

| Address | Name-                       | Description                                                                                                                       | Access    |
|---------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------|
| 0x800   | TX_FRAGMENTS_31_0           | Number of transmitted frames less<br>than 64 bytes and reporting a CRC<br>error (lower 32 bits)                                   | RO        |
| 0x801   | TX_FRAGMENTS_63_32          | Number of transmitted frames less<br>than 64 bytes and reporting a CRC<br>error (upper 32 bits)                                   | RO        |
| 0x802   | TX_JABBERS_31_0             | Number of transmitted oversized frames reporting a CRC error (lower 32 bits)                                                      | RO        |
| 0x803   | TX_JABBERS_63_32            | Number of transmitted oversized frames reporting a CRC error (upper 32 bits)                                                      | RO        |
| 0x804   | TX_FCSERR_31_0              | Number of transmitted packets with FCS errors. (lower 32 bits)                                                                    | RO        |
| 0x805   | TX_FCSERR_63_32             | Number of transmitted packets with FCS errors. (upper 32 bits)                                                                    | RO        |
| 0x806   | TX_CRCERR_OKPKT_31_0        | Number of frames of any size that<br>are malformed but are neither<br>undersized or oversized with a CRC<br>error (lower 32 bits) | RO        |
| 0x807   | TX_CRCERR_OKPKT_63_3<br>2   | Number of frames of any size that<br>are malformed but are neither<br>undersized or oversized with a CRC<br>error (upper 32 bits) | RO        |
| 0x808   | TX_MCAST_DATA_ERR_31<br>_0  | Number of errored multicast frames<br>transmitted, excluding control frames<br>(lower 32 bits)                                    | RO        |
| 0x809   | TX_MCAST_DATA_ERR_63<br>_32 | Number of errored multicast frames<br>transmitted, excluding control frames<br>(upper 32 bits)                                    | RO        |
| 0x80A   | TX_BCAST_DATA_ERR_31<br>_0  | Number of errored broadcast frames<br>transmitted, excluding control frames<br>(lower 32 bits)                                    | RO        |
| 0x80B   | TX_BCAST_DATA_ERR_63<br>_32 | Number of errored broadcast frames<br>transmitted, excluding control frames<br>(upper 32 bits)                                    | RO        |
| 0x80C   | TX_UCAST_DATA_ERR_31<br>_0  | Number of errored unicast frames<br>transmitted, excluding control frames<br>(lower 32 bits)                                      | RO        |
| 0x80D   | TX_UCAST_DATA_ERR_63<br>_32 | Number of errored unicast frames<br>transmitted, excluding control frames<br>(upper 32 bits)                                      | RO        |
| 0x80E   | TX_MCAST_CTRL_ERR_31<br>_0  | Number of errored multicast control frames transmitted (lower 32 bits)                                                            | RO        |
| 0x80F   | TX_MCAST_CTRL_ERR_63<br>_32 | Number of errored multicast control frames transmitted (upper 32 bits)                                                            | RO        |
|         | •                           | •                                                                                                                                 | continued |



| Address | Name-                       | Description                                                                                                                     | Access |
|---------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------|--------|
| 0x810   | TX_BCAST_CTRL_ERR_31<br>_0  | Number of errored broadcast control frames transmitted (lower 32 bits)                                                          | RO     |
| 0x811   | TX_BCAST_CTRL_ERR_63<br>_32 | Number of errored broadcast control frames transmitted (upper 32 bits)                                                          | RO     |
| 0x812   | TX_UCAST_CTRL_ERR_31<br>_0  | Number of errored unicast control frames transmitted (lower 32 bits)                                                            | RO     |
| 0x813   | TX_UCAST_CTRL_ERR_63<br>_32 | Number of errored unicast control frames transmitted (upper 32 bits)                                                            | RO     |
| 0x814   | TX_PAUSE_ERR_31_0           | Number of errored pause frames transmitted (lower 32 bits)                                                                      | RO     |
| 0x815   | TX_PAUSE_ERR_63_32          | Number of errored pause frames transmitted (upper 32 bits)                                                                      | RO     |
| 0x816   | TX_64B_31_0                 | Number of 64-byte transmitted<br>frames (lower 32 bits), including the<br>CRC field but excluding the preamble<br>and SFD bytes | RO     |
| 0x817   | TX_64B_63_32                | Number of 64-byte transmitted<br>frames (upper 32 bits), including the<br>CRC field but excluding the preamble<br>and SFD bytes | RO     |
| 0x818   | TX_65to127B_31_0            | Number of transmitted frames<br>between 65–127 bytes (lower 32<br>bits)                                                         | RO     |
| 0x819   | TX_65to127B_63_32           | Number of transmitted frames<br>between 65–127 bytes (upper 32<br>bits)                                                         | RO     |
| 0x81A   | TX_128to255B_31_0           | Number of transmitted frames<br>between 128–255 bytes (lower 32<br>bits)                                                        | RO     |
| 0x81B   | TX_128to255B_63_32          | Number of transmitted frames<br>between 128–255 bytes (upper 32<br>bits)                                                        | RO     |
| 0x81C   | TX_256to511B_31_0           | Number of transmitted frames<br>between 256–511 bytes (lower 32<br>bits)                                                        | RO     |
| 0x81D   | TX_256to511B_63_32          | Number of transmitted frames<br>between 256–511 bytes (upper 32<br>bits)                                                        | RO     |
| 0x81E   | TX_512to1023B_31_0          | Number of transmitted frames<br>between 512–1023 bytes (lower 32<br>bits)                                                       | RO     |
| 0x81F   | TX_512to1023B_63_32         | Number of transmitted frames<br>between 512–1023 bytes (upper 32<br>bits)                                                       | RO     |
| 0x820   | TX_1024to1518B_31_0         | Number of transmitted frames<br>between 1024–1518 bytes (lower 32<br>bits)                                                      | RO     |
| 0x821   | TX_1024to1518B_63_32        | Number of transmitted frames<br>between 1024–1518 bytes (upper 32<br>bits)                                                      | RO     |





| Address | Name-                      | Description                                                                                                                                              | Access |
|---------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 0x822   | TX_1519toMAXB_31_0         | Number of transmitted frames of size<br>between 1519 bytes and the number<br>of bytes specified in the<br>MAX_TX_SIZE_CONFIG register<br>(lower 32 bits) | RO     |
| 0x823   | TX_1519toMAXB_63_32        | Number of transmitted frames of size<br>between 1519 bytes and the number<br>of bytes specified in the<br>MAX_TX_SIZE_CONFIG register<br>(upper 32 bits) | RO     |
| 0x824   | TX_OVERSIZE_31_0           | Number of oversized frames (frames<br>with more bytes than the number<br>specified in the<br>MAX_TX_SIZE_CONFIG register)<br>transmitted (lower 32 bits) | RO     |
| 0x825   | TX_OVERSIZE_63_32          | Number of oversized frames (frames<br>with more bytes than the number<br>specified in the<br>MAX_TX_SIZE_CONFIG register)<br>transmitted (upper 32 bits) | RO     |
| 0x826   | TX_MCAST_DATA_OK_31_<br>0  | Number of valid multicast frames<br>transmitted, excluding control frames<br>(lower 32 bits)                                                             | RO     |
| 0x827   | TX_MCAST_DATA_OK_63_<br>32 | Number of valid multicast frames<br>transmitted, excluding control frames<br>(upper 32 bits)                                                             | RO     |
| 0x828   | TX_BCAST_DATA_OK_31_<br>0  | Number of valid broadcast frames<br>transmitted, excluding control frames<br>(lower 32 bits)                                                             | RO     |
| 0x829   | TX_BCAST_DATA_OK_63_<br>32 | Number of valid broadcast frames<br>transmitted, excluding control frames<br>(upper 32 bits)                                                             | RO     |
| 0x82A   | TX_UCAST_DATA_OK_31_<br>0  | Number of valid unicast frames<br>transmitted, excluding control frames<br>(lower 32 bits)                                                               | RO     |
| 0x82B   | TX_UCAST_DATA_OK_63_<br>32 | Number of valid unicast frames<br>transmitted, excluding control frames<br>(upper 32 bits)                                                               | RO     |
| 0x82C   | TX_MCAST_CTRL_OK_31_<br>0  | Number of valid multicast frames<br>transmitted, excluding data frames<br>(lower 32 bits)                                                                | RO     |
| 0x82D   | TX_MCAST_CTRL_OK_63_<br>32 | Number of valid multicast frames<br>transmitted, excluding data frames<br>(upper 32 bits)                                                                | RO     |
| 0x82E   | TX_BCAST_CTRL_OK_31_<br>0  | Number of valid broadcast frames<br>transmitted, excluding data frames<br>(lower 32 bits)                                                                | RO     |
| 0x82F   | TX_BCAST_CTRL_OK_63_<br>32 | Number of valid broadcast frames<br>transmitted, excluding data frames<br>(upper 32 bits)                                                                | RO     |
| 0x830   | TX_UCAST_CTRL_OK_31_<br>0  | Number of valid unicast frames<br>transmitted, excluding data frames<br>(lower 32 bits)                                                                  | RO     |



| Address        | Name-                     | Description                                                                                                                                                                                                                                                                                                   | Access |
|----------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 0x831          | TX_UCAST_CTRL_OK_63<br>32 | Number of valid unicast frames<br>transmitted, excluding data frames<br>(upper 32 bits)                                                                                                                                                                                                                       | RO     |
| 0x832          | TX_PAUSE_31_0             | Number of valid pause frames transmitted (lower 32 bits)                                                                                                                                                                                                                                                      | RO     |
| 0x833          | TX_PAUSE_63_32            | Number of valid pause frames transmitted (upper 32 bits)                                                                                                                                                                                                                                                      | RO     |
| 0x834          | TX_RNT_31_0               | Number of transmitted runt packets<br>(lower 32 bits). The IP core does not<br>transmit frames of length less than<br>nine bytes. The IP core pads frames<br>of length nine bytes to 64 bytes to<br>extend them to 64 bytes. Therefore,<br>this counter does not increment in<br>normal operating conditions. | RO     |
| 0x835          | TX_RNT_63_32              | Number of transmitted runt packets<br>(upper 32 bits). The IP core does not<br>transmit frames of length less than<br>nine bytes. The IP core pads frames<br>of length nine bytes to 64 bytes to<br>extend them to 64 bytes. Therefore,<br>this counter does not increment in<br>normal operating conditions. | RO     |
| 0x836          | TX_st_31_0                | Number of TX frame starts (lower 32 bits)                                                                                                                                                                                                                                                                     | RO     |
| 0x837          | TX_st_63_32               | Number of TX frame starts (upper 32 bits)                                                                                                                                                                                                                                                                     | RO     |
| 0x838          | TX_lenerr_31_0            | Number of frames where the length<br>of the frame advertised in the L/T<br>field was larger than the frame that<br>was received (lower 32 bits).<br>Length checking must be enabled                                                                                                                           | RO     |
| 0x839          | TX_lenerr_63_32           | Number of frames where the length<br>of the frame advertised in the L/T<br>field was larger than the frame that<br>was received (upper 32 bits).<br>Length checking must be enabled                                                                                                                           | RO     |
| 0x83A          | TX_pfc_err_31_0           | Number of malformed TX PFC frames with CRC errors (lower 32 bits)                                                                                                                                                                                                                                             | RO     |
| 0x83B          | TX_pfc_err_63_32          | Number of malformed TX PFC frames with CRC errors (upper 32 bits)                                                                                                                                                                                                                                             | RO     |
| 0x83C          | TX_pfc_31_0               | Number of TX PFC frames without error (lower 32 bits)                                                                                                                                                                                                                                                         | RO     |
| 0x83D          | TX_pfc_63_32              | Number of TX PFC frames without error (upper 32 bits)                                                                                                                                                                                                                                                         | RO     |
| 0x840          | txstat_revid              | Returns a 4 byte value indicating the revision of this design                                                                                                                                                                                                                                                 | RO     |
| 0x841          | txstat_scratch            | 32 bits of scratch register space for testing                                                                                                                                                                                                                                                                 | RO     |
| 0x842 to 0x844 | Reserved                  |                                                                                                                                                                                                                                                                                                               |        |
| 0x845          | TX_CNTR_CONFIG            | Bits[2:0]: Configuration of TX statistics counters:                                                                                                                                                                                                                                                           | RW     |





| Address | Name- | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Access    |
|---------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| Address | Name- | <ul> <li>Description</li> <li>Bit[2] = 1: Freeze stats CSRs so that all TX Stats values read from the registers will be from the same moment: <ul> <li>Note that the actual stats collection counters are not frozen, but because they are all 'read' at the time of the freeze, they are cleared.</li> <li>If a shadow request is started while snapshot is active, a new capture will be executed.</li> <li>Likewise, if a shadow request is active while snapshot is active, a new capture will be executed.</li> <li>Likewise, if a shadow request is active while snapshot is active, a new capture will be executed.</li> <li>While either a shadow request or a capture is active, tx_shadow_on will be high.</li> <li>Snapshot and shadow requests apply to several of the RX PCS counters as well as MAC statistics.</li> <li>Bit[1] = 1: Reset the parity error bit in cntr_TX_status.</li> <li>Parity error bit will remain in reset until rst_tx_parity is set back to 0</li> <li>Bit[0] = 1: Reset all TX Stats counters</li> <li>TX stats will stay in reset until reset is set back to 0.</li> <li>Reset also applies when snapshot or shadow is active, and will clear the AVMM visible registers.</li> <li>rst_tx_stats does not clear</li> </ul> </li> </ul> | Access    |
|         |       | the parity error bit.<br>Bits[31:3] are Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |
|         |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | continued |



| Address        | Name-                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Access |
|----------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 0x846          | TX_CNTR_STATUS                                                | <ul> <li>Bit[1] =1: The CSRs for the TX<br/>Statistics are currently frozen,<br/>and holding the statistic values<br/>from the last time a shadow<br/>request was made.<br/>Shadow on is asserted for either<br/>a shadow request or a snapshot</li> <li>Bit[0] = 1: A parity error was<br/>detected on at least one of the<br/>statistics counters since the last<br/>time this bit was cleared         <ul> <li>Statistics counter values are<br/>stored periodically by EHIP for<br/>long term storage.</li> <li>Whenever a counter value is<br/>calculated for the new value.</li> <li>Whenever a stats value is<br/>updated, the parity value of<br/>the old value is calculated. If it<br/>doesn't match the stored<br/>value, the sticky parity error<br/>bit is asserted.</li> <li>If tx_parity_err is high, it<br/>means sometime in the past,<br/>a parity error was detected on<br/>the stats memory.</li> </ul> </li> <li>Bits[31:2] are Reserved.</li> </ul> | RO     |
| 0x847-0x85F    | Reserved                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | I      |
| 0x860<br>0x861 | TX_Payload_OctetsOK_31<br>_0<br>TX_Payload_OctetsOK_63<br>_32 | <ul> <li>Number of transmitted payload bytes<br/>in frames with no FCS, undersized,<br/>oversized, or payload length errors.</li> <li>When TX VLAN/SVLAN detection<br/>is enabled, VLAN/SVLAN header<br/>bytes are also removed from the<br/>count</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO     |
|                |                                                               | <ul> <li>For single lane EHIP modules<br/>(10G or 25G), packets that start<br/>within 4 bytes of a the previous<br/>packet's TERM are not counted<br/>(malformed).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |        |
| 0x862          | TX_Frame_OctetsOK_31_<br>0                                    | Number of transmitted bytes in<br>frames with no FCS, undersized,<br>oversized, or payload length errors.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RO     |
| 0x863          | TX_Frame_OctetsOK_63_<br>32                                   | For single lane EHIP modules (10G or 25G), packets that start within 4 bytes of a the previous packet's TERM are not counted (malformed).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RO     |
| 0x864          | TX_Malformed_CTRL_31<br>_0                                    | Records the number of TX packets that were malformed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RO     |
| 0x865          | TX_Malformed_CTRL_63<br>_32                                   | <ul> <li>A packet is malformed if it is<br/>interrupted by an MII Control<br/>byte other than TERM and ERROR</li> <li>Packets that have ERROR control<br/>bytes but end with a TERM are<br/>not considered malformed</li> <li>For single lane EHIP modules<br/>(10G or 25G), packets that start<br/>within 4 bytes of a the previous<br/>packet's TERM are not counted<br/>(malformed).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RO     |





| Address | Name-                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Access |
|---------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 0x866   | TX_Dropped_CTRL_31_0   | Records the number of TX packets dropped due to errors.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO     |
| 0x867   | TX_Dropped_CTRL_63_3 2 | <ul> <li>The TXMAC automatically pads short frames, except when <i>i_skip_crc</i> is asserted from the packet</li> <li>When CRC is skipped, if the packet is shorter than 21 bytes, it will be counted as a TX dropped packet</li> </ul>                                                                                                                                                                                                                                                                                                                                            | RO     |
| 0x868   | TX_BadLt_CTRL_31_0     | Records the number of TX frames<br>that arrived with a Length/Type field                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RO     |
| 0x869   | TX_BadLt_CTRL_63_32    | <ul> <li>that all ved with a Length // type field that was neither a length nor a type.</li> <li>L/T is considered to be a Length field if the value in the field is 16'd1500 or less</li> <li>L/T is considered to be a Type field if the value in the field is 16'd1536 or more</li> <li>If a packet has a L/T field with value between 16'd1501 and 16'd1535 (inclusive), the L/T field is considered bad, and the counter is incremented</li> <li>Note: If TX_VLAN/SVLAN detection is turned on, it is the L/T field inside the VLAN/SVLAN header that is evaluated.</li> </ul> | RO     |

### **2.12.7. RX Statistics Counter Registers**

### 2.12.7.1. RX Statistics Registers

### Table 71. Receive Side Statistics Registers

| Address | Name                   | Description                                                                                                                                                                               | Access  |
|---------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| 0x900   | RX_FRAGMENTS_31_0      | Number of received frames less than 64 bytes and reporting a CRC error (lower 32 bits)                                                                                                    | RO      |
| 0x901   | RX_FRAGMENTS_63_3<br>2 | Number of received frames less than 64 bytes and reporting a CRC error (upper 32 bits)                                                                                                    | RO      |
| 0x902   | RX_JABBERS_31_0        | Number of received oversized frames reporting a CRC error (lower 32 bits)                                                                                                                 | RO      |
| 0x903   | RX_JABBERS_63_32       | Number of received oversized frames reporting a CRC error (upper 32 bits)                                                                                                                 | RO      |
| 0x904   | RX_FCSERR_31_0         | Number of received packets with FCS errors. This register<br>maintains a count of the number of pulses on the<br>l <n>_rx_fcs_error or rx_fcs_error output signal (lower 32<br/>bits)</n> | RO      |
| 0x905   | RX_FCSERR_63_32        | Number of received packets with FCS errors. This register maintains a count of the number of pulses on the l <n>_rx_fcs_error output signal (upper 32 bits)</n>                           | RO      |
|         | -                      | cc                                                                                                                                                                                        | ntinued |



| Address | Name                        | Description                                                                                                         | Access  |
|---------|-----------------------------|---------------------------------------------------------------------------------------------------------------------|---------|
| 0x906   | RX_CRCERR_OKPKT_3<br>1_0    | Number of received frames with a frame of length at least 64, with CRC error (lower 32 bits)                        | RO      |
| 0x907   | RX_CRCERR_OKPKT_6<br>3_32   | Number of received frames with a frame of length at least 64, with CRC error (upper 32 bits)                        | RO      |
| 0x908   | RX_MCAST_DATA_ERR<br>_31_0  | Number of errored multicast frames received, excluding control frames (lower 32 bits)                               | RO      |
| 0x909   | RX_MCAST_DATA_ERR<br>_63_32 | Number of errored multicast frames received, excluding control frames (upper 32 bits)                               | RO      |
| 0x90A   | RX_BCAST_DATA_ERR<br>_31_0  | Number of errored broadcast frames received, excluding control frames (lower 32 bits)                               | RO      |
| 0x90B   | RX_BCAST_DATA_ERR<br>_63_32 | Number of errored broadcast frames received, excluding control frames (upper 32 bits)                               | RO      |
| 0x90C   | RX_UCAST_DATA_ERR<br>_31_0  | Number of errored unicast frames received, excluding control frames (lower 32 bits)                                 | RO      |
| 0x90D   | RX_UCAST_DATA_ERR<br>_63_32 | Number of errored unicast frames received, excluding control frames (upper 32 bits)                                 | RO      |
| 0x90E   | RX_MCAST_CTRL_ERR<br>_31_0  | Number of errored multicast control frames received (lower 32 bits)                                                 | RO      |
| 0x90F   | RX_MCAST_CTRL_ERR<br>_63_32 | Number of errored multicast control frames received (upper 32 bits)                                                 | RO      |
| 0x910   | RX_BCAST_CTRL_ERR<br>_31_0  | Number of errored broadcast control frames received (lower 32 bits)                                                 | RO      |
| 0x911   | RX_BCAST_CTRL_ERR<br>_63_32 | Number of errored broadcast control frames received (upper 32 bits)                                                 | RO      |
| 0x912   | RX_UCAST_CTRL_ERR<br>_31_0  | Number of errored unicast control frames received (lower 32 bits)                                                   | RO      |
| 0x913   | RX_UCAST_CTRL_ERR<br>_63_32 | Number of errored unicast control frames received (upper 32 bits)                                                   | RO      |
| 0x914   | RX_PAUSE_ERR_31_0           | Number of errored pause frames received (lower 32 bits)                                                             | RO      |
| 0x915   | RX_PAUSE_ERR_63_3<br>2      | Number of errored pause frames received (upper 32 bits)                                                             | RO      |
| 0x916   | RX_64B_31_0                 | Number of 64-byte received frames (lower 32 bits), including the CRC field but excluding the preamble and SFD bytes | RO      |
| 0x917   | RX_64B_63_32                | Number of 64-byte received frames (upper 32 bits), including the CRC field but excluding the preamble and SFD bytes | RO      |
| 0x918   | RX_65to127B_31_0            | Number of received frames between 65–127 bytes (lower 32 bits)                                                      | RO      |
| 0x919   | RX_65to127B_63_32           | Number of received frames between 65–127 bytes (upper 32 bits)                                                      | RO      |
| 0x91A   | RX_128to255B_31_0           | Number of received frames between 128 –255 bytes (lower 32 bits)                                                    | RO      |
| 0x91B   | RX_128to255B_63_3<br>2      | Number of received frames between 128 –255 bytes (upper 32 bits)                                                    | RO      |
| 0x91C   | RX_256to511B_31_0           | Number of received frames between 256 –511 bytes (lower 32 bits)                                                    | RO      |
|         | ·                           |                                                                                                                     | ntinued |





| Address | Name                       | Description                                                                                                                              | Access |
|---------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 0x91D   | RX_256to511B_63_3<br>2     | Number of received frames between 256 $-511$ bytes (upper 32 bits)                                                                       | RO     |
| 0x91E   | RX_512to1023B_31_<br>0     | Number of received frames between 512–1023 bytes (lower 32 bits)                                                                         | RO     |
| 0x91F   | RX_512to1023B_63_<br>32    | Number of received frames between 512 $-1023$ bytes (upper 32 bits)                                                                      | RO     |
| 0x920   | RX_1024to1518B_31<br>_0    | Number of received frames between 1024–1518 bytes (lower 32 bits)                                                                        | RO     |
| 0x921   | RX_1024to1518B_63<br>_32   | Number of received frames between 1024–1518 bytes (upper 32 bits)                                                                        | RO     |
| 0x922   | RX_1519toMAXB_31_<br>0     | Number of received frames between 1519 bytes and the maximum size defined in the MAX_RX_SIZE_CONFIG register (lower 32 bits)             | RO     |
| 0x923   | RX_1519toMAXB_63_<br>32    | Number of received frames between 1519 bytes and the maximum size defined in the RXMAC_SIZE_CONFIG register (upper 32 bits)              | RO     |
| 0x924   | RX_OVERSIZE_31_0           | Number of oversized frames (frames with more bytes than the number specified in the RXMAC_SIZE_CONFIG register) received (lower 32 bits) | RO     |
| 0x925   | RX_OVERSIZE_63_32          | Number of oversized frames (frames with more bytes than the number specified in the RXMAC_SIZE_CONFIG register) received (upper 32 bits) | RO     |
| 0x926   | RX_MCAST_DATA_OK_<br>31_0  | Number of valid multicast frames received, excluding control frames (lower 32 bits)                                                      | RO     |
| 0x927   | RX_MCAST_DATA_OK_<br>63_32 | Number of valid multicast frames received, excluding control frames (upper 32 bits)                                                      | RO     |
| 0x928   | RX_BCAST_DATA_OK_<br>31_0  | Number of valid broadcast frames received, excluding control frames (lower 32 bits)                                                      | RO     |
| 0x929   | RX_BCAST_DATA_OK_<br>63_32 | Number of valid broadcast frames received, excluding control frames (upper 32 bits)                                                      | RO     |
| 0x92A   | RX_UCAST_DATA_OK_<br>31_0  | Number of valid unicast frames received, excluding control frames (lower 32 bits)                                                        | RO     |
| 0x92B   | RX_UCAST_DATA_OK_<br>63_32 | Number of valid unicast frames received, excluding control frames (upper 32 bits)                                                        | RO     |
| 0x92C   | RX_MCAST_CTRL_OK_<br>31_0  | Number of valid multicast frames received, excluding data frames (lower 32 bits)                                                         | RO     |
| 0x92D   | RX_MCAST_CTRL_OK_<br>63_32 | Number of valid multicast frames received, excluding data frames (upper 32 bits)                                                         | RO     |
| 0x92E   | RX_BCAST_CTRL_OK_<br>31_0  | Number of valid broadcast frames received, excluding data frames (lower 32 bits)                                                         | RO     |
| 0x92F   | RX_BCAST_CTRL_OK_<br>63_32 | Number of valid broadcast frames received, excluding data frames (upper 32 bits)                                                         | RO     |
| 0x930   | RX_UCAST_CTRL_OK_<br>31_0  | Number of valid unicast frames received, excluding data frames (lower 32 bits)                                                           | RO     |
| 0x931   | RX_UCAST_CTRL_OK_<br>63_32 | Number of valid unicast frames received, excluding data frames (upper 32 bits)                                                           | RO     |



| Address           | Name             | Description                                                                                                                                                                                                                                                                                    | Access   |
|-------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| 0x932             | RX_PAUSE_31_0    | Number of received pause frames, with or without error (lower 32 bits)                                                                                                                                                                                                                         | RO       |
| 0x933             | RX_PAUSE_63_32   | Number of received pause frames, with or without error (upper 32 bits)                                                                                                                                                                                                                         | RO       |
| 0x934             | RX_RNT_31_0      | Number of received runt packets (lower 32 bits)<br>A run is a packet of size less than 64 bytes but greater than eight<br>bytes. If a packet is eight bytes or smaller, it is considered a<br>decoding error and not a runt frame, and the IP core does not flag<br>it nor count it as a runt. | RO       |
| 0x935             | RX_RNT_63_32     | Number of received runt packets (upper 32 bits)<br>A run is a packet of size less than 64 bytes but greater than eight<br>bytes. If a packet is eight bytes or smaller, it is considered a<br>decoding error and not a runt frame, and the IP core does not flag<br>it nor count it as a runt. | RO       |
| 0x936             | RX_st_31_0       | Number of RX frame starts (lower 32 bits)                                                                                                                                                                                                                                                      | RO       |
| 0x937             | RX_st_63_32      | Number of RX frame starts (upper 32 bits)                                                                                                                                                                                                                                                      | RO       |
| 0x938             | RX_lenerr_31_0   | Number of RX length errors (lower 32 bits)                                                                                                                                                                                                                                                     | RO       |
| 0x939             | RX_lenerr_63_32  | Number of RX length errors (upper 32 bits)                                                                                                                                                                                                                                                     | RO       |
| 0x93A             | RX_pfc_err_31_0  | Number of RX PFC frame with CRC error (lower 32 bits)                                                                                                                                                                                                                                          | RO       |
| 0x93B             | RX_pfc_err_63_32 | Number of RX PFC frame with CRC error (upper 32 bits)                                                                                                                                                                                                                                          | RO       |
| 0x93C             | RX_pfc_31_0      | Number of RX PFC frames without error (lower 32 bits)                                                                                                                                                                                                                                          | RO       |
| 0x93D             | RX_pfc_63_32     | Number of RX PFC frames without error (upper 32 bits)                                                                                                                                                                                                                                          | RO       |
| 0x93E to<br>0x93F | Reserved         |                                                                                                                                                                                                                                                                                                |          |
| 0x940             | rxstat_revid     | Returns a 4 byte value indicating the revision of this design                                                                                                                                                                                                                                  | RO       |
| 0x941             | rxstat_scratch   | 32 bits of scratch register space for testing                                                                                                                                                                                                                                                  | RW       |
| 0x942 to<br>0x944 | Reserved         |                                                                                                                                                                                                                                                                                                | ·        |
| 0x945             | RX_CNTR_CONFIG   | Bits[2:0]: Configuration of RX statistics counters:                                                                                                                                                                                                                                            | RW       |
|                   | 1                |                                                                                                                                                                                                                                                                                                | ontinued |





| Address     | Name                          | Description                                                                                                                                                                                                  | Access |
|-------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
|             |                               | • Bit[2] = 1: Freeze stats CSRs so that all RX Stats values read from the registers will be from the same moment.                                                                                            |        |
|             |                               | <ul> <li>Note that the actual stats collection counters are not frozen,<br/>but because they are all 'read' at the time of the freeze,<br/>they are cleared.</li> </ul>                                      |        |
|             |                               | <ul> <li>If a shadow request is started while snapshot is active, a<br/>new capture will be executed.</li> </ul>                                                                                             |        |
|             |                               | <ul> <li>Likewise, if a shadow request is active while snapshot is<br/>asserted, a new capture will be executed.</li> </ul>                                                                                  |        |
|             |                               | <ul> <li>While either a shadow request or a capture is active,<br/>rx_shadow_on will be high.</li> </ul>                                                                                                     |        |
|             |                               | <ul> <li>Snapshot and shadow requests apply to several of the RX<br/>PCS counters as well as MAC statistics</li> </ul>                                                                                       |        |
|             |                               | • Bit[1] = 1:Reset the parity error bit in RX Statistics Counter Status                                                                                                                                      |        |
|             |                               | <ul> <li>Parity error bit will remain in reset until rst_rx_parity is set<br/>back to 0</li> </ul>                                                                                                           |        |
|             |                               | • Bit[0] = 1: Reset all RX Stats counters                                                                                                                                                                    |        |
|             |                               | <ul> <li>RX stats will stay in reset until reset is set back to 0</li> </ul>                                                                                                                                 |        |
|             |                               | <ul> <li>Reset also applies when snapshot or shadow is active, and<br/>will clear the AVMM visible registers</li> </ul>                                                                                      |        |
|             |                               | <ul> <li>rst_rx_stats does not clear the parity error bit</li> </ul>                                                                                                                                         |        |
|             |                               | Bits[31:3] are Reserved.                                                                                                                                                                                     |        |
| 0x946       | RX_CNTR_STATUS                | <ul> <li>Bit[1] = 1: The CSRs for the RX Statistics are currently frozen,<br/>and holding the Stats values from the last time a shadow<br/>request was made.</li> </ul>                                      | RO     |
|             |                               | <ul> <li>Bit[0] = 1: A parity error was detected on at least one of the statistics counters since the last time this bit was cleared.</li> <li>Bits [31:2] are Reserved.</li> </ul>                          |        |
| 0x947-0x95F | Reserved                      |                                                                                                                                                                                                              |        |
| 0x960       | RX_Payload_OctetsOK<br>_31_0  | Number of received payload bytes in frames with no FCS,<br>undersized, oversized, or payload length errors. When RX VLAN/                                                                                    | RO     |
| 0x961       | RX_Payload_OctetsOK<br>_63_32 | SVLAN detection is enabled, VLAN/SVLAN header bytes are also<br>removed from the count. Use snapshot or shadow to freeze the<br>count before reading it to avoid value change while reading the<br>register. | RO     |
| 0x962       | RX_Frame_OctetsOK_<br>31_0    | Number of received bytes in frames with no FCS, undersized, oversized, or payload length errors. Use snapshot or shadow to                                                                                   | RO     |
| 0x963       | RX_Frame_OctetsOK_<br>63_32   | freeze the count before reading it to avoid value change while reading the register.                                                                                                                         | RO     |

### 2.12.8. 1588 PTP Registers

The 1588 PTP registers together with the 1588 PTP signals process and provide Precision Time Protocol (PTP) timestamp information as defined in the *IEEE 1588-2008 Precision Clock Synchronization Protocol for Networked Measurement and Control Systems Standard*. The 1588 PTP module provides you the support to implement the 1588 Precision Time Protocol in your design.



| Table 72. TX 1588 PTP Registers | Table 72. | TX 1588 PTP Registers |  |
|---------------------------------|-----------|-----------------------|--|
|---------------------------------|-----------|-----------------------|--|

| Addr  | Name                     | Bit    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | HW Reset<br>Value    | Access |
|-------|--------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------|
| 0xA00 | TXPTP_REVID              | [31:0] | IP core revision ID.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0504_2018          | RO     |
| 0xA01 | TXPTP_SCRAT<br>CH        | [31:0] | Scratch register available for testing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 32'b0                | RW     |
| 0xA05 | TX_PTP_CLK_<br>PERIOD    | [19:0] | 20-bit register holding the datapath clock period in<br>the IEEE 1588v2 format. This value is used to<br>estimate delays through the datapath.<br>Period of the 402.83 MHz EHIP clock in 1588v2<br>format.<br>Bits[19:16]: nanoseconds (ns)<br>Bits[15:0]: fractions of nanosecond                                                                                                                                                                                                                                | 0x27B81              | RW     |
| 0xA0A | TX_PTP_EXTR<br>A_LATENCY | [31:0] | User-defined extra latency the IP core adds to<br>outgoing TX 1-step and 2-step timestamps.<br>[31]: Sign bit, set to 1 for negative extra latency<br>Bits[30:16]: Extra latency in nanoseconds<br>Bits[15:0]: Extra latency in fractions of<br>nanosecond (value/17'h10000)<br>For example, to set a TX extra latency of +2.5 ns,<br>set tx_ptp_extra_latency to 32'h00028000.                                                                                                                                   | 32'b0                | RW     |
| 0xA0D | PTP_DEBUG                | [31:0] | <ul> <li>Controls a small number of PTP debug features.</li> <li>Bit[0] = 1: instead of inserting PTP field values<br/>in TX packets when executing PTP TX 1-step<br/>commands, insert fixed values</li> <li>Insert 8'hAA in all bytes that would have<br/>been used for timestamp bytes</li> <li>Insert 8'hBB in all bytes that would have<br/>been used for correction field bytes</li> <li>Insert 8'hCC in all bytes that would have<br/>been used for Extension bytes</li> <li>Bit[31:1]: Reserved</li> </ul> | 0x0                  | RW     |
| 0xB10 | TX_UI_REG                | [23:0] | <ul> <li>Sets the time of a single serial bit on the TX Serial interface.</li> <li>Sets the time for a single TX serial bit. This time is used to generate TX timestamp estimates.</li> <li>Bit[31:24]: Nanoseconds field for the time of a single serial TX bit</li> <li>[23:0]: Fractional nanoseconds field for the time of a single serial TX bit</li> </ul>                                                                                                                                                  | 0x9EE01/0x18<br>D302 | RW     |
| 0xB11 | RX_UI_REG                | [31:0] | <ul> <li>Sets the time of a single serial bit on the RX Serial interface.</li> <li>Sets the time for a single RX serial bit. This time is used to generate RX timestamp estimates.</li> <li>Bit[31:24]: Nanoseconds field for the time of a single serial RX bit</li> <li>[23:0]: Fractional nanoseconds field for the time of a single serial RX bit</li> </ul>                                                                                                                                                  | 0x9EE01/0x18<br>D302 | RW     |





#### Table 73.RX 1588 PTP Registers

| Addr  | Name                     | Bit    | Description                                                                                                                                                                                                                                                                                                                                                                           | HW Reset<br>Value | Access |
|-------|--------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------|
| 0xB00 | RXPTP_REVID              | [31:0] | IP core revision ID.                                                                                                                                                                                                                                                                                                                                                                  | 0x0504 2018       | RO     |
| 0xB01 | RXPTP_SCRAT<br>CH        | [31:0] | Scratch register available for testing.                                                                                                                                                                                                                                                                                                                                               | 32'b0             | RW     |
| 0xB06 | RX_PTP_EXTR<br>A_LATENCY | [31:0] | <ul> <li>32-bit specifying extra latency that EHIP adds to the incoming RX timestamps.</li> <li>Bit[31]: Sign bit, set to 1 for negative latency</li> <li>Bits[30:16]: Extra latency in nanoseconds</li> <li>Bits[15:0]: Extra latency in fractions of a nanosecond</li> <li>For example, to set an RX extra latency of 5.00 ns, set rx_ptp_extra_latency to 32'h00050000.</li> </ul> | 32'b0             | RW     |

#### Table 74. 10G/25G PTP PPM UI Adjustment Registers

| Addr  | Name             | Bit    | Description                                                                                                                                                                      | HW Default<br>Value | Access |
|-------|------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------|
| 0xB19 | TAM_SNAPSHO<br>T | [0]    | Time value control register.<br>When set, the values of the reference time value<br>and AM count number are recorded in TX_TAM and<br>TX_COUNT registers.                        | 0x0                 | RW     |
| 0xB1A | TX_TAM_L         | [31:0] | This register represents the lower 32-bits of the TX<br>TAM value.<br>TX_TAM[31:0]:<br>• Bits[31:16]: Nanosecond field for the LSB<br>• Bits[15:0]: Fractional nanoseconds field | 0×0                 | RO     |
| 0xB1B | TX_TAM_H         | [15:0] | This register represents the upper 16-bits of the TX_TAM value.<br>TX_TAM [47:32]: Nanosecond field for the MSB                                                                  | 0x0                 | RO     |
| 0xB1C | TX_COUNT         | [15:0] | Contains the TX_AM count value.                                                                                                                                                  | 0x0                 | RO     |
| 0xB1D | RX_TAM_L         | [31:0] | This register represents the lower 32-bits of the RX<br>TAM value.<br>RX_TAM[31:0]:<br>• Bits[31:16]: Nanosecond field for the LSB<br>• Bits[15:0]: Fractional nanoseconds field | 0×0                 | RO     |
| 0xB1E | RX_TAM_H         | [15:0] | This register represents the upper 16-bits of the RX_TAM value.<br>RX_TAM[47:32]: Nanosecond field for the MSB                                                                   | 0x0                 | RO     |
| 0xB1F | RX_COUNT         | [15:0] | Contains the RX_AM count value.                                                                                                                                                  | 0x0                 | RO     |

*Note:* TX\_UI\_REG and RX\_UI\_REG are defined in the Table 72 on page 238 table.

### **2.12.9. RS-FEC Registers**

For information on RS-FEC registers, refer to the *E-Tile Transceiver PHY User Guide*: *RS-FEC Registers*.

#### **Related Information**

E-Tile Transceiver PHY User Guide: RS-FEC Registers





### 2.12.10. PMA Registers

For information on PMA registers, refer to the E-Tile Transceiver PHY User Guide: PMA Register Map.

### **Related Information**

- E-Tile Transceiver PHY User Guide
- PMA Register Map ٠

## 2.13. Document Revision History for the E-tile Hard IP for Ethernet **Intel FPGA IP Core**

| Document Version | Intel Quartus<br>Prime Version | <b>IP Version</b> | Changes                                                                                                                                                                                                                                        |
|------------------|--------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2020.01.31       | 19.4                           | 19.4.0            | Made the following changes:                                                                                                                                                                                                                    |
|                  |                                |                   | Updated Parameter Editor Parameters section:                                                                                                                                                                                                   |
|                  |                                |                   | <ul> <li>Removed Reconfig clock rate parameter in the<br/>E-Tile Hard IP for Ethernet Intel FPGA IP<br/>Parameters: IP Tab table.</li> </ul>                                                                                                   |
|                  |                                |                   | <ul> <li>Added Enable Dynamic RSFEC for KR<br/>parameter in the E-Tile Hard IP for Ethernet<br/>Intel FPGA IP Parameters: IP Tab table.</li> </ul>                                                                                             |
|                  |                                |                   | <ul> <li>Added Enable asynchronous adapter clocks<br/>parameter in the E-Tile Hard IP for Ethernet<br/>Intel FPGA IP Parameters: 10GE/25GE Tab<br/>table.</li> </ul>                                                                           |
|                  |                                |                   | <ul> <li>Added Ready latency parameter in the E-Tile<br/>Hard IP for Ethernet Intel FPGA IP Parameters:<br/>10GE/25GE Tab table.</li> </ul>                                                                                                    |
|                  |                                |                   | <ul> <li>Added Enable asynchronous adapter clocks<br/>parameter in the E-Tile Hard IP for Ethernet<br/>Intel FPGA IP Parameters: 100GE Tab table.</li> </ul>                                                                                   |
|                  |                                |                   | <ul> <li>Updated the parallel clock frequency value to<br/>161.132 MHz for 10GE data rate in the <i>PTP</i><br/><i>Timestamp Accuracy per Ethernet Data Rate</i> table.</li> <li>Updated <i>PTP Transmit Functionality</i> section:</li> </ul> |
|                  |                                |                   | <pre>- Added o_sl_ptp_ets_valid,<br/>o_sl_ptp_ets_fp[7:0], and<br/>o_sl_ptp_ets[95:0] signals in the Example<br/>Waveform for 2-step TX Timestamp using<br/>i_sl_ptp_ts_req Signal figure.</pre>                                               |
|                  |                                |                   | <ul> <li>Added i_sl_ptp_cf_offset and<br/>i_sl_ptp_tx_its[95:0] signals in the<br/>Example Waveform for 1-step TX Timestamp<br/>using i_sl_ptp_ins_cf Signal figure.</li> </ul>                                                                |
|                  |                                |                   | <ul> <li>Accurately updated all signal names.</li> </ul>                                                                                                                                                                                       |
|                  |                                |                   | • Added new section: <i>TX and RX PTP Extra Latency</i> .                                                                                                                                                                                      |
|                  |                                |                   | • Updated o_sl_ptp_rx_its signal's width in the<br>Example Waveform PTP Timestamp on RX PTP<br>Interface figure.                                                                                                                               |
|                  |                                |                   | • Added link to the <i>Ethernet Design Example</i><br><i>Components User Guide</i> in the <i>PTP Timpestamp and</i><br><i>TOD Formats</i> section.                                                                                             |
|                  |                                |                   | • Clarified the i_csr_rst_n/i_sl_csr_rst_n reset sequence in the <i>Reset</i> section.                                                                                                                                                         |
|                  |                                |                   | • Added clarifying notes in the <i>Custom Rate Interface</i> section.                                                                                                                                                                          |
|                  |                                |                   | continued                                                                                                                                                                                                                                      |



r



| <ul> <li>Added clarifying notes in the Deterministic Latency<br/>Interface section.</li> <li>Updated 1588 PTP Interface section: <ul> <li>Added comment clarifying 1-step and 2-step<br/>TX/RX timestamp interface signals behavior<br/>when Asynchronous mode is enabled.</li> <li>Updated o_sl_tx_ptp_ready[n-1:0] and<br/>o_sl_rx_ptp_ready[n-1:0] signals<br/>description in the Signals of the PTP Status<br/>Interface table.</li> </ul> </li> <li>Updated text in the Miscellaneous Status and<br/>Debug Signals section.</li> <li>Added three new adaptation flows: <ul> <li>Ethernet Adaptation Flow for 10G/25G and<br/>100G/4x25G Dynamic Reconfiguration Design<br/>Example</li> <li>Ethernet Adaptation Flow with External AIB<br/>Clocking and PTP</li> <li>Ethernet Adaptation Flow with non-external AIB<br/>Clocking and PTP</li> <li>Updated Clocks section.</li> <li>Updated description of i_sl_clk_tcx/rx and<br/>i_sl_async_clk_tx/rx signals in the Clock<br/>Inputs table.</li> <li>Added new section: Asynchronous Adapter Clock<br/>in 25G Mode.</li> <li>Added new section: Asynchronous Adapter Clock<br/>in 100G Mode.</li> </ul></li></ul> | <b>Document Version</b> | Intel Quartus<br>Prime Version | IP Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                         |                                |            | <ul> <li>Interface section.</li> <li>Updated 1588 PTP Interface section: <ul> <li>Added comment clarifying 1-step and 2-step TX/RX timestamp interface signals behavior when Asynchronous mode is enabled.</li> <li>Updated o_sl_tx_ptp_ready[n-1:0] and o_sl_rx_ptp_ready[n-1:0] signals description in the Signals of the PTP Status Interface table.</li> <li>Updated text in the Miscellaneous Status and Debug Signals section.</li> <li>Added three new adaptation flows: <ul> <li>Ethernet Adaptation Flow for 10G/25G and 100G/4x25G Dynamic Reconfiguration Design Example</li> <li>Ethernet Adaptation Flow with External AIB Clocking and PTP</li> <li>Ethernet Adaptation Flow with non-external AIB Clocking</li> </ul> </li> <li>Updated i_reconfig_clk clock frequency range to 100-125 MHz in the Clock Inputs table.</li> <li>Updated description of i_sl_clk_tx/rx and i_sl_async_clk_tx/rx signals in the Clock Inputs table.</li> <li>Added new section: Asynchronous Adapter Clock in 100G Mode.</li> </ul> </li> </ul> |



| <b>Document Version</b> | Intel Quartus<br>Prime Version | <b>IP Version</b> | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------|--------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         |                                |                   | <ul> <li>Updated Reset section:         <ul> <li>Added Intel recommendation details on how to perform reset an IP.</li> <li>Updated the i_csr_rst_n/i_tx_rsn_n, and i_rx_rsn_n signals for RX_FEC and TX_FEC blocks in the Reset Signals Function table</li> </ul> </li> <li>Updated Auto Negotiation and Link Training Registers section:         <ul> <li>Added the rsfec_capable, rsfec_request, anlt_seq_cfg_txinv, and anlt_seq_cfg_txinv, and anlt_seq_cfg_trxinv signals in the ANLT Sequencer Config.</li> <li>Added the enable_consortium_next_page_send, enable_consortium_next_page_receive, enable_consortium_next_page_receive, enable_consortium_next_page_tech_ability_code, and consortium_oui signals in the Auto Negotiation Config Register 1.</li> <li>Added the an_next_page and consortium_oui_upper in the Auto Negotiation Config Register 2.</li> <li>Added the consortium_next_page_received, consortium_next_page_received, consortium_next_page_received, consortium_negotiated_port_type, and rs_fec_negotiated_port_type in the Auto Negotiation Status Register.</li> <li>Updated description of ieee_negotiated_port_type in the Auto Negotiation Status Register 5.</li> <li>Added ne wauto Negotiation Config Register 6.</li> <li>Updated the an_lp_adv_tech_a in the Auto Negotiation Status Register 5.</li> <li>Added new Auto Negotiation Config Register 6.</li> <li>Updated description of override_consortium_next_page_tech and override_consortium_next_page_tech</li> <li>Updated description of override register 5.</li> <li>Added new Auto Negotiation Config Register 5.</li> <li>Added new Auto Negotiation Config Register 5.</li> <li>Updated description of override_consortium_next_page_tech and override_consortium_next_page_tech</li> <li>Updated description of override register 5.</li> <li>Updated description of override_conso</li></ul></li></ul> |
| 2020.01.16              | 19.3                           | 19.3.0            | <ul> <li>Made the following changes:</li> <li>Updated tx_clkout and rx_clkout to 161.132<br/>MHz in the Ethernet 25G x 4 (FEC On) Master-Slave<br/>Configuration: Dynamic Reconfiguration figure.</li> <li>Updated legend with missing clocks in the Ethernet<br/>25G x 4 (FEC On) Master-Slave Configuration:<br/>Dynamic Reconfiguration and Ethernet 25G x 4<br/>(FEC On) Master-Slave Configuration: External AIB<br/>Clocking figures.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2019.12.30              | 19.3                           | 19.3.0            | Made the following changes:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |





| <b>Document Version</b> | Intel Quartus<br>Prime Version | <b>IP Version</b> | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------|--------------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         |                                |                   | • Added 0x864 ~ 0x869 registers and their descriptions in the <i>Reconfiguration and Status Register Descriptions: TX Statistics Registers</i> section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2019.11.15              | 19.3                           | 19.3.0            | <ul> <li>Made the following changes:</li> <li>Added Intel Agilex device family support.</li> <li>Added Ethernet Link Inspector in the <i>E-Tile Hard IP</i> for Ethernet Intel FPGA IP Features table.</li> <li>Added note clarifying transceiver speed grade -3 support in the <i>E-Tile Hard IP</i> for Ethernet Intel FPGA IP Device Speed Grade Support.</li> <li>Updated IP version, Intel Quartus Prime version, and release date in the <i>E-tile Hard IP</i> for Ethernet Intel FPGA IP Current Release Information table.</li> <li>Updated parameters description in the Parameter Editor Parameters section: <ul> <li>Enable Auto-Negotiation on Reset</li> <li>Link Fall Inhibit Time</li> <li>Auto-Negotiation Master</li> <li>Advertise both 10G and 25G during AN</li> <li>Enable Link Training on Reset</li> </ul> </li> <li>Restructured <i>1588 Precision Time Protocol Interface</i> section: <ul> <li>Updated the <i>PTP Receive Block Diagram</i> to include the RX and TX UI Adjustment block</li> <li>Added new <i>TX and RX Unit Interval Adjustment</i> section</li> </ul> </li> <li>Updated Ordering code from IP-ETH-ETILEHARDIP to IP-ETH-ETILEHARDIP and Reset table.</li> <li>Updated ordering code from IP-ETH-ETILEHARDIP to IP-ETH-ETILEHARDIP to IP-ETH-ETILEHARDIP for Ethernet Intel FPGA IP Current Release Information table.</li> <li>Renamed Guidelines and Restrictions section to Guidelines and Restrictions for 24-channel placement variant.</li> <li>Added new section Guidelines and Restrictions for 16-channel placement variant.</li> <li>Added new section Guidelines and Restrictions for 16-channel placement variant.</li> <li>Added clarification in <i>PTP Transmit Functionality</i> and <i>PTP Receive Functionality</i> sections stating that TX/RX PTP operations start only after the o_sl_rx/tx_ready signal is set.</li> <li>Clarified statement to include i_sl_tx_rst_n reset for 10G/25G variant in the Reset Sequence.</li> <li>Reworded description of PTP registers in the 1588 PTP Interface section.</li> <li>Updated Reset Sequence with External AIB Clocking section.</li> <li>Updated Reset</li></ul> |

continued...



L



| <b>Document Version</b> | Intel Quartus<br>Prime Version | IP Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------|--------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         |                                |            | <ul> <li>Removed unclear statement from<br/>i_reconfig_reset description in the <i>Reset</i><br/><i>Signals</i> section.</li> <li>Added clarification in the <i>Auto-Negotiation and Link</i><br/><i>Training</i> section: When enabled, link training<br/>supports the initial and continuous adaptation.</li> <li>Added note to clarify that RX recovered clock is not<br/>available for PTP channels when PTP enabled, in the<br/><i>Clock Outputs</i> table.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2019.09.18              | 19.2                           | 19.2.0     | <ul> <li>Updated Variant Selection figure in the <i>About the E-tile Hard IP for Ethernet Intel FPGA IP Core</i> section.</li> <li>Single 25G MAC with PCS and optional 1588PTP and (528,514) RS-FEC is not supported</li> <li>1 to 4-10GE/25G MAC with PCS and optional 1588PTP and (528,514) RS-FEC is not supported</li> <li>Updated E-Tile Channel Placement Tool link in the <i>Channel Placement</i> section.</li> <li>Updated Example Waveform PTP Timestamp on RX PTP Interface table in the <i>PTP Receive Functionality</i> table.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2019.08.07              | 19.2                           | 19.2.0     | <ul> <li>Updated Variant Selection figure in the About the E-tile Hard IP for Ethernet Intel FPGA IP Core section.</li> <li>Clarified comments in the MAC TX Datapath and the TX Preamble, Start, and SFD Insertion sections.</li> <li>Removed MAC adapters support for the 100G channel in the E-Tile Hard IP for Ethernet Intel FPGA IP Overview and the Resource Utilization sections.</li> <li>Updated the Release Information section.</li> <li>Updated the Specifying the IP Core Parameters and Options section.</li> <li>Added the Reset Sequence with External AIB Clocking section.</li> <li>Updated the 100GE with RS FEC Variant section.</li> <li>Updated the Two Channels 100GE/25GE with RS-FEC and PTP Variant and the Three Channels 100GE/25GE with RS-FEC and PTP Variant and the Three Channels 100GE/25GE with RS-FEC and PTP Variant and the Three Channels 100GE/25GE with RS-FEC and PTP Variant and the Three Channels 100GE/25GE with RS-FEC and PTP Variant and the Three Channels 100GE/25GE with RS-FEC and PTP Variant section.</li> <li>Added link to Intel Stratix 10 Device Datasheet in the E-tile Hard IP for Ethernet Intel FPGA IP Device Speed Grade Support section.</li> <li>Updated the Reconfig clock rate parameter description in the E-tile Hard IP for Ethernet Intel FPGA IP Parameters: IP Tab section.</li> <li>Added reset information in the Four 25G Ethernet Channels (with FEC) within the Single FEC block - Master-Slave Configuration: Option 2 section.</li> <li>Updated the 25G Ethernet Channel (with PTP and External AIB clocking) section.</li> <li>Updated behavior of i_rx_rst_n signal in RX PCS and RX FEC blocks in the Reset Signal Functions table.</li> <li>Renamed the PMA Register Base Addresses table with Transceiver Reconfiguration Interface Register Base Addresses name.</li> </ul> |





| <b>Document Version</b> | Intel Quartus<br>Prime Version | IP Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------|--------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         |                                |            | <ul> <li>Updated following bits in Auto Negotiation and Link<br/>Training Registers:         <ul> <li>Removed RX polarity inversion for lane 0 to lane<br/>3 signals anlt_seq_cfg_rxinv in ANLT<br/>Sequencer Config Fields register</li> <li>Removed TX polarity inversion for lane 0 to lane<br/>3 signals anlt_seq_cfg_txinv in ANLT<br/>Sequencer Config Fields register</li> <li>Removed support for dynamic RS-FEC signals<br/>rsfec_request, rsfec_capable in ANLT<br/>Sequencer Config Fields register</li> <li>Removed rs_fec_negotiated in Auto<br/>Negotiation Status Register</li> <li>Removed consortium_next_page_received<br/>in Auto Negotiation Status Register</li> <li>Updated override_an_tech_22_8, bits<br/>[23:19] in Auto Negotiation Config Register 5</li> <li>Updated an_lp_adv_tech_a, bits [15:11] in<br/>Auto Negotiation Status Register 5</li> </ul> </li> <li>Added Minimizing PMA Adaptation Time section in<br/>the PMA Registers chapter.</li> <li>Added Ethernet Link Inspector chapter.</li> </ul> |
| 2019.05.17              | 19.1                           | 19.1       | <ul> <li>Added Ethernet Enk Enspector energet.</li> <li>Added information for Custom PCS variations.</li> <li>Added 1588 PTP feature support for 100G Ethernet rate variations.</li> <li>Added information for external AIB clocking feature support.</li> <li>Added the following parameters in <i>Parameter Editor Parameters</i> section:         <ul> <li>RSFEC Clocking Mode</li> <li>Enable external AIB clocking</li> <li>Enable external AIB clocking</li> <li>Enable JTAG to Avalon Master Bridge</li> <li>Number of PCS Channels in core</li> <li>Custom PCS mode</li> <li>RSFEC Fibre Channel(s) mode</li> <li>Custom PCS Rate</li> <li>PMA modulation type</li> <li>PMA reference clock frequency</li> <li>Enable custom rate regulation</li> </ul> </li> <li>Added 312.5 and 644.53125 MHz options for PHY Reference Frequency parameter in <i>E-tile Hard IP for Ethernet Intel FPGA Parameters: 10GE/25GE Tab</i> table.</li> <li>Updated the width of the</li></ul>                                                      |

Send Feedback



| <b>Document Version</b> | Intel Quartus<br>Prime Version | <b>IP Version</b> | Changes                                                                                                                                                                                                         |
|-------------------------|--------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         |                                |                   | Added the following PTP timestamp diagrams in PTP<br>Transmit Functionality and PTP Receive<br>Functionality:                                                                                                   |
|                         |                                |                   | <ul> <li>Example Waveform for 2-step TX Timestamp<br/>using i_ptp_ts_req Signal</li> </ul>                                                                                                                      |
|                         |                                |                   | <ul> <li>Example Waveform for 1-step TX Timestamp<br/>using i_ptp_ins_ets Signal</li> </ul>                                                                                                                     |
|                         |                                |                   | <ul> <li>Example Waveform for for 1-step TX Timestamp<br/>using i_ptp_ins_cf Signal</li> </ul>                                                                                                                  |
|                         |                                |                   | <ul> <li>Example Waveform PTP Timestamp on RX PTP<br/>Interface</li> </ul>                                                                                                                                      |
|                         |                                |                   | • Added PTP Timestamp Accuracy and Parallel Clock<br>Frequency Support per Ethernet Data Rate table in<br>Implementing a 1588 System That Includes a E-Tile<br>Hard IP for Ethernet Intel FPGA IP Core section. |
|                         |                                |                   | • Removed the following diagrams from<br>Implementing a 1588 System That Includes a E-Tile<br>Hard IP for Ethernet Intel FPGA IP Core:                                                                          |
|                         |                                |                   | <ul> <li>Example Ethernet System with Ordinary Clock<br/>Master and Ordinary Clock Slave</li> </ul>                                                                                                             |
|                         |                                |                   | <ul> <li>Hardware Configuration Example Using E-Tile</li> <li>Hard IP for Ethernet Intel FPGA IP in a 1588</li> <li>System in Transparent Clock Mode</li> </ul>                                                 |
|                         |                                |                   | <ul> <li>— Software Flow Using Transparent Clock Mode<br/>System</li> </ul>                                                                                                                                     |
|                         |                                |                   | <ul> <li>Example Boundary Clock with One Slave Port<br/>and Two Master Ports</li> </ul>                                                                                                                         |
|                         |                                |                   | <ul> <li>Added dynamic reconfiguration clock requirements<br/>to i_sl_clk_tx/i_sl_clk_tx[n] and<br/>i_sl_clk_rx/i_sl_clk_rx[n] in Clock Inputs<br/>table.</li> </ul>                                            |
|                         |                                |                   | • Added the following topics in the <i>Clock Network Use Cases</i> section:                                                                                                                                     |
|                         |                                |                   | <ul> <li>— 10G Ethernet Channel (with PTP and without<br/>External AIB Clocking)</li> </ul>                                                                                                                     |
|                         |                                |                   | <ul> <li>— 25G Ethernet Channel (with PTP and without<br/>External AIB Clocking)</li> </ul>                                                                                                                     |
|                         |                                |                   | <ul> <li>— 10G Ethernet Channel (with PTP and External<br/>AIB Clocking)</li> </ul>                                                                                                                             |
|                         |                                |                   | <ul> <li>25G Ethernet Channel (with PTP and External<br/>AIB Clocking)</li> </ul>                                                                                                                               |
|                         |                                |                   | Added RX recovered clock frequency for SyncE support in <i>Clock Outputs</i> table.                                                                                                                             |
|                         |                                |                   | Added 10/25G Ethernet Channel (with PTP and<br>without External AIB Clocking) and 10/25G<br>Ethernet Channel (with PTP and External AIB<br>Clocking) sections.                                                  |
|                         |                                |                   | continued                                                                                                                                                                                                       |





| <b>Document Version</b> | Intel Quartus<br>Prime Version | IP Version | Changes                                                                                                                                                               |
|-------------------------|--------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         |                                |            | Added the following bits in Auto Negotiation and<br>Link Training Registers:                                                                                          |
|                         |                                |            | — seq_force_mode in ANLT Sequencer Config                                                                                                                             |
|                         |                                |            | <ul> <li>anlt_seq_cfg_ilpbk in ANLT Sequencer<br/>Config</li> </ul>                                                                                                   |
|                         |                                |            | — anlt_seq_cfg_txinv in ANLT Sequencer<br>Config                                                                                                                      |
|                         |                                |            | <pre>- anlt_seq_cfg_rxinv in ANLT Sequencer<br/>Config</pre>                                                                                                          |
|                         |                                |            | <ul> <li>kr_pause in ANLT Sequencer Config</li> </ul>                                                                                                                 |
|                         |                                |            | <ul> <li>high_effort_train in Link Training Config<br/>Register 1</li> </ul>                                                                                          |
|                         |                                |            | <pre>- train_start_initpre in Link Training Config<br/>Register 1</pre>                                                                                               |
|                         |                                |            | <ul> <li>lt_cfgl_disable_rxcal in Link Training<br/>Config Register 1</li> </ul>                                                                                      |
|                         |                                |            | <ul> <li>lt_cfgl_disable_prxcal in Link Training<br/>Config Register 1</li> </ul>                                                                                     |
|                         |                                |            | <ul> <li>lt_cfgl_disable_prelt in Link Training<br/>Config Register 1</li> </ul>                                                                                      |
|                         |                                |            | <ul> <li>lt_cfg1_disable_postlt in Link Training<br/>Config Register 1</li> </ul>                                                                                     |
|                         |                                |            | <ul> <li>lt_cfg1_ovrd_lf in Link Training Config<br/>Register 1</li> </ul>                                                                                            |
|                         |                                |            | <ul> <li>lt_cfg1_ovrd_hf in Link Training Config<br/>Register 1</li> </ul>                                                                                            |
|                         |                                |            | <ul> <li>lt_cfg1_ovrd_bw in Link Training Config<br/>Register 1</li> </ul>                                                                                            |
|                         |                                |            | <ul> <li>restart_link_training_ln0 in Link<br/>Training Config Register 2</li> </ul>                                                                                  |
|                         |                                |            | <ul> <li>restart_link_training_ln2 in Link<br/>Training Config Register 2</li> </ul>                                                                                  |
|                         |                                |            | <ul> <li>restart_link_training_ln3 in Link<br/>Training Config Register 2</li> </ul>                                                                                  |
|                         |                                |            | <ul> <li>force_tx_nonce_value in Auto Negotiation<br/>Config Register 1</li> </ul>                                                                                    |
|                         |                                |            | <ul> <li>consortium_oui_upper in Auto Negotiation<br/>Config Register 2</li> </ul>                                                                                    |
|                         |                                |            | Added AN Channel Override register.                                                                                                                                   |
|                         |                                |            | • Added Transfer Ready (AIB reset) Status for EHIP, ELANE, and PTP Channels register.                                                                                 |
|                         |                                |            | Added EHIP, ELANE, and RS-FEC Reset Status register.                                                                                                                  |
|                         |                                |            | Removed the following registers:                                                                                                                                      |
|                         |                                |            | <ul> <li>Reference Clock Frequency in KHz</li> </ul>                                                                                                                  |
|                         |                                |            | <ul> <li>Internal Error Vector for RX PCS</li> </ul>                                                                                                                  |
|                         |                                |            | <ul> <li>Internal Error Mask for RX PCS</li> </ul>                                                                                                                    |
|                         |                                |            | Rebranded Altera Debug Master Endpoint to Native<br>PHY Debug Master Endpoint in the <i>E-Tile Hard IP</i><br>for Ethernet Intel FPGA IP Parameters: IP Tab<br>table. |
|                         |                                |            | continued                                                                                                                                                             |



| <b>Document Version</b> | Intel Quartus<br>Prime Version | <b>IP Version</b> | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------|--------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2019.04.19              | 18.1.1                         | 18.1.1            | Updated <i>RX Malformed Packet Handling</i> section to clarify that packets with Error bytes are considered as malformed packets.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2019.01.11              | 18.1.1                         | 18.1.1            | <ul> <li>Added RS-FEC support 25G and 100G Ethernet rate with PCS Only, OTN, and FlexE variations.</li> <li>Updated the <i>Variant Selection</i> figure with new variations.</li> <li>Updated the <i>Resource Utilization for Selected Variations</i> table.</li> <li>Added the following parameters in the <i>E-Tile Hard IP for Ethernet Intel FPGA IP Parameters</i> table:         <ul> <li>IEEE1588/PTP channel placement restriction</li> <li>First RSFEC Lane</li> <li>Request RSFEC</li> <li>Advertise both 10G and 25G during AN</li> <li>Enable Link Training on Reset</li> <li>Enable Altera Debug Master Endpoint (ADME)</li> <li>Ready latency</li> </ul> </li> <li>Added 1588 Precision Time Protocol Interfaces topic.</li> <li>Added 1588 Precision Time Protocol Interfaces topic.</li> <li>Added 1588 Precision Time Protocol Interfaces topic.</li> <li>Added clock network use cases topic for the following use case:             <ul> <li>Single 25G Ethernet channel with single FEC block</li> <li>Four 25G Ethernet channel without FEC</li> <li>Four 25G Ethernet channel with aggregate FEC</li> </ul> </li> <li>Added <i>Guidelines and Restrictions</i> topic to describe supported configurations for multi Native PHY channels with RS-FEC and optional PTP.</li> <li>Added <i>Channel Placement Guidelines and Restrictions</i>.</li> <li>Restructured <i>Functional Description</i> section into <i>MAC, PCS/PCS66, PMA Direct Mode, Auto-Negotiation and Link Training, and TX and RX RS-FEC</i>.</li> <li>Added Determining Link Fault Condition.</li> </ul> |
|                         |                                |                   | commuea                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |





| Document Version | Intel Quartus<br>Prime Version | <b>IP Version</b> | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|--------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |                                |                   | <ul> <li>Added reset sequences in <i>Reset</i> chapter.</li> <li>Changed the following registers to reserved. These registers are not used in the IP core.         <ul> <li>Asymmetric PTP Latency address 0xA0B</li> <li>TX Extra Latency Information for PTP address 0xA0C</li> <li>TX Extra Latency Information for PTP address 0xA0E</li> <li>RX Extra Latency Information for PTP address 0xB07</li> <li>RX Extra Latency Information for PTP address 0xB08</li> </ul> </li> <li>Removed <i>PTP Asymmetric Latency</i> feature support from <i>E-Tile Hard IP for Ethernet Intel FPGA IP</i> table. This feature is not supported in the IP.</li> </ul> |
| 2018.08.10       | 18.0                           | 18.0              | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |





# **3. About the E-Tile CPRI PHY Intel FPGA IP**

The E-Tile CPRI PHY Intel FPGA IP implements the physical layer (layer 1) specification based on the *Common Public Radio Interface (CPRI)* v7.0 Specification (2015-10-09) in Intel Stratix 10 and Intel Agilex E-tile FPGA production devices. The IP supports up to four CPRI channels and the CPRI line rates of 2.4376, 3.0720, 4.9152, 6.1440, 9.8304 Gbps. This IP also supports 10.1376, 12.1651 and 24.33024 Gbps CPRI line rate with and without Reed-Solomon Forward Error Correction (RS-FEC).

## **3.1. Supported Features**

The E-Tile CPRI PHY Intel FPGA IP core has the following features:

- Compliant with the CPRI Specification V7.0 (2015-10-09)
- Supports up to four CPRI channels
- Supports configurable CPRI communication line bit rate of 2.4376, 3.0720, 4.9152, 6.1440, 9.8304, 10.1376, 12.1651 and 24.33024 Gbps using Intel Stratix 10 and Intel Agilex E-tile transceivers
- Supports dynamic reconfiguration to different line bit rates during run time
- Supports RS-FEC block for 10.1376, 12.1651 and 24.33024 Gbps line bit rate
- Supports deterministic latency measurement
- Provides register access interface to external or on-chip processor, using the Intel Avalon Memory-Mapped (Avalon-MM) interconnect specification
- Supports Physical Medium Attachment (PMA) adaptation

### Table 75. E-Tile CPRI PHY IP Core Feature Matrix

The Intel Quartus Prime Pro Edition software supports the following combinations

| CPRI Line Bit Rate<br>(Gbps) | Number of Channels<br>per Instance | RS-FEC Support   | Reference Clock<br>(MHz) | Deterministic<br>Latency Support |
|------------------------------|------------------------------------|------------------|--------------------------|----------------------------------|
| 2.4376                       | 1 to 4                             | No               | 153.6                    | Yes                              |
| 3.0720                       | 1 to 4                             | No               | 153.6                    | Yes                              |
| 4.9152                       | 1 to 4                             | No               | 153.6                    | Yes                              |
| 6.1440                       | 1 to 4                             | No               | 153.6                    | Yes                              |
| 9.8304                       | 1 to 4                             | No               | 153.6                    | Yes                              |
| 10.1376                      | 1 to 4                             | With and Without | 184.32                   | Yes                              |
| 12.1651                      | 1 to 4                             | With and Without | 184.32                   | Yes                              |
| 24.33024                     | 1 to 4                             | With and Without | 184.32                   | Yes                              |

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.





### **3.2. E-Tile CPRI PHY Intel FPGA IP Overview**

The E-Tile CPRI PHY Intel FPGA IP block diagrams show the main blocks, and internal and external connections for each variant.

### Figure 64. E-Tile CPRI PHY IP Block Diagram



- The E-Tile CPRI PHY IP core supports line bit rate of 2.4376, 3.0720, 4.9152, 6.144, 9.8304, 10.1376, 12.1651, and 24.33024 Gbps up to four channels. The RS-FEC block is optional for the IP core variations that target 10.1376, 12.1651, and 24.33024 Gbps CPRI line rate.
- The soft reset sequencer implements the reset sequence of the IP core.
- The IP variations with 2.4376, 3.0720, 4.9152, 6.144, and 9.8304 Gbps CPRI line rates include 8b/10b soft PCS and the IP variations that target CPRI line rates 10 .1376, 12.1651, and 24.33024 Gbps use 64b/66b hard PCS within the Native PHY.
- It supports latency measurement for delay calculation between the FPGA pins to the core.
- *Note:* You need to configure an E-tile Native PHY instance as a PLL that drives CPRI PHY's Application Interface Block (AIB) interface across all the channels. Refer to section *Master-Slave Configuration: Option 2* to see how to configure E-tile Native PHY as a PLL. The E-Tile CPRI PHY IP does not support *Master-Slave Configuration: Option 1*



### **Related Information**

- Master-Slave Configuration: Option 1 on page 147 ٠
- Master-Slave Configuration: Option 2 External AIB Clocking Scheme on page 148 •

# 3.3. E-Tile CPRI PHY Device Family Support

#### Table 76. **Intel FPGA IP Core Device Support Levels**

| Device Support<br>Level | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Advance                 | The IP core is available for simulation and compilation for this device family. Timing models include initial engineering estimates of delays based on early post-layout information. The timing models are subject to change as silicon testing improves the correlation between the actual silicon and the timing models. You can use this IP core for system architecture and resource utilization studies, simulation, pinout, system latency assessments, basic timing assessments (pipeline budgeting), and I/O transfer strategy (datapath width, burst depth, I/O standards tradeoffs). |
| Preliminary             | The IP core is verified with preliminary timing models for this device family. The IP core meets all functional requirements, but might still be undergoing timing analysis for the device family. It can be used in production designs with caution.                                                                                                                                                                                                                                                                                                                                           |
| Final                   | The IP core is verified with final timing models for this device family. The IP core meets all functional and timing requirements for the device family and can be used in production designs.                                                                                                                                                                                                                                                                                                                                                                                                  |

#### Table 77. **E-Tile CPRI PHY IP Core Device Family Support**

Shows the level of support offered by the E-Tile CPRI PHY IP core for each Intel FPGA device family.

| Device Family                           | Support    |
|-----------------------------------------|------------|
| Intel Stratix 10<br>E-tile devices only | Advance    |
| Intel Agilex<br>E-tile devices only     | Advance    |
| Other device families                   | No support |

## 3.4. Resource Utilization

The resources for the E-Tile CPRI PHY IP core were obtained from the Intel Quartus Prime Pro Edition software version 19.4

#### Table 78. **Resource Utilization for Selected Variations**

| CPRI Line Bit<br>Rate (With<br>number of<br>channel1) | Enable Native<br>PHY Debug<br>Master Endpoint<br>Parameter | ALMs  | ALUTs | Dedicated Logic<br>Registers | Memory 20K |
|-------------------------------------------------------|------------------------------------------------------------|-------|-------|------------------------------|------------|
| 24.33024 Gbps<br>with RS-FEC                          | On                                                         | 2,381 | 3,162 | 3,608                        | 6          |
| 24 Gbps without<br>RS-FEC                             | On                                                         | 2,251 | 3,054 | 3,395                        | 6          |
| 12.1651 Gbps<br>with RS-FEC                           | On                                                         | 2,356 | 3,141 | 3,573                        | 6          |
| 12.1651 Gbps<br>without RS-FEC                        | On                                                         | 2,225 | 3,019 | 3,355                        | 6          |
| continued                                             |                                                            |       |       |                              | continued  |





| CPRI Line Bit<br>Rate (With<br>number of<br>channel1) | Enable Native<br>PHY Debug<br>Master Endpoint<br>Parameter | ALMs  | ALUTs | Dedicated Logic<br>Registers | Memory 20K |
|-------------------------------------------------------|------------------------------------------------------------|-------|-------|------------------------------|------------|
| 10.1376 Gbps<br>with RS-FEC                           | On                                                         | 2,376 | 3,192 | 3,630                        | 6          |
| 10.1376 Gbps<br>without RS-FEC                        | On                                                         | 2,242 | 3,030 | 3,325                        | 6          |
| 9.8304 Gbps                                           | On                                                         | 2,749 | 3,742 | 4,653                        | 6          |
| 6.144 Gbps                                            | On                                                         | 2,763 | 3,776 | 4,700                        | 6          |
| 4.9152 Gbps                                           | On                                                         | 2,739 | 3,737 | 4,666                        | 6          |
| 3.0720 Gbps                                           | On                                                         | 2,756 | 3,751 | 4,677                        | 6          |
| 2.4376 Gbps                                           | On                                                         | 2,742 | 3,741 | 4,664                        | 6          |

## **3.5. Release Information**

IP versions are the same as the Intel Quartus Prime Design Suite software versions up to v19.1. From Intel Quartus Prime Design Suite software version 19.2 or later, IP cores have a new IP versioning scheme.

The IP versioning scheme (X.Y.Z) number changes from one software version to another. A change in:

- X indicates a major revision of the IP. If you update your Intel Quartus Prime software, you must regenerate the IP.
- Y indicates the IP includes new features. Regenerate your IP to include these new features.
- Z indicates the IP includes minor changes. Regenerate your IP to include these changes.

#### Table 79. E-Tile CPRI PHY Intel FPGA IP Core Release Information

| Item                        | Description      |
|-----------------------------|------------------|
| IP Version                  | 19.4.0           |
| Intel Quartus Prime Version | 19.4             |
| Release Date                | 2019.12.16       |
| Ordering Code               | IP-CPRI-v7-E-PHY |

## **3.6. E-Tile CPRI PHY Intel FPGA IP Core Device Speed Grade Support**

The E-Tile CPRI PHY Intel FPGA IP core supports Intel Stratix 10 devices with these speed grade properties:

- Transceiver speed grade: -1 or -2
- Core speed grade: -1 or -2



## 3.7. Getting Started

The following sections explain how to install, parameterize, simulate, and initialize the E-tile CPRI PHY Intel FPGA IP core:

### 3.7.1. Installing and Licensing Intel FPGA IP Cores

The Intel Quartus Prime Pro Edition software installation includes the Intel FPGA IP library. This library provides many useful IP cores for your production use without the need for an additional license. Some Intel FPGA IP cores require purchase of a separate license for production use. The Intel FPGA IP Evaluation Mode allows you to evaluate these licensed Intel FPGA IP cores in simulation and hardware, before deciding to purchase a full production IP core license. You only need to purchase a full production license for licensed Intel IP cores after you complete hardware testing and are ready to use the IP in production.

The Intel Quartus Prime software installs IP cores in the following locations by default:

#### Figure 65. **IP Core Installation Path**

#### 📄 intelFPGA( pro)

**quartus** - Contains the Intel Quartus Prime software

**ip** - Contains the Intel FPGA IP library and third-party IP cores

altera - Contains the Intel FPGA IP library source code

</p

#### Table 80. **IP Core Installation Locations**

| Location                                                    | Software                        | Platform |
|-------------------------------------------------------------|---------------------------------|----------|
| <pre><drive>:\intelFPGA_pro\quartus\ip\altera</drive></pre> | Intel Quartus Prime Pro Edition | Windows  |
| <home directory="">:/intelFPGA_pro/quartus/ip/altera</home> | Intel Quartus Prime Pro Edition | Linux    |

### 3.7.1.1. Intel FPGA IP Evaluation Mode

The free Intel FPGA IP Evaluation Mode allows you to evaluate licensed Intel FPGA IP cores in simulation and hardware before purchase. Intel FPGA IP Evaluation Mode supports the following evaluations without additional license:

- Simulate the behavior of a licensed Intel FPGA IP core in your system.
- Verify the functionality, size, and speed of the IP core quickly and easily. .
- Generate time-limited device programming files for designs that include IP cores. ٠
- Program a device with your IP core and verify your design in hardware.





Intel FPGA IP Evaluation Mode supports the following operation modes:

- **Tethered**—Allows running the design containing the licensed Intel FPGA IP indefinitely with a connection between your board and the host computer. Tethered mode requires a serial joint test action group (JTAG) cable connected between the JTAG port on your board and the host computer, which is running the Intel Quartus Prime Programmer for the duration of the hardware evaluation period. The Programmer only requires a minimum installation of the Intel Quartus Prime software, and requires no Intel Quartus Prime license. The host computer controls the evaluation time by sending a periodic signal to the device via the JTAG port. If all licensed IP cores in the design support tethered mode, the evaluation time runs until any IP core evaluation expires. If all of the IP cores support unlimited evaluation time, the device does not time-out.
- **Untethered**—Allows running the design containing the licensed IP for a limited time. The IP core reverts to untethered mode if the device disconnects from the host computer running the Intel Quartus Prime software. The IP core also reverts to untethered mode if any other licensed IP core in the design does not support tethered mode.

When the evaluation time expires for any licensed Intel FPGA IP in the design, the design stops functioning. All IP cores that use the Intel FPGA IP Evaluation Mode time out simultaneously when any IP core in the design times out. When the evaluation time expires, you must reprogram the FPGA device before continuing hardware verification. To extend use of the IP core for production, purchase a full production license for the IP core.





#### **Intel FPGA IP Evaluation Mode Flow** Figure 66.



Note: Refer to each IP core's user guide for parameterization steps and implementation details.

> Intel licenses IP cores on a per-seat, perpetual basis. The license fee includes firstyear maintenance and support. You must renew the maintenance contract to receive updates, bug fixes, and technical support beyond the first year. You must purchase a full production license for Intel FPGA IP cores that require a production license, before generating programming files that you may use for an unlimited time. During Intel FPGA IP Evaluation Mode, the Compiler only generates a time-limited device programming file (<project name>\_time\_limited.sof) that expires at the time limit. To obtain your production license keys, visit the Self-Service Licensing Center.

> The Intel FPGA Software License Agreements govern the installation and use of licensed IP cores, the Intel Quartus Prime design software, and all unlicensed IP cores.





#### **Related Information**

- Intel Quartus Prime Licensing Site
- Introduction to Intel FPGA Software Installation and Licensing

### 3.7.2. Specifying the IP Core Parameters and Options

The IP parameter editor allows you to quickly configure your custom IP variation. Use the following steps to specify IP core options and parameters in the Intel Quartus Prime Pro Edition software.

- 1. If you do not already have an Intel Quartus Prime Pro Edition project in which to integrate your E-Tile CPRI PHY IP core, you must create one.
  - a. In the Intel Quartus Prime Pro Edition, click File ➤ New Project Wizard to create a new Quartus Prime project, or File ➤ Open Project to open an existing Quartus Prime project. The wizard prompts you to specify a device.
  - b. Specify the device family **Intel Stratix 10** or **Agilex (FB/FA)** and select a production E-tile device that meets the speed grade requirements for the IP core.
  - c. Click Finish.
- 2. In the IP Catalog, locate and select E-tile CPRI PHY Intel FPGA IP. The New IP Variation window appears.
- 3. Specify a top-level name for your new custom IP variation. The parameter editor saves the IP variation settings in a file named <*your\_ip*>.ip.
- 4. Click **OK**. The parameter editor appears.
- 5. Specify the parameters for your IP core variation. Refer to Parameter Editor Parameters on page 51 for information about specific IP core parameters.
- 6. Optionally, to generate a simulation testbench or compilation and hardware design example, follow the instructions in the *Design Example User Guide*.
- 7. Click Generate HDL. The Generation dialog box appears.
- 8. Specify output file generation options, and then click **Generate**. The IP variation files generate according to your specifications.
- 9. Click Finish. The parameter editor adds the top-level .ip file to the current project automatically. If you are prompted to manually add the .ip file to the project, click Project ➤ Add/Remove Files in Project to add the file.
- 10. After generating and instantiating your IP variation, make appropriate pin assignments to connect ports and set any appropriate per-instance RTL parameters.

#### **Related Information**

E-tile Hard IP Intel Stratix 10 Design Example User Guide

### 3.7.3. Generated File Structure

The Intel Quartus Prime Pro Edition software generates the following IP core output file structure.





For information about the file structure of the design example, refer to the *E-tile Hard IP Intel Stratix 10 FPGA IP Design Examples User Guide*.

#### Figure 67. E-Tile CPRI PHY IP Core Generated Files



### Table 81. E-Tile CPRI PHY IP Core Generated Files

| File Name                          | Description                                                                                                                                                                          |  |  |  |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| <your_ip>.ip</your_ip>             | The Platform Designer system or top-level IP variation file. < your_ip> is the name that you give your IP variation.                                                                 |  |  |  |
| <your_ip>.cmp</your_ip>            | The VHDL Component Declaration ( . ${\tt cmp}$ ) file is a text file that contains local generic and port definitions that you can use in VHDL design files.                         |  |  |  |
| <your_ip>.html</your_ip>           | A report that contains connection information, a memory map showing the<br>address of each slave with respect to each master to which it is connected, and<br>parameter assignments. |  |  |  |
| <your_ip>_generation.rpt</your_ip> | IP or Platform Designer generation log file. A summary of the messages during IP generation.                                                                                         |  |  |  |
| <your_ip>.qgsimc</your_ip>         | Lists simulation parameters to support incremental regeneration.                                                                                                                     |  |  |  |
| <your_ip>.qgsynthc</your_ip>       | Lists synthesis parameters to support incremental regeneration.                                                                                                                      |  |  |  |
| continued                          |                                                                                                                                                                                      |  |  |  |





| File Name                                          | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <your_ip>.qip</your_ip>                            | Contains all the required information about the IP component to integrate and compile the IP component in the Intel Quartus Prime software.                                                                                                                                                                                                                                                 |
| <your_ip>.sopcinfo</your_ip>                       | Describes the connections and IP component parameterizations in your<br>Platform Designer system. You can parse its contents to get requirements<br>when you develop software drivers for IP components.                                                                                                                                                                                    |
|                                                    | Downstream tools such as the Nios II tool chain use this file. The .sopcinfo<br>file and the system.h file generated for the Nios II tool chain include address<br>map information for each slave relative to each master that accesses the slave.<br>Different masters may have a different address map to access a particular<br>slave component.                                         |
| <your_ip>.csv</your_ip>                            | Contains information about the upgrade status of the IP component.                                                                                                                                                                                                                                                                                                                          |
| <your_ip>.spd</your_ip>                            | Required input file for ip-make-simscript to generate simulation scripts for<br>supported simulators. The .spd file contains a list of files generated for<br>simulation, along with information about memories that you can initialize.                                                                                                                                                    |
| <your_ip>_bb.v</your_ip>                           | You can use the Verilog black-box (_bb.v) file as an empty module declaration for use as a black box.                                                                                                                                                                                                                                                                                       |
| <pre><your_ip>_inst.v or _inst.vhd</your_ip></pre> | HDL example instantiation template. You can copy and paste the contents of this file into your HDL file to instantiate the IP variation.                                                                                                                                                                                                                                                    |
| <your_ip>.regmap</your_ip>                         | If IP contains register information, .regmap file generates. The .regmap file describes the register map information of master and slave interfaces. This file complements the .sopcinfo file by providing more detailed register information about the system. This enables register display views and user customizable statistics in the System Console.                                 |
| <your_ip>.svd</your_ip>                            | Allows hard processor system (HPS) System Debug tools to view the register maps of peripherals connected to HPS in a Platform Designer system. During synthesis, the .svd files for slave interfaces visible to System Console masters are stored in the .sof file in the debug section. System Console reads this section, which Platform Designer can query for register map information. |
| <your_ip>.v or <your_ip>.vhd</your_ip></your_ip>   | For system slaves, Platform Designer can access the registers by name.<br>HDL files that instantiate each submodule or child IP core for synthesis or simulation.                                                                                                                                                                                                                           |
| mentor/                                            | Contains a ModelSim script msim_setup.tcl to set up and run a simulation.                                                                                                                                                                                                                                                                                                                   |
| synopsys/vcs/<br>synopsys/vcsmx/                   | Contains a shell script vcs_setup.sh to set up and run a VCS simulation.<br>Contains a shell script vcsmx_setup.sh and synopsys_ sim.setup file to<br>set up and run a VCS MX* simulation.                                                                                                                                                                                                  |
| cadence/                                           | Contains a shell script ncsim_setup.sh and other setup files to set up and run an NCSIM simulation.                                                                                                                                                                                                                                                                                         |
| submodules/                                        | Contains HDL files for the IP core submodules.                                                                                                                                                                                                                                                                                                                                              |
| <child cores="" ip="">/</child>                    | For each generated child IP core directory, Platform Designer generates synth/ andsim/ sub-directories.                                                                                                                                                                                                                                                                                     |

### **Related Information**

E-tile Hard IP Intel Stratix 10 Design Examples User Guide

Send Feedback



## 3.7.4. E-Tile CPRI PHY Intel FPGA IP Channel Placement

Each E-tile offers up to 24 fractured mode channels. For E-Tile CPRI PHY IP, each E-tile provides up to 23 channels since the 24th channel has to be configured in PLL mode to provide 403 MHz/806 MHz clock to other CPRI channels.

The section below explains how the First RSFEC lane and RSFEC Clocking Mode parameter works for the E-Tile CPRI PHY IP.

#### Figure 68. **E-Tile CPRI PHY IP Parameter Editor**

| Eile Edit System Generate View Tools Help                                                                                                                           |                         |                                                                                                                                      |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 🦉 Parameters 🙁                                                                                                                                                      | - ರ್ 🗆                  | Details 💠 👑 Block Symbol 😣 🗕 🗗 🗖                                                                                                     |
| System: test Path: alt_cpriphy_c3_0<br>E-Tile CPRIPHY Intel FPGA IP                                                                                                 | <u>D</u> etails         | E Show signals                                                                                                                       |
| alt_cpriphy_c3                                                                                                                                                      | Generate Example Design | alt_cpriphy_c3_0                                                                                                                     |
| [IP CPRI Channel(s) PMA Adaptation Example Design                                                                                                                   |                         | o_cdr_lock                                                                                                                           |
| ▼ CPRI Core Options           Number of CPRI Channels in core:           I ▼           First RSFEC Lane:           RSFEC Clocking Mode:           fec_dir_adp_clk_0 | -                       | o_tx_pll_locked<br>o_tx_pll_locked<br>i_rsfec_reconfig_addr<br>i_rsfec_reconfig_addr<br>i_rsfec_reconfig_ead<br>i_rsfec_reconfig_ead |
| Configuration, Debug and Extension Options                                                                                                                          |                         | i_rsfec_reconfig_read<br>i_rsfec_reconfig_read                                                                                       |
| Enable Native PHY Debug Master Endpoint                                                                                                                             |                         | i_rsfec_reconfig_write                                                                                                               |
|                                                                                                                                                                     |                         | noi         Presets         □         □         □           Presets for all_cpriphy_c3_0         0         0         0         0     |
|                                                                                                                                                                     |                         | Clear preset filters                                                                                                                 |
|                                                                                                                                                                     | -                       |                                                                                                                                      |
| II     Sissem Messages      Sissem Messages                                                                                                                         | - 5 0                   | Project<br>└─ Click New to create a preset.<br>Library<br>└─ No presets for E-Tile CPRI PHY Intel FPGA IP 19.4.0                     |
| Type Path                                                                                                                                                           |                         | No presets for E-The CPRI PHT Intel PPGA IP 19.4.0                                                                                   |
| (No messages)                                                                                                                                                       |                         |                                                                                                                                      |
| <b>4</b>                                                                                                                                                            |                         | Apply Update Delete New                                                                                                              |
| 0 Errors, 0 Warnings                                                                                                                                                |                         | Generate HDL                                                                                                                         |

The following figure shows one master 24 Gbps channel providing the datapath clock to other three slave 24 Gbps channels.

The E-Tile CPRI PHY IP uses Native PHY in PLL mode to provide 402.83 MHz and 805.66 MHz clock. All CPRI data rates use the Native PHY in PLL mode. For more information on how to implement the native PHY in PLL mode, refer to the E-tile Hard IP Intel Stratix 10 Design Examples User Guide.

As shown in the figure below, the E-tile CPRI PHY uses Ethernet's clock frequencies because the Ethernet to CPRI dynamic reconfiguration uses Ethernet as the power up protocol so that AIB clock is fixed at Ethernet line rate and it remains unchanged after reconfiguration to CPRI line rates.







#### Figure 69. E-Tile CPRI PHY (FEC On) Master-Slave Configuration

TX PMA generated parallel clock (line rate / 66)

RX PMA generated parallel clock (ine rate / 66) RX PMA generated parallel clock (line rate / PMA interface width)

All four channels use a common RS-FEC block. However, the RS-FEC block uses only one clock from the available four channels. The channel that provides the FEC clock works as a master. The other three channels that uses the same clock for clocking their TX and RX data path works as slave channels. This creates a dependency between the master and the slave channels.

When you implement one or multiple high speed CPRI data rates with RS-FEC channels, you select the first RS-FEC lane option. You have the flexibility to select which first lane to be your master channel.



#### **Related Information**

E-Tile Channel Placement Tool

### 3.7.4.1. One 24.33024 Gbps channel with RS-FEC

You can place the channel to first\_lane0, or first\_lane1, or first\_lane2 or first\_lane3.

The parameter options **first lane0** refers to ch0, **first lane1** refers to ch1, Note: first lane2 refers to ch2, and first lane3 refers to ch3 in all the figures throughout this document.

#### Figure 70. One 24.33024 Gbps Channel with RS-FEC



### 3.7.4.2. Two 24.33024 Gbps Channel with RS-FEC

You can place the first channel of your two channel to first\_lane0 or first\_lane1 or first lane2. You can choose any channel as a master channel from those two channels using the **RS-FEC Clocking Mode** parameter. For example, for **first\_lane1**, you can select either fec\_dir\_adp\_clk\_1, or fec\_dir\_adp\_clk\_2 as your master channel.

#### Figure 71. Two 24.33024 Gbps Channel with RS-FEC



2 channels w/1 rsfec rsfec first lane sel = ch0 rsfec\_clocking\_mode= fec dir adp clk0, or fec dir adp clk1



2 channels w/1 rsfec rsfec\_first\_lane\_sel = ch1 rsfec clocking mode= fec\_dir\_adp\_clk1, or fec dir adp clk2



2 channels w/1 rsfec rsfec first lane sel = ch2rsfec\_clocking\_mode= fec dir adp clk2, or fec dir adp clk3





#### 3.7.4.3. Three 24.33024 Gbps channels with RS-FEC

You can place the first channel of your three channel to **first\_lane0** or **first\_lane1**. You can choose any channel as a master channel from those three channels using the **RS-FEC Clocking Mode** parameter. For example, for **first\_lane0**, you can select **fec\_dir\_adp\_clk\_0**, **fec\_dir\_adp\_clk\_1**, or **fec\_dir\_adp\_clk\_2** as your master channel.

#### Figure 72. Three 24.33024 Gbps Channels with RS-FEC



rsfec\_first\_lane\_sel = ch0
rsfec\_clocking\_mode =
 fec\_dir\_adp\_clk\_0, or
 fec\_dir\_adp\_clk\_1, or
 fec\_dir\_adp\_clk\_2

| rsfec                 | channels |   |  |  |  |
|-----------------------|----------|---|--|--|--|
|                       |          | 3 |  |  |  |
|                       |          | 2 |  |  |  |
|                       |          | 1 |  |  |  |
|                       |          | 0 |  |  |  |
| 3 channels w/ 1 rsfec |          |   |  |  |  |

ELANE IP

rsfec\_first\_lane = ch1
rsfec\_clocking\_mode =
fec\_dir\_adp\_clk\_1, or
fec\_dir\_adp\_clk\_2, or
fec\_dir\_adp\_clk\_3

### 3.7.4.4. Four 24.33024 Gbps channels with RS-FEC

You can place the first channel of your three channel to **first\_lane0** only. You can choose any channel as a master channel from four channels using the **RS-FEC Clocking Mode** parameter. You can select **fec\_dir\_adp\_clk\_0**, **fec\_dir\_adp\_clk\_1**, **fec\_dir\_adp\_clk\_2**, or **fec\_dir\_adp\_clk\_3** as your master channel.

#### Figure 73. Four 24.33024 Gbps Channels with RS-FEC



4 channels w/ 1 rsfec rsfec\_first\_lane = ch0 resfec\_clocking\_mode= fec\_dir\_adp\_clk0, or fec\_dir\_adp\_clk1, or fec\_dir\_adp\_clk2, or fec\_dir\_adp\_clk3, or





### 3.7.4.5. Restrictions

The master channel provides the clock for slave channels to use for clocking their TX and RX data paths. Any interruption to that clock from master channel impacts the already running slave channels. This creates a dependency between the master and the slave channels.

If master channel and slave channels are running at high speed CPRI data rates, and you switch the master channel high speed CPRI data rate to any of the low speed CPRI data rates, the slave channels go down since the clock from master channel is interrupted, as shown in Figure: Master Channel Switch from high speed CPRI data rates with or without RS-FEC to low speed CPRI data rates below.

The high speed CPRI data rates are 24.3, 12.1, and 10.1 Gbps with and without RS-Note: FEC. The low speed CPRI data rates are 2.4, 3.0, 4.9, 6.1, and 9.8 Gbps.

#### Figure 74. Master Channel Switch from high speed CPRI data rates with or without RS-FEC to low speed CPRI data rates



In the figure below, three high speed CPRI data rates slave channels are down.

In order to not impact slave channels which are already running at high speed CPRI data rates as shown in the above case, the master channel's rate reconfiguation should be within the data rates listed as high speed CPRI data rates. In addition to that, if master channel runs at any of the high speed CPRI dara rates, the slave channels have the ability to switch to any CPRI data rates as shown in Figure: Slave Channels Free to switch to any CPRI line rates.





#### Figure 75. Master Channel Switch within high speed CPRI data rates

It does not impact slave channels running at high speed CPRI data rates. rsfec channels rsfec channels High speed High speed 3 3 CPRI CPRI High speed High speed 2 2 CPRI CPRI High speed High speed 1 1 CPRI CPRI Switch within 0 High speed 0 rate switch to high speed CPRI CPRI rates 4 channels w/ 1 rsfec 4 channels w/1 rsfec rsfec\_first\_lane = ch0 rsfec\_first\_lane = ch0

## Figure 76. Slave Channels Free to switch to any CPRI line rates



#### **Related Information**

E-Tile Channel Placement Tool





## 3.7.5. IP Core Testbenches

Intel provides a compilation-only design example and a testbench that you can generate for the E-Tile CPRI PHY IP core.

To generate the testbench, in the E-Tile CPRI PHY parameter editor, you must first set the parameter values for the IP core variation you intend to generate in your end product. If you do not set the parameter values for your DUT to match the parameter values in your end product, the testbench you generate does not exercise the IP core variation you intend.

The testbench demonstrates XGMII data transfer to PHY with internal serial loopback and performs basic latency calculations. It is not intended to be a substitute for a full verification environment.

### 3.7.6. Compiling the Full Design

You can use the Start Compilation command on the Processing menu in the Intel Quartus Prime Pro Edition software to compile your design.

#### **Related Information**

- **Block-Based Design Flows** •
- **Programming Intel FPGA Devices**

### 3.8. Parameter Settings

You customize the IP core by specifying parameters in the IP parameter editor.

#### Table 82. **Parameter Settings: IP Tab**

| Parameter                                  | Supported Values                                                                                                       | Default Setting       | Description                                                                                                                                                                                     |
|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                            | CPRI Co                                                                                                                | re Options            |                                                                                                                                                                                                 |
| Number of CPRI Channels<br>in core         | 1, 2, 3, 4                                                                                                             | 1                     | Sets the number of CPRI channels included in the CPRI core.                                                                                                                                     |
| First RSFEC Lane                           | <ul><li>first_lane0</li><li>first_lane1</li><li>first_lane2</li><li>first_lane3</li></ul>                              | first_lane0           | Sets the first RS-FEC lane.<br>This parameter is only<br>available in IP core<br>variations that target CPRI<br>line rates with RS-FEC block.                                                   |
| RSFEC Clocking Mode                        | <ul> <li>fec_dir_adp_clk_0</li> <li>fec_dir_adp_clk_1</li> <li>fec_dir_adp_clk_2</li> <li>fec_dir_adp_clk_3</li> </ul> | fec_dir_adp_clk_0     | Sets the clocking mode for<br>the RS-FEC block.<br>This parameter is only<br>available in IP core<br>variations that target CPRI<br>line rates with RS-FEC block.                               |
|                                            | Configuration, Debug                                                                                                   | and Extension Options | ·                                                                                                                                                                                               |
| Enable Native PHY Debug<br>Master Endpoint | <ul><li>On</li><li>Off</li></ul>                                                                                       | On                    | When you turn on this<br>parameter, the Native PHY<br>Debug Master Endpoint<br>instantiates an Avalon-MM<br>master and connects the<br>Avalon-MM slave inside the<br>PHY. This allows access to |
|                                            | 1                                                                                                                      |                       | continued                                                                                                                                                                                       |





| Parameter | Supported Values | Default Setting | Description                                                                     |
|-----------|------------------|-----------------|---------------------------------------------------------------------------------|
|           |                  |                 | the PHY registers for debug<br>using the Intel Transceiver<br>Toolkit via JTAG. |

#### Table 83. Parameter Settings: CPRI Channel(s) Tab

| Parameter                                    | Supported Values                                                                                                                                                                                                                                                                                                                                                          | Default Setting    | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                              | CPRI Gene                                                                                                                                                                                                                                                                                                                                                                 | ral Options        |                                                                                                                                                                                                                                                                                                                                                                                                              |
| CPRI Rate                                    | <ul> <li>2.4376G (8b/10b)</li> <li>3.072G (8b/10b)</li> <li>4.9152G (8b/10b)</li> <li>6.144G (8b/10b)</li> <li>9.8304G (8b/10b)</li> <li>10.1376G (64b/66b)</li> <li>10.1376G (64b/66b) with RSFEC</li> <li>12.16512G (64b/66b)</li> <li>12.16512G (64b/66b)</li> <li>with RSFEC</li> <li>24.33024G (64b/66b)</li> <li>24.33024G (64b/66b)</li> <li>with RSFEC</li> </ul> | 10.1376G (64b/66b) | Selects the CPRI data rate.<br>The hard RS-FEC block is<br>included in the core if you<br>select 10.1376, 12.1651,<br>and 24.33024 Gbps (64b/<br>66b) with the RS-FEC<br>option.                                                                                                                                                                                                                             |
| Enable reconfiguration to<br>8b/10b datapath | • On<br>• Off                                                                                                                                                                                                                                                                                                                                                             | Off                | Turn on this parameter if<br>you plan to reconfigure the<br>CPRI line rate of your<br>channels from 64b/66b<br>datapath rates to 8b/10b<br>datapath rates at run-time.<br>If this option is not enabled,<br>the CPRI IP core uses fewer<br>resources, and not be able<br>to change to 8b/10b<br>datapath rates at run-time.                                                                                  |
|                                              | CPRI PM                                                                                                                                                                                                                                                                                                                                                                   | A Options          |                                                                                                                                                                                                                                                                                                                                                                                                              |
| PHY Reference frequency                      | <ul> <li>153.6 MHz</li> <li>184.32 MHz</li> </ul>                                                                                                                                                                                                                                                                                                                         | 184.32 MHz         | Support this value of the<br>reference clock frequency for<br>each CPRI line rate.<br>The CPRI line rates that<br>include 8b/10b soft PCS use<br>a reference clock of 153.6<br>MHz and the CPRI line rates<br>that include 64b/66b hard<br>PCS use a reference clock of<br>184.32 MHz.<br>This option is grayed out and<br>always disabled in the<br>current version of the Intel<br>Quartus Prime software. |

For parameters in the **PMA Adaptation** tab, refer to the *PMA Adaptation* topic in the *Intel Stratix 10 E-Tile Transceiver PHY User Guide.* 

For parameters in the **Example Design** tab, refer to the *E-tile CPRI PHY Intel FPGA IP Design Example* chapter in the *E-tile Hard IP Design Examples User Guide*.



#### **Related Information**

- E-Tile Transceiver PHY User Guide: PMA Parameters Information about PMA Adaptation parameters.
- E-Tile Transceiver PHY User Guide: Dynamic Reconfiguration Examples Information about configuring PMA parameters.
- E-tile Hard IP Intel Stratix 10 Design Example User Guide

## 3.9. Functional Description

### **3.9.1. CPRI PHY Functional Blocks**

The E-Tile CPRI PHY Intel FPGA IP consists of the following modules:

- Native PHY—E-tile transceiver channels which consists of PMA and RS-FEC hard logic to support CPRI and Ethernet protocols. The native PHY also contains the following block:
  - 64b/66b Decoder: A hard PCS block within the Native PHY that provides encoding scheme for 10.1376, 12.1651 and 24.33024 Gbps CPRI line rates.
- Soft reset sequencer—A reset sequencer that staggers and asserts digital reset signals according to the E-Tile CPRI PHY Intel FPGA IP requirements.
- Elastic FIFO (EFIFO)—A dual clock FIFO that match the rate differences between the E-tile hard logic and soft logic.
- Latency measurement—A module that generates sync pulse to measure the datapath delay of the E-Tile CPRI PHY Intel FPGA IP.
- Reconfiguration and Control Status Register (CSR) address decoder-This is an address decoder for PHY reconfiguration interface and soft CSR.
- 8b/10b Decoder: A soft PCS block that provides encoding scheme for 2.4/3.0/4.9/6.14/9.8 CPRI line rates.

### 3.9.1.1. E-tile Native PHY

The E-tile Native PHY consists of PMA and RS-FEC hard logic blocks which supports CPRI and Ethernet protocols.

For more information about the E-tile Native PHY, refer to the E-Tile Transceiver PHY User Guide.

#### **Related Information**

E-Tile Transceiver PHY User Guide

### 3.9.1.2. Soft Reset Sequencer

The soft reset sequencer block manages the digital reset sequence in the soft logic of the E-Tile CPRI PHY IP.







### Figure 77. Conceptual Overview of General IP Core Reset Logic

The IP has four input reset signals and three reset registers. The following table shows the functionality of each reset port and register.





#### Table 84.Reset Signal and Register Functions

In this table, a tick ( $\checkmark$ ) indicates the block is reset by the specified reset signal. A dash (-) indicates the block is not impacted by the specified reset signal.

| Reset                                          | Block                |              |                     |                      |              |                      |               |              |
|------------------------------------------------|----------------------|--------------|---------------------|----------------------|--------------|----------------------|---------------|--------------|
| Port/<br>Register                              | TX EMIB<br>Interface | TX PCS       | TX PMA<br>Interface | RX EMIB<br>Interface | RX PCS       | RX PMA<br>Interfaces | Hard CSR      | Soft CSR     |
| i_sl_csr<br>_rst_n<br>soft_sys<br>_rst<br>(20) | <b>√</b> (21)        | V            | V                   | V                    | $\checkmark$ | V                    | <b>√</b> (22) | _            |
| i_sl_tx_<br>rst_n<br>soft_tx_<br>rst           | _                    | $\checkmark$ | $\checkmark$        | _                    |              | _                    | _             |              |
| i_sl_rx_<br>rst_n<br>soft_rx_<br>rst           | _                    | —            | _                   | _                    | $\checkmark$ | $\checkmark$         | _             | —            |
| i_reconf<br>ig_reset                           | _                    | _            | _                   | _                    | _            | _                    | _             | $\checkmark$ |

#### **Reset Sequence**

The following waveforms show the reset sequence using the i\_sl\_csr\_rst\_n, i\_sl\_tx\_rst\_n, and i\_sl\_rx\_rst\_n signals.

#### **System Considerations**

You should perform a system reset before beginning IP core operation, preferably by asserting the i\_csr\_rst\_n and i\_reconfig\_reset signals together. The IP core implements the correct reset sequence to reset the entire IP core.

If you assert the transmit reset when the downstream receiver is already aligned, the receiver loses alignment. Before the downstream receiver loses lock, it might receive some malformed frames.

If you assert the receive reset while the upstream transmitter is sending packets, the packets in transit are corrupted.

- <sup>(21)</sup> Reset a subset of the PMA functions.
- $^{(22)}$  soft\_sys\_rst resets only the registers in the hard logic and returns the register values to the original SOF values.



 $<sup>^{(20)}</sup>$  For the CPRI data rates with RS-FEC variant, deasserting the master channel's the <code>i\_sl\_csr\_rst\_n</code> signal interrupts all slave channels.



#### Figure 78. External Hard Reset Sequence



#### Figure 79. TX Datapath Reset Sequence



#### Figure 80. RX Datapath Reset Sequence



#### **Related Information**

PMA Reset

More information about resetting PMA channels.

PMA Analog Reset

More information about resetting PMA internal controller.

#### 3.9.1.3. Latency Measurement

The latency measurement in the E-Tile CPRI PHY Intel FPGA IP measures the delay between the FPGA core and the serial pins.

#### 3.9.1.3.1. Deterministic Latency Calculation

The Deterministic Latency (DL) term used across this document refers to the ability to precisely determine the delay between the FPGA core and the PMA pins. Such delay varies from reset to reset and device to device. In most applications the variability is acceptable in order to determine the actual delay within a given reset. The below example shows the calculation delay between pins and FPGA core for the E-Tile CPRI PHY Intel FPGA IP.

The deterministic latency measurement methodology for Intel Stratix 10 E-tile devices is based on the concept of measuring the time when a given word is at the interface to the PMA and when that same word is at the FPGA core. The difference in time between these two events, when added to the PMA propagation delay, determines the total latency between the FPGA core and the serial pins. Such a calculation intrinsically includes all delays due to intermediate logic, FIFOs and all other effects.





### Table 85. Deterministic Latency Measurement for Each Variant

| Variant                                         | TX Delay (ns)                                                             | RX Delay (ns)                                                                                                              |
|-------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| 2.4376/3.0720/4.9152/6.144/9.8304<br>Gbps       | TxDL * (sampling_clock period in ns) /<br>(2^8) + (307 * UI period in ns) | RxDL * (sampling_clock_period) /<br>(2^8) + (315 * UI period in ns) +<br>(RxBitSlipL * UI period in ns)                    |
| 10.1316/12.1651/24.33024 Gbps<br>without RS-FEC | TxDL * (sampling_clock period in ns) /<br>(2^8) + (371 * UI period in ns) | RxDL * (sampling_clock_period) /<br>(2^8) + (-149) * (UI period in ns) +<br>(RxBitSlipH <sup>(23)</sup> * UI period in ns) |
| 10.1316/12.1651/24.33024 Gbps with RS-FEC       | TxDL * (sampling_clock period in ns) /<br>(2^8) + (339 * UI period in ns) | RxDL * (sampling_clock_period) /<br>(2^8) + (-117) * (UI period in ns) -<br>(RxCwPos <sup>(24)</sup> * UI period in ns)    |

The actual latency is a function of multiple factors. The following are the description of the usage of these factors to calculate the resulting TX and RX latencies.

#### Table 86. Latency Calculation Description

| Factor | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TxDL   | Transmitter delay in sampling clock cycle. To calculate the<br>TxDL value, read CPRI PHY register 0xC02 bit[20:0].<br>The register provides value in fixed point format. Bit[20:8]<br>represents integer and bit[7:0] represents fractional<br>number. For example, if bit[20:8] = 0x27 and bit [7:0] =<br>0xF4, the integer value is 39 and the fractional value is<br>0.953125 clock cycles. Therefore, the total delay is<br>39.953125 clock cycles.<br><i>Note:</i> These values are available in the design example log<br>file at \alt_cpriphy_c3_0_example_design<br>\hardware test design\hwtest sl |
|        | <pre>\nardware_test_design\nwtest_si \c3_cpri_test.log.</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| RxDL   | Receiver delay in sampling clock cycle. To calculate the RxDL value, read CPRI PHY register 0xC03 bit [20:0].<br>The register provides value in fixed point format. Bit[20:8] represents integer and bit[7:0] represents fractional number. For example, if bit[20:8] = 0x27 and bit [7:0] = 0xF4, the integer value is 39 and the fractional value is 0.953125 clock cycles. Therefore, the total delay is 39.953125 clock cycles.                                                                                                                                                                         |
|        | <pre>Note: These values are available in the design example log file at \alt_cpriphy_c3_0_example_design</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|        | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



<sup>&</sup>lt;sup>(23)</sup> If RxBitSlipH value is greater than or equal to 63, then the RxBitSlip value is (66-RxBitSlip). Else, the value is just RxBitSlip.

<sup>&</sup>lt;sup>(24)</sup> If RxCwPos value is greater than or equal to 63, then the RxCwPos value is (66-RxCwPos). Else, the value is just RxCwPos.



| Factor                | Description                                                                                                                                                                                                                                                                        |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sampling clock        | For E-Tile CPRI PHY Intel FPGA IP, sampling clock from deterministic logic to external source is 250 Mhz.                                                                                                                                                                          |
| RxBitSlipH/RxBitSlipL | Number of bit slip required to achieve block alignment.<br>Read PMA AVMM register 0x28[6:0] to obtain this value.<br>This value is a constant per link up. This value is added to<br>the RX latency calculation. It is assumed that the CPU<br>aggregating the delays know the UI. |
| RxCWPos               | Number of bit slip required to achieve FEC alignment. Read PMA AVMM register 0x29[4:0] to obtain this value. This value is a constant per link up. This value is added to the RX latency calculation. It is assumed that the CPU aggregating the delays know the UI.               |

## **3.10. E-Tile CPRI PHY Intel FPGA IP Interface Signals**

All input signal names begin with  ${\tt i}\_$  and all output signal names begin with  ${\tt o}\_.$ 

Multi-channel signal names contain an array index [n] to the end of their name, where n=0 to 3.

## 3.10.1. Clock Signals

Each CPRI PHY channel has its own pair of datapath clocks and each transceiver has its own reference clock.

#### Table 87. CPRI PHY Clock Input Signals

| Signal Name    | Width (Bits) | I/O Direction | Description                                                                                                                                                                                                                                                                                                      |
|----------------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_clk_tx[n] | 1            | Input         | Single lane transmit<br>datapath clock. These clocks<br>drive the internal TX<br>datapath for the CPRI PHY<br>channel. Each CPRI PHY<br>channel has its own clock<br>input.<br>The default frequency value<br>is 402.8320 MHz.                                                                                   |
| i_sl_clk_rx[n] | 1            | Input         | Single lane receive datapath<br>clock. These clocks drive the<br>internal RX datapath for the<br>CPRI PHY channel. Each<br>CPRI PHY channel has its<br>own clock input.<br>The default frequency value<br>is 402.8320 MHz.                                                                                       |
| i_clk_ref      | 5            | Input         | Transceiver reference clock<br>for each channel.<br>An input multiplexer that<br>supports five reference<br>clocks. The default clock is<br>index 0. You can select only<br>1 clock at any one time for a<br>given channel. You can<br>switch the clock through the<br>transceiver reconfiguration<br>interface. |
|                |              | ·             | continued                                                                                                                                                                                                                                                                                                        |



| Signal Name    | Width (Bits) | I/O Direction | Description                                                                                                                                                                                                                                                                        |
|----------------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |              |               | Use a 184.32 MHz reference<br>clock to generate the high<br>speed serial clock and<br>datapath parallel clocks for<br>CPRI line rates 10.1 and<br>24.3 Gbps with and without<br>RS-FEC.<br>Use a 153.6 MHz transceiver<br>reference clock for CPRI line<br>rates 2.4/4.9/9.8 Gbps. |
| i_aib_clk      | 1            | Input         | Clock for application<br>interface block (AIB). This<br>clock drives the AIB<br>interface across all channels.<br>The default frequency value<br>is 402.8320 MHz.                                                                                                                  |
| i_aib_x2_clk   | 1            | Input         | Double frequency clock for<br>AIB from external source.<br>This clock also drives the<br>AIB interface across all<br>channels.<br>The default frequency value<br>is 805.6640 MHz.                                                                                                  |
| i_reconfig_clk | 1            | Input         | Reconfiguration clock.<br>Frequency of 100 MHz for<br>CSR access on all the<br>Avalon-MM interfaces.                                                                                                                                                                               |
| i_sampling_clk | 1            | Input         | Sampling clock for<br>deterministic latency logic.<br>The default frequency value<br>is 250 MHz.                                                                                                                                                                                   |

#### Table 88. **Clock Source Signals**

Lists the clock source ports for the CPRI core. The core provides locally generated PLL clocks and recovered clocks that can be used for the datapath.

| Signal Name     | Width (Bits) | I/O Direction | Description                                                                          |
|-----------------|--------------|---------------|--------------------------------------------------------------------------------------|
| o_tx_clkout[n]  | 1            | Output        | Parallel TX clock running at line rate/64.                                           |
| o_tx_clkout2[n] | 1            | Output        | Parallel TX clock running at line rate/66.                                           |
|                 |              |               | This clock drives the active<br>TX and RX MII interface for<br>the CPRI PHY channel. |
| o_rx_clkout[n]  | 5            | Output        | Parallel RX recovered clock running at line rate/64.                                 |
| o_rx_clkout2[n] | 1            | Output        | Parallel RX recovered clock running at line rate/66.                                 |





#### Table 89. **Clock Status Signals**

Lists the clock status ports for the CPRI core. Use these ports to hold the circuits that use clock sources from the core in reset until the PLLs driving the clocks are locked.

| Signal Name        | Width | I/O Direction | Description                                                                                                                                                                                          |
|--------------------|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_tx_pll_locked[n] | 1     | Output        | Indicates the TX PLL driving<br>clock signals from the core is<br>locked.<br>Intel recommends not to use<br>the o_tx_clkout or<br>o_tx_clkout2 clocks until<br>the o_tx_pll_locked<br>clock is high. |
| o_cdr_lock[n]      | 1     | Output        | Indicates that the recovered clocks are locked to data.<br>Intel recommends not to use the o_rx_clkout or o_rx_clkout 2 clocks until the o_cdr_lock clock is high.                                   |

### 3.10.2. TX MII Interface

#### Table 90. **CPRI PHY TX MII Interface**

| Port Name        | Width               | Domain          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------|---------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_tx_mii_d[n] | 64 bits per channel | o_tx_clkout2[n] | TX MII data. Data must be<br>in MII encoding.<br>i_tx_mii_d[7:0] holds<br>the first byte the IP core<br>transmits on the Ethernet<br>link. i_tx_mii_d[0] holds<br>the first bit the IP core<br>transmits on the Ethernet<br>link.                                                                                                                                                                                                                                                      |
| i_sl_tx_mii_c[n] | 8 bits per channel  | o_tx_clkout2[n] | TX MII control bits. Each bit<br>corresponds to a byte of the<br>TX MII data signal. For<br>example, i_tx_mii_c[0]<br>corresponds to<br>i_tx_mii_d[7:0],<br>i_tx_mii_c[1]<br>corresponds to<br>i_tx_mii_d[15:8], and<br>so on.<br>If the value of a bit is 1, the<br>corresponding data byte is a<br>control byte. If the value of<br>a bit is 0, the corresponding<br>data byte is data.<br>The Start of Packet byte<br>(0xFB) and End of Packet<br>byte (0xFD) are control<br>bytes. |

275





#### Figure 81. Transmitting Data Using TX MII Interface

| o_tx_clkout2  |       |  |  |
|---------------|-------|--|--|
| i_sl_tx_mii_d | ХТХТХ |  |  |
| i_sl_tx_mii_c | ХТХХ  |  |  |

The figure above shows how to write packets directly to the TX MII interface.

- ٠ The packets are written using MII.
  - Each byte in i\_sl\_tx\_mii\_d has a corresponding bit in i\_sl\_tx\_mii\_c that indicates whether the byte is a control byte or a data byte; for example, i sl tx mii c[1] is the control bit for i sl tx mii d[15:8].
- The byte order for the TX MII interface flows from right to left; the first byte to be ٠ transmitted from the interface is i\_sl\_tx\_mii\_d[7:0].
- The first bit to be transmitted from the interface is i sl tx mii d[0]. ٠

### 3.10.3. RX MII Interface

#### Table 91. **CPRI PHY RX MII Interface**

| Port Name                        | Width          | Domain          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_sl_rx_mii_d[n] <sup>(25)</sup> | 64 per channel | o_tx_clkout2[n] | RX MII data. Data is in MII<br>encoding.<br>o_sl_rx_mii_d[7:0]<br>holds the first byte the IP<br>core received on the<br>Ethernet link.<br>o_sl_rx_mii_d[0] holds<br>the first bit the IP core<br>received on the Ethernet<br>link.                                                                                                                                                                                                                                        |
| o_sl_rx_mii_c[n] <sup>(25)</sup> | 8 per channel  | o_tx_clkout2[n] | RX MII control bits. Each bit<br>corresponds to a byte of RX<br>MII data.<br>o_sl_rx_mii_c[0]<br>corresponds to<br>o_sl_rx_mii_d[7:0],<br>o_sl_rx_mii_c[1]<br>corresponds to<br>o_sl_rx_mii_d[15:8],<br>and so on.<br>If the value of a bit is 1, the<br>corresponding data byte is a<br>control byte. If the value of<br>a bit is 0, the corresponding<br>data byte is data.<br>The Start of Packet byte<br>(0xFD) and End of Packet<br>byte (0xFD) are control<br>bytes. |



<sup>&</sup>lt;sup>(25)</sup> This RX signal is resynchronized to the TX domain.



#### Figure 82. Receiving Data Using the RX MII Interface



The figure above shows how to read packets from the RX MII interface.

- The packets are MII encoded.
  - Each byte in o\_sl\_rx\_mii\_d has a corresponding bit in o\_sl\_rx\_mii\_c that indicates whether the byte is a control byte or a data byte; for example, o\_sl\_rx\_mii\_c[2] is the control bit for o\_sl\_rx\_mii\_d[23:16].
- The byte order for the RX MII interface flows from right to left; the first byte that the core receives is o\_sl\_rx\_mii\_d[7:0].
- The first bit that the core receives is o\_sl\_rx\_mii\_d[0].

### 3.10.4. TX 8B/10B Interface

The TX 8b/10b interface is available only when you select the **Enable reconfiguration to 8b/10b datapath** parameter or when you select the 8b/10b CPRI line rate. For the CPRI PHY core power up in 64b/66b line rate, the IP core asserts these signals when you reconfigure the core at runtime to enter 8b/10b line rate.

#### Table 92.CPRI PHY TX 8B/10B Interface

| Port Name    | Width               | Domain          | Description                                                               |
|--------------|---------------------|-----------------|---------------------------------------------------------------------------|
| i_sl_tx_d[n] | 16 bits per channel | o_tx_clkout2[n] | Indicates 8b/10b TX data for<br>the corresponding CPRI PHY<br>channel.    |
| i_sl_tx_c[n] | 2 bits per channel  | o_tx_clkout2[n] | Indicates 8b/10b TX control<br>for the corresponding CPRI<br>PHY channel. |

When you transmit the data using the TX 8b/10b interface:

- The frames are 8b/10b encoded.
  - Each byte in i\_sl\_tx\_d has a corresponding bit in i\_sl\_tx\_c that indicates whether the byte is a control byte or a data byte. For example, i\_sl\_tx\_c[1] is the control bit for i\_sl\_tx\_d[15:8].
- The byte order for the TX interface flows from right to left and the first byte that the core transmits is i\_sl\_tx\_d[7:0].
- The first bit that the core transmits is i\_sl\_tx\_d[0].





## 3.10.5. RX 8B/10B Interface

The RX 8b/10b interface is available only when you select the Enable reconfiguration to 8b/10b datapath parameter or you select the 8b/10b CPRI line rate. For the CPRI PHY core power up in 64b/66b line rate, the IP core asserts these signals when you reconfigure the core at runtime to enter 8b/10b line rate.

#### Table 93. **CPRI PHY RX 8B/10B Interface**

| Port Name                    | Width               | Domain          | Description                                                               |
|------------------------------|---------------------|-----------------|---------------------------------------------------------------------------|
| i_sl_rx_d[n] <sup>(25)</sup> | 16 bits per channel | o_tx_clkout2[n] | Indicates 8b/10b RX data for the corresponding CPRI PHY channel.          |
| i_sl_rx_c[n] <sup>(25)</sup> | 2 bits per channel  | o_tx_clkout2[n] | Indicates 8b/10b RX control<br>for the corresponding CPRI<br>PHY channel. |

When you transmit the data using the RX 8b/10b interface:

- The frames are 8b/10b encoded. ٠
  - Each byte in i sl rx d has a corresponding bit in i sl rx d that indicates whether the byte is a control byte or a data byte. For example, i sl rx c[0] is the control bit for i sl rx d[7:0].
- The byte order for the RX interface flows from right to left and the first byte that ٠ the core receives is i sl rx d[7:0].
- ٠ The first bit that the core receives is i\_sl\_rx\_d[0].

### 3.10.6. Status Interface for 64B/66B Line Rate

This section lists the status ports for the CPRI PHY 64b/66b line rate. Each CPRI PHY channel has its own status ports.

#### Table 94. **CPRI PHY Status Interface Signals for 64B/66B Interface**

| Port Name               | Width                | Domain       | Description                                                                                                                                                                                                                            |
|-------------------------|----------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_sl_tx_lanes_stable[n] | 1 bit per<br>channel | Asynchronous | The IP core asserts this signal to indicate that TX PMA is ready. The signal deasserts when i_csr_rst_n or i_tx_rst_n is deasserted.                                                                                                   |
| o_sl_rx_pcs_ready[n]    | 1 bit per<br>channel | Asynchronous | The IP core asserts this signal to indicate that the corresponding RX datapath is ready to receive data. The signal deasserts when <code>i_csr_rst_n</code> or <code>i_rx_rst_n</code> is deasserted.                                  |
| o_sl_rx_block_lock[n]   | 1 bit per<br>channel | Asynchronous | The IP core asserts this signal to indicate that 66b block alignment has completed for the corresponding CPRI PHY channel.                                                                                                             |
| o_sl_rx_hi_ber[n]       | 1 bit per<br>channel | Asynchronous | The IP core asserts this signal in accordance with IEEE 802.3 to indicate RX PCS is in Hi-Bit Error Rate (BER) state for the corresponding CPRI PHY channel.                                                                           |
| o_sl_ehip_ready[n]      | 1 bit per<br>channel | Asynchronous | The IP core asserts this signal after i_sl_csr_rst_n<br>and i_sl_tx_rst_n is asserted to indicate that the<br>CPRI PHY has completed all internal initialization, is<br>ready to accept reconfiguration transactions and send<br>data. |





### 3.10.7. Status Interface for 8B/10B Line Rate

This section lists the status ports for the CPRI PHY 8b/10b line rate. Each CPRI PHY channel has its own status ports.

#### Table 95. CPRI PHY Status Interface Signals for 8B/10B Interface

| Port Name                                | Width                | Domain          | Description                                                                                                                                                                                                                                                                                        |
|------------------------------------------|----------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| o_sl_tx_ready[n]                         | 1 bit per<br>channel | Asynchronous    | <ul> <li>The IP core asserts this signal to indicate that TX is ready for the corresponding transceiver in PMA direct mode.</li> <li>1: TX ready</li> <li>0: TX not ready</li> </ul>                                                                                                               |
| o_sl_rx_ready[n]                         | 1 bit per<br>channel | Asynchronous    | <ul> <li>The IP core asserts this signal to indicate that RX is ready for the corresponding transceiver in PMA direct mode.</li> <li>1: RX ready</li> <li>0: RX not ready</li> </ul>                                                                                                               |
| o_sl_rx_patterndetect[n] <sup>(25)</sup> | 1 bit per<br>channel | o_tx_clkout2[n] | The IP core asserts this signal to indicate that K28.5 has been detected in the current word boundary of o_sl_rx_d or o_sl_rx_c and the received data from the RX PMA achieved the word alignment.<br>This interface should be observed in conjunction with o_sl_rx_disperr and i_sl_rx_errdetect. |
| o_sl_rx_disperr[n] <sup>(25)</sup>       | 2 bit per<br>channel | o_tx_clkout2[n] | The IP core asserts this signal to indicate that it received 10-bit code or data group in the current word boundary of o_sl_rx_d or o_sl_rx_c has a disparity error.<br>• Bit 0: Indicates status for lower data group.<br>• Bit 1: Indicates status for higher data group.                        |
| o_sl_rx_errdetect[n] <sup>(25)</sup>     | 2 bit per<br>channel | o_tx_clkout2[n] | <ul> <li>The IP core asserts this signal to indicate that it received 10-bit data group in the o_sl_rx_d or o_sl_rx_c has an 8b/10b code violation.</li> <li>Bit 0: Indicates status for lower data group.</li> <li>Bit 1: Indicates status for higher data group.</li> </ul>                      |

### 3.10.8. Serial I/O Pins

The CPRI PHY IP core always includes the serial I/O pins. The simulation files use these pins to provide serial connections to the core and for synthesis to define the pin positions of the transceivers used by the core.

#### Table 96.CPRI PHY Serial I/O Pins

| Port Name      | Width             | Description                                            |
|----------------|-------------------|--------------------------------------------------------|
| o_tx_serial[n] | 1 bit per channel | TX side transceiver serial pins. One for each channel. |
| i_rx_serial[n] | 1 bit per channel | RX side transceiver serial pins. One for each channel. |

## 3.10.9. Reconfiguration Interfaces (Avalon-MM)

The E-Tile CPRI PHY IP core has the following reconfiguration interfaces:





- CPRI PHY core reconfiguration: This interface provides access to the Avalon-MM • interface in the CPRI PHY core for each of the CPRI PHY channels.
- Transceiver reconfiguration: This interface provides access to the Avalon-MM • interface in the transceivers and to the other Native PHY components.
- RS-FEC reconfiguration: This interface provides access to the Avalon-MM interface ٠ in the RS-FEC core. Four CPRI PHY channels share one RS-FEC core.

### 3.10.9.1. CPRI PHY Reconfiguration Interface

#### **CPRI PHY Reconfiguration Interface** Table 97.

| Port Name                            | Width               | Domain         | Description                                                                                                                         |
|--------------------------------------|---------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------|
| i_sl_cpri_reconfig_addr[n]           | 19 bits per channel | i_reconfig_clk | Indicates address for the<br>CPRI PHY Avalon-MM<br>interface in a selected<br>channel.                                              |
| i_sl_cpri_reconfig_read[n]           | 1 bit per channel   | i_reconfig_clk | Read command for the CPRI PHY Avalon-MM interface in a selected channel.                                                            |
| i_sl_cpri_reconfig_write[n]          | 1 bit per channel   | i_reconfig_clk | Write command for the CPRI PHY Avalon-MM interface in a selected channel.                                                           |
| o_sl_cpri_reconfig_readdata[n]       | 32 bits per channel | i_reconfig_clk | Read data from reads to<br>the CPRI PHY Avalon-MM<br>interface in a selected<br>channel.                                            |
| o_sl_cpri_reconfig_readdata_valid[n] | 1 bit per channel   | i_reconfig_clk | When the signal is high, it<br>indicates that read data<br>from CPRI PHY Avalon-<br>MM interface is valid in a<br>selected channel. |
| i_sl_cpri_reconfig_writedata[n]      | 32 bits per channel | i_reconfig_clk | Data for writes to the<br>CPRI PHY Avalon-MM<br>interface in a selected<br>channel.                                                 |
| o_sl_cpri_reconfig_writerequest[n]   | 1 bit per channel   | i_reconfig_clk | Avalon-MM stalling signal<br>for operations on the<br>CPRI PHY Avalon-MM<br>interface in a selected<br>channel.                     |

### 3.10.9.2. Transceiver Reconfiguration Interface

#### Table 98. **Transceiver Reconfiguration Signals**

| Port Name                  | Width               | Domain         | Description                                                                                            |
|----------------------------|---------------------|----------------|--------------------------------------------------------------------------------------------------------|
| i_xcvr_reconfig_address[n] | 19 bits per channel | i_reconfig_clk | Specifies transceiver<br>Avalon memory-mapped<br>interface address in a<br>selected channel.           |
| i_xcvr_reconfig_read[n]    | 1 bit per channel   | i_reconfig_clk | The IP core asserts this<br>transceiver read signal to<br>start a read cycle in a<br>selected channel. |
|                            |                     | •              | continued                                                                                              |





| Port Name                      | Width              | Domain         | Description                                                                                                                                                                     |
|--------------------------------|--------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_xcvr_reconfig_write[n]       | 1 bit per channel  | i_reconfig_clk | The IP core asserts this transceiver write signal to write data on reconfig_writedata bus in a selected channel.                                                                |
| i_xcvr_reconfig_writedata[n]   | 8 bits per channel | i_reconfig_clk | Specifies transceiver data<br>to be written on a write<br>cycle in a selected<br>channel.                                                                                       |
| o_xcvr_reconfig_readdata[n]    | 8 bits per channel | i_reconfig_clk | Specifies transceiver data<br>to be read by a ready cycle<br>in a selected channel.                                                                                             |
| o_xcvr_reconfig_waitrequest[n] | 1 bit per channel  | i_reconfig_clk | Represents transceiver<br>Avalon memory-mapped<br>interface stalling signal in<br>selected channel. The read<br>and write cycle is only<br>complete when this signal<br>is low. |

### **3.10.9.3. RS-FEC Reconfiguration Interface**

The RS-FEC reconfiguration interface is only available when you generate the IP core variation for 10.13, 12.16, and 24.3 Gbps CPRI line bit rates.

#### Table 99.RS-FEC Reconfiguration Signals

| Port Name                       | Width               | Domain         | Description                                                                                                                                                          |
|---------------------------------|---------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| i_rsfec_reconfig_address[n]     | 11 bits per channel | i_reconfig_clk | Specifies the RS-FEC<br>Avalon memory-mapped<br>interface address in the<br>selected channel.                                                                        |
| i_rsfec_reconfig_read[n]        | 1 bit per channel   | i_reconfig_clk | The IP core asserts RS-<br>FEC read signal to start a read cycle in a selected channel.                                                                              |
| i_rsfec_reconfig_write[n]       | 1 bit per channel   | i_reconfig_clk | The IP core asserts RS-<br>FEC write signal to write<br>data on the<br>reconfig_writedata<br>bus in a selected channel.                                              |
| i_rsfec_reconfig_writedata[n]   | 8 bits per channel  | i_reconfig_clk | Specifies RS-FEC data to be written on a write cycle in a selected channel.                                                                                          |
| o_rsfec_reconfig_readdata[n]    | 8 bits per channel  | i_reconfig_clk | Specifies RS-FEC data to be read by ready cycle in a selected channel.                                                                                               |
| o_rsfec_reconfig_waitrequest[n] | 1 bit per channel   | i_reconfig_clk | Represents RS-FEC Avalon<br>memory-mapped interface<br>stalling signal in a selected<br>channel. The read and<br>write cycle is complete<br>when this signal is low. |





## 3.11. Registers

You can access the CPRI registers for the E-Tile CPRI PHY Intel FPGA IP using the Avalon-MM reconfiguration interface on each channel. The TX and RX RS-FEC registers are accessible through the RS-FEC reconfiguration interface.

#### Table 100. E-Tile CPRI PHY IP Core AVMM Address Ranges

| Register Type      | Address Range |
|--------------------|---------------|
| PCS Registers      | 0x300-0x3FF   |
| TX MAC Registers   | 0x400-0x4FF   |
| CPRI PHY Registers | 0xC00-0xCFF   |

#### Table 101. RS-FEC Reconfiguration Interface Register Base Addresses

| Register Type              | Address Range |
|----------------------------|---------------|
| TX and RX RS-FEC registers | 0x000-0x2FF   |

### 3.11.1. PHY Registers

#### Table 102. PHY Registers

| Address | Bit | Name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Access | Reset |
|---------|-----|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|         | 5   | set_data_lock | Set data lock<br>1: Force PLL to lock to data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW     | 0x0   |
|         | 4   | set_ref_lock  | Set ref lock<br>1: Force PLL to lock to reference.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R₩     | 0x0   |
| 0x310   | 2   | soft_rx_rst   | Soft RXP Reset<br>1: Resets the RX PCS and RX MAC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R₩     | 0x0   |
|         | 1   | soft_tx_rst   | Soft TXP Reset<br>1: Resets the TX PCS and TX MAC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RW     | 0x0   |
|         | 0   | eio_sys_rst   | Ethernet IO System Reset<br>1: Resets the IP core (TX and RX MACs,<br>Ethernet reconfiguration registers, PCS, and<br>transceivers).                                                                                                                                                                                                                                                                                                                                                                                        | RW     | 0x0   |
| 0x321   | 3:0 | eio_freq_lock | Clock Data Recovery (CDR) PLL locked<br>1: Corresponding physical lane's CDR has<br>locked to reference for 10 and 25G links.                                                                                                                                                                                                                                                                                                                                                                                               | RO     | 0x0   |
| 0x30E   | 9   | use_aligner   | <ul> <li>Use RX PCS Alignment <ol> <li>RX PCS has aligner turned on to align incoming data.</li> <li>The RX PCS expects to receive aligned data, and its internal alignment logic is bypassed.</li> <li>After power on, this register defaults to 0</li> <li>After i_csr_rst_n, this register is set depending on the Select Ethernet IP Layers parameter</li> <li>In all modes that include RS-FEC, this register is set to 0</li> <li>In modes that do not include RS-FEC, this register is set to 1</li> </ol></li></ul> | RW     | 0x0   |





| Address | Bit  | Name            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Access | Reset |
|---------|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| 0x322   | 0    | tx_pcs_ready    | <b>TX Ready</b><br>1: TX Datapath is out of reset, stable, and ready for use.                                                                                                                                                                                                                                                                                                                                                                                                             | RO     | 0x0   |
| 0x323   | 19:0 | frmerr          | <ul> <li>Frame error(s) detected</li> <li>1: A frame error was detected on the corresponding lane.</li> <li>For single lanes, only bit 0 is used</li> <li>This bit is sticky, and must be cleared by asserting sclr_frame_error</li> </ul>                                                                                                                                                                                                                                                | RO     | 0x0   |
| 0x324   | 0    | clr_frmerr      | Clear PHY frame error(s).<br>1: Return all sticky frame error bits to 0.                                                                                                                                                                                                                                                                                                                                                                                                                  | RW     | 0x0   |
| 0x325   | 19   | rx_pcs_in_rst   | Reset RX PCS<br>1: Reset RX PCS.<br>• Defaults to 0 after power-up and<br>i_csr_rst_n asserted                                                                                                                                                                                                                                                                                                                                                                                            | RW     | 0x1   |
|         | 17   | tx_pcs_in_rst   | <pre>Reset TX PCS 1: Reset TX PCS. • Defaults to 0 after power-up and i_csr_rst_n asserted.</pre>                                                                                                                                                                                                                                                                                                                                                                                         | RW     | 0x1   |
|         | 14   | force_hip_ready | <ul> <li>Override Hard IP ready</li> <li>1: Assert force_hip_ready, even if all the conditions for Hard IP ready have not been met.</li> <li>Note that one of the conditions for force_hip_ready is the completion of configuration loading. If there is a problem with the configuration logic, force_hip_ready may be prevented from taking effect</li> <li>This feature is provided for test and debug only</li> <li>Defaults to 0 after power-up and i_csr_rst_n asserted.</li> </ul> | RW     | 0x0   |
|         | 2    | trst            | <ul> <li>TX Datapath reset <ol> <li>Hold TX datapath in reset, including TX PLD,</li> <li>MAC, and TX PCS.</li> <li>Performs same function as the i_tx_rst_n port</li> <li>The IP core assertso_tx_rst signal when this reset is active</li> <li>Does not reset TX MAC statistics</li> <li>Space the assertion and deassertion of reset to prevent sudden changes in power consumption</li> <li>Defaults to 0 after power-up and i_csr_rst_n asserted.</li> </ol></li></ul>               | RW     | 0x0   |
|         | 0    | rrst            | <pre>RX Datapath reset<br/>1: Hold RX datapath in reset, including RX PLD,<br/>RX MAC, and RX PCS.<br/>• Performs same function as the i_rx_rst_n<br/>port<br/>• The IP core asserts o_rx_rst when this<br/>reset is active<br/>• Does not reset RX MAC statistics</pre>                                                                                                                                                                                                                  | RW     | 0x0   |



| Image: bit is a set of the section and deasserition of the section prover up is befaults to 1 after power up is befaults to 0 after i_car_rst_n asserted.Image: bit is a set of the section prover up is befaults to 0 after i_car_rst_n asserted.Image: bit is a set of the section prover up is befaults to 0 after i_car_rst_n asserted.Image: bit is a set of the section prover up is befaults to 0 after i_car_rst_n asserted.Image: bit is a set of the section prover up is befaults to 0 after i_car_rst_n asserted.Image: bit is a set of the section prover up is befaults to 0 after i_car_rst_n asserted.Image: bit is a set of the section prover up is befaults to 0 after i_car_rst_n asserted.Image: bit is a set of the section prover up is befault to 0 after i_car_rst_n asserted.Image: bit is a set of the section prover up is befault to 0 after i_car_rst_n asserted.Image: bit is a set of the section prover up is bit is a set of the section prover up is bit is reached by the section prover up is bit is reached by the section bit is reached by the section bit adversed using snapshot or RX shadow requestImage: bit is reached by the sector prover up is bit is reached by the sector bit i                                                                                   | Address | Bit   | Name                       | Description                                                                                                                                                                                                                                                                                                                                                                                                            | Access | Reset |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
| Image: |         |       |                            | <ul><li>reset to prevent sudden changes in power consumption</li><li>Defaults to 1 after power-up</li></ul>                                                                                                                                                                                                                                                                                                            |        |       |
| 0x32A       31:0       count       BER Count       RO       0x0         0x32A       31:0       count       BER Count       RO       0x0         0x32A       31:0       count       BER Count       RO       0x0         0x32B       19:16       ehip_rx_transfer_ready       EHIP/ELANE RX Channels Transfer Ready<br>Status       RO       0x0         0x32B       19:16       ehip_rx_transfer_ready       EHIP/ELANE RX Channels Transfer Ready<br>Status       RO       0x0         3:0       ehip_tx_transfer_ready       EHIP/ELANE TX Channels Transfer Ready<br>Status       RO       0x0         0x342       31:0       khz_rx       Recovered clock frequency<br>Recovered clock frequency<br>TX clock frequency/100, in KHz.       RO       0x0         0x342       31:0       khz_tx       TX clock frequency<br>TX clock frequency/100, in KHz.       RO       0x0         0x351       24       err_tx_avst_fifo_overflow       TX AVST FIFO Overflow<br>• Indicates that the FIFO was written while<br>ful       RO       0x0         123       err_tx_avst_fifo_empty       TX AVST FIFO ran empty unexpectedly<br>• Overflow would never happen—if it does, this signal goes high       RO       0x0         124       err_tx_avst_fifo_empty       TX AVST FIFO ran empty unexpectedly<br>• Ose not apply when in MAC mode<br>• Empty should never happen—if it does, thi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x326   | 1     | hi_ber                     | 1: One or more virtual lanes are in Hi-BER                                                                                                                                                                                                                                                                                                                                                                             | RO     | 0x0   |
| 111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       111       1111       111       111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         | 0     | rx_aligned                 | 1: The RX PCS is fully aligned and ready to                                                                                                                                                                                                                                                                                                                                                                            | RO     | 0x0   |
| Status       Status       Status         1: transfer_ready       EHIP/ELANE TX Channels Transfer Ready<br>Status       RO       0x0         0x341       31:0       khz_rx       Recovered clock frequency<br>Recovered clock frequency(100, in KHz.       RO       0x0         0x342       31:0       khz_tx       TX clock frequency(100, in KHz.       RO       0x0         0x351       24       err_tx_avst_fifo_overflow       TX AVST FIFO Overflow<br>• Indicates that the FIFO was written while<br>full       RO       0x0         0x351       24       err_tx_avst_fifo_overflow       TX AVST FIFO Overflow<br>• Indicates that the FIFO was written while<br>full       RO       0x0         0x351       24       err_tx_avst_fifo_enterpty       TX AVST FIFO TIPO was written while<br>full       RO       0x0         0x351       24       err_tx_avst_fifo_enterpty       TX AVST FIFO TIPO was written while<br>full       RO       0x0         0x351       23       err_tx_avst_fifo_enterpty       This bit doesn't need to be polled—<br>o_internal_err will be asserted if this<br>signal goes high       RO       0x1         23       err_tx_avst_fifo_enterpty       TX AVST FIFO ran empty unexpectedly<br>• Does not apply when in MAC mode<br>• Empty should never happen—if it does, this<br>indicates a problem with the way i_valid<br>is being driven       RO       0x1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x32A   | 31:0  | count                      | <ul> <li>32-bit count that increments each time the core enters BER_BAS_SH state.</li> <li>Rolls over when maximum count is reached</li> <li>Clears when the channel is reset</li> <li>Can be captured using snapshot or RX</li> </ul>                                                                                                                                                                                 | RO     | 0x0   |
| Status       Status         1: transfer_ready is 1.       R0         0x341       31:0       khz_rx         Recovered clock frequency<br>Recovered clock frequency/100, in KHz.       R0       0x0         0x342       31:0       khz_tx       TX clock frequency/100, in KHz.       R0       0x0         0x351       24       err_tx_avst_fifo_overflow       TX AVST FIFO Overflow       R0       0x0         0x351       24       err_tx_avst_fifo_overflow       TX AVST FIFO Overflow       R0       0x0         0x351       24       err_tx_avst_fifo_overflow       TX AVST FIFO Overflow       R0       0x0         0x351       24       err_tx_avst_fifo_overflow       TX AVST FIFO Overflow       R0       0x0         0x351       24       err_tx_avst_fifo_overflow       TX AVST FIFO overflow       R0       0x0         1. This bit doesn't need to be polled - o_internal_error port is asserted to clear it       - This bit doesn't need to be polled - o_internal_err will be asserted if this signal goes high       R0       0x1         23       err_tx_avst_fifo_empty       TX AVST FIFO ran empty unexpectedly       R0       0x1         • Does not apply when in MAC mode       • Empty should never happen -if it does, this indicates a problem with the way i_valid is being drivan       0x1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x32B   | 19:16 | ehip_rx_transfer_ready     | Status                                                                                                                                                                                                                                                                                                                                                                                                                 | RO     | 0x0   |
| Image: Integration of the integrated integration of the integration of the in        |         | 3:0   | ehip_tx_transfer_ready     | Status                                                                                                                                                                                                                                                                                                                                                                                                                 | RO     | 0x0   |
| 0x351       24       err_tx_avst_fifo_overflow       TX AVST FIFO Overflow       RO       0x0         • Indicates that the FIFO was written while full       • Overflow would never happen—if it does, this indicates a problem with the way i_valid is being driven       RO       0x0         • Once asserted this bit holds value until the i_clear_internal_error port is asserted to clear it       • This bit doesn't need to be polled—o_internal_err will be asserted if this signal goes high       RO       0x1         23       err_tx_avst_fifo_empty       TX AVST FIFO ran empty unexpectedly<br>• Does not apply when in MAC mode<br>• Empty should never happen—if it does, this indicates a problem with the way i_valid<br>is being driven       RO       0x1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x341   | 31:0  | khz_rx                     |                                                                                                                                                                                                                                                                                                                                                                                                                        | RO     | 0x0   |
| <ul> <li>Indicates that the FIFO was written while full</li> <li>Overflow would never happen—if it does, this indicates a problem with the way i_valid is being driven</li> <li>Once asserted this bit holds value until the i_clear_internal_error port is asserted to clear it</li> <li>This bit doesn't need to be polled—         <ul> <li>o_internal_err will be asserted if this signal goes high</li> </ul> </li> <li>23 err_tx_avst_fifo_empty</li> <li>TX AVST FIFO ran empty unexpectedly         <ul> <li>Asserts when the TX FIFO runs empty (regardless of read enable)</li> <li>Does not apply when in MAC mode</li> <li>Empty should never happen—if it does, this indicates a problem with the way i_valid is being driven</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x342   | 31:0  | khz_tx                     |                                                                                                                                                                                                                                                                                                                                                                                                                        | RO     | 0x0   |
| <ul> <li>Asserts when the TX FIFO runs empty<br/>(regardless of read enable)</li> <li>Does not apply when in MAC mode</li> <li>Empty should never happen—if it does, this<br/>indicates a problem with the way i_valid<br/>is being driven</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0x351   |       |                            | <ul> <li>Indicates that the FIFO was written while full</li> <li>Overflow would never happen—if it does, this indicates a problem with the way i_valid is being driven</li> <li>Once asserted this bit holds value until the i_clear_internal_error port is asserted to clear it</li> <li>This bit doesn't need to be polled— <ul> <li>o_internal_err will be asserted if this signal goes high</li> </ul> </li> </ul> |        |       |
| 22     err_tx_avst_fifo_underflow     TX AVST FIFO Underflow     RO     0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         | 23    | err_tx_avst_tifo_empty     | <ul> <li>Asserts when the TX FIFO runs empty<br/>(regardless of read enable)</li> <li>Does not apply when in MAC mode</li> <li>Empty should never happen—if it does, this<br/>indicates a problem with the way i_valid</li> </ul>                                                                                                                                                                                      | RO     | 0x1   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         | 22    | err_tx_avst_fifo_underflow | TX AVST FIFO Underflow                                                                                                                                                                                                                                                                                                                                                                                                 | RO     | 0x0   |





|      |                    | <ul> <li>Indicates that the FIFO was read when<br/>empty after steady state reading was<br/>established</li> <li>Underflow should never happen—if it does,<br/>this indicates a problem with the way</li> </ul>                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                    | <ul> <li>_valid is being driven</li> <li>Once asserted this bit holds value until the<br/>i_clear_internal_error port is<br/>asserted to clear it, or the TX datapath is<br/>reset</li> </ul>                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |                    | • This bit doesn't need to be polled—<br>o_internal_err is asserted if this signal<br>goes high                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 20   | use_hi_ber_monitor | <ul> <li>Enable Hi-BER Monitor</li> <li>0: Turn off Hi-BER monitor</li> <li>1: Turn on Hi-BER monitor</li> <li>The Hi-BER monitor is turned on by default because it is used for standard compliance</li> <li>Hi-BER is needed to support Auto-Negotiation, and is generally used to report</li> </ul> | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|      |                    | <ul> <li>poor link conditions</li> <li>When the Hi-BER monitor is turned on, if a Hi-BER condition is detected, the PCS replaces incoming data with Local Fault blocks</li> </ul>                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |                    | <ul><li>monitor RX data while in a Hi-BER state</li><li>At power-on, this register defaults to 0</li></ul>                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |                    | register is set to the value given by the<br>hi_ber_monitor module parameter                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 20:0 | cycles             | <b>Timer window for BER measurements</b><br>Sets the timer window for BER measurements<br>in clock cycles.                                                                                                                                                                                             | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x312C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|      |                    | The Ethernet Standard (IEEE 802.3) defines<br>the required times for Hi-BER measurements<br>for each rate. These times must be converted<br>to clock cycles with the accuracy of within +1%<br>and -25% of the specified times.                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |                    | Note: If the clock rate you are using is<br>different from the clock rate used to<br>calculate the cycle count, you need to<br>scale the cycle count.                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |                    | <ul> <li>100GBASE-R4: 21'd201415 (from Clause 82, 0.5ms +1%,-25% at 402.3 MHz</li> <li>25GBASE-R1: 21'd806451 (from Clause</li> </ul>                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |                    | <ul> <li>10GBASE-R1: 21'd20141 (from Clause 49,<br/>0.125ms +1%, -25% at 161.13 MHz</li> </ul>                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      |                    | 10GBASE-R1: 21'd50403 (from Clause 49,<br>0.125ms +1%, -25% at 402.83 MHz<br>The RX PCS must be reset after changing this<br>value.                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6:0  | count              | <b>Hi-BER Frame Errors</b><br>Sets the BER count that triggers hi_ber.<br>The Ethernet Standard (IEEE 802.3) defines<br>the appropriate setting for<br>ber_invalid_count based on rate.                                                                                                                | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x61                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      | 20:0               | 20:0 cycles                                                                                                                                                                                                                                                                                            | 20.0       cstabilished       • Underflow should never happen—fit does, this indicates a problem with the way i_valid is being driven         20       use_hi_ber_monitor       • Once asserted this bit holds value until the i_clear_internal_error port is asserted to clear it, or the TX datapath is reset         20       use_hi_ber_monitor       Enable Hi-BER Monitor         20       use_hi_ber_monitor       Enable Hi-BER monitor         20       use_hi_ber_monitor       Enable Hi-BER monitor         21       Tum of Hi-BER monitor       • Tum of Hi-BER monitor         22       Use_hi_ber_monitor       • Hi-BER monitor is turned on by default because it is used for standard compliance         20       use_hi_ber_monitor       • Hi-BER monitor is turned on, if a Hi-BER conditions         20       use_hi_ber_monitor       • Hi-BER monitor is turned on, if a Hi-BER condition is detected, the PCS replaces incoming data with Local Fault blocks         20       cycles       Time window for BER measurements         20:0       cycles       The Where the accuracy of within +1% and 25% of the specified times.         20:0       cycles       Time window for BER measurements in clock cycles with the accuracy of within +1% and 25% of the specified times.         20:0       cycles       The thermet Standard (IEEE 802.3) defines the required times for Hi-BER measurements in clock cycles with the accuracy of within +1% and 25% of the specified times. <td>20       use_hi_ber_monitor       Enable the BR monitor is turned on by default because it is set of the support of the su</td> | 20       use_hi_ber_monitor       Enable the BR monitor is turned on by default because it is set of the support of the su |



| Address | Bit  | Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Access | Reset |
|---------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|
|         |      |       | <ul> <li>100GBASE-R4: 7'd97 (from Clause 82)</li> <li>25GBASE-R1: 7'd97 (from Clause 107)</li> <li>10GBASE-R1: 7'd16 (from Clause 49)</li> <li>The RX PCS must be reset after changing this value.</li> </ul>                                                                                                                                                                                                                                                                                                        |        |       |
| 0x37C   | 31:0 | count | <ul> <li>Error block count</li> <li>Counts the number of error blocks produced by the RX PCS decoder</li> <li>Valid only when the RX PCS decoder is used and alignment is achieved</li> <li>The error blocks can be received from the remote link, or generated by violations of the Ethernet Standard 64B66B encoding specification</li> <li>The counter is 32-bit wide and rolls over when the max count is reached</li> <li>The counter is reset when the RX datapath is reset, or the RX PCS is reset</li> </ul> | RO     | 0x0   |

## **3.11.2. CPRI PHY Registers**

These registers use 32-bit addresses; they are not byte-addressable.

#### Table 103. CPRI PHY Registers

| Address | Bit   | Name                   | Description                                                                                                                                                                                                                              | Access | Reset                                                                                                                                                                                    |
|---------|-------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | [9:5] | rx_bitslipboundary_sel | Reports the<br>number of bits<br>the 8B/10B RX<br>PCS block<br>slipped to<br>achieve a<br>deterministic<br>latency.                                                                                                                      | RO     | 0x0                                                                                                                                                                                      |
| 0×C00   | 4     | cpri_fec_en            | Indicates<br>whether the<br>RS-FEC block is<br>enabled.<br>Deterministic<br>latency uses<br>this register.<br>• 0: Disable<br>RS-FEC<br>• 1: Enable<br>RS-FEC<br>You must reset<br>TX and RX<br>datapaths after<br>changing this<br>bit. | RW     | The reset value<br>depends on the<br>selected IP<br>variant. For<br>example, the<br>reset value is 1<br>if the<br>instantiated IP<br>variant is<br>24.33024G<br>(64/66b) with<br>RS-FEC. |
|         | [3:0] | cpri_rate_sel          | Selects the<br>CPRI speed.<br>EFIFO and<br>deterministic<br>latency use<br>this register.                                                                                                                                                | RW     | The reset value<br>depends on the<br>selected IP<br>variant. For<br>example, the<br>reset value is<br>0xb if the<br>instantiated IP<br>variant is<br><b>continued</b>                    |





| Address | Bit    | Name          | Description                                                                                                                                                                                                                               | Access | Reset                                 |
|---------|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------|
|         |        |               | <ul> <li>0x2: 2.4<br/>Gbps</li> <li>0x4: 4.9<br/>Gbps</li> <li>0x6: 9.8<br/>Gbps</li> <li>0x9: 10<br/>Gbps</li> <li>0xb: 24<br/>Gbps</li> <li>You must reset</li> <li>TX and RX<br/>datapaths after<br/>changing this<br/>bit.</li> </ul> |        | 24.33024G<br>(64/66b) with<br>RS-FEC. |
| 0xC01   | 0      | measure_valid | Indicates<br>whether the<br>deterministic<br>values are valid<br>• 0: Inalid<br>• 1: Valid                                                                                                                                                | RO     | 0x0                                   |
| 0xC02   | [20:0] | tx_delay      | Indicates<br>deterministic<br>latency<br>measurement<br>values for TX<br>data path<br>latency in fixed<br>format<br>(Q13.8).<br>This value is<br>valid only if<br>measure_val<br>id = 1.                                                  | RO     | 0x0                                   |
| 0xC03   | [20:0] | rx_delay      | Indicates<br>deterministic<br>latency<br>measurement<br>values for RX<br>data path<br>latency in fixed<br>format<br>(Q13.8).<br>This value is<br>valid only if<br>measure_val<br>id = 1.                                                  | RO     | 0x0                                   |



## 3.11.3. PMA Registers

For information on PMA registers, refer to the E-Tile Transceiver PHY User Guide: PMA Register Map.

#### **Related Information**

- E-Tile Transceiver PHY User Guide
- **PMA Register Map**

### 3.11.3.1. Minimizing PMA Adaptation Time

When you change the line bit rate of the E-Tile CPRI PHY Intel FPGA IP, you need to calibrate the PMA to obtain the optimal performance. After you initiate a rate switch, the E-Tile CPRI PHY IP requires 100 ms for PMA to be ready. To meet this requirement, you need to minimize the PMA adaptation time by configuring the PMA adaptive engine to use adaptation presets through the PMA registers.

Select the PMA parameter by setting the PMA attribute code 0x2C to PMA attribute value 0x118 into the PMA attribute code registers.

- 1. Write 0x84[7:0] = 0x18.
- 2. Write 0x85[7:0] = 0x1.
- 3. Write 0x86[7:0] = 0x2C.
- 4. Write 0x87[7:0] = 0x0.
- 5. Write 0x90[0] = 1'b1.
- 6. Read 0x8A[7]. It should be 1.
- 7. Read 0x8B[0], until it changes to 0.
- 8. Write 0x8A[7] to 1 to clear the 0x8A[7] flag.

Write a value to the PMA parameter by setting the PMA attribute code 0x6C to PMA attribute value 0x0 into the PMA attribute code registers.

- 9. Write 0x84[7:0] = 0x0.
- 10. Write 0x85[7:0] = 0x00.
- 11. Write 0x86[7:0] = 0x6C.
- 12. Write 0x87[7:0] = 0x00.
- 13. Write  $0 \times 90[0] = 1'b1$ .
- 14. Read 0x8A[7]. It should be 1.
- 15. Read 0x8B[0], until it changes to 0.
- 16. Write 0x8A[7] to 1 to clear the 0x8A[7] flag.

#### **Related Information**

- Configuring a PMA Parameter Tunable by the Adaptive Engine More information about setting fixed value to PMA adaptive engine.
  - Receiver PMA More information about PMA adaptation.





## **3.11.4. RS-FEC Registers**

For information on RS-FEC registers, refer to the *E-Tile Transceiver PHY User Guide*: *RS-FEC Registers*.

#### **Related Information**

E-Tile Transceiver PHY User Guide: RS-FEC Registers

# **3.12. Document Revision History for the E-tile CPRI PHY Intel FPGA IP**

| Document Version | Intel Quartus<br>Prime Version | <b>IP Version</b> | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|--------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2020.03.09       | 19.4                           | 19.4.0            | <ul> <li>Corrected TX Delay and RX Delay values in <i>Table:</i><br/>Deterministic Latency Measurement for Each<br/>Variant</li> <li>Added factors RxBitSlipH and RxBitSlipL in Latency<br/>Calculation Description</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2019.12.16       | 19.4                           | 19.4.0            | <ul> <li>Added support for the Intel Agilex device with E-tile transceivers.</li> <li>The E-Tile CPRI PHY IP now supports the following new CPRI line rates: 3.0720, 6.1440, 10.1316 (with RS-FEC), 12.1651 (with and without RS-FEC).</li> <li>Updated resource utilization numbers in <i>Table: Resource Utilization for Selected Variations</i>.</li> <li>Added <i>Figure: E-Tile CPRI PHY (FEC On) Master-Slave Configuration</i> in section <i>E-Tile CPRI PHY Intel FPGA IP Channel Placement</i>.</li> <li>Updated the following sections to include RS-FEC clocking mode information:         <ul> <li>One 24.33024 Gbps Channel with RS-FEC</li> <li>Three 24.33024 Gbps Channel with RS-FEC</li> <li>Four 24.33024 Gbps Channel with RS-FEC</li> <li>Guptated <i>Restrictions</i> section to include new CPRI line rates information.</li> </ul> </li> <li>Added new parameter <b>RSFEC Clocking Mode</b> in <i>Table: Parameter Settings: IP Tab</i>.</li> <li>Updated description for the UI_constant_offset_[rx,tx] in <i>Table: Latency Calculation Description</i>.</li> <li>Updated <i>Table: Reset Signal and Register Functions</i> in section <i>Soft Reset Sequencer</i>.</li> </ul> |
| 2019.10.22       | 19.2                           | 19.2.0            | Corrected the frequency value of i_clk_ref for CPRI line rates 2.4/4.9/9.8 Gbps in <i>Table: CPRI PHY Clock Input Signals</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2019.08.07       | 19.2                           | 19.2.0            | <ul> <li>The E-Tile CPRI PHY IP now supports CPRI line rates: 2.4376, 4.9152, 9.8304, and 24.33024 Gbps (without RS-FEC).</li> <li>Updated <i>Figure: E-tile CPRI PHY Block Diagram</i>.</li> <li>Added new parameters <b>First RSFEC Lane</b> and <b>Enable reconfiguration to 8b/10b datapath</b> in <i>Table: Parameter Settings: IP Tab</i>.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                  |                                |                   | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



| Document Version | Intel Quartus<br>Prime Version | <b>IP Version</b> | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------|--------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |                                |                   | <ul> <li>Updated the NPDME parameter description in section Parameter Settings.</li> <li>Added the following new sections:         <ul> <li>TX 8B/10B Interface</li> <li>RX 8B/10B Interface</li> <li>Status Interface for 8B/10B Line Rate</li> </ul> </li> <li>Clarified that RX signals are resynchronized to the TX domain.</li> <li>Added deterministic latency calculation equation for the new supported CPRI line rates in section Deterministic Latency Calculation.</li> <li>Updated section E-Tile CPRI PHY Intel FPGA IP Channel Placement.</li> <li>Updated section CPRI PHY Functional Blocks.</li> <li>Modified port names in the following sections:             <ul> <li>CPRI PHY Reconfiguration Interface</li> <li>Transceiver Reconfiguration Interface</li> <li>RS-FEC Reconfiguration Interface</li> </ul> </li> <li>Added calibration requirement in section Minimizing PMA Adaptation Time.</li> </ul> |
| 2019.05.17       | 19.1                           | 19.1              | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |





## **4. About the E-tile Channel Placement Tool and Ethernet** Link Inspector

## 4.1. E-Tile Channel Placement Tool

E-tile supports datacenters, 5G networks, Smart Grid and other market segments. Ethernet, CPRI and OTN are the backbone of these emerging and traditional technologies. The *E-Tile Channel Placement Tool*, in conjunction with the *Device Family Pin Connection Guidelines*, allows you to swiftly plan protocol placements in the product prior to reading comprehensive documentation and implementing designs in Intel Quartus Prime.

The Excel-based *E-Tile Channel Placement Tool*, supplemented with **Instructions**, **Legend**, and **Revision** tabs, is available for download at E-Tile Channel Placement Tool.



#### Figure 83. E-Tile Channel Placement Tool

#### **Related Information**

- Intel Stratix 10 Device Family Pin Connection Guidelines
- Intel Agilex Device Family Pin Connection Guidelines

### **4.2. Ethernet Link Inspector**

The *Ethernet Link Inspector* is an inspection tool that can continuously monitor an Ethernet link that contains an Ethernet IP. The Ethernet link typically includes Ethernet lane alignment status, clock data recover (CDR) lock, media access controller (MAC) statistics, Forward Error Correction (FEC) statistics, and others. If needed, the *Ethernet Link Inspector* can capture an event with the help of Signal Tap Logic

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.

ISO 9001:2015 Registered



Analyzer to further examine the link behavior during Auto Negotiation (AN), Link Training (LT), or any other event during the link operation. The Ethernet Link Inspector also creates a graphical user interface (GUI) to represent the link behavior.

#### **Related Information**

Ethernet Link Inspector User Guide for Intel Stratix 10 Devices

## 4.3. Document Revision History for the E-tile Channel Placement **Tool and the Ethernet Link Inspector**

| Document Version Intel Quartus<br>Prime Version |        | Changes                                                               |  |
|-------------------------------------------------|--------|-----------------------------------------------------------------------|--|
| 2020.01.31                                      | 19.4   | Added the Intel Agilex Device Family Pin Connections Guidelines link. |  |
| 2019.11.15                                      | 19.3   | Added Related Information link for the Intel Agilex device documents. |  |
| 2019.08.07                                      | 19.2   | Added Ethernet Link Inspector section.                                |  |
| 2019.04.19                                      | 18.1.1 | Initial release.                                                      |  |





## **5. E-tile Hard IP User Guide Archives**

If an IP core version is not listed, the user guide for the previous IP core version applies.

| IP Core Version | User Guide                                                                                |
|-----------------|-------------------------------------------------------------------------------------------|
| 19.3            | E-tile Hard IP User Guide: E-Tile Hard IP for Ethernet and E-Tile CPRI PHY Intel FPGA IPs |
| 19.2            | E-tile Hard IP User Guide: E-Tile Hard IP for Ethernet and E-Tile CPRI PHY Intel FPGA IPs |
| 19.1            | E-Tile Hard IP for Ethernet Intel FPGA IP User Guide                                      |
| 18.1.1          | E-Tile Hard IP for Ethernet Intel FPGA IP User Guide                                      |
| 18.0            | E-Tile Hard IP for Ethernet Intel FPGA IP User Guide                                      |

Intel Corporation. All rights reserved. Agilex, Altera, Arria, Cyclone, Enpirion, Intel, the Intel logo, MAX, Nios, Quartus and Stratix words and logos are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.

