# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



## Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China





## 25G Ethernet Intel<sup>®</sup> Arria<sup>®</sup> 10 FPGA IP User Guide

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





| 1. About 25G Ethernet Intel FPGA IP Core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 4                                                                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.1. 25G Ethernet Intel FPGA IP Core Supported Features                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 5                                                                                                                                                 |
| 1.2. 25G Ethernet Intel FPGA IP Core Device Family and Speed Grade Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | .7                                                                                                                                                |
| 1.2.1. Device Family Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | .7                                                                                                                                                |
| 1.2.2. 25G Ethernet Intel FPGA IP Core Device Speed Grade Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | .8                                                                                                                                                |
| 1.3. IP Core Verification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 8                                                                                                                                                 |
| 1.3.1. Simulation Environment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | .8                                                                                                                                                |
| 1.3.2. Compilation Checking                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | .9                                                                                                                                                |
| 1.3.3. Hardware Testing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | .9                                                                                                                                                |
| 1.4. Performance and Resource Utilization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 9                                                                                                                                                 |
| 1.5. Release Information1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1                                                                                                                                                 |
| 2 Cotting Started                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | r                                                                                                                                                 |
| 2. J. Jackelling and Licensing Jakel EDCA ID Cares                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | .2                                                                                                                                                |
| 2.1. Installing and Licensing Intel FPGA IP Cores                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | .2                                                                                                                                                |
| 2.1.1. INTEL FPGA IP EVALUATION MODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | .3                                                                                                                                                |
| 2.2. Specifying the 25G Ethernet Intel FPGA IP Core Parameters and Options                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | .5                                                                                                                                                |
| 2.3. Simulating the IP Core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | .0                                                                                                                                                |
| 2.4. Generated File Structure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ./                                                                                                                                                |
| 2.5. Integrating Your IP Core in Your Design 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | .9                                                                                                                                                |
| 2.5.1. PHI Assignments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | .9                                                                                                                                                |
| 2.5.2. Adding the Transceiver PLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <u>10</u>                                                                                                                                         |
| 2.5.5. Editality Poleficial Jiller III Titler Afrid 10 Devices                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1                                                                                                                                                 |
| 2.5.4. Adding the External Time-or-Day Module for Variations with 1566 PTP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | )1                                                                                                                                                |
| FEALURE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                   |
| 2 5 5 Placement Settings for the 25G Ethernet Intel EPGA IP Core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | זי                                                                                                                                                |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 23<br>23                                                                                                                                          |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 23<br>23<br>• <b>4</b>                                                                                                                            |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 23<br>23<br>24                                                                                                                                    |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 23<br>23<br>24                                                                                                                                    |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 23<br>23<br>24<br>24<br>27                                                                                                                        |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.1. 25G Ethernet Intel FPGA IP Core TX Datapath.       2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 23<br>23<br>24<br>27<br>27<br>28                                                                                                                  |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.1. 25G Ethernet Intel FPGA IP Core TX Datapath.       2         4.1.2. 25 GbE TX PCS.       3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 23<br>23<br>24<br>27<br>27<br>28<br>30                                                                                                            |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 23<br>23<br>24<br>27<br>27<br>28<br>30<br>31                                                                                                      |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.2. 25 Gbt TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 23<br>23<br>24<br>27<br>27<br>28<br>30<br>31<br>34                                                                                                |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 23<br>23<br>24<br>27<br>27<br>28<br>30<br>31<br>34<br>36                                                                                          |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3         4.1.6. Flow Control.       3                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 23<br>23<br>24<br>27<br>28<br>30<br>31<br>34<br>36<br>37                                                                                          |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3         4.1.6. Flow Control.       3         4.1.7. 1588 Precision Time Protocol Interfaces.       4                                                                                                                                                                                                                                                                                                                                                                                                              | 23<br>23<br>24<br>27<br>27<br>28<br>30<br>31<br>34<br>36<br>37<br>40                                                                              |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3         4.1.6. Flow Control.       3         4.1.7. 1588 Precision Time Protocol Interfaces.       4         4.2. User Interface to Ethernet Transmission.       4                                                                                                                                                                                                                                                                                                                                              | 23<br>23<br>24<br>27<br>28<br>30<br>31<br>34<br>36<br>37<br>40<br>49                                                                              |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3         4.1.6. Flow Control.       3         4.1.7. 1588 Precision Time Protocol Interfaces.       4         4.2.1. Order of Transmission.       4                                                                                                                                                                                                                                                                                                                                                                | 23<br>23<br>24<br>27<br>28<br>30<br>31<br>34<br>36<br>37<br>40<br>49<br>49                                                                        |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3         4.1.6. Flow Control.       3         4.1.7. 1588 Precision Time Protocol Interfaces.       4         4.2.1. Order of Transmission.       4         4.2.2. Bit Order For TX and RX Datapaths.       5                                                                                                                                                                                                                                                                                                    | 23<br>23<br>24<br>27<br>27<br>28<br>30<br>31<br>34<br>36<br>37<br>10<br>19<br>19<br>50                                                            |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.1. 25G Ethernet Intel FPGA IP Core TX Datapath.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3         4.1.6. Flow Control.       3         4.1.7. 1588 Precision Time Protocol Interfaces.       4         4.2. User Interface to Ethernet Transmission.       4         4.2.1. Order of Transmission.       4         4.2.2. Bit Order For TX and RX Datapaths.       5                                                                                                                                                                    | 23         23         24         27         28         31         34         36         31         36         37         49         50         50 |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3         4.1.6. Flow Control.       3         4.1.7. 1588 Precision Time Protocol Interfaces.       4         4.2.1. Order of Transmission.       4         4.2.2. Bit Order For TX and RX Datapaths.       5         5. Reset.       5                                                                                                                                                                                                                                                                            | <b>23 24 27 28 30 31 34 36 37 10 19 19 19 10 11 12 11 12 11 12 11 12 11 11</b>                                                                    |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core TX Datapath.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3         4.1.6. Flow Control.       3         4.1.7. 1588 Precision Time Protocol Interfaces.       4         4.2.1. Order of Transmission.       4         4.2.2. Bit Order For TX and RX Datapaths.       5         5. Reset.       5         6. Interfaces and Signal Descriptions.       5         6.1. TX MAC Interface to User Logic.       5                                                                                              | <b>23 24 27 28 31 34 36 7 19 19 19 10 11 27 28 10 11 12 27 11 12 11 12 11 11 11 11</b>                                                            |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1.2. 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3         4.1.6. Flow Control.       3         4.1.7. 1588 Precision Time Protocol Interfaces.       4         4.2.1. Order of Transmission.       4         4.2.2. Bit Order For TX and RX Datapaths.       5         5. Reset.       5         6.1. TX MAC Interface to User Logic.       5                                                                                                                                                                                                                       | <b>23 24 27 28 30 14 27 28 30 14 36 7 16 16 17 17 17 17 17 17 17 17</b>                                                                           |
| 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core.       2         2.6. Compiling the Full Design and Programming the FPGA.       2         3. 25G Ethernet Intel FPGA IP Core Parameters.       2         4. Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core Functional Description.       2         4.1. 25G Ethernet Intel FPGA IP Core TX Datapath.       2         4.1.2 25 GbE TX PCS.       3         4.1.3. 25G Ethernet Intel FPGA IP Core RX Datapath.       3         4.1.4. Link Fault Signaling Interface.       3         4.1.5. 25 GbE RX PCS.       3         4.1.6. Flow Control.       3         4.1.7. 1588 Precision Time Protocol Interfaces.       4         4.2. User Interface to Ethernet Transmission.       4         4.2.1. Order of Transmission.       4         4.2.2. Bit Order For TX and RX Datapaths.       5         5. Reset.       5         6.1 TX MAC Interface to User Logic.       5         6.2. RX MAC Interface to User Logic.       5         6.3. Transceivers.       5 | <b>23 24 7 7 8 8 7 7 8 8 7 7 8 8 7 7 8 8 7 1 1 2 2 4 5 1 1 2 2 4 5 1 1 1 2 1 1 2 1 1 1 1 1 1 1 1 1 1</b>                                          |

Contents



| 6.5. Avalon-MM Management Interface                                          | 58         |
|------------------------------------------------------------------------------|------------|
| 6.6. 1588 PTP Interface Signals                                              | 58         |
| 6.7. Miscellaneous Status and Debug Signals                                  | 63         |
| 6.8. Reset Signals                                                           | 64         |
| 7. Control, Status, and Statistics Register Descriptions                     | 65         |
| 7.1. PHY Registers                                                           | 65         |
| 7.2. TX MAC Registers                                                        | 68         |
| 7.3. RX MAC Registers                                                        | 69         |
| 7.4. Pause/PFC Flow Control Registers                                        | 70         |
| 7.5. Statistics Registers                                                    | 74         |
| 7.5.1. TX Statistics Registers                                               |            |
| 7.5.2. RX Statistics Registers                                               |            |
| 7.6. 1588 PTP Registers                                                      | 81         |
| 7.7. TX Reed-Solomon FEC Registers                                           | 83         |
| 7.8. RX Reed-Solomon FEC Registers                                           |            |
| 8. Debugging the Link                                                        | 85         |
| 8.1. Error Insertion Test and Debugging                                      | 86         |
| 9. Document Revision History for the 25G Ethernet Intel Arria 10 FPGA IP Use | er Guide87 |



## 1. About 25G Ethernet Intel FPGA IP Core

The Intel<sup>®</sup> Arria<sup>®</sup> 10 25G Ethernet Intel FPGA IP core implements the 25G & 50G Ethernet Specification, Draft 1.6 from the 25 Gigabit Ethernet Consortium and the *IEEE 802.3by 25Gb Ethernet* specification. The IP core includes an option to support unidirectional transport as defined in *Clause* 66 of the *IEEE 802.3-2012 Ethernet* Standard. The MAC client side interface for the 25G Ethernet Intel FPGA IP core is a 64-bit Avalon<sup>®</sup> Streaming (Avalon-ST) interface. It maps to one 25.78125 Gbps transceiver. The IP core optionally includes Reed-Solomon forward error correction (FEC) for support of direct attach copper (DAC) cable. *IEEE 802.3 Clause 74* KR-FEC is not supported.

The IP core provides standard media access control (MAC) and physical coding sublayer (PCS), Reed-Solomon FEC, and PMA functions shown in the following block diagram. The PHY comprises the PCS, optional Reed-Solomon FEC, and PMA.



### Figure 1. 25G Ethernet Intel FPGA IP MAC and PHY IP Clock Diagram

The following block diagram shows an example of a network application with 25G Ethernet Intel FPGA IP MAC and PHY.

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, 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:2008 Registered





### Figure 2. Example Network Application



## **1.1. 25G Ethernet Intel FPGA IP Core Supported Features**

The 25G Ethernet Intel FPGA IP core is designed to the 25G & 50G Ethernet Specification, Draft 1.6 from the 25 Gigabit Ethernet Consortium and designed to the IEEE 802.3by 25Gb Ethernet specification, as well as the IEEE 802.3ba-2012 High



*Speed Ethernet Standard* available on the IEEE website (www.ieee.org). The MAC provides RX cut-through frame processing to optimize latency. The IP core supports the following features:

- PHY features:
  - Soft PCS logic that interfaces seamlessly to Intel Arria 10 FPGA 25.78125 gigabits per second (Gbps) serial transceivers.
  - Optional Reed-Solomon forward error correction (FEC).
- Frame structure control features:
  - Support for jumbo packets, defined as packets greater than 1500 bytes.
  - Receive (RX) CRC removal and pass-through control.
  - Transmit (TX) CRC generation and insertion.
  - RX and TX preamble pass-through option for applications that require proprietary user management information transfer.
  - TX automatic frame padding to meet the 64-byte minimum Ethernet frame length.
- Frame monitoring and statistics:
  - RX CRC checking and error reporting.
  - RX malformed packet checking per IEEE specification.
  - Optional statistics counters.
  - Optional fault signaling detects and reports local fault and generates remote fault, with *IEEE 802.3ba-2012 Ethernet Standard Clause 66* support.
  - Unidirectional transport as defined in *Clause 66 of the IEEE 802.3-2012* Ethernet Standard.
- Flow control:
  - Standard IEEE 802.3 Clause 31 and Priority-Based IEEE 802.1Qbb flow control.



- Precision Time Protocol support:
  - Optional support for the IEEE Standard 1588-2008 Precision Clock Synchronization Protocol (1588 PTP). This feature supports PHY operating speed with a constant timestamp accuracy of  $\pm$  3 ns and a dynamic timestamp accuracy of  $\pm$  1 ns.
- Debug and testability features:
  - Programmable serial PMA local loopback (TX to RX) at the serial transceiver for self-diagnostic testing.
  - TX error insertion capability.
  - Optional access to Altera Debug Master Endpoint (ADME) for serial link debugging or monitoring PHY signal integrity.
- User system interfaces:
  - Avalon Memory-Mapped (Avalon-MM) management interface to access the IP core control and status registers.
  - Avalon Streaming (Avalon-ST) data path interface connects to client logic.
  - Configurable ready latency of 0 or 3 clock cycles for Avalon-ST TX interface.
  - Hardware and software reset control.

For a detailed specification of the Ethernet protocol refer to the *IEEE 802.3 Ethernet Standard*.

#### **Related Information**

IEEE website

The IEEE 802.3 Ethernet Standard is available on the IEEE website.

## **1.2. 25G Ethernet Intel FPGA IP Core Device Family and Speed** Grade Support

### **1.2.1. Device Family Support**

### Table 1. Intel IP Core Device Support Levels

| Device Support<br>Level | Definition                                                                                                                                                                                                                                            |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 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 2. 25G Ethernet Intel FPGA IP Core Device Family Support

Shows the level of support offered by the 25G Ethernet Intel FPGA IP core for each Intel device family.

| Device Family         | Support                                                                                                                                                                                                                                                                        |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Intel Arria 10 GT     | Default support level provided in the Intel Quartus <sup>®</sup> Prime software. Refer to the <i>Intel Quartus Prime Standard Edition Software and Device Support Release Notes</i> and the <i>Intel Quartus Prime Pro Edition Software and Device Support Release Notes</i> . |
| Other device families | Not supported.                                                                                                                                                                                                                                                                 |



• Timing and Power Models

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

• Timing and Power Models

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

### 1.2.2. 25G Ethernet Intel FPGA IP Core Device Speed Grade Support

### Table 3. Slowest Supported Device Speed Grades

| IP Core                    | Device Family     | Supported Speed Grades |
|----------------------------|-------------------|------------------------|
| 25G Ethernet Intel FPGA IP | Intel Arria 10 GT | E2                     |

## **1.3. IP Core Verification**

To ensure functional correctness of the 25G Ethernet Intel FPGA IP core, Intel performs extensive validation through both simulation and hardware testing. Before releasing a version of the 25G Ethernet Intel FPGA IP core, Intel runs comprehensive regression tests in the current version of the Intel Quartus Prime software.

Intel verifies that the current version of the Intel Quartus Prime software compiles the previous version of each IP core. Any exceptions to this verification are reported in the *Intel FPGA IP Release Notes*. Intel does not verify compilation with IP core versions older than the previous release.

### **Related Information**

- Knowledge Base Issues for IP core Exceptions to functional correctness are documented in the 25G Ethernet Intel FPGA IP core errata.
- 25G Ethernet Intel FPGA IP Release Notes
- Intel Quartus Prime Design Suite Update Release Notes Includes changes in minor releases (updates).

### **1.3.1. Simulation Environment**

Intel performs the following tests on the 25G Ethernet Intel FPGA IP core in the simulation environment using internal and third-party standard bus functional models (BFM):

- Constrained random tests that cover randomized frame size and contents.
- 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.



### **1.3.2.** Compilation Checking

Intel performs compilation testing on an extensive set of 25G Ethernet Intel FPGA IP core variations and designs to ensure the Intel Quartus Prime software places and routes the IP core ports correctly.

### 1.3.3. Hardware Testing

Intel performs hardware testing of the key functions of the 25G Ethernet Intel FPGA IP core using internal loopback and also with other 25G switches. The hardware tests also ensure reliable solution coverage for hardware related areas such as performance, link synchronization, and reset recovery.

## **1.4. Performance and Resource Utilization**

The following table shows the typical device resource utilization for selected configurations using the current version of the Intel Quartus Prime software. With the exception of M20K memory blocks, the numbers of ALMs and logic registers are rounded up to the nearest 100. The timing margin for this IP core is a minimum of 15%.

### Table 4. IP Core Variation Encoding for Resource Utilization Table

"On" indicates the parameter is turned on. The symbol "—" indicates the parameter is turned off or not available.

| IP Core Variation              | Α  | В                                 | С                                 |
|--------------------------------|----|-----------------------------------|-----------------------------------|
| Parameter                      |    |                                   |                                   |
| Ready Latency                  | 0  | 0                                 | 3                                 |
| Enable RS-FEC                  | —  | On                                | —                                 |
| Enable flow control            | _  | Standard flow control,<br>1 queue | Standard flow control,<br>1 queue |
| Enable link fault generation   | _  | _                                 | On                                |
| Enable preamble passthrough    | —  | —                                 | On                                |
| Enable TX CRC passthrough      | On | —                                 | —                                 |
| Enable MAC statistics counters | _  | On                                | On                                |
| Enable IEEE 1588               | _  | _                                 | On                                |



•

## Table 5.IP Core FPGA Resource Utilization for 25G Ethernet Intel FPGA IP Core for<br/>Intel Arria 10 Devices

Lists the resources and expected performance for selected variations of the 25G Ethernet Intel FPGA IP core.

These results were obtained using the Intel Quartus Prime software v16.1.

- The numbers of ALMs and logic registers are rounded up to the nearest 100.
- The numbers of ALMs, before rounding, are the **ALMs needed** numbers from the Intel Quartus Prime Fitter Report.

| IP Core Variation | ALMs  | Dedicated Logic<br>Registers | M20K Memory Blocks |
|-------------------|-------|------------------------------|--------------------|
| Α                 | 3000  | 7200                         | 0                  |
| В                 | 13800 | 28700                        | 29                 |
| С                 | 11600 | 24900                        | 34                 |

### **Related Information**

- 25G Ethernet Intel FPGA IP Core Parameters on page 24 Information about the parameters and values in the IP core variations.
- Fitter Resources Reports in the Quartus Prime Pro Edition Help



## **1.5. Release Information**

### Table 6. 25G Ethernet Intel FPGA IP Core Current Release Information

| Item           | Description                                  |
|----------------|----------------------------------------------|
| Version        | 17.0                                         |
| Release Date   | 2017.05.08                                   |
| Ordering Codes | IP-25GEUMACPHY (IPR-25GEUMACPHY for renewal) |



## **2. Getting Started**

### **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 Qsys 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.1. Installing and Licensing Intel FPGA IP Cores

The Intel Quartus Prime 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 3. 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 7.IP Core Installation Locations

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

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, 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.





### 2.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.





### Figure 4. 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 or contact your local Intel FPGA representative.

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.



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

## **2.2. Specifying the 25G Ethernet Intel FPGA IP Core Parameters and Options**

The 25G 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 software.

- 1. Depending on whether you are using the Intel Quartus Prime Pro Edition software or the Intel Quartus Prime Standard Edition software, perform one of the following actions:
  - 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.
  - In the Intel Quartus Prime Standard Edition software, in the IP Catalog (Tools > IP Catalog), select the Arria 10 target device family.
- In the IP Catalog (Tools ➤ IP Catalog), locate and double-click the name of the IP core to customize. The New IP Variation window appears.
- 3. In the **New IP Variation** dialog box, specify a top-level name for your custom IP variation. The parameter editor saves the IP variation settings in a file named <*your\_ip*>.gsys (in Intel Quartus Prime Standard Edition) or <*your\_ip*>.ip (in Intel Quartus Prime Pro Edition).
- In the Intel Quartus Prime Standard Edition software, you must select a specific Intel Arria 10 device in the **Device** field, or keep the default device the Quartus Prime software proposes.
- 5. Click **OK**. The parameter editor appears.
- 6. On the **IP** tab, specify the parameters for your IP core variation. Refer to 25G Ethernet Intel FPGA IP Core Parameters on page 24 for information about specific IP core parameters.
- 7. Optionally, to generate a simulation testbench or compilation and hardware design example, follow the instructions in the *Intel Arria 10 25G Ethernet Design Example User Guide*.
- 8. Click Generate HDL. The Generation dialog box appears.
- 9. Specify output file generation options, and then click **Generate**. The IP variation files generate according to your specifications.
  - *Note:* A functional VHDL IP core is not available. Specify Verilog HDL only, for your IP core variation.
- Click Finish. The parameter editor adds the top-level .qsys or .ip file to the current project automatically. If you are prompted to manually add the .qsys or .ip file to the project, click Project ➤ Add/Remove Files in Project to add the file.
- 11. After generating and instantiating your IP variation, make appropriate pin assignments to connect ports.



Intel Arria 10 25G Ethernet Design Example User Guide Information about the **Example Design** tab in the 25G Ethernet Intel FPGA IP parameter editor.

## 2.3. Simulating the IP Core

You can simulate your 25G Ethernet Intel FPGA IP core variation with the functional simulation model and the testbench generated with the IP core. The functional simulation model is a cycle-accurate model that allows for fast functional simulation of your IP core instance using industry-standard Verilog HDL simulators. You can simulate the Intel-provided testbench or create your own testbench to exercise the IP core functional simulation model.

The functional simulation model and testbench files are generated in project subdirectories. These directories also include scripts to compile and run the design example.

*Note:* Use the simulation models only for simulation and not for synthesis or any other purposes. Using these models for synthesis creates a nonfunctional design.

In the top-level wrapper file for your simulation project, you can set the the following RTL parameters to enable simulation optimization. These optimizations significantly decrease the time to reach link initialization.

- SIM\_SHORT\_RST: Shortens the reset times to speed up simulation.
- SIM\_SHORT\_AM: Shortens the interval between alignment markers to accelerate alignment marker lock. Alignment markers are used when Reed-Solomon FEC is enabled.
- SIM\_SIMPLE\_RATE: Sets the PLL reference clock (clk\_ref) to 625 MHz instead of 644.53125 MHz to optimize PLL simulation model behavior

In general, parameters are set through the IP core parameter editor and you should not change them manually. The only exceptions are these simulation optimization parameters.

To set these parameters on the PHY blocks, add the following lines to the top-level wrapper file:

```
defparam <dut instance>.SIM_SHORT_RST = 1'b1;
defparam <dut instance>.SIM_SHORT_AM = 1'b1;
defparam <dut instance>.SIM_SIMPLE_RATE = 1'b1;
```

*Note:* You can use the example testbench as a guide for setting the simulation parameters in your own simulation environment. These lines are already present in the Intel-provided testbench for the IP core.

### **Related Information**

 Simulating Intel FPGA Designs Quartus Prime Standard Edition Handbook Volume 3: Verification chapter that provides information about simulating Intel FPGA IP cores.

---



### Intel Arria 10 25G Ethernet Design Example User Guide

Information about generating and simulating the Intel-provided 25G Ethernet Intel FPGA IP testbench. This testbench demonstrates a basic test of the IP core. It is not intended to be a substitute for a full verification environment.

## 2.4. Generated File Structure

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

For information about the file structure of the design example, refer to the *Arria 10* 25G Ethernet Intel FPGA IP Design Example User Guide.



#### Figure 5. IP Core Generated Files



### Table 8.IP Core Generated Files

| File Name                                                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <pre><your_ip>.qsys (Intel Quartus Prime Standard Edition only)</your_ip></pre> | The Platform Designer system or top-level IP variation file. < your_ip> is the name that you give your IP variation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| <pre><your_ip>.ip (Intel Quartus Prime Pro Edition only)</your_ip></pre>        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| <system>.sopcinfo</system>                                                      | 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. (Intel Quartus Prime<br>Standard Edition only)<br>Downstream tools such as the Nios <sup>®</sup> II Gen 2 tool chain use this file.<br>The .sopcinfo file and the system.h file generated for the Nios II Gen 2 tool<br>chain include address map information for each slave relative to each master<br>that accesses the slave. Different masters may have a different address map to<br>access a particular slave component. |  |
| <your_ip>.cmp</your_ip>                                                         | The VHDL Component Declaration ( <b>.cmp</b> ) file is a text file that contains local generic and port definitions that you can use in VHDL design files.<br>This IP core does not support VHDL. However, the Intel Quartus Prime software generates this file.                                                                                                                                                                                                                                                                                                                                                                        |  |
| <your_ip>.html</your_ip>                                                        | A report that contains connection information, a memory map showing the address of each slave with respect to each master to which it is connected, and 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>.debuginfo</your_ip>                                                   | Contains post-generation information. Used to pass System Console and Bus<br>Analyzer Toolkit information about the Platform Designer interconnect. The Bus<br>Analysis Toolkit uses this file to identify debug components in the Platform<br>Designer interconnect. (Intel Quartus Prime Standard Edition only)                                                                                                                                                                                                                                                                                                                       |  |
| <your_ip>.qgsimc</your_ip>                                                      | Lists simulation parameters to support incremental regeneration. (Intel Quartus Prime Pro Edition only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| <your_ip>.qgsynthc</your_ip>                                                    | Lists synthesis parameters to support incremental regeneration. (Intel Quartus Prime Pro Edition only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| <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>.csv</your_ip>                                                         | Contains information about the upgrade status of the IP component.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| <your_ip>.bsf</your_ip>                                                         | A Block Symbol File (. <b>bsf</b> ) representation of the IP variation for use in Intel Quartus Prime Block Diagram Files ( <b>.bdf</b> ).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| <your_ip>.spd</your_ip>                                                         | Required input file for ip-make-simscript to generate simulation scripts for supported simulators. The <b>.spd</b> file contains a list of files generated for simulation, along with information about memories that you can initialize.                                                                                                                                                                                                                                                                                                                                                                                               |  |
| <your_ip>.ppf</your_ip>                                                         | The Pin Planner File ( <b>.ppf</b> ) stores the port and node assignments for IP components created for use with the Pin Planner.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| <your_ip>_bb.v</your_ip>                                                        | You can use the Verilog black-box ( <b>_bb.v</b> ) file as an empty module declaration for use as a black box.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| <your_ip>.sip</your_ip>                                                         | Contains information required for NativeLink simulation of IP components. You must add the <b>.sip</b> file to your Quartus Prime project. (Intel Quartus Prime Standard Edition only)                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| <pre><your_ip>_inst.v and _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.<br>This IP core does not support VHDL. However, the Intel Quartus Prime software generates the _inst.vhd file.                                                                                                                                                                                                                                                                                                                                                                                 |  |



| File Name                                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <your_ip>.regmap</your_ip>                                | If IP contains register information, <b>.regmap</b> file generates. The <b>.regmap</b> file describes the register map information of master and slave interfaces. This file complements the <b>.sopcinfo</b> 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 within a Platform Designer system.<br>During synthesis, the <b>.svd</b> files for slave interfaces visible to System Console<br>masters are stored in the <b>.sof</b> 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<br/>and<br/><your_ip>.vhd</your_ip></your_ip> | HDL files that instantiate each submodule or child IP core for synthesis or simulation.<br>This IP core does not support VHDL. However, the Intel Quartus Prime software generates this file.                                                                                                                                                                                                                                                                                                       |
| mentor/                                                   | Contains a ModelSim script msim_setup.tcl to set up and run a simulation.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| aldec/                                                    | Contains a Riviera-PRO script rivierapro_setup.tcl to setup and run a simulation.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| synopsys/vcs/<br>synopsys/vcsmx/                          | Contains a shell script vcs_setup.sh to set up and run a VCS <sup>®</sup> simulation. Contains a shell script vcsmx_setup.sh and synopsys_ sim.setup file to set up and run a VCS MX <sup>®</sup> 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 submodule.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <child cores="" ip="">/</child>                           | For each generated child IP core directory, Platform Designer generates synth/ andsim/ sub-directories.                                                                                                                                                                                                                                                                                                                                                                                             |

Intel Arria 10 25G Ethernet Design Example User Guide Information about the 25G Ethernet Intel FPGA IP design example file structure.

## 2.5. Integrating Your IP Core in Your Design

### **2.5.1. Pin Assignments**

When you integrate your 25G Ethernet Intel FPGA IP core instance in your design, you must make appropriate pin assignments. While compiling the IP core alone, you can create virtual pins to avoid making specific pin assignments for top-level signals. When you are ready to map the design to hardware, you can change to the correct pin assignments.

### **Related Information**

### Intel Quartus Prime Help

For information about the Intel Quartus Prime software, including virtual pins.



### 2.5.2. Adding the Transceiver PLL

The 25G Ethernet Intel FPGA IP core targets Arria 10 GT devices. Intel Arria 10 GT devices require an external PLL to drive the TX transceiver serial clock, in order to compile and to function correctly in hardware. In many cases, the same PLL can be shared with an additional transceiver in your design.

### Figure 6. PLL Configuration Example

The TX transceiver PLL is instantiated with an ATX PLL IP core. The TX transceiver PLL must always be instantiated outside the 25G Ethernet Intel FPGA IP core.



You can use the IP Catalog to create a transceiver PLL.

- Select Intel Arria 10 Transceiver ATX PLL.
- In the parameter editor, set the following parameter values:
  - PLL output frequency to 12890.625 MHz. The transceiver performs dual edge clocking, using both the rising and falling edges of the input clock from the PLL. Therefore, this PLL output frequency setting supports a 25.78125 Gbps data rate through the transceiver.
  - PLL reference clock frequency to 644.53125 MHz.

You must connect the ATX PLL to the 25G Ethernet Intel FPGA IP core as follows:

- Connect the clock output port of the ATX PLL to the <code>tx\_serial\_clk</code> input port of the 25G Ethernet Intel FPGA IP core.
- Connect the pll\_locked output port of the ATX PLL to the tx\_pll\_locked input port of the 25G Ethernet Intel FPGA IP core.
- Drive the ATX PLL reference clock port and the 25G Ethernet Intel FPGA IP core clk\_ref input port with the same clock. The clock frequency must be the frequency you specify for the ATX PLL IP core **PLL reference clock frequency** parameter.

### **Related Information**

Transceivers on page 56



#### Intel Arria 10 Transceiver PHY User Guide

Information about the correspondence between PLLs and transceiver channels, and information about how to configure an external transceiver PLL for your own design. You specify the clock network to which the PLL output connects by setting the clock network in the PLL parameter editor.

### 2.5.3. Handling Potential Jitter in Intel Arria 10 Devices

The RX path in the 25G Ethernet Intel FPGA IP core includes cascaded PLLs. Therefore, the IP core clocks might experience additional jitter in Intel Arria 10 devices.

Refer to the KDB Answer *How do I compensate for the jitter of PLL cascading or nondedicated clock path for Arria 10 PLL reference clock?* for a workaround you should apply to the IP core, in your design.

### **Related Information**

https://www.altera.com/support/support-resources/knowledge-base/tools/2017/fb470823.html

KDB Answer: How do I compensate for the jitter of PLL cascading or non-dedicated clock path for Arria 10 PLL reference clock?

### **2.5.4. Adding the External Time-of-Day Module for Variations with 1588 PTP Feature**

25G Ethernet Intel FPGA IP cores 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. 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.

Intel provides the following components that you can combine to create the TOD module the 25G Ethernet Intel FPGA IP core requires:

- A simple TOD clock module, available from the IP Catalog (Interface Protocols
   > Ethernet > Reference Design Components > Ethernet IEEE 1588 Time of
   Day Clock Intel FPGA IP). You can instantiate two of these clock modules and
   connect one to the TX MAC and the other to the RX MAC.
- A single-format TOD synchronizer, available from the IP Catalog (Interface Protocols > Ethernet > Reference Design Components > Ethernet IEEE 1588 TOD Synchronizer Intel FPGA IP). This component can handle only a single TOD format. Therefore, if you set the Time of day format parameter to the value of Enable both formats, you must instantiate and connect two TOD synchronizer modules. If your IP core supports only a single TOD format, your design requires only a single TOD synchronizer module.

Each TOD synchronizer connects a master TOD clock and a slave TOD clock.

- If you create your TOD module with a single TOD synchronizer, the master TOD clock connects to the TX MAC of the 25G Ethernet Intel FPGA IP core and the slave TOD clock connects to the RX MAC of the 25G Ethernet Intel FPGA IP core.
- Alternatively, you can drive both the TX and RX TOD clocks from a single master TOD clock. In that case, your design must include two TOD synchronizers, one to connect the master TOD clock and the slave TX TOD clock and one to connect the master TOD clock and the slave RX TOD clock.



If your IP core supports both TOD formats, double the number of TOD synchronizers in your TOD module. The configuration you implement depends on your system design requirements for 1588 PTP functionality.

### Figure 7. TOD Synchronizer and TOD Clocks in 96-Bit TOD Format Design

Shows the required connections between two TOD clock components and a TOD synchronizer component in a single TOD format design. In a simple TOD module, the master TOD clock connects to the TX MAC of the IP core, and the slave TOD clock connects to the RX MAC of the IP core. If your 25G Ethernet Intel FPGA IP core supports both TOD formats, a second TOD synchronizer connects to the corresponding 64-bit time-of-day signals of the same master and slave TOD clocks.



For information about the Ethernet IEEE 1588 Time of Day Clock and Ethernet IEEE 1588 TOD Synchronizer components, and the requirements for the PLL that connects to the TOD synchronizer, refer to the *Ethernet Design Example Components User Guide*.

### Table 9. TOD Module Required Connections to 25G Ethernet Intel FPGA IP Core

Lists the required connections between the TOD module and the 25G Ethernet Intel FPGA IP core, 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 25G Ethernet Intel FPGA IP core. 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 value you set for **Time of day format** in the parameter editor. For example, an RX TOD module might require only a 96-bit TOD out signal. This table does not list required connections between the TOD module and additional parts of your design.

| TOD Module Signal                                                                    | 25GbE IP Core Signal                                                                                                  |
|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| ${\tt rst_n}$ (input to TX and RX TOD clocks)                                        | Drive this signal from the same source as the $\mbox{csr_rst_n}$ input signal to the 25G Ethernet Intel FPGA IP core. |
| <pre>period_rst_n (input to RX TOD clock) reset_slave (input to Synchronizer)</pre>  | Drive these signals from the same source as the $rx\_rst\_n$ input signal to the 25G Ethernet Intel FPGA IP core.     |
| <pre>period_rst_n (input to TX TOD clock) reset_master (input to Synchronizer)</pre> | Drive these signals from the same source as the $tx\_rst\_n$ input signal to the 25G Ethernet Intel FPGA IP core.     |
| <pre>time_of_day_96b[95:0] (output from TX TOD clock)</pre>                          | <pre>tx_time_of_day_96b_data[95:0] (input)</pre>                                                                      |
| <pre>time_of_day_64b[63:0] (output from TX TOD clock)</pre>                          | <pre>tx_time_of_day_64b_data[63:0] (input)</pre>                                                                      |
| <pre>time_of_day_96b[95:0] (output from RX TOD clock)</pre>                          | <pre>rx_time_of_day_96b_data[95:0] (input)</pre>                                                                      |
| <pre>time_of_day_64b[63:0] (output from RX TOD clock)</pre>                          | <pre>rx_time_of_day_64b_data[63:0] (input)</pre>                                                                      |
| period_clk (input to TX TOD clock)                                                   | clk_txmac (output)                                                                                                    |
|                                                                                      | continued                                                                                                             |



| TOD Module Signal                                                               | 25GbE IP Core Signal |
|---------------------------------------------------------------------------------|----------------------|
| <pre>clk_master (input to Synchronizer)</pre>                                   |                      |
| <pre>period_clk (input to RX TOD clock) clk_slave (input to Synchronizer)</pre> | clk_rxmac (output)   |

- External Time-of-Day Module for 1588 PTP Variations on page 47
- Ethernet Design Example Components User Guide Describes the Ethernet IEEE 1588 Time of Day Clock component and the Ethernet IEEE 1588 TOD Synchronizer component available in the Intel Quartus Prime software from the IP Catalog.

### 2.5.5. Placement Settings for the 25G Ethernet Intel FPGA IP Core

The Quartus Prime software provides the options to specify design partitions and Logic Lock (Standard) or Logic Lock regions for incremental compilation, to control placement on the device. To achieve timing closure for your design, you might need to provide floorplan guidelines using one or both of these features.

The appropriate floorplan is always design-specific, and depends on your full design.

### **Related Information**

• Quartus Prime Standard Edition Handbook Volume 2: Design Implementation and Optimization

Describes incremental compilation, design partitions, and Logic Lock (Standard) regions.

• Intel Quartus Prime Pro Edition Handbook Volume 2: Design Implementation and Optimization

Describes incremental compilation, design partitions, and Logic Lock regions.

## 2.6. Compiling the Full Design and Programming the FPGA

You can use the **Start Compilation** command on the Processing menu in the Intel Quartus Prime software to compile your design. After successfully compiling your design, program the targeted Intel FPGA with the Programmer and verify the design in hardware.

- *Note:* The 25G Ethernet Intel FPGA IP core design example synthesis directories include Synopsys Constraint (.sdc) files that you can copy and modify for your own design.
- *Note:* For additional .sdc file requirements, please refer to the KDB Answer at https:// www.altera.com/support/support-resources/knowledge-base/tools/2017/ fb470823.html.

### **Related Information**

- Incremental Compilation for Hierarchical and Team-Based Design
- Programming Intel Devices
- 25G Ethernet Intel Arria 10 FPGA IP Design Example User Guide Information about generating the design example and the design example directory structure.



## **3. 25G Ethernet Intel FPGA IP Core Parameters**

The 25G Ethernet Intel FPGA IP parameter editor provides the parameters you can set to configure the 25G Ethernet Intel FPGA IP core and simulation testbenches.

The 25G Ethernet Intel FPGA IP parameter editor includes an **Example Design** tab. For information about that tab, refer to the *25G Ethernet Design Example User Guide*.

#### Table 10.IP Core Parameters

| Parameter                       | Range                | Default Setting | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|---------------------------------|----------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| General Options                 |                      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Device Family                   | Arria 10             | Arria 10        | Selects the device family.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| Ready Latency                   | 0, 3                 | 0               | Selects the readyLatency value on the TX client<br>interface. readyLatency is an Avalon-ST interface<br>property that defines the number of clock cycles of<br>delay from when the IP core asserts the 11_tx_ready<br>signal to the clock cycle in which the IP core can accept<br>data on the TX client interface. Refer to the Avalon<br>Interface Specifications.<br>Selecting a latency of 3 eases timing closure at the<br>expense of increased latency for the datapath.<br>If you set the readyLatency to 3 and turn on standard<br>flow control, data might be delayed in the IP core while<br>the IP core is backpressured. |  |
| PCS/PMA Options                 |                      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Enable RS-FEC                   | Enabled,<br>Disabled | Disabled        | When enabled, the IP core implements Reed-Solomon<br>forward error correction (FEC).<br>This parameter is not available if you turn on <b>Enable</b><br><b>IEEE 1588</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| Flow Control Options            |                      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Enable flow control             | Enabled,<br>Disabled | Disabled        | When enabled, the IP core implements flow control.<br>When either link partner experiences congestion, the<br>respective transmit control sends pause frames.<br>Register settings control flow control behavior, including<br>whether the IP core implements standard flow control<br>or priority-based flow control.<br>If you turn on standard flow control and set the<br>readyLatency to 3, data might be delayed in the IP core<br>while the IP core is backpressured.                                                                                                                                                         |  |
| Number of queues                | 1-8                  | 8               | Specifies the number of queues used in managing flow control.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| MAC Options                     |                      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| Enable link fault<br>generation | Enabled,<br>Disabled | Disabled        | When enabled, the IP core implements link fault<br>signaling as defined in the IEEE 802.3-2012 IEEE<br>Standard for Ethernet. The MAC includes a<br>Reconciliation Sublayer (RS) to manage local and<br>remote faults. When enabled, the local RS TX logic can                                                                                                                                                                                                                                                                                                                                                                       |  |
|                                 |                      |                 | continued                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |

Intel Corporation. All rights reserved. Intel, the Intel logo, Altera, Arria, Cyclone, Enpirion, 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.



| Parameter                                        | Range                                                                                                 | Default Setting        | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                                  |                                                                                                       |                        | transmit remote fault sequences in case of a local fault<br>and can transmit IDLE control words in case of a<br>remote fault.                                                                                                                                                                                                                                                                                                      |  |  |
| Enable preamble<br>passthrough                   | Enabled,<br>Disabled                                                                                  | Disabled               | When enabled, the IP core is in RX and TX preamble<br>pass-through mode. In RX preamble pass-through<br>mode, the IP core passes the preamble and Start<br>Frame Delimiter (SFD) to the client instead of stripping<br>them out of the Ethernet packet. In TX preamble pass-<br>through mode, the client specifies the preamble and<br>provides the SFD to be sent in the Ethernet frame.                                          |  |  |
| Enable TX CRC<br>passthrough                     | Enabled,<br>Disabled                                                                                  | Disabled               | When enabled, TX MAC does not insert the CRC-32 checksum in the out-going frame. In pass-through mode, the client must provide frames with at least 64 bytes, including the Frame Check Sequence (FCS). When disabled, the TX MAC computes and inserts a 32-bit FCS in the TX MAC frame.<br>This parameter is not available if you turn on <b>Enable IEEE 1588</b> .                                                               |  |  |
| Enable MAC statistics<br>counters                | Enabled,<br>Disabled                                                                                  | Enabled                | When enabled, the IP core includes statistics counters that characterize TX and RX traffic.                                                                                                                                                                                                                                                                                                                                        |  |  |
| IEEE 1588 Options                                |                                                                                                       |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Enable IEEE 1588                                 | Enabled,<br>Disabled                                                                                  | Disabled               | If enabled, the IP core supports the IEEE Standard<br>1588-2008 Precision Clock Synchronization Protocol, by<br>providing the hooks to implement the Precise Timing<br>Protocol (PTP).<br>This parameter is not available if you turn on <b>Enable</b><br><b>TX CRC passthrough</b> .<br>This parameter is not available if you turn on <b>Enable</b>                                                                              |  |  |
| Time of day format                               | Enable 96-bit<br>timestamp<br>format, Enable<br>64-bit<br>timestamp<br>format, Enable<br>both formats | Enable both<br>formats | Specifies the interface to the Time of Day module. If<br>you select <b>Enable both formats</b> , the IP core includes<br>both the 64-bit interface and the 96-bit interface.<br>This parameter is available only in variations with<br><b>Enable IEEE 1588</b> turned on. The IP core provides the<br>Time of Day interface; the IP core does not include<br>Time of Day and synchronizer modules to connect to<br>this interface. |  |  |
| Fingerprint width                                | 1-32                                                                                                  | 4                      | Specifies the number of bits in the fingerprint that the IP core handles.<br>This parameter is available only in variations with <b>Enable IEEE 1588</b> turned on.                                                                                                                                                                                                                                                                |  |  |
| Configuration, Debug and Extension Options       |                                                                                                       |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Enable Altera Debug<br>Master Endpoint<br>(ADME) | Enabled,<br>Disabled                                                                                  | Disabled               | If enabled, the IP core turns on the following features<br>in the Arria 10 PHY IP core that is included in the 25G<br>Ethernet Intel FPGA IP core:<br>• Enable Altera Debug Master Endpoint (ADME)                                                                                                                                                                                                                                 |  |  |
|                                                  |                                                                                                       |                        | • Enable capability registers<br>If turned off, the IP core is configured without these<br>features.<br>For information about these Arria 10 features, refer to<br>the Arria 10 Transceiver PHY User Guide.                                                                                                                                                                                                                        |  |  |

• 25G Ethernet Design Example User Guide Information about the **Example Design** tab in the 25G Ethernet Intel FPGA IP parameter editor.