



# Intel® Arria® 10 Transceiver PHY User Guide

Updated for Intel® Quartus® Prime Design Suite: **21.1**



[Subscribe](#)



[Send Feedback](#)

**UG-01143 | 2021.06.10**

Latest document on the web: [PDF](#) | [HTML](#)

## Contents

---

|                                                                        |           |
|------------------------------------------------------------------------|-----------|
| <b>1. Arria® 10 Transceiver PHY Overview .....</b>                     | <b>8</b>  |
| 1.1. Device Transceiver Layout.....                                    | 9         |
| 1.1.1. Arria 10 GX Device Transceiver Layout.....                      | 10        |
| 1.1.2. Intel Arria 10 GT Device Transceiver Layout.....                | 15        |
| 1.1.3. Arria 10 GX and GT Device Package Details .....                 | 17        |
| 1.1.4. Arria 10 SX Device Transceiver Layout.....                      | 18        |
| 1.1.5. Arria 10 SX Device Package Details.....                         | 19        |
| 1.2. Transceiver PHY Architecture Overview.....                        | 20        |
| 1.2.1. Transceiver Bank Architecture.....                              | 20        |
| 1.2.2. PHY Layer Transceiver Components.....                           | 25        |
| 1.2.3. Transceiver Phase-Locked Loops.....                             | 28        |
| 1.2.4. Clock Generation Block (CGB).....                               | 29        |
| 1.3. Calibration.....                                                  | 29        |
| 1.4. Intel Arria 10 Transceiver PHY Overview Revision History.....     | 30        |
| <b>2. Implementing Protocols in Arria 10 Transceivers.....</b>         | <b>32</b> |
| 2.1. Transceiver Design IP Blocks.....                                 | 32        |
| 2.2. Transceiver Design Flow.....                                      | 33        |
| 2.2.1. Select and Instantiate the PHY IP Core.....                     | 33        |
| 2.2.2. Configure the PHY IP Core.....                                  | 35        |
| 2.2.3. Generate the PHY IP Core.....                                   | 36        |
| 2.2.4. Select the PLL IP Core.....                                     | 36        |
| 2.2.5. Configure the PLL IP Core.....                                  | 38        |
| 2.2.6. Generate the PLL IP Core .....                                  | 39        |
| 2.2.7. Reset Controller .....                                          | 39        |
| 2.2.8. Create Reconfiguration Logic.....                               | 39        |
| 2.2.9. Connect the PHY IP to the PLL IP Core and Reset Controller..... | 40        |
| 2.2.10. Connect Datapath .....                                         | 40        |
| 2.2.11. Make Analog Parameter Settings .....                           | 40        |
| 2.2.12. Compile the Design.....                                        | 41        |
| 2.2.13. Verify Design Functionality.....                               | 41        |
| 2.3. Arria 10 Transceiver Protocols and PHY IP Support.....            | 41        |
| 2.4. Using the Arria 10 Transceiver Native PHY IP Core.....            | 45        |
| 2.4.1. Presets.....                                                    | 48        |
| 2.4.2. General and Datapath Parameters .....                           | 48        |
| 2.4.3. PMA Parameters.....                                             | 51        |
| 2.4.4. Enhanced PCS Parameters .....                                   | 55        |
| 2.4.5. Standard PCS Parameters.....                                    | 62        |
| 2.4.6. PCS Direct .....                                                | 67        |
| 2.4.7. Dynamic Reconfiguration Parameters.....                         | 67        |
| 2.4.8. PMA Ports.....                                                  | 73        |
| 2.4.9. Enhanced PCS Ports.....                                         | 77        |
| 2.4.10. Standard PCS Ports.....                                        | 87        |
| 2.4.11. IP Core File Locations.....                                    | 92        |
| 2.4.12. Unused Transceiver RX Channels.....                            | 93        |
| 2.4.13. Unsupported Features.....                                      | 94        |
| 2.5. Interlaken.....                                                   | 94        |

|                                                                                                                                                                       |            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 2.5.1. Metaframe Format and Framing Layer Control Word.....                                                                                                           | 95         |
| 2.5.2. Interlaken Configuration Clocking and Bonding.....                                                                                                             | 97         |
| 2.5.3. How to Implement Interlaken in Arria 10 Transceivers.....                                                                                                      | 103        |
| 2.5.4. Design Example.....                                                                                                                                            | 106        |
| 2.5.5. Native PHY IP Parameter Settings for Interlaken.....                                                                                                           | 107        |
| <b>2.6. Ethernet.....</b>                                                                                                                                             | <b>111</b> |
| 2.6.1. Gigabit Ethernet (GbE) and GbE with IEEE 1588v2.....                                                                                                           | 112        |
| 2.6.2. 10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC Variants.....                                                                                    | 124        |
| 2.6.3. 10GBASE-KR PHY IP Core .....                                                                                                                                   | 135        |
| 2.6.4. 1-Gigabit/10-Gigabit Ethernet (GbE) PHY IP Core.....                                                                                                           | 164        |
| 2.6.5. 1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP Core.....                                                                                                 | 199        |
| 2.6.6. XAUI PHY IP Core.....                                                                                                                                          | 221        |
| 2.6.7. Acronyms.....                                                                                                                                                  | 235        |
| <b>2.7. PCI Express (PIPE).....</b>                                                                                                                                   | <b>236</b> |
| 2.7.1. Transceiver Channel Datapath for PIPE.....                                                                                                                     | 237        |
| 2.7.2. Supported PIPE Features.....                                                                                                                                   | 238        |
| 2.7.3. How to Connect TX PLLs for PIPE Gen1, Gen2, and Gen3 Modes.....                                                                                                | 247        |
| 2.7.4. How to Implement PCI Express (PIPE) in Arria 10 Transceivers.....                                                                                              | 253        |
| 2.7.5. Native PHY IP Parameter Settings for PIPE .....                                                                                                                | 255        |
| 2.7.6. fPLL IP Parameter Core Settings for PIPE.....                                                                                                                  | 260        |
| 2.7.7. ATX PLL IP Parameter Core Settings for PIPE.....                                                                                                               | 262        |
| 2.7.8. Native PHY IP Ports for PIPE.....                                                                                                                              | 264        |
| 2.7.9. fPLL Ports for PIPE.....                                                                                                                                       | 271        |
| 2.7.10. ATX PLL Ports for PIPE.....                                                                                                                                   | 273        |
| 2.7.11. Preset Mappings to TX De-emphasis.....                                                                                                                        | 274        |
| 2.7.12. How to Place Channels for PIPE Configurations.....                                                                                                            | 275        |
| 2.7.13. PHY IP Core for PCIe (PIPE) Link Equalization for Gen3 Data Rate.....                                                                                         | 281        |
| 2.7.14. Using Transceiver Toolkit (TTK)/System Console/Reconfiguration Interface to manually tune Arria 10 PCIe designs (Hard IP(HIP) and PIPE) (For debug only)..... | 284        |
| <b>2.8. CPRI.....</b>                                                                                                                                                 | <b>286</b> |
| 2.8.1. Transceiver Channel Datapath and Clocking for CPRI.....                                                                                                        | 287        |
| 2.8.2. Supported Features for CPRI .....                                                                                                                              | 288        |
| 2.8.3. Word Aligner in Manual Mode for CPRI.....                                                                                                                      | 290        |
| 2.8.4. How to Implement CPRI in Arria 10 Transceivers.....                                                                                                            | 291        |
| 2.8.5. Native PHY IP Parameter Settings for CPRI.....                                                                                                                 | 292        |
| <b>2.9. Other Protocols.....</b>                                                                                                                                      | <b>296</b> |
| 2.9.1. Using the "Basic (Enhanced PCS)" and "Basic with KR FEC" Configurations of Enhanced PCS.....                                                                   | 296        |
| 2.9.2. Using the Basic/Custom, Basic/Custom with Rate Match Configurations of Standard PCS.....                                                                       | 307        |
| 2.9.3. Design Considerations for Implementing Arria 10 GT Channels.....                                                                                               | 326        |
| 2.9.4. How to Implement PCS Direct Transceiver Configuration Rule.....                                                                                                | 331        |
| <b>2.10. Simulating the Transceiver Native PHY IP Core.....</b>                                                                                                       | <b>332</b> |
| 2.10.1. NativeLink Simulation Flow.....                                                                                                                               | 333        |
| 2.10.2. Scripting IP Simulation.....                                                                                                                                  | 338        |
| 2.10.3. Custom Simulation Flow.....                                                                                                                                   | 339        |
| 2.11. Implementing Protocols in Intel Arria 10 Transceivers Revision History.....                                                                                     | 342        |
| <b>3. PLLs and Clock Networks.....</b>                                                                                                                                | <b>356</b> |
| 3.1. PLLs.....                                                                                                                                                        | 358        |

|                                                                        |            |
|------------------------------------------------------------------------|------------|
| 3.1.1. Transmit PLLs Spacing Guideline when using ATX PLLs.....        | 358        |
| 3.1.2. ATX PLL.....                                                    | 359        |
| 3.1.3. fPLL.....                                                       | 368        |
| 3.1.4. CMU PLL.....                                                    | 377        |
| 3.2. Input Reference Clock Sources.....                                | 382        |
| 3.2.1. Dedicated Reference Clock Pins.....                             | 383        |
| 3.2.2. Receiver Input Pins.....                                        | 384        |
| 3.2.3. PLL Cascading as an Input Reference Clock Source.....           | 384        |
| 3.2.4. Reference Clock Network.....                                    | 385        |
| 3.2.5. Global Clock or Core Clock as an Input Reference Clock.....     | 385        |
| 3.3. Transmitter Clock Network.....                                    | 385        |
| 3.3.1. x1 Clock Lines.....                                             | 386        |
| 3.3.2. x6 Clock Lines.....                                             | 387        |
| 3.3.3. xN Clock Lines.....                                             | 389        |
| 3.3.4. GT Clock Lines.....                                             | 391        |
| 3.4. Clock Generation Block.....                                       | 393        |
| 3.5. FPGA Fabric-Transceiver Interface Clocking.....                   | 394        |
| 3.6. Transmitter Data Path Interface Clocking.....                     | 396        |
| 3.7. Receiver Data Path Interface Clocking.....                        | 397        |
| 3.8. Unused/Idle Clock Line Requirements.....                          | 399        |
| 3.9. Channel Bonding.....                                              | 399        |
| 3.9.1. PMA Bonding.....                                                | 399        |
| 3.9.2. PMA and PCS Bonding.....                                        | 401        |
| 3.9.3. PCS Bonding Channels Placement Restrictions.....                | 402        |
| 3.9.4. Selecting Channel Bonding Schemes.....                          | 404        |
| 3.9.5. Skew Calculations.....                                          | 405        |
| 3.10. PLL Feedback and Cascading Clock Network.....                    | 405        |
| 3.11. Using PLLs and Clock Networks.....                               | 410        |
| 3.11.1. Non-bonded Configurations.....                                 | 410        |
| 3.11.2. Bonded Configurations.....                                     | 415        |
| 3.11.3. Implementing PLL Cascading.....                                | 420        |
| 3.11.4. Mix and Match Example.....                                     | 421        |
| 3.11.5. Timing Closure Recommendations.....                            | 425        |
| 3.12. PLLs and Clock Networks Revision History.....                    | 426        |
| <b>4. Resetting Transceiver Channels.....</b>                          | <b>428</b> |
| 4.1. When Is Reset Required? .....                                     | 428        |
| 4.2. Transceiver PHY Implementation.....                               | 429        |
| 4.3. How Do I Reset?.....                                              | 430        |
| 4.3.1. Model 1: Default Model.....                                     | 430        |
| 4.3.2. Model 2: Acknowledgment Model.....                              | 439        |
| 4.3.3. Transceiver Blocks Affected by Reset and Powerdown Signals..... | 444        |
| 4.4. Using the Transceiver PHY Reset Controller.....                   | 445        |
| 4.4.1. Parameterizing the Transceiver PHY Reset Controller IP.....     | 447        |
| 4.4.2. Transceiver PHY Reset Controller Parameters.....                | 447        |
| 4.4.3. Transceiver PHY Reset Controller Interfaces.....                | 449        |
| 4.4.4. Transceiver PHY Reset Controller Resource Utilization.....      | 453        |
| 4.5. Using a User-Coded Reset Controller.....                          | 453        |
| 4.5.1. User-Coded Reset Controller Signals.....                        | 453        |
| 4.6. Combining Status or PLL Lock Signals .....                        | 454        |
| 4.7. Timing Constraints for Bonded PCS and PMA Channels.....           | 455        |

|                                                                                     |            |
|-------------------------------------------------------------------------------------|------------|
| 4.8. Resetting Transceiver Channels Revision History.....                           | 457        |
| <b>5. Arria 10 Transceiver PHY Architecture.....</b>                                | <b>459</b> |
| 5.1. Arria 10 PMA Architecture.....                                                 | 459        |
| 5.1.1. Transmitter.....                                                             | 459        |
| 5.1.2. Serializer.....                                                              | 459        |
| 5.1.3. Transmitter Buffer.....                                                      | 460        |
| 5.1.4. Receiver.....                                                                | 462        |
| 5.1.5. Receiver Buffer.....                                                         | 463        |
| 5.1.6. Clock Data Recovery (CDR) Unit.....                                          | 470        |
| 5.1.7. Deserializer.....                                                            | 472        |
| 5.1.8. Loopback.....                                                                | 472        |
| 5.2. Arria 10 Enhanced PCS Architecture.....                                        | 473        |
| 5.2.1. Transmitter Datapath.....                                                    | 474        |
| 5.2.2. Receiver Datapath.....                                                       | 483        |
| 5.3. Arria 10 Standard PCS Architecture.....                                        | 491        |
| 5.3.1. Transmitter Datapath.....                                                    | 492        |
| 5.3.2. Receiver Datapath.....                                                       | 497        |
| 5.4. Arria 10 PCI Express Gen3 PCS Architecture.....                                | 507        |
| 5.4.1. Transmitter Datapath.....                                                    | 508        |
| 5.4.2. Receiver Datapath.....                                                       | 509        |
| 5.4.3. PIPE Interface.....                                                          | 510        |
| 5.5. Intel Arria 10 Transceiver PHY Architecture Revision History.....              | 511        |
| <b>6. Reconfiguration Interface and Dynamic Reconfiguration .....</b>               | <b>514</b> |
| 6.1. Reconfiguring Channel and PLL Blocks.....                                      | 515        |
| 6.2. Interacting with the Reconfiguration Interface.....                            | 515        |
| 6.2.1. Reading from the Reconfiguration Interface.....                              | 517        |
| 6.2.2. Writing to the Reconfiguration Interface.....                                | 517        |
| 6.3. Configuration Files.....                                                       | 518        |
| 6.4. Multiple Reconfiguration Profiles.....                                         | 521        |
| 6.5. Embedded Reconfiguration Streamer.....                                         | 522        |
| 6.6. Arbitration.....                                                               | 524        |
| 6.7. Recommendations for Dynamic Reconfiguration.....                               | 527        |
| 6.8. Steps to Perform Dynamic Reconfiguration.....                                  | 528        |
| 6.9. Direct Reconfiguration Flow.....                                               | 531        |
| 6.10. Native PHY IP or PLL IP Core Guided Reconfiguration Flow.....                 | 531        |
| 6.11. Reconfiguration Flow for Special Cases.....                                   | 533        |
| 6.11.1. Switching Transmitter PLL .....                                             | 533        |
| 6.11.2. Switching Reference Clocks.....                                             | 535        |
| 6.12. Changing PMA Analog Parameters.....                                           | 539        |
| 6.12.1. Changing VOD, Pre-emphasis Using Direct Reconfiguration Flow.....           | 542        |
| 6.12.2. Changing CTLE Settings in Manual Mode Using Direct Reconfiguration Flow..   | 543        |
| 6.12.3. CTLE Settings in Triggered Adaptation Mode.....                             | 543        |
| 6.12.4. Enabling and Disabling Loopback Modes Using Direct Reconfiguration Flow.... | 545        |
| 6.13. Ports and Parameters.....                                                     | 547        |
| 6.14. Dynamic Reconfiguration Interface Merging Across Multiple IP Blocks.....      | 554        |
| 6.15. Embedded Debug Features.....                                                  | 556        |
| 6.15.1. Native PHY Debug Master Endpoint.....                                       | 556        |
| 6.15.2. Optional Reconfiguration Logic.....                                         | 556        |
| 6.16. Using Data Pattern Generators and Checkers.....                               | 562        |

|                                                                                           |            |
|-------------------------------------------------------------------------------------------|------------|
| 6.16.1. Using PRBS Data Pattern Generator and Checker.....                                | 562        |
| 6.16.2. Using Pseudo Random Pattern Mode.....                                             | 571        |
| 6.17. Timing Closure Recommendations.....                                                 | 572        |
| 6.18. Unsupported Features.....                                                           | 575        |
| 6.19. Arria 10 Transceiver Register Map.....                                              | 576        |
| 6.20. Reconfiguration Interface and Dynamic Revision History.....                         | 576        |
| <b>7. Calibration.....</b>                                                                | <b>579</b> |
| 7.1. Reconfiguration Interface and Arbitration with PreSICE Calibration Engine .....      | 579        |
| 7.2. Calibration Registers.....                                                           | 581        |
| 7.2.1. Avalon Memory-Mapped Interface Arbitration Registers.....                          | 581        |
| 7.2.2. Transceiver Channel Calibration Registers.....                                     | 582        |
| 7.2.3. Fractional PLL Calibration Registers.....                                          | 582        |
| 7.2.4. ATX PLL Calibration Registers.....                                                 | 583        |
| 7.2.5. Capability Registers.....                                                          | 583        |
| 7.2.6. Rate Switch Flag Register.....                                                     | 585        |
| 7.3. Power-up Calibration.....                                                            | 586        |
| 7.4. User Recalibration.....                                                              | 588        |
| 7.4.1. Recalibration After Transceiver Reference Clock Frequency or Data Rate Change..... | 591        |
| 7.5. Calibration Example.....                                                             | 593        |
| 7.5.1. ATX PLL Recalibration.....                                                         | 593        |
| 7.5.2. Fractional PLL Recalibration.....                                                  | 593        |
| 7.5.3. CDR/CMU PLL Recalibration.....                                                     | 594        |
| 7.5.4. PMA Recalibration.....                                                             | 594        |
| 7.6. Calibration Revision History.....                                                    | 595        |
| <b>8. Analog Parameter Settings.....</b>                                                  | <b>597</b> |
| 8.1. Making Analog Parameter Settings using the Assignment Editor.....                    | 597        |
| 8.2. Updating Quartus Settings File with the Known Assignment.....                        | 597        |
| 8.3. Analog Parameter Settings List.....                                                  | 598        |
| 8.4. Receiver General Analog Settings.....                                                | 600        |
| 8.4.1. XCVR_A10_RX_LINK.....                                                              | 600        |
| 8.4.2. XCVR_A10_RX_TERM_SEL.....                                                          | 601        |
| 8.4.3. XCVR_VCCR_VCCT_VOLTAGE - RX.....                                                   | 601        |
| 8.5. Receiver Analog Equalization Settings.....                                           | 602        |
| 8.5.1. CTLE Settings.....                                                                 | 602        |
| 8.5.2. VGA Settings.....                                                                  | 605        |
| 8.5.3. Decision Feedback Equalizer (DFE) Settings.....                                    | 606        |
| 8.6. Transmitter General Analog Settings.....                                             | 608        |
| 8.6.1. XCVR_A10_TX_LINK.....                                                              | 608        |
| 8.6.2. XCVR_A10_TX_TERM_SEL.....                                                          | 609        |
| 8.6.3. XCVR_A10_TX_COMPENSATION_EN.....                                                   | 609        |
| 8.6.4. XCVR_VCCR_VCCT_VOLTAGE - TX.....                                                   | 610        |
| 8.6.5. XCVR_A10_TX_SLEW_RATE_CTRL.....                                                    | 611        |
| 8.7. Transmitter Pre-Emphasis Analog Settings.....                                        | 612        |
| 8.7.1. XCVR_A10_TX_PRE_EMP_SIGN_PRE_TAP_1T.....                                           | 612        |
| 8.7.2. XCVR_A10_TX_PRE_EMP_SIGN_PRE_TAP_2T.....                                           | 612        |
| 8.7.3. XCVR_A10_TX_PRE_EMP_SIGN_1ST_POST_TAP.....                                         | 613        |
| 8.7.4. XCVR_A10_TX_PRE_EMP_SIGN_2ND_POST_TAP.....                                         | 613        |
| 8.7.5. XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_PRE_TAP_1T.....                                 | 614        |
| 8.7.6. XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_PRE_TAP_2T.....                                 | 614        |

|                                                             |            |
|-------------------------------------------------------------|------------|
| 8.7.7. XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_1ST_POST_TAP..... | 615        |
| 8.7.8. XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_2ND_POST_TAP..... | 616        |
| 8.8. Transmitter VOD Settings.....                          | 616        |
| 8.8.1. XCVR_A10_TX_VOD_OUTPUT_SWING_CTRL.....               | 616        |
| 8.9. Dedicated Reference Clock Settings.....                | 617        |
| 8.9.1. XCVR_A10_REFCLK_TERM_TRISTATE.....                   | 617        |
| 8.9.2. XCVR_A10_TX_XTX_PATH_ANALOG_MODE.....                | 618        |
| 8.10. Unused Transceiver RX Channels Settings.....          | 618        |
| 8.11. Analog Parameter Settings Revision History.....       | 618        |
| <b>9. Debugging Transceiver Toolkit.....</b>                | <b>620</b> |
| 9.1. Transceiver Toolkit GUI.....                           | 620        |
| 9.1.1. Main View Functions.....                             | 621        |
| 9.2. Transceiver Debugging Flow Walkthrough.....            | 622        |
| 9.2.1. Enabling Transceiver Toolkit Support.....            | 622        |
| 9.2.2. Programming Design into an Intel FPGA.....           | 624        |
| 9.2.3. Loading Design to the Transceiver Toolkit.....       | 625        |
| 9.2.4. Creating Transceiver Links.....                      | 626        |
| 9.2.5. Running Link Test.....                               | 630        |
| 9.3. Linking Hardware Resource for Multiple FPGAs.....      | 633        |
| 9.3.1. Linking One Design to One Device.....                | 635        |
| 9.3.2. Linking Two Designs to Two Devices.....              | 635        |
| 9.3.3. Linking One Design on Two Devices.....               | 635        |
| 9.3.4. Linking Designs and Devices on Separate Boards.....  | 635        |
| 9.4. Troubleshooting Common Errors.....                     | 636        |
| 9.5. Debugging Transceiver Toolkit Revision History.....    | 636        |

## 1. Arria® 10 Transceiver PHY Overview

This user guide provides details about the Arria® 10 transceiver physical (PHY) layer architecture, PLLs, clock networks, and transceiver PHY IP. It also provides protocol specific implementation details and describes features such as transceiver reset and dynamic reconfiguration of transceiver channels and PLLs.

Intel® Arria 10 FPGAs offer up to 96 GX transceiver channels with integrated advanced high speed analog signal conditioning and clock data recovery techniques for chip-to-chip, chip-to-module, and backplane applications.

The Arria 10 GX and SX devices have GX transceiver channels that can support data rates up to 17.4 Gbps for chip-to-chip applications and 12.5 Gbps for backplane applications.

The Arria 10 GT device has up to 6 GT transceiver channels, that can support data rates up to 25.8 Gbps for short reach chip-to-chip and chip-to-module applications. Additionally, the GT devices have GX transceiver channels that can support data rates up to 17.4 Gbps for chip-to-chip and 12.5 Gbps for backplane applications. If all 6 GT channels are used in GT mode, then the GT device also has up to 54 GX transceiver channels.

The Arria 10 transceivers support reduced power modes with data rates up to 11.3 Gbps (chip-to-chip) for critical power sensitive designs. In GX devices that have transceivers on both sides of the device, each side can be operated independently in standard and reduced power modes. You can achieve transmit and receive data rates below 1.0 Gbps with oversampling.

**Table 1. Data Rates Supported by GX Transceiver Channel Type**

| Device Variant | Standard Power Mode (1), (2) |                       | Reduced Power Mode (1), (2) |
|----------------|------------------------------|-----------------------|-----------------------------|
|                | Chip-to-Chip                 | Backplane             | Chip-to-Chip                |
| SX (3)         | 1.0 Gbps to 17.4 Gbps        | 1.0 Gbps to 12.5 Gbps | 1.0 Gbps to 11.3 Gbps       |
| GX(3)          | 1.0 Gbps to 17.4 Gbps        | 1.0 Gbps to 12.5 Gbps | 1.0 Gbps to 11.3 Gbps       |
| GT (4)         | 1.0 Gbps to 17.4 Gbps        | 1.0 Gbps to 12.5 Gbps | 1.0 Gbps to 11.3 Gbps       |

- (1) To operate GX transceiver channels at designated data rates in standard and reduced power modes, apply the corresponding core and periphery power supplies. Refer to the *Arria 10 Device Datasheet* for more details.
- (2) The minimum operational data rate is 1.0 Gbps for both the transmitter and receiver. For transmitter data rates less than 1.0 Gbps, oversampling must be applied at the transmitter. For receiver data rates less than 1.0 Gbps, oversampling must be applied at the receiver.
- (3) For SX and GX device variants, the maximum transceiver data rates are specified for the fastest (-1) transceiver speed grade.

**Table 2. Data Rates Supported by GT Transceiver Channel Type**

| Device Variant <sup>(4)</sup> | Data Rates <sup>(5), (2)</sup> |                       |
|-------------------------------|--------------------------------|-----------------------|
|                               | Chip-to-Chip                   | Backplane             |
| GT                            | 1.0 Gbps to 25.8 Gbps          | 1.0 Gbps to 12.5 Gbps |

**Note:** The device data rates depend on the device speed grade. Refer to *IntelArria 10 Device Datasheet* for details on available speed grades and supported data rates.

### Related Information

- [IntelArria 10 Device Datasheet](#)
- [IntelArria 10 Device Overview](#)

## 1.1. Device Transceiver Layout

**Figure 1. Arria 10 FPGA Architecture Block Diagram**

The transceiver channels are placed on the left side periphery in most Arria 10 devices. For larger Arria 10 devices, additional transceiver channels are placed on the right side periphery.



<sup>(4)</sup> For GT device variants, the maximum transceiver data rates are specified for (-1) transceiver speed grade.

<sup>(5)</sup> Because the GT transceiver channels are designed for peak performance, they do not have a reduced power mode of operation.

### 1.1.1. Arria 10 GX Device Transceiver Layout

The largest Arria 10 GX device includes 96 transceiver channels. A column array of eight transceiver banks on the left and the right side periphery of the device is shown in the following figure. Each transceiver bank has six transceiver channels. Some devices have transceiver banks with only three channels. The transceiver banks with only three channels are the uppermost transceiver banks. Arria 10 devices also include PCI Express\* Hard IP blocks.

The figures below illustrate different transceiver bank layouts for Arria 10 GX device variants.

For more information about PCIe\* Hard IP transceiver placements, refer to *Related Information* at the end of this section.

**Figure 2. Arria 10 GX Devices with 96 Transceiver Channels and Four PCIe Hard IP Blocks**



Notes:

- (1) Nomenclature of left column bottom transceiver banks always ends with "C".
- (2) Nomenclature of right column bottom transceiver banks may end with "C", "D", or "E".

| Legend:                                                                                |
|----------------------------------------------------------------------------------------|
| PCIe Gen1 - Gen3 Hard IP blocks with Configuration via Protocol (CvP) capabilities.    |
| PCIe Gen1 - Gen3 Hard IP blocks without Configuration via Protocol (CvP) capabilities. |
| Arria 10 GX device with 96 transceiver channels and four PCIe Hard IP blocks.          |

**Figure 3. Arria 10 GX Devices with 72 and 48 Transceiver Channels and Four PCIe Hard IP Blocks.**



**Figure 4. Arria 10 GX Devices with 66 Transceiver Channels and Three PCIe Hard IP Blocks**



**Figure 5. Arria 10 GX Devices with 48, 36, and 24 Transceiver Channels and Two PCIe Hard IP Blocks**



Note:  
(1) These devices have transceivers only on the left hand side of the device.

Legend:

- [Light Blue Box] PCIe Gen1 - Gen3 Hard IP blocks with Configuration via Protocol (CvP) capabilities.
- [Grey Box] PCIe Gen1 - Gen3 Hard IP blocks without Configuration via Protocol (CvP) capabilities.
- [Blue Box] Arria 10 GX device with 48 transceiver channels and two PCIe Hard IP blocks.
- [Green Box] Arria 10 GX device with 36 transceiver channels and two PCIe Hard IP blocks.
- [Teal Box] Arria 10 GX device with 24 transceiver channels and two PCIe Hard IP blocks.

**Figure 6. Arria 10 GX Devices with 12 Transceiver Channels and One PCIe Hard IP Block**



**Figure 7. Arria 10 GX Devices with 6 Transceiver Channels and One PCIe Hard IP Block**



### Related Information

- [Intel Arria 10 Avalon® Streaming Interface for PCIe Solutions User Guide](#)
- [Intel Arria 10 Avalon® Memory-Mapped Interface for PCIe Solutions User Guide](#)
- [Intel Arria 10 Avalon® Memory-Mapped Interface DMA for PCIe Solutions User Guide](#)
- [Intel Arria 10 Avalon® Streaming Interface with SR-IOV PCIe Solutions User Guide](#)

### 1.1.2. Intel Arria 10 GT Device Transceiver Layout

The Intel Arria 10 GT device has 72 transceiver channels and four PCI Express\* Hard IP blocks. A total of 6 GT transceiver channels that can support data rates up to 25.8 Gbps.

In the GT device, transceiver banks GXBL1E, GXBL1G, and GXBL1H each contain two GT transceiver channels. Transceiver banks GXBL1E and GXBL1H channels 3 and 4 can be used as GT or GX transceiver channel. Transceiver bank GXBL1G channels 0 and 1 can be used as GT or GX transceiver channels. When none of the GT capable

transceiver channels are used as GT transceiver channels, the entire transceiver channels in the bank can be reconfigured as GX transceiver channels. However, when any of the GT capable transceiver channels in transceiver banks GXBL1E, GXBL1G, and GXBL1H is enabled as a GT transceiver channel, the remaining channels in the transceiver bank cannot be used with the exception of the other GT capable channel in the transceiver bank.

If you're using GT transceivers in bank GXBL1E, then the adjacent PCIe Hard IP block cannot be used.

**Figure 8. Intel Arria 10 GT Device with 72 Transceiver Channels and Four PCIe Hard IP Blocks**



The GT device has 72 transceiver channels, which include 6 GT transceiver channels supporting data rates greater than 17.4 Gbps. If all six GT transceiver channels are used in GT mode, there are 54 GX transceiver channels that can drive chip to chip data rates up to 17.4 Gbps and backplanes at data rates up to 12.5 Gbps and 12 GX channels that are unusable.

In the GT device, the GX transceiver channels on the entire right side can be used in standard or reduced power mode. In GT devices where none of the GT channels are used to operate in GT data rates above 17.4 Gbps, the transceiver channels on either the entire right side or entire left side can be used as GX channels in standard or reduced power mode.

### Related Information

- [Intel Arria 10 Avalon® Streaming Interface for PCIe Solutions User Guide](#)
- [Intel Arria 10 Avalon® Memory-Mapped Interface for PCIe Solutions User Guide](#)

- Intel Arria 10 Avalon® Memory-Mapped Interface DMA for PCIe Solutions User Guide
- Intel Arria 10 Avalon® Streaming Interface with SR-IOV PCIe Solutions User Guide

### 1.1.3. Arria 10 GX and GT Device Package Details

The following tables list package sizes, available transceiver channels, and PCI Express Hard IP blocks for Arria 10 GX and GT devices.

**Table 3. Package Details for GX Devices with Transceivers and Hard IP Blocks Located on the Left Side Periphery of the Device**

- Package U19: 19mm x 19mm package; 484 pins.
- Package F27: 27mm x 27mm package; 672 pins.
- Package F29: 29mm x 29mm package; 780 pins.
- Packages F34 and F35: 35 mm x 35 mm package size; 1152 pins.
- Package F40: 40 mm x 40 mm package size; 1517 pins. K = 36 transceiver channels, N = 48 transceiver channels.

| Device                                             | U19  | F27   | F29   | F34   | F35   | K F40 | N F40 |
|----------------------------------------------------|------|-------|-------|-------|-------|-------|-------|
| <b>Transceiver Count, PCIe Hard IP Block Count</b> |      |       |       |       |       |       |       |
| GX 016                                             | 6, 1 | 12, 1 | 12, 1 |       |       |       |       |
| GX 022                                             | 6, 1 | 12, 1 | 12, 1 |       |       |       |       |
| GX 027                                             |      | 12, 1 | 12, 1 | 24, 2 | 24, 2 |       |       |
| GX 032                                             |      | 12, 1 | 12, 1 | 24, 2 | 24, 2 |       |       |
| GX 048                                             |      |       | 12, 1 | 24, 2 | 36, 2 |       |       |
| GX 057                                             |      |       |       | 24, 2 | 36, 2 | 36, 2 | 48, 2 |
| GX 066                                             |      |       |       | 24, 2 | 36, 2 | 36, 2 | 48, 2 |
| GX 090                                             |      |       |       | 24, 2 |       |       | 48, 2 |
| GX 115                                             |      |       |       | 24, 2 |       |       | 48, 2 |

**Table 4. Package Details for GX and GT Devices with Transceivers and Hard IP Blocks Located on the Left and Right Side Periphery of the Device**

- Package F40: 40 mm x 40 mm package size; 1517 pins. R = 66 transceiver channels.
- Package F45: 45mm x 45mm package size; 1932 pins. N = 48 transceiver channels, S = 72 transceiver channels, U = 96 transceiver channels.
- If you're using GT transceivers in bank GXBL1E, the nth adjacent PCIe Hard IP block cannot be used.

| Device                                             | R F40 | N F45 | S F45 | U F45 |
|----------------------------------------------------|-------|-------|-------|-------|
| <b>Transceiver Count, PCIe Hard IP Block Count</b> |       |       |       |       |
| GX 090                                             | 66, 3 | 48, 4 | 72, 4 | 96, 4 |
| GX 115                                             | 66, 3 | 48, 4 | 72, 4 | 96, 4 |
| GT 090                                             |       |       | 72, 4 |       |
| GT 115                                             |       |       | 72, 4 |       |

### 1.1.4. Arria 10 SX Device Transceiver Layout

The largest SX device includes 48 transceiver channels. All SX devices include GX transceiver channel type. The transceiver banks in SX devices are located on the left side periphery of the device.

For more information about PCIe Hard IP transceiver placements, refer to *Related Information* at the end of this section.

**Figure 9. Arria 10 SX Device with 48, 36, and 24 Transceiver Channels and Two Hard IP Blocks**



**Figure 10. Arria 10 SX Device with 12 Transceiver Channels and One Hard IP Block**



Note:  
(1) These devices have transceivers only on the left hand side of the device.

Legend:  
PCIe Gen1 - Gen3 Hard IP blocks with Configuration via Protocol (CvP) capabilities.  
Arria 10 SX device with 12 transceiver channels and one Hard IP block.

**Figure 11. Arria 10 SX Device with Six Transceiver Channels and One Hard IP Block**



Note:  
(1) Only CH5 and CH4 support PCIe Hard IP block with Configuration via Protocol (CvP) capabilities.  
(2) These devices have transceivers only on the left hand side of the device.

Legend:  
PCIe Gen1 - Gen3 Hard IP block with Configuration via Protocol (CvP) capabilities.  
Arria 10 SX device with six transceiver channels and one PCIe Hard IP block.

### Related Information

- Intel Arria 10 Avalon® Streaming Interface for PCIe Solutions User Guide
- Intel Arria 10 Avalon® Memory-Mapped Interface for PCIe Solutions User Guide
- Intel Arria 10 Avalon® Memory-Mapped Interface DMA for PCIe Solutions User Guide
- Intel Arria 10 Avalon® Streaming Interface with SR-IOV PCIe Solutions User Guide

#### 1.1.5. Arria 10 SX Device Package Details

The following tables list package sizes, available transceiver channels, and PCI Express Hard IP blocks for Arria 10 SX devices.

**Table 5. Package Details for SX Devices with Transceivers and Hard IP Blocks Located on the Left Side Periphery of the Device**

- Package U19: 19mm x 19mm package; 484 pins.
- Package F27: 27mm x 27mm package; 672 pins.
- Package F29: 29mm x 29mm package; 780 pins.
- Packages F34 and F35: 35 mm x 35 mm package size; 1152 pins.
- Package F40: 40 mm x 40 mm package size; 1517 pins. K = 36 transceiver channels, N = 48 transceiver channels.

| Device                                             | U19  | F27   | F29   | F34   | F35   | K F40 | N F40 |
|----------------------------------------------------|------|-------|-------|-------|-------|-------|-------|
| <b>Transceiver Count, PCIe Hard IP Block Count</b> |      |       |       |       |       |       |       |
| SX 016                                             | 6, 1 | 12, 1 | 12, 1 |       |       |       |       |
| SX 022                                             | 6, 1 | 12, 1 | 12, 1 |       |       |       |       |
| SX 027                                             |      | 12, 1 | 12, 1 | 24, 2 | 24, 2 |       |       |
| SX 032                                             |      | 12, 1 | 12, 1 | 24, 2 | 24, 2 |       |       |
| SX 048                                             |      |       | 12, 1 | 24, 2 | 36, 2 |       |       |
| SX 057                                             |      |       |       | 24, 2 | 36, 2 | 36, 2 | 48, 2 |
| SX 066                                             |      |       |       | 24, 2 | 36, 2 | 36, 2 | 48, 2 |

## 1.2. Transceiver PHY Architecture Overview

A link is defined as a single entity communication port. A link can have one or more transceiver channels. A transceiver channel is synonymous with a transceiver lane.

For example, a 10GBASE-R link has one transceiver channel or lane with a data rate of 10.3125 Gbps. A 40GBASE-R link has four transceiver channels. Each transceiver channel operates at a lane data rate of 10.3125 Gbps. Four transceiver channels give a total collective link bandwidth of 41.25 Gbps (40 Gbps before and after 64B/66B Physical Coding Sublayer (PCS) encoding and decoding).

### 1.2.1. Transceiver Bank Architecture

The transceiver bank is the fundamental unit that contains all the functional blocks related to the device's high speed serial transceivers.

Each transceiver bank includes six transceiver channels in all devices except for the devices with 66 transceiver channels. Devices with 66 transceiver channels have both six channel and three channel transceiver banks. The uppermost transceiver bank on the left and the right side of these devices is a three channel transceiver bank. All other devices contain only six channel transceiver banks.

The figures below show the transceiver bank architecture with the phase locked loop (PLL) and clock generation block (CGB) resources available in each bank.

Figure 12. Three-Channel GX Transceiver Bank Architecture



**Note:** This figure is a high level overview of the transceiver bank architecture. For details about the available clock networks refer to the *PLLs and Clock Networks* chapter.

**Figure 13. Six-Channel GX Transceiver Bank Architecture**


**Note:** This figure is a high level overview of the transceiver bank architecture. For details about the available clock networks refer to the *PLLs and Clock Networks* chapter.

**Figure 14. GT Transceiver Bank Architecture**

In the GT device, the transceiver banks GXBL1E, GXBL1G, and GXBL1H include GT channels.

**Note:**

This figure is a high level overview of the transceiver bank architecture. For details about the available clock networks refer to the *PLLs and Clock Networks* chapter.

**Figure 15. GT Transceiver Bank Architecture for Banks GXBL1E and GXBL1H**


**Note:** This figure is a high level overview of the transceiver bank architecture. For details about the available clock networks refer to the *PLLs and Clock Networks* chapter.

The transceiver channels perform all the required PHY layer functions between the FPGA fabric and the physical medium. The high speed clock required by the transceiver channels is generated by the transceiver PLLs. The master and local clock generation blocks (CGBs) provide the necessary high speed serial and low speed parallel clocks to drive the non-bonded and bonded channels in the transceiver bank.

### Related Information

- [PLLs and Clock Networks](#) on page 356
- [Transceiver Basics](#)  
Online training course for transceivers.

## 1.2.2. PHY Layer Transceiver Components

Transceivers in Arria 10 devices support both Physical Medium Attachment (PMA) and Physical Coding Sublayer (PCS) functions at the physical (PHY) layer.

A PMA is the transceiver's electrical interface to the physical medium. The transceiver PMA consists of standard blocks such as:

- serializer/deserializer (SERDES)
- clock and data recovery PLL
- analog front end transmit drivers
- analog front end receive buffers

The PCS can be bypassed with a PCS Direct configuration. Both the PMA and PCS blocks are fed by multiple clock networks driven by high performance PLLs. In PCS Direct configuration, the data flow is through the PCS block, but all the internal PCS blocks are bypassed. In this mode, the PCS functionality is implemented in the FPGA fabric.

### 1.2.2.1. The GX Transceiver Channel

**Figure 16. GX Transceiver Channel in Full Duplex Mode.**



Notes:

(1) The FPGA Fabric - PCS and PCS-PMA interface widths are configurable.

Arria 10 GX transceiver channels have three types of PCS blocks that together support continuous data rates between 1.0 Gbps and 17.4 Gbps.

**Table 6. PCS Types Supported by GX Transceiver Channels**

| PCS Type      | Data Rate                            |
|---------------|--------------------------------------|
| Standard PCS  | 1.0 Gbps to 10.81344 Gbps            |
| Enhanced PCS  | 1.0 Gbps <sup>(6)</sup> to 17.4 Gbps |
| PCIe Gen3 PCS | 8 Gbps                               |

Note:

1. The GX channel can also operate in PCS Direct configuration for data rates from 1.0 Gbps to 17.4 Gbps. To operate GX transceiver channels in PCS Direct designated data rates, refer to the *Intel Arria 10 Device Datasheet* for more details on power supply, speed grade, and transceiver configurations requirement.
2. The minimum operational data rate is 1.0 Gbps for both the transmitter and receiver. For transmitter data rates less than 1.0 Gbps, oversampling must be applied at the transmitter. For receiver data rates less than 1.0 Gbps, oversampling must be applied at the receiver.
3. To operate GX transceiver channels with the PCS at designated data rates, refer to the *Intel Arria 10 Device Datasheet* for more details on power supply, speed grade, and transceiver configurations requirement.

#### Related Information

[Intel Arria 10 Device Datasheet](#)

#### 1.2.2.2. The GT Transceiver Channel

The GT transceiver channels are used for supporting data rates from 17.4 Gbps to 25.8 Gbps. The PCS Direct datapath that bypasses all PCS blocks is the primary configuration used to support GT data rates from 17.4 Gbps to 25.8 Gbps. Alternatively, the Enhanced PCS in Basic low latency configuration can also be used to support GT data rates from 17.4 Gbps to 25.8 Gbps. The GT transceiver channels can also be configured as GX transceiver channels. When they are configured as GX transceiver channels, the Standard PCS, Enhanced PCS, and PCIe Gen3 PCS are available and they support data rates from 1.0 Gbps to 17.4 Gbps.

---

<sup>(6)</sup> Applies when operating in reduced power modes. For standard power modes, the Enhanced PCS minimum data rate is 1600 Mbps.

**Figure 17. GT Transceiver Channel in Full Duplex Mode Operating Between 17.4 Gbps and 25.8 Gbps**



Notes:

- (1) The Enhanced PCS must be configured in Basic low latency mode to support data rate range from 17.4 Gbps to 25.8 Gbps.
- (2) The FPGA Fabric - PCS and PCS-PMA interface widths are configurable.
- (3) The Standard PCS and PCIe Gen3 PCS blocks are available when the GT channel is configured as a GX transceiver channel.

**Table 7. PCS Types and Data Rates Supported by GT Channel Configurations**

| GT Channel Configuration | PCS Type      | Data Rates Supported                  |
|--------------------------|---------------|---------------------------------------|
| GT                       | Standard PCS  | Not available for GT configuration    |
|                          | Enhanced PCS  | 17.4 Gbps to 25.8 Gbps <sup>(7)</sup> |
|                          | PCIe Gen3 PCS | Not available for GT configuration    |
| GX                       | Standard PCS  | 1.0 Gbps to 12 Gbps                   |
|                          | Enhanced PCS  | 1.0 Gbps <sup>(8)</sup> to 17.4 Gbps  |
|                          | PCIe Gen3 PCS | 8 Gbps                                |

Note:

1. The GT channels can also operate in PCS Direct configuration for data rates from 1.0 Gbps to 25.8 Gbps. The PCS Direct datapath that bypasses all PCS blocks is the primary configuration used to support GT data rates from 17.4 Gbps to 25.8 Gbps. To operate GX and GT transceiver channels in PCS Direct designated data rates, refer to the *IntelArria 10 Device Datasheet* for more details on power supply, speed grade, and transceiver configurations requirement.
2. The minimum operational data rate is 1.0 Gbps for both the transmitter and receiver. For transmitter data rates less than 1.0 Gbps, oversampling must be applied at the transmitter. For receiver data rates less than 1.0 Gbps, oversampling must be applied at the receiver.
3. To operate GX and GT transceiver channels with the PCS at designated data rates, refer to the *IntelArria 10 Device Datasheet* for more details on power supply, speed grade, and transceiver configurations requirement.

<sup>(7)</sup> The Enhanced PCS must be configured in Basic low latency mode to support data rate range from 17.4 Gbps to 25.8 Gbps.

<sup>(8)</sup> Applies when operating in reduced power modes. For standard power modes, the Enhanced PCS minimum data rate is 1600 Mbps.

### Related Information

[IntelArria 10 Device Datasheet](#)

## 1.2.3. Transceiver Phase-Locked Loops

Each transceiver channel in Arria 10 devices has direct access to three types of high performance PLLs:

- Advanced Transmit (ATX) PLL
- Fractional PLL (fPLL)
- Channel PLL / Clock Multiplier Unit (CMU) PLL.

These transceiver PLLs along with the Master or Local Clock Generation Blocks (CGB) drive the transceiver channels.

### Related Information

[PLLs](#) on page 358

For more information on transceiver PLLs in Arria 10 devices.

### 1.2.3.1. Advanced Transmit (ATX) PLL

An advanced transmit (ATX ) PLL is a high performance PLL. It supports both integer frequency synthesis and coarse resolution fractional frequency synthesis. The ATX PLL is the transceiver channel's primary transmit PLL. It can operate over the full range of supported data rates required for high data rate applications.

### Related Information

- [ATX PLL](#) on page 359  
For more information on ATX PLL.
- [ATX PLL IP Core](#) on page 363  
For details on implementing the ATX PLL IP.

### 1.2.3.2. Fractional PLL (fPLL)

A fractional PLL (fPLL) is an alternate transmit PLL used for generating lower clock frequencies for 12.5 Gbps and lower data rate applications. fPLLs support both integer frequency synthesis and fine resolution fractional frequency synthesis. Unlike the ATX PLL, the fPLL can also be used to synthesize frequencies that can drive the core through the FPGA fabric clock networks.

### Related Information

- [fPLL](#) on page 368  
For more information on fPLL.
- [fPLL IP Core](#) on page 371  
For details on implementing the fPLL IP.

### 1.2.3.3. Channel PLL (CMU/CDR PLL)

A channel PLL resides locally within each transceiver channel. Its primary function is clock and data recovery in the transceiver channel when the PLL is used in clock data recovery (CDR) mode. The channel PLLs of channel 1 and 4 can be used as transmit

PLLs when configured in clock multiplier unit (CMU) mode. The channel PLLs of channel 0, 2, 3, and 5 cannot be configured in CMU mode and therefore cannot be used as transmit PLLs.

#### **Related Information**

- [CMU PLL](#) on page 377  
For more information on CMU PLL.
- [CMU PLL IP Core](#) on page 379  
For information on implementing CMU PLL IP.

### **1.2.4. Clock Generation Block (CGB)**

In Arria 10 devices, there are two types of clock generation blocks (CGBs):

- Master CGB
- Local CGB

Transceiver banks with six transceiver channels have two master CGBs. Master CGB1 is located at the top of the transceiver bank and master CGB0 is located at the bottom of the transceiver bank. Transceiver banks with three channels have only one master CGB. The master CGB divides and distributes bonded clocks to a bonded channel group. It also distributes non-bonded clocks to non-bonded channels across the x6/xN clock network.

Each transceiver channel has a local CGB. The local CGB is used for dividing and distributing non-bonded clocks to its own PCS and PMA blocks.

#### **Related Information**

- [Clock Generation Block](#) on page 393  
For more information on clock generation block.

### **1.3. Calibration**

Arria 10 FPGAs contain a dedicated calibration engine to compensate for process variations. The calibration engine calibrates the analog portion of the transceiver to allow both the transmitter and receiver to operate at optimum performance.

The CLKUSR pin clocks the calibration engine. All transceiver reference clocks and the CLKUSR clock must be free running and stable at the start of FPGA configuration to successfully complete the calibration process and for optimal transceiver performance.

**Note:** For more information about CLKUSR electrical characteristics, refer to *IntelArria 10 Device Datasheet*. The CLKUSR can also be used as an FPGA configuration clock. For information about configuration requirements for the CLKUSR pin, refer to the *Configuration, Design Security, and Remote System Upgrades in Arria 10 Devices* chapter in the *Arria 10 Core Fabric and General-Purpose I/O Handbook*. For more information about calibration, refer to the *Calibration* chapter. For more information about CLKUSR pin requirements, refer to the *IntelArria 10 GX, GT, and SX Device Family Pin Connection Guidelines*.

#### **Related Information**

- [IntelArria 10 Device Datasheet](#)

- Configuration, Design Security, and Remote System Upgrades in Arria 10 Devices
- IntelArria 10 GX, GT, and SX Device Family Pin Connection Guidelines

## 1.4. Intel Arria 10 Transceiver PHY Overview Revision History

| <b>Document Version</b> | <b>Changes</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2018.06.15              | Made the following changes: <ul style="list-style-type: none"> <li>• Changed the data rate range for the Standard PCS in the "PCS types Supported by GX Transceiver Channels" table.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2016.05.02              | Made the following changes: <ul style="list-style-type: none"> <li>• Maximum backplane rate updated from 16.0 Gbps to 12.5 Gbps.</li> <li>• No Backplane support when VCCR/T_GXB=0.95 (Low Power Mode).</li> <li>• Added a footnote to refer to Arria 10 Device datasheet for PCS Types Supported by GX and GT Transceiver Channels.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2016.02.11              | Made the following changes: <ul style="list-style-type: none"> <li>• Changed the "Arria 10 GT Devices with 72 Transceiver Channels and Four PCIe Hard IP Blocks" figure.</li> <li>• Changed the "GT Transceiver Bank Architecture" figure.</li> <li>• Added the "GT Transceiver Bank Architecture for Banks GXBL1E and GXBL1H" figure.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2015.11.02              | Made the following changes: <ul style="list-style-type: none"> <li>• Changed the minimum data rate from 611 Mbps to 1.0 Gbps.</li> <li>• Changed the location of a PCIe Hard IP block in the "Arria 10 GX Devices with 66 Transceiver Channels and Three PCIe Hard IP Blocks" figure.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2015.05.11              | Changed lower limit of supported data rate from 1.0 Gbps to 611 Mbps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2014.12.15              | Made the following changes: <ul style="list-style-type: none"> <li>• Added statement that a 125-Mbps data rate is possible with oversampling in the "Arria 10 Transceiver PHY Overview" section.</li> <li>• Changed the data rate ranges for Standard PCS and Enhanced PCS in the "PCS Types Supported by GX Transceiver Channels" table.</li> <li>• Changed the note in "The GX Transceiver Channel" section.</li> <li>• Changed the data rate ranges for Standard PCS and Enhanced PCS in the "PCS Types and Data Rates Supported by GT Channel Configurations" table.</li> <li>• Added a legend entry to the "Arria 10 GT Devices with 96 Transceiver Channels and Four PCIe Hard IP Blocks" figure.</li> <li>• Added a legend entry to the "Arria 10 GT Devices with 72 Transceiver Channels and Four PCIe Hard IP Blocks" figure.</li> <li>• Added a legend entry to the "Arria 10 GT Devices with 48 Transceiver Channels and Two PCIe Hard IP Blocks" figure.</li> <li>• Changed the note to the "PCS Types and Data Rates Supported by GT Channel Configurations" table.</li> <li>• Changed the Data Rates Supported for GT channel Standard PCS and PCIe Gen3 PCS types in the "PCS Types and Data Rates Supported by GT Channel Configurations" table.</li> <li>• Added a related link to the <a href="#">Arria 10 GX, GT, and SX Device Family Pin Connection Guidelines</a> in the "Calibration" section.</li> </ul> |
| 2014.08.15              | Made the following changes: <ul style="list-style-type: none"> <li>• Changed the maximum data rate for GT channels to 25.8 Gbps.</li> <li>• Changed minimum data rate supported by GT transceiver channels to 1 Gbps from 611 Mbps.</li> <li>• Changed the figure "Arria 10 GX Devices with Six Transceiver Channels and One PCIe Hard IP Block" to add a clarification about PCIe Hard IP block.</li> <li>• Updated the legend for all figures in "Arria 10 GT Device Transceiver Layout" section.</li> <li>• Changed the device package names in Table1-3 and Table 1-4 in "Arria 10 GX and GT Device Package Details Section."</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"><li>• Updated figure "Arria 10 SX Device with 48,36, and 24 Transceiver Channels and Two PCIe Hard IP Blocks.</li><li>• Updated figure "Arria 10 SX Devices with Six Transceiver Channels and One PCIe Hard IP Block" to add a clarification about PCIe Hard IP.</li><li>• Updated the device package names in Table 1-5 in "Arria 10 SX Device Package Details" section.</li><li>• Removed all references of the note about PCS-Direct support available in future release.</li></ul> |
| 2013.12.02       | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

## 2. Implementing Protocols in Arria 10 Transceivers

### 2.1. Transceiver Design IP Blocks

**Figure 18.** Arria 10 Transceiver Design Fundamental Building Blocks



## 2.2. Transceiver Design Flow

**Figure 19. Transceiver Design Flow**

**Note:** The design examples in the FPGA Developer Center provide useful guidance for developing your own design. However, they are not guaranteed by Intel.



### Related Information

[FPGA Developer Center](#)

#### 2.2.1. Select and Instantiate the PHY IP Core

Select the appropriate PHY IP core to implement your protocol.

Refer to the *Arria 10 Transceiver Protocols and PHY IP Support* section to decide which PHY IP to select to implement your protocol.

You can create your Quartus® Prime project first, and then instantiate the various IPs required for your design. In this case, specify the location to save your IP HDL files. The current version of the PHY IP does not have the option to set the speed grade. Specify the device family and speed grade when you create the Quartus Prime project.

You can also instantiate the PHY IP directly to evaluate the various features.

To instantiate a PHY IP:

1. Open the Quartus Prime software.
2. Click **Tools > IP Catalog**.
3. At the top of the **IP Catalog** window, select **Arria 10** device family
4. In **IP Catalog**, under **Library > Interface Protocols**, select the appropriate PHY IP and then click **Add**.
5. In the **New IP Instance Dialog Box**, provide the IP instance name.
6. Select **Arria 10** device family.
7. Select the appropriate device and click **OK**.

The PHY IP Parameter Editor window opens.

**Figure 20.** Arria 10 Transceiver PHY Types

#### Related Information

[Arria 10 Transceiver Protocols and PHY IP Support](#) on page 41

### 2.2.2. Configure the PHY IP Core

Configure the PHY IP core by selecting the valid parameters for your design. The valid parameter settings are different for each protocol. Refer to the appropriate protocol's section for selecting valid parameters for each protocol.

#### Related Information

- [Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45  
For information on Native PHY IP.

- [Interlaken](#) on page 94
- [Gigabit Ethernet \(GbE\) and GbE with IEEE 1588v2](#) on page 112
- [10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC Variants](#) on page 124
- [10GBASE-KR PHY IP Core](#) on page 135
- [1-Gigabit/10-Gigabit Ethernet \(GbE\) PHY IP Core](#) on page 164
- [PCI Express \(PIPE\)](#) on page 236
- [CPRI](#) on page 286
- [Using the "Basic \(Enhanced PCS\)" and "Basic with KR FEC" Configurations of Enhanced PCS](#) on page 296
- [Using the Basic/Custom, Basic/Custom with Rate Match Configurations of Standard PCS](#) on page 307
- [Design Considerations for Implementing Arria 10 GT Channels](#) on page 326

### 2.2.3. Generate the PHY IP Core

After configuring the PHY IP, complete the following steps to generate the PHY IP.

1. Click the **Generate HDL** button in the **Parameter Editor** window. The **Generation** dialog box opens.
2. In **Synthesis** options, under **Create HDL design for synthesis** select Verilog or VHDL.
3. Select appropriate **Simulation** options depending on the choice of the hardware description language you selected under **Synthesis** options.
4. In **Output Directory**, select **Clear output directories for selected generation targets** if you want to clear any previous IP generation files from the selected output directory.
5. Click **Generate**.

The Quartus Prime software generates a *<phy ip instance name>* folder, *<phy ip instance name>\_sim* folder, *<phy ip instance name>.qip* file, *<phy ip instance name>.qsys* file, and *<phy ip instance name>.v* file or *<phy ip instance name>.vhd* file. This *<phy ip instance name>.v* file is the top level design file for the PHY IP and is placed in the *<phy ip instance name>/synth* folder. The other folders contain lower level design files used for simulation and compilation.

#### Related Information

[IP Core File Locations](#) on page 92

For more information about IP core file structure

### 2.2.4. Select the PLL IP Core

Arria 10 devices have three types of PLL IP cores:

- Advanced Transmit (ATX) PLL IP core.
- Fractional PLL (fPLL) IP core.
- Channel PLL / Clock Multiplier Unit (CMU) PLL IP core.

Select the appropriate PLL IP for your design. For additional details, refer to the *PLLs and Clock Networks* chapter.

To instantiate a PLL IP:

1. Open the Quartus Prime software.
2. Click **Tools > IP Catalog**.
3. At the top of the **IP Catalog** window, select **Arria 10** device family
4. In **IP Catalog**, under **Library > Basic Functions > Clocks, PLLs, and Resets > PLL** choose the PLL IP (**Arria 10 fPLL**, **Arria 10 Transceiver ATX PLL**, or **Arria 10 Transceiver CMU PLL**) you want to include in your design and then click **Add**.
5. In the **New IP Instance Dialog Box**, provide the IP instance name.
6. Select **Arria 10** device family.
7. Select the appropriate device and click **OK**.

The PLL IP GUI window opens.

**Figure 21.** Arria 10 Transceiver PLL Types

#### Related Information

[PLLs](#) on page 358

### 2.2.5. Configure the PLL IP Core

Understand the available PLLs, clock networks, and the supported clocking configurations. Configure the PLL IP to achieve the adequate data rate for your design.

#### Related Information

- [ATX PLL IP Core](#) on page 363
- [fPLL IP Core](#) on page 371
- [CMU PLL IP Core](#) on page 379
- [Using PLLs and Clock Networks](#) on page 410

### 2.2.6. Generate the PLL IP Core

After configuring the PLL IP core, complete the following steps to generate the PLL IP core.

1. Click the **Generate HDL** button in the **Parameter Editor** window. The **Generation** dialog box opens.
2. In **Synthesis** options, under **Create HDL design for synthesis** select Verilog or VHDL.
3. Select appropriate **Simulation** options depending on the choice of the hardware description language you selected under **Synthesis** options.
4. In **Output Directory**, select **Clear output directories for selected generation targets** if you want to clear any previous IP generation files from the selected output directory.
5. Click **Generate**.

The Quartus® Prime software generates a *<pll ip core instance name>* folder, *<pll ip core instance name>\_sim* folder, *<pll ip core instance name>.qip* file, *<pll ip core instance name>.qsys*, and *<pll ip core instance name>.v* file or *<pll ip core instance name>.vhdl* file. The *<pll ip core instance name>.v* file is the top level design file for the PLL IP core and is placed in the *<pll ip core instance name>/synth* folder. The other folders contain lower level design files used for simulation and compilation.

#### Related Information

- [IP Core File Locations](#) on page 92  
For more information about IP core file structure

### 2.2.7. Reset Controller

There are two methods to reset the transceivers in Arria 10 devices:

- Use the Transceiver PHY Reset Controller.
- Create your own reset controller that follows the recommended reset sequence.

#### Related Information

- [Resetting Transceiver Channels](#) on page 428

### 2.2.8. Create Reconfiguration Logic

Dynamic reconfiguration is the ability to dynamically modify the transceiver channels and PLL settings during device operation. To support dynamic reconfiguration, your design must include an Avalon master that can access the dynamic reconfiguration registers using the Avalon® memory-mapped interface.

The Avalon memory-mapped interface master enables PLL and channel reconfiguration. You can dynamically adjust the PMA parameters, such as differential output voltage swing ( $V_{od}$ ), and pre-emphasis settings. This adjustment can be done by writing to the Avalon memory-mapped interface reconfiguration registers through the user generated Avalon memory-mapped interface master.

For detailed information on dynamic reconfiguration, refer to *Reconfiguration Interface and Dynamic Reconfiguration* chapter.

#### Related Information

[Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514

### 2.2.9. Connect the PHY IP to the PLL IP Core and Reset Controller

Connect the PHY IP, PLL IP core, and the reset controller. Write the top level module to connect all the IP blocks.

All of the I/O ports for each IP, can be seen in the `<phy instance name>.v` file or `<phy instance name>.vhd`, and in the `<phy_instance_name>_bb.v` file.

For more information about description of the ports, refer to the ports tables in the *PLLs*, *Using the Transceiver Native PHY IP Core*, and *Resetting Transceiver Channels* chapters.

#### Related Information

- [Enhanced PCS Ports](#) on page 77
- [Standard PCS Ports](#) on page 87
- [Resetting Transceiver Channels](#) on page 428
- [Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45
- [PLLs and Clock Networks](#) on page 356

### 2.2.10. Connect Datapath

Connect the transceiver PHY layer design to the Media Access Controller (MAC) IP core or to a data generator / analyzer or a frame generator / analyzer.

### 2.2.11. Make Analog Parameter Settings

Make analog parameter settings to I/O pins using the **Assignment Editor** or updating the Quartus Prime Settings File.

After verifying your design functionality, make pin assignments and PMA analog parameter settings for the transceiver pins.

1. Assign FPGA pins to all the transceiver and reference clock I/O pins. For more details, refer to the *Arria 10 Pin Connection Guidelines*.
2. Set the analog parameters to the transmitter, receiver, and reference clock pins using the **Assignment Editor**.

All of the pin assignments and analog parameters set using the **Pin Planner** and the **Assignment Editor** are saved in the `<top_level_project_name>.qsf` file. You can also directly modify the Quartus Settings File (.qsf) to set PMA analog parameters.

#### Related Information

- [Analog Parameter Settings](#) on page 597
- [Intel Arria 10 GX, GT, and SX Device Family Pin Connection Guidelines](#)

### 2.2.12. Compile the Design

To compile the transceiver design, add the `<phy_instancename>.qip` files for all the IP blocks generated using the IP Catalog to the Quartus Prime project library. You can alternatively add the **.qsys** and **.qip** variants of the IP cores.

**Note:** If you add both the **.qsys** and the **.qip** file into the Quartus Prime project, the software generates an error.

#### Related Information

[Intel Quartus Prime Incremental Compilation for Hierarchical and Team-Based Design](#)  
For more information about compilation details.

### 2.2.13. Verify Design Functionality

Simulate your design to verify the functionality of your design. For more details, refer to *Simulating the Native Transceiver PHY IP Core* section.

#### Related Information

- [Simulating the Transceiver Native PHY IP Core](#) on page 332
- [Quartus Prime Handbook - Volume 3: Verification](#)  
Information about design simulation and verification.

## 2.3. Arria 10 Transceiver Protocols and PHY IP Support

**Table 8. Arria 10 Transceiver Protocols and PHY IP Support**

| Protocol                 | Transceiver PHY IP Core                                           | PCS Support       | Transceiver Configuration Rule <sup>(9)</sup> | Protocol Preset <sup>(10)</sup>        |
|--------------------------|-------------------------------------------------------------------|-------------------|-----------------------------------------------|----------------------------------------|
| PCIe Gen3 x1, x2, x4, x8 | Native PHY IP core (PIPE)/Hard IP for PCI Express <sup>(11)</sup> | Standard and Gen3 | Gen3 PIPE                                     | PCIe PIPE Gen3 x1<br>PCIe PIPE Gen3 x8 |
| PCIe Gen2 x1, x2, x4, x8 | Native PHY IP (PIPE) core/Hard IP for PCI Express <sup>(11)</sup> | Standard          | Gen2 PIPE                                     | PCIe PIPE Gen2 x1<br>PCIe PIPE Gen2 x8 |
| PCIe Gen1 x1, x2, x4, x8 | Native PHY IP (PIPE) core/Hard IP for PCI Express <sup>(11)</sup> | Standard          | Gen1 PIPE                                     | User created                           |

*continued...*

<sup>(9)</sup> For more information about Transceiver Configuration Rules, refer to *Using the Intel Arria 10 Transceiver Native PHY IP Core* section.

<sup>(10)</sup> For more information about Protocol Presets, refer to *Using the Intel Arria 10 Transceiver Native PHY IP Core* section.

<sup>(11)</sup> Hard IP for PCI Express is also available as a separate IP core.

| Protocol                                        | Transceiver PHY IP Core                        | PCS Support             | Transceiver Configuration Rule <sup>(9)</sup> | Protocol Preset <sup>(10)</sup>                             |
|-------------------------------------------------|------------------------------------------------|-------------------------|-----------------------------------------------|-------------------------------------------------------------|
| 1000BASE-X Gigabit Ethernet                     | Native PHY IP core                             | Standard                | GbE                                           | GIGE - 1.25 Gbps                                            |
| 1000BASE-X Gigabit Ethernet with 1588           | Native PHY IP core                             | Standard                | GbE 1588                                      | GIGE - 1.25 Gbps 1588                                       |
| 10GBASE-R                                       | Native PHY IP core                             | Enhanced                | 10GBASE-R                                     | 10GBASE-R Low Latency                                       |
| 10GBASE-R 1588                                  | Native PHY IP core                             | Enhanced                | 10GBASE-R 1588                                | 10GBASE-R 1588                                              |
| 10GBASE-R with KR FEC                           | Native PHY IP core                             | Enhanced                | 10GBASE-R w/KR FEC                            | 10GBASE-R w/KR FEC                                          |
| 10GBASE-KR and 1000BASE-X                       | 1G/10GbE and 10GBASE-KR PHY IP <sup>(12)</sup> | Standard and Enhanced   | Not applicable                                | BackPlane_wo_1588 LineSide (optical) LineSide(optical)_1588 |
| 40GBASE-R                                       | Native PHY IP core                             | Enhanced                | Basic (Enhanced PCS)                          | Low Latency Enhanced PCS <sup>(13)</sup>                    |
| 40GBASE-R with FEC/ 40GBASE-KR4 <sup>(14)</sup> | Native PHY IP core                             | Enhanced                | Basic w/KR FEC                                | User created                                                |
| 100GBASE-R via CAUI-4/CPPI-4/BP and CEI-25G     | Native PHY IP core                             | Enhanced and PCS Direct | Basic (Enhanced PCS) / PCS Direct             | Low Latency GT <sup>(15)</sup>                              |
| 100GBASE-R via CAUI                             | Native PHY IP core                             | Enhanced                | Basic (Enhanced PCS)                          | Low Latency Enhanced PCS <sup>(16)</sup>                    |
| 100GBASE-R via CAUI with FEC                    | Native PHY IP core                             | Enhanced                | Basic w/KR FEC                                | User created                                                |
| XAUI                                            | XAUI PHY IP core                               | Soft PCS                | Not applicable                                | Not applicable                                              |
| SPAUI                                           | Native PHY IP core                             | Standard and Enhanced   | Basic/Custom (Standard PCS)                   | User created                                                |

**continued...**

- 
- (9) For more information about Transceiver Configuration Rules, refer to *Using the Intel Arria 10 Transceiver Native PHY IP Core* section.
  - (10) For more information about Protocol Presets, refer to *Using the Intel Arria 10 Transceiver Native PHY IP Core* section.
  - (12) The 1G/10GbE and 10GBASE-KR PHY IP core includes the necessary soft IP for link training, auto speed negotiation, and sequencer functions.
  - (13) To implement 40GBASE-R using the Low Latency Enhanced PCS preset, change the number of data channels to four and select appropriate PCS- FPGA Fabric and PCS-PMA width.
  - (14) Link training, auto speed negotiation and sequencer functions are not included in the Native PHY IP. The user would have to create soft logic to implement these functions when using Native PHY IP.
  - (15) Low Latency GT protocol preset requires some modification to implement CAUI-4/CPPI-4/BP-4 and CEI-25G.
  - (16) To implement 100GBASE-R via CAUI using the Low Latency Enhanced PCS preset, change the number of data channels to 10 and select appropriate PCS-FPGA Fabric and PCS-PMA width.

| Protocol                                                      | Transceiver PHY IP Core | PCS Support           | Transceiver Configuration Rule <sup>(9)</sup>       | Protocol Preset <sup>(10)</sup>                                                   |
|---------------------------------------------------------------|-------------------------|-----------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------|
|                                                               |                         |                       | Basic (Enhanced PCS)                                |                                                                                   |
| DDR XAUI                                                      | Native PHY IP core      | Standard and Enhanced | Basic/Custom (Standard PCS)<br>Basic (Enhanced PCS) | User created                                                                      |
| Interlaken (CEI-6G/11G) <sup>(17)</sup>                       | Native PHY IP core      | Enhanced              | Interlaken                                          | Interlaken<br>10x12.5Gbps<br>Interlaken<br>6x10.3Gbps<br>Interlaken<br>1x6.25Gbps |
| OTU-4 (100G) via OTL4.10/OIF SFI-S                            | Native PHY IP core      | Enhanced              | Basic (Enhanced PCS)                                | SFI-S 64:64 4x11.3 Gbps <sup>(18)</sup>                                           |
| OTU-3 (40G) via OTL3.4/OIF SFI-5.2/SFI-5.1                    | Native PHY IP core      | Enhanced              | Basic (Enhanced PCS)                                | User created                                                                      |
| OTU-2 (10G) via SFP+/SFF-8431/CEI-11G                         | Native PHY IP core      | Enhanced              | Basic (Enhanced PCS)                                | User created                                                                      |
| OTU-2 (10G) via OIF SFI-5.1s                                  | Native PHY IP core      | Enhanced              | Basic (Enhanced PCS)                                | User created                                                                      |
| OTU-1 (2.7G)                                                  | Native PHY IP core      | Standard              | Basic/Custom (Standard PCS)                         | User created                                                                      |
| SONET/SDH STS-768/STM-256 (40G) via OIF SFI-5.2/STL256.4      | Native PHY IP core      | Enhanced              | Basic (Enhanced PCS)                                | User created                                                                      |
| SONET/SDH STS-768/STM-256 (40G) via OIF SFI-5.1               | Native PHY IP core      | Enhanced              | Basic (Enhanced PCS)                                | User created                                                                      |
| SONET/SDH STS-192/STM-64 (10G) via SFP+/SFF-8431/CEI-11G      | Native PHY IP core      | Enhanced              | Basic (Enhanced PCS)                                | User created                                                                      |
| SONET/SDH STS-192/STM-64 (10G) via OIF SFI-5.1s/Sxi-5/SFI-4.2 | Native PHY IP core      | Enhanced              | Basic (Enhanced PCS)                                | User created                                                                      |
| SONET STS-96 (5G) via OIF SFI-5.1s                            | Native PHY IP core      | Enhanced              | Basic/Custom (Standard PCS)                         | SONET/SDH OC-96                                                                   |

*continued...*

<sup>(9)</sup> For more information about Transceiver Configuration Rules, refer to *Using the Intel Arria 10 Transceiver Native PHY IP Core* section.

<sup>(10)</sup> For more information about Protocol Presets, refer to *Using the Intel Arria 10 Transceiver Native PHY IP Core* section.

<sup>(17)</sup> A Transmit PCS soft bonding logic required for multi-lane bonding configuration is provided in the design example.

<sup>(18)</sup> To implement OTU-4 (100G) via OTL4.10/OIF SFI-S using SFI-S 64:64 4x11.3Gbps preset, change the number of data channels to 10 for OTL4.10 or user desired number of channels and datarate implemented for SFI-S.

| Protocol                                        | Transceiver PHY IP Core            | PCS Support                               | Transceiver Configuration Rule <sup>(9)</sup> | Protocol Preset <sup>(10)</sup> |
|-------------------------------------------------|------------------------------------|-------------------------------------------|-----------------------------------------------|---------------------------------|
| SONET/SDH STS-48/STM-16 (2.5G) via SFP/TFI-5.1  | Native PHY IP core                 | Standard                                  | Basic/Custom (Standard PCS)                   | SONET/SDH OC-48                 |
| SONET/SDH STS-12/STM-4 (0.622G) via SFP/TFI-5.1 | Native PHY IP core <sup>(19)</sup> | Standard                                  | Basic/Custom (Standard PCS)                   | SONET/SDH OC-12                 |
| Intel QPI 1.1/2.0                               | Native PHY IP core                 | PCS Direct                                | PCS Direct                                    | User created                    |
| SD-SDI/HD-SDI/3G-SDI                            | Native PHY IP core                 | Standard                                  | Basic/Custom (Standard PCS)                   | 3G/HD SDI NTSC<br>3G/HD SDI PAL |
| Vx1                                             | Native PHY IP core                 | Standard                                  | Basic/Custom (Standard PCS)                   | User created                    |
| DisplayPort <sup>(20)</sup>                     | Native PHY IP core                 | Standard                                  | Basic/Custom (Standard PCS)                   | User created                    |
| 1.25G/ 2.5G 10G GPON/EPON                       | Native PHY IP core                 | Enhanced                                  | Basic (Enhanced PCS)                          | User created                    |
| 2.5G/1.25G GPON/EPON                            | Native PHY IP core                 | Standard                                  | Basic/Custom (Standard PCS)                   | User created                    |
| 16G/10G Fibre Channel                           | Native PHY IP core                 | Enhanced                                  | Basic (Enhanced PCS)                          | User created                    |
| 8G/4G/2G/1G Fibre Channel                       | Native PHY IP core                 | Standard                                  | Basic/Custom (Standard PCS)                   | User created                    |
| EDR Infiniband x1, x4                           | Native PHY IP core                 | Enhanced (low latency mode)<br>PCS Direct | Basic (Enhanced PCS)<br>PCS Direct            | User created                    |
| FDR/FDR-10 Infiniband x1, x4, x12               | Native PHY IP core                 | Enhanced                                  | Basic (Enhanced PCS)                          | User created                    |
| SDR/DDR/QDR Infiniband x1, x4, x12              | Native PHY IP core                 | Standard                                  | Basic/Custom (Standard PCS)                   | User created                    |
| CPRI v6.1 12.16512/CPRI v6.0 10.1376 Gbps       | Native PHY IP core                 | Enhanced                                  | 10GBASE-R 1588<br>10GBASE-R                   | User created                    |
| CPRI 4.2/OBSAI RP3 v4.2                         | Native PHY IP core                 | Standard                                  | CPRI (Auto) / CPRI (Manual)                   | CPRI 9.8Gbps Auto Mode          |
| <b><i>continued...</i></b>                      |                                    |                                           |                                               |                                 |

- 
- (9) For more information about Transceiver Configuration Rules, refer to *Using the Intel Arria 10 Transceiver Native PHY IP Core* section.
- (10) For more information about Protocol Presets, refer to *Using the Intel Arria 10 Transceiver Native PHY IP Core* section.
- (19) The minimum operational data rate is 1.0 Gbps for both the transmitter and receiver. For transmitter data rates less than 1.0 Gbps, oversampling must be applied at the transmitter. For receiver data rates less than 1.0 Gbps, oversampling must be applied at the receiver.
- (20) To meet DisplayPort TX electrical full compliance to VESA DisplayPort Standard version 1.3 and VESA DisplayPort PHY Compliance Specification version 1.2b , VCCT\_GXB & VCCR\_GXB needs to be 1.03V or higher. Test Refer to AN745: *Design Guidelines for DisplayPort and HDMI Interfaces* for further details.

| Protocol                             | Transceiver PHY IP Core | PCS Support                         | Transceiver Configuration Rule <sup>(9)</sup>                                                                    | Protocol Preset <sup>(10)</sup>             |
|--------------------------------------|-------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------------------------|
|                                      |                         |                                     |                                                                                                                  | CPRI 9.8 Gbps Manual Mode                   |
| SRIO 2.2/1.3                         | Native PHY IP core      | Standard                            | Basic/Custom with Rate Match(Standard PCS)                                                                       | Serial Rapid IO 1.25 Gbps                   |
| SAS 3.0                              | Native PHY IP core      | Enhanced                            | Basic (Enhanced PCS)                                                                                             | User created                                |
| SATA 3.0/2.0/1.0 and SAS 2.0/1.1/1.0 | Native PHY IP core      | Standard                            | Basic/Custom (Standard PCS)                                                                                      | SAS Gen2/Gen1.1/Gen1<br>SATA Gen3/Gen2/Gen1 |
| HiGig/HiGig+/HiGig2/HiGig2+          | Native PHY IP core      | Standard                            | Basic/Custom (Standard PCS)                                                                                      | User created                                |
| JESD204A / JESD204B                  | Native PHY IP core      | Standard and Enhanced               | Basic/Custom (Standard PCS) Basic (Enhanced PCS) <sup>(21)</sup>                                                 | User created                                |
| ASI                                  | Native PHY IP core      | Standard                            | Basic/Custom (Standard PCS)                                                                                      | User created                                |
| SPI-5 (100G) / SPI-5 (50G)           | Native PHY IP core      | Enhanced                            | Basic (Enhanced PCS)                                                                                             | User created                                |
| Custom and other protocols           | Native PHY IP core      | Standard and Enhanced<br>PCS Direct | Basis/Custom (Standard PCS)<br>Basic (Enhanced PCS)<br>Basic/Custom with Rate Match (Standard PCS)<br>PCS Direct | User created                                |

#### Related Information

- Using the Arria 10 Transceiver Native PHY IP Core on page 45
- AN745: Design Guidelines for DisplayPort and HDMI Interfaces

## 2.4. Using the Arria 10 Transceiver Native PHY IP Core

This section describes the use of the Intel-provided Arria 10 Transceiver Native PHY IP core. This Native PHY IP core provides direct access to Arria 10 transceiver PHY features.

Use the Native PHY IP core to configure the transceiver PHY for your protocol implementation. To instantiate the IP, click **Tools > IP Catalog** to select your IP core variation. Use the **Parameter Editor** to specify the IP parameters and configure the PHY IP for your protocol implementation. To quickly configure the PHY IP, select a

---

<sup>(9)</sup> For more information about Transceiver Configuration Rules, refer to *Using the Intel Arria 10 Transceiver Native PHY IP Core* section.

<sup>(10)</sup> For more information about Protocol Presets, refer to *Using the Intel Arria 10 Transceiver Native PHY IP Core* section.

<sup>(21)</sup> For JESD204B, Enhanced PCS is used when the data rate is above 12.0 Gbps

preset that matches your protocol configuration as a starting point. Presets are PHY IP configuration settings for various protocols that are stored in the **IP Parameter Editor**. Presets are explained in detail in the *Presets* section below.

You can also configure the PHY IP by selecting an appropriate **Transceiver Configuration Rule**. The transceiver configuration rules check the valid combinations of the PCS and PMA blocks in the transceiver PHY layer, and report errors or warnings for any invalid settings.

Use the Native PHY IP core to instantiate the following PCS options:

- Standard PCS
- Enhanced PCS
- PCIe Gen3 PCS
- PCS Direct

Based on the Transceiver Configuration Rule that you select, the PHY IP core selects the appropriate PCS. The PHY IP core allows you to select all the PCS blocks if you intend to dynamically reconfigure from one PCS to another. Refer to *General and Datapath Parameters* section for more details on how to enable PCS blocks for dynamic reconfiguration. Refer to the *How to Place Channels for PIPE Configuration* section or the PCIE solutions guides on restrictions on placement of transceiver channels next to active banks with PCI Express interfaces that are Gen3 capable..

After you configure the PHY IP core in the **Parameter Editor**, click **Generate HDL** to generate the IP instance. The top level file generated with the IP instance includes all the available ports for your configuration. Use these ports to connect the PHY IP core to the PLL IP core, the reset controller IP core, and to other IP cores in your design.

**Figure 22. Native PHY IP Core Ports and Functional Blocks**



Figure 23. Native PHY IP Core Parameter Editor



**Note:** Although the Quartus Prime software provides legality checks, the supported FPGA fabric to PCS interface widths and the supported data rates are pending characterization.

### Related Information

- [Configure the PHY IP Core](#) on page 35
- [Interlaken](#) on page 94
- [Gigabit Ethernet \(GbE\) and GbE with IEEE 1588v2](#) on page 112
- [10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC Variants](#) on page 124
- [10GBASE-KR PHY IP Core](#) on page 135
- [1-Gigabit/10-Gigabit Ethernet \(GbE\) PHY IP Core](#) on page 164
- [PCI Express \(PIPE\)](#) on page 236
- [CPRI](#) on page 286
- [Using the "Basic \(Enhanced PCS\)" and "Basic with KR FEC" Configurations of Enhanced PCS](#) on page 296
- [Using the Basic/Custom, Basic/Custom with Rate Match Configurations of Standard PCS](#) on page 307
- [Design Considerations for Implementing Arria 10 GT Channels](#) on page 326
- [PMA Parameters](#) on page 51
- [Presets](#) on page 48
- [General and Datapath Parameters](#) on page 48
- [Enhanced PCS Ports](#) on page 77
- [Standard PCS Ports](#) on page 87
- [PMA Ports](#) on page 73
- [How to Place Channels for Pipe Configuration](#) on page 275

## 2.4.1. Presets

You can select preset settings for the Native PHY IP core defined for each protocol. Use presets as a starting point to specify parameters for your specific protocol or application.

To apply a preset to the Native PHY IP core, double-click on the preset name. When you apply a preset, all relevant options and parameters are set in the current instance of the Native PHY IP core. For example, selecting the **Interlaken** preset enables all parameters and ports that the Interlaken protocol requires.

Selecting a preset does not prevent you from changing any parameter to meet the requirements of your design. Any changes that you make are validated by the design rules for the transceiver configuration rules you specified, not the selected preset.

*Note:* Selecting a preset clears any prior selections user has made so far.

## 2.4.2. General and Datapath Parameters

You can customize your instance of the Native PHY IP core by specifying parameter values. In the **Parameter Editor**, the parameters are organized in the following sections for each functional block and feature:

- General, Common PMA Options, and Datapath Options
- TX PMA
- RX PMA
- Standard PCS
- Enhanced PCS
- PCS Direct Datapath
- Dynamic Reconfiguration
- Analog PMA Settings (Optional)
- Generation Options

**Table 9. General, Common PMA Options, and Datapath Options**

| Parameter                                                | Value                          | Description                                                                                                                                                                                                                                                                               |
|----------------------------------------------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Message level for rule violations</b>                 | <b>error</b><br><b>warning</b> | Specifies the messaging level for parameter rule violations. Selecting <b>error</b> causes all rule violations to prevent IP generation. Selecting <b>warning</b> displays all rule violations as warnings in the message window and allows IP generation despite the violations.<br>(22) |
| VCCR_GXB and VCCT_GXB supply voltage for the Transceiver | 0_9V, 1_0V, 1_1V               | Selects the VCCR_GXB and VCCT_GXB supply voltage for the Transceiver.<br><i>Note:</i> This option is only used for GUI rule validation. Use Quartus Prime Setting File (.qsf) assignments to set this parameter in your static design.                                                    |
| <b>Transceiver Link Type</b>                             | sr, lr                         | Selects the type of transceiver link. sr-Short Reach (Chip-to-chip communication), lr-Long Reach (Backplane communication).                                                                                                                                                               |

*continued...*

(22) Although you can generate the PHY with warnings, you can not compile the PHY in Quartus Prime.

| Parameter                              | Value                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                        |                                                               | <i>Note:</i> This option is only used for GUI rule validation. Use Quartus Prime Setting File (.qsf) assignments to set this parameter in your static design.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Transceiver configuration rules</b> | User Selection                                                | <p>Specifies the valid configuration rules for the transceiver. This parameter specifies the configuration rule against which the <b>Parameter Editor</b> checks your PMA and PCS parameter settings for specific protocols. Depending on the transceiver configuration rule selected, the <b>Parameter Editor</b> validates the parameters and options selected by you and generates error messages or warnings for all invalid settings.</p> <p>To determine the transceiver configuration rule to be selected for your protocol, refer to the "Transceiver Configuration Rule Parameters" table below for more details about each transceiver configuration rule.</p> <p>This parameter is used for rule checking and is not a preset. You need to set all parameters for your protocol implementation.</p> |
| <b>PMA configuration rules</b>         | <b>Basic</b><br><b>SATA/SAS</b><br><b>QPI</b><br><b>GPON</b>  | <p>Specifies the configuration rule for PMA. Select Basic for all other protocol modes except for SATA, GPON, and QPI.</p> <p>SATA (Serial ATA) can be used only if the <b>Transceiver configuration rule</b> is set to <b>Basic/Custom (Standard PCS)</b>.</p> <p>GPON can be used only if the <b>Transceiver configuration rule</b> is set to <b>Basic (Enhanced PCS)</b>.</p> <p>QPI can be used only if the <b>Transceiver configuration rule</b> is set to <b>PCS Direct</b>.</p>                                                                                                                                                                                                                                                                                                                         |
| <b>Transceiver mode</b>                | <b>TX/RX Duplex</b><br><b>TX Simplex</b><br><b>RX Simplex</b> | <p>Specifies the operational mode of the transceiver.</p> <ul style="list-style-type: none"> <li>• <b>TX/RX Duplex</b> : Specifies a single channel that supports both transmission and reception.</li> <li>• <b>TX Simplex</b> : Specifies a single channel that supports only transmission.</li> <li>• <b>RX Simplex</b> : Specifies a single channel that supports only reception.</li> </ul> <p>The default is <b>TX/RX Duplex</b>.</p>                                                                                                                                                                                                                                                                                                                                                                    |
| <b>Number of data channels</b>         | <b>1 - &lt;n&gt;</b>                                          | <p>Specifies the number of transceiver channels to be implemented. The maximum number of channels available, ( &lt;n&gt; ), depends on the package you select.</p> <p>The default value is <b>1</b>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Data rate</b>                       | < valid Transceiver data rate >                               | Specifies the data rate in megabits per second (Mbps).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

*continued...*

| Parameter                                            | Value         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable datapath and interface reconfiguration</b> | <b>On/Off</b> | When you turn this option on, you can preconfigure and dynamically switch between the Standard PCS, Enhanced PCS, and PCS direct datapaths.<br>The default value is <b>Off</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>Enable simplified data interface</b>              | <b>On/Off</b> | By default, all 128-bits are ports for the tx_parallel_data and rx_parallel_data buses are exposed. You must understand the mapping of data and control signals within the interface. Refer to the <i>Enhanced PCS TX and RX Control Ports</i> section for details about mapping of data and control signals.<br>When you turn on this option, the Native PHY IP core presents a simplified data and control interface between the FPGA fabric and transceiver. Only the sub-set of the 128-bits that are active for a particular FPGA fabric width are ports.<br>The default value is <b>Off</b> . <sup>(23)</sup> |
| <b>Provide separate interface for each channel</b>   | <b>On/Off</b> | When selected the Native PHY IP core presents separate data, reset and clock interfaces for each channel rather than a wide bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**Table 10. Transceiver Configuration Rule Parameters**

| Transceiver Configuration Setting                | Description                                                                                                                                                                                                                                            |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Basic/Custom (Standard PCS)</b>               | Enforces a standard set of rules within the Standard PCS. Select these rules to implement custom protocols requiring blocks within the Standard PCS or protocols not covered by the other configuration rules.                                         |
| <b>Basic/Custom w /Rate Match (Standard PCS)</b> | Enforces a standard set of rules including rules for the Rate Match FIFO within the Standard PCS. Select these rules to implement custom protocols requiring blocks within the Standard PCS or protocols not covered by the other configuration rules. |
| <b>CPRI (Auto)</b>                               | Enforces rules required by the CPRI protocol. The receiver word aligner mode is set to <b>Auto</b> . In <b>Auto</b> mode, the word aligner is set to deterministic latency.                                                                            |
| <b>CPRI (Manual)</b>                             | Enforces rules required by the CPRI protocol. The receiver word aligner mode is set to <b>Manual</b> . In <b>Manual</b> mode, logic in the FPGA fabric controls the word aligner.                                                                      |
| <b>GbE</b>                                       | Enforces rules that the 1 Gbps Ethernet (1 GbE) protocol requires.                                                                                                                                                                                     |
| <b>GbE 1588</b>                                  | Enforces rules for the 1 GbE protocol with support for Precision time protocol (PTP) as defined in the <i>IEEE 1588 Standard</i> .                                                                                                                     |
| <b>Gen1 PIPE</b>                                 | Enforces rules for a Gen1 PCIe® PIPE interface that you can connect to a soft MAC and Data Link Layer.                                                                                                                                                 |
| <b>Gen2 PIPE</b>                                 | Enforces rules for a Gen2 PCIe PIPE interface that you can connect to a soft MAC and Data Link Layer.                                                                                                                                                  |
| <b>Gen3 PIPE</b>                                 | Enforces rules for a Gen3 PCIe PIPE interface that you can connect to a soft MAC and Data Link Layer.                                                                                                                                                  |
| <b>Basic (Enhanced PCS)</b>                      | Enforces a standard set of rules within the Enhanced PCS. Select these rules to implement protocols requiring blocks within the Enhanced PCS or protocols not covered by the other configuration rules.                                                |
| <b>Interlaken</b>                                | Enforces rules required by the Interlaken protocol.                                                                                                                                                                                                    |
| <b>10GBASE-R</b>                                 | Enforces rules required by the 10GBASE-R protocol.                                                                                                                                                                                                     |

*continued...*

(23) This option cannot be used, if you intend to dynamically reconfigure between PCS datapaths, or reconfigure the interface of the transceiver.

| Transceiver Configuration Setting | Description                                                                                                                                                                                                                                        |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>10GBASE-R 1588</b>             | Enforces rules required by the 10GBASE-R protocol with 1588 enabled.                                                                                                                                                                               |
| <b>10GBASE-R w/KR FEC</b>         | Enforces rules required by the 10GBASE-R protocol with KR FEC block enabled.                                                                                                                                                                       |
| <b>40GBASE-R w/KR FEC</b>         | Enforces rules required by the 40GBASE-R protocol with the KR FEC block enabled.                                                                                                                                                                   |
| <b>Basic w/KR FEC</b>             | Enforces a standard set of rules required by the Enhanced PCS when you enable the KR FEC block. Select this rule to implement custom protocols requiring blocks within the Enhanced PCS or protocols not covered by the other configuration rules. |
| <b>PCS Direct</b>                 | Enforces rules required by the PCS Direct mode. In this configuration the data flows through the PCS channel, but all the internal PCS blocks are bypassed. If required, the PCS functionality can be implemented in the FPGA fabric.              |

#### Related Information

- [Device Transceiver Layout](#) on page 9
- [Enhanced PCS TX and RX Control Ports](#) on page 83

### 2.4.3. PMA Parameters

You can specify values for the following types of PMA parameters:

#### TX PMA

- TX Bonding Options
- TX PLL Options
- TX PMA Optional Ports

#### RX PMA

- RX CDR Options
- Equalization
- RX PMA Optional Ports

**Table 11. TX Bonding Options**

| Parameter                      | Value                                                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TX channel bonding mode</b> | <b>Not bonded</b><br><b>PMA only bonding</b><br><b>PMA and PCS bonding</b> | Selects the bonding mode to be used for the channels specified. Bonded channels use a single TX PLL to generate a clock that drives multiple channels, reducing channel-to-channel skew. The following options are available:<br><b>Not bonded:</b> In a non-bonded configuration, only the high speed serial clock is expected to be connected from the TX PLL to the Native PHY IP core. The low speed parallel clock is generated by the local clock generation block (CGB) present in the transceiver channel. For non-bonded configurations, because the channels are not related to each other and the feedback path is local to the PLL, the skew between channels cannot be calculated.<br><b>PMA only bonding:</b> In PMA bonding, the high speed serial clock is routed from the transmitter PLL to the master CGB. The master CGB generates the high speed and low parallel clocks and the local CGB for each channel is bypassed. Refer to the <i>Channel Bonding</i> section for more details.<br><b>PMA and PCS bonding:</b> In a PMA and PCS bonded configuration, the local CGB in each channel is bypassed and the parallel clocks generated by the master CGB are used to clock the |

*continued...*

| Parameter                                   | Value                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------------------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |                                                 | <p>network. The master CGB generates both the high and low speed clocks. The master channel generates the PCS control signals and distributes to other channels through a control plane block.</p> <p>The default value is <b>Not bonded</b>. Refer to <i>Channel Bonding</i> section in <i>PLLs and Clock Networks</i> chapter for more details.</p>                                                                |
| <b>PCS TX channel bonding master</b>        | <b>Auto, 0 to &lt;number of channels&gt; -1</b> | <p>Specifies the master PCS channel for PCS bonded configurations. Each Native PHY IP core instance configured with bonding must specify a bonding master. If you select <b>Auto</b>, the Native PHY IP core automatically selects a recommended channel.</p> <p>The default value is <b>Auto</b>. Refer to the <i>PLLs and Clock Networks</i> chapter for more information about the TX channel bonding master.</p> |
| <b>Actual PCS TX channel bonding master</b> | <b>0 to &lt;number of channels&gt; -1</b>       | This parameter is automatically populated based on your selection for the <b>PCS TX channel bonding master</b> parameter. Indicates the selected master PCS channel for PCS bonded configurations.                                                                                                                                                                                                                   |

**Table 12. TX PLL Options**

| Parameter                                        | Value                                                | Description                                                                                                                                                                          |
|--------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TX local clock division factor</b>            | <b>1, 2, 4, 8</b>                                    | Specifies the value of the divider available in the transceiver channels to divide the TX PLL output clock to generate the correct frequencies for the parallel and serial clocks.   |
| <b>Number of TX PLL clock inputs per channel</b> | <b>1, 2, 3 , 4</b>                                   | Specifies the number of TX PLL clock inputs per channel. Use this parameter when you plan to dynamically switch between TX PLL clock sources. Up to four input sources are possible. |
| <b>Initial TX PLL clock input selection</b>      | <b>0 to &lt;number of TX PLL clock inputs&gt; -1</b> | Specifies the initially selected TX PLL clock input. This parameter is necessary when you plan to switch between multiple TX PLL clock inputs.                                       |

**Table 13. TX PMA Optional Ports**

| Parameter                                  | Value         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable tx_pma_analog_reset_ack port</b> | <b>On/Off</b> | Enables the optional <code>tx_pma_analog_reset_ack</code> output port. This port should not be used for register mode data transfers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>Enable tx_pma_clkout port</b>           | <b>On/Off</b> | Enables the optional <code>tx_pma_clkout</code> output clock. This is the low speed parallel clock from the TX PMA. The source of this clock is the serializer. It is driven by the PCS/PMA interface block. <sup>(24)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>Enable tx_pma_div_clkout port</b>       | <b>On/Off</b> | <p>Enables the optional <code>tx_pma_div_clkout</code> output clock. This clock is generated by the serializer. You can use this to drive core logic, to drive the FPGA - transceivers interface.</p> <p>Data rate must be equal or higher than 5 Gbps to enable the use of this clock port.</p> <p>If you select a <b>tx_pma_div_clkout division factor</b> of 1 or 2, this clock output is derived from the PMA parallel clock. If you select a <b>tx_pma_div_clkout division factor</b> of 33, 40, or 66, this clock is derived from the PMA high serial clock. This clock is commonly used when the interface to the TX FIFO runs at a different rate than the PMA parallel clock frequency, such as 66:40 applications.</p> |

continued...

<sup>(24)</sup> This clock should not be used to clock the FPGA - transceivers interface. This clock may be used as a reference clock to an external clock cleaner.

| Parameter                                  | Value                             | Description                                                                                                                                                                                                                                                                                                  |
|--------------------------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>tx_pma_div_clkout division factor</b>   | <b>Disabled, 1, 2, 33, 40, 66</b> | Selects the division factor for the tx_pma_div_clkout output clock when enabled. <sup>(25)</sup>                                                                                                                                                                                                             |
| <b>Enable tx_pma_iqtxrx_clkout port</b>    | <b>On/Off</b>                     | Enables the optional tx_pma_iqtxrx_clkout output clock. This clock can be used to cascade the TX PMA output clock to the input of a PLL.                                                                                                                                                                     |
| <b>Enable tx_pma_elecidle port</b>         | <b>On/Off</b>                     | Enables the tx_pma_elecidle port. When you assert this port, the transmitter is forced into an electrical idle condition. This port has no effect when the transceiver is configured for PCI Express.                                                                                                        |
| <b>Enable tx_pma_qpipullup port (QPI)</b>  | <b>On/Off</b>                     | Enables the tx_pma_qpipullup control input port. Use this port only for Quick Path Interconnect (QPI) applications.                                                                                                                                                                                          |
| <b>Enable tx_pma_qpipulldn port (QPI)</b>  | <b>On/Off</b>                     | Enables the tx_pma_qpipulldn control input port. Use this port only for QPI applications.                                                                                                                                                                                                                    |
| <b>Enable tx_pma_txdetectrx port (QPI)</b> | <b>On/Off</b>                     | Enables the tx_pma_txdetectrx control input port. The receiver detect block in the TX PMA detects the presence of a receiver at the other end of the channel. After receiving a tx_pma_txdetectrx request the receiver detect block initiates the detection process. Use this port only in QPI applications. |
| <b>Enable tx_pma_rxfound port (QPI)</b>    | <b>On/Off</b>                     | Enables the tx_pma_rxfound status output port. The receiver detect block in TX PMA detects the presence of a receiver at the other end by using the tx_pma_txdetectrx input. The tx_pma_rxfound port reports the status of the detection operation. Use this port only in QPI applications.                  |
| <b>Enable rx_serialpbken port</b>          | <b>On/Off</b>                     | Enables the optional rx_serialpbken control input port. The assertion of this signal enables the TX to RX serial loopback path within the transceiver. This is an asynchronous input signal.                                                                                                                 |

**Table 14. RX CDR Options**

| Parameter                                     | Value                                                 | Description                                                                                                                                                                                       |
|-----------------------------------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Number of CDR reference clocks</b>         | <b>1 - 5</b>                                          | Specifies the number of CDR reference clocks. Up to 5 sources are possible.<br>The default value is 1.<br>Use this feature when you want to dynamically re-configure CDR reference clock source.  |
| <b>Selected CDR reference clock</b>           | <b>0 to &lt;number of CDR reference clocks&gt; -1</b> | Specifies the initial CDR reference clock. This parameter determines the available CDR references used.<br>The default value is 0.                                                                |
| <b>Selected CDR reference clock frequency</b> | <b>&lt; data rate dependent &gt;</b>                  | Specifies the CDR reference clock frequency. This value depends on the data rate specified.                                                                                                       |
| <b>PPM detector threshold</b>                 | <b>100<br/>300<br/>500<br/>1000</b>                   | Specifies the PPM threshold for the CDR. If the PPM between the incoming serial data and the CDR reference clock, exceeds this threshold value, the CDR loses lock.<br>The default value is 1000. |

<sup>(25)</sup> The default value is **Disabled**.

**Table 15. Equalization**

| Parameters                      | Value                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CTLE adaptation mode</b>     | <b>Manual</b>                                  | <p>Specifies the Continuous Time Linear Equalization (CTLE) operation mode.</p> <p>For manual mode, set the CTLE options through the Assignment Editor, or modify the Quartus Settings File (.qsf), or write to the reconfiguration registers using the Avalon Memory-Mapped interface.</p> <p>Refer to <a href="#">Continuous Time Linear Equalization (CTLE)</a> on page 464 section in <i>Arria 10 Transceiver Architecture</i> chapter for more details about CTLE architecture. Refer to <a href="#">How to Enable CTLE and DFE</a> on page 468 for more details on supported adaptation modes.</p>                                                                                |
| <b>DFE adaptation mode</b>      | <b>Adaptation enabled<br/>Manual, Disabled</b> | <p>Specifies the operating mode for the <i>Decision Feedback Equalization</i> (DFE) block in the RX PMA.</p> <p>The default value is <b>Disabled</b>.</p> <p>For manual mode, you can set the DFE options through the Assignment Editor, or by modifying the Quartus Settings File (.qsf), or write to the reconfiguration registers using the Avalon memory-mapped interface.</p> <p>Refer to the <a href="#">Decision Feedback Equalization (DFE)</a> on page 466 section in the <i>Arria 10 Transceiver PHY Architecture</i> chapter for more details about DFE. Refer to <a href="#">How to Enable CTLE and DFE</a> on page 468 for more details on supported adaptation modes.</p> |
| <b>Number of fixed DFE taps</b> | <b>3, 7 , 11</b>                               | Specifies the number of fixed DFE taps. Select the number of taps depending on the loss in your transmission channel and the type of equalization required.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**Table 16. RX PMA Optional Ports**

| Parameters                               | Value                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable rx_analog_reset_ack port</b>   | <b>On/Off</b>                     | Enables the optional <code>rx_analog_reset_ack</code> output. This port should not be used for register mode data transfers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>Enable rx_pma_clkout port</b>         | <b>On/Off</b>                     | Enables the optional <code>rx_pma_clkout</code> output clock. This port is the recovered parallel clock from the RX clock data recovery (CDR). <sup>(26)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>Enable rx_pma_div_clkout port</b>     | <b>On/Off</b>                     | <p>Enables the optional <code>rx_pma_div_clkout</code> output clock. The deserializer generates this clock. Use this to drive core logic, to drive the RX PCS-to-FPGA fabric interface, or both.</p> <p>If you select a <code>rx_pma_div_clkout</code> division factor of 1 or 2, this clock output is derived from the PMA parallel clock. If you select a <code>rx_pma_div_clkout</code> division factor of 33, 40, or 66, this clock is derived from the PMA serial clock. This clock is commonly used when the interface to the RX FIFO runs at a different rate than the PMA parallel clock frequency, such as 66:40 applications.</p> |
| <b>rx_pma_div_clkout division factor</b> | <b>Disabled, 1, 2, 33, 40, 66</b> | Selects the division factor for the <code>rx_pma_div_clkout</code> output clock when enabled. <sup>(27)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>Enable rx_pma_iqtxrx_clkout port</b>  | <b>On/Off</b>                     | Enables the optional <code>rx_pma_iqtxrx_clkout</code> output clock. This clock can be used to cascade the RX PMA output clock to the input of a PLL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

*continued...*

(26) This clock should not be used to clock the FPGA - transceiver interface. This clock may be used as a concept clock to an external clock cleaner.

(27) The default value is **Disabled**.

| Parameters                                                                       | Value         | Description                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------------------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable rx_pma_clkslip port</b>                                                | <b>On/Off</b> | Enables the optional <code>rx_pma_clkslip</code> control input port. This signal can be used for word alignment. A falling edge on this signal makes the RX deserializer bit slip the serial data by one unit interval (UI). In rare cases, a two UI slip can occur. When this happens and word alignment detection is not completed, continue slipping until the word alignment detection completes. |
| <b>Enable rx_pma_qpipulldn port (QPI)</b>                                        | <b>On/Off</b> | Enables the <code>rx_pma_qpipulldn</code> control input port. Use this port only for QPI applications.                                                                                                                                                                                                                                                                                                |
| <b>Enable rx_is_lockedtodata port</b>                                            | <b>On/Off</b> | Enables the optional <code>rx_is_lockedtodata</code> status output port. This signal indicates that the RX CDR is currently in lock to data mode or is attempting to lock to the incoming data stream. This is an asynchronous output signal.                                                                                                                                                         |
| <b>Enable rx_is_lockedtoref port</b>                                             | <b>On/Off</b> | Enables the optional <code>rx_is_lockedtoref</code> status output port. This signal indicates that the RX CDR is currently locked to the CDR reference clock. This is an asynchronous output signal.                                                                                                                                                                                                  |
| <b>Enable rx_set_lockedtodata port and rx_set_lockedtoref ports</b>              | <b>On/Off</b> | Enables the optional <code>rx_set_lockedtodata</code> and <code>rx_set_lockedtoref</code> control input ports. You can use these control ports to manually control the lock mode of the RX CDR. These are asynchronous input signals.                                                                                                                                                                 |
| <b>Enable rx_serialpbken port</b>                                                | <b>On/Off</b> | Enables the optional <code>rx_serialpbken</code> control input port. The assertion of this signal enables the TX to RX serial loopback path within the transceiver. This is an asynchronous input signal.                                                                                                                                                                                             |
| <b>Enable PRBS (Pseudo Random Bit Sequence) verifier control and status port</b> | <b>On/Off</b> | Enables the optional <code>rx_prbs_err</code> , <code>rx_prbs_clr</code> , and <code>rx_prbs_done</code> control ports. These ports control and collect status from the internal PRBS verifier.                                                                                                                                                                                                       |

#### Related Information

- [PLLs and Clock Networks](#) on page 356
- [Channel Bonding](#) on page 399
- [Continuous Time Linear Equalization \(CTLE\)](#) on page 464
- [Decision Feedback Equalization \(DFE\)](#) on page 466
- [Analog Parameter Settings](#) on page 597
- [How to Enable CTLE and DFE](#) on page 468

#### 2.4.4. Enhanced PCS Parameters

This section defines parameters available in the Native PHY IP core GUI to customize the individual blocks in the Enhanced PCS.

The following tables describe the available parameters. Based on the selection of the **Transceiver Configuration Rule**, if the specified settings violate the protocol standard, the Native PHY IP core **Parameter Editor** prints error or warning messages.

**Note:** For detailed descriptions about the optional ports that you can enable or disable, refer to the *Enhanced PCS Ports* section.

**Table 17. Enhanced PCS Parameters**

| Parameter                                        | Range                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enhanced PCS / PMA interface width</b>        | <b>32, 40, 64</b>           | Specifies the interface width between the Enhanced PCS and the PMA.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>FPGA fabric /Enhanced PCS interface width</b> | <b>32, 40, , 64, 66, 67</b> | Specifies the interface width between the Enhanced PCS and the FPGA fabric.<br>The 66-bit FPGA fabric to PCS interface width uses 64-bits from the TX and RX parallel data. The block synchronizer determines the block boundary of the 66-bit word, with lower 2 bits from the control bus.<br>The 67-bit FPGA fabric to PCS interface width uses the 64-bits from the TX and RX parallel data. The block synchronizer determines the block boundary of the 67-bit word with lower 3 bits from the control bus. |
| <b>Enable Enhanced PCS low latency mode</b>      | <b>On/Off</b>               | Enables the low latency path for the Enhanced PCS. When you turn on this option, the individual functional blocks within the Enhanced PCS are bypassed to provide the lowest latency path from the PMA through the Enhanced PCS. When enabled, this mode is applicable for GX devices. Intel recommends not enabling it for GT devices.                                                                                                                                                                          |
| <b>Enable RX/TX FIFO double width mode</b>       | <b>On/Off</b>               | Enables the double width mode for the RX and TX FIFOs. You can use double width mode to run the FPGA fabric at half the frequency of the PCS.                                                                                                                                                                                                                                                                                                                                                                    |

**Table 18. Enhanced PCS TX FIFO Parameters**

| Parameter                               | Range                                                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TX FIFO Mode</b>                     | <b>Phase-Compensation Register Interlaken Basic Fast Register</b> | Specifies one of the following modes: <ul style="list-style-type: none"> <li><b>Phase Compensation:</b> The TX FIFO compensates for the clock phase difference between the read clock <code>rx_clkout</code> and the write clocks <code>tx_coreclkin</code> or <code>tx_clkout</code>. You can tie <code>tx_enh_data_valid</code> to 1'b1.</li> <li><b>Register:</b> The TX FIFO is bypassed. The <code>tx_parallel_data</code>, <code>tx_control</code> and <code>tx_enh_data_valid</code> are registered at the FIFO output. Assert <code>tx_enh_data_valid</code> port 1'b1 at all times. The user must connect the write clock <code>tx_coreclkin</code> to the read clock <code>tx_clkout</code>.</li> <li><b>Interlaken:</b> The TX FIFO acts as an elastic buffer. In this mode, there are additional signals to control the data flow into the FIFO. Therefore, the FIFO write clock frequency does not have to be the same as the read clock frequency. You can control writes to the FIFO with <code>tx_enh_data_valid</code>. By monitoring the FIFO flags, you can avoid the FIFO full and empty conditions. The Interlaken frame generator controls reads.</li> <li><b>Basic:</b> The TX FIFO acts as an elastic buffer. This mode allows driving write and read side of FIFO with different clock frequencies. <code>tx_coreclkin</code> or <code>rx_coreclkin</code> must have a minimum frequency of the lane data rate divided by 66. The frequency range for <code>tx_coreclkin</code> or <code>rx_coreclkin</code> is <math>(\text{data rate}/32) - (\text{data rate}/66)</math>. For best results, Intel recommends that <code>tx_coreclkin</code> or <code>rx_coreclkin</code> = <math>(\text{data rate}/32)</math>. Monitor FIFO flag to control write and read operations. For additional details refer to <a href="#">Enhanced PCS FIFO Operation</a> on page 304 section</li> <li><b>Fast Register:</b> The TX FIFO allows a higher maximum frequency (<math>f_{MAX}</math>) between the FPGA fabric and the TX PCS at the expense of higher latency.</li> </ul> |
| <b>TX FIFO partially full threshold</b> | <b>10, 11, 12, 13</b>                                             | Specifies the partially full threshold for the Enhanced PCS TX FIFO. Enter the value at which you want the TX FIFO to flag a partially full status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

*continued...*

| Parameter                                | Range             | Description                                                                                                                                                                                    |
|------------------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TX FIFO partially empty threshold</b> | <b>2, 3, 4, 5</b> | Specifies the partially empty threshold for the Enhanced PCS TX FIFO. Enter the value at which you want the TX FIFO to flag a partially empty status.                                          |
| <b>Enable tx_enh_fifo_full port</b>      | <b>On / Off</b>   | Enables the <b>tx_enh_fifo_full port</b> . This signal indicates when the TX FIFO is full. This signal is synchronous to <code>tx_coreclkin</code> .                                           |
| <b>Enable tx_enh_fifo_pfull port</b>     | <b>On / Off</b>   | Enables the <b>tx_enh_fifo_pfull port</b> . This signal indicates when the TX FIFO reaches the specified partially full threshold. This signal is synchronous to <code>tx_coreclkin</code> .   |
| <b>Enable tx_enh_fifo_empty port</b>     | <b>On / Off</b>   | Enables the <b>tx_enh_fifo_empty port</b> . This signal indicates when the TX FIFO is empty. This signal is synchronous to <code>tx_coreclkin</code> .                                         |
| <b>Enable tx_enh_fifo_pempty port</b>    | <b>On / Off</b>   | Enables the <b>tx_enh_fifo_pempty port</b> . This signal indicates when the TX FIFO reaches the specified partially empty threshold. This signal is synchronous to <code>tx_coreclkin</code> . |

**Table 19. Enhanced PCS RX FIFO Parameters**

| Parameter                                                  | Range                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RX FIFO Mode</b>                                        | <b>Phase-Compensation Register Interlaken 10GBASE-R Basic</b> | <p>Specifies one of the following modes for Enhanced PCS RX FIFO:</p> <ul style="list-style-type: none"> <li><b>Phase Compensation</b>: This mode compensates for the clock phase difference between the read clocks <code>rx_coreclkin</code> or <code>tx_clkout</code> and the write clock <code>rx_clkout</code>.</li> <li><b>Register</b> : The RX FIFO is bypassed. The <code>rx_parallel_data</code>, <code>rx_control</code>, and <code>rx_enh_data_valid</code> are registered at the FIFO output. The FIFO's read clock <code>rx_coreclkin</code> and write clock <code>rx_clkout</code> are tied together.</li> <li><b>Interlaken</b>: Select this mode for the Interlaken protocol. To implement the deskew process, you must implement an FSM that controls the FIFO operation based on FIFO flags. In this mode the FIFO acts as an elastic buffer.</li> <li><b>10GBASE-R</b>: In this mode, data passes through the FIFO after block lock is achieved. OS (Ordered Sets) are deleted and Idles are inserted to compensate for the clock difference between the RX PMA clock and the fabric clock of +/- 100 ppm for a maximum packet length of 64000 bytes.</li> <li><b>Basic</b>: In this mode, the RX FIFO acts as an elastic buffer. This mode allows driving write and read side of FIFO with different clock frequencies. <code>tx_coreclkin</code> or <code>rx_coreclkin</code> must have a minimum frequency of the lane data rate divided by 66. The frequency range for <code>tx_coreclkin</code> or <code>rx_coreclkin</code> is <math>(\text{data rate}/32) - (\text{data rate}/66)</math>. The gearbox data valid flag controls the FIFO read enable. You can monitor the <code>rx_enh_fifo_pfull</code> and <code>rx_enh_fifo_empty</code> flags to determine whether or not to read from the FIFO. For additional details refer to <a href="#">Enhanced PCS FIFO Operation</a> on page 304.</li> </ul> <p><i>Note:</i> The flags are for Interlaken and Basic modes only. They should be ignored in all other cases.</p> |
| <b>RX FIFO partially full threshold</b>                    | 18-29                                                         | Specifies the partially full threshold for the Enhanced PCS RX FIFO. The default value is 23.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>RX FIFO partially empty threshold</b>                   | 2-10                                                          | Specifies the partially empty threshold for the Enhanced PCS RX FIFO. The default value is 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>Enable RX FIFO alignment word deletion (Interlaken)</b> | <b>On / Off</b>                                               | When you turn on this option, all alignment words (sync words), including the first sync word, are removed after frame synchronization is achieved. If you enable this option, you must also enable control word deletion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

*continued...*

| Parameter                                                | Range           | Description                                                                                                                                                                                                                                                                                                           |
|----------------------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable RX FIFO control word deletion (Interlaken)</b> | <b>On / Off</b> | When you turn on this option, Interlaken control word removal is enabled. When the Enhanced PCS RX FIFO is configured in <b>Interlaken</b> mode, enabling this option, removes all control words after frame synchronization is achieved. Enabling this option requires that you also enable alignment word deletion. |
| <b>Enable rx_enh_data_valid port</b>                     | <b>On / Off</b> | Enables the <b>rx_enh_data_valid port</b> . This signal indicates when RX data from RX FIFO is valid. This signal is synchronous to <b>rx_coreclk</b> .                                                                                                                                                               |
| <b>Enable rx_enh_fifo_full port</b>                      | <b>On / Off</b> | Enables the <b>rx_enh_fifo_full port</b> . This signal indicates when the RX FIFO is full. This is an asynchronous signal.                                                                                                                                                                                            |
| <b>Enable rx_enh_fifo_pfull port</b>                     | <b>On / Off</b> | Enables the <b>rx_enh_fifo_pfull port</b> . This signal indicates when the RX FIFO has reached the specified partially full threshold. This is an asynchronous signal.                                                                                                                                                |
| <b>Enable rx_enh_fifo_empty port</b>                     | <b>On / Off</b> | Enables the <b>rx_enh_fifo_empty port</b> . This signal indicates when the RX FIFO is empty. This signal is synchronous to <b>rx_coreclk</b> .                                                                                                                                                                        |
| <b>Enable rx_enh_fifo_pempty port</b>                    | <b>On / Off</b> | Enables the <b>rx_enh_fifo_pempty port</b> . This signal indicates when the RX FIFO has reached the specified partially empty threshold. This signal is synchronous to <b>rx_coreclk</b> .                                                                                                                            |
| <b>Enable rx_enh_fifo_del port (10GBASE-R)</b>           | <b>On / Off</b> | Enables the optional <b>rx_enh_fifo_del status output port</b> . This signal indicates when a word has been deleted from the rate match FIFO. This signal is only used for 10GBASE-R transceiver configuration rule. This is an asynchronous signal.                                                                  |
| <b>Enable rx_enh_fifo_insert port (10GBASE-R)</b>        | <b>On / Off</b> | Enables the <b>rx_enh_fifo_insert port</b> . This signal indicates when a word has been inserted into the rate match FIFO. This signal is only used for 10GBASE-R transceiver configuration rule. This signal is synchronous to <b>rx_coreclk</b> .                                                                   |
| <b>Enable rx_enh_fifo_rd_en port</b>                     | <b>On / Off</b> | Enables the <b>rx_enh_fifo_rd_en input port</b> . This signal is enabled to read a word from the RX FIFO. This signal is synchronous to <b>rx_coreclk</b> .                                                                                                                                                           |
| <b>Enable rx_enh_fifo_align_val port (Interlaken)</b>    | <b>On / Off</b> | Enables the <b>rx_enh_fifo_align_val status output port</b> . Only used for Interlaken transceiver configuration rule. This signal is synchronous to <b>rx_clkout</b> .                                                                                                                                               |
| <b>Enable rx_enh_fifo_align_clr port (Interlaken)</b>    | <b>On / Off</b> | Enables the <b>rx_enh_fifo_align_clr input port</b> . Only used for Interlaken. This signal is synchronous to <b>rx_clkout</b> .                                                                                                                                                                                      |

**Table 20. Interlaken Frame Generator Parameters**

| Parameter                                   | Range           | Description                                                                                                                                                      |
|---------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable Interlaken frame generator</b>    | <b>On / Off</b> | Enables the frame generator block of the Enhanced PCS.                                                                                                           |
| <b>Frame generator metaframe length</b>     | 5-8192          | Specifies the metaframe length of the frame generator. This metaframe length includes 4 framing control words created by the frame generator.                    |
| <b>Enable Frame Generator Burst Control</b> | <b>On / Off</b> | Enables frame generator burst. This determines whether the frame generator reads data from the TX FIFO based on the input of port <b>tx_enh_frame_burst_en</b> . |

*continued...*

| Parameter                                   | Range           | Description                                                                                                                                                                                                                                  |
|---------------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable tx_enh_frame_port</b>             | <b>On / Off</b> | Enables the tx_enh_frame status output port. When the Interlaken frame generator is enabled, this signal indicates the beginning of a new metaframe. This is an asynchronous signal.                                                         |
| <b>Enable tx_enh_frame_diag_status_port</b> | <b>On / Off</b> | Enables the tx_enh_frame_diag_status 2-bit input port. When the Interlaken frame generator is enabled, the value of this signal contains the status message from the framing layer diagnostic word. This signal is synchronous to tx_clkout. |
| <b>Enable tx_enh_frame_burst_en_port</b>    | <b>On / Off</b> | Enables the tx_enh_frame_burst_en input port. When burst control is enabled for the Interlaken frame generator, this signal is asserted to control the frame generator data reads from the TX FIFO. This signal is synchronous to tx_clkout. |

**Table 21. Interlaken Frame Synchronizer Parameters**

| Parameter                                   | Range           | Description                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable Interlaken frame synchronizer</b> | <b>On / Off</b> | When you turn on this option, the Enhanced PCS frame synchronizer is enabled.                                                                                                                                                                                                                                                    |
| <b>Frame synchronizer metaframe length</b>  | 5-8192          | Specifies the metaframe length of the frame synchronizer.                                                                                                                                                                                                                                                                        |
| <b>Enable rx_enh_frame_port</b>             | <b>On / Off</b> | Enables the <b>rx_enh_frame_status_output_port</b> . When the Interlaken frame synchronizer is enabled, this signal indicates the beginning of a new metaframe. This is an asynchronous signal.                                                                                                                                  |
| <b>Enable rx_enh_frame_lock_port</b>        | <b>On / Off</b> | Enables the <b>rx_enh_frame_lock_output_port</b> . When the Interlaken frame synchronizer is enabled, this signal is asserted to indicate that the frame synchronizer has achieved metaframe delineation. This is an asynchronous output signal.                                                                                 |
| <b>Enable rx_enh_frame_diag_status_port</b> | <b>On / Off</b> | Enables the <b>rx_enh_frame_diag_status_output_port</b> . When the Interlaken frame synchronizer is enabled, this signal contains the value of the framing layer diagnostic word (bits [33:32]). This is a 2 bit per lane output signal. It is latched when a valid diagnostic word is received. This is an asynchronous signal. |

**Table 22. Interlaken CRC32 Generator and Checker Parameters**

| Parameter                                                    | Range           | Description                                                                                                                                                                                                                                                                                                                                           |
|--------------------------------------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable Interlaken TX CRC-32 Generator</b>                 | <b>On / Off</b> | When you turn on this option, the TX Enhanced PCS datapath enables the CRC32 generator function. CRC32 can be used as a diagnostic tool. The CRC contains the entire metaframe including the diagnostic word.                                                                                                                                         |
| <b>Enable Interlaken TX CRC-32 generator error insertion</b> | <b>On / Off</b> | When you turn on this option, the error insertion of the interlaken CRC-32 generator is enabled. Error insertion is cycle-accurate. When this feature is enabled, the assertion of tx_control[8] or tx_err_ins signal causes the CRC calculation during that word is incorrectly inverted, and thus, the CRC created for that metaframe is incorrect. |
| <b>Enable Interlaken RX CRC-32 checker</b>                   | <b>On / Off</b> | Enables the CRC-32 checker function.                                                                                                                                                                                                                                                                                                                  |
| <b>Enable rx_enh_crc32_err_port</b>                          | <b>On / Off</b> | When you turn on this option, the Enhanced PCS enables the <b>rx_enh_crc32_err_port</b> . This signal is asserted to indicate that the CRC checker has found an error in the current metaframe. This is an asynchronous signal.                                                                                                                       |

**Table 23. 10GBASE-R BER Checker Parameters**

| Parameter                                              | Range           | Description                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable rx_enh_highber port (10GBASE-R)</b>          | <b>On / Off</b> | Enables the <b>rx_enh_highber port</b> . For 10GBASE-R transceiver configuration rule, this signal is asserted to indicate a bit error rate higher than $10^{-4}$ . Per the 10GBASE-R specification, this occurs when there are at least 16 errors within 125 $\mu$ s. This is an asynchronous signal.                                                                                                               |
| <b>Enable rx_enh_highber_clr_cnt port (10GBASE-R)</b>  | <b>On / Off</b> | Enables the <b>rx_enh_highber_clr_cnt input port</b> . For the 10GBASE-R transceiver configuration rule, this signal is asserted to clear the internal counter. This counter indicates the number of times the BER state machine has entered the "BER_BAD_SH" state. This is an asynchronous signal.                                                                                                                 |
| <b>Enable rx_enh_clr_errblk_count port (10GBASE-R)</b> | <b>On / Off</b> | Enables the <b>rx_enh_clr_errblk_count input port</b> . For the 10GBASE-R transceiver configuration rule, this signal is asserted to clear the internal counter. This counter indicates the number of the times the RX state machine has entered the RX_E state. For protocols with FEC block enabled, this signal is asserted to reset the status counters within the RX FEC block. This is an asynchronous signal. |

**Table 24. 64b/66b Encoder and Decoder Parameters**

| Parameter                                    | Range           | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable TX 64b/66b encoder (10GBASE-R)</b> | <b>On / Off</b> | When you turn on this option, the Enhanced PCS enables the TX 64b/66b encoder.                                                                                                                                                                                                                                                                                                                                                     |
| <b>Enable RX 64b/66b decoder (10GBASE-R)</b> | <b>On / Off</b> | When you turn on this option, the Enhanced PCS enables the RX 64b/66b decoder.                                                                                                                                                                                                                                                                                                                                                     |
| <b>Enable TX sync header error insertion</b> | <b>On / Off</b> | When you turn on this option, the Enhanced PCS supports cycle-accurate error creation to assist in exercising error condition testing on the receiver. When error insertion is enabled and the error flag is set, the encoding sync header for the current word is generated incorrectly. If the correct sync header is 2'b01 (control type), 2'b00 is encoded. If the correct sync header is 2'b10 (data type), 2'b11 is encoded. |

**Table 25. Scrambler and Descrambler Parameters**

| Parameter                                           | Range                       | Description                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable TX scrambler (10GBASE-R/Interlaken)</b>   | <b>On / Off</b>             | Enables the scrambler function. This option is available for the Basic (Enhanced PCS) mode, Interlaken, and 10GBASE-R protocols. You can enable the scrambler in Basic (Enhanced PCS) mode when the block synchronizer is enabled and with 66:32, 66:40, or 66:64 gear box ratios.                                                                        |
| <b>TX scrambler seed (10GBASE-R/Interlaken)</b>     | User-specified 58-bit value | You must provide a non-zero seed for the Interlaken protocol. For a multi-lane Interlaken Transceiver Native PHY IP, the first lane scrambler has this seed. For other lanes' scrambler, this seed is increased by 1 per each lane. The initial seed for 10GBASE-R is 0x03FFFFFFF. This parameter is required for the 10GBASE-R and Interlaken protocols. |
| <b>Enable RX descrambler (10GBASE-R/Interlaken)</b> | <b>On / Off</b>             | Enables the descrambler function. This option is available for Basic (Enhanced PCS) mode, Interlaken, and 10GBASE-R protocols. You can enable the descrambler in Basic (Enhanced PCS) mode with the block synchronizer enabled and with 66:32, 66:40, or 66:64 gear box ratios.                                                                           |

**Table 26. Interlaken Disparity Generator and Checker Parameters**

| Parameter                                        | Range           | Description                                                                                                                           |
|--------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable Interlaken TX disparity generator</b>  | <b>On / Off</b> | When you turn on this option, the Enhanced PCS enables the disparity generator. This option is available for the Interlaken protocol. |
| <b>Enable Interlaken RX disparity checker</b>    | <b>On / Off</b> | When you turn on this option, the Enhanced PCS enables the disparity checker. This option is available for the Interlaken protocol.   |
| <b>Enable Interlaken TX random disparity bit</b> | <b>On / Off</b> | Enables the Interlaken random disparity bit. When enabled, a random number is used as disparity bit which saves one cycle of latency. |

**Table 27. Block Synchronizer Parameters**

| Parameter                           | Range           | Description                                                                                                                                                                        |
|-------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable RX block synchronizer</b> | <b>On / Off</b> | When you turn on this option, the Enhanced PCS enables the RX block synchronizer. This option is available for the Basic (Enhanced PCS) mode, Interlaken, and 10GBASE-R protocols. |
| <b>Enable rx_enh_blk_lock port</b>  | <b>On / Off</b> | Enables the <b>rx_enh_blk_lock</b> port. When you enable the block synchronizer, this signal is asserted to indicate that the block delineation has been achieved.                 |

**Table 28. Gearbox Parameters**

| Parameter                                | Range           | Description                                                                                                                                                                                                                                                                       |
|------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable TX data bitslip</b>            | <b>On / Off</b> | When you turn on this option, the TX gearbox operates in bitslip mode. The <b>tx_enh_bitslip port</b> controls number of bits which TX parallel data slips before going to the PMA.                                                                                               |
| <b>Enable TX data polarity inversion</b> | <b>On / Off</b> | When you turn on this option, the polarity of TX data is inverted. This allows you to correct incorrect placement and routing on the PCB.                                                                                                                                         |
| <b>Enable RX data bitslip</b>            | <b>On / Off</b> | When you turn on this option, the Enhanced PCS RX block synchronizer operates in bitslip mode. When enabled, the <b>rx_bitslip port</b> is asserted on the rising edge to ensure that RX parallel data from the PMA slips by one bit before passing to the PCS.                   |
| <b>Enable RX data polarity inversion</b> | <b>On / Off</b> | When you turn on this option, the polarity of the RX data is inverted. This allows you to correct incorrect placement and routing on the PCB.                                                                                                                                     |
| <b>Enable tx_enh_bitslip port</b>        | <b>On / Off</b> | Enables the <b>tx_enh_bitslip port</b> . When TX bit slip is enabled, this signal controls the number of bits which TX parallel data slips before going to the PMA.                                                                                                               |
| <b>Enable rx_bitslip port</b>            | <b>On / Off</b> | Enables the <b>rx_bitslip port</b> . When RX bit slip is enabled, the <b>rx_bitslip</b> signal is asserted on the rising edge to ensure that RX parallel data from the PMA slips by one bit before passing to the PCS. This port is shared between Standard PCS and Enhanced PCS. |

**Note:** If a design is slipping more bits than the PCS/PMA width, the Enhanced RX PCS FIFO could overflow. To clear the overflow, assert **rx\_digitalreset**.

**Table 29. KR-FEC Parameters**

| Parameter                                   | Range                               | Description                                                                                                                                                                     |
|---------------------------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable RX KR-FEC error marking</b>       | <b>On/Off</b>                       | When you turn on this option, the decoder asserts both sync bits (2'b11) when it detects an uncorrectable error. This feature increases the latency through the KR-FEC decoder. |
| <b>Error marking type</b>                   | <b>10G, 40G</b>                     | Specifies the error marking type (10G or 40G).                                                                                                                                  |
| <b>Enable KR-FEC TX error insertion</b>     | <b>On/Off</b>                       | Enables the error insertion feature of the KR-FEC encoder. This feature allows you to insert errors by corrupting data starting a bit 0 of the current word.                    |
| <b>KR-FEC TX error insertion spacing</b>    | <b>User Input</b> (1 bit to 15 bit) | Specifies the spacing of the KR-FEC TX error insertion.                                                                                                                         |
| <b>Enable tx_enh_frame port</b>             | <b>On/Off</b>                       | Enables the <b>tx_enh_frame port</b> .                                                                                                                                          |
| <b>Enable rx_enh_frame port</b>             | <b>On/Off</b>                       | Enables the <b>rx_enh_frame port</b> .                                                                                                                                          |
| <b>Enable rx_enh_frame_diag_status port</b> | <b>On/Off</b>                       | Enables the <b>rx_enh_frame_diag_status port</b> .                                                                                                                              |

#### Related Information

- [Arria 10 Enhanced PCS Architecture](#) on page 473
- [Using the "Basic \(Enhanced PCS\)" and "Basic with KR FEC" Configurations of Enhanced PCS](#) on page 296
- [Interlaken](#) on page 94
- [10GBASE-KR PHY IP Core](#) on page 135
- [Enhanced PCS Ports](#) on page 77
- [10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC Variants](#) on page 124

#### 2.4.5. Standard PCS Parameters

This section provides descriptions of the parameters that you can specify to customize the Standard PCS.

For specific information about configuring the Standard PCS for these protocols, refer to the sections of this user guide that describe support for these protocols.

**Table 30. Standard PCS Parameters**

**Note:** For detailed descriptions of the optional ports that you can enable or disable, refer to the [Standard PCS Ports](#) on page 87 section.

| Parameter                                          | Range                        | Description                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Standard PCS/PMA interface width</b>            | <b>8, 10, 16, 20</b>         | Specifies the data interface width between the Standard PCS and the transceiver PMA.                                                                                                                                                                                                                          |
| <b>FPGA fabric/Standard TX PCS interface width</b> | <b>8, 10, 16, 20, 32, 40</b> | Shows the FPGA fabric to TX PCS interface width. This value is determined by the current configuration of individual blocks within the Standard TX PCS datapath.                                                                                                                                              |
| <b>FPGA fabric/Standard RX PCS interface width</b> | <b>8, 10, 16, 20, 32, 40</b> | Shows the FPGA fabric to RX PCS interface width. This value is determined by the current configuration of individual blocks within the Standard RX PCS datapath.                                                                                                                                              |
| <b>Enable Standard PCS low latency mode</b>        | <b>On / Off</b>              | Enables the low latency path for the Standard PCS. Some of the functional blocks within the Standard PCS are bypassed to provide the lowest latency. You cannot turn on this parameter while using the <b>Basic/Custom w/Rate Match (Standard PCS)</b> specified for <b>Transceiver configuration rules</b> . |

**Table 31. Standard PCS FIFO Parameters**

| Parameter                              | Range                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TX FIFO mode</b>                    | <b>low_latency register_fifo fast_register</b> | Specifies the Standard PCS TX FIFO mode. The following modes are available: <ul style="list-style-type: none"> <li><b>low_latency</b>: This mode adds 2-3 cycles of latency to the TX datapath.</li> <li><b>register_fifo</b>: In this mode the FIFO is replaced by registers to reduce the latency through the PCS. Use this mode for protocols that require deterministic latency, such as CPRI.</li> <li><b>fast_register</b>: This mode allows a higher maximum frequency (<math>f_{MAX}</math>) between the FPGA fabric and the TX PCS at the expense of higher latency.</li> </ul> |
| <b>RX FIFO mode</b>                    | <b>low_latency register_fifo</b>               | The following modes are available: <ul style="list-style-type: none"> <li><b>low_latency</b>: This mode adds 2-3 cycles of latency to the RX datapath.</li> <li><b>register_fifo</b>: In this mode the FIFO is replaced by registers to reduce the latency through the PCS. Use this mode for protocols that require deterministic latency, such as CPRI or 1588.</li> </ul>                                                                                                                                                                                                             |
| <b>Enable tx_std_pcfifo_full port</b>  | <b>On / Off</b>                                | Enables the <code>tx_std_pcfifo_full</code> port. This signal indicates when the standard TX phase compensation FIFO is full. This signal is synchronous with <code>tx_coreclk</code> .                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Enable tx_std_pcfifo_empty port</b> | <b>On / Off</b>                                | Enables the <code>tx_std_pcfifo_empty</code> port. This signal indicates when the standard TX phase compensation FIFO is empty. This signal is synchronous with <code>tx_coreclk</code> .                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>Enable rx_std_pcfifo_full port</b>  | <b>On / Off</b>                                | Enables the <code>rx_std_pcfifo_full</code> port. This signal indicates when the standard RX phase compensation FIFO is full. This signal is synchronous with <code>rx_coreclk</code> .                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Enable rx_std_pcfifo_empty port</b> | <b>On / Off</b>                                | Enables the <code>rx_std_pcfifo_empty</code> port. This signal indicates when the standard RX phase compensation FIFO is empty. This signal is synchronous with <code>rx_coreclk</code> .                                                                                                                                                                                                                                                                                                                                                                                                |

**Table 32. Byte Serializer and Deserializer Parameters**

| Parameter                          | Range                                                             | Description                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable TX byte serializer</b>   | <b>Disabled</b><br><b>Serialize x2</b><br><b>Serialize x4</b>     | Specifies the TX byte serializer mode for the Standard PCS. The transceiver architecture allows the Standard PCS to operate at double or quadruple the data width of the PMA serializer. The byte serializer allows the PCS to run at a lower internal clock frequency to accommodate a wider range of FPGA interface widths. <b>Serialize x4</b> is only applicable for PCIe protocol implementation.                |
| <b>Enable RX byte deserializer</b> | <b>Disabled</b><br><b>Deserialize x2</b><br><b>Deserialize x4</b> | Specifies the mode for the RX byte deserializer in the Standard PCS. The transceiver architecture allows the Standard PCS to operate at double or quadruple the data width of the PMA deserializer. The byte deserializer allows the PCS to run at a lower internal clock frequency to accommodate a wider range of FPGA interface widths. <b>Deserialize x4</b> is only applicable for PCIe protocol implementation. |

**Table 33. 8B/10B Encoder and Decoder Parameters**

| Parameter                                 | Range           | Description                                                                                                                                                                                |
|-------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable TX 8B/10B encoder</b>           | <b>On / Off</b> | When you turn on this option, the Standard PCS enables the TX 8B/10B encoder.                                                                                                              |
| <b>Enable TX 8B/10B disparity control</b> | <b>On / Off</b> | When you turn on this option, the Standard PCS includes disparity control for the 8B/10B encoder. You can force the disparity of the 8B/10B encoder using the tx_forcedisp control signal. |
| <b>Enable RX 8B/10B decoder</b>           | <b>On / Off</b> | When you turn on this option, the Standard PCS includes the 8B/10B decoder.                                                                                                                |

**Table 34. Rate Match FIFO Parameters**

| Parameter                                            | Range                                                                                                                               | Description                                                                                                                                                                                                                                                                                                                                             |
|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RX rate match FIFO mode</b>                       | <b>Disabled</b><br><b>Basic 10-bit PMA width</b><br><b>Basic 20-bit PMA width</b><br><b>GbE</b><br><b>PIPE</b><br><b>PIPE 0 ppm</b> | Specifies the operation of the RX rate match FIFO in the Standard PCS.<br><a href="#">Rate Match FIFO in Basic (Single Width) Mode</a> on page 313<br><a href="#">Rate Match FIFO Basic (Double Width) Mode</a> on page 315<br><a href="#">Rate Match FIFO for GbE</a> on page 117<br><a href="#">Transceiver Channel Datapath for PIPE</a> on page 237 |
| <b>RX rate match insert/delete -ve pattern (hex)</b> | User-specified 20 bit pattern                                                                                                       | Specifies the -ve (negative) disparity value for the RX rate match FIFO as a hexadecimal string.                                                                                                                                                                                                                                                        |
| <b>RX rate match insert/delete +ve pattern (hex)</b> | User-specified 20 bit pattern                                                                                                       | Specifies the +ve (positive) disparity value for the RX rate match FIFO as a hexadecimal string.                                                                                                                                                                                                                                                        |
| <b>Enable rx_std_rmfifo_full port</b>                | <b>On / Off</b>                                                                                                                     | Enables the optional rx_std_rmfifo_full port.                                                                                                                                                                                                                                                                                                           |
| <b>Enable rx_std_rmfifo_empty port</b>               | <b>On / Off</b>                                                                                                                     | Enables the rx_std_rmfifo_empty port.                                                                                                                                                                                                                                                                                                                   |
| <b>PCI Express* Gen3 rate match FIFO mode</b>        | <b>Bypass</b><br><b>0 ppm</b><br><b>600 ppm</b>                                                                                     | Specifies the PPM tolerance for the PCI Express Gen3 rate match FIFO.                                                                                                                                                                                                                                                                                   |

**Table 35. Word Aligner and Bitslip Parameters**

| Parameter                                                             | Range                                                                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable TX bitslip</b>                                              | <b>On / Off</b>                                                                                    | When you turn on this option, the PCS includes the bitslip function. The outgoing TX data can be slipped by the number of bits specified by the tx_std_bitslipboundarysel control signal.                                                                                                                                                                                                                    |
| <b>Enable tx_std_bitslipboundarysel port</b>                          | <b>On / Off</b>                                                                                    | Enables the tx_std_bitslipboundarysel control signal.                                                                                                                                                                                                                                                                                                                                                        |
| <b>RX word aligner mode</b>                                           | <b>bitslip<br/>manual (PLD controlled)<br/>synchronous state machine<br/>deterministic latency</b> | Specifies the RX word aligner mode for the Standard PCS. The word aligned width depends on the PCS and PMA width, and whether or not 8B/10B is enabled. Refer to "Word Aligner" for more information.                                                                                                                                                                                                        |
| <b>RX word aligner pattern length</b>                                 | <b>7, 8, 10, 16, 20,<br/>32, 40</b>                                                                | Specifies the length of the pattern the word aligner uses for alignment. Refer to "RX Word Aligner Pattern Length" table in "Word Aligner". It shows the possible values of "Rx Word Aligner Pattern Length" in all available word aligner modes.                                                                                                                                                            |
| <b>RX word aligner pattern (hex)</b>                                  | User-specified                                                                                     | Specifies the word alignment pattern in hex.                                                                                                                                                                                                                                                                                                                                                                 |
| <b>Number of word alignment patterns to achieve sync</b>              | 0-255                                                                                              | Specifies the number of valid word alignment patterns that must be received before the word aligner achieves synchronization lock. The default is 3.                                                                                                                                                                                                                                                         |
| <b>Number of invalid words to lose sync</b>                           | 0-63                                                                                               | Specifies the number of invalid data codes or disparity errors that must be received before the word aligner loses synchronization. The default is 3.                                                                                                                                                                                                                                                        |
| <b>Number of valid data words to decrement error count</b>            | 0-255                                                                                              | Specifies the number of valid data codes that must be received to decrement the error counter. If the word aligner receives enough valid data codes to decrement the error count to 0, the word aligner returns to synchronization lock.                                                                                                                                                                     |
| <b>Enable fast sync status reporting for deterministic Latency SM</b> | <b>On / Off</b>                                                                                    | When enabled, the rx_syncstatus asserts high immediately after the deserializer has completed slipping the bits to achieve word alignment. When it is not selected, rx_syncstatus asserts after the cycle slip operation is complete and the word alignment pattern is detected by the PCS (i.e. rx_patterndetect is asserted). This parameter is only applicable when the selected protocol is CPRI (Auto). |
| <b>Enable rx_std_wa_patternalign port</b>                             | <b>On / Off</b>                                                                                    | Enables the rx_std_wa_patternalign port. When the word aligner is configured in manual mode and when this signal is enabled, the word aligner aligns to next incoming word alignment pattern.                                                                                                                                                                                                                |
| <b>Enable rx_std_wa_a1a2size port</b>                                 | <b>On / Off</b>                                                                                    | Enables the optional rx_std_wa_a1a2size control input port.                                                                                                                                                                                                                                                                                                                                                  |
| <b>Enable rx_std_bitslipboundarysel port</b>                          | <b>On / Off</b>                                                                                    | Enables the optional rx_std_bitslipboundarysel status output port.                                                                                                                                                                                                                                                                                                                                           |
| <b>Enable rx_bitslip port</b>                                         | <b>On / Off</b>                                                                                    | Enables the rx_bitslip port. This port is shared between the Standard PCS and Enhanced PCS.                                                                                                                                                                                                                                                                                                                  |

**Table 36. Bit Reversal and Polarity Inversion**

| Parameter                              | Range           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable TX bit reversal</b>          | <b>On / Off</b> | When you turn on this option, the 8B/10B Encoder reverses TX parallel data before transmitting it to the PMA for serialization. The transmitted TX data bit order is reversed. The normal order is LSB to MSB. The reverse order is MSB to LSB. During the operation of the circuit, this setting can be changed through dynamic reconfiguration.                                                                                                                                                                                  |
| <b>Enable TX byte reversal</b>         | <b>On / Off</b> | When you turn on this option, the 8B/10B Encoder reverses the byte order before transmitting data. This function allows you to reverse the order of bytes that were erroneously swapped. The PCS can swap the ordering of either one of the 8- or 10-bit words, when the PCS/PMA interface width is 16 or 20 bits. This option is not valid under certain <b>Transceiver configuration rules</b> .                                                                                                                                 |
| <b>Enable TX polarity inversion</b>    | <b>On / Off</b> | When you turn on this option, the <code>tx_std_polinv</code> port controls polarity inversion of TX parallel data to the PMA. When you turn on this parameter, you also need to turn on the <b>Enable tx_polinv port</b> .                                                                                                                                                                                                                                                                                                         |
| <b>Enable tx_polinv port</b>           | <b>On / Off</b> | When you turn on this option, the <code>tx_polinv</code> input control port is enabled. You can use this control port to swap the positive and negative signals of a serial differential link, if they were erroneously swapped during board layout.                                                                                                                                                                                                                                                                               |
| <b>Enable RX bit reversal</b>          | <b>On / Off</b> | When you turn on this option, the word aligner reverses RX parallel data. The received RX data bit order is reversed. The normal order is LSB to MSB. The reverse order is MSB to LSB. This setting can be changed through dynamic reconfiguration. When you enable <b>Enable RX bit reversal</b> , you must also enable <b>Enable rx_std_bitrev_ena port</b> .                                                                                                                                                                    |
| <b>Enable rx_std_bitrev_ena port</b>   | <b>On / Off</b> | When you turn on this option and assert the <code>rx_std_bitrev_ena</code> control port, the RX data order is reversed. The normal order is LSB to MSB. The reverse order is MSB to LSB.                                                                                                                                                                                                                                                                                                                                           |
| <b>Enable RX byte reversal</b>         | <b>On / Off</b> | When you turn on this option, the word aligner reverses the byte order, before storing the data in the RX FIFO. This function allows you to reverse the order of bytes that are erroneously swapped. The PCS can swap the ordering of either one of the 8- or 10-bit words, when the PCS / PMA interface width is 16 or 20 bits. This option is not valid under certain <b>Transceiver configuration rules</b> . When you enable <b>Enable RX byte reversal</b> , you must also select the <b>Enable rx_std_byterev_ena port</b> . |
| <b>Enable rx_std_byterev_ena port</b>  | <b>On / Off</b> | When you turn on this option and assert the <code>rx_std_byterev_ena</code> input control port, the order of the individual 8- or 10-bit words received from the PMA is swapped.                                                                                                                                                                                                                                                                                                                                                   |
| <b>Enable RX polarity inversion</b>    | <b>On / Off</b> | When you turn on this option, the <code>rx_std_polinv</code> port inverts the polarity of RX parallel data. When you turn on this parameter, you also need to enable <b>Enable rx_polinv port</b> .                                                                                                                                                                                                                                                                                                                                |
| <b>Enable rx_polinv port</b>           | <b>On / Off</b> | When you turn on this option, the <code>rx_polinv</code> input is enabled. You can use this control port to swap the positive and negative signals of a serial differential link if they were erroneously swapped during board layout.                                                                                                                                                                                                                                                                                             |
| <b>Enable rx_std_signaldetect port</b> | <b>On / Off</b> | When you turn on this option, the optional <code>rx_std_signaldetect</code> output port is enabled. This signal is required for the PCI Express protocol. If enabled, the signal threshold detection circuitry senses whether the signal level present at the RX input buffer is above the signal detect                                                                                                                                                                                                                           |

*continued...*

| Parameter | Range | Description                                                                                                                                                                |
|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |       | threshold voltage that you specified. You can specify the signal detect threshold using a Quartus Prime Assignment Editor or by modifying the Quartus Settings File (.qsf) |

**Table 37. PCIe Ports**

| Parameter                                                   | Range           | Description                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable PCIe dynamic datarate switch ports</b>            | <b>On / Off</b> | When you turn on this option, the pipe_rate, pipe_sw, and pipe_sw_done ports are enabled. You should connect these ports to the PLL IP core instance in multi-lane PCIe Gen2 and Gen3 configurations. The pipe_sw and pipe_sw_done ports are only available for multi-lane bonded configurations.                                                                                                            |
| <b>Enable PCIe pipe_hclk_in and pipe_hclk_out ports</b>     | <b>On / Off</b> | When you turn on this option, the pipe_hclk_in, and pipe_hclk_out ports are enabled. The pipe_hclk_in port must be connected to the PLL IP core instance for the PCI Express configurations. The pipe_hclk_out port can be left floating when you connect tx_clkout to the MAC clock input.                                                                                                                  |
| <b>Enable PCIe Gen3 analog control ports</b>                | <b>On / Off</b> | When you turn on this option, the pipe_g3_txdeemph and pipe_g3_rxpresentint ports are enabled. You can use these ports for equalization for Gen3 configurations.                                                                                                                                                                                                                                             |
| <b>Enable PCIe electrical idle control and status ports</b> | <b>On / Off</b> | When you turn on this option, the pipe_rx_eidleinversel and pipe_rx_elecidle ports are enabled. These ports are used for PCI Express configurations.                                                                                                                                                                                                                                                         |
| <b>Enable PCIe pipe_rx_polarity port</b>                    | <b>On / Off</b> | When you turn on this option, the pipe_rx_polarity input control port is enabled. You can use this option to control channel signal polarity for PCI Express configurations. When the Standard PCS is configured for PCIe, the assertion of this signal inverts the RX bit polarity. For other <b>Transceiver configuration rules</b> the optional rx_polinv port inverts the polarity of the RX bit stream. |

#### Related Information

- Standard PCS Ports on page 87
- Word Aligner on page 497

#### 2.4.6. PCS Direct

**Table 38. PCS Direct Datapath Parameters**

| Parameter                         | Range                            | Description                                                                 |
|-----------------------------------|----------------------------------|-----------------------------------------------------------------------------|
| <b>PCS Direct interface width</b> | <b>8, 10, 16, 20, 32, 40, 64</b> | Specifies the data interface width between the PLD and the transceiver PMA. |

#### 2.4.7. Dynamic Reconfiguration Parameters

Dynamic reconfiguration allows you to change the behavior of the transceiver channels and PLLs without powering down the device.

Each transceiver channel and PLL includes an Avalon memory-mapped interface slave interface for reconfiguration. This interface provides direct access to the programmable address space of each channel and PLL. Because each channel and PLL includes a dedicated Avalon memory-mapped interface slave interface, you can

dynamically modify channels either concurrently or sequentially. If your system does not require concurrent reconfiguration, you can parameterize the Transceiver Native PHY IP to share a single reconfiguration interface.

You can use dynamic reconfiguration to change many functions and features of the transceiver channels and PLLs. For example, you can change the reference clock input to the TX PLL. You can also change between the Standard and Enhanced datapaths.

To enable Intel Arria 10 transceiver toolkit capability in the Native PHY IP core, you must enable the following options:

- **Enable dynamic reconfiguration**
- **Enable Native PHY Debug Master Endpoint**
- **Enable capability registers**
- **Enable control and status registers**
- **Enable PRBS (Pseudo Random Binary Sequence) soft accumulators**

**Table 39. Dynamic Reconfiguration**

| Parameter                                                                             | Value         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------------------------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable dynamic reconfiguration</b>                                                 | <b>On/Off</b> | When you turn on this option, the dynamic reconfiguration interface is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Share reconfiguration interface</b>                                                | <b>On/Off</b> | When you turn on this option, the Transceiver Native PHY IP presents a single Avalon memory-mapped interface slave interface for dynamic reconfiguration for all channels. In this configuration, the upper [n-1:10] address bits of the reconfiguration address bus specify the channel. The channel numbers are binary encoded. Address bits [9:0] provide the register offset address within the reconfiguration space for a channel.                                                                                         |
| <b>Enable Native PHY Debug Master Endpoint</b>                                        | <b>On/Off</b> | When you turn on this option, the Transceiver Native PHY IP includes an embedded Native PHY Debug Master Endpoint (NPDME) that connects internally to the Avalon memory-mapped interface slave interface for dynamic reconfiguration. The NPDME can access the reconfiguration space of the transceiver. It can perform certain test and debug functions via JTAG using the System Console. This option requires you to enable the <b>Share reconfiguration interface</b> option for configurations using more than one channel. |
| <b>Separate reconfig_waitrequest from the status of AVMM arbitration with PreSICE</b> | <b>On/Off</b> | When enabled, the <code>reconfig_waitrequest</code> does not indicate the status of Avalon memory-mapped interface arbitration with PreSICE. The Avalon memory-mapped interface arbitration status is reflected in a soft status register bit. This feature requires that the "Enable control and status registers" feature under "Optional Reconfiguration Logic" be enabled.                                                                                                                                                   |

**Table 40. Optional Reconfiguration Logic**

| Parameter                                                            | Value               | Description                                                                                                                                     |
|----------------------------------------------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable capability registers</b>                                   | <b>On/Off</b>       | Enables capability registers that provide high level information about the configuration of the transceiver channel.                            |
| <b>Set user-defined IP identifier</b>                                | <b>User-defined</b> | Sets a user-defined numeric identifier that can be read from the <code>user_identifier</code> offset when the capability registers are enabled. |
| <b>Enable control and status registers</b>                           | <b>On/Off</b>       | Enables soft registers to read status signals and write control signals on the PHY interface through the embedded debug.                        |
| <b>Enable PRBS (Pseudo Random Binary Sequence) soft accumulators</b> | <b>On/Off</b>       | Enables soft logic for performing PRBS bit and error accumulation when the hard PRBS generator and checker are used.                            |

**Table 41. Configuration Files**

| Parameter                                                 | Value                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Configuration file prefix</b>                          | <code>&lt;prefix&gt;</code> | Here, the file prefix to use for generated configuration files is specified. Each variant of the Transceiver Native PHY IP should use a unique prefix for configuration files.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>Generate SystemVerilog package file</b>                | <b>On/Off</b>               | When you turn on this option, the Transceiver Native PHY IP generates a SystemVerilog package file, <code>reconfig_parameters.sv</code> . This file contains parameters defined with the attribute values required for reconfiguration.                                                                                                                                                                                                                                                                                                                                                                                                             |
| <b>Generate C header file</b>                             | <b>On/Off</b>               | When you turn on this option, the Transceiver Native PHY IP generates a C header file, <code>reconfig_parameters.h</code> . This file contains macros defined with the attribute values required for reconfiguration.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>Generate MIF (Memory Initialization File)</b>          | <b>On/Off</b>               | When you turn on this option, the Transceiver Native PHY IP generates a MIF, <code>reconfig_parameters.mif</code> . This file contains the attribute values required for reconfiguration in a data format.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>Include PMA analog settings in configuration files</b> | <b>On/Off</b>               | When enabled, the IP allows you to configure the PMA analog settings that are selected in the Analog PMA settings (Optional) tab. These settings are included in your generated configuration files.<br><br><i>Note:</i> You must still specify the analog settings for your current configuration using Quartus Prime Setting File (.qsf) assignments in Quartus. This option does not remove the requirement to specify Quartus Prime Setting File (.qsf) assignments for your analog settings. Refer to the <i>Analog Parameter Settings</i> chapter in the <i>Arria 10 Transceiver PHY User Guide</i> for details on using the QSF assignments. |

**Table 42. Configuration Profiles**

| Parameter                                | Value         | Description                                                                                                                                                                                                                                                                                |
|------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enable multiple reconfiguration profiles | <b>On/Off</b> | When enabled, you can use the GUI to store multiple configurations. This information is used by Quartus to include the necessary timing arcs for all configurations during timing driven compilation. The Native PHY generates reconfiguration files for all of the stored configurations. |

*continued...*

| Parameter                                | Value  | Description                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                          |        | profiles. The Native PHY also checks your multiple reconfiguration profiles for consistency to ensure you can reconfigure between them. Among other things this checks that you have exposed the same ports for each configuration. <sup>(28)</sup>                                                                                                                                           |
| Enable embedded reconfiguration streamer | On/Off | Enables the embedded reconfiguration streamer, which automates the dynamic reconfiguration process between multiple predefined configuration profiles. This is optional and increases logic utilization. The PHY includes all of the logic and data necessary to dynamically reconfigure between pre-configured profiles.                                                                     |
| Generate reduced reconfiguration files   | On/Off | When enabled, The Native PHY generates reconfiguration report files containing only the attributes or RAM data that are different between the multiple configured profiles. The reconfiguration time decreases with the use of reduced .mif files.                                                                                                                                            |
| Number of reconfiguration profiles       | 1-8    | Specifies the number of reconfiguration profiles to support when multiple reconfiguration profiles are enabled.                                                                                                                                                                                                                                                                               |
| Selected reconfiguration profile         | 0-7    | Selects which reconfiguration profile to store/load/clear/refresh, when clicking the relevant button for the selected profile.                                                                                                                                                                                                                                                                |
| Store configuration to selected profile  | -      | Clicking this button saves or stores the current Native PHY parameter settings to the profile specified by the <b>Selected reconfiguration profile</b> parameter.                                                                                                                                                                                                                             |
| Load configuration from selected profile | -      | Clicking this button loads the current Native PHY with parameter settings from the stored profile specified by the <b>Selected reconfiguration profile</b> parameter.                                                                                                                                                                                                                         |
| Clear selected profile                   | -      | Clicking this button clears or erases the stored Native PHY parameter settings for the profile specified by the <b>Selected reconfiguration profile</b> parameter. An empty profile defaults to the current parameter settings of the Native PHY.                                                                                                                                             |
| Clear all profiles                       | -      | Clicking this button clears the Native PHY parameter settings for all the profiles.                                                                                                                                                                                                                                                                                                           |
| Refresh selected profile                 | -      | Clicking this button is equivalent to clicking the <b>Load configuration from selected profile</b> and <b>Store configuration to selected profile</b> buttons in sequence. This operation loads the Native PHY parameter settings from stored profile specified by the <b>Selected reconfiguration profile</b> parameter and subsequently stores or saves the parameters back to the profile. |

**Table 43. Analog PMA Settings (Optional) for Dynamic Reconfiguration**

| Parameter                                               | Value                    | Description                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TX Analog PMA Settings</b>                           |                          |                                                                                                                                                                                                                                                                                                                                                  |
| Analog Mode (Load Intel-recommended Default settings)   | Cei_11100_Lr to xfp_9950 | Selects the analog protocol mode to pre-select the TX pin swing settings (VOD, Pre-emphasis, and Slew Rate). After loading the pre-selected values in the GUI, if one or more of the individual TX pin swing settings need to be changed, then enable the option to override the Intel-recommended defaults to individually modify the settings. |
| Override Intel-recommended Analog Mode Default settings | On/Off                   | Enables the option to override the Intel-recommended settings for the selected TX Analog Mode for one or more TX analog parameters.                                                                                                                                                                                                              |

continued...

(28) For more information on timing closure, refer to the *Reconfiguration Interface and Dynamic Reconfiguration* chapter.

| Parameter                                   | Value                              | Description                                                                                                                                                                                                   |
|---------------------------------------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output Swing Level (VOD)                    | <b>0-31</b>                        | Selects the transmitter programmable output differential voltage swing.                                                                                                                                       |
| Pre-Emphasis First Pre-Tap Polarity         | Fir_pre_1t_neg<br>Fir_pre_1t_pos   | Selects the polarity of the first pre-tap for pre-emphasis.                                                                                                                                                   |
| Pre-Emphasis First Pre-Tap Magnitude        | <b>0-16</b> <sup>(29)</sup>        | Selects the magnitude of the first pre-tap for pre-emphasis                                                                                                                                                   |
| Pre-Emphasis Second Pre-Tap Polarity        | Fir_pre_2t_neg<br>Fir_pre_2t_pos   | Selects the polarity of the second pre-tap for pre-emphasis.                                                                                                                                                  |
| Pre-Emphasis Second Pre-Tap Magnitude       | <b>0-7</b> <sup>(30)</sup>         | Selects the magnitude of the second pre-tap for pre-emphasis.                                                                                                                                                 |
| Pre-Emphasis First Post-Tap Polarity        | Fir_post_1t_neg<br>Fir_post_1t_pos | Selects the polarity of the first post-tap for pre-emphasis                                                                                                                                                   |
| Pre-Emphasis First Post-Tap Magnitude       | <b>0-25</b> <sup>(31)</sup>        | Selects the magnitude of the first post-tap for pre-emphasis.                                                                                                                                                 |
| Pre-Emphasis Second Post-Tap Polarity       | Fir_post_2t_neg<br>Fir_post_2t_pos | Selects the polarity of the second post-tap for pre-emphasis.                                                                                                                                                 |
| Pre-Emphasis Second Post-Tap Magnitude      | <b>0-12</b> <sup>(32)</sup>        | Selects the magnitude of the second post-tap for pre-emphasis                                                                                                                                                 |
| Slew Rate Control                           | slew_r0 to slew_r5                 | Selects the slew rate of the TX output signal. Valid values span from slowest to the fastest rate.                                                                                                            |
| High-Speed Compensation                     | Enable/Disable                     | Enables the power-distribution network (PDN) induced inter-symbol interference (ISI) compensation in the TX driver. When enabled, it reduces the PDN induced ISI jitter, but increases the power consumption. |
| On-Chip termination                         | r_r1<br>r_r2                       | Selects the on-chip TX differential termination.                                                                                                                                                              |
| <b>RX Analog PMA settings</b>               |                                    |                                                                                                                                                                                                               |
| Override Intel-recommended Default settings | On/Off                             | Enables the option to override the Intel-recommended settings for one or more RX analog parameters                                                                                                            |

*continued...*

- 
- (29) For more information refer to *Available Options* table in the *XCVR\_A10\_TX\_PRE\_EMP\_SWITCHING\_CTRL\_PRE\_TAP\_1T* section of the *Analog Parameter Settings* chapter.
- (30) For more information refer to *Available Options* table in the *XCVR\_A10\_TX\_PRE\_EMP\_SWITCHING\_CTRL\_PRE\_TAP\_2T* section of the *Analog Parameter Settings* chapter.
- (31) For more information refer to *Available Options* table in the *XCVR\_A10\_TX\_PRE\_EMP\_SWITCHING\_CTRL\_1ST\_POST\_TAP* section of the *Analog Parameter Settings* chapter.
- (32) For more information refer to *Available Options* table in the *XCVR\_A10\_TX\_PRE\_EMP\_SWITCHING\_CTRL\_2ND\_POST\_TAP* section of the *Analog Parameter Settings* chapter.

| Parameter                                                   | Value                                             | Description                                                                                                                          |
|-------------------------------------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| CTLE (Continuous Time Linear Equalizer) mode                | non_s1_mode<br>S1_mode                            | Selects between the RX high gain mode non_s1_mode or RX high data rate mode s1_mode for the Continuous Time Linear Equalizer (CTLE). |
| DC gain control of high gain mode CTLE                      | No_dc_gain to stg4_gain7                          | Selects the DC gain of the Continuous Time Linear Equalizer (CTLE) in high gain mode                                                 |
| AC Gain Control of High Gain Mode CTLE                      | radp_ctle_acgain_4s_0 to radp_ctle_acgain_4s_28   | Selects the AC gain of the Continuous Time Linear Equalizer (CTLE) in high gain mode when CTLE is in manual mode.                    |
| AC Gain Control of High Data Rate Mode CTLE                 | radp_ctle_eqz_1s_sel_0 to Radp_ctle_eqz_1s_sel_15 | Selects the AC gain of the Continuous Time Linear Equalizer (CTLE) in high data rate mode when CTLE is in manual mode.               |
| Variable Gain Amplifier (VGA) Voltage Swing Select          | radp_vga_sel_0 to radp_vga_sel_7                  | Selects the Variable Gain Amplifier (VGA) output voltage swing when both the CTLE and DFE blocks are in manual mode                  |
| Decision Feedback Equalizer (DFE) Fixed Tap 1 Co-efficient  | radp_dfe_fxtap1_0 to radp_dfe_fxtap1_127          | Selects the co-efficient of the fixed tap 1 of the Decision Feedback Equalizer (DFE) when operating in manual mode                   |
| Decision Feedback Equalizer (DFE) Fixed Tap 2 Co-efficient  | radp_dfe_fxtap2_0 to radp_dfe_fxtap2_127          | Selects the co-efficient of the fixed tap 2 of the Decision Feedback Equalizer (DFE) when operating in manual mode                   |
| Decision Feedback Equalizer (DFE) Fixed Tap 3 Co-efficient  | radp_dfe_fxtap3_0 to radp_dfe_fxtap3_127          | Selects the co-efficient of the fixed tap 3 of the Decision Feedback Equalizer (DFE) when operating in manual mode.                  |
| Decision Feedback Equalizer (DFE) Fixed Tap 4 Co-efficient  | radp_dfe_fxtap4_0 to radp_dfe_fxtap4_63           | Selects the co-efficient of the fixed tap 4 of the Decision Feedback Equalizer (DFE) when operating in manual mode.                  |
| Decision Feedback Equalizer (DFE) Fixed Tap 5 Co-efficient  | radp_dfe_fxtap5_0 to radp_dfe_fxtap5_63           | Selects the co-efficient of the fixed tap 5 of the Decision Feedback Equalizer (DFE) when operating in manual mode.                  |
| Decision Feedback Equalizer (DFE) Fixed Tap 6 Co-efficient  | radp_dfe_fxtap6_0 to radp_dfe_fxtap6_31           | Selects the co-efficient of the fixed tap 6 of the Decision Feedback Equalizer (DFE) when operating in manual mode.                  |
| Decision Feedback Equalizer (DFE) Fixed Tap 7 Co-efficient  | radp_dfe_fxtap7_0 to radp_dfe_fxtap7_31           | Selects the co-efficient of the fixed tap 7 of the Decision Feedback Equalizer (DFE) when operating in manual mode.                  |
| Decision Feedback Equalizer (DFE) Fixed Tap 8 Co-efficient  | radp_dfe_fxtap8_0 to radp_dfe_fxtap8_31           | Selects the co-efficient of the fixed tap 8 of the Decision Feedback Equalizer (DFE) when operating in manual mode.                  |
| Decision Feedback Equalizer (DFE) Fixed Tap 9 Co-efficient  | radp_dfe_fxtap9_0 to radp_dfe_fxtap9_31           | Selects the co-efficient of the fixed tap 9 of the Decision Feedback Equalizer (DFE) when operating in manual mode.                  |
| Decision Feedback Equalizer (DFE) Fixed Tap 10 Co-efficient | radp_dfe_fxtap10_0 to radp_dfe_fxtap10_31         | Selects the co-efficient of the fixed tap 10 of the Decision Feedback Equalizer (DFE) when operating in manual mode.                 |
| Decision Feedback Equalizer (DFE) Fixed Tap 11 Co-efficient | radp_dfe_fxtap11_0 to radp_dfe_fxtap11_31         | Selects the co-efficient of the fixed tap 11 of the Decision Feedback Equalizer (DFE) when operating in manual mode.                 |
| On-Chip termination                                         | R_ext0, r_r1, r_r2                                | Selects the on-chip RX differential termination.                                                                                     |

**Table 44. Generation Options**

| Parameter                             | Value  | Description                                                                                                                                          |
|---------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Generate parameter documentation file | On/Off | When you turn on this option, generation produces a Comma-Separated Value (.csv) file with descriptions of the Transceiver Native PHY IP parameters. |

#### Related Information

- [Analog Parameter Settings](#) on page 597
- [XCVR\\_A10\\_TX\\_PRE\\_EMP\\_SWITCHING\\_CTRL\\_PRE\\_TAP\\_1T](#) on page 614
- [XCVR\\_A10\\_TX\\_PRE\\_EMP\\_SWITCHING\\_CTRL\\_PRE\\_TAP\\_2T](#) on page 614
- [XCVR\\_A10\\_TX\\_PRE\\_EMP\\_SWITCHING\\_CTRL\\_1ST\\_POST\\_TAP](#) on page 615
- [XCVR\\_A10\\_TX\\_PRE\\_EMP\\_SWITCHING\\_CTRL\\_2ND\\_POST\\_TAP](#) on page 616
- [Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514
- [Transmitter Pre-Emphasis First Pre-Tap Value](#) on page 612
- [Transmitter Pre-Emphasis Second Pre-Tap Value](#) on page 612
- [Transmitter Pre-Emphasis First Post-Tap Value](#) on page 613
- [Transmitter Pre-Emphasis Second Post-Tap Value](#) on page 613

### 2.4.8. PMA Ports

This section describes the PMA and calibration ports for the Arria 10 Transceiver Native PHY IP core.

The following tables, the variables represent these parameters:

- <n>—The number of lanes
- <d>—The serialization factor
- <s>—The symbol size
- <p>—The number of PLLs

**Table 45. TX PMA Ports**

| Name                                                                 | Direction | Clock Domain | Description                                                                                                                                                                                                                         |
|----------------------------------------------------------------------|-----------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_serial_data[<n>-1:0]                                              | Input     | N/A          | This is the serial data output of the TX PMA.                                                                                                                                                                                       |
| tx_serial_clk0                                                       | Input     | Clock        | This is the serial clock from the TX PLL. The frequency of this clock depends on the data rate and clock division factor. This clock is for non bonded channels only. For bonded channels use the tx_bonding_clocks clock TX input. |
| tx_bonding_clocks[<n><6>-1:0]                                        | Input     | Clock        | This is a 6-bit bus which carries the low speed parallel clock per channel. These clocks are outputs from the master CGB. Use these clocks for bonded channels only.                                                                |
| <b>Optional Ports</b>                                                |           |              |                                                                                                                                                                                                                                     |
| tx_serial_clk1<br>tx_serial_clk2<br>tx_serial_clk3<br>tx_serial_clk4 | Inputs    | Clocks       | These are the serial clocks from the TX PLL. The frequency of these clocks depends on the data rate and clock division factor. These additional ports are enabled when you specify more than one TX PLL.                            |

*continued...*

| Name                       | Direction | Clock Domain                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------|-----------|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_analog_reset_ac_k       | Output    | Asynchronous                                                         | Enables the optional tx_pma_analog_reset_ack output. This port should not be used for register mode data transfers                                                                                                                                                                                                                                                                                                                                   |
| tx_pma_clkout              | Output    | Clock                                                                | This clock is the low speed parallel clock from the TX PMA. It is available when you turn on <b>Enable tx_pma_clkout port</b> in the Transceiver Native PHY IP core <b>Parameter Editor</b> . <sup>(33)</sup>                                                                                                                                                                                                                                        |
| tx_pma_div_clkout          | Output    | Clock                                                                | If you specify a tx_pma_div_clkout division factor of 1 or 2, this clock output is derived from the PMA parallel clock (low speed parallel clock). If you specify a tx_pma_div_clkout division factor of 33, 40, or 66, this clock is derived from the PMA serial clock. This clock is commonly used when the interface to the TX FIFO runs at a different rate than the PMA parallel clock frequency, such as 66:40 applications.                   |
| tx_pma_iqtxrx_clkout       | Output    | Clock                                                                | This port is available if you turn on <b>Enable tx_pma_iqtxrx_clkout port</b> in the Transceiver Native PHY IP core <b>Parameter Editor</b> . This output clock can be used to cascade the TX PMA output clock to the input of a PLL.                                                                                                                                                                                                                |
| tx_pma_elecidle[<n>-1:0]   | Input     | Asynchronous                                                         | When you assert this signal, the transmitter is forced to electrical idle. This port has no effect when you configure the transceiver for the PCI Express protocol.                                                                                                                                                                                                                                                                                  |
| tx_pma_qpipullup[<n>-1:0]  | Input     | Asynchronous                                                         | This port is available if you turn on <b>Enable tx_pma_qpipullup port</b> (QPI) in the Transceiver Native PHY IP core <b>Parameter Editor</b> . It is only used for Quick Path Interconnect (QPI) applications.                                                                                                                                                                                                                                      |
| tx_pma_qpipulldn[<n>-1:0]  | Input     | Asynchronous                                                         | This port is available if you turn on <b>Enable tx_pma_qpipulldn port</b> (QPI) in the Transceiver Native PHY IP core <b>Parameter Editor</b> . It is only used for Quick Path Interconnect (QPI) applications.                                                                                                                                                                                                                                      |
| tx_pma_txdetectrx[<n>-1:0] | Input     | Asynchronous                                                         | This port is available if you turn on <b>Enable tx_pma_txdetectrx port</b> (QPI) in the Transceiver Native PHY IP core <b>Parameter Editor</b> . When asserted, the receiver detect block in TX PMA detects the presence of a receiver at the other end of the channel. After receiving the tx_pma_txdetectrx request, the receiver detect block initiates the detection process. Use this port for Quick Path Interconnect (QPI) applications only. |
| tx_pma_rxfound[<n>-1:0]    | Output    | Synchronous to rx_coreclkin or rx_clkout based on the configuration. | This port is available if you turn on <b>Enable tx_rxfound_pma port</b> (QPI) in the Transceiver Native PHY IP core <b>Parameter Editor</b> . When asserted, indicates that the receiver detect block in TX PMA has detected a receiver at the other end of the channel. Use this port for Quick Path Interconnect (QPI) applications only.                                                                                                          |
| rx_serialpbken[<n>-1:0]    | Input     | Asynchronous                                                         | This port is available if you turn on <b>Enable rx_serialpbken port</b> in the Transceiver Native PHY IP core <b>Parameter Editor</b> . The assertion of this signal enables the TX to RX serial loopback path within the transceiver. This signal can be enabled in Duplex or Simplex mode. If enabled in Simplex mode, you must drive the signal on both the TX and RX instances from the same source. Otherwise the design fails compilation.     |

(33) This clock is not to be used to clock the FPGA - transceiver interface. This clock may be used as a reference clock to an external clock cleaner.

**Table 46. RX PMA Ports**

| Name                          | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------------------|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_serial_data[<n>-1:0]       | Input     | N/A          | Specifies serial data input to the RX PMA.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| rx_cdr_refclk0                | Input     | Clock        | Specifies reference clock input to the RX clock data recovery (CDR) circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>Optional Ports</b>         |           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| rx_cdr_refclk1-rx_cdr_refclk4 | Input     | Clock        | Specifies reference clock inputs to the RX clock data recovery (CDR) circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| rx_analog_reset_ack           | Output    | Asynchronous | Enables the optional rx_pma_analog_reset_ack output. This port should not be used for register mode data transfers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| rx_pma_clkout                 | Output    | Clock        | This clock is the recovered parallel clock from the RX CDR circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| rx_pma_div_clkout             | Output    | Clock        | The deserializer generates this clock. This is used to drive core logic, PCS-to-FPGA fabric interface, or both. If you specify a <b>rx_pma_div_clkout</b> division factor of 1 or 2, this clock output is derived from the PMA parallel clock (low speed parallel clock). If you specify a <b>rx_pma_div_clkout</b> division factor of 33, 40, or 66, this clock is derived from the PMA serial clock. This clock is commonly used when the interface to the RX FIFO runs at a different rate than the PMA parallel clock (low speed parallel clock) frequency, such as 66:40 applications. |
| rx_pma_iqtxrx_clkout          | Output    | Clock        | This port is available if you turn on <b>Enable rx_pma_iqtxrx_clkout port</b> in the Transceiver Native PHY IP core <b>Parameter Editor</b> . This output clock can be used to cascade the RX PMA output clock to the input of a PLL.                                                                                                                                                                                                                                                                                                                                                       |
| rx_pma_clkslip                | Output    | Clock        | When asserted, indicates that the deserializer has either skipped one serial bit or paused the serial clock for one cycle to achieve word alignment. As a result, the period of the parallel clock could be extended by 1 unit interval (UI) during the clock slip operation.                                                                                                                                                                                                                                                                                                               |
| rx_pma_qpipulldn[<n>-1:0]     | Input     | Asynchronous | This port is only used for Quick Path Interconnect (QPI) applications.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| rx_is_lockedtodata[<n>-1:0]   | Output    | rx_clkout    | When asserted, indicates that the CDR PLL is locked to the incoming data, rx_serial_data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| rx_is_lockedtoref[<n>-1:0]    | Output    | rx_clkout    | When asserted, indicates that the CDR PLL is locked to the input reference clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| rx_set_locktodata[<n>-1:0]    | Input     | Asynchronous | This port provides manual control of the RX CDR circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| rx_set_locktoref[<n>-1:0]     | Input     | Asynchronous | This port provides manual control of the RX CDR circuitry.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| rx_seriallpbken[<n>-1:0]      | Input     | Asynchronous | This port is available if you turn on <b>Enable rx_seriallpbken port</b> in the Transceiver Native PHY IP core <b>Parameter Editor</b> . The assertion of this signal enables the TX to RX serial loopback path within the transceiver. This signal is enabled in Duplex or Simplex mode. If enabled in Simplex mode, you must drive the signal on both the TX and RX instances from the same source. Otherwise the design fails compilation.                                                                                                                                               |

*continued...*

| Name                     | Direction | Clock Domain              | Description                                                                                                                                                                                                         |
|--------------------------|-----------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_prbs_done[<n>-1 : 0]  | Output    | rx_coreclkin or rx_clkout | When asserted, indicates the verifier has aligned and captured consecutive PRBS patterns and the first pass through a polynomial is complete.                                                                       |
| rx_prbs_err[<n>-1 : 0]   | Output    | rx_coreclkin or rx_clkout | When asserted, indicates an error only after the rx_prbs_done signal has been asserted. This signal gets asserted for three parallel clock cycles for every error that occurs. Errors can only occur once per word. |
| rx_prbs_err_clr[<n>-1:0] | Input     | rx_coreclkin or rx_clkout | When asserted, clears the PRBS pattern and deasserts the rx_prbs_done signal.                                                                                                                                       |

**Table 47. Calibration Status Ports**

| Name                 | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                  |
|----------------------|-----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_cal_busy[<n>-1:0] | Output    | Asynchronous | When asserted, indicates that the initial TX calibration is in progress. For both initial and manual recalibration, this signal is asserted during calibration and deasserts after calibration is completed. You must hold the channel in reset until calibration completes. |
| rx_cal_busy[<n>-1:0] | Output    | Asynchronous | When asserted, indicates that the initial RX calibration is in progress. For both initial and manual recalibration, this signal is asserted during calibration and deasserts after calibration is completed.                                                                 |

**Table 48. Reset Ports**

| Name                     | Direction | Clock Domain <sup>(34)</sup> | Description                                           |
|--------------------------|-----------|------------------------------|-------------------------------------------------------|
| tx_analogreset[<n>-1:0]  | Input     | Asynchronous                 | Resets the analog TX portion of the transceiver PHY.  |
| tx_digitalreset[<n>-1:0] | Input     | Asynchronous                 | Resets the digital TX portion of the transceiver PHY. |
| rx_analogreset[<n>-1:0]  | Input     | Asynchronous                 | Resets the analog RX portion of the transceiver PHY.  |
| rx_digitalreset[<n>-1:0] | Input     | Asynchronous                 | Resets the digital RX portion of the transceiver PHY. |

<sup>(34)</sup> Although the reset ports are not synchronous to any clock domain, Intel recommends that you synchronize the reset ports with the system clock.

## 2.4.9. Enhanced PCS Ports

**Figure 24. Enhanced PCS Interfaces**

The labeled inputs and outputs to the PMA and PCS modules represent buses, not individual signals.



In the following tables, the variables represent these parameters:

- $<n>$ —The number of lanes
- $<d>$ —The serialization factor
- $<s>$ — The symbol size
- $<p>$ —The number of PLLs

**Table 49. Enhanced TX PCS: Parallel Data, Control, and Clocks**

| Name                             | Direction | Clock Domain                                                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------|-----------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_parallel_data[ $<n>128-1:0$ ] | Input     | Synchronous to the clock driving the write side of the FIFO (tx_coreclk or tx_clkout) | <p>TX parallel data inputs from the FPGA fabric to the TX PCS. If you select <b>Enable simplified interface</b> in the Transceiver Native PHY IP <b>Parameter Editor</b>, tx_parallel_data includes only the bits required for the configuration you specify. You must ground the data pins that are not active. For single width configuration, the following bits are active:</p> <ul style="list-style-type: none"> <li>• 32-bit FPGA fabric to PCS interface width: tx_parallel_data[31:0]. Ground [127:32].</li> <li>• 40-bit FPGA fabric to PCS interface width: tx_parallel_data[39:0]. Ground [127:40].</li> <li>• 64-bit FPGA fabric to PCS interface width: tx_parallel_data[63:0] Ground [127:64].</li> </ul> |

*continued...*

| Name                                                 | Direction | Clock Domain                                                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------------------------|-----------|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                      |           |                                                                                       | <p>For double width configuration, the following bits are active:</p> <ul style="list-style-type: none"> <li>40-bit FPGA fabric to PCS interface width: data[103:64], [39:0]. Ground [127:104], [63:40].</li> <li>64-bit FPGA fabric to PCS interface width: data[127:64], [63:0].</li> </ul> <p>Double-width mode is not supported for 32-bit, 50-bit, and 67-bit FPGA fabric to PCS interface widths.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| unused_tx_parallel_data                              | Input     | tx_clkout                                                                             | <p>Port is enabled, when you enable <b>Enable simplified data interface</b>. Connect all of these bits to 0. When <b>Enable simplified data interface</b> is disabled, the unused bits are a part of tx_parallel_data. Refer to tx_parallel_data to identify the bits you need to ground.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| tx_control[<n><3>-1:0] or<br>tx_control[<n><18>-1:0] | Input     | Synchronous to the clock driving the write side of the FIFO (tx_coreclk or tx_clkout) | <p>tx_control bits have different functionality depending on the transceiver configuration rule selected. When <b>Simplified data interface</b> is enabled, the number of bits in this bus change because the unused bits are shown as part of the unused_tx_control port.</p> <p>Refer to <a href="#">Enhanced PCS TX and RX Control Ports</a> on page 83 section for more details.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| unused_tx_control[<n><15>-1:0]                       | Input     | Synchronous to the clock driving the write side of the FIFO (tx_coreclk or tx_clkout) | <p>This port is enabled when you enable <b>Enable simplified data interface</b>. Connect all of these bits to 0. When <b>Enable simplified data interface</b> is disabled, the unused bits are a part of the tx_control.</p> <p>Refer to tx_control to identify the bits you need to ground.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| tx_err_ins                                           | Input     | tx_coreclk                                                                            | <p>For the Interlaken protocol, you can use this bit to insert the synchronous header and CRC32 errors if you have turned on <b>Enable simplified data interface</b>.</p> <p>When asserted, the synchronous header for that cycle word is replaced with a corrupted one. A CRC32 error is also inserted if <b>Enable Interlaken TX CRC-32 generator error insertion</b> is turned on. The corrupted sync header is 2'b00 for a control word, and 2'b11 for a data word. For CRC32 error insertion, the word used for CRC calculation for that cycle is incorrectly inverted, causing an incorrect CRC32 in the Diagnostic Word of the Metaframe.</p> <p>Note that a synchronous header error and a CRC32 error cannot be created for the Framing Control Words because the Frame Control Words are created in the frame generator embedded in TX PCS. Both the synchronous header error and the CRC32 errors are inserted if the CRC-32 error insertion feature is enabled in the Transceiver Native PHY IP GUI.</p> |
| tx_coreclk                                           | Input     | Clock                                                                                 | The FPGA fabric clock. Drives the write side of the TX FIFO. For the Interlaken protocol, the frequency of this clock could be from datarate/67 to datarate/32. Using frequency lower than this range can cause the TX FIFO to underflow and result in data corruption.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| tx_clkout                                            | Output    | Clock                                                                                 | This is a parallel clock generated by the local CGB for non bonded configurations, and master CGB for bonded configurations. This clocks the blocks of the TX Enhanced PCS. The frequency of this clock is equal to the datarate divided by PCS/PMA interface width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

**Table 50. Enhanced RX PCS: Parallel Data, Control, and Clocks**

| Name                         | Direction | Clock Domain                                                                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------------|-----------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_parallel_data[<n>128-1:0] | Output    | Synchronous to the clock driving the read side of the FIFO (rx_coreclk in or rx_clkout) | <p>RX parallel data from the RX PCS to the FPGA fabric. If you select, <b>Enable simplified data interface</b> in the Transceiver Native PHY IP GUI, rx_parallel_data includes only the bits required for the configuration you specify. Otherwise, this interface is 128 bits wide.</p> <p>When FPGA fabric to PCS interface width is 64 bits, the following bits are active for interfaces less than 128 bits. You can leave the unused bits floating or not connected.</p> <ul style="list-style-type: none"> <li>• 32-bit FPGA fabric to PCS width: data[31:0].</li> <li>• 40-bit FPGA fabric to PCS width: data[39:0].</li> <li>• 64-bit FPGA fabric to PCS width: data[63:0].</li> </ul> <p>When the FPGA fabric to PCS interface width is 128 bits, the following bits are active:</p> <ul style="list-style-type: none"> <li>• 40-bit FPGA fabric to PCS width: data[103:64], [39:0].</li> <li>• 64-bit FPGA fabric to PCS width: data[127:0].</li> </ul> |
| unused_rx_parallel_data      | Output    | rx_clkout                                                                               | This signal specifies the unused data when you turn on <b>Enable simplified data interface</b> . When simplified data interface is not set, the unused bits are a part of rx_parallel_data. You can leave the unused data outputs floating or not connected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| rx_control[<n><20>-1:0]      | Output    | Synchronous to the clock driving the read side of the FIFO (rx_coreclk in or rx_clkout) | Indicates whether the rx_parallel_data bus is control or data.<br>Refer to the <a href="#">Enhanced PCS TX and RX Control Ports</a> on page 83 section for more details.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| unused_rx_control[<n>10-1:0] | Output    | Synchronous to the clock driving the read side of the FIFO (rx_coreclk in or rx_clkout) | These signals only exist when you turn on <b>Enable simplified data interface</b> . When simplified data interface is not set, the unused bits are a part of rx_control. These outputs can be left floating.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| rx_coreclkin                 | Input     | Clock                                                                                   | The FPGA fabric clock. Drives the read side of the RX FIFO. For Interlaken protocol, the frequency of this clock could be from datarate/67 to datarate/32.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| rx_clkout                    | Output    | Clock                                                                                   | The low speed parallel clock recovered by the transceiver RX PMA, that clocks the blocks in the RX Enhanced PCS. The frequency of this clock is equal to data rate divided by PCS/PMA interface width.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**Table 51. Enhanced PCS TX FIFO**

| Name                       | Direction | Clock Domain                                                                            | Description                                                                                                                                                                                                                                                                                                                             |
|----------------------------|-----------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_enh_data_valid[<n>-1:0] | Input     | Synchronous to the clock driving the write side of the FIFO (tx_coreclkin or tx_clkout) | Assertion of this signal indicates that the TX data is valid. Connect this signal to 1'b1 for 10GBASE-R without 1588. For 10GBASE-R with 1588, you must control this signal based on the gearbox ratio. For Basic and Interlaken, you need to control this port based on TX FIFO flags so that the FIFO does not underflow or overflow. |

*continued...*

| Name                        | Direction | Clock Domain                                                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------------|-----------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |           |                                                                                        | Refer to <a href="#">Enhanced PCS FIFO Operation</a> on page 304 for more details.                                                                                                                                                                                                                                                                                                                                                                   |
| tx_enh_fifo_full[<n>-1:0]   | Output    | Synchronous to the clock driving the write side of the FIFO<br>tx_coreclk or tx_clkout | Assertion of this signal indicates the TX FIFO is full. Because the depth is always constant, you can ignore this signal for the phase compensation mode.<br>Refer to <a href="#">Enhanced PCS FIFO Operation</a> on page 304 for more details.                                                                                                                                                                                                      |
| tx_enh_fifo_pfull[<n>-1:0]  | Output    | Synchronous to the clock driving the write side of the FIFO<br>tx_coreclk or tx_clkout | This signal gets asserted when the TX FIFO reaches its partially full threshold. Because the depth is always constant, you can ignore this signal for the phase compensation mode.<br>Refer to <a href="#">Enhanced PCS FIFO Operation</a> on page 304 for more details.                                                                                                                                                                             |
| tx_enh_fifo_empty[<n>-1:0]  | Output    | Synchronous to the clock driving the write side of the FIFO<br>tx_coreclk or tx_clkout | When asserted, indicates that the TX FIFO is empty. This signal gets asserted for 2 to 3 clock cycles. Because the depth is always constant, you can ignore this signal for the phase compensation mode.<br>Refer to <a href="#">Enhanced PCS FIFO Operation</a> on page 304 for more details.                                                                                                                                                       |
| tx_enh_fifo_pempty[<n>-1:0] | Output    | Synchronous to the clock driving the write side of the FIFO<br>tx_coreclk or tx_clkout | When asserted, indicates that the TX FIFO has reached its specified partially empty threshold. When you turn this option on, the Enhanced PCS enables the tx_enh_fifo_pempty port, which is asynchronous. This signal gets asserted for 2 to 3 clock cycles. Because the depth is always constant, you can ignore this signal for the phase compensation mode.<br>Refer to <a href="#">Enhanced PCS FIFO Operation</a> on page 304 for more details. |

**Table 52. Enhanced PCS RX FIFO**

| Name                       | Direction | Clock Domain                                                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------|-----------|---------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_enh_data_valid[<n>-1:0] | Output    | Synchronous to the clock driving the read side of the FIFO<br>rx_coreclk or rx_clkout | When asserted, indicates that rx_parallel_data is valid. Discard invalid RX parallel data when rx_enh_data_valid signal is low.<br>This option is available when you select the following parameters: <ul style="list-style-type: none"><li>• Enhanced PCS <b>Transceiver configuration rules</b> specifies Interlaken</li><li>• Enhanced PCS <b>Transceiver configuration rules</b> specifies Basic, and RX FIFO mode is <b>Phase compensation</b></li><li>• Enhanced PCS <b>Transceiver configuration rules</b> specifies Basic, and RX FIFO mode is <b>Register</b><br/>Refer to <a href="#">Enhanced PCS FIFO Operation</a> on page 304 for more details.</li></ul> |
| rx_enh_fifo_full[<n>-1:0]  | Output    | Synchronous to the clock driving the read side of the FIFO<br>rx_coreclk or rx_clkout | When asserted, indicates that the RX FIFO is full. This signal gets asserted for 2 to 3 clock cycles. Because the depth is always constant, you can ignore this signal for the phase compensation mode.<br>Refer to <a href="#">Enhanced PCS FIFO Operation</a> on page 304 for more details.                                                                                                                                                                                                                                                                                                                                                                           |
| rx_enh_fifo_pfull[<n>-1:0] | Output    | Synchronous to the clock driving the read side of                                     | When asserted, indicates that the RX FIFO has reached its specified partially full threshold. This signal gets asserted for 2 to 3 clock cycles. Because the depth is always constant, you can ignore this signal for the phase compensation mode.                                                                                                                                                                                                                                                                                                                                                                                                                      |

*continued...*

| Name                           | Direction | Clock Domain                                                                            | Description                                                                                                                                                                                                                                                         |
|--------------------------------|-----------|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                |           | the FIFO<br>rx_coreclkin<br>or rx_clkout                                                | Refer to Enhanced PCS FIFO Operation on page 304 for more details.                                                                                                                                                                                                  |
| rx_enh_fifo_empty[<n>-1:0]     | Output    | Synchronous to the clock driving the read side of the FIFO<br>rx_coreclkin or rx_clkout | When asserted, indicates that the RX FIFO is empty. Because the depth is always constant, you can ignore this signal for the phase compensation mode. Refer to Enhanced PCS FIFO Operation on page 304 for more details.                                            |
| rx_enh_fifo_pempty[<n>-1:0]    | Output    | Synchronous to the clock driving the read side of the FIFO<br>rx_coreclkin or rx_clkout | When asserted, indicates that the RX FIFO has reached its specified partially empty threshold. Because the depth is always constant, you can ignore this signal for the phase compensation mode. Refer to Enhanced PCS FIFO Operation on page 304 for more details. |
| rx_enh_fifo_del[<n>-1:0]       | Output    | Synchronous to the clock driving the read side of the FIFO<br>rx_coreclkin or rx_clkout | When asserted, indicates that a word has been deleted from the RX FIFO. This signal gets asserted for 2 to 3 clock cycles. This signal is used for the 10GBASE-R protocol.                                                                                          |
| rx_enh_fifo_insert[<n>-1:0]    | Output    | Synchronous to the clock driving the read side of the FIFO<br>rx_coreclkin or rx_clkout | When asserted, indicates that a word has been inserted into the RX FIFO. This signal is used for the 10GBASE-R protocol.                                                                                                                                            |
| rx_enh_fifo_rd_en[<n>-1:0]     | Output    | Synchronous to the clock driving the read side of the FIFO<br>rx_coreclkin or rx_clkout | For Interlaken only, when this signal is asserted, a word is read from the RX FIFO. You need to control this signal based on RX FIFO flags so that the FIFO does not underflow or overflow.                                                                         |
| rx_enh_fifo_align_val[<n>-1:0] | Input     | Synchronous to the clock driving the read side of the FIFO<br>rx_coreclkin or rx_clkout | When asserted, indicates that the word alignment pattern has been found. This signal is only valid for the Interlaken protocol.                                                                                                                                     |
| rx_enh_fifo_align_clr[<n>-1:0] | Input     | Synchronous to the clock driving the read side of the FIFO<br>rx_coreclkin or rx_clkout | When asserted, the FIFO resets and begins searching for a new alignment pattern. This signal is only valid for the Interlaken protocol. Assert this signal for at least 4 cycles.                                                                                   |

**Table 53. Interlaken Frame Generator, Synchronizer, and CRC32**

| Name                                | Direction | Clock Domain | Description                                                                                                                                                          |
|-------------------------------------|-----------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_enh_frame[<n>-1:0]               | Output    | tx_clkout    | Asserted for 2 or 3 parallel clock cycles to indicate the beginning of a new metaframe.                                                                              |
| tx_enh_frame_diag_status[<n> 2-1:0] | Input     | tx_clkout    | Drives the lane status message contained in the framing layer diagnostic word (bits[33:32]). This message is inserted into the next diagnostic word generated by the |

***continued...***

| Name                                | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                     |           |              | frame generator block. This bus must be held constant for 5 clock cycles before and after the tx_enh_frame pulse. The following encodings are defined: <ul style="list-style-type: none"> <li>Bit[1]: When 1, indicates the lane is operational. When 0, indicates the lane is not operational.</li> <li>Bit[0]: When 1, indicates the link is operational. When 0, indicates the link is not operational.</li> </ul>                                                                                                                                                                                  |
| tx_enh_frame_burst_en[<n>-1:0]      | Input     | tx_clkout    | If <b>Enable frame burst</b> is enabled, this port controls frame generator data reads from the TX FIFO to the frame generator. It is latched once at the beginning of each Metaframe. If the value of tx_enh_frame_burst_en is 0, the frame generator does not read data from the TX FIFO for current Metaframe. Instead, the frame generator inserts SKIP words as the payload of Metaframe. When tx_enh_frame_burst_en is 1, the frame generator reads data from the TX FIFO for the current Metaframe. This port must be held constant for 5 clock cycles before and after the tx_enh_frame pulse. |
| rx_enh_frame[<n>-1:0]               | Output    | rx_clkout    | When asserted, indicates the beginning of a new received Metaframe. This signal is pulse stretched.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| rx_enh_frame_lock[<n>-1:0]          | Output    | rx_clkout    | When asserted, indicates the Frame Synchronizer state machine has achieved Metaframe delineation. This signal is pulse stretched.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| rx_enh_frame_diag_status[2 <n>-1:0] | Output    | rx_clkout    | Drives the lane status message contained in the framing layer diagnostic word (bits[33:32]). This signal is latched when a valid diagnostic word is received in the end of the Metaframe while the frame is locked. The following encodings are defined: <ul style="list-style-type: none"> <li>Bit[1]: When 1, indicates the lane is operational. When 0, indicates the lane is not operational.</li> <li>Bit[0]: When 1, indicates the link is operational. When 0, indicates the link is not operational.</li> </ul>                                                                                |
| rx_enh_crc32_err[<n>-1:0]           | Output    | rx_clkout    | When asserted, indicates a CRC error in the current Metaframe. Asserted at the end of current Metaframe. This signal gets asserted for 2 or 3 cycles.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

**Table 54. 10GBASE-R BER Checker**

| Name                                                 | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                        |
|------------------------------------------------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_enh_highber[<n>-1:0]                              | Output    | rx_clkout    | When asserted, indicates a bit error rate that is greater than $10^{-4}$ . For the 10GBASE-R protocol, this BER rate occurs when there are at least 16 errors within 125 $\mu$ s. This signal gets asserted for 2 to 3 clock cycles.                                                                               |
| rx_enh_highber_clr_count[<n>-1:0]                    | Input     | rx_clkout    | When asserted, clears the internal counter that indicates the number of times the BER state machine has entered the BER_BAD_SH state.                                                                                                                                                                              |
| rx_enh_clr_errblk_count[<n>-1:0] (10GBASE-R and FEC) | Input     | rx_clkout    | When asserted the error block counter resets to 0. Assertion of this signal clears the internal counter that counts the number of times the RX state machine has entered the RX_E state. In modes where the FEC block is enabled, the assertion of this signal resets the status counters within the RX FEC block. |

**Table 55. Block Synchronizer**

| Name                     | Direction | Clock Domain | Description                                                                                                                        |
|--------------------------|-----------|--------------|------------------------------------------------------------------------------------------------------------------------------------|
| rx_enh_blk_lock<n>-1:0 ] | Output    | rx_clkout    | When asserted, indicates that block synchronizer has achieved block delineation. This signal is used for 10GBASE-R and Interlaken. |

**Table 56. Gearbox**

| Name                     | Direction | Clock Domain | Description                                                                                                                                                                                                                                                        |
|--------------------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_bitslip[<n>-1:0]      | Input     | rx_clkout    | The rx_parallel_data slips 1 bit for every positive edge of the rx_bitslip input. Keep the minimum interval between rx_bitslip pulses to at least 20 cycles. The maximum shift is <pcswidth -1> bits, so that if the PCS is 64 bits wide, you can shift 0-63 bits. |
| tx_enh_bitslip[<n>-1:0 ] | Input     | rx_clkout    | The value of this signal controls the number of bits to slip the tx_parallel_data before passing to the PMA.                                                                                                                                                       |

**Table 57. KR-FEC**

| Name                     | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                   |
|--------------------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_enh_frame[<n>-1:0]    | Output    | tx_clkout    | Asynchronous status flag output of TX KR-FEC that signifies the beginning of generated KR FEC frame                                                                                                                                                                                           |
| rx_enh_frame[<n>-1:0]    | Output    | rx_clkout    | Asynchronous status flag output of RX KR-FEC that signifies the beginning of received KR FEC frame                                                                                                                                                                                            |
| rx_enh_frame_diag_status | Output    | rx_clkout    | Asynchronous status flag output of RX KR-FEC that indicates the status of the current received frame. <ul style="list-style-type: none"> <li>• 00: No error</li> <li>• 01: Correctable Error</li> <li>• 10: Un-correctable error</li> <li>• 11: Reset condition/pre-lock condition</li> </ul> |

#### Related Information

- [ATX PLL IP Core](#) on page 363
- [CMU PLL IP Core](#) on page 379
- [fPLL IP Core](#) on page 371
- [Ports and Parameters](#) on page 547
- [Transceiver PHY Reset Controller Interfaces](#) on page 449

#### 2.4.9.1. Enhanced PCS TX and RX Control Ports

This section describes the tx\_control and rx\_control bit encodings for different protocol configurations.

When Enable simplified data interface is ON, all of the unused ports shown in the tables below, appear as a separate port. For example: It appears as unused\_tx\_control/ unused\_rx\_control port.

### Enhanced PCS TX Control Port Bit Encodings

**Table 58. Bit Encodings for Interlaken**

| Name       | Bit    | Functionality                            | Description                                                                                                                                                                   |
|------------|--------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_control | [1:0]  | Synchronous header                       | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word.                                                                                              |
|            | [2]    | Inversion control                        | A logic low indicates that the built-in disparity generator block in the Enhanced PCS maintains the Interlaken running disparity.                                             |
|            | [7:3]  | Unused                                   |                                                                                                                                                                               |
|            | [8]    | Insert synchronous header error or CRC32 | You can use this bit to insert synchronous header error or CRC32 errors. The functionality is similar to tx_err_ins. Refer to tx_err_ins signal description for more details. |
|            | [17:9] | Unused                                   |                                                                                                                                                                               |

**Table 59. Bit Encodings for 10GBASE-R , 10GBASE-KR with FEC**

| Name       | Bit    | Functionality                                 |
|------------|--------|-----------------------------------------------|
| tx_control | [0]    | XGMII control signal for parallel_data[7:0]   |
|            | [1]    | XGMII control signal for parallel_data[15:8]  |
|            | [2]    | XGMII control signal for parallel_data[23:16] |
|            | [3]    | XGMII control signal for parallel_data[31:24] |
|            | [4]    | XGMII control signal for parallel_data[39:32] |
|            | [5]    | XGMII control signal for parallel_data[47:40] |
|            | [6]    | XGMII control signal for parallel_data[55:48] |
|            | [7]    | XGMII control signal for parallel_data[63:56] |
|            | [17:8] | Unused                                        |

**Table 60. Bit Encodings for Basic Single Width Mode**

For basic single width mode, the total word length is 66-bit with 64-bit data and 2-bit synchronous header.

| Name       | Bit    | Functionality      | Description                                                                      |
|------------|--------|--------------------|----------------------------------------------------------------------------------|
| tx_control | [1:0]  | Synchronous header | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word. |
|            | [17:2] | Unused             |                                                                                  |

**Table 61. Bit Encodings for Basic Double Width Mode**

For basic double width mode, the total word length is 66-bit with 128-bit data and 4-bit synchronous header.

| Name       | Bit     | Functionality      | Description                                                                      |
|------------|---------|--------------------|----------------------------------------------------------------------------------|
| tx_control | [1:0]   | Synchronous header | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word. |
|            | [8:2]   | Unused             |                                                                                  |
|            | [10:9]  | Synchronous header | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word. |
|            | [17:11] | Unused             |                                                                                  |

**Table 62. Bit Encodings for Basic Mode**

In this case, the total word length is 67-bit with 64-bit data and 2-bit synchronous header.

| Name       | Bit   | Functionality      | Description                                                                                                        |
|------------|-------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| tx_control | [1:0] | Synchronous header | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word.                                   |
|            | [2]   | Inversion control  | A logic low indicates that built-in disparity generator block in the Enhanced PCS maintains the running disparity. |

### Enhanced PCS RX Control Port Bit Encodings

**Table 63. Bit Encodings for Interlaken**

| Name       | Bit     | Functionality                                                        | Description                                                                                                                                                                                                |
|------------|---------|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_control | [1:0]   | Synchronous header                                                   | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word.                                                                                                                           |
|            | [2]     | Inversion control                                                    | A logic low indicates that the built-in disparity generator block in the Enhanced PCS maintains the Interlaken running disparity. In the current implementation, this bit is always tied logic low (1'b0). |
|            | [3]     | Payload word location                                                | A logic high (1'b1) indicates the payload word location in a metaframe.                                                                                                                                    |
|            | [4]     | Synchronization word location                                        | A logic high (1'b1) indicates the synchronization word location in a metaframe.                                                                                                                            |
|            | [5]     | Scrambler state word location                                        | A logic high (1'b1) indicates the scrambler word location in a metaframe.                                                                                                                                  |
|            | [6]     | SKIP word location                                                   | A logic high (1'b1) indicates the SKIP word location in a metaframe.                                                                                                                                       |
|            | [7]     | Diagnostic word location                                             | A logic high (1'b1) indicates the diagnostic word location in a metaframe.                                                                                                                                 |
|            | [8]     | Synchronization header error, metaframe error, or CRC32 error status | A logic high (1'b1) indicates synchronization header error, metaframe error, or CRC32 error status.                                                                                                        |
|            | [9]     | Block lock and frame lock status                                     | A logic high (1'b1) indicates that block lock and frame lock have been achieved.                                                                                                                           |
|            | [19:10] | Unused                                                               |                                                                                                                                                                                                            |

**Table 64. Bit Encodings for 10GBASE-R , 10GBASE-KR with FEC**

| Name       | Bit | Functionality                                 |
|------------|-----|-----------------------------------------------|
| rx_control | [0] | XGMII control signal for parallel_data[7:0]   |
|            | [1] | XGMII control signal for parallel_data[15:8]  |
|            | [2] | XGMII control signal for parallel_data[23:16] |

*continued...*

| Name | Bit    | Functionality                                 |
|------|--------|-----------------------------------------------|
|      | [3]    | XGMII control signal for parallel_data[31:24] |
|      | [4]    | XGMII control signal for parallel_data[39:32] |
|      | [5]    | XGMII control signal for parallel_data[47:40] |
|      | [6]    | XGMII control signal for parallel_data[55:48] |
|      | [7]    | XGMII control signal for parallel_data[63:56] |
|      | [19:8] | Unused                                        |

**Table 65. Bit Encodings for Basic Single Width Mode**

For basic single width mode, the total word length is 66-bit with 64-bit data and 2-bit synchronous header.

| Name       | Bit     | Functionality                   | Description                                                                      |
|------------|---------|---------------------------------|----------------------------------------------------------------------------------|
| rx_control | [1:0]   | Synchronous header              | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word. |
|            | [7:2]   | Unused                          |                                                                                  |
|            | [9:8]   | Synchronous header error status | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word. |
|            | [19:10] | Unused                          |                                                                                  |

**Table 66. Bit Encodings for Basic Double Width Mode**

For basic double width mode, total word length is 66-bit with 128-bit data, and 4-bit synchronous header.

| Name       | Bit     | Functionality                   | Description                                                                      |
|------------|---------|---------------------------------|----------------------------------------------------------------------------------|
| rx_control | [1:0]   | Synchronous header              | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word. |
|            | [7:2]   | Unused                          |                                                                                  |
|            | [8]     | Synchronous header error status | Active-high status signal that indicates a synchronous header error.             |
|            | [9]     | Block lock is achieved          | Active-high status signal indicating when block lock is achieved.                |
|            | [11:10] | Synchronous header              | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word. |
|            | [17:12] | Unused                          |                                                                                  |
|            | [18]    | Synchronous header error status | Active-high status signal that indicates a synchronous header error.             |
|            | [19]    | Block lock is achieved          | Active-high status signal indicating when Block Lock is achieved.                |

**Table 67. Bit Encodings for Basic Mode**

In this case, the total word length is 67-bit with 64-bit data and 2-bit synchronous header.

| Name       | Bit   | Functionality      | Description                                                                                                        |
|------------|-------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| rx_control | [1:0] | Synchronous header | The value 2'b01 indicates a data word. The value 2'b10 indicates a control word.                                   |
|            | [2]   | Inversion control  | A logic low indicates that built-in disparity generator block in the Enhanced PCS maintains the running disparity. |

## 2.4.10. Standard PCS Ports

**Figure 25. Transceiver Channel using the Standard PCS Ports**

Standard PCS ports appear if either one of the transceiver configuration modes is selected that uses Standard PCS or if **Data Path Reconfiguration** is selected even if the transceiver configuration is not one of those that uses Standard PCS.



In the following tables, the variables represent these parameters:

- $<n>$ —The number of lanes
- $<w>$ —The width of the interface
- $<d>$ —The serialization factor
- $<s>$ — The symbol size
- $<p>$ —The number of PLLs

**Table 68. TX Standard PCS: Data, Control, and Clocks**

| Name                             | Direction | Clock Domain | Description                                                                                                                                                               |
|----------------------------------|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_parallel_data[<n><br>128-1:0] | Input     | tx_clkout    | TX parallel data input from the FPGA fabric to the TX PCS.                                                                                                                |
| unused_tx_parallel_d<br>ata      | Input     | tx_clkout    | This signal specifies the unused data when you turn on <b>Enable simplified data interface</b> . When simplified data interface is not set, the unused bits are a part of |

*continued...*

| Name         | Direction | Clock Domain | Description                                                                                                                                                                                        |
|--------------|-----------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |           |              | tx_parallel_data. Connect all these bits to 0. If you do not connect the unused data bits to 0, then TX parallel data may not be serialized correctly by the Native PHY IP core.                   |
| tx_coreclkin | Input     | Clock        | The FPGA fabric clock. This clock drives the write port of the TX FIFO.                                                                                                                            |
| tx_clkout    | Output    | Clock        | This is the parallel clock generated by the local CGB for non bonded configurations, and master CGB for bonded configuration. This clocks the tx_parallel_data from the FPGA fabric to the TX PCS. |

**Table 69. RX Standard PCS: Data, Control, Status, and Clocks**

| Name                          | Direction | Clock Domain                                                                            | Description                                                                                                                                                                                                                                 |
|-------------------------------|-----------|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_parallel_data[<n> 128-1:0] | Output    | Synchronous to the clock driving the read side of the FIFO (rx_coreclk in or rx_clkout) | RX parallel data from the RX PCS to the FPGA fabric. For each 128-bit word of rx_parallel_data, the data bits correspond to rx_parallel_data[7:0] when 8B/10B decoder is enabled and rx_parallel_data[9:0] when 8B/10B decoder is disabled. |
| unused_rx_parallel_data       | Output    | Synchronous to the clock driving the read side of the FIFO (rx_coreclk in or rx_clkout) | This signal specifies the unused data when you turn on <b>Enable simplified data interface</b> . When simplified data interface is not set, the unused bits are a part of rx_parallel_data. These outputs can be left floating.             |
| rx_clkout                     | Output    | Clock                                                                                   | The low speed parallel clock recovered by the transceiver RX PMA, that clocks the blocks in the RX Standard PCS.                                                                                                                            |
| rx_coreclkin                  | Input     | Clock                                                                                   | RX parallel clock that drives the read side clock of the RX FIFO.                                                                                                                                                                           |

**Table 70. Standard PCS FIFO**

| Name                         | Direction | Clock Domain                                                                             | Description                                   |
|------------------------------|-----------|------------------------------------------------------------------------------------------|-----------------------------------------------|
| tx_std_pcfifo_full[<n>-1:0]  | Output    | Synchronous to the clock driving the write side of the FIFO (tx_coreclk in or tx_clkout) | Indicates when the standard TX FIFO is full.  |
| tx_std_pcfifo_empty[<n>-1:0] | Output    | Synchronous to the clock driving the write side of the FIFO (tx_coreclk in or tx_clkout) | Indicates when the standard TX FIFO is empty. |
| rx_std_pcfifo_full[<n>-1:0]  | Output    | Synchronous to the clock driving the read side of                                        | Indicates when the standard RX FIFO is full.  |

*continued...*

| Name                         | Direction | Clock Domain                                                                                             | Description                                   |
|------------------------------|-----------|----------------------------------------------------------------------------------------------------------|-----------------------------------------------|
|                              |           | the FIFO<br>(rx_coreclkin or<br>rx_clkout)                                                               |                                               |
| rx_std_pcfifo_empty[<n>-1:0] | Output    | Synchronous<br>to the clock<br>driving the<br>read side of<br>the FIFO<br>(rx_coreclkin or<br>rx_clkout) | Indicates when the standard RX FIFO is empty. |

**Table 71. Rate Match FIFO**

| Name                         | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_std_rmfifo_full[<n>-1:0]  | Output    | Asynchronous | Rate match FIFO full flag. When asserted the rate match FIFO is full. You must synchronize this signal. This port is only used for GigE mode.                                                                                                                                                                                                                             |
| rx_std_rmfifo_empty[<n>-1:0] | Output    | Asynchronous | Rate match FIFO empty flag. When asserted, match FIFO is empty. You must synchronize this signal. This port is only used for GigE mode.                                                                                                                                                                                                                                   |
| rx_rmfifostatus[<n>-1:0]     | Output    | Asynchronous | Indicates FIFO status. The following encodings are defined: <ul style="list-style-type: none"><li>• 2'b00: Normal operation</li><li>• 2'b01: Deletion, rx_std_rmfifo_full = 1</li><li>• 2'b10: Insertion, rx_std_rmfifo_empty = 1</li><li>• 2'b11: Full. rx_rmfifostatus is a part of rx_parallel_data. rx_rmfifostatus corresponds to rx_parallel_data[14:13].</li></ul> |

**Table 72. 8B/10B Encoder and Decoder**

| Name                          | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                 |
|-------------------------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_datak                      | Input     | tx_clkout    | tx_datak is exposed if 8B/10B enabled and simplified data interface is set. When 1, indicates that the 8B/10B encoded word of tx_parallel_data is control. When 0, indicates that the 8B/10B encoded word of tx_parallel_data is data. tx_datak is a part of tx_parallel_data when simplified data interface is not set.    |
| tx_forcedisp[<n>(<w>/<s>-1:0] | Input     | Asynchronous | This signal allows you to force the disparity of the 8B/10B encoder. When "1", forces the disparity of the output data to the value driven on tx_dispval. When "0", the current running disparity continues. tx_forcedisp is a part of tx_parallel_data. tx_forcedisp corresponds to tx_parallel_data[9].                   |
| tx_dispval[<n>(<w>/<s>-1:0]   | Input     | Asynchronous | Specifies the disparity of the data. When 0, indicates positive disparity, and when 1, indicates negative disparity. tx_dispval is a part of tx_parallel_data. tx_dispval corresponds to tx_dispval[10].                                                                                                                    |
| rx_datak[<n><w>/<s>-1:0]      | Output    | rx_clkout    | rx_datak is exposed if 8B/10B is enabled and simplified data interface is set. When 1, indicates that the 8B/10B decoded word of rx_parallel_data is control. When 0, indicates that the 8B/10B decoded word of rx_parallel_data is data. rx_datak is a part of rx_parallel_data when simplified data interface is not set. |

*continued...*

| Name                             | Direction | Clock Domain                                                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------------|-----------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_errdetect[<n><w>/<s>-1:0]     | Output    | Synchronous to the clock driving the read side of the FIFO (rx_coreclkin or rx_clkout) | When asserted, indicates a code group violation detected on the received code group. Used along with rx_disperr signal to differentiate between code group violation and disparity errors. The following encodings are defined for rx_errdetect/rx_disperr: <ul style="list-style-type: none"><li>• 2'b00: no error</li><li>• 2'b10: code group violation</li><li>• 2'b11: disparity error. rx_errdetect is a part of rx_parallel_data. For each 128-bit word, rx_errdetect corresponds to rx_parallel_data[9].</li></ul> |
| rx_disperr[<n><w>/<s>-1:0]       | Output    | Synchronous to the clock driving the read side of the FIFO (rx_coreclkin or rx_clkout) | When asserted, indicates a disparity error on the received code group. rx_disperr is a part of rx_parallel_data. For each 128-bit word, rx_disperr corresponds to rx_parallel_data[11].                                                                                                                                                                                                                                                                                                                                   |
| rx_runningdisp[<n><w>/<s>-1:0]   | Output    | Synchronous to the clock driving the read side of the FIFO (rx_coreclkin or rx_clkout) | When high, indicates that rx_parallel_data was received with negative disparity. When low, indicates that rx_parallel_data was received with positive disparity. rx_runningdisp is a part of rx_parallel_data. For each 128 bit word, rx_runningdisp corresponds to rx_parallel_data[15].                                                                                                                                                                                                                                 |
| rx_patterndetect[<n><w>/<s>-1:0] | Output    | Asynchronous                                                                           | When asserted, indicates that the programmed word alignment pattern has been detected in the current word boundary. rx_patterndetect is a part of rx_parallel_data. For each 128-bit word, rx_patterndetect corresponds to rx_parallel_data[12].                                                                                                                                                                                                                                                                          |
| rx_syncstatus[<n><w>/<s>-1:0]    | Output    | Asynchronous                                                                           | When asserted, indicates that the conditions required for synchronization are being met. rx_syncstatus is a part of rx_parallel_data. For each 128-bit word, rx_syncstatus corresponds to rx_parallel_data[10].                                                                                                                                                                                                                                                                                                           |

**Table 73. Word Aligner and Bitslip**

| Name                                  | Direction | Clock Domain             | Description                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------|-----------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_std_bitslipboundary sel[5 <n>-1:0] | Input     | Asynchronous             | Bitslip boundary selection signal. Specifies the number of bits that the TX bit slipper must slip.                                                                                                                                                                                                                                                                                                                         |
| rx_std_bitslipboundary sel[5 <n>-1:0] | Output    | Asynchronous             | This port is used in deterministic latency word aligner mode. This port reports the number of bits that the RX block slipped. This port values should be taken into consideration in either Deterministic Latency Mode or Manual Mode of Word Aligner.                                                                                                                                                                     |
| rx_std_wa_patternalign n[<n>-1:0]     | Input     | Synchronous to rx_clkout | Active when you place the word aligner in manual mode. In manual mode, you align words by asserting rx_std_wa_patternalign. When the PCS-PMA Interface width is 10 bits, rx_std_wa_patternalign is level sensitive. For all the other PCS-PMA Interface widths, rx_std_wa_patternalign is positive edge sensitive. You can use this port only when the word aligner is configured in manual or deterministic latency mode. |

*continued...*

| Name                        | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |           |              | <p>When the word aligner is in manual mode, and the PCS-PMA interface width is 10 bits, this is a level sensitive signal. In this case, the word aligner monitors the input data for the word alignment pattern, and updates the word boundary when it finds the alignment pattern.</p> <p>For all other PCS-PMA interface widths, this signal is edge sensitive. This signal is internally synchronized inside the PCS using the PCS parallel clock and should be asserted for at least 2 clock cycles to allow synchronization.</p> |
| rx_std_wa_a1a2size[<n>-1:0] | Input     | Asynchronous | Used for the SONET protocol. Assert when the A1 and A2 framing bytes must be detected. A1 and A2 are SONET backplane bytes and are only used when the PMA data width is 8 bits.                                                                                                                                                                                                                                                                                                                                                       |
| rx_bitslip[<n>-1:0]         | Input     | Asynchronous | Used when word aligner mode is bitslip mode. When the Word Aligner is in either Manual (PLD controlled), Synchronous State Machine or Deterministic Latency ,the rx_bitslip signal is not valid and should be tied to 0. For every rising edge of the rx_std_bitslip signal, the word boundary is shifted by 1 bit. Each bitslip removes the earliest received bit from the received data.                                                                                                                                            |

**Table 74. Bit Reversal and Polarity Inversion**

| Name                         | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                 |
|------------------------------|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_std_byterev_ena[<n>-1:0]  | Input     | Asynchronous | This control signal is available when the PMA width is 16 or 20 bits. When asserted, enables byte reversal on the RX interface. Used if the MSB and LSB of the transmitted data are erroneously swapped.                                                                                                                                    |
| rx_std_bitrev_ena[<n>-1:0]   | Input     | Asynchronous | When asserted, enables bit reversal on the RX interface. Bit order may be reversed if external transmission circuitry transmits the most significant bit first. When enabled, the receive circuitry receives all words in the reverse order. The bit reversal circuitry operates on the output of the word aligner.                         |
| tx_polinv[<n>-1:0]           | Input     | Asynchronous | When asserted, the TX polarity bit is inverted. Only active when TX bit polarity inversion is enabled.                                                                                                                                                                                                                                      |
| rx_polinv[<n>-1:0]           | Input     | Asynchronous | When asserted, the RX polarity bit is inverted. Only active when RX bit polarity inversion is enabled.                                                                                                                                                                                                                                      |
| rx_std_signaldetect[<n>-1:0] | Output    | Asynchronous | When enabled, the signal threshold detection circuitry senses whether the signal level present at the RX input buffer is above the signal detect threshold voltage. You can specify the signal detect threshold using a Quartus Prime Settings File (.qsf) assignment. This signal is required for the PCI Express, SATA and SAS protocols. |

### Related Information

- [ATX PLL IP Core](#) on page 363
- [CMU PLL IP Core](#) on page 379
- [fPLL IP Core](#) on page 371
- [Ports and Parameters](#) on page 547
- [Transceiver PHY Reset Controller Interfaces](#) on page 449
- [Analog Parameter Settings](#) on page 597

## 2.4.11. IP Core File Locations

When you generate your Transceiver Native PHY IP, the Quartus® Prime software generates the HDL files that define your instance of the IP. In addition, the Quartus Prime software generates an example Tcl script to compile and simulate your design in the ModelSim\* simulator. It also generates simulation scripts for Synopsys\* VCS, Aldec\* Active-HDL, Aldec Riviera-Pro, and Cadence\* Incisive Enterprise.

**Figure 26. Directory Structure for Generated Files**



The following table describes the directories and the most important files for the parameterized Transceiver Native PHY IP core and the simulation environment. These files are in clear text.

**Table 75. Transceiver Native PHY Files and Directories**

| File Name                     | Description                                                                        |
|-------------------------------|------------------------------------------------------------------------------------|
| <project_dir>                 | The top-level project directory.                                                   |
| <your_ip_name>.v or .vhdl     | The top-level design file.                                                         |
| <your_ip_name>.qip            | A list of all files necessary for Quartus Prime compilation.                       |
| <your_ip_name>.bsf            | A Block Symbol File (.bsf) for your Transceiver Native PHY instance.               |
| <project_dir>/<your_ip_name>/ | The directory that stores the HDL files that define the Transceiver Native PHY IP. |
| <project_dir>/sim             | The simulation directory.                                                          |
| <project_dir>/sim/aldec       | Simulation files for Riviera-PRO simulation tools.                                 |
| <project_dir>/sim/cadence     | Simulation files for Cadence simulation tools.                                     |
| <project_dir>/sim/mentor      | Simulation files for Mentor simulation tools.                                      |
| <project_dir>/sim/synopsys    | Simulation files for Synopsys simulation tools.                                    |
| <project_dir>/synth           | The directory that stores files used for synthesis.                                |

The Verilog and VHDL Transceiver Native PHY IP cores have been tested with the following simulators:

- ModelSim SE
- Synopsys VCS MX
- Cadence NCSim

If you select VHDL for your transceiver PHY, only the wrapper generated by the Quartus Prime software is in VHDL. All the underlying files are written in Verilog or SystemVerilog. To enable simulation using a VHDL-only ModelSim license, the underlying Verilog and SystemVerilog files for the Transceiver Native PHY IP are encrypted so that they can be used with the top-level VHDL wrapper without using a mixed-language simulator.

For more information about simulating with ModelSim, refer to the *Mentor Graphics ModelSim and QuestaSim Support* chapter in volume 3 of the *Quartus Prime Handbook*.

The Transceiver Native PHY IP cores do not support the NativeLink feature in the Quartus Prime software.

#### Related Information

- [Simulating the Transceiver Native PHY IP Core](#) on page 332
- [Mentor Graphics ModelSim and QuestaSim Support](#)

#### 2.4.12. Unused Transceiver RX Channels

To prevent performance degradation of unused transceiver RX channels over time, the following assignments must be added to an Arria 10 device QSF. You can either use a global assignment or per-pin assignments.

```
set_global_assignment -name PRESERVE_UNUSED_XCVR_CHANNEL ON  
or
```

```
set_instance_assignment -name PRESERVE_UNUSED_XCVR_CHANNEL ON -to  
<pin_name> (U34, for example)>
```

An example of a <pin\_name> is U34, not PIN\_U34.

When you perform this procedure, the Intel Quartus Prime software instantiates the clock data recovery (CDR) PLL corresponding to each unused receiver channel. The CDR uses CLKUSR as reference clock and is configured to run at 1 Gbps. To use CLKUSR as reference clock, the pin must be assigned a 100- to 125 MHz clock. When you implement these assignments, it causes a power consumption increase per receiver channel. Please contact your local support center for details.

#### Related Information

[Unused/Idle Clock Line Requirements](#) on page 399

### 2.4.13. Unsupported Features

Native PHY should not be included in QXP.

## 2.5. Interlaken

Interlaken is a scalable, channelized chip-to-chip interconnect protocol.

The key advantages of Interlaken are scalability and low I/O count compared to earlier protocols such as SPI 4.2. Other key features include flow control, low overhead framing, and extensive integrity checking. Interlaken operates on 64-bit data words and 3 control bits, which are striped round-robin across the lanes. The protocol accepts packets on 256 logical channels and is expandable to accommodate up to 65,536 logical channels. Packets are split into small bursts that can optionally be interleaved. The burst semantics include integrity checking and per logical channel flow control.

The Interlaken interface is supported with 1 to 48 lanes running at data rates up to 12.5 Gbps per lane on Arria 10 devices. Interlaken is implemented using the Enhanced PCS. The Enhanced PCS has demonstrated interoperability with Interlaken ASSP vendors and third-party IP suppliers.

Arria 10 devices provide three preset variations for Interlaken in the Arria 10 Transceiver Native PHY IP Parameter Editor:

- Interlaken 10x12.5 Gbps
- Interlaken 1x6.25 Gbps
- Interlaken 6x10.3 Gbps

Depending on the line rate, the enhanced PCS can use a PMA to PCS interface width of 32, 40, or 64 bits.

**Figure 27. Transceiver Channel Datapath and Clocking for Interlaken**

This figure assumes the serial data rate is 12.5 Gbps and the PMA width is 40 bits.



### Related Information

- [Interlaken Protocol Definition v1.2](#)
- [Interlaken Look-Aside Protocol Definition, v1.1](#)

#### 2.5.1. Metaframe Format and Framing Layer Control Word

The Enhanced PCS supports programmable metaframe lengths from 5 to 8192 words. However, for stability and performance, Intel recommends you set the frame length to no less than 128 words. In simulation, use a smaller metaframe length to reduce simulation times. The payload of a metaframe could be pure data payload and a Burst/Idle control word from the MAC layer.

**Figure 28. Framing Layer Metaframe Format**


The framing control words include:

- Synchronization (SYNC)—for frame delineation and lane alignment (deskew)
- Scrambler State (SCRM)—to synchronize the scrambler
- Skip (SKIP)—for clock compensation in a repeater
- Diagnostic (DIAG)—provides per-lane error check and optional status message

To form a metaframe, the Enhanced PCS frame generator inserts the framing control words and encapsulates the control and data words read from the TX FIFO as the metaframe payload.

**Figure 29. Interlaken Synchronization and Scrambler State Words Format**

|      |         |                  |  |
|------|---------|------------------|--|
| bx10 | b011110 | h0F678F678F678F6 |  |
| bx10 | b001010 | Scrambler State  |  |

66      63      58 57      0

**Figure 30. Interlaken Skip Word Format**

|      |         |       |       |     |     |     |     |     |
|------|---------|-------|-------|-----|-----|-----|-----|-----|
| bx10 | b000111 | h21E  | h1E   | h1E | h1E | h1E | h1E | h1E |
| 66   | 63      | 58 57 | 48 47 | 40  |     |     |     | 0   |

The DIAG word is comprised of a status field and a CRC-32 field. The 2-bit status is defined by the Interlaken specification as:

- Bit 1 (Bit 33): Lane health
  - 1: Lane is healthy
  - 0: Lane is not healthy
- Bit 0 (Bit 32): Link health
  - 1: Link is healthy
  - 0: Link is not healthy

The tx\_enh\_frame\_diag\_status[1:0] input from the FPGA fabric is inserted into the Status field each time a DIAG word is created by the framing generator.

**Figure 31. Interlaken Diagnostic Word**

|      |         |         |        |         |
|------|---------|---------|--------|---------|
| bx10 | b011001 | h000000 | Status | CRC32   |
| 66   | 63      | 58 57   | 34 33  | 32 31 0 |

## 2.5.2. Interlaken Configuration Clocking and Bonding

The Arria 10 Interlaken PHY layer solution is scalable and has flexible data rates. You can implement a single lane link or bond up to 48 lanes together. You can choose a lane data rate up to 17.4 Gbps for GX devices and 25.8 Gbps for GT devices. You can also choose between different reference clock frequencies, depending on the PLL used to clock the transceiver. Refer to the *Arria 10 Device Datasheet* for the minimum and maximum data rates that Arria 10 transceivers can support at different speed grades.

You can use an ATX PLL or fPLL to provide the clock for the transmit channel. An ATX PLL has better jitter performance compared to an fPLL. You can use the CMU PLL to clock only the non-bonded Interlaken transmit channels. However, if you use the CMU PLL, you lose one RX transceiver channel.

For the multi-lane Interlaken interface, TX channels are usually bonded together to minimize the transmit skew between all bonded channels. Currently, xN bonding and PLL feedback compensation bonding schemes are available to support a multi-lane Interlaken implementation. If the system tolerates higher channel-to-channel skew, you can choose to not bond the TX channels.

To implement bonded multi-channel Interlaken, all channels must be placed contiguously. The channels may all be placed in one bank (if not greater than six lanes) or they may span several banks.

### Related Information

- [Using PLLs and Clock Networks](#) on page 410  
For more information about implementing PLLs and clocks
- [Arria 10 Device Datasheet](#)

### 2.5.2.1. xN Clock Bonding Scenario

The following figure shows a xN bonding example supporting 10 lanes. Each lane is running at 12.5 Gbps. The first six TX channels reside in one transceiver bank and the other four TX channels reside in the adjacent transceiver bank. The ATX PLL provides the serial clock to the master CGB. The CGB then provides parallel and serial clocks to all of the TX channels inside the same bank and other banks through the xN clock network.

Because of xN clock network skew, the maximum achievable data rate decreases when TX channels span several transceiver banks.

**Figure 32. 10X12.5 Gbps xN Bonding**


#### Related Information

- [Implementing x6/xN Bonding Mode](#) on page 416  
For detailed information on xN bonding limitations
- [Using PLLs and Clock Networks](#) on page 410  
For more information about implementing PLLs and clocks

#### 2.5.2.2. TX Multi-Lane Bonding and RX Multi-Lane Deskew Alignment State Machine

The Interlaken configuration sets the enhanced PCS TX and RX FIFOs in Interlaken elastic buffer mode. In this mode of operation, TX and RX FIFO control and status port signals are provided to the FPGA fabric. Connect these signals to the MAC layer as required by the protocol. Based on these FIFO status and control signals, you can implement the multi-lane deskew alignment state machine in the FPGA fabric to control the transceiver RX FIFO block.

**Note:** You must also implement the soft bonding logic to control the transceiver TX FIFO block.

#### 2.5.2.2.1. TX FIFO Soft Bonding

The MAC layer logic and TX soft bonding logic control the writing of the Interlaken word to the TX FIFO with `tx_enh_data_valid` (functions as a TX FIFO write enable) by monitoring the TX FIFO flags (`tx_fifo_full`, `tx_fifo_pfull`, `tx_fifo_empty`, `tx_fifo_pempty`, and so forth). On the TX FIFO read side, a read enable is controlled by the frame generator. If `tx_enh_frame_burst_en` is asserted high, the frame generator reads data from the TX FIFO.

A TX FIFO pre-fill stage must be implemented to perform the TX channel soft bonding. The following figure shows the state of the pre-fill process.

**Figure 33. TX Soft Bonding Flow**


The following figure shows that after deasserting `tx_digitalreset`, TX soft bonding logic starts filling the TX FIFO until all lanes are full.

**Figure 34. TX FIFO Pre-fill (6-lane Interface)**



After the TX FIFO pre-fill stage completes, the transmit lanes synchronize and the MAC layer begins to send valid data to the transceiver's TX FIFO. You must never allow the TX FIFO to overflow or underflow. If it does, you must reset the transceiver and repeat the TX FIFO pre-fill stage.

For a single lane Interlaken implementation, TX FIFO soft bonding is not required. You can begin sending an Interlaken word to the TX FIFO after tx\_digitalreset deasserts.

The following figure shows the MAC layer sending valid data to the Native PHY after the pre-fill stage. `tx_enh_frame_burst_en` is asserted, allowing the frame generator to read data from the TX FIFO. The TX MAC layer can now control `tx_enh_data_valid` and write data to the TX FIFO based on the FIFO status signals.

**Figure 35. MAC Sending Valid Data (6-lane Interface)**



#### 2.5.2.2.2. RX Multi-lane FIFO Deskew State Machine

Add deskew logic at the receiver side to eliminate the lane-to-lane skew created at the transmitter of the link partner, PCB, medium, and local receiver PMA.

Implement a multi-lane alignment deskew state machine to control the RX FIFO operation based on available RX FIFO status flags and control signals.

**Figure 36. State Flow of the RX FIFO Deskew**


Each lane's `rx_enh_fifo_rd_en` should remain deasserted before the RX FIFO deskew is completed. After frame lock is achieved (indicated by the assertion of `rx_enh_frame_lock`; this signal is not shown in the above state flow), data is written into the RX FIFO after the first alignment word (SYNC word) is found on that channel. Accordingly, the RX FIFO partially empty flag (`rx_enh_fifo_pempty`) of that channel is asserted. The state machine monitors the `rx_enh_fifo_pempty` and `rx_enh_fifo_pfull` signals of all channels. If the `rx_enh_fifo_pempty` signals from all channels deassert before any channels `rx_enh_fifo_pfull` assert, which implies the SYNC word has been found on all lanes of the link, the MAC layer can start reading from all the RX FIFO by asserting `rx_enh_fifo_rd_en` simultaneously. Otherwise, if the `rx_enh_fifo_pfull` signal of any channel asserts high before the `rx_enh_fifo_pempty` signals deassertion on all channels, the state machine needs to flush the RX FIFO by asserting `rx_enh_fifo_align_clr` high for 4 cycles and repeating the soft deskew process.

The following figure shows one RX deskew scenario. In this scenario, all of the RX FIFO partially empty lanes are deasserted while the pfull lanes are still deasserted. This indicates the deskew is successful and the FPGA fabric starts reading data from the RX FIFO.

**Figure 37. RX FIFO Deskew**



### 2.5.3. How to Implement Interlaken in Arria 10 Transceivers

You should be familiar with the Interlaken protocol, Enhanced PCS and PMA architecture, PLL architecture, and the reset controller before implementing the Interlaken protocol PHY layer.

Arria 10 devices provide three preset variations for Interlaken in the IP Parameter Editor:

- Interlaken 10x12.5 Gbps
- Interlaken 1x6.25 Gbps
- Interlaken 6x10.3 Gbps

1. Instantiate the **Arria 10 Transceiver Native PHY IP** from the IP Catalog (**Installed IP > Library > Interface Protocols > Transceiver PHY > Arria 10 Transceiver Native PHY**). Refer to [Select and Instantiate the PHY IP Core](#) on page 33 for more details.
2. Select **Interlaken** from the **Transceiver configuration rules** list located under **Datapath Options**, depending on which protocol you are implementing.
3. Use the parameter values in the tables in [Transceiver Native PHY IP Parameters for Interlaken Transceiver Configuration Rules](#). Or you can use the protocol presets described in [Transceiver Native PHY Presets](#). You can then modify the settings to meet your specific requirements.
4. Click **Generate** to generate the Native PHY IP (this is your RTL file).

**Figure 38. Signals and Ports of Native PHY IP for Interlaken**

**Notes:**

- (1) The width of `tx_parallel_data` and `tx_control` depends on whether the simplified interface is enabled or not. If the simplified interface is enabled, then `tx_parallel_data` = 64 bits and `tx_control` = 3 bits. The width shown here is without simplified interface.
- (2) The width of `rx_parallel_data` and `rx_control` depends on whether the simplified interface is enabled or not. If the simplified interface is enabled, then `rx_parallel_data` = 64 bits and `rx_control` = 10 bits. The width shown here is without simplified interface.

5. Configure and instantiate your PLL.
6. Create a transceiver reset controller. You can use your own reset controller or use the Transceiver PHY Reset Controller.
7. Implement a TX soft bonding logic and an RX multi-lane alignment deskew state machine using fabric logic resources for multi-lane Interlaken implementation.
8. Connect the Native PHY IP to the PLL IP and the reset controller.

**Figure 39. Connection Guidelines for an Interlaken PHY Design**

This figure shows the connection of all these blocks in the Interlaken PHY design example available on the Intel FPGA Wiki website.

For the blue blocks, Intel provides an IP core. The gray blocks use the TX soft bonding logic that is included in the design example. The white blocks are your test logic or MAC layer logic.



9. Simulate your design to verify its functionality.

**Figure 40. 24 Lanes Bonded Interlaken Link, TX Direction**

To show more details, three different time segments are shown with the same zoom level.



24 lanes bonded Interlaken link, TX direction

**Figure 41. 24 Lanes Bonded Interlaken Link, RX Direction**

To show more details, three different time segments are shown with different zoom level.



### Related Information

- [Arria 10 Enhanced PCS Architecture](#) on page 473  
For more information about Enhanced PCS architecture
- [Arria 10 PMA Architecture](#) on page 459  
For more information about PMA architecture
- [Using PLLs and Clock Networks](#) on page 410  
For more information about implementing PLLs and clocks
- [PLLs](#) on page 358  
PLL architecture and implementation details
- [Resetting Transceiver Channels](#) on page 428  
Reset controller general information and implementation details
- [Enhanced PCS Ports](#) on page 77  
For detailed information about the available ports in the Interlaken protocol

### 2.5.4. Design Example

Intel provides a PHY layer-only design example to help you integrate an Interlaken PHY into your complete design.

The TX soft bonding logic is included in the design example. Intel recommends that you integrate this module into your design.

The *Interlaken Design Example* is available on the Arria 10 Transceiver PHY Design Examples Wiki page.

**Note:** The design examples on the Wiki page provide useful guidance for developing your own designs, but they are not guaranteed by Intel. Use them with caution.

### Related Information

[Interlaken Design Example](#)

## 2.5.5. Native PHY IP Parameter Settings for Interlaken

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

**Table 76. General and Datapath Parameters**

| Parameter                                            | Value                                                                                                 |
|------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| <b>Message level for rule violations</b>             | <b>error</b><br><b>warning</b>                                                                        |
| <b>Transceiver configuration rules</b>               | <b>Interlaken</b>                                                                                     |
| <b>PMA configuration rules</b>                       | <b>basic</b>                                                                                          |
| <b>Transceiver mode</b>                              | <b>TX / RX Duplex</b><br><b>TX Simplex</b><br><b>RX Simplex</b>                                       |
| <b>Number of data channels</b>                       | <b>1 to 96</b>                                                                                        |
| <b>Data rate</b>                                     | <b>Up to 17.4 Gbps for GX devices</b><br>(Depending on Enhanced PCS to PMA interface width selection) |
| <b>Enable datapath and interface reconfiguration</b> | <b>On / Off</b>                                                                                       |
| <b>Enable simplified data interface</b>              | <b>On / Off</b>                                                                                       |
| <b>Provide separate interface for each channel</b>   | <b>On / Off</b>                                                                                       |

**Table 77. TX PMA Parameters**

| Parameter                                        | Value                                                                                                                                           |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TX channel bonding mode</b>                   | <b>Not bonded</b><br><b>PMA-only bonding</b><br><b>PMA and PCS bonding</b>                                                                      |
| <b>PCS TX channel bonding master</b>             | If <b>TX channel bonding mode</b> is set to <b>PMA and PCS bonding</b> , then:<br><b>Auto, 0, 1, 2, 3 through [Number of data channels - 1]</b> |
| <b>Actual PCS TX channel bonding master</b>      | If <b>TX channel bonding mode</b> is set to <b>PMA and PCS bonding</b> , then:<br><b>0, 1, 2, 3 through [Number of data channels - 1]</b>       |
| <b>TX local clock division factor</b>            | If <b>TX channel bonding mode</b> is not bonded, then:<br><b>1, 2, 4, 8</b>                                                                     |
| <b>Number of TX PLL clock inputs per channel</b> | If <b>TX channel bonding mode</b> is not bonded, then:<br><b>1, 2, 3, 4</b>                                                                     |
| <b>Initial TX PLL clock input selection</b>      | <b>0</b>                                                                                                                                        |
| <b>Enable tx_pma_clkout port</b>                 | <b>On / Off</b>                                                                                                                                 |
| <b>Enable tx_pma_div_clkout port</b>             | <b>On / Off</b>                                                                                                                                 |
| <b>tx_pma_div_clkout division factor</b>         | When <b>Enable tx_pma_div_clkout port</b> is <b>On</b> , then:<br><b>Disabled, 1, 2, 33, 40, 66</b>                                             |
| <b>Enable tx_pma_elecidle port</b>               | <b>On / Off</b>                                                                                                                                 |
| <b>Enable tx_pma_qpipullup port (QPI)</b>        | <b>Off</b>                                                                                                                                      |

*continued...*

| Parameter                                  | Value           |
|--------------------------------------------|-----------------|
| <b>Enable tx_pma_qpipuldn port (QPI)</b>   | <b>Off</b>      |
| <b>Enable tx_pma_txdetectrx port (QPI)</b> | <b>Off</b>      |
| <b>Enable tx_pma_rxfound port (QPI)</b>    | <b>Off</b>      |
| <b>Enable rx_serialpbken port</b>          | <b>On / Off</b> |

**Table 78. RX PMA Parameters**

| Parameter                                                  | Value                                                                                               |
|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| <b>Number of CDR reference clocks</b>                      | <b>1 to 5</b>                                                                                       |
| <b>Selected CDR reference clock</b>                        | <b>0 to 4</b>                                                                                       |
| <b>Selected CDR reference clock frequency</b>              | Select legal range defined by the Quartus Prime software                                            |
| <b>PPM detector threshold</b>                              | <b>100, 300, 500, 1000</b>                                                                          |
| <b>CTLE adaptation mode</b>                                | <b>manual,</b>                                                                                      |
| <b>DFE adaptation mode</b>                                 | <b>adaptation enabled, manual, disabled</b>                                                         |
| <b>Number of fixed dfe taps</b>                            | <b>3, 7, 11</b>                                                                                     |
| <b>Enable rx_pma_clkout port</b>                           | <b>On / Off</b>                                                                                     |
| <b>Enable rx_pma_div_clkout port</b>                       | <b>On / Off</b>                                                                                     |
| <b>rx_pma_div_clkout division factor</b>                   | When <b>Enable rx_pma_div_clkout port</b> is <b>On</b> , then:<br><b>Disabled, 1, 2, 33, 40, 66</b> |
| <b>Enable rx_pma_clkslip port</b>                          | <b>On / Off</b>                                                                                     |
| <b>Enable rx_pma_qpipuldn port (QPI)</b>                   | <b>Off</b>                                                                                          |
| <b>Enable rx_is_lockedtodata port</b>                      | <b>On / Off</b>                                                                                     |
| <b>Enable rx_is_lockedtoref port</b>                       | <b>On / Off</b>                                                                                     |
| <b>Enable rx_set_locktodata and rx_set_locktoref ports</b> | <b>On / Off</b>                                                                                     |
| <b>Enable rx_serialpbken port</b>                          | <b>On / Off</b>                                                                                     |
| <b>Enable PRBS verifier control and status ports</b>       | <b>On / Off</b>                                                                                     |

**Table 79. Enhanced PCS Parameters**

| Parameter                                         | Value                                                                                                                             |
|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| <b>Enhanced PCS / PMA interface width</b>         | <b>32, 40, 64</b>                                                                                                                 |
| <b>FPGA fabric / Enhanced PCS interface width</b> | <b>67</b>                                                                                                                         |
| <b>Enable 'Enhanced PCS' low latency mode</b>     | Allowed when the PMA interface width is 32 and preset variations for data rate is 10.3125 Gbps or 6.25 Gbps; otherwise <b>Off</b> |
| <b>Enable RX/TX FIFO double-width mode</b>        | <b>Off</b>                                                                                                                        |
| <b>TX FIFO mode</b>                               | <b>Interlaken</b>                                                                                                                 |
| <b>TX FIFO partially full threshold</b>           | <b>8 to 15</b>                                                                                                                    |
| <b>TX FIFO partially empty threshold</b>          | <b>1 to 8</b>                                                                                                                     |
| <b>Enable tx_enh_fifo_full port</b>               | <b>On / Off</b>                                                                                                                   |

*continued...*

| Parameter                                                  | Value                                               |
|------------------------------------------------------------|-----------------------------------------------------|
| <b>Enable tx_enh_fifo_pfull port</b>                       | <b>On / Off</b>                                     |
| <b>Enable tx_enh_fifo_empty port</b>                       | <b>On / Off</b>                                     |
| <b>Enable tx_enh_fifo_pempty port</b>                      | <b>On / Off</b>                                     |
| <b>RX FIFO mode</b>                                        | <b>Interlaken</b>                                   |
| <b>RX FIFO partially full threshold</b>                    | from <b>10-29</b> (no less than pempty_threshold+8) |
| <b>RX FIFO partially empty threshold</b>                   | <b>2 to 10</b>                                      |
| <b>Enable RX FIFO alignment word deletion (Interlaken)</b> | <b>On / Off</b>                                     |
| <b>Enable RX FIFO control word deletion (Interlaken)</b>   | <b>On / Off</b>                                     |
| <b>Enable rx_enh_data_valid port</b>                       | <b>On / Off</b>                                     |
| <b>Enable rx_enh_fifo_full port</b>                        | <b>On / Off</b>                                     |
| <b>Enable rx_enh_fifo_pfull port</b>                       | <b>On / Off</b>                                     |
| <b>Enable rx_enh_fifo_empty port</b>                       | <b>On / Off</b>                                     |
| <b>Enable rx_enh_fifo_pempty port</b>                      | <b>On / Off</b>                                     |
| <b>Enable rx_enh_fifo_del port (10GBASE-R)</b>             | <b>Off</b>                                          |
| <b>Enable rx_enh_fifo_insert port (10GBASE-R)</b>          | <b>Off</b>                                          |
| <b>Enable rx_enh_fifo_rd_en port</b>                       | <b>On</b>                                           |
| <b>Enable rx_enh_fifo_align_val port (Interlaken)</b>      | <b>On / Off</b>                                     |
| <b>Enable rx_enh_fifo_align_clr port (Interlaken)</b>      | <b>On</b>                                           |

**Table 80.** Interlaken Frame Generator Parameters

| Parameter                                   | Value                                                                 |
|---------------------------------------------|-----------------------------------------------------------------------|
| <b>Enable Interlaken frame generator</b>    | <b>On</b>                                                             |
| <b>Frame generator metaframe length</b>     | <b>5 to 8192</b> (Intel recommends a minimum metaframe length of 128) |
| <b>Enable frame generator burst control</b> | <b>On</b>                                                             |
| <b>Enable tx_enh_frame port</b>             | <b>On</b>                                                             |
| <b>Enable tx_enh_frame_diag_status port</b> | <b>On</b>                                                             |
| <b>Enable tx_enh_frame_burst_en port</b>    | <b>On</b>                                                             |

**Table 81.** Interlaken Frame Synchronizer Parameters

| Parameter                                   | Value                                                                 |
|---------------------------------------------|-----------------------------------------------------------------------|
| <b>Enable Interlaken frame synchronizer</b> | <b>On</b>                                                             |
| <b>Frame synchronizer metaframe length</b>  | <b>5 to 8192</b> (Intel recommends a minimum metaframe length of 128) |
| <b>Enable rx_enh_frame port</b>             | <b>On</b>                                                             |
| <b>Enable rx_enh_frame_lock port</b>        | <b>On / Off</b>                                                       |
| <b>Enable rx_enh_frame_diag_status port</b> | <b>On / Off</b>                                                       |

**Table 82. Interlaken CRC-32 Generator and Checker Parameters**

| Parameter                                             | Value    |
|-------------------------------------------------------|----------|
| Enable Interlaken TX CRC-32 generator                 | On       |
| Enable Interlaken TX CRC-32 generator error insertion | On / Off |
| Enable Interlaken RX CRC-32 checker                   | On       |
| Enable rx_enh_crc32_err port                          | On / Off |

**Table 83. Scrambler and Descrambler Parameters**

| Parameter                                      | Value                   |
|------------------------------------------------|-------------------------|
| Enable TX scrambler (10GBASE-R / Interlaken)   | On                      |
| TX scrambler seed (10GBASE-R / Interlaken)     | 0x1 to 0xFFFFFFFFFFFFFF |
| Enable RX descrambler (10GBASE-R / Interlaken) | On                      |

**Table 84. Interlaken Disparity Generator and Checker Parameters**

| Parameter                                 | Value    |
|-------------------------------------------|----------|
| Enable Interlaken TX disparity generator  | On       |
| Enable Interlaken RX disparity checker    | On       |
| Enable Interlaken TX random disparity bit | On / Off |

**Table 85. Block Sync Parameters**

| Parameter                    | Value    |
|------------------------------|----------|
| Enable RX block synchronizer | On       |
| Enable rx_enh_blk_lock port  | On / Off |

**Table 86. Gearbox Parameters**

| Parameter                         | Value    |
|-----------------------------------|----------|
| Enable TX data bitslip            | Off      |
| Enable TX data polarity inversion | On / Off |
| Enable RX data bitslip            | Off      |
| Enable RX data polarity inversion | On / Off |
| Enable tx_enh_bitslip port        | Off      |
| Enable rx_bitslip port            | Off      |

**Table 87. Dynamic Reconfiguration Parameters**

| Parameter                               | Value    |
|-----------------------------------------|----------|
| Enable dynamic reconfiguration          | On / Off |
| Share reconfiguration interface         | On / Off |
| Enable Native PHY Debug Master Endpoint | On / Off |

*continued...*

| Parameter                                                                             | Value           |
|---------------------------------------------------------------------------------------|-----------------|
| <b>Separate reconfig_waitrequest from the status of AVMM arbitration with PreSICE</b> | <b>On / Off</b> |
| <b>Enable capability registers</b>                                                    | <b>On / Off</b> |
| <b>Set user-defined IP identifier:</b>                                                | <b>0 to 255</b> |
| <b>Enable control and status registers</b>                                            | <b>On / Off</b> |
| <b>Enable prbs soft accumulators</b>                                                  | <b>On / Off</b> |

**Table 88. Configuration Files Parameters**

| Parameter                                                 | Value           |
|-----------------------------------------------------------|-----------------|
| <b>Configuration file prefix</b>                          | —               |
| <b>Generate SystemVerilog package file</b>                | <b>On / Off</b> |
| <b>Generate C header file</b>                             | <b>On / Off</b> |
| <b>Generate MIF (Memory Initialization File)</b>          | <b>On / Off</b> |
| <b>Include PMA analog settings in configuration files</b> | <b>On / Off</b> |

**Table 89. Configuration Profiles Parameters**

| Parameter                                       | Value           |
|-------------------------------------------------|-----------------|
| <b>Enable multiple reconfiguration profiles</b> | <b>On / Off</b> |
| <b>Enable embedded reconfiguration streamer</b> | <b>On / Off</b> |
| <b>Generate reduced reconfiguration files</b>   | <b>On / Off</b> |
| <b>Number of reconfiguration profiles</b>       | 1 to 8          |
| <b>Selected reconfiguration profile</b>         | 1 to 7          |

#### Related Information

Using the Arria 10 Transceiver Native PHY IP Core on page 45

## 2.6. Ethernet

The Ethernet standard comprises many different PHY standards with variations in signal transmission medium and data rates. The 1G/10GbE and 10GBASE-KR PHY IP Core enables Ethernet connectivity at 1 Gbps and 10 Gbps over backplanes. The 10GBASE-KR PHY IP is also known as the Backplane Ethernet PHY IP. It includes link training and auto negotiation to support the IEEE Backplane Ethernet standard.

| Data Rate | Transceiver Configuration Rule/IP                                                                                                             |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 1G        | <ul style="list-style-type: none"> <li>Gigabit Ethernet</li> <li>Gigabit Ethernet 1588</li> </ul>                                             |
| 10G       | <ul style="list-style-type: none"> <li>10GBASE-R</li> <li>10GBASE-R 1588</li> <li>10GBASE-R with KR FEC</li> <li>10GBASE-KR PHY IP</li> </ul> |
| 1G/10G    | 1G/10G Ethernet PHY IP                                                                                                                        |

## 2.6.1. Gigabit Ethernet (GbE) and GbE with IEEE 1588v2

Gigabit Ethernet (GbE) is a high-speed local area network technology that provides data transfer rates of about 1 Gbps. GbE builds on top of the ethernet protocol, but increases speed tenfold over Fast Ethernet. IEEE 802.3 defines GbE as an intermediate (or transition) layer that interfaces various physical media with the media access control (MAC) in a Gigabit Ethernet system. Gigabit Ethernet PHY shields the MAC layer from the specific nature of the underlying medium and is divided into three sub-layers shown in the following figure.

**Figure 42. GbE PHY Connection to IEEE 802.3 MAC and RS**



**Figure 43. Transceiver Channel Datapath and Clocking at 1250 Mbps for GbE, GbE with IEEE 1588v2**



Notes:

1. This block is set in low latency mode for GbE and register\_fifo mode for GbE with IEEE 1588v2.
2. The rate match FIFO of the hard PCS is disabled for GbE with IEEE 1588v2 because it is not able to achieve deterministic latency. It is also disabled for Triple-speed Ethernet (TSE) configurations that require an auto-negotiation sequence. The insertion/deletion operation could break the auto-negotiation functionality due to the rate matching of different frequency PPM scenarios. The soft rate match FIFO is constructed in the GbE Serial Gigabit Media Independent Interface (SGMII) IP core.
3. The byte serializer can be enabled or disabled.
4. The byte deserializer can be enabled or disabled.
5. The CGB is in the Native PHY.

#### Note:

The Native PHY only supports basic PCS functions. The Native PHY does not support auto-negotiation state machine, collision-detect, and carrier-sense. If required, you must implement these functions in the FPGA fabric or external circuits.

#### GbE with IEEE 1588v2

GbE with IEEE 1588v2 provides a standard method to synchronize devices on a network with submicrosecond precision. To improve performance, the protocol synchronizes slave clocks to a master clock so that events and time stamps are synchronized in all devices. The protocol enables heterogeneous systems that include clocks of various inherent precision, resolution, and stability to synchronize to a grandmaster clock.

The TX FIFO and RX FIFO are set to **register\_fifo** mode for GbE with IEEE 1588v2.

#### Related Information

##### [Triple-Speed Ethernet IP Function User Guide](#).

For more information about the IEEE 1588v2 implementation in GbE PHY and MAC, and design examples.

#### 2.6.1.1. 8B/10B Encoding for GbE, GbE with IEEE 1588v2

The 8B/10B encoder clocks 8-bit data and 1-bit control identifiers from the transmitter phase compensation FIFO and generates 10-bit encoded data. The 10-bit encoded data is sent to the PMA.

The IEEE 802.3 specification requires GbE to transmit Idle ordered sets (/I/) continuously and repetitively whenever the gigabit media-independent interface (GMII) is Idle. This transmission ensures that the receiver maintains bit and word synchronization whenever there is no active data to be transmitted.

For the GbE protocol, the transmitter replaces any /Dx.y/ following a /K28.5/ comma with either a /D5.6/ (/I1/ ordered set) or a /D16.2/ (/I2/ ordered set), depending on the current running disparity. The exception is when the data following the /K28.5/ is /D21.5/ (/C1/ ordered set) or /D2.2/ (/C2/) ordered set. If the running disparity before the /K28.5/ is positive, an /I1/ ordered set is generated. If the running disparity is negative, a /I2/ ordered set is generated. The disparity at the end of a /I1/ is the opposite of that at the beginning of the /I1/. The disparity at the end of a /I2/ is the same as the beginning running disparity immediately preceding transmission of the Idle code. This sequence ensures a negative running disparity at the end of an Idle ordered set. A /Kx.y/ following a /K28.5/ does not get replaced.

**Note:** /D14.3/, /D24.0/, and /D15.8/ are replaced by /D5.6/ or /D16.2/ (for I1 and I2 ordered sets). D21.5 (/C1/) is not replaced.

**Figure 44. Idle Ordered-Set Generation Example**



### Related Information

8B/10B Encoder on page 494

#### 2.6.1.1.1. Reset Condition for 8B/10B Encoder in GbE, GbE with IEEE 1588v2

After deassertion of `tx_digitalreset`, the transmitters automatically transmit at least three /K28.5/ comma code groups before transmitting user data on the `tx_parallel_data` port. This transmission could affect the synchronization state machine behavior at the receiver.

Depending on when you start transmitting the synchronization sequence, there could be an even or odd number of /Dx.y/ code groups transmitted between the last of the three automatically sent /K28.5/ code groups and the first /K28.5/ code group of the synchronization sequence. If there is an even number of /Dx.y/ code groups received between these two /K28.5/ code groups, the first /K28.5/ code group of the synchronization sequence begins at an odd code group boundary. The synchronization state machine treats this as an error condition and goes into the loss of synchronization state.

**Figure 45. Reset Condition**



### 2.6.1.2. Word Alignment for GbE, GbE with IEEE 1588v2

The word aligner for the GbE and GbE with IEEE 1588v2 protocols is configured in automatic synchronization state machine mode. The Intel Quartus Prime Pro Edition software automatically configures the synchronization state machine to indicate synchronization when the receiver receives three consecutive synchronization ordered sets. A synchronization ordered set is a /K28.5/ code group followed by an odd number of valid /Dx.y/ code groups. The fastest way for the receiver to achieve synchronization is to receive three continuous {/K28.5/, /Dx.y/} ordered sets.

The GbE PHY IP core signals receiver synchronization status on the `rx_syncstatus` port of each channel. A high on the `rx_syncstatus` port indicates that the lane is synchronized; a low on the `rx_syncstatus` port indicates that the lane has fallen out of synchronization. The receiver loses synchronization when it detects three invalid code groups separated by less than three valid code groups or when it is reset.

**Table 90. Synchronization State Machine Parameter Settings for GbE**

| Synchronization State Machine Parameter             | Setting |
|-----------------------------------------------------|---------|
| Number of word alignment patterns to achieve sync   | 3       |
| Number of invalid data words to lose sync           | 3       |
| Number of valid data words to decrement error count | 3       |

The following figure shows `rx_syncstatus` high when three consecutive ordered sets are sent through `rx_parallel_data`.

**Figure 46.** rx\_syncstatus High

**Related Information**
[Word Aligner on page 497](#)

### 2.6.1.3. 8B/10B Decoding for GbE, GbE with IEEE 1588v2

The 8B/10B decoder takes a 10-bit encoded value as input and produces an 8-bit data value and 1-bit control value as output.

**Figure 47.** Decoding for GbE

Dx.y(0x8d), Dx.y(0xa4), K28.5(0xbc), and Dx.y(0x50) are received at **rx\_parallel\_data**. /K28.5/ is set as the word alignment pattern. **rx\_patterndetect** goes high whenever it detects /K28.5/(0xbc). **rx\_dataak** is high when bc is received, indicating that the decoded word is a control word. Otherwise, **rx\_dataak** is low. **rx\_runningdisp** is high for 0x8d, indicating that the decoded word has negative disparity and 0xa4 has positive disparity.


**Related Information**
[8B/10B Decoder on page 504](#)

#### 2.6.1.4. Rate Match FIFO for GbE

The rate match FIFO compensates frequency Part-Per-Million (ppm) differences between the upstream transmitter and the local receiver reference clock up to 125 MHz  $\pm$  100 ppm difference.

**Note:** 200 ppm total is only true if calculated as (125 MHz + 100 ppm) - (125 MHz - 100 ppm) = 200 ppm. By contrast, (125 MHz + 0 ppm) - (125 MHz - 200 ppm) is out of specification.

The GbE protocol requires the transmitter to send idle ordered sets /I1/ (/K28.5/D5.6/) and /I2/ (/K28.5/D16.2/) during inter-packet gaps (IPG) adhering to the rules listed in the IEEE 802.3-2008 specification.

The rate match operation begins after the synchronization state machine in the word aligner indicates synchronization is acquired by driving the `rx_syncstatus` signal high. The rate matcher deletes or inserts both symbols /K28.5/ and /D16.2/ of the /I2/ ordered sets as a pair in the operation to prevent the rate match FIFO from overflowing or underflowing. The rate match operation can insert or delete as many /I2/ ordered sets as necessary.

The following figure shows a rate match deletion operation example where three symbols must be deleted. Because the rate match FIFO can only delete /I2/ ordered sets, it deletes two /I2/ ordered sets (four symbols deleted).

**Figure 48. Rate Match FIFO Deletion**



The following figure shows an example of rate match FIFO insertion in the case where one symbol must be inserted. Because the rate match FIFO can only insert /I2/ ordered sets, it inserts one /I2/ ordered set (two symbols inserted).

**Figure 49. Rate Match FIFO Insertion**



`rx_std_rmfifo_full` and `rx_std_rmfifo_empty` are forwarded to the FPGA fabric to indicate rate match FIFO full and empty conditions.

The rate match FIFO does not delete code groups to overcome a FIFO full condition. It asserts the `rx_std_rmfifo_full` flag for at least two recovered clock cycles to indicate rate match FIFO full. The following figure shows the rate match FIFO full condition when the write pointer is faster than the read pointer.

**Figure 50. Rate Match FIFO Full Condition**


The rate match FIFO does not insert code groups to overcome the FIFO empty condition. It asserts the `rx_std_rmfifo_empty` flag for at least two recovered clock cycles to indicate that the rate match FIFO is empty. The following figure shows the rate match FIFO empty condition when the read pointer is faster than the write pointer.

**Figure 51. Rate Match FIFO Empty Condition**


In the case of rate match FIFO full and empty conditions, you must assert the `rx_digitalreset` signal to reset the receiver PCS blocks.

#### Related Information

[Rate Match FIFO on page 503](#)

#### 2.6.1.5. How to Implement GbE, GbE with IEEE 1588v2 in Arria 10 Transceivers

You should be familiar with the Standard PCS and PMA architecture, PLL architecture, and the reset controller before implementing the GbE protocol.

1. Instantiate the **Arria 10 Transceiver Native PHY IP** from the IP Catalog.

Refer to [Select and Instantiate the PHY IP Core](#) on page 33.

2. Select **GbE** or **GbE 1588** from the **Transceiver configuration rules** list located under **Datapath Options**, depending on which protocol you are implementing.
3. Use the parameter values in the tables in [Native PHY IP Parameter Settings for GbE and GbE with IEEE 1588v2](#) on page 120 as a starting point. Or, you can use the protocol presets described in [Transceiver Native PHY Presets](#). Use the **GIGE-1.25 Gbps** preset for GbE, and the **GIGE-1.25 Gbps 1588** preset for GbE 1588. You can then modify the setting to meet your specific requirements.
4. Click **Generate** to generate the Native PHY IP core top-level RTL file.

**Figure 52. Signals and Ports for Native PHY IP Configured for GbE or GbE with IEEE 1588v2**

Generating the IP core creates signals and ports based on your parameter settings.



Note:

1. rx\_rmfifostatus is not available in the GbE with 1588 configuration.

5. Instantiate and configure your PLL.
6. Instantiate a transceiver reset controller.

You can use your own reset controller or use the Native PHY Reset Controller IP core.

7. Connect the Native PHY IP to the PLL IP and the reset controller. Use the information in the figure below to connect the ports.

**Figure 53. Connection Guidelines for a GbE/GbE with IEEE 1588v2 PHY Design**

**Note:**

1. The `pll_cal_busy` signal is not available when using the CMU PLL.
2. The `pll_powerdown` signal is not available separately for user control when using the fPLL.  
The reset controller handles PLL reset for the fPLL.

8. Simulate your design to verify its functionality.

#### Related Information

- [Arria 10 Standard PCS Architecture](#) on page 491  
For more information about Standard PCS architecture
- [Arria 10 PMA Architecture](#) on page 459  
For more information about PMA architecture
- [Using PLLs and Clock Networks](#) on page 410  
For more information about implementing PLLs and clocks
- [PLLs](#) on page 358  
PLL architecture and implementation details
- [Resetting Transceiver Channels](#) on page 428  
Reset controller general information and implementation details
- [Standard PCS Ports](#) on page 87  
Port definitions for the Transceiver Native PHY Standard Datapath

#### 2.6.1.6. Native PHY IP Parameter Settings for GbE and GbE with IEEE 1588v2

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

**Table 91. General and Datapath Options**

The first two sections of the Native PHY [IP] parameter editor for the Native PHY IP provide a list of general and datapath options to customize the transceiver.

| Parameter                                            | Value                                                              |
|------------------------------------------------------|--------------------------------------------------------------------|
| <b>Message level for rule violations</b>             | <b>error<br/>warning</b>                                           |
| <b>Transceiver configuration rules</b>               | <b>GbE</b> (for GbE)<br><b>GbE 1588</b> (for GbE with IEEE 1588v2) |
| <b>Transceiver mode</b>                              | <b>TX/RX Duplex</b><br><b>TX Simplex</b><br><b>RX Simplex</b>      |
| <b>Number of data channels</b>                       | <b>1 to 96</b>                                                     |
| <b>Data rate</b>                                     | <b>1250 Mbps</b>                                                   |
| <b>Enable datapath and interface reconfiguration</b> | <b>On/Off</b>                                                      |
| <b>Enable simplified data interface</b>              | <b>On/Off</b>                                                      |

**Table 92. TX PMA Parameters**

| Parameter                                        | Value                             |
|--------------------------------------------------|-----------------------------------|
| <b>TX channel bonding mode</b>                   | <b>Not bonded</b>                 |
| <b>TX local clock division factor</b>            | <b>1, 2, 4, 8</b>                 |
| <b>Number of TX PLL clock inputs per channel</b> | <b>1, 2, 3, 4</b>                 |
| <b>Initial TX PLL clock input selection</b>      | <b>0 to 3</b>                     |
| <b>Enable tx_pma_clkout port</b>                 | <b>On/Off</b>                     |
| <b>Enable tx_pma_div_clkout port</b>             | <b>On/Off</b>                     |
| <b>tx_pma_div_clkout division factor</b>         | <b>Disabled, 1, 2, 33, 40, 66</b> |
| <b>Enable tx_pma_elecidle port</b>               | <b>On/Off</b>                     |
| <b>Enable tx_pma_qpipullup port (QPI)</b>        | <b>On/Off</b>                     |
| <b>Enable tx_pma_qpipulldn port (QPI)</b>        | <b>On/Off</b>                     |
| <b>Enable tx_pma_txdetectrx port (QPI)</b>       | <b>On/Off</b>                     |
| <b>Enable tx_pma_rxfound port (QPI)</b>          | <b>On/Off</b>                     |
| <b>Enable rx_seriallpbken port</b>               | <b>On/Off</b>                     |

**Table 93. RX PMA Parameters**

| Parameter                                     | Value                                                    |
|-----------------------------------------------|----------------------------------------------------------|
| <b>Number of CDR reference Clocks</b>         | <b>1 to 5</b>                                            |
| <b>Selected CDR reference clock</b>           | <b>0 to 4</b>                                            |
| <b>Selected CDR reference clock frequency</b> | Select legal range defined by the Quartus Prime software |
| <b>PPM detector threshold</b>                 | <b>100, 300, 500, 1000</b>                               |
| <b>CTLE adaptation mode</b>                   | <b>manual</b>                                            |
| <i>continued...</i>                           |                                                          |

| Parameter                                                  | Value                             |
|------------------------------------------------------------|-----------------------------------|
| <b>DFE adaptation mode</b>                                 | <b>disabled</b>                   |
| <b>Number of fixed dfe taps</b>                            | N/A                               |
| <b>Enable rx_pma_clkout port</b>                           | <b>On/Off</b>                     |
| <b>Enable rx_pma_div_clkout port</b>                       | <b>On/Off</b>                     |
| <b>rx_pma_div_clkout division factor</b>                   | <b>Disabled, 1, 2, 33, 40, 66</b> |
| <b>Enable rx_pma_iqtxrx_clkout port</b>                    | <b>On/Off</b>                     |
| <b>Enable rx_pma_clkslip port</b>                          | <b>On/Off</b>                     |
| <b>Enable rx_pma_qpipulldn port (QPI)</b>                  | <b>Off</b>                        |
| <b>Enable rx_is_lockedtodata port</b>                      | <b>On/Off</b>                     |
| <b>Enable rx_is_lockedtoref port</b>                       | <b>On/Off</b>                     |
| <b>Enable rx_set_locktodata and rx_set_locktoref ports</b> | <b>On/Off</b>                     |
| <b>Enable rx_serialpbken port</b>                          | <b>On/Off</b>                     |
| <b>Enable PRBS verifier control and status ports</b>       | <b>On/Off</b>                     |

**Table 94. Standard PCS Parameters**

| Parameters                                             | Value                                                                                 |
|--------------------------------------------------------|---------------------------------------------------------------------------------------|
| <b>Standard PCS / PMA interface width</b>              | <b>10</b>                                                                             |
| <b>FPGA fabric / Standard TX PCS interface width</b>   | <b>8</b>                                                                              |
| <b>FPGA fabric / Standard RX PCS interface width</b>   | <b>8</b>                                                                              |
| <b>Enable Standard PCS low latency mode</b>            | <b>Off</b>                                                                            |
| <b>TX FIFO mode</b>                                    | <b>low latency</b> (for GbE)<br><b>register_fifo</b> (for GbE with IEEE 1588v2)       |
| <b>RX FIFO mode</b>                                    | <b>low latency</b> (for GbE)<br><b>register_fifo</b> (for GbE with IEEE 1588v2)       |
| <b>Enable tx_std_pcfifo_full port</b>                  | <b>On/Off</b>                                                                         |
| <b>Enable tx_std_pcfifo_empty port</b>                 | <b>On/Off</b>                                                                         |
| <b>Enable rx_std_pcfifo_full port</b>                  | <b>On/Off</b>                                                                         |
| <b>Enable rx_std_pcfifo_empty port</b>                 | <b>On/Off</b>                                                                         |
| <b>TX byte serializer mode</b>                         | <b>Disabled</b>                                                                       |
| <b>RX byte deserializer mode</b>                       | <b>Disabled</b>                                                                       |
| <b>Enable TX 8B/10B encoder</b>                        | <b>On</b>                                                                             |
| <b>Enable TX 8B/10B disparity control</b>              | <b>On/Off</b>                                                                         |
| <b>Enable RX 8B/10B decoder</b>                        | <b>On</b>                                                                             |
| <b>RX rate match FIFO mode</b>                         | <b>gige</b> (for GbE)<br><b>disabled</b> (for GbE with IEEE 1588v2)                   |
| <b>RX rate match insert / delete -ve pattern (hex)</b> | 0x000ab683 (/K28.5/D2.2/) (for GbE)<br>0x00000000 (disabled for GbE with IEEE 1588v2) |
| <i>continued...</i>                                    |                                                                                       |

| Parameters                                                            | Value                                                                                                                             |
|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| <b>RX rate match insert / delete +ve pattern (hex)</b>                | 0x000a257c (/K28.5/D16.2/) (for GbE)<br>0x00000000 (disabled for GbE with IEEE 1588v2)                                            |
| <b>Enable rx_std_rmfifo_full port</b>                                 | <b>On/Off</b><br>(option disabled for GbE with IEEE 1588v2)                                                                       |
| <b>Enable rx_std_rmfifo_empty port</b>                                | <b>On/Off</b><br>(option disabled for GbE with IEEE 1588v2)                                                                       |
| <b>PCI Express Gen3 rate match FIFO mode</b>                          | <b>Bypass</b>                                                                                                                     |
| <b>Enable TX bit slip</b>                                             | <b>Off</b>                                                                                                                        |
| <b>Enable tx_std_bitslipboundarysel port</b>                          | <b>On/Off</b>                                                                                                                     |
| <b>RX word aligner mode</b>                                           | <b>Synchronous state machine</b>                                                                                                  |
| <b>RX word aligner pattern length</b>                                 | <b>7</b>                                                                                                                          |
| <b>RX word aligner pattern (hex)</b>                                  | 0x0000000000000007c (Comma) (for 7-bit aligner pattern length), 0x0000000000000017c (/K28.5/) (for 10-bit aligner pattern length) |
| <b>Number of word alignment patterns to achieve sync</b>              | <b>3</b>                                                                                                                          |
| <b>Number of invalid data words to lose sync</b>                      | <b>3</b>                                                                                                                          |
| <b>Number of valid data words to decrement error count</b>            | <b>3</b>                                                                                                                          |
| <b>Enable fast sync status reporting for deterministic latency SM</b> | <b>On/Off</b>                                                                                                                     |
| <b>Enable rx_std_wa_patternalign port</b>                             | <b>Off</b>                                                                                                                        |
| <b>Enable rx_std_wa_a1a2size port</b>                                 | <b>Off</b>                                                                                                                        |
| <b>Enable rx_std_bitslipboundarysel port</b>                          | <b>Off</b>                                                                                                                        |
| <b>Enable rx_bitslip port</b>                                         | <b>Off</b>                                                                                                                        |
| <b>Enable TX bit reversal</b>                                         | <b>Off</b>                                                                                                                        |
| <b>Enable TX byte reversal</b>                                        | <b>Off</b>                                                                                                                        |
| <b>Enable TX polarity inversion</b>                                   | <b>On/Off</b>                                                                                                                     |
| <b>Enable tx_polinv port</b>                                          | <b>On/Off</b>                                                                                                                     |
| <b>Enable RX bit reversal</b>                                         | <b>Off</b>                                                                                                                        |
| <b>Enable rx_std_bitrev_ena port</b>                                  | <b>Off</b>                                                                                                                        |
| <b>Enable RX byte reversal</b>                                        | <b>Off</b>                                                                                                                        |
| <b>Enable rx_std_byterev_ena port</b>                                 | <b>Off</b>                                                                                                                        |
| <b>Enable RX polarity inversion</b>                                   | <b>On/Off</b>                                                                                                                     |
| <b>Enable rx_polinv port</b>                                          | <b>On/Off</b>                                                                                                                     |
| <b>Enable rx_std_signaldetect port</b>                                | <b>On/Off</b>                                                                                                                     |
| All options under <b>PCIe Ports</b>                                   | <b>Off</b>                                                                                                                        |

### Related Information

[Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45

## 2.6.2. 10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC Variants

10GBASE-R PHY is the Ethernet-specific physical layer running at a 10.3125-Gbps data rate as defined in Clause 49 of the IEEE 802.3-2008 specification. Arria 10 transceivers can implement 10GBASE-R variants like 10GBASE-R with IEEE 1588v2, and with forward error correction (FEC).

The 10GBASE-R parallel data interface is the 10 Gigabit Media Independent Interface (XGMII) that interfaces with the Media Access Control (MAC), which has the optional Reconciliation Sub-layer (RS).

**Figure 54. 10GBASE-R PHY as Part of the IEEE802.3-2008 Open System Interconnection (OSI)**



10GBASE-R is a single-channel protocol that runs independently. You can configure the transceivers to implement 10GBASE-R PHY functionality by using the presets of the Native PHY IP. The 10GBASE-R PHY IP is compatible with the 10-Gbps Ethernet MAC Intel FPGA IP Core Function. The complete PCS and PHY solutions can be used to interface with a third-party PHY MAC layer as well.

The following 10GBASE-R variants area available from presets:

- 10GBASE-R
- 10GBASE-R Low Latency
- 10GBASE-R Register Mode
- 10GBASE-R w/ KR-FEC

Intel recommends that you use the presets for selecting the suitable 10GBASE-R variants directly if you are configuring through the Native PHY IP core.

**Figure 55. Transceiver Channel Datapath and Clocking for 10GBASE-R**



### 10GBASE-R with IEEE 1588v2

When choosing the 10GBASE-R PHY with IEEE 1588v2 mode preset, the hard TX and RX FIFO are set to register mode. The output clock frequency of tx\_clkout and rx\_clkout to the FPGA fabric is based on the PCS-PMA interface width. For example, if the PCS-PMA interface is 40-bit, tx\_clkout and rx\_clkout run at 10.3125 Gbps/40-bit = 257.8125 MHz.

The 10GBASE-R PHY with IEEE 1588v2 creates the soft TX phase compensation FIFO and the RX clock compensation FIFO in the FPGA core so that the effective XGMII data is running at 156.25 MHz interfacing with the MAC layer.

The IEEE 1588 Precision Time Protocol (PTP) is supported by the preset of the Arria 10 transceiver Native PHY that configures 10GBASE-R PHY IP in IEEE-1588v2 mode. PTP is used for precise synchronization of clocks in applications such as:

- Distributed systems in telecommunications
  - Power generation and distribution
  - Industrial automation
  - Robotics
  - Data acquisition
  - Test equipment
  - Measurement

The protocol is applicable to systems communicating by local area networks including, but not limited to, Ethernet. The protocol enables heterogeneous systems that include clocks of various inherent precision, resolution, and stability to synchronize to a grandmaster clock.

**Figure 56.** Transceiver Channel Datapath and Clocking for 10GBASE-R with IEEE 1588v2



## **10GBASE-R with FEC**

Arria 10 10GBASE-R has the optional FEC variant that also targets the 10GBASE-KR PHY. This provides a coding gain to increase the link budget and BER performance on a broader set of backplane channels as defined in Clause 69. It provides additional margin to account for variations in manufacturing and environment conditions. The additional TX FEC sublayer:

- Receives data from the TX PCS
- Transcodes 64b/66b words
- Performs encoding/framing
- Scrambles and sends the FEC data to the PMA

The RX FEC sublayer:

- Receives data from the PMA
- Performs descrambling
- Achieves FEC framing synchronization
- Decodes and corrects data where necessary and possible
- Recodes 64b/66b words and sends the data to the PCS

The 10GBASE-R with KR FEC protocol is a KR FEC sublayer placed between the PCS and PMA sublayers of the 10GBASE-R physical layer.

**Figure 57. Transceiver Channel Datapath and Clocking for 10GBASE-R with KR FEC**



The CMU PLL or the ATX PLLs generate the TX high speed serial clock.

**Figure 58. Clock Generation and Distribution for 10GBASE-R with FEC Support**

Example using a 64-bit PCS-PMA interface width.



### 2.6.2.1. The XGMII Clocking Scheme in 10GBASE-R

The XGMII interface, specified by IEEE 802.3-2008, defines the 32-bit data and 4-bit wide control character. These characters are clocked between the MAC/RS and the PCS at both the positive and negative edge (double data rate – DDR) of the 156.25 MHz interface clock.

The transceivers do not support the XGMII interface to the MAC/RS as defined in the IEEE 802.3-2008 specification. Instead, they support a 64-bit data and 8-bit control single data rate (SDR) interface between the MAC/RS and the PCS.

**Figure 59. XGMII Interface (DDR) and Transceiver Interface (SDR) for 10GBASE-R Configurations**



**Note:** Clause 46 of the IEEE 802.3-2008 specification defines the XGMII interface between the 10GBASE-R PCS and the Ethernet MAC/RS.

The dedicated reference clock input to the variants of the 10GBASE-R PHY can be run at either 322.265625 MHz or 644.53125 MHz.

For 10GBASE-R, you must achieve 0 ppm of the frequency between the read clock of TX phase compensation FIFO (PCS data) and the write clock of TX phase compensation FIFO (XGMII data in the FPGA fabric). This can be achieved by using the same reference clock as the transceiver dedicated reference clock input as well as the reference clock input for a core PLL (fPLL, for example) to produce the XGMII clock. The same core PLL can be used to drive the RX XGMII data. This is because the RX clock compensation FIFO is able to handle the frequency PPM difference of  $\pm 100$  ppm between RX PCS data driven by the RX recovered clock and RX XGMII data.

**Note:** 10GBASE-R is the single-channel protocol that runs independently. Therefore Intel recommends that you use the presets for selecting the suitable 10GBASE-R variants directly. If it is being configured through the Native PHY IP, the channel bonding option should be disabled. Enabling the channel bonding for multiple channels could degrade the link performance in terms of TX jitter eye and RX jitter tolerance.

### 2.6.2.1.1. TX FIFO and RX FIFO

In 10GBASE-R configuration, the TX FIFO behaves as a phase compensation FIFO and the RX FIFO behaves as a clock compensation FIFO.

In 10GBASE-R with 1588 configuration, both the TX FIFO and the RX FIFO are used in register mode. The TX phase compensation FIFO and the RX clock compensation FIFO are constructed in the FPGA fabric by the PHY IP automatically.

In 10GBASE-R with KR FEC configuration, you use the TX FIFO in phase compensation mode and the RX FIFO behaves as a clock compensation FIFO.

#### Related Information

[Arria 10 Enhanced PCS Architecture](#) on page 473

For more information about the Enhanced PCS Architecture

### 2.6.2.2. How to Implement 10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC in Arria 10 Transceivers

You should be familiar with the 10GBASE-R and PMA architecture, PLL architecture, and the reset controller before implementing the 10GBASE-R, 10GBASE-R with IEEE 1588v2, or 10GBASE-R with FEC Transceiver Configuration Rules.

You must design your own MAC and other layers in the FPGA to implement the 10GBASE-R, 10GBASE-R with 1588, or 10GBASE-R with KR FEC Transceiver Configuration Rule using the Native PHY IP.

1. Instantiate the **Arria 10 Transceiver Native PHY IP** from the IP Catalog. Refer to [Select and Instantiate the PHY IP Core](#) on page 33 for more details.
2. Select **10GBASE-R, 10GBASE-R 1588**, or **10GBASE-R with KR FEC** from the **Transceiver configuration rule** list located under **Datapath Options**, depending on which protocol you are implementing.
3. Use the parameter values in the tables in [Transceiver Native PHY Parameters for the 10GBASE-R Protocol](#) as a starting point. Or, you can use the protocol presets described in [Transceiver Native PHY Presets](#). Select **10GBASE-R Register Mode for 10GBASE-R with IEEE 1588v2**. You can then modify the settings to meet your specific requirements.
4. Click **Generate** to generate the Native PHY IP core RTL file.

**Figure 60. Signals and Ports of Native PHY IP Core for the 10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC**

Generating the IP core creates signals and ports based on your parameter settings.



Notes:

1. For 10GBASE-R with 1588 configurations, this signal is user-controlled.
2. For 10GBASE-R with 1588 configurations, this signal is connected from the output of TX FIFO in the FPGA fabric.

5. Instantiate and configure your PLL.

6. Create a transceiver reset controller. You can use your own reset controller or use the Arria 10 Transceiver Native PHY Reset Controller IP.
7. Connect the Arria 10 Transceiver Native PHY to the PLL IP and the reset controller.

**Figure 61. Connection Guidelines for a 10GBASE-R or 10GBASE-R with FEC PHY Design**



**Figure 62. Connection Guidelines for a 10GBASE-R with IEEE 1588v2 PHY Design**



8. Simulate your design to verify its functionality.

#### Related Information

- [Arria 10 Enhanced PCS Architecture](#) on page 473  
For more information about Enhanced PCS architecture
- [Arria 10 PMA Architecture](#) on page 459  
For more information about PMA architecture
- [Using PLLs and Clock Networks](#) on page 410  
For more information about implementing PLLs and clocks
- [PLLs](#) on page 358  
PLL architecture and implementation details
- [Resetting Transceiver Channels](#) on page 428  
Reset controller general information and implementation details
- [Enhanced PCS Ports](#) on page 77  
For detailed information about the available ports in the 10GBASE-R 1588 protocol.

### 2.6.2.3. Native PHY IP Parameter Settings for 10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

**Table 95. General and Datapath Parameters**

The first two sections of the Transceiver Native PHY parameter editor provide a list of general and datapath options to customize the transceiver.

| Parameter                                            | Range                                                         |
|------------------------------------------------------|---------------------------------------------------------------|
| <b>Message level for rule violations</b>             | <b>error, warning</b>                                         |
| <b>Transceiver Configuration Rule</b>                | <b>10GBASE-R<br/>10GBASE-R 1588<br/>10GBASE-R with KR FEC</b> |
| <b>Transceiver mode</b>                              | <b>TX / RX Duplex, TX Simplex, RX Simplex</b>                 |
| <b>Number of data channels</b>                       | <b>1 to 96</b>                                                |
| <b>Data rate</b>                                     | <b>10312.5 Mbps</b>                                           |
| <b>Enable datapath and interface reconfiguration</b> | <b>Off</b>                                                    |
| <b>Enable simplified data interface</b>              | <b>On<br/>Off</b>                                             |

**Table 96. TX PMA Parameters**

| Parameter                                        | Range             |
|--------------------------------------------------|-------------------|
| <b>TX channel bonding mode</b>                   | <b>Not bonded</b> |
| <b>TX local clock division factor</b>            | <b>1, 2, 4, 8</b> |
| <b>Number of TX PLL clock inputs per channel</b> | <b>1, 2, 3, 4</b> |
| <b>Initial TX PLL clock input selection</b>      | <b>0</b>          |

**Table 97. RX PMA Parameters**

| Parameter                                                     | Range                                                |
|---------------------------------------------------------------|------------------------------------------------------|
| <b>Number of CDR reference clocks</b>                         | <b>1 to 5</b>                                        |
| <b>Selected CDR reference clock</b>                           | <b>0 to 4</b>                                        |
| <b>Selected CDR reference clock frequency</b> <sup>(35)</sup> | <b>156.25 MHz, 322.265625 MHz, and 644.53125 MHz</b> |
| <b>PPM detector threshold</b>                                 | <b>100, 300, 500, 1000</b>                           |
| <b>CTLE adaptation mode</b>                                   | <b>manual</b>                                        |
| <b>DFE adaptation mode</b>                                    | <b>adaptation enabled, manual, disabled</b>          |
| <b>Number of fixed DFE taps</b>                               | <b>3, 7, 11</b>                                      |

<sup>(35)</sup> The CDR reference clock frequency depends on your design settings. Intel recommends that you verify the link datarates to ensure the CDR locking capability before production.

**Table 98. Enhanced PCS Parameters**

| Parameter                                | Range                                                                                                                                                                             |
|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enhanced PCS/PMA interface width         | <b>32, 40, 64</b><br><i>Note: 10GBASE-R with KR-FEC allows <b>64</b> only.</i>                                                                                                    |
| FPGA fabric/Enhanced PCS interface width | <b>66</b>                                                                                                                                                                         |
| Enable Enhanced PCS low latency mode     | <b>On</b><br><b>Off</b>                                                                                                                                                           |
| Enable RX/TX FIFO double-width mode      | <b>Off</b>                                                                                                                                                                        |
| TX FIFO mode                             | <ul style="list-style-type: none"> <li><b>Phase Compensation</b> (10GBASE-R and 10GBASE-R with KR FEC)</li> <li><b>Register or Fast register</b> (10GBASE-R with 1588)</li> </ul> |
| TX FIFO partially full threshold         | <b>11</b>                                                                                                                                                                         |
| TX FIFO partially empty threshold        | <b>2</b>                                                                                                                                                                          |
| RX FIFO mode                             | <ul style="list-style-type: none"> <li><b>10GBASE-R</b> (10GBASE-R and 10GBASE-R with KR FEC)</li> <li><b>Register</b> (10GBASE-R with 1588)</li> </ul>                           |
| RX FIFO partially full threshold         | <b>23</b>                                                                                                                                                                         |
| RX FIFO partially empty threshold        | <b>2</b>                                                                                                                                                                          |

**Table 99. 64B/66B Encoder and Decoder Parameters**

| Parameter                             | Range                   |
|---------------------------------------|-------------------------|
| Enable TX 64B/66B encoder             | <b>On</b>               |
| Enable RX 64B/66B decoder             | <b>On</b>               |
| Enable TX sync header error insertion | <b>On</b><br><b>Off</b> |

**Table 100. Scrambler and Descrambler Parameters**

| Parameter                                      | Range            |
|------------------------------------------------|------------------|
| Enable TX scrambler (10GBASE-R / Interlaken)   | <b>On</b>        |
| TX scrambler seed (10GBASE-R / Interlaken)     | 0x03ffffffffffff |
| Enable RX descrambler (10GBASE-R / Interlaken) | <b>On</b>        |

**Table 101. Block Sync Parameters**

| Parameter                    | Range                   |
|------------------------------|-------------------------|
| Enable RX block synchronizer | <b>On</b>               |
| Enable rx_enh_blk_lock port  | <b>On</b><br><b>Off</b> |

**Table 102. Gearbox Parameters**

| Parameter                         | Range                   |
|-----------------------------------|-------------------------|
| Enable TX data polarity inversion | <b>On</b><br><b>Off</b> |
| Enable RX data polarity inversion | <b>On</b><br><b>Off</b> |

**Table 103. Dynamic Reconfiguration Parameters**

| Parameter                                              | Range                   |
|--------------------------------------------------------|-------------------------|
| <b>Enable dynamic reconfiguration</b>                  | <b>On</b><br><b>Off</b> |
| <b>Share reconfiguration interface</b>                 | <b>On</b><br><b>Off</b> |
| <b>Enable Native PHY Debug Master Endpoint</b>         | <b>On</b><br><b>Off</b> |
| <b>De-couple reconfig_waitrequest from calibration</b> | <b>On</b><br><b>Off</b> |

**Table 104. Configuration Files Parameters**

| Parameter                                        | Range                   |
|--------------------------------------------------|-------------------------|
| <b>Configuration file prefix</b>                 | —                       |
| <b>Generate SystemVerilog package file</b>       | <b>On</b><br><b>Off</b> |
| <b>Generate C header file</b>                    | <b>On</b><br><b>Off</b> |
| <b>Generate MIF (Memory Initialization File)</b> | <b>On</b><br><b>Off</b> |

**Table 105. Generation Options Parameters**

| Parameter                                    | Range                   |
|----------------------------------------------|-------------------------|
| <b>Generate parameter documentation file</b> | <b>On</b><br><b>Off</b> |

#### Related Information

Using the Arria 10 Transceiver Native PHY IP Core on page 45

#### 2.6.2.4. Native PHY IP Ports for 10GBASE-R and 10GBASE-R with IEEE 1588v2 Transceiver Configurations

**Figure 63. High BER**

This figure shows the rx\_enh\_highber status signal going high when there are errors on the rx\_parallel\_data output.

|                  |                   |                   |                   |   |                   |
|------------------|-------------------|-------------------|-------------------|---|-------------------|
| rx_parallel_data | 1122334455667788h | X                 | 1122334455667788h | X | 1122334455667788h |
| rx_control       |                   | 00h               |                   |   |                   |
| tx_parallel_data |                   | 1122334455667788h |                   |   |                   |
| tx_control       |                   | 00h               |                   |   |                   |
| rx_enh_highber   | 0h                | X                 |                   |   | 1h                |

**Figure 64. Block Lock Assertion**

This figure shows the assertion on `rx_enh_blk_lock` signal when the Receiver detects the block delineation.

|                                |                   |                     |
|--------------------------------|-------------------|---------------------|
| <code>rx_parallel_data</code>  | 0100009C0100009Ch | X 0707070707070707h |
| <code>rx_control</code>        | 11h               | X FFh               |
| <code>tx_parallel_data</code>  |                   | 0707070707070707h   |
| <code>tx_control</code>        |                   | FFh                 |
| <code>rx_enh_highber</code>    | 0h                | X 1h                |
| <code>rx_ready</code>          | 0h                |                     |
| <code>rx_enh_block_lock</code> | 0h                | X 1h                |

The following figures show Idle insertion and deletion.

**Figure 65. IDLE Word Insertion**

This figure shows the insertion of IDLE words in the receiver data stream.



**Figure 66. IDLE Word Deletion**

This figure shows the deletion of IDLE words from the receiver data stream.



**Figure 67. OS Word Deletion**

This figure shows the deletion of Ordered set word in the receiver data stream.



### 2.6.3. 10GBASE-KR PHY IP Core

The 10GBASE-KR Ethernet PHY IP core supports the following features of Ethernet standards:

- Auto negotiation for backplane Ethernet as defined in *Clause 73* of the *IEEE 802.3 2008 Standard*. The 10GBASE-KR Ethernet PHY Function can auto negotiate between 1000BASE-X, 1000BASE-KR , and 1000BASE-KR with FEC.
- 10GBASE-KR Ethernet protocol with link training as defined in *Clause 72* of the *IEEE 802.3 2008 Standard*. In addition to the link-partner TX tuning as defined in *Clause 72*, this PHY also automatically configures the local device RX interface to achieve less than  $10^{-12}$  bit error rate (BER) target.
- Gigabit Media Independent Interface (GMII) to connect PHY with media access control (MAC) as defined in *Clause 35* of the *IEEE 802.3 2008 Standard*
- Forward Error Correction (FEC) as defined in *Clause 74* of the *IEEE 802.3 2008 Standard*

The Backplane Ethernet 10GBASE-KR PHY IP core includes the following new modules to enable operation over a backplane:

- Link Training (LT)—The LT mechanism allows the 10GBASE-KR PHY to automatically configure the link-partner TX PMDs for the lowest Bit Error Rate (BER). LT is defined in Clause 72 of IEEE Std 802.3ap-2007.
- Auto negotiation (AN)—The 10GBASE-KR PHY IP core can auto-negotiate between 1000BASE-KX (1GbE) and 10GBASE-KR (10GbE) PHY types. The AN function is mandatory for Backplane Ethernet. It is defined in *Clause 73* of the *IEEE Std 802.3ap-2007*.
- Forward Error Correction (FEC)—FEC function is an optional feature defined in *Clause 74* of *IEEE 802.3ap-2007*. It provides an error detection and correction mechanism.

#### Related Information

- IEEE Std 802.3ap-2008 Standard
- Standard for a Precision Clock Synchronization Protocol for Networked Measurement and Control Systems

#### 2.6.3.1. 10GBASE-KR PHY Release Information

**Table 106. 10GBASE-KR PHY Release Information**

| Item           | Description                                        |
|----------------|----------------------------------------------------|
| Version        | 19.1                                               |
| Release Date   | April 2019                                         |
| Ordering Codes | IP-10GBASEKRPHY (IP)<br>IPR-10GBASEKRPHY (Renewal) |
| Product ID     | 0106                                               |
| Vendor ID      | 6AF7                                               |

#### 2.6.3.2. 10GBASE-KR PHY Performance and Resource Utilization

This topic provides performance and resource utilization for the IP.

The following table shows the typical expected resource utilization for selected configurations using the Quartus Prime software v15.1 for Arria 10 devices. The numbers of ALMs and logic registers are rounded up to the nearest 100.

**Table 107. 10GBASE-KR PHY Performance and Resource Utilization**

| Variant                 | ALMs | ALUTs | Registers | M20K |
|-------------------------|------|-------|-----------|------|
| 10GBASE-KR PHY          | 2400 | 3750  | 3100      | 1    |
| 10GBASE-KR PHY with FEC | 2400 | 3750  | 3100      | 1    |

#### 2.6.3.3. 10GBASE-KR Functional Description

The following figure shows the supporting components inside the 10GBASE-KR PHY IP core.

**Figure 68. 10GBASE-KR PHY IP Core Block Diagram**



**Note:** The 10GBASE-KR PHY IP core does not support backplane applications with IEEE 1588 Precision Time Protocol.

The 10GBASE-KR PHY IP core includes the following components:

#### Standard and Enhanced PCS Datapaths

The Enhanced PCS and PMA inside the Native PHY are configured to be the 10GBASE-R PHY. Refer to the Standard PCS and Enhanced PCS architecture chapters for more details on how these blocks support 1G, 10G protocols and FEC.

#### Auto Negotiation, IEEE 802.3 Clause 73

The auto negotiation (AN) is needed to synchronize the start time of the link training on both sides of the link partners. This ensures that the link training can be done effectively within the 500 ms of the specified time frame as required.

#### Link Training (LT), IEEE 802.3 Clause 72

Arria 10 devices have soft link training IP that complies with the IEEE 802.3 Clause 72 standard training procedure. This IP includes:

- training frame lock that is different from the regular 64b/66b frame\_lock
- training frame generation
- the control channel codec
- Local Device (LD) coefficient update
- Link Partner (LP) coefficient generation

## Reconfiguration Block

The Reconfiguration Block performs Avalon memory-mapped interface writes to the PHY for both PCS and PMA reconfiguration. The Avalon memory-mapped interface master accepts requests from the PMA or PCS controller. It performs the Read-Modify-Write or Write commands on the Avalon memory-mapped interface. The PCS controller receives rate change requests from the Sequencer and translates them to a series of Read-Modify-Write or Write commands to the PMA and PCS.

Eight compile-time configuration modes are supported. The configuration modes include one set of four with reference clock at 322 MHz and one set of four with reference clock at 644 MHz. Each set of four consists of all combinations of FEC sublayer on/off.

**Figure 69.** **Reconfiguration Block Details**



## Related Information

- [Arria 10 Enhanced PCS Architecture](#) on page 473
- [Arria 10 Standard PCS Architecture](#) on page 491

### 2.6.3.4. Parameterizing the 10GBASE-KR PHY

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

The Arria 10 1G/10GbE and 10GBASE-KR PHY IP core allows you to select either the **Backplane-KR** or **1Gb/10Gb Ethernet** variant. When you select the **Backplane-KR** variant, the **Link Training (LT)** and **Auto Negotiation (AN)** tabs appear. The **1Gb/10Gb Ethernet** variant (1G/10GbE) does not implement the LT and AN functions.

Complete the following steps to parameterize the 10GBASE-KR PHY IP core in the parameter editor:

1. Instantiate the **Arria 10 1G/10GbE and 10GBASE-KR PHY** from the IP Catalog.

Refer to [Select and Instantiate the PHY IP Core](#) on page 33.

2. Select **Backplane-KR** from the **IP variant** list located under **Ethernet Intel FPGA IP Core Type**.
3. Use the parameter values in the tables in [10GBASE-R Parameters](#) on page 140, [10GBASE-KR Auto-Negotiation and Link Training Parameters](#) on page 140, and [10GBASE-KR Optional Parameters](#) on page 141 as a starting point. You can then modify the setting to meet your specific requirements.
4. Click **Generate HDL** to generate the **10GBASE-KR PHY** IP core top-level HDL file.

**Note:** You might observe timing violations. If the timing path is within the IP, you can ignore these violations.

#### Related Information

- [Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45
- [10GBASE-KR Auto-Negotiation and Link Training Parameters](#) on page 140

#### 2.6.3.4.1. General Options

The General Options allow you to specify options common to 10GBASE-KR mode.

**Table 108. General Options Parameters**

| Parameter Name                                   | Options                 | Description                                                                                                                                                                                                                                                               |
|--------------------------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable internal PCS reconfiguration logic</b> | <b>On</b><br><b>Off</b> | This parameter is only an option when SYNTH_SEQ = 0. When set to 0, it does not include the reconfiguration module or expose the start_pcs_reconfig or rc_busy ports. When set to 1, it provides a simple interface to initiate reconfiguration between 1G and 10G modes. |
| <b>Enable IEEE 1588 Precision Time Protocol</b>  | <b>On</b><br><b>Off</b> | When you turn on this parameter, you enable the IEEE 1588 Precision Time Protocol logic for both 1G and 10G modes.                                                                                                                                                        |
| <b>Enable M20K block ECC protection</b>          | <b>On</b><br><b>Off</b> | When you turn on this parameter, you enable error correction code (ECC) support on the embedded Nios CPU system. This parameter is only valid for the backplane variant.                                                                                                  |
| <b>Enable tx_pma_clkout port</b>                 | <b>On</b><br><b>Off</b> | When you turn on this parameter, the tx_pma_clkout port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                 |
| <b>Enable rx_pma_clkout port</b>                 | <b>On</b><br><b>Off</b> | When you turn on this parameter, the rx_pma_clkout port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                 |
| <b>Enable tx_divclk port</b>                     | <b>On</b><br><b>Off</b> | When you turn on this parameter, the tx_divclk port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                     |
| <b>Enable rx_divclk port</b>                     | <b>On</b><br><b>Off</b> | When you turn on this parameter, the rx_divclk port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                     |
| <b>Enable tx_clkout port</b>                     | <b>On</b><br><b>Off</b> | When you turn on this parameter, the tx_clkout port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                     |
| <b>Enable rx_clkout port</b>                     | <b>On</b><br><b>Off</b> | When you turn on this parameter, the rx_clkout port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                     |

*continued...*

| Parameter Name                                                               | Options                                       | Description                                                                                                                                                                                                                                        |
|------------------------------------------------------------------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable Hard PRBS support and Native PHY Debug Master Endpoint support</b> | <b>On</b><br><b>Off</b>                       | When you turn on this parameter, you enable the Native PHY Debug Master Endpoint (NPDME) and Hard PRBS data generation and checking logic in the Native PHY. The transceiver toolkit (TTK) requires NPDME to be enabled in the Native PHY IP core. |
| <b>Reference clock frequency</b>                                             | <b>644.53125 MHz</b><br><b>322.265625 MHz</b> | Specifies the input reference clock frequency. The default is <b>322.265625 MHz</b> .                                                                                                                                                              |
| <b>Enable additional control and status ports</b>                            | <b>On</b><br><b>Off</b>                       | When you turn on this option on, the core includes the <code>rx_block_lock</code> and <code>rx_hi_ber</code> output.                                                                                                                               |
| <b>Include FEC sublayer</b>                                                  | <b>On</b><br><b>Off</b>                       | When you turn on this parameter, the core includes logic to implement FEC and a soft 10GBASE-R PCS. This is applicable only for the 10G mode.                                                                                                      |
| <b>Set FEC_ability bit on power up and reset</b>                             | <b>On</b><br><b>Off</b>                       | When you turn on this parameter, the core sets the <code>Assert KR FEC Ability</code> bit (0xB0[16]) FEC ability bit during power up and reset, causing the core to assert the FEC ability. This option is required for FEC functionality.         |
| <b>Set FEC_Enable bit on power up and reset</b>                              | <b>On</b><br><b>Off</b>                       | When you turn on this parameter, the core sets the <code>KR FEC Request</code> bit (0xB0[18]) during power up and reset, causing the core to request the FEC ability during Auto Negotiation. This option is required for FEC functionality.       |

### Related Information

[Clock and Reset Interfaces](#) on page 143

#### 2.6.3.4.2. 10GBASE-R Parameters

The 10GBASE-R parameters specify basic features of the 10GBASE-R PCS. The FEC options also allow you to specify the FEC ability.

**Table 109. 10GBASE-R Parameters**

| Parameter Name                                    | Options                                       | Description                                                                                                         |
|---------------------------------------------------|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| <b>10GbE Reference clock frequency</b>            | <b>644.53125 MHz</b><br><b>322.265625 MHz</b> | Specifies the input reference clock frequency. The default is <b>322.265625 MHz</b> .                               |
| <b>Enable additional control and status ports</b> | <b>On</b><br><b>Off</b>                       | When you turn on this parameter, the core includes the <code>rx_block_lock</code> and <code>rx_hi_ber</code> ports. |

**Table 110. FEC Options**

| Parameter Name              | Options                 | Description                                                                                         |
|-----------------------------|-------------------------|-----------------------------------------------------------------------------------------------------|
| <b>Include FEC sublayer</b> | <b>On</b><br><b>Off</b> | When you turn on this parameter, the core includes logic to implement FEC and a soft 10GBASE-R PCS. |

#### 2.6.3.4.3. 10GBASE-KR Auto-Negotiation and Link Training Parameters

**Table 111. Auto Negotiation and Link Training Settings**

| Name                           | Range     | Description                                       |
|--------------------------------|-----------|---------------------------------------------------|
| <b>Enable Auto-Negotiation</b> | <b>On</b> | Enables or disables the Auto-Negotiation feature. |

*continued...*

| Name                                                       | Range                                  | Description                                                                                                                                                                                                                                                                                                                                |
|------------------------------------------------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                            | <b>Off</b>                             |                                                                                                                                                                                                                                                                                                                                            |
| <b>Pause ability-C0</b>                                    | <b>On</b><br><b>Off</b>                | Depends upon MAC. Local device pause capability C2:0 = D12:10 of AN word.<br>C0 is the same as PAUSE.                                                                                                                                                                                                                                      |
| <b>Pause ability-C1</b>                                    | <b>On</b><br><b>Off</b>                | Depends upon MAC. Local device pause capability C2:0 = D12:10 of AN word.<br>C1 is the same as ASM_DIR.                                                                                                                                                                                                                                    |
| <b>Enable Link Training</b>                                | <b>On</b><br><b>Off</b>                | Enables or disables the Link Training feature.                                                                                                                                                                                                                                                                                             |
| <b>Maximum bit error count</b>                             | <b>15, 31, 63, 127, 255, 511, 1023</b> | Specifies the number of bit errors for the error counter expected during each step of the link training. If the number of errors exceeds this number for each step, the core returns an error. The number of errors depends upon the amount of time for each step and the quality of the physical link media.<br>The default value is 511. |
| <b>Number of frames to send before sending actual data</b> | <b>127, 255</b>                        | This timer is started when the local receiver is trained and detects that the remote receiver is ready to receive data. The local physical medium dependent (PMD) layer delivers wait_timer additional training frames to ensure that the link partner correctly detects the local receiver state.<br>The default value is 127.            |

#### 2.6.3.4.4. 10GBASE-KR Optional Parameters

**Table 112. Optional Parameters**

In the following table, the exact correspondence between numerical values and voltages is pending characterization of the Native PHY.

| Name                                                    | Value   | Description                                                                                                                                                                                                                                            |
|---------------------------------------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PHY Management clock (MGMT_CLK) frequency in MHz</b> | 100–162 | Determines the value of the Link Fail Inhibit timer in IEEE 802.3 clause 73.10.2. <ul style="list-style-type: none"> <li>• 500 – 510 ms for BASE-R</li> <li>• 40 – 50 ms for GbE, XAUI</li> </ul> The default value is 125.                            |
| <b>VMAXRULE VOD tap MAX Rule</b>                        | 0–31    | Specifies the maximum $V_{OD}$ . The default value is 30.                                                                                                                                                                                              |
| <b>VMINRULE Device VMIN Rule</b>                        | 0–31    | Specifies the minimum $V_{OD}$ . The default value is 6.                                                                                                                                                                                               |
| <b>VODMINRULE VOD tap MIN Rule</b>                      | 0–31    | Specifies the minimum $V_{OD}$ for the first tap. The default value is 14.                                                                                                                                                                             |
| <b>VPOSTRULE</b>                                        | 0–38    | Specifies the maximum value that the internal algorithm for pre-emphasis tests in determining the optimum post-tap setting. The default value is 25.                                                                                                   |
| <b>VPRERULE</b>                                         | 0–31    | Specifies the maximum value that the internal algorithm for pre-emphasis tests in determining the optimum pre-tap setting. The default value is 16.                                                                                                    |
| <b>PREMVAL Preset VOD tap Value</b>                     | 0–31    | Specifies the Preset $V_{OD}$ value. This value is set by the Preset command of the link training protocol, defined in Clause 72.6.10.2.3.1 of the Link Training protocol. This is the value from which the algorithm starts. The default value is 30. |
| <b>PREPOSTVAL</b>                                       | 0–31    | Specifies the preset Post-tap value. The default value is 0.                                                                                                                                                                                           |

*continued...*

| Name                                   | Value | Description                                                                                                                                                                                         |
|----------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PREPVAL</b>                         | 0–15  | Specifies the preset Pre-tap value. The default value is 0.                                                                                                                                         |
| <b>INITMAINVAL Init VOD tap Value</b>  | 0–31  | Specifies the initial $V_{OD}$ value. This value is set by the Initialize command of the link training protocol, defined in Clause 72.6.10.2.3.2 of IEEE Std 802.3ap-2007. The default value is 25. |
| <b>INITPOSTVAL Init Post tap Value</b> | 0–38  | Specifies the initial Post-tap value. The default value is 13.                                                                                                                                      |
| <b>INITPREVAL Init Pre tap Value</b>   | 0–15  | Specifies the initial Pre-tap value. The default value is 3.                                                                                                                                        |

#### 2.6.3.4.5. Speed Detection Parameters

Selecting the speed detection option gives the PHY the ability to detect to link partners that support 1G/10GbE but have disabled Auto-Negotiation. During Auto-Negotiation, if AN cannot detect Differential Manchester Encoding (DME) pages from a link partner, the Sequencer reconfigures to 1GbE and 10GbE modes (Speed/Parallel detection) until it detects a valid 1G or 10GbE pattern.

**Table 113. Speed Detection**

| Parameter Name                                  | Options                 | Description                                                                                                                                                                                                                                                                                     |
|-------------------------------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable automatic speed detection</b>         | <b>On</b><br><b>Off</b> | When you turn this option <b>On</b> , the core includes the Sequencer block that sends reconfiguration requests to detect 1G or 10GbE when the Auto Negotiation block is not able to detect AN data.                                                                                            |
| <b>Avalon-MM clock frequency</b>                | 100–162 MHz             | Specifies the clock frequency for phy_mgmt_clk.                                                                                                                                                                                                                                                 |
| <b>Link fail inhibit time for 10Gb Ethernet</b> | 504 ms                  | Specifies the time before link_status is set to FAIL or OK. A link fails if the link_fail_inhibit_time has expired before link_status is set to OK. The legal range is 500–510 ms. For more information, refer to "Clause 73 Auto Negotiation for Backplane Ethernet" in IEEE Std 802.3ap-2007. |
| <b>Link fail inhibit time for 1Gb Ethernet</b>  | 40–50 ms                | Specifies the time before link_status is set to FAIL or OK. A link fails if the link_fail_inhibit_time has expired before link_status is set to OK. The legal range is 40–50 ms.                                                                                                                |
| <b>Enable PCS-Mode port</b>                     | <b>On</b><br><b>Off</b> | Enables or disables the PCS-Mode port.                                                                                                                                                                                                                                                          |

### 2.6.3.5. 10GBASE-KR PHY Interfaces

**Figure 70.** 10GBASE-KR Top-Level Signals



The block diagram shown in the GUI labels the external pins with the interface type and places the interface name inside the box. The interface type and name are used in the `_hw.tcl` file. If you turn on **Show signals**, the **block diagram** displays all top-level signal names.

#### Related Information

##### *Component Interface Tcl Reference*

For more information about `_hw.tcl` files

#### 2.6.3.5.1. Clock and Reset Interfaces

**Table 114.** Clock and Reset Signals

| Signal Name                     | Direction | Description                                                                                                                                     |
|---------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>tx_serial_clk_10g</code>  | Input     | High speed clock from the 10G PLL to drive 10G PHY TX PMA. The frequency of this clock is 5.15625 GHz.                                          |
| <code>tx_serial_clk_1g</code>   | Input     | High speed clock from 1G PLL to drive the 1G PHY TX PMA. This clock is not required if GbE is not used. The frequency of this clock is 625 MHz. |
| <code>rx_cdr_ref_clk_10g</code> | Input     | 10G PHY RX PLL reference clock. This clock frequency can be 644.53125 MHz or 322.2656 MHz.                                                      |
| <code>rx_cdr_ref_clk_1g</code>  | Input     | 1G PHY RX PLL reference clock. The frequency is 125 MHz. This clock is only required if 1G is enabled.                                          |

*continued...*

| <b>Signal Name</b> | <b>Direction</b> | <b>Description</b>                                                                                                                                                                                                                     |
|--------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_pma_clkout      | Output           | Clock used to drive the 10G TX PCS and 1G TX PCS parallel data. For example, when the hard PCS is reconfigured to the 10G mode without FEC enabled, the frequency is 257.81 MHz. The frequency is 161.13 MHz for 10G with FEC enabled. |
| rx_pma_clkout      | Output           | Clock used to drive the 10G RX PCS and 1G RX PCS parallel data. For example, when the hard PCS is reconfigured to the 10G mode without FEC enabled, the frequency is 257.81 MHz. The frequency is 161.13 MHz for 10G with FEC enabled. |
| tx_clkout          | Output           | XGMII/GMII TX clock for the TX parallel data source interface. This clock frequency is 257.81 MHz in 10G mode, and 161.13 MHz with FEC enabled.                                                                                        |
| rx_clkout          | Output           | XGMII RX clock for the RX parallel data source interface. This clock frequency is 257.81 in 10G mode, and 161.13 MHz with FEC enabled.                                                                                                 |
| tx_pma_div_clkout  | Output           | The divided 33 clock from the TX serializer. You can use this clock for the xgmii_tx_clk or xgmii_rx_clk. The frequency is 156.25 MHz for 10G. The frequencies are the same whether or not you enable FEC.                             |
| rx_pma_div_clkout  | Output           | The divided 33 clock from CDR recovered clock. The frequency is 156.25 MHz for 10G. The frequencies are the same whether or not you enable FEC. This clock is not used for clocking the 10G RX datapath.                               |
| tx_analogreset     | Input            | Resets the analog TX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                          |
| tx_digitalreset    | Input            | Resets the digital TX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                         |
| rx_analogreset     | Input            | Resets the analog RX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                          |
| rx_digitalreset    | Input            | Resets the digital RX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                         |
| usr_seq_reset      | Input            | Resets the sequencer. Initiates a PCS reconfiguration, and may restart AN, LT or both if these modes are enabled. Synchronous to mgmt_clk.                                                                                             |

### Related Information

- [Input Reference Clock Sources on page 382](#)
- [PLLs on page 358](#)

#### 2.6.3.5.2. Data Interfaces

**Table 115. XGMII Signals**

The MAC drives the TX XGMII signals to the 10GbE PHY. The 10GbE PHY drives the RX XGMII signals to the MAC.

| <b>Signal Name</b>                | <b>Direction</b> | <b>Clock Domain</b>         | <b>Description</b>                                                                                                                                                  |
|-----------------------------------|------------------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>10GbE XGMII Data Interface</b> |                  |                             |                                                                                                                                                                     |
| xgmii_tx_dc[71:0]                 | Input            | Synchronous to xgmii_tx_clk | XGMII data and control for 8 lanes. Each lane consists of 8 bits of data and 1 bit of control.                                                                      |
| xgmii_tx_clk                      | Input            | Clock signal                | Clock for single data rate (SDR) XGMII TX interface to the MAC. It should connect to xgmii_rx_clk. This clock can be connected to the tx_div_clkout; however, Intel |

*continued...*

| Signal Name       | Direction | Clock Domain                | Description                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------|-----------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |           |                             | <p>recommends that you connect it to a PLL for use with the Triple Speed Ethernet IP function. The frequency is 125 MHz for 1G and 156.25 MHz for 10G. This clock is driven from the MAC.</p> <p>The frequencies are the same whether or not you enable FEC.</p>                                                                                                                |
| xgmii_rx_dc[71:0] | Output    | Synchronous to xgmii_rx_clk | RX XGMII data and control for 8 lanes. Each lane consists of 8 bits of data and 1 bit of control.                                                                                                                                                                                                                                                                               |
| xgmii_rx_clk      | Input     | Clock signal                | <p>Clock for SDR XGMII RX interface to the MAC. This clock can be connected to the tx_div_clkout ; however, Intel recommends that you connect it to a PLL for use with the Triple Speed Ethernet IP function. The frequency is 125 MHz for 1G and 156.25 MHz for 10G. This clock is driven from the MAC.</p> <p>The frequencies are the same whether or not you enable FEC.</p> |

### 2.6.3.5.3. XGMII Mapping to Standard SDR XGMII Data

**Table 116. TX XGMII Mapping to Standard SDR XGMII Interface**

The 72-bit TX XGMII data bus format is different than the standard SDR XGMII interface. This table shows the mapping of this non-standard format to the standard SDR XGMII interface.

| Signal Name        | SDR XGMII Signal Name | Description    |
|--------------------|-----------------------|----------------|
| xgmii_tx_dc[7:0]   | xgmii_sdr_data[7:0]   | Lane 0 data    |
| xgmii_tx_dc[8]     | xgmii_sdr_ctrl[0]     | Lane 0 control |
| xgmii_tx_dc[16:9]  | xgmii_sdr_data[15:8]  | Lane 1 data    |
| xgmii_tx_dc[17]    | xgmii_sdr_ctrl[1]     | Lane 1 control |
| xgmii_tx_dc[25:18] | xgmii_sdr_data[23:16] | Lane 2 data    |
| xgmii_tx_dc[26]    | xgmii_sdr_ctrl[2]     | Lane 2 control |
| xgmii_tx_dc[34:27] | xgmii_sdr_data[31:24] | Lane 3 data    |
| xgmii_tx_dc[35]    | xgmii_sdr_ctrl[3]     | Lane 3 control |
| xgmii_tx_dc[43:36] | xgmii_sdr_data[39:32] | Lane 4 data    |
| xgmii_tx_dc[44]    | xgmii_sdr_ctrl[4]     | Lane 4 control |
| xgmii_tx_dc[52:45] | xgmii_sdr_data[47:40] | Lane 5 data    |
| xgmii_tx_dc[53]    | xgmii_sdr_ctrl[5]     | Lane 5 control |
| xgmii_tx_dc[61:54] | xgmii_sdr_data[55:48] | Lane 6 data    |
| xgmii_tx_dc[62]    | xgmii_sdr_ctrl[6]     | Lane 6 control |
| xgmii_tx_dc[70:63] | xgmii_sdr_data[63:56] | Lane 7 data    |
| xgmii_tx_dc[71]    | xgmii_sdr_ctrl[7]     | Lane 7 control |

**Table 117. RX XGMII Mapping to Standard SDR XGMII Interface**

The 72-bit RX XGMII data bus format is different from the standard SDR XGMII interface. This table shows the mapping of this non-standard format to the standard SDR XGMII interface.

| Signal Name        | XGMII Signal Name     | Description    |
|--------------------|-----------------------|----------------|
| xgmii_rx_dc[7:0]   | xgmii_sdr_data[7:0]   | Lane 0 data    |
| xgmii_rx_dc[8]     | xgmii_sdr_ctrl[0]     | Lane 0 control |
| xgmii_rx_dc[16:9]  | xgmii_sdr_data[15:8]  | Lane 1 data    |
| xgmii_rx_dc[17]    | xgmii_sdr_ctrl[1]     | Lane 1 control |
| xgmii_rx_dc[25:18] | xgmii_sdr_data[23:16] | Lane 2 data    |
| xgmii_rx_dc[26]    | xgmii_sdr_ctrl[2]     | Lane 2 control |
| xgmii_rx_dc[34:27] | xgmii_sdr_data[31:24] | Lane 3 data    |
| xgmii_rx_dc[35]    | xgmii_sdr_ctrl[3]     | Lane 3 control |
| xgmii_rx_dc[43:36] | xgmii_sdr_data[39:32] | Lane 4 data    |
| xgmii_rx_dc[44]    | xgmii_sdr_ctrl[4]     | Lane 4 control |
| xgmii_rx_dc[52:45] | xgmii_sdr_data[47:40] | Lane 5 data    |
| xgmii_rx_dc[53]    | xgmii_sdr_ctrl[5]     | Lane 5 control |
| xgmii_rx_dc[61:54] | xgmii_sdr_data[55:48] | Lane 6 data    |
| xgmii_rx_dc[62]    | xgmii_sdr_ctrl[6]     | Lane 6 control |
| xgmii_rx_dc[70:63] | xgmii_sdr_data[63:56] | Lane 7 data    |
| xgmii_rx_dc[71]    | xgmii_sdr_ctrl[7]     | Lane 7 control |

#### 2.6.3.5.4. Serial Data Interface

**Table 118. Serial Data Signals**

| Signal Name    | Direction | Description           |
|----------------|-----------|-----------------------|
| rx_serial_data | Input     | RX serial input data  |
| tx_serial_data | Output    | TX serial output data |

#### 2.6.3.5.5. Control and Status Interfaces

**Table 119. Control and Status Signals**

| Signal Name  | Direction | Clock Domain             | Description                                                                                                                                                                                                                                                      |
|--------------|-----------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| led_link     | Output    | Synchronous to tx_clkout | When asserted, indicates successful link synchronization.                                                                                                                                                                                                        |
| led_disp_err | Output    | Synchronous to rx_clkout | Disparity error signal indicating a 10-bit running disparity error. Asserted for one rx_clkout_1g cycle when a disparity error is detected. A running disparity error indicates that more than the previous and perhaps the current received group had an error. |
| led_an       | Output    | Synchronous to rx_clkout | Clause 37 Auto-negotiation status. The PCS function asserts this signal when auto-negotiation completes.                                                                                                                                                         |

*continued...*

| Signal Name    | Direction | Clock Domain            | Description                                                  |                                                                                                                                                                                                                                                                                                   |
|----------------|-----------|-------------------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| led_panel_link | Output    | Synchronous to mgmt_clk | When asserted, this signal indicates the following behavior: |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | Mode                                                         | Behavior                                                                                                                                                                                                                                                                                          |
|                |           |                         | 1000 Base-X without Auto-negotiation                         | When asserted, indicates successful link synchronization.                                                                                                                                                                                                                                         |
|                |           |                         | SGMII mode without Auto-negotiation                          | When asserted, indicates successful link synchronization.                                                                                                                                                                                                                                         |
|                |           |                         | 1000 Base-X with Auto-negotiation                            | Clause 37 Auto-negotiation status. The PCS function asserts this signal when auto-negotiation completes.                                                                                                                                                                                          |
|                |           |                         | SGMII mode with MAC mode Auto-negotiation                    | Clause 37 Auto-negotiation status. The PCS function asserts this signal when auto-negotiation completes.                                                                                                                                                                                          |
|                |           |                         | rx_block_lock                                                |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | Synchronous to rx_clkout                                     | Asserted to indicate that the block synchronizer has established synchronization.                                                                                                                                                                                                                 |
|                |           |                         | rx_hi_ber                                                    |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | Synchronous to rx_clkout                                     | Asserted by the BER monitor block to indicate a Sync Header high bit error rate greater than $10^{-4}$ .                                                                                                                                                                                          |
|                |           |                         | rx_is_lockedtodata                                           |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | Asynchronous signal                                          | When asserted, indicates the RX channel is locked to input data.                                                                                                                                                                                                                                  |
|                |           |                         | tx_cal_busy                                                  |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | Synchronous to mgmt_clk                                      | When asserted, indicates that the TX channel is being calibrated.                                                                                                                                                                                                                                 |
|                |           |                         | rx_cal_busy                                                  |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | Synchronous to mgmt_clk                                      | When asserted, indicates that the RX channel is being calibrated.                                                                                                                                                                                                                                 |
|                |           |                         | tx_pcfifo_error_1g                                           |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | N/A                                                          | When asserted, indicates that the standard PCS TX phase compensation FIFO is either full or empty.                                                                                                                                                                                                |
|                |           |                         | rx_pcfifo_error_1g                                           |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | N/A                                                          | When asserted, indicates that the Standard PCS RX phase compensation FIFO is either full or empty.                                                                                                                                                                                                |
|                |           |                         | lcl_rf                                                       |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | Synchronous to xgmii_tx_clk                                  | When asserted, indicates a Remote Fault (RF).The MAC sends this fault signal to its link partner. Bit D13 of the Auto Negotiation Advanced Remote Fault register (0xC2) records this error.                                                                                                       |
|                |           |                         | rx_clkslip                                                   |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | Asynchronous signal                                          | When asserted, the deserializer either skips one serial bit or pauses the serial clock for one cycle to achieve word alignment. As a result, the period of the parallel clock could be extended by 1 unit interval (UI) during the clock slip operation.This is an optional control input signal. |
|                |           |                         | rx_data_ready                                                |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | Synchronous to xgmii_rx_clk                                  | When asserted, indicates that the MAC can begin sending data to the PHY.                                                                                                                                                                                                                          |
|                |           |                         | rx_latency_adj_10g[15:0]                                     |                                                                                                                                                                                                                                                                                                   |
|                |           |                         | Synchronous to xgmii_rx_clk                                  | When you enable 1588, this signal outputs the real time latency in XGMII clock cycles (156.25 MHz) for the RX PCS and PMA datapath for 10G mode. Bits 0 to 9 represent the fractional number of clock cycles. Bits 10 to 15 represent the number of clock cycles.                                 |

*continued...*

| Signal Name              | Direction | Clock Domain                | Description                                                                                                                                                                                                                                                       |
|--------------------------|-----------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_latency_adj_10g[15:0] | Output    | Synchronous to xgmii_tx_clk | When you enable 1588, this signal outputs the real time latency in XGMII clock cycles (156.25 MHz) for the TX PCS and PMA datapath for 10G mode. Bits 0 to 9 represent the fractional number of clock cycles. Bits 10 to 15 represent the number of clock cycles. |
| rx_latency_adj_10g[21:0] | Output    | Synchronous to gmii_rx_clk  | When you enable 1588, this signal outputs the real time latency in GMII clock cycles (125 MHz) for the RX PCS and PMA datapath for 1G mode. Bits 0 to 9 represent the fractional number of clock cycles. Bits 10 to 21 represent the number of clock cycles.      |
| tx_latency_adj_10g[21:0] | Output    | Synchronous to gmii_tx_clk  | When you enable 1588, this signal outputs the real time latency in GMII clock cycles (125 MHz) for the TX PCS and PMA datapath for 1G mode. Bits 0 to 9 represent the fractional number of clock cycles. Bits 10 to 21 represent the number of clock cycles.      |

### 2.6.3.5.6. Dynamic Reconfiguration Interface

You can use the dynamic reconfiguration interface signals to dynamically change between 1G and 10G data rates.

**Table 120. Dynamic Reconfiguration Interface Signals**

| Signal Name        | Direction | Clock Domain            | Description                                                                                                                                                                                                                                                                                        |
|--------------------|-----------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rc_busy            | Output    | Synchronous to mgmt_clk | When asserted, indicates that reconfiguration is in progress. Synchronous to the mgmt_clk. This signal is only exposed under the following condition: <ul style="list-style-type: none"><li>• Turn on <b>Enable internal PCS reconfiguration logic</b></li></ul>                                   |
| start_pcs_reconfig | Input     | Synchronous to mgmt_clk | When asserted, initiates reconfiguration of the PCS. Sampled with the mgmt_clk. This signal is only exposed under the following condition: <ul style="list-style-type: none"><li>• Turn on <b>Enable internal PCS reconfiguration logic</b></li></ul>                                              |
| mode_1g_10gbar     | Input     | Synchronous to mgmt_clk | This signal selects either the 1G or 10G tx-parallel-data going to the PCS. It is only used for the 1G/10G application (variant) under the following circumstances: <ul style="list-style-type: none"><li>• the Sequencer (auto-rate detect) is not enabled</li><li>• 1G mode is enabled</li></ul> |

### 2.6.3.6. Avalon Memory-Mapped Interface Registers

The Avalon memory-mapped interface slave signals provide access to all registers.

**Table 121. Avalon Memory-Mapped Interface Signals**

| Signal Name     | Direction | Clock Domain            | Description                                                                                                                                                                                                                                                                                               |
|-----------------|-----------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mgmt_clk        | Input     | Clock                   | The clock signal that controls the Avalon memory-mapped interface PHY management. If you plan to use the same clock for the PHY management interface and transceiver reconfiguration, you must restrict the frequency to 100-125 MHz to meet the specification for the transceiver reconfiguration clock. |
| mgmt_clk_reset  | Input     | Asynchronous reset      | Resets the PHY management interface. This signal is active high and level sensitive.                                                                                                                                                                                                                      |
| mgmt_addr[10:0] | Input     | Synchronous to mgmt_clk | 11-bit Avalon memory-mapped interface address.                                                                                                                                                                                                                                                            |

*continued...*

| Signal Name          | Direction | Clock Domain            | Description                                                                                                                                                                                                              |
|----------------------|-----------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mgmt_writedata[31:0] | Input     | Synchronous to mgmt_clk | Input data.                                                                                                                                                                                                              |
| mgmt_readdata[31:0]  | Output    | Synchronous to mgmt_clk | Output data.                                                                                                                                                                                                             |
| mgmt_write           | Input     | Synchronous to mgmt_clk | Write signal. Active high.                                                                                                                                                                                               |
| mgmt_read            | Input     | Synchronous to mgmt_clk | Read signal. Active high.                                                                                                                                                                                                |
| mgmt_waitrequest     | Output    | Synchronous to mgmt_clk | When asserted, indicates that the Avalon memory-mapped interface slave is unable to respond to a read or write request. When asserted, control signals to the Avalon memory-mapped interface slave must remain constant. |

### Related Information

[Avalon Interface Specifications](#)

#### 2.6.3.6.1. 10GBASE-KR PHY Register Definitions

The Avalon memory-mapped interface slave signals provide access to the control and status registers.

The following table specifies the control and status registers that you can access over the Avalon memory-mapped interface PHY management. A single address space provides access to all registers.

**Note:** Unless otherwise indicated, the default value of all registers is 0.

**Note:** Writing to reserved or undefined register addresses may have undefined side effects.

**Table 122. 10GBASE-KR Register Definitions**

| Word Addr | Bit | R/W | Name             | Description                                                                                                                                                                                                                                                                                                                                                                              |
|-----------|-----|-----|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4B0     | 0   | RW  | Reset SEQ        | When set to 1, resets the 10GBASE-KR sequencer (auto rate detect logic), initiates a PCS reconfiguration, and may restart Auto-Negotiation, Link Training or both if AN and LT are enabled (10GBASE-KR mode). SEQ Force Mode[2:0] forces these modes. This reset self clears.                                                                                                            |
|           | 1   | RW  | Disable AN Timer | Auto-Negotiation disable timer. If disabled ( Disable AN Timer = 1 ), AN may get stuck and require software support to remove the ABILITY_DETECT capability if the link partner does not include this feature. In addition, software may have to take the link out of loopback mode if the link is stuck in the ACKNOWLEDGE_DETECT state. To enable this timer set Disable AN Timer = 0. |
|           | 2   | RW  | Disable LF Timer | When set to 1, disables the Link Fail timer. When set to 0, the Link Fault timer is enabled.                                                                                                                                                                                                                                                                                             |
|           | 3   | RW  | fail_lt_if_ber   | When set to 1, the last LT measurement is a non-zero number. Treat this as a failed run. 0 = normal.                                                                                                                                                                                                                                                                                     |

*continued...*

| <b>Word Addr</b> | <b>Bit</b> | <b>R/W</b> | <b>Name</b>                  | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                |
|------------------|------------|------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 7:4        | RW         | SEQ Force Mode[3:0]          | Forces the sequencer to a specific protocol. Must write the Reset SEQ bit to 1 for the Force to take effect. The following encodings are defined: <ul style="list-style-type: none"> <li>• 0000: No force</li> <li>• 0001: GigE</li> <li>• 0010: XAUI</li> <li>• 0100: 10GBASE-R</li> <li>• 0101: 10GBASE-KR</li> <li>• 1100: 10GBASE-KR FEC</li> </ul>                           |
|                  | 8          | RW         | Enable Arria 10 Calibration  | When set to 1, it enables the Arria 10 HSSI reconfiguration calibration as part of the PCS dynamic reconfiguration. 0 skips the calibration when the PCS is reconfigured.                                                                                                                                                                                                         |
|                  | 11:9       | RW         | Reserved                     | —                                                                                                                                                                                                                                                                                                                                                                                 |
|                  | 12         | RW         | LT failure response          | When set to 1, LT failure causes the PHY to go into data mode. When set to 0, LT failure restarts auto-negotiation (if enabled). If auto-negotiation is not enabled, the PHY restarts LT.                                                                                                                                                                                         |
|                  | 16         | RW         | KR FEC enable 171.0          | When set to 1, FEC is enabled. When set to 0, FEC is disabled. Resets to the CAPABLE_FEC parameter value.                                                                                                                                                                                                                                                                         |
|                  | 17         | RW         | KR FEC enable err ind 171.1  | When set to 1, KR PHY FEC decoding errors are signaled to the PCS. When set to 0, FEC errors are not signaled to the PCS. See <i>Clause 74.8.3 of IEEE 802.3ap-2007</i> for details.                                                                                                                                                                                              |
|                  | 18         | RW         | KR FEC request               | When set to 1, enables the FEC request. When this bit changes, you must assert the Reset SEQ bit (0x4B0[0]) to renegotiate with the new value. When set to 0, disables the FEC request.                                                                                                                                                                                           |
| 0x4B1            | 0          | R          | SEQ Link Ready               | When asserted, the sequencer is indicating that the link is ready.                                                                                                                                                                                                                                                                                                                |
|                  | 1          | R          | SEQ AN timeout               | When asserted, the sequencer has had an Auto Negotiation timeout. This bit is latched and is reset when the sequencer restarts Auto Negotiation.                                                                                                                                                                                                                                  |
|                  | 2          | R          | SEQ LT timeout               | When set, indicates that the Sequencer has had a timeout.                                                                                                                                                                                                                                                                                                                         |
|                  | 13:8       | R          | SEQ Reconfig Mode[5:0]       | Specifies the Sequencer mode for PCS reconfiguration. The following modes are defined: <ul style="list-style-type: none"> <li>• Bit 8, mode[0]: AN mode</li> <li>• Bit 9, mode[1]: LT Mode</li> <li>• Bit 10, mode[2]: 10G data mode</li> <li>• Bit 11, mode[3]: GigE data mode</li> <li>• Bit 12, mode[4]: Reserved for XAUI</li> <li>• Bit 13, mode[5]: 10G FEC mode</li> </ul> |
|                  | 16         | R          | KR FEC ability 170.0         | When set to 1, indicates that the 10GBASE-KR PHY supports FEC. Set as parameter SYNTH_FEC. For more information, refer to <i>Clause 45.2.1.84 of IEEE 802.3ap-2007</i> .                                                                                                                                                                                                          |
|                  | 17         | R          | KR FEC err ind ability 170.0 | When set to 1, indicates that the 10GBASE-KR PHY is capable of reporting FEC decoding errors to the PCS. For more information, refer to <i>Clause 74.8.3 of IEEE 802.3ap-2007</i> .                                                                                                                                                                                               |
|                  | 0:10       | —          | Reserved                     | —                                                                                                                                                                                                                                                                                                                                                                                 |
| 0x4B2            | 11         | RW         | KR FEC TX Error Insert       | Writing a 1 inserts one error pulse into the TX FEC depending on the Transcoder and Burst error settings. This bit self clears.                                                                                                                                                                                                                                                   |

*continued...*

| Word Addr      | Bit   | R/W | Name                          | Description                                                                                                                                                                                                                                                                                                                |
|----------------|-------|-----|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | 31:12 | —   | Reserved                      | —                                                                                                                                                                                                                                                                                                                          |
| 0x4B5 to 0x4BF |       |     | Reserved for 40G KR           | Intentionally left empty for address compatibility with 40G MAC + PHY KR solutions.                                                                                                                                                                                                                                        |
| 0x4C0          | 0     | RW  | AN enable                     | When set to 1, enables Auto Negotiation function. The default value is 1. For additional information, refer to 7.0.12 in Clause 73.8 Management Register Requirements, of <i>IEEE 802.3ap-2007</i> .                                                                                                                       |
|                | 1     | RW  | AN base pages ctrl            | When set to 1, the user base pages are enabled. You can send any arbitrary data via the user base page low/high bits. When set to 0, the user base pages are disabled and the state machine generates the base pages to send.                                                                                              |
|                | 2     | RW  | AN next pages ctrl            | When set to 1, the user next pages are enabled. You can send any arbitrary data via the user next page low/high bits. When set to 0, the user next pages are disabled. The state machine generates the null message to send as next pages.                                                                                 |
|                | 3     | RW  | Local device remote fault     | When set to 1, the local device signals Remote Faults in the Auto Negotiation pages. When set to 0, a fault has not occurred.                                                                                                                                                                                              |
|                | 4     | RW  | Force TX nonce value          | When set to 1, forces the TX nonce value to support some UNH testing modes. When set to 0, this is normal operation.                                                                                                                                                                                                       |
|                | 5     | RW  | Override AN Parameters Enable | When set to 1, overrides the AN_TECH, AN_FEC, and AN_PAUSE parameters and uses the bits in 0x4C3 instead. You must reset the Sequencer to reconfigure and restart into Auto Negotiation mode. When set to 0, this is normal operation and is used with 0x4B0 bit 0 and 0x4C3 bits[30:16].                                  |
| 0x4C1          | 0     | RW  | Reset AN                      | When set to 1, resets all the 10GBASE-KR Auto Negotiation state machines. This bit is self-clearing.                                                                                                                                                                                                                       |
|                | 4     | RW  | Restart AN TX SM              | When set to 1, restarts the 10GBASE-KR TX state machine. This bit self clears. This bit is active only when the TX state machine is in the Auto Negotiation state. For more information, refer to 7.0.9 in Clause 73.8 Management Register Requirements of <i>IEEE 802.3ap-2007</i> .                                      |
|                | 8     | RW  | AN Next Page                  | When asserted, new next page info is ready to send. The data is in the XNP TX registers. When 0, the TX interface sends null pages. This bit self clears. Next Page (NP) is encoded in bit D15 of Link Codeword. For more information, refer to Clause 73.6.9 and 7.16.15 of Clause 45.2.7.6 of <i>IEEE 802.3ap-2007</i> . |
| 0x4C2          | 1     | RO  | AN page received              | When set to 1, a page has been received. When 0, a page has not been received. The current value clears when the register is read. For more information, refer to 7.1.6 in Clause 73.8 of <i>IEEE 802.3ap-2007</i> .                                                                                                       |
|                | 2     | RO  | AN Complete                   | When asserted, Auto-Negotiation has completed. When 0, Auto Negotiation is in progress. For more information, refer to 7.1.5 in Clause 73.8 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                  |
|                | 3     | RO  | AN ADV Remote Fault           | When set to 1, fault information has been sent to the link partner. When 0, a fault has not occurred. The current value clears when the register is read. Remote Fault (RF) is encoded in bit D13 of the base Link Codeword. For more information, refer to Clause 73.6.7 of and 7.16.13 of <i>IEEE 802.3ap-2007</i> .     |
|                | 4     | RO  | AN RX SM Idle                 | When set to 1, the Auto-Negotiation state machine is in the idle state. Incoming data is not Clause 73 compatible. When 0, the Auto-Negotiation is in progress.                                                                                                                                                            |

*continued...*

| Word Addr | Bit   | R/W | Name                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------|-------|-----|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 5     | RO  | AN Ability                           | When set to 1, the transceiver PHY is able to perform Auto Negotiation. When set to 0, the transceiver PHY is not able to perform Auto Negotiation. If your variant includes Auto Negotiation, this bit is tied to 1. For more information, refer to 7.1.3 and 7.48.0 of Clause 45 of IEEE 802.3ap-2007.                                                                                                                                                                                                        |
|           | 6     | RO  | AN Status                            | When set to 1, link is up. When 0, the link is down. The current value clears when the register is read. For more information, refer to 7.1.2 of Clause 45 of IEEE 802.3ap-2007.                                                                                                                                                                                                                                                                                                                                |
|           | 7     | RO  | LP AN Ability                        | When set to 1, the link partner is able to perform Auto Negotiation. When 0, the link partner is not able to perform Auto-Negotiation. For more information, refer to 7.1.0 of Clause 45 of IEEE 802.3ap-2007.                                                                                                                                                                                                                                                                                                  |
| 0x4C2     | 8     | RO  | FEC negotiated – enable FEC from SEQ | When set to 1, PHY is negotiated to perform FEC. When set to 0, PHY is not negotiated to perform FEC.                                                                                                                                                                                                                                                                                                                                                                                                           |
|           | 9     | RO  | Seq AN Failure                       | When set to 1, a sequencer Auto Negotiation failure has been detected. When set to 0, an Auto Negotiation failure has not been detected.                                                                                                                                                                                                                                                                                                                                                                        |
|           | 17:12 | RO  | KR AN Link Ready[5:0]                | Provides a one-hot encoding of an_receive_idle = true and link status for the supported link as described in Clause 73.10.1. The following encodings are defined: <ul style="list-style-type: none"> <li>• 6'b000000: 1000BASE-KX</li> <li>• 6'b000001: 10GBASE-KX4</li> <li>• 6'b000100: 10GBASE-KR</li> <li>• 6'b001000: 40GBASE-KR4</li> <li>• 6'b010000: 40GBASE-CR4</li> <li>• 6'b100000: 100GBASE-CR10</li> </ul>                                                                                         |
| 0x4C3     | 15:0  | RW  | User base page low                   | The Auto Negotiation TX state machine uses these bits if the Auto Negotiation base pages ctrl bit is set. The following bits are defined: <ul style="list-style-type: none"> <li>• [15]: Next page bit</li> <li>• [14]: ACK which is controlled by the SM</li> <li>• [13]: Remote Fault bit</li> <li>• [12:10]: Pause bits</li> <li>• [9:5]: Echoed nonce which are set by the state machine</li> <li>• [4:0]: Selector</li> </ul> Bit 49, the PRBS bit, is generated by the Auto Negotiation TX state machine. |
|           | 21:16 | RW  | Override AN_TECH[5:0]                | AN_TECH value with which to override the current value. The following bits are defined: <ul style="list-style-type: none"> <li>• Bit-16 = AN_TECH[0] = 1000BASE-KX</li> <li>• Bit-17 = AN_TECH[1] = XAUI</li> <li>• Bit-18 = AN_TECH[2] = 10GBASE-KR</li> <li>• Bit-19 = AN_TECH[3] = 40G</li> <li>• Bit-20 = AN_TECH[4] = CR-4</li> <li>• Bit-21 = AN_TECH[5] = 100G</li> </ul> You must set 0x4C0 bit-5 for this to take effect .                                                                             |
|           | 25:24 | RW  | Override AN_FEC[1:0]                 | AN_FEC value with which to override the current value. The following bits are defined: <ul style="list-style-type: none"> <li>• Bit-24 = AN_FEC [0] = Capability</li> <li>• Bit-25 = AN_FEC [1] = Request</li> </ul> You must set 0x4C0 bit-5 for this to take effect.                                                                                                                                                                                                                                          |

continued...

| Word Addr | Bit   | R/W | Name                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|-------|-----|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 30:28 | RW  | Override AN_PAUSE[2:0] | <p>AN_PAUSE value with which to override the current value. The following bits are defined:</p> <ul style="list-style-type: none"> <li>• Bit-28 = AN_PAUSE [0] = Pause Ability</li> <li>• Bit-29 = AN_PAUSE [1] = Asymmetric Direction</li> <li>• Bit-30 = AN_PAUSE [2] = Reserved</li> </ul> <p>You must set 0x4C0 bit-5 for this to take effect.</p>                                                                                                                                                                                      |
| 0x4C4     | 31:0  | RW  | User base page high    | <p>The Auto Negotiation TX state machine uses these bits if the Auto Negotiation base pages ctrl bit is set. The following bits are defined:</p> <ul style="list-style-type: none"> <li>• [29:5]: Correspond to page bits 45:21 which are the technology ability.</li> <li>• [4:0]: Correspond to bits 20:16 which are TX nonce bits. Bit 49, the PRBS bit, is generated by the Auto Negotiation TX state machine.</li> </ul>                                                                                                               |
| 0x4C5     | 15:0  | RW  | User Next page low     | <p>The Auto Negotiation TX state machine uses these bits if the AN Next Page control bit is set. The following bits are defined:</p> <ul style="list-style-type: none"> <li>• [15]: next page bit</li> <li>• [14]: ACK controlled by the state machine</li> <li>• [13]: Message Page (MP) bit</li> <li>• [12]: ACK2 bit</li> <li>• [11]: Toggle bit</li> </ul> <p>For more information, refer to Clause 73.7.7.1 Next Page encodings of IEEE 802.3ap-2007. Bit 49, the PRBS bit, is generated by the Auto-Negotiation TX state machine.</p> |
| 0x4C6     | 31:0  | RW  | User Next page high    | <p>The Auto Negotiation TX state machine uses these bits if the Auto Negotiation next pages ctrl bit is set. Bits [31:0] correspond to page bits [47:16]. Bit 49, the PRBS bit, is generated by the Auto Negotiation TX state machine.</p>                                                                                                                                                                                                                                                                                                  |
| 0x4C7     | 15:0  | RO  | LP base page low       | <p>The AN RX state machine receives these bits from the link partner. The following bits are defined:</p> <ul style="list-style-type: none"> <li>• [15] Next page bit</li> <li>• [14] ACK which is controlled by the state machine</li> <li>• [13] RF bit</li> <li>• [12:10] Pause bits</li> <li>• [9:5] Echoed Nonce which are set by the state machine</li> <li>• [4:0] Selector</li> </ul>                                                                                                                                               |
| 0x4C8     | 31:0  | RO  | LP base page high      | <p>The AN RX state machine receives these bits from the link partner. The following bits are defined:</p> <ul style="list-style-type: none"> <li>• [31:30]: Reserved</li> <li>• [29:5]: Correspond to page bits [45:21] which are the technology ability</li> <li>• [4:0]: Correspond to bits [20:16] which are TX Nonce bits</li> </ul>                                                                                                                                                                                                    |
| 0x4C9     | 15:0  | RO  | LP Next page low       | <p>The AN RX state machine receives these bits from the link partner. The following bits are defined:</p> <ul style="list-style-type: none"> <li>• [15]: Next page bit</li> <li>• [14]: ACK which is controlled by the state machine</li> <li>• [13]: MP bit</li> <li>• [12] ACK2 bit</li> <li>• [11] Toggle bit</li> </ul> <p>For more information, refer to Clause 73.7.7.1 Next Page encodings of IEEE 802.3ap-2007.</p>                                                                                                                 |

*continued...*

| <b>Word Addr</b> | <b>Bit</b> | <b>R/W</b> | <b>Name</b>                    | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|------------|------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4CA            | 31:0       | RO         | LP Next page high              | The AN RX state machine receives these bits from the link partner. Bits [31:0] correspond to page bits [47:16]                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0x4CB            | 24:0       | RO         | AN LP ADV Tech_A[24:0]         | <p>Received technology ability field bits of Clause 73 Auto Negotiation. The 10GBASE-KR PHY supports A0 and A2. The following protocols are defined:</p> <ul style="list-style-type: none"> <li>• A0 1000BASE-KX</li> <li>• A1 10GBASE-KX4</li> <li>• A2 10GBASE-KR</li> <li>• A3 40GBASE-KR4</li> <li>• A4 40GBASE-CR4</li> <li>• A5 100GBASE-CR10</li> <li>• A24:6 are reserved</li> </ul> <p>For more information, refer to Clause 73.6.4 and AN LP base page ability registers (7.19-7.21) of Clause 45 of <i>IEEE 802.3ap-2007</i>.</p> |
|                  | 26:25      | RO         | AN LP ADV FEC_F[1:0]           | Received FEC ability bits FEC (F0:F1) is encoded in bits D46:D47 of the base Link Codeword. F0 is FEC ability. F1 is FEC requested. See Clause 73.6.5 of <i>IEEE 802.3ap-2007</i> for details.                                                                                                                                                                                                                                                                                                                                               |
|                  | 27         | RO         | AN LP ADV Remote Fault         | Received Remote Fault (RF) ability bits. RF is encoded in bit D13 of the base link codeword in Clause 73 AN. For more information, refer to Clause 73.6.7 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                                                                                                      |
|                  | 30:28      | RO         | AN LP ADV Pause Ability_C[2:0] | <p>Received pause ability bits. Pause (C0:C1) is encoded in bits D11:D10 of the base link codeword in Clause 73 AN as follows:</p> <ul style="list-style-type: none"> <li>• C0 is the same as PAUSE as defined in Annex 28B</li> <li>• C1 is the same as ASM_DIR as defined in Annex 28B</li> <li>• C2 is reserved</li> </ul>                                                                                                                                                                                                                |
| 0x4D0            | 0          | RW         | Link Training enable           | When 1, enables the 10GBASE-KR start-up protocol. When 0, disables the 10GBASE-KR start-up protocol. The default value is 1. For more information, refer to Clause 72.6.10.3.1 and 10GBASE-KR PMD control register bit (1.150.1) of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                               |
|                  | 1          | RW         | dis_max_wait_tmr               | When set to 1, disables the LT max_wait_timer. Used for characterization mode when setting much longer BER timer values. The default value is 0.                                                                                                                                                                                                                                                                                                                                                                                             |
|                  | 2          | RW         | Reserved                       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                  | 3          | RW         | Reserved                       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                  | 7:4        | RW         | main_step_cnt [3:0]            | Specifies the number of equalization steps for each main tap update. There are about 20 settings for the internal algorithm to test. The valid range is 1-15. The default value is 4'b0001.                                                                                                                                                                                                                                                                                                                                                  |
|                  | 11:8       | RW         | prepost_step_cnt [3:0]         | Specifies the number of equalization steps for each pre- and post-tap update. From 16-31 steps are possible. The default value is 4'b0001.                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0x4D0            | 14:12      | RW         | equal_cnt [2:0]                | <p>Adds hysteresis to the error count to avoid local minimums. The following values are defined:</p> <ul style="list-style-type: none"> <li>• 000 = 0</li> <li>• 001 = 2</li> <li>• 010 = 4</li> <li>• 011 = 8</li> <li>• 100 = 16</li> </ul>                                                                                                                                                                                                                                                                                                |

*continued...*

| Word Addr | Bit   | R/W | Name                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------|-------|-----|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |       |     |                                            | <ul style="list-style-type: none"> <li>• 101 = 32</li> <li>• 110 = 64</li> <li>• 111 = 128</li> </ul> The default value is 101.                                                                                                                                                                                                                                                                                        |
|           | 15    | RW  | disable Initialize PMA on max_wait_timeout | When set to 1, PMA values (VOD, Pre-tap, Post-tap) are not initialized upon entry into the Training_Failure state. This happens when max_wait_timer_done, which sets training_failure = true (reg 0xD2 bit 3). Used for UNH testing. When set to 0, PMA values are initialized upon entry into Training_Failure state. Refer to Figure 72-5 of IEEE 802.3ap-2007 for more details. The default value is 0.             |
|           | 16    | RW  | Ovride LP Coef enable                      | When set to 1, overrides the link partner's equalization coefficients; software changes the update commands sent to the link partner TX equalizer coefficients. When set to 0, uses the Link Training logic to determine the link partner coefficients. Used with 0x4D1 bit-4 and 0x4D4 bits[7:0]. The default value is 0.                                                                                             |
|           | 17    | RW  | Ovride Local RX Coef enable                | When set to 1, overrides the local device equalization coefficients generation protocol. When set, the software changes the local TX equalizer coefficients. When set to 0, uses the update command received from the link partner to determine local device coefficients. Used with 0x4D1 bit-8 and 0x4D4 bits[23:16]. The default value is 0.                                                                        |
| 0x4D0     | 18    | RW  | VOD Training Enable                        | Defines whether or not to skip adjustment of the link partner's VOD (main tap) during link training. The following values are defined: <ul style="list-style-type: none"> <li>• 1 = Exercise VOD (main tap) adjustment during link training</li> <li>• 0 = Skip VOD (main tap) adjustment during link training</li> </ul> The default value is 0.                                                                      |
|           | 19    | RW  | Bypass DFE                                 | Defines whether or not Decision Feedback Equalization (DFE) is enabled at the end of link training. The following values are defined: <ul style="list-style-type: none"> <li>• 1 = Bypass continuous adaptive DFE at the end of link training</li> <li>• 0 = Enable continuous adaptive DFE at the end of link training</li> </ul> The default value for simulation is 1. The default value for hardware is 0.         |
|           | 21:20 | RW  | dfe_freeze_mode                            | Defines the behavior of DFE taps at the end of link training <ul style="list-style-type: none"> <li>• 00 = do not freeze any DFE taps</li> <li>• 01 = Freeze all DFE taps</li> <li>• 10 = reserved</li> <li>• 11 = reserved</li> </ul> The default value is 01.<br><i>Note:</i> These bits are only effective when bit [19] is set to 0.                                                                               |
| 0x4D0     | 22    | RW  | adp_ctle_vga_mode                          | Defines whether or not CTLE/VGA adaptation is in adaptive or manual mode. The following values are defined: <ul style="list-style-type: none"> <li>• 0 = CTLE sweep before start of TX-EQ during link training.</li> <li>• 1 = manual CTLE mode. Link training algorithm sets fixed CTLE value, as specified in bits [28:24]. The default value is 1 for simulation. .</li> </ul> The default value is 0 for hardware. |

*continued...*

| Word Addr | Bit   | R/W | Name                                   | Description                                                                                                                                                                                                                                                                                                               |
|-----------|-------|-----|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 28:24 | RW  | Manual CTLE                            | Defines the CTLE value used by the link training algorithm when in manual CTLE mode. These bits are only effective when 0x4D0[22] is set to 1.<br>The default value is 1.                                                                                                                                                 |
|           | 31:29 | RW  | Manual VGA                             | Defines the VGA value used by the link training algorithm when in manual VGA mode. These bits are only effective when 0x4D0[22] is set to 1.<br>The default value is 4 for simulation. The default value is 7 for hardware.                                                                                               |
| 0x4D1     | 0     | RW  | Restart Link training                  | When set to 1, resets the 10GBASE-KR start-up protocol. When set to 0, continues normal operation. This bit self clears. For more information, refer to the state variable <code>mr_restart_training</code> as defined in Clause 72.6.10.3.1 and 10GBASE-KR PMD control register bit (1.150.0) <i>IEEE 802.3ap-2007</i> . |
|           | 4     | RW  | Updated TX Coef new                    | When set to 1, there are new link partner coefficients available to send. The LT logic starts sending the new values set in 0x4D4 bits[7:0] to the remote device. When set to 0, continues normal operation. This bit self clears. Must enable this override in 0x4D0 bit16.                                              |
|           | 8     | RW  | Updated RX coef new                    | When set to 1, new local device coefficients are available. The LT logic changes the local TX equalizer coefficients as specified in 0x4D4 bits[23:16]. When set to 0, continues normal operation. This bit self clears. Must enable the override in 0x4D0 bit17.                                                         |
|           | 21:20 | RW  | Reserved                               | Reserved                                                                                                                                                                                                                                                                                                                  |
|           | 0     | RO  | Link Trained - Receiver status         | When set to 1, the receiver is trained and is ready to receive data. When set to 0, receiver training is in progress. For more information, refer to the state variable <code>rx_trained</code> as defined in Clause 72.6.10.3.1 of <i>IEEE 802.3ap-2007</i> .                                                            |
| 0x4D2     | 1     | RO  | Link Training Frame lock               | When set to 1, the training frame delineation has been detected. When set to 0, the training frame delineation has not been detected. For more information, refer to the state variable <code>frame_lock</code> as defined in Clause 72.6.10.3.1 of <i>IEEE 802.3ap-2007</i> .                                            |
|           | 2     | RO  | Link Training Start-up protocol status | When set to 1, the start-up protocol is in progress. When set to 0, start-up protocol has completed. For more information, refer to the state variable <code>training</code> as defined in Clause 72.6.10.3.1 of <i>IEEE 802.3ap-2007</i> .                                                                               |
|           | 3     | RO  | Link Training failure                  | When set to 1, a training failure has been detected. When set to 0, a training failure has not been detected. For more information, refer to the state variable <code>training_failure</code> as defined in Clause 72.6.10.3.1 of <i>IEEE 802.3ap-2007</i> .                                                              |
|           | 4     | RO  | Link Training Error                    | When set to 1, excessive errors occurred during Link Training. When set to 0, the BER is acceptable.                                                                                                                                                                                                                      |
|           | 5     | RO  | Link Training Frame lock Error         | When set to 1, indicates a frame lock was lost during Link Training. If the tap settings specified by the fields of 0x4D5 are the same as the initial parameter value, the frame lock error was unrecoverable.                                                                                                            |
|           | 6     | RO  | RXEQ Frame Lock Loss                   | Frame lock not detected at some point during RXEQ, possibly triggering conditional RXEQ mode.                                                                                                                                                                                                                             |
|           | 7     | RO  | CTLE Fine-grained Tuning Error         | Could not determine the best CTLE due to maximum BER limit at each step in the Fine-grained Tuning mode.                                                                                                                                                                                                                  |

continued...

| Word Addr | Bit   | R/W      | Name                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------|-------|----------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4D3     | 9:0   | RW       | ber_time_frames            | <p>Specifies the number of training frames to examine for bit errors on the link for each step of the equalization settings. Used only when ber_time_k_frames is 0. The following values are defined:</p> <ul style="list-style-type: none"> <li>• A value of 2 is about <math>10^3</math> bytes</li> <li>• A value of 20 is about <math>10^4</math> bytes</li> <li>• A value of 200 is about <math>10^5</math> bytes</li> </ul> <p>The default value for simulation is 2'b11. The default value for hardware is 0.</p>                                                                                                                                                                                                                                                                                                                                  |
|           | 19:10 | RW       | ber_time_k_frames          | <p>Specifies the number of thousands of training frames to examine for bit errors on the link for each step of the equalization settings. Set ber_time_m_frames = 0 for time/bits to match the following values:</p> <ul style="list-style-type: none"> <li>• A value of 3 is about <math>10^7</math> bits = about 1.3 ms</li> <li>• A value of 25 is about <math>10^8</math> bits = about 11ms</li> <li>• A value of 250 is about <math>10^9</math> bits = about 11 0ms</li> </ul> <p>The default value for simulation is 0. The default value for hardware is 0xF.</p>                                                                                                                                                                                                                                                                                 |
|           | 29:20 | RW       | ber_time_m_frames          | <p>Specifies the number of millions of training frames to examine for bit errors on the link for each step of the equalization settings. Set ber_time_k_frames = 4'd1000 = 0x43E8 for time/bits to match the following values:</p> <ul style="list-style-type: none"> <li>• A value of 3 is about <math>10^{10}</math> bits = about 1.3 seconds</li> <li>• A value of 25 is about <math>10^{11}</math> bits = about 11 seconds</li> <li>• A value of 250 is about <math>10^{12}</math> bits = about 110 seconds</li> </ul>                                                                                                                                                                                                                                                                                                                               |
| 0x4D4     | 5:0   | RO or RW | LD coefficient update[5:0] | <p>Reflects the contents of the first 16-bit word of the training frame sent from the local device control channel. Normally, the bits in this register are read-only; however, when you override training by setting the Override Coef enable control bit, these bits become writable. The following fields are defined:</p> <ul style="list-style-type: none"> <li>• [5: 4]: Coefficient (+1) update <ul style="list-style-type: none"> <li>— 2'b11: Reserved</li> <li>— 2'b01: Increment</li> <li>— 2'b10: Decrement</li> <li>— 2'b00: Hold</li> </ul> </li> <li>• [3:2]: Coefficient (0) update (same encoding as [5:4])</li> <li>• [1:0]: Coefficient (-1) update (same encoding as [5:4])</li> </ul> <p>For more information, refer to 10G BASE-KR LD coefficient update register bits (1.154.5:0) in Clause 45.2.1.80.3 of IEEE 802.3ap-2007.</p> |
|           | 6     | RO or RW | LD Initialize Coefficients | <p>When set to 1, requests the link partner coefficients be set to configure the TX equalizer to its INITIALIZE state. When set to 0, continues normal operation. For more information, refer to 10G BASE-KR LD coefficient update register bits (1.154.12) in Clause 45.2.1.80.3 and Clause 72.6.10.2.3.2 of IEEE 802.3ap-2007.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|           | 7     | RO or RW | LD Preset Coefficients     | <p>When set to 1, requests the link partner coefficients be set to a state where equalization is turned off. When set to 0 the link operates normally. For more information, refer to 10G BASE-KR LD coefficient update register bit (1.154.13) in Clause 45.2.1.80.3 and Clause 72.6.10.2.3.2 of IEEE 802.3ap-2007.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0x4D4     | 13:8  | RO       | LD coefficient status[5:0] | <p>Status report register for the contents of the second, 16-bit word of the training frame most recently sent from the local device control channel. The following fields are defined:</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

**continued...**

| <b>Word Addr</b> | <b>Bit</b> | <b>R/W</b> | <b>Name</b>                                | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|------------|------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |            |            |                                            | <ul style="list-style-type: none"> <li>[5:4]: Coefficient (post-tap)           <ul style="list-style-type: none"> <li>— 2'b11: Maximum</li> <li>— 2'b01: Minimum</li> <li>— 2'b10: Updated</li> <li>— 2'b00: Not updated</li> </ul> </li> <li>[3:2]: Coefficient (0) (same encoding as [5:4])</li> <li>[1:0]: Coefficient (pre-tap) (same encoding as [5:4])</li> </ul> <p>For more information, refer to 10G BASE-KR LD status report register bit (1.155.5:0) in Clause 45.2.1.81 of <i>IEEE 802.3ap-2007</i>.</p>                                                                                                                                                                                                                                                                                                                                                    |
|                  | 14         | RO         | Link Training ready<br>- LD Receiver ready | When set to 1, the local device receiver has determined that training is complete and is prepared to receive data. When set to 0, the local device receiver is requesting that training continue. Values for the receiver ready bit are defined in Clause 72.6.10.2.4.4. For more information, refer to 10G BASE-KR LD status report register bit (1.155.15) in Clause 45.2.1.81 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0x4D4            | 21:16      | RO or RW   | LP coefficient update[5:0]                 | <p>Reflects the contents of the first 16-bit word of the training frame most recently received from the control channel. Normally the bits in this register are read only; however, when training is disabled by setting low the KR Training enable control bit, these bits become writable. The following fields are defined:</p> <ul style="list-style-type: none"> <li>[5:4]: Coefficient (+1) update           <ul style="list-style-type: none"> <li>— 2'b11: Reserved</li> <li>— 2'b01: Increment</li> <li>— 2'b10: Decrement</li> <li>— 2'b00: Hold</li> </ul> </li> <li>[3:2]: Coefficient (0) update (same encoding as [5:4])</li> <li>[1:0]: Coefficient (-1) update (same encoding as [5:4])</li> </ul> <p>For more information, refer to 10G BASE-KR LP coefficient update register bits (1.152.5:0) in Clause 45.2.1.78.3 of <i>IEEE 802.3ap-2007</i>.</p> |
|                  | 22         | RO or RW   | LP Initialize Coefficients                 | When set to 1, the local device transmit equalizer coefficients are set to the INITIALIZE state. When set to 0, normal operation continues. The function and values of the initialize bit are defined in Clause 72.6.10.2.3.2. For more information, refer to 10G BASE-KR LP coefficient update register bits (1.152.12) in Clause 45.2.1.78.3 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                  | 23         | RO or RW   | LP Preset Coefficients                     | When set to 1, the local device TX coefficients are set to a state where equalization is turned off. Preset coefficients are used. When set to 0, the local device operates normally. The function and values of the initialize bit are defined in Clause 72.6.10.2.3.1. The function and values of the preset bit are defined in Clause 72.6.10.2.3.2. For more information, refer to 10G BASE-KR LP coefficient update register bits (1.152.13) in Clause 45.2.1.78.3 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                                                                                                                   |
| 0x4D4            | 29:24      | RO         | LP coefficient status[5:0]                 | Status report register reflects the contents of the second, 16-bit word of the training frame most recently received from the control channel: The following fields are defined:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

*continued...*

| Word Addr | Bit   | R/W | Name                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|-------|-----|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |       |     |                            | <ul style="list-style-type: none"> <li>[5:4]: Coefficient (+1)           <ul style="list-style-type: none"> <li>2'b11: Maximum</li> <li>2'b01: Minimum</li> <li>2'b10: Updated</li> <li>2'b00: Not updated</li> </ul> </li> <li>[3:2]: Coefficient (0) (same encoding as [5:4])</li> <li>n [1:0]: Coefficient (-1) (same encoding as [5:4])</li> </ul> <p>For more information, refer to 10G BASE-KR LP status report register bits (1.153.5:0) in Clause 45.2.1.79 of <i>IEEE 802.3ap-2007</i>.</p> |
|           | 30    | RO  | LP Receiver ready          | <p>When set to 1, the link partner receiver has determined that training is complete and is prepared to receive data. When set to 0, the link partner receiver is requesting that training continue.</p> <p>Values for the receiver ready bit are defined in Clause 72.6.10.2.4.4. For more information, refer to 10G BASE-KR LP status report register bits (1.153.15) in Clause 45.2.1.79 of <i>IEEE 802.3ap-2007</i>.</p>                                                                         |
| 0x4D5     | 4:0   | R   | LT V <sub>OD</sub> setting | Stores the most recent TX V <sub>OD</sub> setting trained by the link partner's RX based on the LT coefficient update logic driven by Clause 72. It reflects Link Partner commands to fine-tune the TX preemphasis taps.                                                                                                                                                                                                                                                                             |
|           | 13:8  | R   | LT Post-tap setting        | Stores the most recent TX post-tap setting trained by the link partner's RX based on the LT coefficient update logic driven by Clause 72. It reflects Link Partner commands to fine-tune the TX pre-emphasis taps.                                                                                                                                                                                                                                                                                   |
|           | 20:16 | R   | LT Pre-tap setting         | Stores the most recent TX pre-tap setting trained by the link partner's RX based on the LT coefficient update logic driven by Clause 72. It reflects Link Partner commands to fine-tune the TX pre-emphasis taps.                                                                                                                                                                                                                                                                                    |
| 0x4D5     | 27:24 | R   | RXEQ CTLE Setting          | Most recent ctle_rc setting sent to the reconfig bundle during RX equalization.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|           | 29:28 | R   | RXEQ CTLE Mode             | Most recent ctle_mode setting sent to the reconfig bundle during RX equalization.                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | 31:30 | R   | RXEQ DFE Mode              | Most recent dfe_mode setting sent to the reconfig bundle during RX equalization.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x4D6     | 4:0   | RW  | LT VODMAX ovrd             | <p>Override value for the <b>VMAXRULE</b> parameter. When enabled, this value substitutes for the <b>VMAXRULE</b> to allow channel-by-channel override of the device settings. This only affects the local device TX output for the channel specified.</p> <p>This value must be greater than the <b>INITMAINVAL</b> parameter for proper operation. Note this also overrides the <b>PREMAINVAL</b> parameter value.</p>                                                                             |
|           | 5     | RW  | LT VODMAX ovrd Enable      | When set to 1, enables the override value for the <b>VMAXRULE</b> parameter stored in the LT VODMAX ovrd register field.                                                                                                                                                                                                                                                                                                                                                                             |
|           | 12:8  | RW  | LT VODMin ovrd             | <p>Override value for the <b>VODMINRULE</b> parameter. When enabled, this value substitutes for the <b>VMINRULE</b> to allow channel-by-channel override of the device settings. This override only effects the local device TX output for this channel.</p> <p>The value to be substituted must be less than the <b>INITMAINVAL</b> parameter and greater than the <b>VMINRULE</b> parameter for proper operation.</p>                                                                              |

*continued...*

| Word Addr | Bit            | R/W | Name                  | Description                                                                                                                                                                                                                                                                                                                                                      |
|-----------|----------------|-----|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 13             | RW  | LT VODMin ovrd Enable | When set to 1, enables the override value for the <b>VODMINRULE</b> parameter stored in the LT VODMin ovrd register field.                                                                                                                                                                                                                                       |
|           | 21:16          | RW  | LT VPOST ovrd         | Override value for the <b>VPOSTRULE</b> parameter. When enabled, this value substitutes for the <b>VPOSTRULE</b> to allow channel-by-channel override of the device settings. This override only effects the local device TX output for this channel.<br>The value to be substituted must be greater than the <b>INITPOSTVAL</b> parameter for proper operation. |
|           | 22             | RW  | LT VPOST ovrd Enable  | When set to 1, enables the override value for the <b>VPOSTRULE</b> parameter stored in the LT VPOST ovrd register field.                                                                                                                                                                                                                                         |
|           | 28:24          | RW  | LT VPre ovrd          | Override value for the <b>VPRERULE</b> parameter. When enabled, this value substitutes for the <b>VPOSTRULE</b> to allow channel-by-channel override of the device settings. This override only effects the local device TX output for this channel.<br>The value to be substituted must be greater than the <b>INITPREVAL</b> parameter for proper operation.   |
|           | 29             | RW  | LT VPre ovrd Enable   | When set to 1, enables the override value for the <b>VPRERULE</b> parameter stored in the LT VPre ovrd register field.                                                                                                                                                                                                                                           |
|           | 0x4D7 to 0x4FF |     | Reserved for 40G KR   | Left empty for address compatibility with 40G MAC+PHY KR solution.                                                                                                                                                                                                                                                                                               |

### 2.6.3.6.2. Hard Transceiver PHY Registers

**Table 123. Hard Transceiver PHY Registers**

| Addr        | Bit   | Access | Name                     | Description                                                                                                                                                                                                                                                |
|-------------|-------|--------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x000-0x3FF | [9:0] | RW     | Access to HSSI registers | All registers in the physical coding sub-layer (PCS) and physical media attachment (PMA) that you can dynamically reconfigure are in this address space. Refer to the <i>Arria 10 Dynamic Transceiver Reconfiguration</i> chapter for further information. |

#### Related Information

[Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514

### 2.6.3.6.3. Enhanced PCS Registers

**Table 124. Enhanced PCS Registers**

| Addr  | Bit  | Access | Name            | Description                                                                                                                    |
|-------|------|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------|
| 0x480 | 31:0 | RW     | Indirect_addr   | Because the PHY implements a single channel, this register must remain at the default value of 0 to specify logical channel 0. |
| 0x481 | 2    | RW     | RCLR_ERRBLK_CNT | Error block counter clear register. When set to 1, clears the error block counter. When set to 0, normal operation continues.  |
|       | 3    | RW     | RCLR_BER_COUNT  | BER counter clear register. When set to 1, clears the BER counter. When set to 0, normal operation continues.                  |

*continued...*

| Addr  | Bit | Access | Name          | Description                                                                                                                      |
|-------|-----|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------|
| 0x482 | 1   | RO     | HI_BER        | High BER status. When set to 1, the PCS reports a high BER. When set to 0, the PCS does not report a high BER.                   |
|       | 2   | RO     | BLOCK_LOCK    | Block lock status. When set to 1, the PCS is locked to received blocks. When set to 0, the PCS is not locked to received blocks. |
|       | 3   | RO     | TX_FIFO_FULL  | When set to 1, the TX_FIFO is full.                                                                                              |
|       | 4   | RO     | RX_FIFO_FULL  | When set to 1, the RX_FIFO is full.                                                                                              |
|       | 7   | RO     | Rx_DATA_READY | When set to 1, indicates the PHY is ready to receive data.                                                                       |

#### 2.6.3.6.4. PMA Registers

The PMA registers allow you to reset the PMA, customize the TX and RX serial data interface, and provide status information.

**Table 125. 1G Data Mode**

| Addr  | Bit | R/W | Name                   | Description                                                                                |
|-------|-----|-----|------------------------|--------------------------------------------------------------------------------------------|
| 0x4A8 | 0   | RW  | tx_invpolarity         | When set, the TX interface inverts the polarity of the TX data to the 8B/10B encoder.      |
|       | 1   | RW  | rx_invpolarity         | When set, the RX channels inverts the polarity of the received data to the 8B/10B decoder. |
|       | 2   | RW  | rx_bitreversal_enable  | When set, enables bit reversal on the RX interface to the word aligner.                    |
|       | 3   | RW  | rx_bytereversal_enable | When set, enables byte reversal on the RX interface to the byte deserializer.              |
|       | 4   | RW  | force_electrical_idle  | When set, forces the TX outputs to electrical idle.                                        |
| 0x4A9 | 0   | R   | rx_syncstatus          | When set, the word aligner is synchronized.                                                |
|       | 1   | R   | rx_patterndetect       | GbE word aligner detected comma.                                                           |
|       | 2   | R   | rx_rlv                 | Run length violation.                                                                      |
|       | 3   | R   | rx_rmfifodatainserted  | Rate match FIFO inserted code group.                                                       |
|       | 4   | R   | rx_rmfifodatadeleted   | Rate match FIFO deleted code group.                                                        |
|       | 5   | R   | rx_disperr             | RX 8B10B disparity error.                                                                  |
|       | 6   | R   | rx_errdetect           | RX 8B10B error detected.                                                                   |

**Table 126. PMA Registers**

| Address | Bit | R/W | Name                | Description                                                                                                              |
|---------|-----|-----|---------------------|--------------------------------------------------------------------------------------------------------------------------|
| 0x444   | 1   | RW  | reset_tx_digital    | Writing a 1 asserts the internal TX digital reset signal. You must write a 0 to clear the reset condition.               |
|         | 2   | RW  | reset_rx_analog     | Writing a 1 causes the internal RX analog reset signal to be asserted. You must write a 0 to clear the reset condition.  |
|         | 3   | RW  | reset_rx_digital    | Writing a 1 causes the internal RX digital reset signal to be asserted. You must write a 0 to clear the reset condition. |
| 0x461   | 0   | RW  | phy_serial_loopback | Writing a 1 puts the channel in serial loopback mode.                                                                    |

*continued...*

| Address | Bit | R/W | Name                   | Description                                                                                                                  |
|---------|-----|-----|------------------------|------------------------------------------------------------------------------------------------------------------------------|
| 0x464   | 0   | RW  | pma_rx_set_locktodata  | When set, programs the RX clock data recovery (CDR) PLL to lock to the incoming data.                                        |
| 0x465   | 0   | RW  | pma_rx_set_locktoref   | When set, programs the RX CDR PLL to lock to the reference clock.                                                            |
| 0x466   | 0   | RO  | pma_rx_is_lockedtodata | When asserted, indicates that the RX CDR PLL is locked to the RX data, and that the RX CDR has changed from LTR to LTD mode. |
| 0x467   | 0   | RO  | pma_rx_is_lockedtoref  | When asserted, indicates that the RX CDR PLL is locked to the reference clock.                                               |

### 2.6.3.7. Creating a 10GBASE-KR Design

Follow these steps to create a 10GBASE-KR design.

1. Generate the 10GBASE-KR PHY with the required parameterization.

The 10GBASE-KR PHY IP core includes a reconfiguration block. The reconfiguration block provides the Avalon memory-mapped interface to access the PHY registers.

2. Instantiate a reset controller. You can generate a Transceiver Reset Controller IP core from the IP Catalog. You must connect the Transceiver Reset Controller IP core and 10GBASE-KR PHY IP core power and reset signals.
3. Instantiate one TX PLL for the 1G data rate and one TX PLL for the 10G data rate. Connect the high speed serial clock and PLL lock signals between 10GBASE-KR PHY and TX PLLs. For the 1G data rate you can use either fPLL, ATX PLL, or CMU PLL. For the 10G data rate you can use ATX PLL or CMU PLL.
4. Generate a fPLL to create the 156.25 MHz XGMII clock from the 10G reference clock.
5. Use the tx\_pma\_divclk from the 10GBASE-KR PHY or generate a fPLL to create the 156.25 MHz XGMII clock from the 10G reference clock.  
Unlike in the 10GBASE-KR PHY IP core for Stratix V devices, no Memory Initialization Files (.mif) are required for the 10GBASE-KR design in Arria 10 devices.
6. Complete the design by creating a top level module to connect all the IP (10GBASE-KR PHY IP core, PLL IP core, and Reset Controller) blocks.

#### Related Information

- [fPLL](#) on page 368
- [CMU PLL](#) on page 377
- [ATX PLL](#) on page 359
- [Using the Transceiver PHY Reset Controller](#) on page 445
- [10GBASE-KR Functional Description](#) on page 136

### 2.6.3.8. Design Example

**Figure 71. PHY-Only Design Example with Two Backplane Ethernet and Two Line-Side (1G/10G) Ethernet Channels**



#### Related Information

- [Arria 10 Transceiver PHY Design Examples](#)
- [10-Gbps Ethernet MAC IP Function User Guide](#).  
For more information about latency in the MAC as part of the Precision Time Protocol implementation.

### 2.6.3.9. Simulation Support

The 1G/10GbE and 10GBASE-KR PHY IP core supports the following Intel-supported simulators for this Quartus Prime software release:

- ModelSim Verilog
- ModelSim VHDL
- VCS Verilog

- VCS VHDL
- NCSIM Verilog
- NCSIM VHDL simulation

When you generate a 1G/10GbE or 10GBASE-KR PHY IP core, the Quartus Prime software optionally generates an IP functional simulation model.

#### 2.6.4. 1-Gigabit/10-Gigabit Ethernet (GbE) PHY IP Core

The Ethernet standard comprises many different PHY standards with variations in signal transmission medium and data rates.

The 1G/10Gbps Ethernet PHY IP core targets the reconfigurable 10-Mbps/100-Mbps/1-Gbps/10-Gbps data rates with one core dynamically. This Ethernet PHY interfaces to 1G/10GbE dual speed SFP+ pluggable modules, 10MB-10GbE 10GBASE-T, and 10MB/100MB/1000MB 1000BASE-T copper external PHY devices to drive CAT-6/7 shielded twisted pair cables, and chip-to-chip interfaces.

The 1G/10 Gbps Ethernet PHY (1G/10GbE ) IP function allows you to support the following features of Ethernet standards:

- 1 GbE protocol as defined in *Clause 36 of the IEEE 802.3-2008 Standard*
- GMII to connect the PHY with a media access control (MAC) as defined in *Clause 35 of the IEEE 802.3-2008 Standard*
- Gigabit Ethernet Auto-negotiation as defined in *Clause 37 of the IEEE 802.3-2008 Standard*
- 10GBASE-R Ethernet protocol as defined in *Clause 49 of the IEEE 802.3-2008 Standard*
- Single data rate (64 data bits and 8 control bits) XGMII to provide simple and inexpensive interconnection between the MAC and the PHY as defined in *Clause 46 of the IEEE 802.3-2008 Standard*
- SGMII 10-Mbps/100-Mbps/1-Gbps data rate where 10-Mbps/100-Mbps MII to connect physical media with the MAC as defined in *Clause 22 of the IEEE 802.3-2008 Standard*
- Forward Error correction(FEC) as defined in *Clause 74 of the IEEE 802.3-2008 Standard*
- Precision time protocol (PTP) as defined in the *IEEE 1588 Standard*

The 1G/10Gbps Ethernet PHY IP Core allows you to implement the 1GbE protocol using the Standard PCS and to implement the 10GbE protocol using Enhanced PCS and PMA. You can switch dynamically between the 1G and 10G data rates using dynamic reconfiguration to reprogram the core. Or, you can use the speed detection option to automatically switch data rates based on received data.

**Figure 72. Top Level Modules of the 1G/10GbE PHY IP Function**

The Enhanced PCS receives and transmits XGMII data. The Standard PCS receives and transmits GMII data.



For more information about clock and reset signal descriptions, refer to *Clock and Reset Interfaces*.

An Avalon memory-mapped interface slave provides access to the 1G/10GbE PHY IP Core registers. These registers control many of the functions of the other blocks. Many of these bits are defined in *Clause 45 of IEEE 802.3ap-2008 Standard*.

#### Related Information

- [Clock and Reset Interfaces](#) on page 168
- [IEEE Std 802.3ap-2008 Standard](#)
- [Standard for a Precision Clock Synchronization Protocol for Networked Measurement and Control Systems](#)

#### 2.6.4.1. 1G/10GbE PHY Release Information

This topic provides information about this release of the 1G/10GbE PHY IP Core.

**Table 127. 1G/10GbE Release Information**

| Item           | Description                                              |
|----------------|----------------------------------------------------------|
| Version        | 19.1                                                     |
| Release Date   | April 2019                                               |
| Ordering Codes | IP-1G10GBASER (primary)<br>IPR-1G10GBASER (renewal code) |
| Product ID     | 0107                                                     |
| Vendor ID      | 6AF7                                                     |

### 2.6.4.2. 1G/10GbE PHY Performance and Resource Utilization

This topic provides performance and resource utilization for the 1G/10GbE PHY IP core in Arria 10 devices.

The following table shows the typical expected resource utilization for selected configurations using the Quartus Prime software version 15.1. The numbers of ALMs and logic registers are rounded up to the nearest 50.

**Table 128. 1GbE/10GbE PHY Performance and Resource Utilization**

| Variant                        | ALMs | ALUTs | Registers | M20K |
|--------------------------------|------|-------|-----------|------|
| 1G/10GbE PHY with IEEE 1588 v2 | 2650 | 3950  | 5100      | 6    |
| 1G/10GbE PHY                   | 1500 | 2350  | 2850      | 2    |
| 1G/10GbE PHY with FEC          | 1500 | 2350  | 2850      | 2    |

### 2.6.4.3. 1G/10GbE PHY Functional Description

**Figure 73. 1G/10GbE PHY Block Diagram**



#### Standard and Enhanced PCS Datapaths

The Standard PCS and PMA inside the Native PHY are configured as the Gigabit Ethernet PHY. The Enhanced PCS and PMA inside the Native PHY are configured as the 10GBASE-R PHY. Refer to the Standard PCS and Enhanced PCS architecture chapters for more details.

## Sequencer

The Sequencer controls the start-up sequence of the PHY IP, including reset and power-on. It selects which PCS (1G or 10G) and PMA interface is active. The Sequencer interfaces to the reconfiguration block to request a change from one data rate to the other data rate.

## GigE PCS

The GigE PCS includes the GMII interface and *Clause 37* auto negotiation and SGMII functionality.

## Soft Enhanced PCS FIFO for IEEE 1588v2

In IEEE 1588v2 mode, the enhanced PCS FIFOs for both TX and RX are constructed in soft IP to include the latency information via the latency adjustment ports. For more information about the required latency information in the MAC as part of the Precision Time Protocol implementation, refer to the *Low Latency Ethernet 10G MAC Intel FPGA IP User Guide*.

## Reconfiguration Block

The reconfiguration logic performs the Avalon memory-mapped interface writes to the PHY for both PCS and PMA reconfiguration. The following figure shows the details of the reconfiguration blocks. The Avalon memory-mapped interface master accepts requests from the PMA or PCS controller. It performs the Read-Modify-Write or Write commands using the Avalon memory-mapped interface. The PCS controller receives data rate change requests from the Sequencer and translates them to a series of Read-Modify-Write or Write commands to the PMA and PCS.

**Figure 74. Reconfiguration Block Details**

The 1G/10GbE PHY IP core is very flexible. For example, you can configure it with or without IEEE 1588v2, and with or without FEC in the enhanced PCS datapath.



**Notes:**

1. rcfg = Reconfiguration
2. MGMT\_CLK = Management Clock

### Related Information

- [Arria 10 Enhanced PCS Architecture](#) on page 473
- [Arria 10 Standard PCS Architecture](#) on page 491
- [Arria 10 PMA Architecture](#) on page 459
- [Low Latency Ethernet 10G MAC Intel FPGA IP User Guide](#)  
For more information about latency in the MAC as part of the Precision Time Protocol implementation.

#### 2.6.4.4. Clock and Reset Interfaces

You can use a fPLL or a CMU PLL to generate the clock for the TX PMA for the 1G data rate. For the 10G data rate, you can use the ATX PLL or the CMU PLL. For the 1G data rate, the frequency of the TX and RX clocks is 125 MHz, which is 1/8 of the MAC data rate. For the 10G data rate, the frequency of TX and RX clocks is 156.25 MHz, 1/64 of the MAC data rate. You can generate the 156.25 MHz clock directly by using a fPLL, or you can divide the clock from TX PLL by 33. The 1G/10GbE PHY does not support bonded clocks.

The following figure provides an overview of the clocking for this core.

**Figure 75. Clocks for Standard and 10G PCS and TX PLLs**



The following table describes the clock and reset signals.

**Table 129. Clock and Reset Signals**

| Signal Name        | Direction | Description                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_serial_clk_10g  | Input     | High speed clock from the 10G PLL to drive 10G PHY TX PMA. The frequency of this clock is 5.15625 GHz.                                                                                                                                                                                                                                                                              |
| tx_serial_clk_1g   | Input     | The clock from the external 1G PLL to drive the TX high speed serial interface (HSSI) circuits. Connected to the tx_serial_clk input of the native PHY.                                                                                                                                                                                                                             |
| rx_cdr_ref_clk_10g | Input     | 10G PHY RX PLL reference clock. This clock frequency can be 644.53125 MHz or 322.2656 MHz.                                                                                                                                                                                                                                                                                          |
| rx_cdr_refclk_1g   | Input     | The RX 1G PLL reference clock to drive the RX HSSI circuits. Connected to the rx_cdr_refclk input of the native PHY.                                                                                                                                                                                                                                                                |
| mgmt_clk           | Input     | Avalon memory-mapped interface clock and control system clock. Its frequency range is 100 MHz to 125 MHz.                                                                                                                                                                                                                                                                           |
| mgmt_clk_reset     | Input     | When asserted, it resets the whole PHY.                                                                                                                                                                                                                                                                                                                                             |
| xgmii_tx_clk       | Input     | Clock for XGMII TX interface with MAC. Can be connected to tx_div_clkout. This drives the tx_coreclkin port of the Native PHY.                                                                                                                                                                                                                                                      |
| xgmii_rx_clk       | Input     | The clock for the XGMII RX interface with the MAC. Intel recommends connecting it directly to a PLL for use with TSE. This drives rx_coreclk in of the native PHY. Its frequency is 156.25 or 312.5 MHz.                                                                                                                                                                            |
| tx_clkout          | Output    | Transmit parallel clock. It is sourced from out_pld_pcs_tx_clk_out on the HSSI. This could be used to provide the XGMII clocks or the GMII clocks, though if the PHY is reconfigured, the frequency changes. Its frequency is 125, 156.25, 161, 258, or 312.5 MHz.                                                                                                                  |
| rx_clkout          | Output    | Receive parallel clock. It is sourced from out_pld_pcs_rx_clk_out on the HSSI. If the PHY is reconfigured, the frequency changes. Its frequency is 125, 156.25, 161, 258, or 312.5 MHz.                                                                                                                                                                                             |
| tx_pma_clkout      | Output    | Transmit PMA clock. This is the clock for the 1588 mode TX FIFO and the 1G TX and RX PCS parallel data interface. Note: Use tx_div_clkout or xgmii_tx_clk for 10G TX datapath clocking. This clock is provided for the 1G mode GMII/MII data and SyncE mode where the clock can be used as a reference to lock an external clock source. Its frequency is 125, 161, or 258 MHz.     |
| rx_pma_clkout      | Output    | Receive PMA clock. This is the clock for the 1588 mode RX FIFO and the 1G RX FIFO. Note: Use tx_div_clkout or xgmii_rx_clk for 10G RX datapath clocking. This clock is provided for the SyncE mode where the clock can be used as a reference to lock an external clock source. Its frequency is 125, 161, or 258 MHz.                                                              |
| tx_div_clk         | Output    | This is the transmit div33 clock, which is sourced from the Native PHY tx_pma_div_clkout. It could be connected to the xgmii_tx_clk and xgmii_rx_clk clock inputs to drive the MAC interface, though if the PHY is reconfigured to 1G mode, the frequency changes. Its frequency is 125, 156.25, or 312.5 MHz.                                                                      |
| rx_div_clk         | Output    | This is the receive div33 clock, which is recovered from the received data. It drives the Auto Negotiation (AN) and Link Training (LT) logic and is sourced from the Native PHY rx_pma_div_clkout port. Note: Use tx_clkout or xgmii_rx_clk for 10G TX datapath clocking. If the PHY is reconfigured to 1G mode, the frequency changes. Its frequency is 125, 156.25, or 312.5 MHz. |

*continued...*

| Signal Name     | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| calc_clk_1g     | Input     | This is the clock for the GIGE PCS 1588 mode. To achieve high accuracy for all speed modes, the recommended frequency for calc_clk_1g is 80 MHz. In addition, the 80 MHz clock should have the same parts per million (ppm) as the 125 MHz pll_ref_clk_1g input. The random error without a rate match FIFO mode is: <ul style="list-style-type: none"> <li>• <math>\pm 1</math> ns at 1000 Mbps</li> <li>• <math>\pm 5</math> ns at 100 Mbps</li> <li>• <math>\pm 25</math> ns at 10 Mbps</li> </ul> |
| tx_analogreset  | Input     | Resets the analog TX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| tx_digitalreset | Input     | Resets the digital TX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| rx_analogreset  | Input     | Resets the analog RX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| rx_digitalreset | Input     | Resets the digital RX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| usr_seq_reset   | Input     | Resets the sequencer. Initiates a PCS reconfiguration, and may restart AN, LT or both if these modes are enabled. Synchronous to mgmt_clk.                                                                                                                                                                                                                                                                                                                                                            |
| rx_data_ready   | Output    | When asserted, indicates that you can start to send the 10G data. Synchronous to xgmii_rx_clk.                                                                                                                                                                                                                                                                                                                                                                                                        |

#### Related Information

- [Input Reference Clock Sources](#) on page 382
- [PLLs](#) on page 358

#### 2.6.4.5. Parameterizing the 1G/10GbE PHY

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

The Arria 10 1G/10GbE and 10GBASE-KR PHY IP core allows you to select either the **Backplane-KR** or **1Gb/10Gb Ethernet** variant. The **1Gb/10Gb Ethernet** variant (1G/10GbE) does not implement the link training and auto-negotiation functions.

Complete the following steps to parameterize the 1Gb/10Gb Ethernet PHY IP core in the parameter editor:

1. Instantiate the **Arria 10 1G/10GbE and 10GBASE-KR PHY** from the IP Catalog. Refer to [Select and Instantiate the PHY IP Core](#) on page 33.
2. Select **1Gb/10Gb Ethernet** from the **IP variant** list located under **Ethernet Intel FPGA IP Core Type**.
3. Use the parameter values in the tables in [10GBASE-R Parameters](#) on page 140, [10M/100M/1Gb Ethernet Parameters](#) on page 172, [Speed Detection Parameters](#) on page 142, and [PHY Analog Parameters](#) on page 173 as a starting point. Or, you can select the **BackPlane\_wo\_1588** option in the **Presets** tab on the right side of the IP Parameter Editor. You can then modify the setting to meet your specific requirements.
4. Click **Generate HDL** to generate the **1Gb/10Gb Ethernet** IP core top-level HDL file.

**Note:** You might observe timing violations. If the timing path is within the IP, you can ignore these violations.

### Related Information

- [Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45
- [General Options](#) on page 139
- [10GBASE-R Parameters](#) on page 140
- [10M/100M/1Gb Ethernet Parameters](#) on page 172
- [Speed Detection Parameters](#) on page 142
- [PHY Analog Parameters](#) on page 173

#### 2.6.4.5.1. General Options

The General Options allow you to specify options common to 10GBASE-KR mode.

**Table 130. General Options Parameters**

| Parameter Name                                                               | Options                 | Description                                                                                                                                                                                                                                                                                                       |
|------------------------------------------------------------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable internal PCS reconfiguration logic</b>                             | <b>On</b><br><b>Off</b> | This parameter is only an option when <code>SYNTH_SEQ = 0</code> . When set to 0, it does not include the reconfiguration module or expose the <code>start_pcs_reconfig</code> or <code>rc_busy</code> ports. When set to 1, it provides a simple interface to initiate reconfiguration between 1G and 10G modes. |
| <b>Enable IEEE 1588 Precision Time Protocol</b>                              | <b>On</b><br><b>Off</b> | When you turn on this parameter, you enable the IEEE 1588 Precision Time Protocol logic for both 1G and 10G modes.                                                                                                                                                                                                |
| <b>Enable M20K block ECC protection</b>                                      | <b>On</b><br><b>Off</b> | When you turn on this parameter, you enable error correction code (ECC) support on the embedded Nios CPU system. This parameter is only valid for the backplane variant.                                                                                                                                          |
| <b>Enable tx_pma_clkout port</b>                                             | <b>On</b><br><b>Off</b> | When you turn on this parameter, the <code>tx_pma_clkout</code> port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                                            |
| <b>Enable rx_pma_clkout port</b>                                             | <b>On</b><br><b>Off</b> | When you turn on this parameter, the <code>rx_pma_clkout</code> port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                                            |
| <b>Enable tx_divclk port</b>                                                 | <b>On</b><br><b>Off</b> | When you turn on this parameter, the <code>tx_divclk</code> port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                                                |
| <b>Enable rx_divclk port</b>                                                 | <b>On</b><br><b>Off</b> | When you turn on this parameter, the <code>rx_divclk</code> port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                                                |
| <b>Enable tx_clkout port</b>                                                 | <b>On</b><br><b>Off</b> | When you turn on this parameter, the <code>tx_clkout</code> port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                                                |
| <b>Enable rx_clkout port</b>                                                 | <b>On</b><br><b>Off</b> | When you turn on this parameter, the <code>rx_clkout</code> port is enabled. Refer to the Clock and Reset Interfaces section for more information about this port.                                                                                                                                                |
| <b>Enable Hard PRBS support and Native PHY Debug Master Endpoint support</b> | <b>On</b><br><b>Off</b> | When you turn on this parameter, you enable the Native PHY Debug Master Endpoint (NPDME) and Hard PRBS data generation and checking logic in the Native PHY. The transceiver toolkit (TTK) requires NPDME to be enabled in the Native PHY IP core.                                                                |

*continued...*

| Parameter Name                                    | Options                                 | Description                                                                                                                                                                                                                                  |
|---------------------------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Reference clock frequency</b>                  | <b>644.53125 MHz<br/>322.265625 MHz</b> | Specifies the input reference clock frequency. The default is <b>322.265625 MHz</b> .                                                                                                                                                        |
| <b>Enable additional control and status ports</b> | <b>On<br/>Off</b>                       | When you turn this option on, the core includes the <code>rx_block_lock</code> and <code>rx_hi_ber</code> output.                                                                                                                            |
| <b>Include FEC sublayer</b>                       | <b>On<br/>Off</b>                       | When you turn on this parameter, the core includes logic to implement FEC and a soft 10GBASE-R PCS. This is applicable only for the 10G mode.                                                                                                |
| <b>Set FEC_ability bit on power up and reset</b>  | <b>On<br/>Off</b>                       | When you turn on this parameter, the core sets the <code>Assert KR FEC Ability</code> bit (0xB0[16]) FEC ability bit during power up and reset, causing the core to assert the FEC ability. This option is required for FEC functionality.   |
| <b>Set FEC_Enable bit on power up and reset</b>   | <b>On<br/>Off</b>                       | When you turn on this parameter, the core sets the <code>KR FEC Request</code> bit (0xB0[18]) during power up and reset, causing the core to request the FEC ability during Auto Negotiation. This option is required for FEC functionality. |

#### Related Information

[Clock and Reset Interfaces](#) on page 143

#### 2.6.4.5.2. 10GBASE-R Parameters

The 10GBASE-R parameters specify basic features of the 10GBASE-R PCS. The FEC options also allow you to specify the FEC ability.

**Table 131. 10GBASE-R Parameters**

| Parameter Name                                    | Options                                 | Description                                                                                                         |
|---------------------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| <b>10GbE Reference clock frequency</b>            | <b>644.53125 MHz<br/>322.265625 MHz</b> | Specifies the input reference clock frequency. The default is <b>322.265625 MHz</b> .                               |
| <b>Enable additional control and status ports</b> | <b>On<br/>Off</b>                       | When you turn on this parameter, the core includes the <code>rx_block_lock</code> and <code>rx_hi_ber</code> ports. |

**Table 132. FEC Options**

| Parameter Name              | Options           | Description                                                                                         |
|-----------------------------|-------------------|-----------------------------------------------------------------------------------------------------|
| <b>Include FEC sublayer</b> | <b>On<br/>Off</b> | When you turn on this parameter, the core includes logic to implement FEC and a soft 10GBASE-R PCS. |

#### 2.6.4.5.3. 10M/100M/1Gb Ethernet Parameters

The 10M/100M/1GbE parameters allow you to specify options for the MII interface and the 1GbE data rate.

**Table 133. 10M/100M/1Gb Ethernet**

| Parameter Name                      | Options   | Description                                                                           |
|-------------------------------------|-----------|---------------------------------------------------------------------------------------|
| <b>Enable 1Gb Ethernet protocol</b> | <b>On</b> | When you turn this option on, the core includes the GMII interface and related logic. |

*continued...*

| Parameter Name                                  | Options                 | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                 | <b>Off</b>              |                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>Enable 10Mb/100Mb Ethernet functionality</b> | <b>On</b><br><b>Off</b> | When you turn this option on, the core includes the MII PCS. It also supports 4-speed mode to implement a 10M/100M interface to the MAC for the GbE line rate.                                                                                                                                                                                                                                          |
| <b>PHY ID (32 bits)</b>                         | 32-bit value            | An optional 32-bit value that serves as a unique identifier for a particular type of PCS. The identifier includes the following components: <ul style="list-style-type: none"> <li>Bits 3-24 of the Organizationally Unique Identifier (OUI) assigned by the IEEE</li> <li>6-bit model number</li> <li>4-bit revision number</li> </ul> If unused, do not change the default value which is 0x00000000. |
| <b>PHY core version (16 bits)</b>               | 16-bit value            | This is an optional 16-bit value that identifies the PHY core version.                                                                                                                                                                                                                                                                                                                                  |

#### 2.6.4.5.4. Speed Detection Parameters

Selecting the speed detection option gives the PHY the ability to detect link partners that support 1G/10GbE but have disabled Auto-Negotiation. During Auto-Negotiation, if AN cannot detect Differential Manchester Encoding (DME) pages from a link partner, the Sequencer reconfigures to 1GbE and 10GbE modes (Speed/Parallel detection) until it detects a valid 1G or 10GbE pattern.

**Table 134. Speed Detection**

| Parameter Name                                  | Options                 | Description                                                                                                                                                                                                                                                                                     |
|-------------------------------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable automatic speed detection</b>         | <b>On</b><br><b>Off</b> | When you turn this option <b>On</b> , the core includes the Sequencer block that sends reconfiguration requests to detect 1G or 10GbE when the Auto Negotiation block is not able to detect AN data.                                                                                            |
| <b>Avalon-MM clock frequency</b>                | 100-162 MHz             | Specifies the clock frequency for phy_mgmt_clk.                                                                                                                                                                                                                                                 |
| <b>Link fail inhibit time for 10Gb Ethernet</b> | 504 ms                  | Specifies the time before link_status is set to FAIL or OK. A link fails if the link_fail_inhibit_time has expired before link_status is set to OK. The legal range is 500-510 ms. For more information, refer to "Clause 73 Auto Negotiation for Backplane Ethernet" in IEEE Std 802.3ap-2007. |
| <b>Link fail inhibit time for 1Gb Ethernet</b>  | 40-50 ms                | Specifies the time before link_status is set to FAIL or OK. A link fails if the link_fail_inhibit_time has expired before link_status is set to OK. The legal range is 40-50 ms.                                                                                                                |
| <b>Enable PCS-Mode port</b>                     | <b>On</b><br><b>Off</b> | Enables or disables the PCS-Mode port.                                                                                                                                                                                                                                                          |

#### 2.6.4.5.5. PHY Analog Parameters

You can specify analog parameters using the Intel Quartus Prime Assignment Editor, the Pin Planner, or the Intel Quartus Prime Settings File (.qsf).

## 2.6.4.6. 1G/10GbE PHY Interfaces

**Figure 76.** 1G/10GbE PHY Top-Level Signals



The block diagram shown in the parameter editor labels the external pins with the interface type and places the interface name inside the box. The interface type and name are provided in the `_hw.tcl` file. If you turn on **Show signals**, the **block diagram** displays all top-level signal names. For more information about `_hw.tcl` files, refer to the *Component Interface Tcl Reference* chapter in volume 1 of the *Intel Quartus Prime Handbook*.

**Note:** Intel is deprecating some of the signals shown in this figure. The descriptions of these signals identifies them as not functional.

### Related Information

[Component Interface Tcl Reference](#)

### 2.6.4.6.1. Clock and Reset Interfaces

**Table 135. Clock and Reset Signals**

| Signal Name        | Direction | Description                                                                                                                                                                                                                            |
|--------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_serial_clk_10g  | Input     | High speed clock from the 10G PLL to drive 10G PHY TX PMA. The frequency of this clock is 5.15625 GHz.                                                                                                                                 |
| tx_serial_clk_1g   | Input     | High speed clock from 1G PLL to drive the 1G PHY TX PMA. This clock is not required if GbE is not used. The frequency of this clock is 625 MHz.                                                                                        |
| rx_cdr_ref_clk_10g | Input     | 10G PHY RX PLL reference clock. This clock frequency can be 644.53125 MHz or 322.2656 MHz.                                                                                                                                             |
| rx_cdr_ref_clk_1g  | Input     | 1G PHY RX PLL reference clock. The frequency is 125 MHz. This clock is only required if 1G is enabled.                                                                                                                                 |
| tx_pma_clkout      | Output    | Clock used to drive the 10G TX PCS and 1G TX PCS parallel data. For example, when the hard PCS is reconfigured to the 10G mode without FEC enabled, the frequency is 257.81 MHz. The frequency is 161.13 MHz for 10G with FEC enabled. |
| rx_pma_clkout      | Output    | Clock used to drive the 10G RX PCS and 1G RX PCS parallel data. For example, when the hard PCS is reconfigured to the 10G mode without FEC enabled, the frequency is 257.81 MHz. The frequency is 161.13 MHz for 10G with FEC enabled. |
| tx_clkout          | Output    | XGMII/GMII TX clock for the TX parallel data source interface. This clock frequency is 257.81 MHz in 10G mode, and 161.13 MHz with FEC enabled.                                                                                        |
| rx_clkout          | Output    | XGMII RX clock for the RX parallel data source interface. This clock frequency is 257.81 in 10G mode, and 161.13 MHz with FEC enabled.                                                                                                 |
| tx_pma_div_clkout  | Output    | The divided 33 clock from the TX serializer. You can use this clock for the xgmii_tx_clk or xgmii_rx_clk. The frequency is 156.25 MHz for 10G. The frequencies are the same whether or not you enable FEC.                             |
| rx_pma_div_clkout  | Output    | The divided 33 clock from CDR recovered clock. The frequency is 156.25 MHz for 10G. The frequencies are the same whether or not you enable FEC. This clock is not used for clocking the 10G RX datapath.                               |
| tx_analogreset     | Input     | Resets the analog TX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                          |
| tx_digitalreset    | Input     | Resets the digital TX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                         |
| rx_analogreset     | Input     | Resets the analog RX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                          |
| rx_digitalreset    | Input     | Resets the digital RX portion of the transceiver PHY. Synchronous to mgmt_clk.                                                                                                                                                         |
| usr_seq_reset      | Input     | Resets the sequencer. Initiates a PCS reconfiguration, and may restart AN, LT or both if these modes are enabled. Synchronous to mgmt_clk.                                                                                             |

#### Related Information

- [Input Reference Clock Sources](#) on page 382
- [PLLs](#) on page 358

#### 2.6.4.6.2. Data Interfaces

**Table 136. XGMII Signals**

The MAC drives the TX XGMII signals to the 10GbE PHY. The 10GbE PHY drives the RX XGMII signals to the MAC.

| Signal Name                       | Direction | Clock Domain                | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------|-----------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>10GbE XGMII Data Interface</b> |           |                             |                                                                                                                                                                                                                                                                                                                                                                                                                           |
| xgmii_tx_dc[71:0]                 | Input     | Synchronous to xgmii_tx_clk | XGMII data and control for 8 lanes. Each lane consists of 8 bits of data and 1 bit of control.                                                                                                                                                                                                                                                                                                                            |
| xgmii_tx_clk                      | Input     | Clock signal                | Clock for single data rate (SDR) XGMII TX interface to the MAC. It should connect to xgmii_rx_clk. This clock can be connected to the tx_div_clkout; however, Intel recommends that you connect it to a PLL for use with the Triple Speed Ethernet IP function. The frequency is 125 MHz for 1G and 156.25 MHz for 10G. This clock is driven from the MAC.<br>The frequencies are the same whether or not you enable FEC. |
| xgmii_rx_dc[71:0]                 | Output    | Synchronous to xgmii_rx_clk | RX XGMII data and control for 8 lanes. Each lane consists of 8 bits of data and 1 bit of control.                                                                                                                                                                                                                                                                                                                         |
| xgmii_rx_clk                      | Input     | Clock signal                | Clock for SDR XGMII RX interface to the MAC. This clock can be connected to the tx_div_clkout ; however, Intel recommends that you connect it to a PLL for use with the Triple Speed Ethernet IP function. The frequency is 125 MHz for 1G and 156.25 MHz for 10G. This clock is driven from the MAC.<br>The frequencies are the same whether or not you enable FEC.                                                      |

#### 2.6.4.6.3. XGMII Mapping to Standard SDR XGMII Data

**Table 137. TX XGMII Mapping to Standard SDR XGMII Interface**

The 72-bit TX XGMII data bus format is different than the standard SDR XGMII interface. This table shows the mapping of this non-standard format to the standard SDR XGMII interface.

| Signal Name        | SDR XGMII Signal Name | Description    |
|--------------------|-----------------------|----------------|
| xgmii_tx_dc[7:0]   | xgmii_sdr_data[7:0]   | Lane 0 data    |
| xgmii_tx_dc[8]     | xgmii_sdr_ctrl[0]     | Lane 0 control |
| xgmii_tx_dc[16:9]  | xgmii_sdr_data[15:8]  | Lane 1 data    |
| xgmii_tx_dc[17]    | xgmii_sdr_ctrl[1]     | Lane 1 control |
| xgmii_tx_dc[25:18] | xgmii_sdr_data[23:16] | Lane 2 data    |
| xgmii_tx_dc[26]    | xgmii_sdr_ctrl[2]     | Lane 2 control |
| xgmii_tx_dc[34:27] | xgmii_sdr_data[31:24] | Lane 3 data    |
| xgmii_tx_dc[35]    | xgmii_sdr_ctrl[3]     | Lane 3 control |
| xgmii_tx_dc[43:36] | xgmii_sdr_data[39:32] | Lane 4 data    |
| xgmii_tx_dc[44]    | xgmii_sdr_ctrl[4]     | Lane 4 control |
| xgmii_tx_dc[52:45] | xgmii_sdr_data[47:40] | Lane 5 data    |
| xgmii_tx_dc[53]    | xgmii_sdr_ctrl[5]     | Lane 5 control |

*continued...*

| Signal Name        | SDR XGMII Signal Name | Description    |
|--------------------|-----------------------|----------------|
| xgmii_tx_dc[61:54] | xgmii_sdr_data[55:48] | Lane 6 data    |
| xgmii_tx_dc[62]    | xgmii_sdr_ctrl[6]     | Lane 6 control |
| xgmii_tx_dc[70:63] | xgmii_sdr_data[63:56] | Lane 7 data    |
| xgmii_tx_dc[71]    | xgmii_sdr_ctrl[7]     | Lane 7 control |

**Table 138. RX XGMII Mapping to Standard SDR XGMII Interface**

The 72-bit RX XGMII data bus format is different from the standard SDR XGMII interface. This table shows the mapping of this non-standard format to the standard SDR XGMII interface.

| Signal Name        | XGMII Signal Name     | Description    |
|--------------------|-----------------------|----------------|
| xgmii_rx_dc[7:0]   | xgmii_sdr_data[7:0]   | Lane 0 data    |
| xgmii_rx_dc[8]     | xgmii_sdr_ctrl[0]     | Lane 0 control |
| xgmii_rx_dc[16:9]  | xgmii_sdr_data[15:8]  | Lane 1 data    |
| xgmii_rx_dc[17]    | xgmii_sdr_ctrl[1]     | Lane 1 control |
| xgmii_rx_dc[25:18] | xgmii_sdr_data[23:16] | Lane 2 data    |
| xgmii_rx_dc[26]    | xgmii_sdr_ctrl[2]     | Lane 2 control |
| xgmii_rx_dc[34:27] | xgmii_sdr_data[31:24] | Lane 3 data    |
| xgmii_rx_dc[35]    | xgmii_sdr_ctrl[3]     | Lane 3 control |
| xgmii_rx_dc[43:36] | xgmii_sdr_data[39:32] | Lane 4 data    |
| xgmii_rx_dc[44]    | xgmii_sdr_ctrl[4]     | Lane 4 control |
| xgmii_rx_dc[52:45] | xgmii_sdr_data[47:40] | Lane 5 data    |
| xgmii_rx_dc[53]    | xgmii_sdr_ctrl[5]     | Lane 5 control |
| xgmii_rx_dc[61:54] | xgmii_sdr_data[55:48] | Lane 6 data    |
| xgmii_rx_dc[62]    | xgmii_sdr_ctrl[6]     | Lane 6 control |
| xgmii_rx_dc[70:63] | xgmii_sdr_data[63:56] | Lane 7 data    |
| xgmii_rx_dc[71]    | xgmii_sdr_ctrl[7]     | Lane 7 control |

#### 2.6.4.6.4. GMII Interface

The GMII interface signals drive data to and from the PHY.

**Table 139. GMII Interface Ports**

| Signal Name    | Direction | Description                                                                             |
|----------------|-----------|-----------------------------------------------------------------------------------------|
| gmii_tx_d[7:0] | Input     | Data to be encoded and sent to the link partner. This signal is clocked with tx_clkout. |
| gmii_tx_en     | Input     | The GMII TX control signal. Synchronous to tx_clkout.                                   |
| gmii_tx_err    | Input     | The GMII TX error signal. Synchronous to tx_clkout.                                     |
| gmii_rx_d[7:0] | Output    | Data to be encoded and sent to the link partner. This signal is clocked with tx_clkout. |
| gmii_rx_dv     | Output    | The GMII RX control signal. Synchronous to tx_clkout.                                   |

*continued...*

| <b>Signal Name</b> | <b>Direction</b> | <b>Description</b>                                                                                                                                                                                                                                                                  |
|--------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gmii_rx_err        | Output           | The GMII RX error signal. Synchronous to tx_clkout.                                                                                                                                                                                                                                 |
| led_char_err       | Output           | 10-bit character error. Asserted for one rx_clkout_1g cycle when an erroneous 10-bit character is detected.                                                                                                                                                                         |
| led_link           | Output           | When asserted, this signal indicates successful link synchronization.                                                                                                                                                                                                               |
| led_disp_err       | Output           | When asserted, this signal indicates a 10-bit running disparity error. Asserted for one rx_clkout_1g cycle when a disparity error is detected. A running disparity error indicates that errors were detected on more received groups than the previous and possibly current groups. |
| led_an             | Output           | This signal indicates the auto-negotiation status. The PCS function asserts this signal when an auto-negotiation completes.                                                                                                                                                         |

#### 2.6.4.6.5. Serial Data Interface

**Table 140. Serial Data Signals**

| <b>Signal Name</b> | <b>Direction</b> | <b>Description</b>    |
|--------------------|------------------|-----------------------|
| rx_serial_data     | Input            | RX serial input data  |
| tx_serial_data     | Output           | TX serial output data |

#### 2.6.4.6.6. Control and Status Interfaces

**Table 141. Control and Status Signals**

| <b>Signal Name</b> | <b>Direction</b> | <b>Clock Domain</b>      | <b>Description</b>                                                                                                                                                                                                                                               |
|--------------------|------------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| led_link           | Output           | Synchronous to tx_clkout | When asserted, indicates successful link synchronization.                                                                                                                                                                                                        |
| led_disp_err       | Output           | Synchronous to rx_clkout | Disparity error signal indicating a 10-bit running disparity error. Asserted for one rx_clkout_1g cycle when a disparity error is detected. A running disparity error indicates that more than the previous and perhaps the current received group had an error. |
| led_an             | Output           | Synchronous to rx_clkout | Clause 37 Auto-negotiation status. The PCS function asserts this signal when auto-negotiation completes.                                                                                                                                                         |
| led_panel_link     | Output           | Synchronous to mgmt_clk  | When asserted, this signal indicates the following behavior:                                                                                                                                                                                                     |
|                    |                  |                          | <b>Mode</b> <b>Behavior</b>                                                                                                                                                                                                                                      |
|                    |                  |                          | 1000 Base-X without Auto-negotiation      When asserted, indicates successful link synchronization.                                                                                                                                                              |

*continued...*

| Signal Name              | Direction | Clock Domain                | Description                                                                                                                                                                                                                                                                                       |                                                                                                          |
|--------------------------|-----------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
|                          |           |                             | Mode                                                                                                                                                                                                                                                                                              | Behavior                                                                                                 |
|                          |           |                             | SGMII mode without Auto-negotiation                                                                                                                                                                                                                                                               | When asserted, indicates successful link synchronization.                                                |
|                          |           |                             | 1000 Base-X with Auto-negotiation                                                                                                                                                                                                                                                                 | Clause 37 Auto-negotiation status. The PCS function asserts this signal when auto-negotiation completes. |
|                          |           |                             | SGMII mode with MAC mode Auto-negotiation                                                                                                                                                                                                                                                         | Clause 37 Auto-negotiation status. The PCS function asserts this signal when auto-negotiation completes. |
| rx_block_lock            | Output    | Synchronous to rx_clkout    | Asserted to indicate that the block synchronizer has established synchronization.                                                                                                                                                                                                                 |                                                                                                          |
| rx_hi_ber                | Output    | Synchronous to rx_clkout    | Asserted by the BER monitor block to indicate a Sync Header high bit error rate greater than $10^{-4}$ .                                                                                                                                                                                          |                                                                                                          |
| rx_is_lockedtodata       | Output    | Asynchronous signal         | When asserted, indicates the RX channel is locked to input data.                                                                                                                                                                                                                                  |                                                                                                          |
| tx_cal_busy              | Output    | Synchronous to mgmt_clk     | When asserted, indicates that the TX channel is being calibrated.                                                                                                                                                                                                                                 |                                                                                                          |
| rx_cal_busy              | Output    | Synchronous to mgmt_clk     | When asserted, indicates that the RX channel is being calibrated.                                                                                                                                                                                                                                 |                                                                                                          |
| tx_pcfifo_error_1g       | Output    | N/A                         | When asserted, indicates that the standard PCS TX phase compensation FIFO is either full or empty.                                                                                                                                                                                                |                                                                                                          |
| rx_pcfifo_error_1g       | Output    | N/A                         | When asserted, indicates that the Standard PCS RX phase compensation FIFO is either full or empty.                                                                                                                                                                                                |                                                                                                          |
| lcl_rf                   | Input     | Synchronous to xgmii_tx_clk | When asserted, indicates a Remote Fault (RF).The MAC sends this fault signal to its link partner. Bit D13 of the Auto Negotiation Advanced Remote Fault register (0xC2) records this error.                                                                                                       |                                                                                                          |
| rx_clkslip               | Input     | Asynchronous signal         | When asserted, the deserializer either skips one serial bit or pauses the serial clock for one cycle to achieve word alignment. As a result, the period of the parallel clock could be extended by 1 unit interval (UI) during the clock slip operation.This is an optional control input signal. |                                                                                                          |
| rx_data_ready            | Output    | Synchronous to xgmii_rx_clk | When asserted, indicates that the MAC can begin sending data to the PHY.                                                                                                                                                                                                                          |                                                                                                          |
| rx_latency_adj_10g[15:0] | Output    | Synchronous to xgmii_rx_clk | When you enable 1588, this signal outputs the real time latency in XGMII clock cycles (156.25 MHz) for the RX PCS and PMA datapath for 10G mode. Bits 0 to 9 represent the fractional number of clock cycles. Bits 10 to 15 represent the number of clock cycles.                                 |                                                                                                          |

*continued...*

| <b>Signal Name</b>       | <b>Direction</b> | <b>Clock Domain</b>         | <b>Description</b>                                                                                                                                                                                                                                                |
|--------------------------|------------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_latency_adj_10g[15:0] | Output           | Synchronous to xgmii_tx_clk | When you enable 1588, this signal outputs the real time latency in XGMII clock cycles (156.25 MHz) for the TX PCS and PMA datapath for 10G mode. Bits 0 to 9 represent the fractional number of clock cycles. Bits 10 to 15 represent the number of clock cycles. |
| rx_latency_adj_10g[21:0] | Output           | Synchronous to gmii_rx_clk  | When you enable 1588, this signal outputs the real time latency in GMII clock cycles (125 MHz) for the RX PCS and PMA datapath for 1G mode. Bits 0 to 9 represent the fractional number of clock cycles. Bits 10 to 21 represent the number of clock cycles.      |
| tx_latency_adj_10g[21:0] | Output           | Synchronous to gmii_tx_clk  | When you enable 1588, this signal outputs the real time latency in GMII clock cycles (125 MHz) for the TX PCS and PMA datapath for 1G mode. Bits 0 to 9 represent the fractional number of clock cycles. Bits 10 to 21 represent the number of clock cycles.      |

#### 2.6.4.6.7. MII

**Table 142. MII Signals**

| <b>Name</b>                   | <b>Direction</b> | <b>Description</b>                                                                                                                                                                             |
|-------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MII Transmit Interface</b> |                  |                                                                                                                                                                                                |
| mii_tx_d[3:0]                 | Input            | MII transmit data bus.                                                                                                                                                                         |
| mii_tx_en                     | Input            | Assert this signal to indicate that the data on mii_tx_d[3:0] is valid.                                                                                                                        |
| mii_tx_err                    | Input            | Assert this signal to indicate to the PHY device that the frame sent is invalid.                                                                                                               |
| <b>MII Receive Interface</b>  |                  |                                                                                                                                                                                                |
| mii_rx_d[3:0]                 | Output           | MII receive data bus.                                                                                                                                                                          |
| mii_rx_dv                     | Output           | Asserted to indicate that the data on mii_rx_d[3:0] is valid. The signal stays asserted during frame reception, from the first preamble byte until the last byte of the CRC field is received. |
| mii_rx_err                    | Output           | Asserted by the PHY to indicate that the current frame contains errors.                                                                                                                        |
| mii_col                       | Output           | Collision detection. Asserted by the PCS function to indicate that a collision was detected during frame transmission.                                                                         |
| mii_crs                       | Output           | Carrier sense detection. Asserted by the PCS function to indicate that a transmit or receive activity is detected on the Ethernet line.                                                        |

#### 2.6.4.6.8. Dynamic Reconfiguration Interface

You can use the dynamic reconfiguration interface signals to dynamically change between 1G and 10G data rates.

**Table 143. Dynamic Reconfiguration Interface Signals**

| <b>Signal Name</b> | <b>Direction</b> | <b>Clock Domain</b>     | <b>Description</b>                                                                                                                                                           |
|--------------------|------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rc_busy            | Output           | Synchronous to mgmt_clk | When asserted, indicates that reconfiguration is in progress. Synchronous to the mgmt_clk. This signal is only exposed under the following condition:<br><i>continued...</i> |

| Signal Name        | Direction | Clock Domain            | Description                                                                                                                                                                                                                                                                                       |
|--------------------|-----------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    |           |                         | <ul style="list-style-type: none"> <li>Turn on <b>Enable internal PCS reconfiguration logic</b></li> </ul>                                                                                                                                                                                        |
| start_pcs_reconfig | Input     | Synchronous to mgmt_clk | When asserted, initiates reconfiguration of the PCS. Sampled with the mgmt_clk. This signal is only exposed under the following condition: <ul style="list-style-type: none"> <li>Turn on <b>Enable internal PCS reconfiguration logic</b></li> </ul>                                             |
| mode_1g_10gbar     | Input     | Synchronous to mgmt_clk | This signal selects either the 1G or 10G tx-parallel-data going to the PCS. It is only used for the 1G/10G application (variant) under the following circumstances: <ul style="list-style-type: none"> <li>the Sequencer (auto-rate detect) is not enabled</li> <li>1G mode is enabled</li> </ul> |

### 2.6.4.7. Avalon Memory-Mapped Interface Registers

The Avalon memory-mapped interface slave signals provide access to all registers.

**Table 144. Avalon Memory-Mapped Interface Signals**

| Signal Name          | Direction | Clock Domain            | Description                                                                                                                                                                                                                                                                                               |
|----------------------|-----------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mgmt_clk             | Input     | Clock                   | The clock signal that controls the Avalon memory-mapped interface PHY management. If you plan to use the same clock for the PHY management interface and transceiver reconfiguration, you must restrict the frequency to 100-125 MHz to meet the specification for the transceiver reconfiguration clock. |
| mgmt_clk_reset       | Input     | Asynchronous reset      | Resets the PHY management interface. This signal is active high and level sensitive.                                                                                                                                                                                                                      |
| mgmt_addr[10:0]      | Input     | Synchronous to mgmt_clk | 11-bit Avalon memory-mapped interface address.                                                                                                                                                                                                                                                            |
| mgmt_writedata[31:0] | Input     | Synchronous to mgmt_clk | Input data.                                                                                                                                                                                                                                                                                               |
| mgmt_readdata[31:0]  | Output    | Synchronous to mgmt_clk | Output data.                                                                                                                                                                                                                                                                                              |
| mgmt_write           | Input     | Synchronous to mgmt_clk | Write signal. Active high.                                                                                                                                                                                                                                                                                |
| mgmt_read            | Input     | Synchronous to mgmt_clk | Read signal. Active high.                                                                                                                                                                                                                                                                                 |
| mgmt_waitrequest     | Output    | Synchronous to mgmt_clk | When asserted, indicates that the Avalon memory-mapped interface slave is unable to respond to a read or write request. When asserted, control signals to the Avalon memory-mapped interface slave must remain constant.                                                                                  |

#### Related Information

[Avalon Interface Specifications](#)

### 2.6.4.7.1. 1G/10GbE Register Definitions

The Avalon memory-mapped interface master signals provide access to the control and status registers.

The following table specifies the control and status registers that you can access over the Avalon memory-mapped interface. A single address space provides access to all registers.

**Note:** Unless otherwise indicated, the default value of all registers is 0.

**Note:** Do not write to any register that is not specified.

**Table 145. 1G/10GbE Register Definitions**

| Word Addr | Bit  | R/W | Name                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|------|-----|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4B0     | 0    | RW  | Reset SEQ                   | When set to 1, resets the 10GBASE-KR sequencer (auto rate detect logic), initiates a PCS reconfiguration, and may restart Auto-Negotiation (AN), Link Training (LT), or both if AN and LT are enabled (10GBASE-KR mode). SEQ Force Mode[2:0] forces these modes. This reset self clears.                                                                                                                                          |
|           | 1    | RW  | Disable AN Timer            | AN disable timer. If disabled ( Disable AN Timer = 1 ), AN may get stuck and require software support to remove the ABILITY_DETECT capability if the link partner does not include this feature. In addition, software may have to take the link out of loopback mode if the link is stuck in the ACKNOWLEDGE_DETECT state. To enable this timer set Disable AN Timer = 0.                                                        |
|           | 2    | RW  | Disable LF Timer            | When set to 1, disables the Link Fail timer. When set to 0, the Link Fault timer is enabled.                                                                                                                                                                                                                                                                                                                                      |
|           | 3    | RW  | fail_lt_if_ber              | When set to 1, the last LT measurement is a non-zero number. Treat this as a failed run. 0 = Normal.                                                                                                                                                                                                                                                                                                                              |
|           | 7:4  | RW  | SEQ Force Mode[2:0]         | Other than the "No force" mode (0x4B0[7:4] = 4'b0000), you must write the Reset SEQ (0x4B0[0]) to 1 when switching to the required data mode by changing (forcing) the 0x4B0[7:4] bits. The following encodings are defined: <ul style="list-style-type: none"> <li>• 0000: No force</li> <li>• 0001: GbE</li> <li>• 0010: XAUI</li> <li>• 0100: 10GBASE-R</li> <li>• 0101: 10GBASE-KR</li> <li>• 1100: 10GBASE-KR FEC</li> </ul> |
|           | 8    | RW  | Enable Arria 10 Calibration | When set to 1, it enables the Arria 10 HSSI reconfiguration calibration as part of the PCS dynamic reconfiguration. 0 skips the calibration when the PCS is reconfigured.                                                                                                                                                                                                                                                         |
|           | 16   | RW  | KR FEC enable 171.0         | When set to 1, FEC is enabled. When set to 0, FEC is disabled. Resets to the CAPABLE_FEC parameter value.                                                                                                                                                                                                                                                                                                                         |
|           | 17   | RW  | KR FEC enable err ind 171.1 | When set to 1, KR PHY FEC decoding errors are signaled to the PCS. When set to 0, FEC errors are not signaled to the PCS. See Clause 74.8.3 of IEEE 802.3ap-2007 for details.                                                                                                                                                                                                                                                     |
|           | 18   | RW  | KR FEC request              | When set to 1, enables the FEC request. When this bit changes, you must assert the Reset SEQ bit (0x4B0[0]) to renegotiate with the new value. When set to 0, disables the FEC request.                                                                                                                                                                                                                                           |
|           | 0    | R   | SEQ Link Ready              | When asserted, the sequencer indicates the link is ready.                                                                                                                                                                                                                                                                                                                                                                         |
| 0x4B1     | 1    | R   | SEQ AN timeout              | When asserted, the sequencer has had an AN timeout. This bit is latched and is reset when the sequencer restarts AN.                                                                                                                                                                                                                                                                                                              |
|           | 2    | R   | SEQ LT timeout              | When set, indicates that the sequencer has had a timeout.                                                                                                                                                                                                                                                                                                                                                                         |
|           | 13:8 | R   | SEQ Reconfig Mode[5:0]      | Specifies the sequencer mode for PCS reconfiguration. The following modes are defined: <ul style="list-style-type: none"> <li>• Bit 8, mode[0]: AN mode</li> <li>• Bit 9, mode[1]: LT Mode</li> <li>• Bit 10, mode[2]: 10G data mode</li> </ul>                                                                                                                                                                                   |

*continued...*

| Word Addr                | Bit   | R/W  | Name                          | Description                                                                                                                                                                                                                                                                                                             |
|--------------------------|-------|------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          |       |      |                               | <ul style="list-style-type: none"> <li>Bit 11, mode[3]: GbE data mode</li> <li>Bit 12, mode[4]: Reserved for XAUI</li> <li>Bit13, mode[5]: 10G FEC mode</li> </ul>                                                                                                                                                      |
|                          | 16    | R    | KR FEC ability 170.0          | When set to 1, indicates that the 10GBASE-KR PHY supports FEC. Set as parameter SYNTH_FEC. For more information, refer to <i>Clause 45.2.1.84 of IEEE 802.3ap-2007</i> .                                                                                                                                                |
|                          | 17    | R    | KR FEC err ind ability 170.0  | When set to 1, indicates that the 10GBASE-KR PHY is capable of reporting FEC decoding errors to the PCS. For more information, refer to <i>Clause 74.8.3 of IEEE 802.3ap-2007</i> .                                                                                                                                     |
| 0x4B2                    | 0:10  | RW   | Reserved                      | —                                                                                                                                                                                                                                                                                                                       |
|                          | 11    | RWSC | KR FEC TX Error Insert        | Writing a 1 inserts one error pulse into the TX FEC depending on the transcoder and burst error settings.                                                                                                                                                                                                               |
|                          | 31:15 | RWSC | Reserved                      | —                                                                                                                                                                                                                                                                                                                       |
| 0x4B5 to 0x4BF           |       |      | Reserved for 40G KR           | Intentionally left empty for address compatibility with 40G MAC + PHY KR solutions.                                                                                                                                                                                                                                     |
| 0x4C0<br><sup>(36)</sup> | 0     | RW   | AN enable                     | When set to 1, enables the AN function. The default value is 1. For additional information, refer to bit 7.0.12 in Clause 73.8 Management Register Requirements of <i>IEEE 802.3ap-2007</i> .                                                                                                                           |
|                          | 1     | RW   | AN base pages ctrl            | When set to 1, the user base pages are enabled. You can send any arbitrary data via the user base page low/high bits. When set to 0, the user base pages are disabled and the state machine generates the base pages to send.                                                                                           |
|                          | 2     | RW   | AN next pages ctrl            | When set to 1, the user next pages are enabled. You can send any arbitrary data via the user next page low/high bits. When set to 0, the user next pages are disabled. The state machine generates the null message to send as next pages.                                                                              |
|                          | 3     | RW   | Local device remote fault     | When set to 1, the local device signals Remote Faults in the AN pages. When set to 0, a fault has not occurred.                                                                                                                                                                                                         |
|                          | 4     | RW   | Force TX nonce value          | When set to 1, forces the TX nonce value to support some UNH testing modes. When set to 0, this is normal operation.                                                                                                                                                                                                    |
|                          | 5     | RW   | Override AN Parameters Enable | When set to 1, overrides the AN_TECH, AN_FEC, and AN_PAUSE parameters and uses the bits in 0x4C3 instead. You must reset the Sequencer to reconfigure and restart into AN mode. When set to 0, this is normal operation and is used with 0x4B0 bit 0 and 0x4C3 bits[30:16].                                             |
| 0x4C1                    | 0     | RW   | Reset AN                      | When set to 1, resets all the 10GBASE-KR AN state machines. This bit is self clearing.                                                                                                                                                                                                                                  |
|                          | 4     | RW   | Restart AN TX SM              | When set to 1, restarts the 10GBASE-KR TX state machine. This bit self clears and is active only when the TX state machine is in the AN state. For more information, refer to bit 7.0.9 in Clause 73.8 Management Register Requirements of <i>IEEE 802.3ap-2007</i> .                                                   |
|                          | 8     | RW   | AN Next Page                  | When asserted, new next page (NP) info is ready to send. The data is in the XNP TX registers. When 0, the TX interface sends null pages. This bit self clears. NP is encoded in bit D15 of Link Codeword. For more information, refer to Clause 73.6.9 and bit 7.16.15 of Clause 45.2.7.6 of <i>IEEE 802.3ap-2007</i> . |

***continued...***

(36) These register bits are only applicable to the 10GBASE-KR mode.

| Word Addr | Bit   | R/W | Name                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|-------|-----|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4C2     | 1     | RO  | AN page received                     | When set to 1, a page has been received. When 0, a page has not been received. The current value clears when the register is read. For more information, refer to bit 7.1.6 in Clause 73.8 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                              |
|           | 2     | RO  | AN Complete                          | When asserted, AN has completed. When 0, AN is in progress. For more information, refer to bit 7.1.5 in Clause 73.8 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                                                     |
|           | 3     | RO  | AN ADV Remote Fault                  | When set to 1, fault information has been sent to the link partner. When 0, a fault has not occurred. The current value clears when the register is read. Remote Fault (RF) is encoded in bit D13 of the base Link Codeword. For more information, refer to Clause 73.6.7 of and bit 7.16.13 of <i>IEEE 802.3ap-2007</i> .                                                                                                                            |
|           | 4     | RO  | AN RX SM Idle                        | When set to 1, the AN state machine is in the idle state. Incoming data is not Clause 73 compatible. When 0, the AN is in progress.                                                                                                                                                                                                                                                                                                                   |
|           | 5     | RO  | AN Ability                           | When set to 1, the transceiver PHY is able to perform AN. When set to 0, the transceiver PHY is not able to perform AN. If your variant includes AN, this bit is tied to 1. For more information, refer to bits 7.1.3 and 7.48.0 of Clause 45 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                           |
|           | 6     | RO  | AN Status                            | When set to 1, link is up. When 0, the link is down. The current value clears when the register is read. For more information, refer to bit 7.1.2 of Clause 45 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                          |
|           | 7     | RO  | LP AN Ability                        | When set to 1, the link partner is able to perform AN. When 0, the link partner is not able to perform AN. For more information, refer to bit 7.1.0 of Clause 45 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                        |
|           | 8     | RO  | FEC negotiated – enable FEC from SEQ | When set to 1, the PHY is negotiated to perform FEC. When set to 0, the PHY is not negotiated to perform FEC.                                                                                                                                                                                                                                                                                                                                         |
| 0x4C2     | 9     | RO  | Seq AN Failure                       | When set to 1, a sequencer AN failure has been detected. When set to 0, an AN failure has not been detected.                                                                                                                                                                                                                                                                                                                                          |
|           | 17:12 | RO  | KR AN Link Ready[5:0]                | Provides a one-hot encoding of <code>an_receive_idle = true</code> and link status for the supported link as described in Clause 73.10.1. The following encodings are defined: <ul style="list-style-type: none"> <li>• 6'b000000: 1000BASE-KX</li> <li>• 6'b000001: 10GBASE-KX4</li> <li>• 6'b000100: 10GBASE-KR</li> <li>• 6'b001000: 40GBASE-KR4</li> <li>• 6'b010000: 40GBASE-CR4</li> <li>• 6'b100000: 100GBASE-CR10</li> </ul>                  |
| 0x4C3     | 15:0  | RW  | User base page low                   | The AN TX state machine uses these bits if the AN base pages ctrl bit is set. The following bits are defined: <ul style="list-style-type: none"> <li>• [15]: Next page bit</li> <li>• [14]: ACK, controlled by the SM</li> <li>• [13]: Remote Fault bit</li> <li>• [12:10]: Pause bits</li> <li>• [9:5]: Echoed nonce, set by the state machine</li> <li>• [4:0]: Selector</li> </ul> The auto generation TX state machine generates the PRBS bit 49. |
|           | 21:16 | RW  | Override AN_TECH[5:0]                | AN_TECH value to override. The following bits are defined: <ul style="list-style-type: none"> <li>• Bit-16 = AN_TECH[0] = 1000BASE-KX</li> <li>• Bit-18 = AN_TECH[2] = 10GBASE-KR</li> </ul> You must set 0xC0 bit-5 for this to take effect .                                                                                                                                                                                                        |

continued...

| Word Addr | Bit   | R/W | Name                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|-------|-----|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 25:24 | RW  | Override AN_FEC[1:0]   | <p>AN_FEC value to override. The following bits are defined:</p> <ul style="list-style-type: none"> <li>Bit-24 = AN_FEC [0] = Capability</li> <li>Bit-25 = AN_FEC [1] = Request</li> </ul> <p>You must set 0xC0 bit-5 for this to take effect.</p>                                                                                                                                                                                                                                                   |
|           | 30:28 | RW  | Override AN_PAUSE[2:0] | <p>AN_PAUSE value to override. The following bits are defined:</p> <ul style="list-style-type: none"> <li>Bit-28 = AN_PAUSE [0] = Pause Ability</li> <li>Bit-29 = AN_PAUSE [1] = Asymmetric Direction</li> <li>Bit-30 = AN_PAUSE [2] = Reserved</li> </ul> <p>You must set 0xC0 bit-5 for this to take effect.</p>                                                                                                                                                                                   |
| 0x4C4     | 31:0  | RW  | User base page high    | <p>The AN TX state machine uses these bits if the AN base pages ctrl bit is set. The following bits are defined:</p> <ul style="list-style-type: none"> <li>[29:5]: Correspond to page bits 45:21, the technology ability.</li> <li>[4:0]: Correspond to bits 20:16, the TX nonce bits.</li> </ul> <p>The AN TX state machine generates the PRBS bit 49.</p>                                                                                                                                         |
| 0x4C5     | 15:0  | RW  | User Next page low     | <p>The AN TX state machine uses these bits if the AN next pages ctrl bit is set. The following bits are defined:</p> <ul style="list-style-type: none"> <li>[15]: Next page bit</li> <li>[14]: ACK, controlled by the state machine</li> <li>[13]: Message Page (MP) bit</li> <li>[12]: ACK2 bit</li> <li>[11]: Toggle bit</li> </ul> <p>For more information, refer to Clause 73.7.7.1 Next Page encodings of IEEE 802.3ap-2007. Bit 49, the PRBS bit, is generated by the AN TX state machine.</p> |
| 0x4C6     | 31:0  | RW  | User Next page high    | <p>The AN TX state machine uses these bits if the AN next pages ctrl bit is set. Bits [31:0] correspond to page bits [47:16]. Bit 49, the PRBS bit, is generated by the AN TX state machine.</p>                                                                                                                                                                                                                                                                                                     |
| 0x4C7     | 15:0  | RO  | LP base page low       | <p>The AN RX state machine receives these bits from the link partner. The following bits are defined:</p> <ul style="list-style-type: none"> <li>[15] Next page bit</li> <li>[14] ACK, which is controlled by the state machine</li> <li>[13] RF bit</li> <li>[12:10] Pause bits</li> <li>[9:5] Echoed nonce which are set by the state machine</li> <li>[4:0] Selector</li> </ul>                                                                                                                   |
| 0x4C8     | 31:0  | RO  | LP base page high      | <p>The AN RX state machine received these bits from the link partner. The following bits are defined:</p> <ul style="list-style-type: none"> <li>[31:30]: Reserved</li> <li>[29:5]: Correspond to page bits [45:21], the technology ability</li> <li>[4:0]: Correspond to bits [20:16], the TX Nonce bits</li> </ul>                                                                                                                                                                                 |
| 0x4C9     | 15:0  | RO  | LP Next page low       | <p>The AN RX state machine receives these bits from the link partner. The following bits are defined:</p> <ul style="list-style-type: none"> <li>[15]: Next page bit</li> <li>[14]: ACK which is controlled by the state machine</li> <li>[13]: MP bit</li> <li>[12]: ACK2 bit</li> <li>[11]: Toggle bit</li> </ul> <p>For more information, refer to Clause 73.7.7.1 Next Page encodings of IEEE 802.3ap-2007.</p>                                                                                  |

*continued...*

| <b>Word Addr</b> | <b>Bit</b> | <b>R/W</b> | <b>Name</b>                    | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|------------|------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4CA            | 31:0       | RO         | LP Next page high              | The AN RX state machine receives these bits from the link partner. Bits [31:0] correspond to page bits [47:16].                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0x4CB            | 24:0       | RO         | AN LP ADV Tech_A[24:0]         | <p>Received technology ability field bits of Clause 73 Auto-Negotiation. The 10GBASE-KR PHY supports A0 and A2. The following protocols are defined:</p> <ul style="list-style-type: none"> <li>• A0 1000BASE-KX</li> <li>• A1 10GBASE-KX4</li> <li>• A2 10GBASE-KR</li> <li>• A3 40GBASE-KR4</li> <li>• A4 40GBASE-CR4</li> <li>• A5 100GBASE-CR10</li> <li>• A24:6 are reserved</li> </ul> <p>For more information, refer to Clause 73.6.4 and AN LP base page ability registers (7.19-7.21) of Clause 45 of <i>IEEE 802.3ap-2007</i>.</p> |
|                  | 26:25      | RO         | AN LP ADV FEC_F[1:0]           | Received FEC ability bits (F0:F1) is encoded in bits D46:D47 of the base Link Codeword. F0 is FEC ability. F1 is FEC requested. See Clause 73.6.5 of <i>IEEE 802.3ap-2007</i> for details.                                                                                                                                                                                                                                                                                                                                                   |
|                  | 27         | RO         | AN LP ADV Remote Fault         | Received Remote Fault (RF) ability bits. RF is encoded in bit D13 of the base link codeword in Clause 73 AN. For more information, refer to Clause 73.6.7 and bits AN LP base page ability register AN LP base page ability registers (7.19-7.21) of Clause 45 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                 |
|                  | 30:28      | RO         | AN LP ADV Pause Ability_C[2:0] | <p>Received pause ability bits. Pause (C0:C1) is encoded in bits D11:D10 of the base link codeword in Clause 73 AN as follows:</p> <ul style="list-style-type: none"> <li>• C0 is the same as PAUSE as defined in Annex 28B</li> <li>• C1 is the same as ASM_DIR as defined in Annex 28B</li> <li>• C2 is reserved</li> </ul> <p>For more information, refer to bits AN LP base page ability registers (7.19-7.21) of Clause 45 of <i>IEEE 802.3ap-2007</i>.</p>                                                                             |
| 0x4D0            | 0          | RW         | Link Training enable           | When 1, enables the 10GBASE-KR start-up protocol. When 0, disables the 10GBASE-KR start-up protocol. The default value is 1. For more information, refer to Clause 72.6.10.3.1 and 10GBASE-KR PMD control register bit (1.150.1) of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                               |
|                  | 1          | RW         | dis_max_wait_tmr               | When set to 1, disables the LT max_wait_timer . Used for characterization mode when setting much longer bit error rate (BER) timer values.                                                                                                                                                                                                                                                                                                                                                                                                   |
|                  | 2          | RW         | quick_mode                     | When set to 1, only the init and preset values calculate the best BER.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                  | 3          | RW         | pass_one                       | When set to 1, the BER algorithm considers more than the first local minimum when searching for the lowest BER. The default value is 1.                                                                                                                                                                                                                                                                                                                                                                                                      |
|                  | 7:4        | RW         | main_step_cnt [3:0]            | Specifies the number of equalization steps for each main tap update. There are about 20 settings for the internal algorithm to test. The valid range is 1-15. The default value is 4'b0010.                                                                                                                                                                                                                                                                                                                                                  |
|                  | 11:8       | RW         | prpo_step_cnt [3:0]            | Specifies the number of equalization steps for each pre- and post-tap update. From 16-31 steps are possible. The default value is 4'b0001.                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0x4D0            | 14:12      | RW         | equal_cnt [2:0]                | Adds hysteresis to the error count to avoid local minimums. The following values are defined: <ul style="list-style-type: none"> <li>• 000 = 0</li> <li>• 001 = 1</li> <li>• 010 = 2</li> </ul>                                                                                                                                                                                                                                                                                                                                              |

*continued...*

| Word Addr | Bit   | R/W | Name                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|-------|-----|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |       |     |                                            | <ul style="list-style-type: none"> <li>• 011 = 3</li> <li>• 100 = 4</li> <li>• 101 = 8</li> <li>• 110 = 16</li> <li>• 111 = Reserved</li> </ul> The default value is 010.                                                                                                                                                                                                                                         |
|           | 15    | RW  | disable Initialize PMA on max_wait_timeout | When set to 1, PMA values (VOD, pre-tap, post-tap) are not initialized upon entry into the Training_Failure state. This happens when max_wait_timer_done, which sets training_failure = true (reg 0x4D2 bit 3). Used for University of New Hampshire (UNH) testing. When set to 0, PMA values are initialized upon entry into Training_Failure state. Refer to Figure 72-5 of IEEE 802.3ap-2007 for more details. |
|           | 16    | RW  | Ovride LP Coef enable                      | When set to 1, overrides the link partner's equalization coefficients; software changes the update commands sent to the link partner TX equalizer coefficients. When set to 0, uses the Link Training logic to determine the link partner coefficients. Used with 0x4D1 bit-4 and 0x4D4 bits[7:0].                                                                                                                |
|           | 17    | RW  | Ovride Local RX Coef enable                | When set to 1, overrides the local device equalization coefficients generation protocol. When set, the software changes the local TX equalizer coefficients. When set to 0, uses the update command received from the link partner to determine local device coefficients. Used with 0x4D1 bit-8 and 0x4D4 bits[23:16]. The default value is 1.                                                                   |
| 0x4D0     | 22    | RW  | adp_ctle_mode                              | Reserved. Default = 000                                                                                                                                                                                                                                                                                                                                                                                           |
|           | 28:24 | RW  | Manual ctle                                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                          |
|           | 31:29 | RW  | max_post_step[2:0]                         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0x4D1     | 0     | RW  | Restart Link training                      | When set to 1, resets the 10GBASE-KR start-up protocol. When set to 0, continues normal operation. This bit self clears. For more information, refer to the state variable mr_restart_training as defined in Clause 72.6.10.3.1 and 10GBASE-KR PMD control register bit (1.150.0) IEEE 802.3ap-2007.                                                                                                              |
|           | 4     | RW  | Updated TX Coef new                        | When set to 1, there are new link partner coefficients available to send. The LT logic starts sending the new values set in 0x4D4 bits[7:0] to the remote device. When set to 0, continues normal operation. This bit self clears. Must enable this override in 0x4D0 bit 16.                                                                                                                                     |
|           | 8     | RW  | Updated RX coef new                        | When set to 1, new local device coefficients are available. The LT logic changes the local TX equalizer coefficients as specified in 0x4D4 bits[23:16]. When set to 0, continues normal operation. This bit self clears. Must enable the override in 0x4D0 bit 17.                                                                                                                                                |
| 0x4D2     | 0     | RO  | Link Trained - Receiver status             | When set to 1, the receiver is trained and is ready to receive data. When set to 0, receiver training is in progress. For more information, refer to the state variable rx_trained as defined in Clause 72.6.10.3.1 and bit 10GBASE-KR PMD control register bit 10GBASE_KR PMD status register bit (1.151.0) of IEEE 802.3ap-2007.                                                                                |
|           | 1     | RO  | Link Training Frame lock                   | When set to 1, the training frame delineation has been detected. When set to 0, the training frame delineation has not been detected. For more information, refer to the state variable frame_lock as defined in Clause 72.6.10.3.1 and 10GBASE_KR PMD status register bit 10GBASE_KR PMD status register bit (1.151.1) of IEEE 802.3ap-2007.                                                                     |

*continued...*

| Word Addr | Bit   | R/W      | Name                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|-------|----------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 2     | RO       | Link Training Start-up protocol status | When set to 1, the start-up protocol is in progress. When set to 0, start-up protocol has completed. For more information, refer to the state training as defined in Clause 72.6.10.3.1 and 10GBASE_KR PMD status register bit (1.151.2) of IEEE 802.3ap-2007.                                                                                                                                                                                                                                                                                                              |
|           | 3     | RO       | Link Training failure                  | When set to 1, a training failure has been detected. When set to 0, a training failure has not been detected. For more information, refer to the state variable training_failure as defined in Clause 72.6.10.3.1 and bit 10GBASE_KR PMD status register bit (1.151.3) of IEEE 802.3ap-2007.                                                                                                                                                                                                                                                                                |
|           | 4     | RO       | Link Training Error                    | When set to 1, excessive errors occurred during Link Training. When set to 0, the BER is acceptable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|           | 5     | RO       | Link Training Frame lock Error         | When set to 1, indicates a frame lock was lost during Link Training. If the tap settings specified by the fields of 0x4D5 are the same as the initial parameter value, the frame lock error was unrecoverable.                                                                                                                                                                                                                                                                                                                                                              |
|           | 6     | RO       | RXEQ Frame Lock Loss                   | Frame lock not detected at some point during RXEQ, possibly triggering conditional RXEQ mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           | 7     | RO       | CTLE Fine-grained Tuning Error         | Could not determine the best CTLE due to maximum BER limit at each step in the fine-grained tuning mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | 0x4D3 | RW       | ber_time_frames                        | <p>Specifies the number of training frames to examine for bit errors on the link for each step of the equalization settings. Used only when ber_time_k_frames is 0. The following values are defined:</p> <ul style="list-style-type: none"> <li>• A value of 2 is about <math>10^3</math> bytes</li> <li>• A value of 20 is about <math>10^4</math> bytes</li> <li>• A value of 200 is about <math>10^5</math> bytes</li> </ul> <p>The default value for simulation is 2'b11. The default value for hardware is 0.</p>                                                     |
|           | 19:10 | RW       | ber_time_k_frames                      | <p>Specifies the number of thousands of training frames to examine for bit errors on the link for each step of the equalization settings. Set ber_time_m_frames = 0 for time/bits to match the following values:</p> <ul style="list-style-type: none"> <li>• A value of 3 is about <math>10^7</math> bits = About 1.3 ms</li> <li>• A value of 25 is about <math>10^8</math> bits = About 11 ms</li> <li>• A value of 250 is about <math>10^9</math> bits = About 110 ms</li> </ul> <p>The default value for simulation is 0. The default value for hardware is 0x415.</p> |
|           | 29:20 | RW       | ber_time_m_frames                      | <p>Specifies the number of millions of training frames to examine for bit errors on the link for each step of the equalization settings. Set ber_time_k_frames = 4'd1000 = 0x43E8 for time/bits to match the following values:</p> <ul style="list-style-type: none"> <li>• A value of 3 is about <math>10^{10}</math> bits = About 1.3 seconds</li> <li>• A value of 25 is about <math>10^{11}</math> bits = About 11 seconds</li> <li>• A value of 250 is about <math>10^{12}</math> bits = About 110 seconds</li> </ul>                                                  |
| 0x4D4     | 5:0   | RO or RW | LD coefficient update[5:0]             | Reflects the contents of the first 16-bit word of the training frame sent from the local device control channel. Normally, the bits in this register are read-only; however, when you override training by setting the Ovride Coef enable control bit, these bits become writable. The following fields are defined:                                                                                                                                                                                                                                                        |

continued...

| Word Addr | Bit   | R/W      | Name                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------|-------|----------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |       |          |                                            | <ul style="list-style-type: none"> <li>[5: 4]: Coefficient (+1) update           <ul style="list-style-type: none"> <li>— 2'b11: Reserved</li> <li>— 2'b01: Increment</li> <li>— 2'b10: Decrement</li> <li>— 2'b00: Hold</li> </ul> </li> <li>[3:2]: Coefficient (0) update (same encoding as [5:4])</li> <li>[1:0]: Coefficient (-1) update (same encoding as [5:4])</li> </ul> <p>For more information, refer to bit 10G BASE-KR LD coefficient update register bits (1.154.5:0) in Clause 45.2.1.80.3 of <i>IEEE 802.3ap-2007</i>.</p>                                                                                                                                                                                                                                                                                                                                          |
|           | 6     | RO or RW | LD Initialize Coefficients                 | When set to 1, requests the link partner coefficients be set to configure the TX equalizer to its INITIALIZE state. When set to 0, continues normal operation. For more information, refer to 10G BASE-KR LD coefficient update register bits (1.154.12) in Clause 45.2.1.80.3 and Clause 72.6.10.2.3.2 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           | 7     | RO or RW | LD Preset Coefficients                     | When set to 1, requests the link partner coefficients be set to a state where equalization is turned off. When set to 0 the link operates normally. For more information, refer to bit 10GBASE-KR LD coefficient update register bit (1.154.13) in Clause 45.2.1.80.3 and Clause 72.6.10.2.3.2 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|           | 13:8  | RO       | LD coefficient status[5:0]                 | <p>Status report register for the contents of the second, 16-bit word of the training frame most recently sent from the local device control channel. The following fields are defined:</p> <ul style="list-style-type: none"> <li>[5:4]: Coefficient (post-tap)           <ul style="list-style-type: none"> <li>— 2'b11: Maximum</li> <li>— 2'b01: Minimum</li> <li>— 2'b10: Updated</li> <li>— 2'b00: Not updated</li> </ul> </li> <li>[3:2]: Coefficient (0) (same encoding as [5:4])</li> <li>[1:0]: Coefficient (pre-tap) (same encoding as [5:4])</li> </ul> <p>For more information, refer to bit 10GBASE-KR LD status report register bit (1.155.5:0) in Clause 45.2.1.81 of <i>IEEE 802.3ap-2007</i>.</p>                                                                                                                                                                |
| 0x4D4     | 14    | RO       | Link Training ready<br>– LD Receiver ready | When set to 1, the local device receiver has determined that training is complete and it is prepared to receive data. When set to 0, the local device receiver requests that training continue. Values for the receiver ready bit are defined in Clause 72.6.10.2.4.4. For more information, refer to bit 10GBASE-KR LD status report register bit (1.155.15) in Clause 45.2.1.81 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | 21:16 | RO or RW | LP coefficient update[5:0]                 | <p>Reflects the contents of the first 16-bit word of the training frame most recently received from the control channel.</p> <p>Normally the bits in this register are read only; however, when training is disabled by setting low the KR training enable control bit, these bits become writable. The following fields are defined:</p> <ul style="list-style-type: none"> <li>[5: 4]: Coefficient (+1) update           <ul style="list-style-type: none"> <li>— 2'b11: Reserved</li> <li>— 2'b01: Increment</li> <li>— 2'b10: Decrement</li> <li>— 2'b00: Hold</li> </ul> </li> <li>[3:2]: Coefficient (0) update (same encoding as [5:4])</li> <li>[1:0]: Coefficient (-1) update (same encoding as [5:4])</li> </ul> <p>For more information, refer to bit 10GBASE-KR LP coefficient update register bits (1.152.5:0) in Clause 45.2.1.78.3 of <i>IEEE 802.3ap-2007</i>.</p> |

*continued...*

| <b>Word Addr</b> | <b>Bit</b> | <b>R/W</b> | <b>Name</b>                | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------|------------|------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 22         | RO or RW   | LP Initialize Coefficients | When set to 1, the local device transmit equalizer coefficients are set to the INITIALIZE state. When set to 0, normal operation continues. The function and values of the initialize bit are defined in Clause 72.6.10.2.3.2. For more information, refer to bit 10GBASE-KR LP coefficient update register bits (1.152.12) in Clause 45.2.1.78.3 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                                                          |
| 0x4D4            | 23         | RO or RW   | LP Preset Coefficients     | When set to 1, the local device TX coefficients are set to a state where equalization is turned off. Preset coefficients are used. When set to 0, the local device operates normally. The function and values of the preset bit are defined in 72.6.10.2.3.1. The function and values of the initialize bit are defined in Clause 72.6.10.2.3.2. For more information, refer to bit 10GBASE-KR LP coefficient update register bits (1.152.13) in Clause 45.2.1.78.3 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                        |
|                  | 29:24      | RO         | LP coefficient status[5:0] | Status report register reflecting the contents of the second, 16-bit word of the training frame most recently received from the control channel. The following fields are defined: <ul style="list-style-type: none"> <li>• [5:4]: Coefficient (+1) <ul style="list-style-type: none"> <li>— 2'b11: Maximum</li> <li>— 2'b01: Minimum</li> <li>— 2'b10: Updated</li> <li>— 2'b00: Not updated</li> </ul> </li> <li>• [3:2]: Coefficient (0) (same encoding as [5:4])</li> <li>• n [1:0]: Coefficient (-1) (same encoding as [5:4])</li> </ul> For more information, refer to bit 10GBASE-KR LP status report register bits (1.153.5:0) in Clause 45.2.1.79 of <i>IEEE 802.3ap-2007</i> . |
|                  | 30         | RO         | LP Receiver ready          | When set to 1, the link partner receiver has determined that training is complete and is prepared to receive data. When set to 0, the link partner receiver is requesting that training continue. Values for the receiver ready bit are defined in Clause 72.6.10.2.4.4. For more information, refer to bit 10GBASE-KR LP status report register bits (1.153.15) in Clause 45.2.1.79 of <i>IEEE 802.3ap-2007</i> .                                                                                                                                                                                                                                                                       |
| 0x4D5            | 4:0        | R          | LT V <sub>OD</sub> setting | Stores the most recent V <sub>OD</sub> setting that LT specified. It reflects Link Partner commands to fine-tune the V <sub>OD</sub> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                  | 13:8       | R          | LT Post-tap setting        | Stores the most recent post-tap setting that LT specified. It reflects Link Partner commands to fine-tune the TX pre-emphasis taps.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                  | 20:16      | R          | LT Pre-tap setting         | Stores the most recent pre-tap setting that LT specified. It reflects Link Partner commands to fine-tune the TX pre-emphasis taps.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x4D5            | 27:24      | R          | RXEQ CTLE Setting          | Most recent ctle_rc setting sent to the reconfig bundle during RX equalization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | 29:28      | R          | RXEQ CTLE Mode             | Most recent ctle_mode setting sent to the reconfig bundle during RX equalization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                  | 31:30      | R          | RXEQ DFE Mode              | Most recent dfe_mode setting sent to the reconfig bundle during RX equalization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0x4D6            | 4:0        | RW         | LT VODMAX ovrd             | Override value for the VMAXRULE parameter. When enabled, this value substitutes for the VMAXRULE to allow channel-by-channel override of the device settings. This only effects the local device TX output for the channel specified.<br><br>This value must be greater than the INITMAINVAL parameter for proper operation. Note this also overrides the PREMAINVAL parameter value.                                                                                                                                                                                                                                                                                                    |

*continued...*

| Word Addr      | Bit   | R/W | Name                  | Description                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|-------|-----|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | 5     | RW  | LT VODMAX ovrd Enable | When set to 1, enables the override value for the VMAXRULE parameter stored in the LT VODMAX ovrd register field.                                                                                                                                                                                                                                                                |
|                | 12:8  | RW  | LT VODMin ovrd        | Override value for the VODMINRULE parameter. When enabled, this value substitutes for the VMINRULE to allow channel-by-channel override of the device settings. This override only effects the local device TX output for this channel.<br>The value to be substituted must be less than the INITMAINVAL parameter and greater than the VMINRULE parameter for proper operation. |
|                | 13    | RW  | LT VODMin ovrd Enable | When set to 1, enables the override value for the VODMINRULE parameter stored in the LT VODMIN ovrd register field.                                                                                                                                                                                                                                                              |
|                | 21:16 | RW  | LT VPOST ovrd         | Override value for the VPOSTRULE parameter. When enabled, this value substitutes for the VPOSTRULE to allow channel-by-channel override of the device settings. This override only effects the local device TX output for this channel.<br>The value to be substituted must be greater than the INITPOSTVAL parameter for proper operation.                                      |
|                | 22    | RW  | LT VPOST ovrd Enable  | When set to 1, enables the override value for the VPOSTRULE parameter stored in the LT VPOST ovrd register field.                                                                                                                                                                                                                                                                |
|                | 28:24 | RW  | LT VPre ovrd          | Override value for the VPRERULE parameter. When enabled, this value substitutes for the VPOSTRULE to allow channel-by-channel override of the device settings. This override only effects the local device TX output for this channel.<br>The value greater than the INITPREVAL parameter for proper operation.                                                                  |
|                | 29    | RW  | LT VPre ovrd Enable   | When set to 1, enables the override value for the VPRERULE parameter stored in the LT VPre ovrd register field.                                                                                                                                                                                                                                                                  |
| 0x4D7 to 0x4FF |       |     | Reserved for 40G KR   | Left empty for address compatibility with 40G MAC+PHY KR solution.                                                                                                                                                                                                                                                                                                               |

#### Related Information

[Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514

#### 2.6.4.7.2. Hard Transceiver PHY Registers

**Table 146. Hard Transceiver PHY Registers**

| Addr        | Bit   | Access | Name                     | Description                                                                                                                                                                                                                                                |
|-------------|-------|--------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x000-0x3FF | [9:0] | RW     | Access to HSSI registers | All registers in the physical coding sub-layer (PCS) and physical media attachment (PMA) that you can dynamically reconfigure are in this address space. Refer to the <i>Arria 10 Dynamic Transceiver Reconfiguration</i> chapter for further information. |

#### Related Information

[Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514

### 2.6.4.7.3. Enhanced PCS Registers

**Table 147. Enhanced PCS Registers**

| Addr  | Bit  | Access | Name            | Description                                                                                                                      |
|-------|------|--------|-----------------|----------------------------------------------------------------------------------------------------------------------------------|
| 0x480 | 31:0 | RW     | Indirect_addr   | Because the PHY implements a single channel, this register must remain at the default value of 0 to specify logical channel 0.   |
| 0x481 | 2    | RW     | RCLR_ERRBLK_CNT | Error block counter clear register. When set to 1, clears the error block counter. When set to 0, normal operation continues.    |
|       | 3    | RW     | RCLR_BER_COUNT  | BER counter clear register. When set to 1, clears the BER counter. When set to 0, normal operation continues.                    |
| 0x482 | 1    | RO     | HI_BER          | High BER status. When set to 1, the PCS reports a high BER. When set to 0, the PCS does not report a high BER.                   |
|       | 2    | RO     | BLOCK_LOCK      | Block lock status. When set to 1, the PCS is locked to received blocks. When set to 0, the PCS is not locked to received blocks. |
|       | 3    | RO     | TX_FIFO_FULL    | When set to 1, the TX_FIFO is full.                                                                                              |
|       | 4    | RO     | RX_FIFO_FULL    | When set to 1, the RX_FIFO is full.                                                                                              |
|       | 7    | RO     | Rx_DATA_READY   | When set to 1, indicates the PHY is ready to receive data.                                                                       |

### 2.6.4.7.4. Arria 10 GMII PCS Registers

| Addr                       | Bit | R/W | Name                      | Description                                                                                                                                                                                                                   |
|----------------------------|-----|-----|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x490                      | 9   | RW  | RESTART_AUTO_NEGOTIATION  | Set this bit to 1 to restart the Clause 37 auto-negotiation (AN) sequence. For normal operation, set this bit to the default 0 value. This bit is self-clearing.                                                              |
|                            | 12  | RW  | AUTO_NEGOTIATION_ENABLE   | Set this bit to 1 to enable Clause 37 AN. The default value is 1.                                                                                                                                                             |
|                            | 15  | RW  | Reset                     | Set this bit to 1 to generate a synchronous reset pulse which resets all the PCS state machines, comma detection function, and the 8B/10B encoder and decoder. For normal operation, set this bit to 0. This bit self clears. |
| 0x491                      | 2   | R   | LINK_STATUS               | A value of 1 indicates that a valid link is operating. A value of 0 indicates an invalid link. If link synchronization is lost, this bit is 0.                                                                                |
|                            | 3   | R   | AUTO_NEGOTIATION_ABILITY  | A value of 1 indicates that the PCS function supports Clause 37 AN.                                                                                                                                                           |
|                            | 5   | R   | AUTO_NEGOTIATION_COMPLETE | A value of 1 indicates the following status: <ul style="list-style-type: none"><li>• The AN process is complete.</li><li>• The AN control registers are valid.</li></ul>                                                      |
| 0x494<br>(1000BASE-X mode) | 5   | RW  | FD                        | Full-duplex mode enable for the local device. Set to 1 for full-duplex support.                                                                                                                                               |
|                            | 6   | RW  | HD                        | Half-duplex mode enable for the local device. Set to 1 for half-duplex support. This bit should always be set to 0 for the KR PHY IP.                                                                                         |

*continued...*

| Addr                       | Bit                   | R/W | Name       | Description                                                                                                                                                                                                                                                                                                                                        |
|----------------------------|-----------------------|-----|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | 8:7                   | RW  | PS2,PS1    | Pause support for the local device. The following encodings are defined for PS1/PS2: <ul style="list-style-type: none"><li>• PS1=0 / PS2=0: Pause is not supported</li><li>• PS1=0 / PS2=1: Asymmetric pause toward link partner</li><li>• PS1=1 / PS2=0: Symmetric pause</li><li>• PS1=1 / PS2=1: Pause is supported on TX and RX</li></ul>       |
|                            | 13:12                 | RW  | RF2,RF1    | Remote fault condition for local device. The following encodings are defined for RF1/RF2: <ul style="list-style-type: none"><li>• RF1=0 / RF2=0: No error, link is valid (reset condition)</li><li>• RF1=0 / RF2=1: Offline</li><li>• RF1=1 / RF2=0: Failure condition</li><li>• RF1=1 / RF2=1: AN error</li></ul>                                 |
|                            | 14                    | RO  | ACK        | Acknowledge for local device. A value of 1 indicates that the device has received three consecutive matching ability values from its link partner.                                                                                                                                                                                                 |
|                            | 15                    | RW  | NP         | Next page. In the device ability register, this bit is always set to 0.                                                                                                                                                                                                                                                                            |
| 0x495<br>(1000BASE-X mode) | 5                     | R   | FD         | Full-duplex mode enable for the link partner. This bit must be 1 because only full duplex is supported.                                                                                                                                                                                                                                            |
|                            | 6                     | R   | HD         | Half-duplex mode enable for the link partner. A value of 1 indicates support for half duplex. This bit must be 0 because half-duplex mode is not supported.                                                                                                                                                                                        |
|                            | 8:7                   | R   | PS2,PS1    | Specifies pause support for link partner. The following encodings are defined for PS1/PS2: <ul style="list-style-type: none"><li>• PS1=0 / PS2=0: Pause is not supported</li><li>• PS1=0 / PS2=1: Asymmetric pause toward link partner</li><li>• PS1=1 / PS2=0: Symmetric pause</li><li>• PS1=1 / PS2=1: Pause is supported on TX and RX</li></ul> |
|                            | 13:12                 | R   | RF2,RF1    | Remote fault condition for link partner. The following encodings are defined for RF1/RF2: <ul style="list-style-type: none"><li>• RF1=0 / RF2=0: No error, link is valid (reset condition)</li><li>• RF1=0 / RF2=1: Offline</li><li>• RF1=1 / RF2=0: Failure condition</li><li>• RF1=1 / RF2=1: AN error</li></ul>                                 |
|                            | 14                    | R   | ACK        | Acknowledge for link partner. A value of 1 indicates that the device has received three consecutive matching ability values from its link partner.                                                                                                                                                                                                 |
|                            | 15                    | R   | NP         | Next page. In link partner register. When set to 0, the link partner has a Next Page to send. When set to 1, the link partner does not send a Next Page. Next Page is not supported in AN.                                                                                                                                                         |
|                            | 0x494<br>(SGMII mode) | 14  | RO         | ACK                                                                                                                                                                                                                                                                                                                                                |
| 0x495<br>(SGMII mode)      | 11:10                 | RO  | Speed[1:0] | Link partner speed: <ul style="list-style-type: none"><li>• 00: copper interface speed is 10 Mbps</li><li>• 01: copper interface speed is 100 Mbps</li><li>• 10: copper interface speed is 1 Gigabit</li><li>• 11: reserved</li></ul>                                                                                                              |

*continued...*

| Addr  | Bit  | R/W | Name                               | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|-----|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 12   | RO  | COPPER_DUPLEX_STATUS               | <p>Link partner capability:</p> <ul style="list-style-type: none"> <li>• 1: copper interface is capable of full-duplex operation</li> <li>• 0: copper interface is capable of half-duplex operation</li> </ul> <p><i>Note:</i> The PHY IP Core does not support half duplex operation because it is not supported in SGMII mode of the 1G/10G PHY IP core.</p>                                                      |
|       | 14   | RO  | ACK                                | Link partner acknowledge. Value as specified in IEEE 802.3z standard.                                                                                                                                                                                                                                                                                                                                               |
|       | 15   | RO  | COPPER_LINK_STATUS                 | Link partner status: <ul style="list-style-type: none"> <li>• 1: copper interface link is up</li> <li>• 0: copper interface link is down</li> </ul>                                                                                                                                                                                                                                                                 |
| 0x496 | 0    | R   | LINK_PARTNER_AUTO_NEGOTIATION_ABLE | Set to 1, indicates that the link partner supports AN. The default value is 0.                                                                                                                                                                                                                                                                                                                                      |
|       | 1    | R   | PAGE_RECEIVE                       | A value of 1 indicates that a new page has been received with new partner ability available in the register partner ability. The default value is 0 when the system management agent performs a read access.                                                                                                                                                                                                        |
| 0x4A2 | 15:0 | RW  | Link timer[15:0]                   | Low-order 16 bits of the 21-bit auto-negotiation link timer. Each timer step corresponds to 8 ns (assuming a 125 MHz clock). The total timer corresponds to 16 ms. The reset value sets the timer to 10 ms for hardware mode and 10 us for simulation mode.                                                                                                                                                         |
| 0x4A3 | 4:0  | RW  | Link timer[20:16]                  | High-order 5 bits of the 21-bit auto-negotiation link timer.                                                                                                                                                                                                                                                                                                                                                        |
| 0x4A4 | 0    | RW  | SGMII_ENA                          | Determines the PCS function operating mode. Setting this bit to 1'b1 enables SGMII mode. Setting this bit to 1'b0 enables 1000BASE-X gigabit mode.                                                                                                                                                                                                                                                                  |
|       | 1    | RW  | USE_SGMII_AN                       | In SGMII mode, setting this bit to 1'b1 configures the PCS with the link partner abilities advertised during auto-negotiation. If this bit is set to 1'b0, the PCS function should be configured with the SGMII_SPEED and SGMII_DUPLEX bits.                                                                                                                                                                        |
|       | 3:2  | RW  | SGMII_SPEED                        | <p>SGMII speed. When the PCS operates in SGMII mode (SGMII_ENA = 1) and is not programmed for automatic configuration (USE_SGMII_AN = 0), the following encodings specify the speed :</p> <ul style="list-style-type: none"> <li>• 2'b00: 10 Mbps</li> <li>• 2'b01: 100 Mbps</li> <li>• 2'b10: Gigabit</li> <li>• 2'b11: Reserved</li> </ul> <p>These bits are not used when SGMII_ENA = 0 or USE_SGMII_AN = 1.</p> |
|       | 4    | RW  | SGMII_half-duplex                  | When set to 1, enables half-duplex mode for 10/100 Mbps speed. This bit is ignored when SGMII_ENA = 0 or USE_SGMII_AN = 1. These bits are only valid when you enable the SGMII mode only and not the clause-37 auto-negotiation mode.                                                                                                                                                                               |

#### 2.6.4.7.5. PMA Registers

The PMA registers allow you to reset the PMA, customize the TX and RX serial data interface, and provide status information.

**Table 148. 1G Data Mode**

| <b>Addr</b> | <b>Bit</b> | <b>R/W</b> | <b>Name</b>            | <b>Description</b>                                                                         |
|-------------|------------|------------|------------------------|--------------------------------------------------------------------------------------------|
| 0x4A8       | 0          | RW         | tx_invpolarity         | When set, the TX interface inverts the polarity of the TX data to the 8B/10B encoder.      |
|             | 1          | RW         | rx_invpolarity         | When set, the RX channels inverts the polarity of the received data to the 8B/10B decoder. |
|             | 2          | RW         | rx_bitreversal_enable  | When set, enables bit reversal on the RX interface to the word aligner.                    |
|             | 3          | RW         | rx_bytereversal_enable | When set, enables byte reversal on the RX interface to the byte deserializer.              |
|             | 4          | RW         | force_electrical_idle  | When set, forces the TX outputs to electrical idle.                                        |
| 0x4A9       | 0          | R          | rx_syncstatus          | When set, the word aligner is synchronized.                                                |
|             | 1          | R          | rx_patterndetect       | GbE word aligner detected comma.                                                           |
|             | 2          | R          | rx_rlv                 | Run length violation.                                                                      |
|             | 3          | R          | rx_rmfifodatainserted  | Rate match FIFO inserted code group.                                                       |
|             | 4          | R          | rx_rmfifodatadeleted   | Rate match FIFO deleted code group.                                                        |
|             | 5          | R          | rx_disperr             | RX 8B10B disparity error.                                                                  |
|             | 6          | R          | rx_errdetect           | RX 8B10B error detected.                                                                   |

**Table 149. PMA Registers**

| <b>Address</b> | <b>Bit</b> | <b>R/W</b> | <b>Name</b>            | <b>Description</b>                                                                                                           |
|----------------|------------|------------|------------------------|------------------------------------------------------------------------------------------------------------------------------|
| 0x444          | 1          | RW         | reset_tx_digital       | Writing a 1 asserts the internal TX digital reset signal. You must write a 0 to clear the reset condition.                   |
|                | 2          | RW         | reset_rx_analog        | Writing a 1 causes the internal RX analog reset signal to be asserted. You must write a 0 to clear the reset condition.      |
|                | 3          | RW         | reset_rx_digital       | Writing a 1 causes the internal RX digital reset signal to be asserted. You must write a 0 to clear the reset condition.     |
| 0x461          | 0          | RW         | phy_serial_loopback    | Writing a 1 puts the channel in serial loopback mode.                                                                        |
| 0x464          | 0          | RW         | pma_rx_set_locktodata  | When set, programs the RX clock data recovery (CDR) PLL to lock to the incoming data.                                        |
| 0x465          | 0          | RW         | pma_rx_set_locktoref   | When set, programs the RX CDR PLL to lock to the reference clock.                                                            |
| 0x466          | 0          | RO         | pma_rx_is_lockedtodata | When asserted, indicates that the RX CDR PLL is locked to the RX data, and that the RX CDR has changed from LTR to LTD mode. |
| 0x467          | 0          | RO         | pma_rx_is_lockedtoref  | When asserted, indicates that the RX CDR PLL is locked to the reference clock.                                               |

#### 2.6.4.7.6. Speed Change Summary

**Table 150. Speed Change Summary**

| Speed Change                            | Speed Change Method                | Detailed Information                                                                                                                                |
|-----------------------------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 1GbE and 10GBASE-R                      | Interface Signals                  | <ul style="list-style-type: none"> <li>Refer to <i>Dynamic Reconfiguration Interface</i>.</li> <li><a href="#">Figure 77</a> on page 197</li> </ul> |
| SGMII (10M, 100M and 1GbE)              | Avalon memory-mapped interface bus | <a href="#">Table 124</a> on page 160                                                                                                               |
| 1GbE, 10GBASE-R, and 10GBASE-R with FEC | Avalon memory-mapped interface bus | <a href="#">Table 145</a> on page 182                                                                                                               |

**Note:** You can configure the static speed while generating the IP core using the IP Parameter Editor.

#### Related Information

[Dynamic Reconfiguration Interface](#) on page 148

#### 2.6.4.8. Creating a 1G/10GbE Design

Follow these steps to create a 1G/10GbE design using the 1G/10GbE PHY IP.

1. Generate the 1G/10GbE PHY with the required parameterization.

The 1G/10GbE PHY IP Core includes reconfiguration logic. This logic provides the Avalon memory-mapped interface that you can use to read and write to PHY registers. All read and write operations must adhere to the Avalon specification.

2. Instantiate a reset controller using the Transceiver Reset Controller Intel FPGA IP Core in the IP Catalog. Connect the power and reset signals between the 1G/10GbE PHY and the reset controller.
3. Instantiate one TX PLL for the 1G data rate and one TX PLL for the 10G data rate. Connect the high speed serial clock and PLL lock signals between 1G/10GbE PHY and TX PLLs. You can use any combination of fPLLs, ATX, or CMU PLLs.
4. Use the `tx_pma_divclk` from 1G/10GbE PHY or generate a fPLL to create the 156.25 MHz XGMII clock from the 10G reference clock.  
No Memory Initialization Files (**.mif**) are required for the 1G/10GbE design in Arria 10 devices.
5. Complete the design by creating a top level module to connect all the IP (1G/10GbE PHY IP, PLL IP and Reset Controller) blocks.

#### Related Information

- [fPLL](#) on page 368
- [CMU PLL](#) on page 377
- [ATX PLL](#) on page 359
- [Using the Transceiver PHY Reset Controller](#) on page 445
- [1G/10GbE PHY Functional Description](#) on page 166

#### 2.6.4.9. Design Guidelines

Consider the following guidelines while designing with 1G/10GbE PHY.

### Using the 1G/10GbE PHY without the Sequencer

The sequencer brings up channel-based initial datapath and performs parallel detection. To use the 1G/10GbE PHY without the sequencer, turn off the **Enable automatic speed detection** parameter.

Turning off the sequencer results in the following additional ports:

- rc\_busy
- start\_pcs\_reconfig
- mode\_1g\_10gbar

These ports perform manual reconfiguration. The following figure shows how these ports are used for 1G and 10G configuration.

**Figure 77. Timing for Reconfiguration without the Sequencer**



#### 2.6.4.10. Channel Placement Guidelines

The channels of multi-channel 1G/10G designs do not need to be placed contiguously. However, channels instantiated in different transceiver banks require PLLs in the same bank.

##### Related Information

[Arria 10 Avalon Memory-Mapped Interface for PCIe\\* Solutions](#)

#### 2.6.4.11. Design Example

Intel provides a design example to assist you in integrating your Ethernet PHY IP into your complete design.

The MAC and PHY design example instantiates the 1G/10GbE PHY IP along with the 1G/10G Ethernet MAC and supporting logic. It is part of the Intel Quartus Prime software installation and is located in the `<quartus_install_dir>/<version_number>/ip/altera/ethernet` subdirectory. For more information about this example design, refer to the [Low Latency Ethernet 10G MAC Intel Arria 10 FPGA IP Design Example User Guide](#).

A design example that instantiates the 1G/10G PHY and its supporting logic is available on the Intel FPGA wiki. The following figure shows the block diagram of the 1G/10GbE PHY-only design example. The default configuration includes two channels for backplane Ethernet and two channels for line-side (1G/10G) applications.

**Figure 78. 1G/10GbE PHY Only Design Example**


#### Related Information

- Arria 10 Transceiver PHY Design Examples
- AN 735: Altera Low Latency Ethernet 10G MAC IP Core Migration Guidelines

#### 2.6.4.12. Simulation Support

The 1G/10GbE and 10GBASE-KR PHY IP core supports the following Intel-supported simulators for this Quartus Prime software release:

- ModelSim Verilog
- ModelSim VHDL
- VCS Verilog
- VCS VHDL
- NCSIM Verilog
- NCSIM VHDL simulation

When you generate a 1G/10GbE or 10GBASE-KR PHY IP core, the Quartus Prime software optionally generates an IP functional simulation model.

### 2.6.4.13. TimeQuest Timing Constraints

To pass timing analysis, you must decouple the clocks in different time domains. The necessary Synopsys Design Constraints File (.sdc) timing constraints are included in the top-level wrapper file.

## 2.6.5. 1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP Core

### 2.6.5.1. About the 1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP Core

The 1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP core implements the Ethernet protocol as defined in Clause 36 of the *IEEE 802.3 2005 Standard*. The PHY IP core consists of a physical coding sublayer (PCS) function and an embedded physical media attachment (PMA). You can dynamically switch the PHY operating speed.

**Note:** Intel FPGAs implement and support the required Media Access Control (MAC) and PHY (PCS+PMA) IP to interface in a chip-to-chip or chip-to-module channel with external MGBASE-T and NBASE-T PHY standard devices. You are required to use an external PHY device to drive any copper media.

**Figure 79. Block Diagram of the PHY IP Core**



### Related Information

- [Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45
- [Recommended Reset Sequence](#) on page 430
- [Low Latency Ethernet 10G MAC User Guide](#)  
Describes the Low Latency Ethernet 10G MAC IP Core.

### 2.6.5.1.1. Features

**Table 151. PHY Features**

| Feature                        | Description                                                                                                                        |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Multiple operating speeds      | 1G, 2.5G, 5G, and 10G.                                                                                                             |
| MAC-side interface             | 16-bit GMII for 1G and 2.5G.                                                                                                       |
|                                | 32-bit XGMII for 1G/2.5G/5G/10G (USXGMII).                                                                                         |
|                                | 64-bit XGMII for 10G.                                                                                                              |
| Network-side interface         | 1.25 Gbps for 1G.                                                                                                                  |
|                                | 3.125 Gbps for 2.5G.                                                                                                               |
|                                | 10.3125 Gbps for 1G/2.5G/5G/10G (USXGMII).                                                                                         |
| Avalon Memory-Mapped interface | Provides access to the configuration registers of the PHY.                                                                         |
| PCS function                   | 1000BASE-X for 1G and 2.5G.                                                                                                        |
|                                | 10GBASE-R for 10G.                                                                                                                 |
|                                | USXGMII PCS for 1G/2.5G/5G/10G                                                                                                     |
| Auto-negotiation               | Implements clause 37. Supported in 1GbE only.<br>USXGMII Auto-negotiation supported in the 1G/2.5G/5G/10G (USXGMII) configuration. |
| IEEE 1588v2                    | Provides the required latency to the MAC if the MAC enables the IEEE 1588v2 feature.                                               |
| Sync-E                         | Provides the clock for Sync-E implementation.                                                                                      |

### 2.6.5.1.2. Release Information

**Table 152. PHY Release Information**

| Item           | Description |
|----------------|-------------|
| Version        | 19.1        |
| Release Date   | April 2019  |
| Ordering Codes | IP-10GMRPHY |
| Product ID     | 00E4        |
| Vendor ID      | 6AF7        |
| Open Core Plus | Supported   |

### 2.6.5.1.3. Device Family Support

**Table 153. Intel FPGA IP Core Device Support Levels**

| Device Support Level | Definition                                                                                                                                                                                                                                                         |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Preliminary          | Intel verifies the IP core 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. This IP core can be used in production designs with caution. |
| Final                | Intel verifies the IP core with final timing models for this device family. The IP core meets all functional and timing requirements for the device family. This IP core is ready to be used in production designs.                                                |

| Device Family  | Operating Mode                                            | Support Level |
|----------------|-----------------------------------------------------------|---------------|
| Intel Arria 10 | 2.5G<br>1G/2.5G<br>1G/2.5G/10G<br>10M/100M/1G/2.5G/5G/10G | Final         |

#### 2.6.5.1.4. Resource Utilization

The following estimates are obtained by compiling the PHY IP core with the Intel Quartus Prime software.

**Table 154. Resource Utilization**

| Device         | Speed                             | ALMs | ALUTs | Logic Registers | Memory Block (M20K) |
|----------------|-----------------------------------|------|-------|-----------------|---------------------|
| Intel Arria 10 | 1G/2.5G                           | 550  | 750   | 1250            | 2                   |
|                | 1G/2.5G with IEEE 1588v2 enabled  | 1200 | 1850  | 2550            | 2                   |
|                | 1G/2.5G/10G (MGBASE-T)            | 1150 | 1500  | 2550            | 6                   |
|                | 10M/100M/1G/2.5G/5G/10G (USXGMII) | 700  | 950   | 1750            | 3                   |

#### 2.6.5.2. Using the IP Core

The Intel FPGA IP Library is installed as part of the Intel Quartus Prime installation process. You can select the 1G/2.5G/5G/10G Multi-rate Ethernet Intel FPGA IP core from the library and parameterize it using the IP parameter editor.

##### 2.6.5.2.1. Parameter Settings

You customize the PHY IP core by specifying the parameters in the parameter editor in the Intel Quartus Prime software. The parameter editor enables only the parameters that are applicable to the selected speed.

**Table 155. Multi-rate Ethernet PHY IP Core Parameters**

| Name                                            | Value                                                     | Description                                                                                                                                                                                          |
|-------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Speed</b>                                    | 2.5G<br>1G/2.5G<br>1G/2.5G/10G<br>10M/100M/1G/2.5G/5G/10G | The operating speed of the PHY.                                                                                                                                                                      |
| <b>Enable IEEE 1588 Precision Time Protocol</b> | On, Off                                                   | Select this option for the PHY to provide latency information to the MAC. The MAC requires this information if it enables the IEEE 1588v2 feature. This option is enabled only for 2.5G and 1G/2.5G. |
| <b>Connect to MGBASE-T PHY</b>                  | On, Off                                                   | Select this option when the external PHY is MGBASE-T compatible. This parameter is enabled for 2.5G, 1G/2.5G, and 1G/2.5G/10G (MGBASE-T) modes.                                                      |

*continued...*

| Name                                                           | Value                 | Description                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Connect to NBASE-T PHY</b>                                  | On, Off               | Select this option when the external PHY is NBASE-T compatible.<br>This parameter is enabled for 10M/100M/1G/2.5G/5G/10G (USXGMII) modes.                                                                                                                                                                                                                                          |
| <b>PHY ID (32 bit)</b>                                         | 32-bit value          | An optional 32-bit unique identifier: <ul style="list-style-type: none"> <li>• Bits 3 to 24 of the Organizationally Unique Identifier (OUI) assigned by the IEEE</li> <li>• 6-bit model number</li> <li>• 4-bit revision number</li> </ul> If unused, do not change the default value, which is 0x00000000.                                                                        |
| <b>Reference clock frequency for 10 GbE (MHz)</b>              | 322.265625, 644.53125 | Specify the frequency of the reference clock for 10GbE.                                                                                                                                                                                                                                                                                                                            |
| <b>Selected TX PMA local clock division factor for 1 GbE</b>   | 1, 2, 4, 8            | This parameter is the local clock division factor in the 1G mode. It is directly mapped to the Native PHY IP Core GUI options.                                                                                                                                                                                                                                                     |
| <b>Selected TX PMA local clock division factor for 2.5 GbE</b> | 1, 2                  | This parameter is the local clock division factor in the 2.5G mode. It is directly mapped to the Native PHY IP Core GUI options.                                                                                                                                                                                                                                                   |
| <b>Enable Native PHY Debug Master Endpoint (NPDME)</b>         | On, Off               | Available in Native PHY and TX PLL IP parameter editors. When enabled, the Native PHY Debug Master Endpoint (NPDME) is instantiated and has access to the Avalon memory-mapped interface of the Native PHY. You can access certain test and debug functions using System Console with the NPDME. Refer to the <i>Embedded Debug Features</i> section for more details about NPDME. |
| <b>Enable capability registers</b>                             | On, Off               | Available in Native PHY and TX PLL IP parameter editors. Enables capability registers. These registers provide high-level information about the transceiver channel's/PLL's configuration.                                                                                                                                                                                         |
| <b>Set user-defined IP identifier</b>                          | User-specified        | Available in Native PHY and TX PLL IP parameter editors. Sets a user-defined numeric identifier that can be read from the <code>user_identifier</code> offset when the capability registers are enabled.                                                                                                                                                                           |
| <b>Enable control and status registers</b>                     | On, Off               | Available in Native PHY and TX PLL IP parameter editors. Enables soft registers for reading status signals and writing control signals on the PHY/PLL interface through the NPDME or reconfiguration interface.                                                                                                                                                                    |
| <b>Enable PRBS soft accumulators</b>                           | On, Off               | Available in Native PHY IP parameter editor only. Enables soft logic to perform PRBS bit and error accumulation when using the hard PRBS generator and checker.                                                                                                                                                                                                                    |

### Related Information

[Embedded Debug Features](#) on page 556

#### 2.6.5.3. Functional Description

The 1G/2.5G/5G/10G Multi-rate PHY Intel FPGA IP core for Intel Arria 10 devices implements the 10M to 10Gbps Ethernet PHY in accordance with the IEEE 802.3 Ethernet Standard. This IP core handles the frame encapsulation and flow of data between a client logic and Ethernet network via a 10M to 10GbE PCS and PMA (PHY). You can use the Native PHY IP core to configure the transceiver PHY for your protocol implementation.

**Figure 80. Architecture of 2.5G, 1G/2.5G, and 1G/2.5G/10G (MGBASE-T) Configuration**



In the transmit direction, the PHY encodes the Ethernet frame as required for reliable transmission over the media to the remote end. In the receive direction, the PHY passes frames to the MAC.

**Note:** You can generate the MAC and PHY design example using the Low Latency Ethernet 10G MAC Intel FPGA IP Parameter Editor.

The IP core includes the following interfaces:

- Datapath client-interface:
  - 10GbE—XGMII, 64 bits
  - 1G/2.5GbE—GMII, 16 bit
  - 10M/100M/1G/2.5G/5G/10G (USXGMII)—XGMII, 32 bits

For 1G/2.5/10G (MGBASE-T), select an interface based on the respective operating speed.
- Management interface—Avalon memory-mapped interface host slave for PHY management.
- Datapath Ethernet interface with the following available options:
  - 10GbE—Single 10.3125 Gbps serial link
  - 2.5GbE—Single 3.125 Gbps serial link
  - 1GbE—Single 1.25 Gbps SGMII serial link
  - 10M/100M/1G/2.5G/5G/10G (USXGMII) —Single 10.3125 Gbps serial link

For 1G/2.5/10G (MGBASE-T), select an Ethernet interface based on the respective operating speed.
- Transceiver PHY dynamic reconfiguration interface—an Avalon memory-mapped interface to read and write the Intel Arria 10 Native PHY IP core registers. This interface supports dynamic reconfiguration of the transceiver. It is used to configure the transceiver operating modes to switch to desired Ethernet operating speeds.

**Figure 81. Architecture of 10M/100M/1G/2.5G/5G/10G (USXGMII) Configuration**



The 10M/100M/1G/2.5G/5G/10G (USXGMII) configuration supports the following features:

- USXGMII—10M/100M/1G/2.5G/5G/10G speeds
- Full duplex data transmission
- USXGMII Auto-Negotiation

#### Related Information

[Low Latency Ethernet 10G MAC Intel Arria 10 FPGA IP Design Example User Guide](#)

##### 2.6.5.3.1. Clocking and Reset Sequence

Clocking Requirements:

- For 64-bit XGMII, the 156.25 MHz clock must have zero ppm difference with reference clock of 10G transceiver PLL. Therefore, the 156.25 MHz clock must be derived from the transceiver 10G reference clock for 1G/2.5G/10G (MGBASE-T) variant.
- For 32-bit XGMII, the 312.5 MHz clock must have zero ppm difference with reference clock of 10G transceiver PLL. Therefore, the 312.5 MHz clock must be derived from the transceiver 10G reference clock for 10M/100M/1G/2.5G/5G/10G (USXGMII) variant.

Reset sequence for all configurations is handled by the transceiver reset controller. For 1G/2.5G and 1G/2.5G/10G (MGBASE-T), transceiver reset sequence is automatically triggered after completion of speed switching/reconfiguration in the MAC+PHY example design.

The 1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP core for Intel Arria 10 devices supports up to  $\pm 100$  ppm clock frequency difference for a maximum packet length of 16,000 bytes.

#### Related Information

[Resetting Transceiver Channels](#) on page 428

##### 2.6.5.3.2. Timing Constraints

Constrain the PHY based on the fastest speed. For example, if you configure the PHY as 1G/2.5G, constrain it based on 2.5G.

**Table 156. Timing Constraints**

| PHY Configuration                 | Constrain PHY for        |
|-----------------------------------|--------------------------|
| 2.5G                              | 2.5G datapath            |
| 1G/2.5G                           | 2.5G datapath            |
| 1G/2.5G/10G (MGBASE-T)            | 10G and 1G/2.5G datapath |
| 10M/100M/1G/2.5G/5G/10G (USXGMII) | 10G datapath             |

When you select MGBASE-T configuration for external PHY with 1G/2.5G/10G operating mode, Intel recommends that you add the following constraints in the timing constraint file to constrain the PHY for the 10G datapath as well as the 1G/2.5G datapath:

**Note:** Prior to editing the timing constraint file, you must define the PHY hierarchy path to `<Installation Directory>/ip/altera/ethernet/alt_mge_phy/example/alt_mge_phy_multi_speed_10g.sdc`.

- Create generated clocks for 1G/2.5G datapath. Since the 1G and 2.5G hard PCS configurations are the same, the constraint is set based on 2.5G datapath. For example:

```

# Create the 1G/2.5G RX clock
set rx_pma_clk_1g2p5g_name      "${ch_phy}rx_pma_clk_1g2p5g"
set clock_node                   "${ch_phy}${native_ls_inst}
$rx_pma_clk_1g2p5g_target"
create_generated_clock -name $rx_pma_clk_1g2p5g_name -source
[get_clock_info -targets refclk_1g2p5g] -divide_by 2 -multiply_by 5
[get_pins $clock_node] -add

set rx_clk_1g2p5g_name          "${ch_phy}rx_clk_1g2p5g"
set clock_source                "${ch_phy}${native_ls_inst}
$rx_pcs_clk_1g2p5g_source"
set clock_node                  "${ch_phy}${native_ls_inst}
$rx_pcs_clk_1g2p5g_target"
create_generated_clock -name $rx_clk_1g2p5g_name -source [get_pins
$clock_source] -master_clock $rx_pma_clk_1g2p5g_name -divide_by 2 -
multiply_by 1 [get_pins $clock_node] -add

set rx_clkout_1g2p5g_name       "${ch_phy}rx_clkout_1g2p5g"
set clock_source                "${ch_phy}${native_ls_inst}
$rx_pld_clk_1g2p5g_source"
set clock_node                  "${ch_phy}${native_ls_inst}
$rx_pld_clk_1g2p5g_target"
create_generated_clock -name $rx_clkout_1g2p5g_name -source [get_pins
$clock_source] -master_clock $rx_pma_clk_1g2p5g_name -divide_by 2 -
multiply_by 1 [get_pins $clock_node] -add

# Create the 1G/2.5G TX clock
set tx_pma_clk_1g2p5g_name     "${ch_phy}tx_pma_clk_1g2p5g"
set clock_node                   "${ch_phy}${native_ls_inst}
$tx_pma_clk_1g2p5g_target"
create_generated_clock -name $tx_pma_clk_1g2p5g_name -source
[get_clock_info -targets $serclk_1g2p5g] -divide_by 5 -multiply_by 1
[get_pins $clock_node] -add

set tx_clk_1g2p5g_name          "${ch_phy}tx_clk_1g2p5g"
set clock_source                "${ch_phy}${native_ls_inst}
$tx_pcs_clk_1g2p5g_source"
set clock_node                  "${ch_phy}${native_ls_inst}
$tx_pcs_clk_1g2p5g_target"
create_generated_clock -name $tx_clk_1g2p5g_name -source [get_pins
$clock_source] -master_clock $tx_pma_clk_1g2p5g_name -divide_by 2 -
multiply_by 1 [get_pins $clock_node] -add

set tx_clkout_1g2p5g_name       "${ch_phy}tx_clkout_1g2p5g"
set clock_source                "${ch_phy}${native_ls_inst}
$tx_pld_clk_1g2p5g_source"
set clock_node                  "${ch_phy}${native_ls_inst}
$tx_pld_clk_1g2p5g_target"
create_generated_clock -name $tx_clkout_1g2p5g_name -source [get_pins
$clock_source] -master_clock $tx_pma_clk_1g2p5g_name -divide_by 2 -
multiply_by 1 [get_pins $clock_node] -add

```

**Note:** The clock node for `rx_clkout_1g2p5g_name` and `tx_clkout_1g2p5g_name` is set to `rx_pld_clk_10g_target` and `tx_pld_clk_10g_target` respectively because the design for this configuration is compiled with respect to the fastest speed, which is 10G. As such, this node connection that has been created by Intel Quartus Prime software is reused to set the timing constraint for 1G/2.5G datapath.

- Create default clock for 10G datapath. The Timing Analyzer does not create these clocks due to the creation of 1G/2.5G clocks in the above constraint. Also, the Timing Analyzer does not create clocks that come from the same master clock.

```

# Create the 10G (default) clocks which were not created by the IPSTA due
to 1G/2.5G clocks just created above
set rx_clkout_10g_name      "${ch_phy}rx_clkout"

```

```

set master_src      "${ch_phy}rx_pma_clk"
set clock_source   "${ch_phy}$native_ls_inst$rx_pld_clk_10g_source"
set clock_node     "${ch_phy}$native_ls_inst$rx_pld_clk_10g_target"
create_generated_clock -name $rx_clkout_10g_name -source [get_pins
$clock_source] -master_clock $master_src [get_pins $clock_node] -add

set tx_clkout_10g_name "${ch_phy}tx_clkout"
set master_src      "${ch_phy}tx_pma_clk"
set clock_source   "${ch_phy}$native_ls_inst$tx_pld_clk_10g_source"
set clock_node     "${ch_phy}$native_ls_inst$tx_pld_clk_10g_target"
create_generated_clock -name $tx_clkout_10g_name -source [get_pins
$clock_source] -master_clock $master_src [get_pins $clock_node] -add

# PMA clock name for setting false path
set rx_pma_clk_10g_name "${ch_phy}rx_pma_clk"
set tx_pma_clk_10g_name "${ch_phy}tx_pma_clk"

```

where 1g2p5g and 10g are referred to the 1G/2.5G and 10G clocks respectively.

- Set false path from 10G clock to 1G/2.5G PHY logic and vice versa. Since the 1G/2.5G PHY logic is not running at 10G clock speed, you do not have to ensure timing closure for 1G/2.5G datapath at 10G clock. For example:

```

set_false_path -from [get_clocks "$rx_pma_clk_10g_name $rx_clkout_10g_name
$tx_pma_clk_10g_name $tx_clkout_10g_name"] -to [get_registers "*|
alt_mge16_pcs_pma:*|* $hssi_8g_pcs_if"]
set_false_path -from [get_registers "*|alt_mge16_pcs_pma:*|*
$hssi_8g_pcs_if"] -to [get_clocks "$rx_pma_clk_10g_name $rx_clkout_10g_name
$tx_pma_clk_10g_name $tx_clkout_10g_name"]

```

where the path indicated by 10g is associated to the 10G clock, whereas the alt\_mge16\_pcs\_pma path indicates the 1G/2.5G PHY logic.

- Since the 10G PHY logic is not running at 1G/2.5G clock, you do not need to ensure timing closure for 10G datapath at the slower clock speed. False path is set from 1G/2.5G clock to 10G PHY logic and vice versa. For example:

```

set_false_path -from [get_clocks "$rx_pma_clk_1g2p5g_name
$rx_clk_1g2p5g_name $rx_clkout_1g2p5g_name $tx_pma_clk_1g2p5g_name
$tx_clk_1g2p5g_name $tx_clkout_1g2p5g_name"] -to [get_registers "*|
alt_mge_phy_xgmii_pcs:*|* $hssi_10g_pcs_if"]
set_false_path -from [get_registers "*|alt_mge_phy_xgmii_pcs:*|*
$hssi_10g_pcs_if"] -to [get_clocks "$rx_pma_clk_1g2p5g_name
$rx_clk_1g2p5g_name $rx_clkout_1g2p5g_name $tx_pma_clk_1g2p5g_name
$tx_clk_1g2p5g_name $tx_clkout_1g2p5g_name"]

```

where the path indicated by 1g2p5g are associated to the 1G/2.5G clocks, whereas the alt\_mge\_phy\_xgmii\_pcs indicates the 10G PHY logic.

### 2.6.5.3.3. Switching Operation Speed

**Table 157. Supported Operating Speed**

| PHY Configurations | Features              | 10M | 100M | 1G | 2.5G                     | 5G | 10G |
|--------------------|-----------------------|-----|------|----|--------------------------|----|-----|
| 2.5G               | Protocol              | —   | —    | —  | 1000BASE-X at 2.5x       | —  | —   |
|                    | Transceiver Data Rate | —   | —    | —  | 3.125 Gbps               | —  | —   |
|                    | MAC Interface         | —   | —    | —  | 16-bit GMII @ 156.25 MHz | —  | —   |

*continued...*

| PHY Configurations                | Features                              | 10M                                 | 100M                               | 1G                                | 2.5G                             | 5G                               | 10G                              |
|-----------------------------------|---------------------------------------|-------------------------------------|------------------------------------|-----------------------------------|----------------------------------|----------------------------------|----------------------------------|
| 1G/2.5G                           | Protocol                              | —                                   | —                                  | 1000BASE-X / SGMII                | 1000BASE-X at 2.5x               | —                                | —                                |
|                                   | Transceiver Data Rate                 | —                                   | —                                  | 1.25 Gbps                         | 3.125 Gbps                       | —                                | —                                |
|                                   | MAC Interface                         | —                                   | —                                  | 16-bit GMII @ 62.5 MHz            | 16-bit GMII @ 156.25 MHz         | —                                | —                                |
| 1G/2.5G/10G (MGBASE-T)            | Protocol                              | —                                   | —                                  | 1000BASE-X / SGMII                | 1000BASE-X at 2.5x               | —                                | 10GBASE-R                        |
|                                   | Transceiver Data Rate                 | —                                   | —                                  | 1.25 Gbps                         | 3.125 Gbps                       | —                                | 10.3125 Gbps                     |
|                                   | MAC Interface                         | —                                   | —                                  | 16-bit GMII @ 62.5 MHz            | 16-bit GMII @ 156.25 MHz         | —                                | 64-bit XGMII @ 156.25 MHz        |
| 10M/100M/1G/2.5G/5G/10G (USXGMII) | Protocol                              | 10GBASE-R<br>1000x data replication | 10GBASE-R<br>100x data replication | 10GBASE-R<br>10x data replication | 10GBASE-R<br>4x data replication | 10GBASE-R<br>2x data replication | 10GBASE-R<br>No data replication |
|                                   | Transceiver Data Rate <sup>(37)</sup> | 10.3125 Gbps                        | 10.3125 Gbps                       | 10.3125 Gbps                      | 10.3125 Gbps                     | 10.3125 Gbps                     | 10.3125 Gbps                     |
|                                   | MAC Interface                         | 32-bit XGMII @ 312.5 MHz            | 32-bit XGMII @ 312.5 MHz           | 32-bit XGMII @ 312.5 MHz          | 32-bit XGMII @ 312.5 MHz         | 32-bit XGMII @ 312.5 MHz         | 32-bit XGMII @ 312.5 MHz         |

You can change the PHY speed using the reconfiguration block in the MAC+PHY example design.

1. Initiates the speed change by writing to the corresponding register of the reconfiguration block.<sup>(38)</sup>
2. The reconfiguration block performs the following steps:
  - a. Sets the `xcvr_mode` signal of the 1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP core to the requested speed.
  - b. Reads the generated `.mif` file for the configuration settings and configures the transceiver accordingly.
  - c. Selects the corresponding transceiver PLL.
  - d. Triggers the transceiver recalibration.
3. The reconfiguration block triggers the PHY reset through the transceiver reset controller.

### Related Information

[Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514

<sup>(37)</sup> With oversampling for lower data rates.

<sup>(38)</sup> You can change the speed within USXGMII (10M/100M/1G/2.5G/5G/10G) through CSR. It doesn't require reconfiguration block.

## 2.6.5.4. Configuration Registers

### 2.6.5.4.1. Register Map

You can access the 16-bit/32-bit configuration registers via the Avalon memory-mapped interface.

**Table 158. Register Map**

| Address Range | Usage            | Bit | Configuration                         |
|---------------|------------------|-----|---------------------------------------|
| 0x00 : 0x1F   | 1000BASE-X/SGMII | 16  | 2.5G, 1G/2.5G, 1G/2.5G/10G (MGBASE-T) |
| 0x400 : 0x41F | USXGMII          | 32  | 10M/100M/1G/2.5G/5G/10G (USXGMII)     |
| 0x461         | Serial Loopback  | 32  | 10M/100M/1G/2.5G/5G/10G (USXGMII)     |

### 2.6.5.4.2. Configuration Registers

You can access the 16-/32-bit configuration registers via the Avalon memory-mapped interface. The 16-bit configuration registers apply only to 2.5G, 1G/2.5G, and 1G/2.5G/10G (MGBASE-T) operating modes, whereas the 32-bit configuration registers apply only to 10M/100M/1G/2.5G/5G/10G (USXGMII) operating mode.

Observe the following guidelines when accessing the registers:

- Do not write to reserved or undefined registers.
- When writing to the registers, perform read-modify-write to ensure that reserved or undefined register bits are not overwritten.

**Table 159. Types of Register Access**

| Access | Definition                                                                                                                                                                     |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RO     | Read only.                                                                                                                                                                     |
| RW     | Read and write.                                                                                                                                                                |
| RWC    | Read, and write and clear. The user application writes 1 to the register bit(s) to invoke a defined instruction. The IP core clears the bit(s) upon executing the instruction. |

**Table 160. PHY Register Definitions**

| Addr | Name    | Description                                                                                                                                                                                                | Access | HW Reset Value |
|------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 0x00 | control | • Bit [15]: RESET. Set this bit to 1 to trigger a soft reset.<br>The PHY clears the bit when the reset is completed. The register values remain intact during the reset.                                   | RWC    | 0              |
|      |         | • Bit[14]: LOOPBACK. Set this bit to 1 to enable loopback on the serial interface.                                                                                                                         |        |                |
|      |         | • Bit [12]: AUTO_NEGOTIATION_ENABLE. Set this bit to 1 to enable auto-negotiation.<br>Auto-negotiation is supported only in 1GbE. Therefore, set this bit to 0 when you switch to a speed other than 1GbE. |        |                |

*continued...*

| Addr      | Name            | Description                                                                                                                                                                                                                                                                                                                                  | Access | HW Reset Value                     |
|-----------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------|
|           |                 | <ul style="list-style-type: none"> <li>Bit [9]: RESTART_AUTO_NEGOTIATION. Set this bit to 1 to restart auto-negotiation. The PHY clears the bit as soon as auto-negotiation is restarted.</li> <li>The rest of the bits are reserved.</li> </ul>                                                                                             | RWC    | 0                                  |
|           |                 | <ul style="list-style-type: none"> <li>The rest of the bits are reserved.</li> </ul>                                                                                                                                                                                                                                                         | —      | —                                  |
| 0x01      | status          | Bit [5]: AUTO_NEGOTIATION_COMPLETE. A value of "1" indicates that the auto-negotiation is completed.                                                                                                                                                                                                                                         | RO     | 0                                  |
|           |                 | Bit [3]: AUTO_NEGOTIATION_ABILITY. A value of "1" indicates that the PCS function supports auto-negotiation.                                                                                                                                                                                                                                 | RO     | 1                                  |
|           |                 | Bit [2]: LINK_STATUS. A value of "0" indicates that the link is lost. Value of 1 indicates that the link is established.                                                                                                                                                                                                                     | RO     | 0                                  |
|           |                 | <ul style="list-style-type: none"> <li>The rest of the bits are reserved.</li> </ul>                                                                                                                                                                                                                                                         | —      | —                                  |
| 0x02:0x03 | phy_identifier  | The value set in the <b>PHY_IDENTIFIER</b> parameter.                                                                                                                                                                                                                                                                                        | RO     | Value of PHY_IDEN TIFIER parameter |
| 0x04      | dev_ability     | Use this register to advertise the device abilities during auto-negotiation.                                                                                                                                                                                                                                                                 | —      | —                                  |
|           |                 | <ul style="list-style-type: none"> <li>Bits [13:12]: RF. Specify the remote fault.                     <ul style="list-style-type: none"> <li>00: No error.</li> <li>01: Link failure.</li> <li>10: Offline.</li> <li>11: Auto-negotiation error.</li> </ul> </li> </ul>                                                                     | RW     | 00                                 |
|           |                 | <ul style="list-style-type: none"> <li>Bits [8:7]: PS. Specify the PAUSE support.                     <ul style="list-style-type: none"> <li>00: No PAUSE.</li> <li>01: Symmetric PAUSE.</li> <li>10: Asymmetric PAUSE towards the link partner.</li> <li>11: Asymmetric and symmetric PAUSE towards the link device.</li> </ul> </li> </ul> | RW     | 11                                 |
|           |                 | <ul style="list-style-type: none"> <li>Bit [5]: FD. Ensure that this bit is always set to 1.</li> </ul>                                                                                                                                                                                                                                      | RW     | 1                                  |
|           |                 | <ul style="list-style-type: none"> <li>The rest of the bits are reserved.</li> </ul>                                                                                                                                                                                                                                                         | —      | —                                  |
|           |                 | The device abilities of the link partner during auto-negotiation.                                                                                                                                                                                                                                                                            | —      | —                                  |
|           |                 | <ul style="list-style-type: none"> <li>Bit [14]: ACK. A value of "1" indicates that the link partner has received three consecutive matching ability values from the device.</li> </ul>                                                                                                                                                      | RO     | 0                                  |
| 0x05      | partner_ability | <ul style="list-style-type: none"> <li>Bits [13:12]: RF. The remote fault.                     <ul style="list-style-type: none"> <li>00: No error.</li> <li>01: Link failure.</li> <li>10: Offline.</li> <li>11: Auto-negotiation error.</li> </ul> </li> </ul>                                                                             | RO     | 0                                  |

continued...

| Addr      | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Access | HW Reset Value             |
|-----------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------|
|           |                   | <ul style="list-style-type: none"> <li>Bits [8:7]: PS. The PAUSE support.           <ul style="list-style-type: none"> <li>— 00: No PAUSE.</li> <li>— 01: Symmetric PAUSE.</li> <li>— 10: Asymmetric PAUSE towards the link partner.</li> <li>— 11: Asymmetric and symmetric PAUSE towards the link device.</li> </ul> </li> <li>Bit [6]: HD. A value of "1" indicates that half-duplex is supported.</li> <li>Bit [5]: FD. A value of "1" indicates that full-duplex is supported.</li> <li>The rest of the bits are reserved.</li> </ul> | RO     | 0                          |
|           |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RO     | 0                          |
|           |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RO     | 0                          |
|           |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | —      | —                          |
| 0x06      | an_expansion      | The PCS capabilities and auto-negotiation status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | —      | —                          |
|           |                   | Bit [1]: PAGE_RECEIVE. A value of "1" indicates that the partner_ability register has been updated. This bit is automatically cleared once it is read.                                                                                                                                                                                                                                                                                                                                                                                     | RO     | 0                          |
|           |                   | Bit [0]: LINK_PARTNER_AUTO_NEGOTIATION_ABLE. A value of "1" indicates that the link partner supports auto-negotiation.                                                                                                                                                                                                                                                                                                                                                                                                                     | RO     | 0                          |
| 0x07      | device_next_page  | The PHY does not support the next page feature. These registers are always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RO     | 0                          |
| 0x08      | partner_next_page |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RO     | 0                          |
| 0x09:0x0F | Reserved          | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | —      | —                          |
| 0x10      | scratch           | Provides a memory location to test read and write operations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | RW     | 0                          |
| 0x11      | rev               | The current version of the PHY IP core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RO     | Current version of the PHY |
| 0x12:0x13 | link_timer        | 21-bit auto-negotiation link timer. <ul style="list-style-type: none"> <li>Offset 0x12: link_timer[15:0]. Bits [8:0] are always be set to 0.</li> <li>Offset 0x13: link_timer[20:16] occupies the lower 5 bits. The remaining 11 bits are reserved and must always be set to 0.</li> </ul>                                                                                                                                                                                                                                                 | RW     | 0                          |
| 0x14:0x1F | Reserved          | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | —      | —                          |
| 0x400     | usxgmii_control   | Control Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | —      | —                          |
|           |                   | Bit [0]: USXGMII_ENA: <ul style="list-style-type: none"> <li>0: 10GBASE-R mode</li> <li>1: USXGMII mode</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                         | RW     | 0x0                        |
|           |                   | Bit [1]: USXGMII_AN_ENA is used when USXGMII_ENA is set to 1: <ul style="list-style-type: none"> <li>0: Disables USXGMII Auto-Negotiation and manually configures the operating speed with the USXGMII_SPEED register.</li> <li>1: Enables USXGMII Auto-Negotiation, and automatically configures operating speed with link partner ability advertised during USXGMII Auto-Negotiation.</li> </ul>                                                                                                                                         | RW     | 0x1                        |

*continued...*

| Addr        | Name                    | Description                                                                                                                                                                                                                                                                            | Access                     | HW Reset Value |
|-------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------------|
|             |                         | Bit [4:2]: USXGMII_SPEED is the operating speed of the PHY in USXGMII mode and USE_USXGMII_AN is set to 0.<br>• 3'b000: 10M<br>• 3'b001: 100M<br>• 3'b010: 1G<br>• 3'b011: 10G<br>• 3'b100: 2.5G<br>• 3'b101: 5G<br>• 3'b110: Reserved<br>• 3'b111: Reserved                           | RW                         | 0x0            |
|             |                         | Bit [8:5]: Reserved                                                                                                                                                                                                                                                                    | —                          | —              |
|             |                         | Bit [9]: RESTART_AUTO_NEGOTIATION<br>Write 1 to restart Auto-Negotiation sequence. The bit is cleared by hardware when Auto-Negotiation is restarted.                                                                                                                                  | RWC (hardw are self-clear) | 0x0            |
|             |                         | Bit [15:10]: Reserved                                                                                                                                                                                                                                                                  | —                          | —              |
|             |                         | Bit [30:16]: Reserved                                                                                                                                                                                                                                                                  | —                          | —              |
| 0x401       | usxgmii_status          | Status Register<br>Bit [1:0]: Reserved<br>Bit [2]: LINK_STATUS indicates link status for USXGMII all speeds<br>• 1: Link is established<br>• 0: Link synchronization is lost, a 0 is latched                                                                                           | RO                         | 0x0            |
| 0x401       | usxgmii_status          | Bit [3]: Reserved                                                                                                                                                                                                                                                                      | —                          | —              |
| 0x401       | usxgmii_status          | Bit [4]: Reserved                                                                                                                                                                                                                                                                      | —                          | —              |
| 0x401       | usxgmii_status          | Bit [5]: AUTO_NEGOTIATION_COMPLETE<br>A value of 1 indicates the Auto-Negotiation process is completed.                                                                                                                                                                                | RO                         | 0x0            |
| 0x401       | usxgmii_status          | Bit [15:6]: Reserved                                                                                                                                                                                                                                                                   | —                          | —              |
| 0x401       | usxgmii_status          | Bit [31:16]: Reserved                                                                                                                                                                                                                                                                  | —                          | —              |
| 0x402:0x404 | Reserved                | —                                                                                                                                                                                                                                                                                      | —                          | —              |
| 0x405       | usxgmii_partner_ability | Device abilities advertised to the link partner during Auto-Negotiation<br>Bit [0]: Reserved<br>Bit [6:1]: Reserved<br>Bit [7]: EEE_CLOCK_STOP_CAPABILITY<br>Indicates whether or not energy efficient ethernet (EEE) clock stop is supported.<br>• 0: Not supported<br>• 1: Supported | —                          | —              |
| 0x405       | usxgmii_partner_ability | Bit [8]: EEE_CAPABILITY<br>Indicates whether or not EEE is supported.<br>• 0: Not supported<br>• 1: Supported                                                                                                                                                                          | RO                         | 0x0            |
| 0x405       | usxgmii_partner_ability |                                                                                                                                                                                                                                                                                        | RO                         | 0x0            |

continued...

| Addr        | Name                | Description                                                                                                                                                                                                                                                                                                                                               | Access                    | HW Reset Value               |
|-------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------------------------|
|             |                     | Bit [11:9]: SPEED<br>• 3'b000: 10M<br>• 3'b001: 100M<br>• 3'b010: 1G<br>• 3'b011: 10G<br>• 3'b100: 2.5G<br>• 3'b101: 5G<br>• 3'b110: Reserved<br>• 3'b111: Reserved                                                                                                                                                                                       | RO                        | 0x0                          |
|             |                     | Bit [12]: DUPLEX<br>Indicates the duplex mode.<br>• 0: Half duplex<br>• 1: Full duplex                                                                                                                                                                                                                                                                    | RO                        | 0x0                          |
|             |                     | Bit [13]: Reserved                                                                                                                                                                                                                                                                                                                                        | —                         | —                            |
|             |                     | Bit [14]: ACKNOWLEDGE<br>A value of 1 indicates that the device has received three consecutive matching ability values from its link partner.                                                                                                                                                                                                             | RO                        | 0x0                          |
|             |                     | Bit [15]: LINK<br>Indicates the link status.<br>• 0: Link down<br>• 1: Link up                                                                                                                                                                                                                                                                            | RO                        | 0x0                          |
|             |                     | Bit [31:16]: Reserved                                                                                                                                                                                                                                                                                                                                     | —                         | —                            |
| 0x406:0x411 | Reserved            | —                                                                                                                                                                                                                                                                                                                                                         | —                         | —                            |
| 0x412       | usxgmii_link_timer  | Auto-Negotiation link timer. Sets the link timer value in bit [19:14] from 0 to 2 ms in approximately 0.05 ms steps. You must program the link timer to ensure that it matches the link timer value of the external NBASE-T PHY IP Core.<br>The reset value sets the link timer to approximately 1.6 ms.<br>Bits [13:0] are reserved and always set to 0. | [19:14]: RW<br>[13:0]: RO | [19:14]: 0x1F<br>[13:0]: 0x0 |
| 0x413:0x41F | Reserved            | —                                                                                                                                                                                                                                                                                                                                                         | —                         | —                            |
| 0x461       | phy_serial_loopback | Configures the transceiver serial loopback in the PMA from TX to RX.<br>Bit [0]<br>• 0: Disables the PHY serial loopback<br>• 1: Enables the PHY serial loopback                                                                                                                                                                                          | RW                        | 0x0                          |
|             |                     | Bit [15:1]: Reserved                                                                                                                                                                                                                                                                                                                                      | —                         | —                            |
|             |                     | Bit [31:16]: Reserved                                                                                                                                                                                                                                                                                                                                     | —                         | —                            |

## 2.6.5.5. Interface Signals

**Figure 82. PHY Interface Signals**



### 2.6.5.5.1. Clock and Reset Signals

**Table 161. Clock and Reset Signals**

| Signal Name          | Direction | Width | Description                                                                                                                                                          |
|----------------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Clock signals</b> |           |       |                                                                                                                                                                      |
| tx_clkout            | Output    | 1     | GMII TX clock, derived from tx_serial_clk[1:0]. Provides 156.25 MHz timing reference for 2.5GbE; 62.5 MHz for 1GbE.                                                  |
| rx_clkout            | Output    | 1     | GMII RX clock, derived from tx_serial_clk[1:0]. Provides 156.25 MHz timing reference for 2.5GbE; 62.5 MHz for 1GbE.                                                  |
| csr_clk              | Input     | 1     | Clock for the control and status Avalon memory-mapped interface. Intel recommends 125 – 156.25 MHz for this clock.                                                   |
| xgmii_tx_coreclk     | Input     | 1     | XGMII TX clock. Provides 156.25 MHz timing reference for 10GbE and 312.5 MHz for 10M/100M/1G/2.5G/5G/10G (USXGMII) mode. Synchronous to tx_serial_clk with zero ppm. |
| xgmii_rx_coreclk     | Input     | 1     | XGMII RX clock. Provides 156.25 MHz timing reference for 10GbE and 312.5 MHz for 10M/100M/1G/2.5G/5G/10G (USXGMII) mode.                                             |

*continued...*

| Signal Name          | Direction | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| latency_measure_clk  | Input     | 1     | Sampling clock for measuring the latency of the 16-bit GMII datapath. This clock operates at 80 MHz and is available only when the IEEE 1588v2 feature is enabled.                                                                                                                                                                                                                                                                              |
| tx_serial_clk        | Input     | 1-3   | Serial clock from transceiver PLLs. <ul style="list-style-type: none"><li>• 2.5GbE: Connect bit [0] to the transceiver PLL. This clock operates at 1562.5 MHz.</li><li>• 1GbE: Connect bit [1] to the transceiver PLL. This clock operates at 625 MHz.</li><li>• 10GbE: Connect bit [2] to the transceiver PLL. This clock operates at 5156.25 MHz.</li><li>• 10M/100M/1G/2.5G/5G/10G (USXGMII) mode: Connect bit [0] to 5156.25 MHz.</li></ul> |
| rx_cdr_refclk        | Input     | 1     | 125 MHz RX CDR reference clock for 1GbE and 2.5GbE                                                                                                                                                                                                                                                                                                                                                                                              |
| rx_cdr_refclk_1      | Input     | 1     | RX CDR reference clock for 10GbE. The frequency of this clock can be either 322.265625 MHz or 644.53125 MHz, as specified by the <b>Reference clock frequency for 10 GbE (MHz)</b> parameter setting.                                                                                                                                                                                                                                           |
| rx_pma_clkout        | Output    | 1     | Recovered clock from CDR, operates at the following frequency:<br>10M/100M/1G/2.5G/5G/10G (USXGMII) speed mode: <ul style="list-style-type: none"><li>• All speeds: 322.265625 MHz</li><li>Other speed modes:<ul style="list-style-type: none"><li>• 1GbE: 125 MHz</li><li>• 2.5GbE: 312.5 MHz</li><li>• 10GbE: 322.265625 MHz</li></ul></li></ul>                                                                                              |
| <b>Reset signals</b> |           |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| reset                | Input     | 1     | Active-high global reset. Assert this signal to trigger an asynchronous global reset.                                                                                                                                                                                                                                                                                                                                                           |
| tx_analogreset       | Input     | 1     | Connect this signal to the Transceiver PHY Reset Controller IP core. When asserted, triggers an asynchronous reset to the analog block on the TX path.                                                                                                                                                                                                                                                                                          |
| tx_digitalreset      | Input     | 1     | Connect this signal to the Transceiver PHY Reset Controller IP core. When asserted, triggers an asynchronous reset to the digital logic on the TX path.                                                                                                                                                                                                                                                                                         |
| rx_analogreset       | Input     | 1     | Connect this signal to the Transceiver PHY Reset Controller IP core. When asserted, triggers an asynchronous reset to the receiver CDR.                                                                                                                                                                                                                                                                                                         |
| rx_digitalreset      | Input     | 1     | Connect this signal to the Transceiver PHY Reset Controller IP core. When asserted, triggers an asynchronous reset to the digital logic on the RX path.                                                                                                                                                                                                                                                                                         |

### 2.6.5.5.2. Operating Mode and Speed Signals

**Table 162. Transceiver Mode and Operating Speed Signals**

| Signal Name     | Direction | Width | Description                                                                                                                                                                                                                                                  |
|-----------------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| xcvr_mode       | Input     | 2     | Connect this signal to the reconfiguration block. Use the values below to set the speed: <ul style="list-style-type: none"><li>• 0x0 = 1G</li><li>• 0x1 = 2.5G</li><li>• 0x3 = 10G</li></ul>                                                                 |
| operating_speed | Output    | 3     | Connect this signal to the MAC. This signal provides the current operating speed of the PHY: <ul style="list-style-type: none"><li>• 0x0 = 10G</li><li>• 0x1 = 1G</li><li>• 0x2 = 100M</li><li>• 0x3 = 10M</li><li>• 0x4 = 2.5G</li><li>• 0x5 = 5G</li></ul> |

### 2.6.5.3. GMII Signals

The 16-bit TX and RX GMII supports 1GbE and 2.5GbE at 62.5 MHz and 156.25 MHz respectively.

**Table 163. GMII Signals**

| Signal Name                                      | Direction | Width | Description                                                                                                                                                                                                                                                                                                                               |
|--------------------------------------------------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TX GMII signals</b> —synchronous to tx_clkout |           |       |                                                                                                                                                                                                                                                                                                                                           |
| gmii16b_tx_d                                     | Input     | 16    | TX data from the MAC. The MAC sends the lower byte first followed by the upper byte.                                                                                                                                                                                                                                                      |
| gmii16b_tx_en                                    | Input     | 2     | When asserted, indicates the start of a new frame from the MAC. Bit[0] corresponds to gmii16b_tx_d[7:0]; bit[1] corresponds to gmii16b_tx_d[15:8]. This signal remains asserted until the PHY receives the last byte of the data frame.                                                                                                   |
| gmii16b_tx_err                                   | Input     | 2     | When asserted, indicates an error. Bit[0] corresponds to gmii16b_tx_err[7:0]; bit[1] corresponds to gmii16b_tx_err[15:8]. The bits can be asserted at any time during a frame transfer to indicate an error in the current frame.                                                                                                         |
| gmii16b_tx_latency                               | Output    | 22    | The latency of the PHY excluding the PMA block on the TX datapath: <ul style="list-style-type: none"><li>• Bits [21:10]: The number of clock cycles.</li><li>• Bits [9:0]: The fractional number of clock cycles.</li></ul> This signal is available when only the <b>Enable IEEE 1588 Precision Time Protocol</b> parameter is selected. |
| <b>RX GMII signals</b> —synchronous to rx_clkout |           |       |                                                                                                                                                                                                                                                                                                                                           |
| gmii16b_rx_d                                     | Output    | 16    | RX data to the MAC. The PHY sends the lower byte first followed by the upper byte. Rate matching is done by the PHY on the RX data from the RX recovered clock to rx_clkout.                                                                                                                                                              |

*continued...*

| Signal Name        | Direction | Width | Description                                                                                                                                                                                                                                                                                                                                  |
|--------------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gmiil6b_rx_err     | Output    | 2     | When asserted, indicates an error. Bit[0] corresponds to gmiil6b_rx_err[7:0]; bit[1] corresponds to gmiil6b_rx_err[15:8].<br>The bits can be asserted at any time during a frame transfer to indicate an error in the current frame.                                                                                                         |
| gmiil6b_rx_dv      | Output    | 2     | When asserted, indicates the start of a new frame. Bit[0] corresponds to gmiil6b_rx_d[7:0]; bit[1] corresponds to gmiil6b_rx_d[15:8].<br>This signal remains asserted until the PHY sends the last byte of the data frame.                                                                                                                   |
| gmiil6b_rx_latency | Output    | 22    | The latency of the PHY excluding the PMA block on the RX datapath: <ul style="list-style-type: none"> <li>• Bits [21:10]: The number of clock cycles.</li> <li>• Bits [9:0]: The fractional number of clock cycles.</li> </ul> This signal is available only when the <b>Enable IEEE 1588 Precision Time Protocol</b> parameter is selected. |

#### 2.6.5.5.4. XGMII Signals

The XGMII supports 10GbE at 156.25 MHz.

**Table 164. XGMII Signals**

| Signal Name                                                | Direction | Width                                 | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------------------------------|-----------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TX XGMII signals</b> —synchronous to xgmii_tx_coreclkin |           |                                       |                                                                                                                                                                                                                                                                                                                                                                                                      |
| xgmii_tx_data                                              | Input     | 64, 32                                | TX data from the MAC. The MAC sends the data in the following order: bits[7:0], bits[15:8], and so forth.<br>The width is: <ul style="list-style-type: none"> <li>• 64 bits for 1G/2.5G/10G configurations.</li> <li>• 32 bits for 10M/100M/1G/2.5G/5G/10G configurations.</li> </ul>                                                                                                                |
| xgmii_tx_control                                           | Input     | 8, 4                                  | TX control from the MAC: <ul style="list-style-type: none"> <li>• xgmii_tx_control[0] corresponds to xgmii_tx_data[7:0]</li> <li>• xgmii_tx_control[1] corresponds to xgmii_tx_data[15:8]</li> <li>• and so forth.</li> </ul> The width is: <ul style="list-style-type: none"> <li>• 8 bits for 1G/2.5G/10G configurations.</li> <li>• 4 bits for 10M/100M/1G/2.5G/5G/10G configurations.</li> </ul> |
| xgmii_tx_valid                                             | Input     | 1                                     | Indicates valid data on xgmii_tx_control and xgmii_tx_data from the MAC.<br>Your logic/MAC must toggle the valid data as shown below:                                                                                                                                                                                                                                                                |
| <b>Speed</b>                                               |           | <b>Toggle Rate</b>                    |                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10M                                                        |           | Asserted once every 1000 clock cycles |                                                                                                                                                                                                                                                                                                                                                                                                      |

*continued...*

| Signal Name                                                | Direction | Width | Description         |                                      |
|------------------------------------------------------------|-----------|-------|---------------------|--------------------------------------|
|                                                            |           |       | Speed               | Toggle Rate                          |
|                                                            |           |       | 100M                | Asserted once every 100 clock cycles |
|                                                            |           |       | 1G                  | Asserted once every 10 clock cycles  |
|                                                            |           |       | 2.5G                | Asserted once every 4 clock cycles   |
|                                                            |           |       | 5G                  | Asserted once every 2 clock cycles   |
|                                                            |           |       | 10G                 | Asserted in every clock cycle        |
| <b>RX XGMII signals</b> —synchronous to xgmii_rx_coreclkin |           |       | <i>continued...</i> |                                      |

| Signal Name      | Direction                           | Width  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |             |     |                                  |      |                                 |    |                                     |      |                                    |    |                                    |     |                               |
|------------------|-------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------|-----|----------------------------------|------|---------------------------------|----|-------------------------------------|------|------------------------------------|----|------------------------------------|-----|-------------------------------|
| xgmii_rx_data    | Output                              | 64, 32 | <p>RX data to the MAC. The PHY sends the data in the following order: bits[7:0], bits[15:8], and so forth. The width is:</p> <ul style="list-style-type: none"> <li>• 64 bits for 1G/2.5G/10G configurations.</li> <li>• 32 bits for 10M/100M/1G/2.5G/5G/10G (USXGMII) configurations.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |             |     |                                  |      |                                 |    |                                     |      |                                    |    |                                    |     |                               |
| xgmii_rx_control | Output                              | 8, 4   | <p>RX control to the MAC.</p> <ul style="list-style-type: none"> <li>• xgmii_rx_control[0] corresponds to xgmii_rx_data[7:0]</li> <li>• xgmii_rx_control[1] corresponds to xgmii_rx_data[15:8]</li> <li>• and so forth.</li> </ul> <p>The width is:</p> <ul style="list-style-type: none"> <li>• 8 bits for 1G/2.5G/10G configurations.</li> <li>• 4 bits for 10M/100M/1G/2.5G/5G/10G (USXGMII) configurations.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |             |     |                                  |      |                                 |    |                                     |      |                                    |    |                                    |     |                               |
| xgmii_rx_valid   | Output                              | 1      | <p>Indicates valid data on xgmii_rx_control and xgmii_rx_data from the MAC.</p> <p>The toggle rate from the PHY is shown in the table below.</p> <p>Note: The toggle rate may vary when the start of a packet is received or when rate match occurs inside the PHY. You should not expect the valid data pattern to be fixed.</p> <table border="1"> <thead> <tr> <th>Speed</th> <th>Toggle Rate</th> </tr> </thead> <tbody> <tr> <td>10M</td> <td>Asserted every 1000 clock cycles</td> </tr> <tr> <td>100M</td> <td>Asserted every 100 clock cycles</td> </tr> <tr> <td>1G</td> <td>Asserted once every 10 clock cycles</td> </tr> <tr> <td>2.5G</td> <td>Asserted once every 4 clock cycles</td> </tr> <tr> <td>5G</td> <td>Asserted once every 2 clock cycles</td> </tr> <tr> <td>10G</td> <td>Asserted in every clock cycle</td> </tr> </tbody> </table> | Speed | Toggle Rate | 10M | Asserted every 1000 clock cycles | 100M | Asserted every 100 clock cycles | 1G | Asserted once every 10 clock cycles | 2.5G | Asserted once every 4 clock cycles | 5G | Asserted once every 2 clock cycles | 10G | Asserted in every clock cycle |
| Speed            | Toggle Rate                         |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |             |     |                                  |      |                                 |    |                                     |      |                                    |    |                                    |     |                               |
| 10M              | Asserted every 1000 clock cycles    |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |             |     |                                  |      |                                 |    |                                     |      |                                    |    |                                    |     |                               |
| 100M             | Asserted every 100 clock cycles     |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |             |     |                                  |      |                                 |    |                                     |      |                                    |    |                                    |     |                               |
| 1G               | Asserted once every 10 clock cycles |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |             |     |                                  |      |                                 |    |                                     |      |                                    |    |                                    |     |                               |
| 2.5G             | Asserted once every 4 clock cycles  |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |             |     |                                  |      |                                 |    |                                     |      |                                    |    |                                    |     |                               |
| 5G               | Asserted once every 2 clock cycles  |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |             |     |                                  |      |                                 |    |                                     |      |                                    |    |                                    |     |                               |
| 10G              | Asserted in every clock cycle       |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |             |     |                                  |      |                                 |    |                                     |      |                                    |    |                                    |     |                               |

### 2.6.5.5. Status Signals

**Table 165. Status Signals**

| Signal Name         | Direction | Clock Domain             | Width | Description                                                             |
|---------------------|-----------|--------------------------|-------|-------------------------------------------------------------------------|
| led_char_err        | Output    | Synchronous to rx_clkout | 1     | Asserted when a 10-bit character error is detected in the RX data.      |
| led_link            | Output    | Synchronous to tx_clkout | 1     | Asserted when the link synchronization for 1GbE or 2.5GbE is successful |
| <i>continued...</i> |           |                          |       |                                                                         |

| Signal Name   | Direction | Clock Domain             | Width | Description                                                                |
|---------------|-----------|--------------------------|-------|----------------------------------------------------------------------------|
| led_disp_err  | Output    | Synchronous to rx_clkout | 1     | Asserted when a 10-bit running disparity error is detected in the RX data. |
| led_an        | Output    | Synchronous to rx_clkout | 1     | Asserted when auto-negotiation is completed.                               |
| rx_block_lock | Output    | Synchronous to rx_clkout | 1     | Asserted when the link synchronization for 10GbE is successful.            |

#### 2.6.5.5.6. Serial Interface Signals

The serial interface connects to an external device.

**Table 166. Serial Interface Signals**

| Signal Name    | Direction | Width | Description |
|----------------|-----------|-------|-------------|
| tx_serial_data | Output    | 1     | TX data.    |
| rx_serial_data | Input     | 1     | RX data.    |

#### 2.6.5.5.7. Transceiver Status and Reconfiguration Signals

**Table 167. Control and Status Signals**

| Signal Name                                                     | Direction | Width | Description                                                                                                                               |
|-----------------------------------------------------------------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------|
| rx_is_lockedtodata                                              | Output    | 1     | Asserted when the CDR is locked to the RX data.                                                                                           |
| tx_cal_busy                                                     | Output    | 1     | Asserted when TX calibration is in progress.                                                                                              |
| rx_cal_busy                                                     | Output    | 1     | Asserted when RX calibration is in progress.                                                                                              |
| <b>Transceiver reconfiguration signals for Arria 10 devices</b> |           |       |                                                                                                                                           |
| reconfig_clk                                                    | Input     | 1     | Reconfiguration signals connected to the reconfiguration block. The reconfig_clk signal provides the timing reference for this interface. |
| reconfig_reset                                                  | Input     | 1     |                                                                                                                                           |
| reconfig_address                                                | Input     | 10    |                                                                                                                                           |
| reconfig_write                                                  | Input     | 1     |                                                                                                                                           |
| reconfig_read                                                   | Input     | 1     |                                                                                                                                           |
| reconfig_writedata                                              | Input     | 32    |                                                                                                                                           |
| reconfig_readdata                                               | Output    | 32    |                                                                                                                                           |
| reconfig_waitrequest                                            | Output    | 1     |                                                                                                                                           |

#### 2.6.5.5.8. Avalon Memory-Mapped Interface Signals

The Avalon memory-mapped interface is an Avalon memory-mapped interface slave port. This interface uses word addressing and provides access to the 16-bit configuration registers of the PHY.

**Table 168. Avalon Memory-Mapped Interface Signals**

| Signal Name     | Direction | Width  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|-----------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| csr_address     | Input     | 5, 11  | Use this bus to specify the register address to read from or write to. The width is: <ul style="list-style-type: none"><li>• 5 bits for 2.5G and 1G/2.5G configurations.</li><li>• 11 bits for 10M/100M/1G/2.5G/5G/10G (USXGMII) configurations.</li></ul>                                                                                                                                                                                                                                                                              |
| csr_read        | Input     | 1      | Assert this signal to request a read operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| csr_readdata    | Output    | 16, 32 | Data read from the specified register. The data is valid only when the csr_waitrequest signal is deasserted. The width is: <ul style="list-style-type: none"><li>• 16 bits for 2.5G and 1G/2.5G configurations.</li><li>• 32 bits for 10M/100M/1G/2.5G/5G/10G (USXGMII) configurations. The upper 16 bits are reserved.</li></ul>                                                                                                                                                                                                       |
| csr_write       | Input     | 1      | Assert this signal to request a write operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| csr_writedata   | Input     | 16, 32 | Data to be written to the specified register. The data is written only when the csr_waitrequest signal is deasserted. The width is: <ul style="list-style-type: none"><li>• 16 bits for 2.5G and 1G/2.5G configurations.</li><li>• 32 bits for 10M/100M/1G/2.5G/5G/10G (USXGMII) configurations. The upper 16 bits are reserved.</li></ul>                                                                                                                                                                                              |
| csr_waitrequest | Output    | 1      | When asserted, indicates that the PHY is busy and not ready to accept any read or write requests. <ul style="list-style-type: none"><li>• When you have requested for a read or write, keep the control signals to the Avalon memory-mapped interface constant while this signal is asserted. The request is complete when it is deasserted.</li><li>• This signal can be high or low during idle cycles and reset. Therefore, the user application must not make any assumption of its assertion state during these periods.</li></ul> |

## 2.6.6. XAUI PHY IP Core

In a XAUI configuration, the transceiver channel data path is configured using a soft PCS. The XAUI configuration provides the transceiver channel datapath, clocking, and channel placement guidelines. You can implement a XAUI link using the IP Catalog.

Under **Ethernet** in the Interfaces menu, select the XAUI PHY IP core. The XAUI PHY IP core implements the XAUI PCS in soft logic.

XAUI is a specific physical layer implementation of the 10 Gigabit Ethernet link defined in the IEEE 802.3ae-2008 specification. The XAUI PHY uses the XGMII interface to connect to the IEEE802.3 MAC and Reconciliation Sublayer (RS). The IEEE 802.3ae-2008 specification requires the XAUI PHY link to support:

- A 10 Gbps data rate at the XGMII interface
- Four lanes each at 3.125 Gbps at the PMD interface

**Figure 83.** XAUI and XGMII Layers


Intel's XAUI PHY IP core implements the IEEE 802.3 Clause 48 specification to extend the operational distance of the XGMII interface and reduce the number of interface signals.

XAUI extends the physical separation possible between the 10 Gbps Ethernet MAC function and the Ethernet standard PHY component to one meter. The XAUI PHY IP core accepts 72-bit data (single data rate—SDR XGMII) from the application layer at 156.25 Mbps. The serial interface runs at  $4 \times 3.125$  Gbps.

**Figure 84.** XAUI PHY IP Core


Intel's third-party IP partner for Dual Data Rate XAUI (DDR XAUI or DXAUI) and Reduced XAUI (RXAUI) support is MorethanIP (MTIP).

XAUUI does not support open compute project (OCP) networking.

### Related Information

- IEEE 802.3 Clause 48
- MorethanIP

#### 2.6.6.1. Transceiver Datapath in a XAUUI Configuration

The XAUUI PHY IP core is partially implemented in soft logic inside the FPGA core. You must ensure that your channel placement is compatible with the soft PCS implementation.

**Figure 85. Transceiver Channel Datapath for XAUUI Configuration**

The XAUUI configuration uses both the soft PCS and the Standard PCS as shown in the following figure.



#### 2.6.6.2. XAUUI Supported Features

##### 64-Bit SDR Interface to the MAC/RS

Clause 46 of the IEEE 802.3-2008 specification defines the XGMII interface between the XAUUI PCS and the Ethernet MAC/RS. Each of the four XAUUI lanes must transfer 8-bit data and a 1-bit control code at both the positive and negative edge (double data rate) of the 156.25 MHz interface clock.

Arria 10 transceivers and a soft PCS solution in a XAUUI configuration do not support the XGMII interface to the MAC/RS as defined in the IEEE 802.3-2008 specification. Instead, they transfer 16-bit data and the 2-bit control code on each of the four XAUUI lanes. The transfer occurs only at the positive edge (single data rate) of the 156.25 MHz interface clock.

**Figure 86. Implementation of the XGMII Specification in Arria 10 Devices Configuration**

The ATX PLL is only supported to drive the internal transceiver. The FPLL is only supported to drive `xgmii_tx_clk` and `xgmii_rx_clk`. Both the ATX PLL and the FPLL must be clocked by the same reference clock to maintain 0 ppm.


**8B/10B Encoding/Decoding**

Each of the four lanes in a XAU1 configuration supports an independent 8B/10B encoder/decoder as specified in Clause 48 of the IEEE802.3-2008 specification. 8B/10B encoding limits the maximum number of consecutive 1s and 0s in the serial data stream to five. This limit ensures DC balance as well as enough transitions for the receiver CDR to maintain a lock to the incoming data.

The XAU1 PHY IP core provides status signals to indicate both running disparity and the 8B/10B code group error.

## Transmitter and Receiver State Machines

In a XAUI configuration, the Arria 10 soft PCS implements the transmitter and receiver state diagrams shown in Figure 48-6 and Figure 48-9 of the IEEE802.3-2008 specification.

The transmitter state machine performs the following functions in conformance with the 10GBASE-X PCS:

- Encoding the XGMII data to PCS code groups
- Converting Idle ||I|| ordered sets into Sync ||K||, Align ||A||, and Skip ||R|| ordered sets

The receiver state machine performs the following functions in conformance with the 10GBASE-X PCS:

- Decoding the PCS code groups to XGMII data
- Converting Sync ||K||, Align ||A||, and Skip ||R|| ordered sets into Idle ||I|| ordered sets

## Synchronization

The word aligner block in the receiver PCS of each of the four XAUI lanes implements the receiver synchronization state diagram shown in Figure 48-7 of the IEEE802.3-2008 specification.

The XAUI PHY IP core provides a status signal per lane to indicate if the word aligner is synchronized to a valid word boundary.

## Deskew

The lane aligner block in the receiver PCS implements the receiver deskew state diagram shown in Figure 48-8 of the IEEE 802.3-2008 specification.

The lane aligner starts the deskew process only after the word aligner block in each of the four XAUI lanes indicates successful synchronization to a valid word boundary.

The XAUI PHY IP core provides a status signal to indicate successful lane deskew in the receiver PCS.

## Clock Compensation

The rate match FIFO in the receiver PCS datapath compensates up to  $\pm 100$  ppm difference between the remote transmitter and the local receiver. It compensates by inserting and deleting Skip ||R|| columns, depending on the ppm difference.

The clock compensation operation begins after:

- The word aligner in all four XAUI lanes indicates successful synchronization to a valid word boundary.
- The lane aligner indicates a successful lane deskew.

The rate match FIFO provides status signals to indicate the insertion and deletion of the Skip ||R|| column for clock rate compensation.

### 2.6.6.3. XAUI PHY Release Information

**Table 169.** XAUI Release Information

| Item         | Description   |
|--------------|---------------|
| Version      | 16.0          |
| Release Date | November 2016 |
| Product ID   | 00D7          |
| Vendor ID    | 6AF7          |

### 2.6.6.4. XAUI PHY Device Family Support

IP cores provide either final or preliminary support for target Intel device families. These terms have the following definitions:

- Final support—Verified with final timing models for this device.
- Preliminary support—Verified with preliminary timing models for this device.

**Table 170.** Device Family Support

| Device Family | Support |
|---------------|---------|
| <b>XAUI</b>   |         |
| Arria 10      | Final   |

## 2.6.6.5. Transceiver Clocking and Channel Placement Guidelines in XAUI Configuration

### Transceiver Clocking

**Figure 87. Transceiver Clocking for XAUI Configuration Without Phase Compensation FIFO Enabled**

The external ATX PLL generates the transmitter serial and parallel clocks for the four XAUI channels. You must instantiate the PLL and connect it to XAUI. The x6 clock line carries the transmitter serial and parallel clocks to the PMA and PCS of each of the four channels.



Note:  
1. Use the ATX PLL as the transmit PLL for XAUI support in Arria 10 devices.

**Note:** When configuring ATX PLL, the PMA width setting must be set to 20-bit per transceiver channel. This ensures that the serial clock is running at 3.125 Gbps while the input reference clock is 156.25 MHz.

**Figure 88. Transceiver Clocking for XAUI Configuration With Phase Compensation FIFO Enabled**

When phase compensation FIFO is enabled, you can connect the core to different clocks on the Avalon-ST interface.



Note:  
1. One recovered clock drives four XAUUI channels.

### 2.6.6.6. XAUI PHY Performance and Resource Utilization

The following table lists the typical expected device resource utilization for different configurations using the current version of the Intel Quartus Prime software targeting an Arria 10 device. The numbers of combinational ALUTs and logic registers are rounded to the nearest 100.

**Table 171. XAUI PHY Performance and Resource Utilization**

| Implementation | Number of 3.125 Gbps Channels | Combinational ALUTs | Dedicated Logic Registers | M20K Memory Blocks |
|----------------|-------------------------------|---------------------|---------------------------|--------------------|
| Soft XAUI      | 4                             | 1700                | 1700                      | 3                  |

### 2.6.6.7. Parameterizing the XAUI PHY

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

Complete the following steps to configure the XAUI PHY IP core in the IP Catalog:

- For **Which device family will you be using?**, select **Arria 10**.
- Click **Installed IP > Library > Interface Protocols > Ethernet > XAUI PHY**.
- Use the tabs on the IP Catalog to select the options required for the protocol.
- Refer to the following topics to learn more about the parameters:
  - General Parameters

- b. Analog Parameters
  - c. Advanced Options Parameters
5. Click **Finish** to generate your customized XAUI PHY IP core.

#### Related Information

- [Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45
- [XAUI PHY General Parameters](#) on page 229
- [Analog Parameter Settings](#) on page 597
- [XAUI PHY Advanced Options Parameters](#) on page 229

#### 2.6.6.7.1. XAUI PHY General Parameters

This section describes the settings available on the **General Options** tab.

**Table 172. General Options**

| Name                             | Value            | Description                                                                          |
|----------------------------------|------------------|--------------------------------------------------------------------------------------|
| <b>Device family</b>             | <b>Arria 10</b>  | The target device family.                                                            |
| <b>XAUI interface type</b>       | <b>Soft XAUI</b> | Implements the PCS in soft logic and the PMA in hard logic. Includes four channels.  |
| <b>Enable Sync-E support</b>     | <b>On / Off</b>  | Shows separate reference clocks for CDR PLL and TX PLL.                              |
| <b>Number of XAUI interfaces</b> | <b>1</b>         | Specifies the number of XAUI interfaces. Only 1 is available in the current release. |

#### 2.6.6.7.2. XAUI PHY Advanced Options Parameters

This section describes the settings available on the **Advanced Options** tab.

**Table 173. Advanced Options**

| Name                                    | Value           | Description                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Include control and status ports</b> | <b>On / Off</b> | If you turn this option on, the top-level IP core includes the status signals and digital resets shown in XAUI Top-Level Signals—Soft PCS and PMA and XAUI Top-Level Signals—Hard IP PCS and PMA. If you turn this option off, you can access control and status information using the Avalon memory-mapped interface to the control and status registers. The default setting is off. |
| <b>Enable dynamic reconfiguration</b>   | <b>On / Off</b> | When you turn this option on, you can connect the dynamic reconfiguration ports to an external reconfiguration module.                                                                                                                                                                                                                                                                 |
| <b>Enable rx_recovered_clk pin</b>      | <b>On / Off</b> | When you turn this option on, the RX recovered clock signal is an output signal.                                                                                                                                                                                                                                                                                                       |
| <b>Enable phase compensation FIFO</b>   | <b>On / Off</b> | Enables the phase compensation FIFO to allow different clocks on the xgmii interface.                                                                                                                                                                                                                                                                                                  |

#### 2.6.6.8. XAUI PHY Ports

The following figure illustrates the top-level signals of the XAUI PHY IP core for the soft IP implementation.

**Figure 89. XAUI Top-Level Signals—Soft PCS and PMA**


### 2.6.6.9. XAUI PHY Interfaces

The XAUI PCS interface to the FPGA fabric uses a SDR XGMII interface. This interface implements a simple version of the Avalon-ST protocol. The interface does not include ready or valid signals. Consequently, the sources always drive data and the sinks must always be ready to receive data.

For more information about the Avalon-ST protocol, including timing diagrams, refer to the *Avalon Interface Specifications*.

Depending on the parameters you choose, the application interface runs at either 156.25 Mbps or 312.5 Mbps. At either frequency, data is only driven on the rising edge of clock. To meet the bandwidth requirements, the datapath is eight bytes wide with eight control bits, instead of the standard four bytes of data and four bits of control. The XAUI PHY IP core treats the datapath as two, 32-bit data buses and includes logic to interleave them, starting with the low-order bytes.

**Figure 90. Interleaved SDR XGMII Data Mapping**


#### Related Information

[Avalon Interface Specifications](#)

### 2.6.6.9.1. SDR XGMII TX Interface

**Table 174.** SDR TX XGMII Interface

| Signal Name       | Direction | Description                                                                                                                                                                                                                                                                                                                                              |
|-------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| xgmii_tx_dc[71:0] | Input     | Contains 4 lanes of data and control for XGMII. Each lane consists of 16 bits of data and 2 bits of control. Synchronous to mgmt_clk. <ul style="list-style-type: none"><li>• Lane 0-[7:0]/[8], [43:36]/[44]</li><li>• Lane 1-[16:9]/[17], [52:45]/[53]</li><li>• Lane 2-[25:18]/[26], [61:54]/[62]</li><li>• Lane 3-[34:27]/[35],[70:63]/[71]</li></ul> |
| xgmii_tx_clk      | Input     | The XGMII SDR TX clock which runs at 156.25 MHz.                                                                                                                                                                                                                                                                                                         |

### 2.6.6.9.2. SDR XGMII RX Interface

**Table 175.** SDR RX XGMII Interface

| Signal Name        | Direction | Description                                                                                                                                                                                                                                                                                                                                              |
|--------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| xgmii_rx_dc_[71:0] | Output    | Contains 4 lanes of data and control for XGMII. Each lane consists of 16 bits of data and 2 bits of control. Synchronous to mgmt_clk. <ul style="list-style-type: none"><li>• Lane 0-[7:0]/[8], [43:36]/[44]</li><li>• Lane 1-[16:9]/[17], [52:45]/[53]</li><li>• Lane 2-[25:18]/[26], [61:54]/[62]</li><li>• Lane 3-[34:27]/[35],[70:63]/[71]</li></ul> |
| xgmii_rx_clk       | Output    | The XGMII SDR RX clock which runs at 156.25 MHz.                                                                                                                                                                                                                                                                                                         |
| xgmii_rx_inclk     | Input     | The XGMII SDR RX input clock which runs at 156.25 MHz. This port is only available when <b>Enable phase compensation FIFO</b> is selected.                                                                                                                                                                                                               |

### 2.6.6.9.3. Transceiver Serial Data Interface

The XAUI transceiver serial data interface has four lanes of serial data for both the TX and RX interfaces. This interface runs at 3.125 Gbps. There is no separate clock signal because it is encoded in the data.

**Table 176.** Serial Data Interface

| Signal Name              | Direction | Description         |
|--------------------------|-----------|---------------------|
| xaui_rx_serial_data[3:0] | Input     | Serial input data.  |
| xaui_tx_serial_data[3:0] | Output    | Serial output data. |

#### 2.6.6.9.4. XAUI PHY Clocks, Reset, and Powerdown Interfaces

**Figure 91.** Clock Inputs and Outputs for IP Core with Soft PCS



**Table 177.** Clock and Reset Signals

| Signal Name              | Direction | Description                                                         |
|--------------------------|-----------|---------------------------------------------------------------------|
| <code>pll_ref_clk</code> | Input     | This is a 156.25 MHz reference clock that is used by the CDR logic. |

#### 2.6.6.9.5. XAUI PHY PMA Channel Controller Interface

**Table 178.** PMA Channel Controller Signals

| Signal Name                        | Direction | Description                                                                                                               |
|------------------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------|
| <code>rx_recovered_clk[3:0]</code> | Output    | This is the RX clock, which is recovered from the received data stream.                                                   |
| <code>rx_ready</code>              | Output    | Indicates PMA RX has exited the reset state and the transceiver can receive data. Synchronous to <code>mgmt_clk</code> .  |
| <code>tx_ready</code>              | Output    | Indicates PMA TX has exited the reset state and the transceiver can transmit data. Synchronous to <code>mgmt_clk</code> . |
| <code>pll_cal_busy_i</code>        | Input     | Indicates the PLL calibration status.                                                                                     |

#### 2.6.6.9.6. XAUI PHY Optional PMA Control and Status Interface

Use the Avalon memory-mapped interface PHY management to read the state of the optional PMA control and status signals available in the XAUI PHY IP core registers. In some cases you may need to know the instantaneous value of a signal to ensure correct functioning of the XAUI PHY. In such cases, you can include the required signal in the top-level module of your XAUI PHY IP core.

**Table 179.** Optional Control and Status Signals—Soft IP Implementation

| Signal Name                    | Direction | Description                                                                                                                                                                                |
|--------------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>rx_channelaligned</code> | Output    | When asserted, indicates that all 4 RX channels are aligned. Synchronous to <code>mgmt_clk</code> . This signal is asserted when the RX lanes are fully aligned and ready to receive data. |
| <code>rx_dispperr[7:0]</code>  | Output    | Received 10-bit code or data group has a disparity error. It is paired with <code>rx_errdetect</code> which is also asserted when a disparity error occurs. The                            |

*continued...*

| Signal Name                     | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 |           | <code>rx_dispperr</code> signal is 2 bits wide per channel for a total of 8 bits per XAUI link. Synchronous to <code>mgmt_clk</code> .                                                                                                                                                                                                                                                                                                             |
| <code>rx_errdetect[7:0]</code>  | Output    | When asserted, indicates an 8B/10B code group violation. It is asserted if the received 10-bit code group has a code violation or disparity error. Use <code>rx_errdetect</code> with the <code>rx_dispperr</code> signal to differentiate between a code violation error, a disparity error, or both. The <code>rx_errdetect</code> signal is 2 bits wide per channel for a total of 8 bits per XAUI link. Synchronous to <code>mgmt_clk</code> . |
| <code>rx_syncstatus[7:0]</code> | Output    | Synchronization indication. RX synchronization is indicated on the <code>rx_syncstatus</code> port of each channel. The <code>rx_syncstatus</code> signal is 2 bits per channel for a total of 8 bits per hard XAUI link. The <code>rx_syncstatus</code> signal is 1 bit per channel for a total of 4 bits per soft XAUI link. Synchronous to <code>mgmt_clk</code> .                                                                              |

#### 2.6.6.10. XAUI PHY Register Interface and Register Descriptions

The Avalon memory-mapped interface PHY management provides access to the XAUI PHY IP core PCS, PMA, and transceiver reconfiguration registers.

**Table 180. Signals in the Avalon Memory-Mapped Interface PHY management**

| Signal Name                           | Direction | Description                                                                                                                                                                                                              |
|---------------------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>phy_mgmt_clk</code>             | Input     | Avalon memory-mapped interface clock input.                                                                                                                                                                              |
| <code>phy_mgmt_clk_reset</code>       | Input     | Global reset signal that resets the entire XAUI PHY. This signal is active high and level sensitive.                                                                                                                     |
| <code>phy_mgmt_addr[8:0]</code>       | Input     | 9-bit Avalon memory-mapped interface address.                                                                                                                                                                            |
| <code>phy_mgmt_writedata[31:0]</code> | Input     | 32-bit input data.                                                                                                                                                                                                       |
| <code>phy_mgmt_readdata[31:0]</code>  | Output    | 32-bit output data.                                                                                                                                                                                                      |
| <code>phy_mgmt_write</code>           | Input     | Write signal. Asserted high.                                                                                                                                                                                             |
| <code>phy_mgmt_read</code>            | Input     | Read signal. Asserted high.                                                                                                                                                                                              |
| <code>phy_mgmt_waitrequest</code>     | Output    | When asserted, indicates that the Avalon memory-mapped interface slave is unable to respond to a read or write request. When asserted, control signals to the Avalon memory-mapped interface slave must remain constant. |

For more information about the Avalon memory-mapped interface, including timing diagrams, refer to the *Avalon Interface Specification*.

The following table specifies the registers that you can access using the Avalon memory-mapped interface PHY management using word addresses and a 32-bit embedded processor. A single address space provides access to all registers.

**Note:** Writing to reserved or undefined register addresses may have undefined side effects.

**Table 181. XAUI PHY IP Core Registers**

| Word Addr                                                 | Bits      | R/W | Register Name          | Description                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------|-----------|-----|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Reset Control Registers—Automatic Reset Controller</b> |           |     |                        |                                                                                                                                                                                                                                                                       |
| 0x041                                                     | [31:0]    | RW  | reset_ch_bitmask       | Bit mask for reset registers at addresses 0x042 and 0x044. The default value is all 1s. You can reset channel <n> when bit<n> = 1.                                                                                                                                    |
| 0x042                                                     | [1:0]     | W   | reset_control(write)   | Writing a 1 to bit 0 initiates a TX digital reset using the reset controller module. The reset affects channels enabled in the reset_ch_bitmask. Writing a 1 to bit 1 initiates a RX digital reset of channels enabled in the reset_ch_bitmask. This bit self-clears. |
|                                                           |           | R   | reset_status(read)     | Reading bit 0 returns the status of the reset controller TX ready bit. Reading bit 1 returns the status of the reset controller RX ready bit. This bit self-clears.                                                                                                   |
| <b>Reset Controls –Manual Mode</b>                        |           |     |                        |                                                                                                                                                                                                                                                                       |
| 0x044                                                     | [31:4,0 ] | RW  | Reserved               | It is safe to write 0s to reserved bits.                                                                                                                                                                                                                              |
|                                                           | [1]       | RW  | reset_tx_digital       | Writing a 1 causes the internal TX digital reset signal to be asserted, resetting all channels enabled in reset_ch_bitmask. You must write a 0 to clear the reset condition.                                                                                          |
|                                                           | [2]       | RW  | reset_rx_analog        | Writing a 1 causes the internal RX analog reset signal to be asserted, resetting the RX analog logic of all channels enabled in reset_ch_bitmask. You must write a 0 to clear the reset condition.                                                                    |
|                                                           | [3]       | RW  | reset_rx_digital       | Writing a 1 causes the RX digital reset signal to be asserted, resetting the RX digital channels enabled in reset_ch_bitmask. You must write a 0 to clear the reset condition.                                                                                        |
| <b>PMA Control and Status Registers</b>                   |           |     |                        |                                                                                                                                                                                                                                                                       |
| 0x061                                                     | [31:0]    | RW  | phy_serial_loopback    | Writing a 1 to channel <n> puts channel <n> in serial loopback mode. For information about pre- or post-CDR serial loopback modes, refer to Loopback Modes.                                                                                                           |
| 0x064                                                     | [31:0]    | RW  | pma_rx_set_locktodata  | When set, programs the RX CDR PLL to lock to the incoming data. Bit <n> corresponds to channel <n>.                                                                                                                                                                   |
| 0x065                                                     | [31:0]    | RW  | pma_rx_set_locktoref   | When set, programs the RX CDR PLL to lock to the reference clock. Bit <n> corresponds to channel <n>.                                                                                                                                                                 |
| 0x066                                                     | [31:0]    | RO  | pma_rx_is_lockedtodata | When asserted, indicates that the RX CDR PLL is locked to the RX data, and that the RX CDR has changed from LTR to LTD mode. Bit <n> corresponds to channel <n>.                                                                                                      |
| 0x067                                                     | [31:0]    | RO  | pma_rx_is_lockedtoref  | When asserted, indicates that the RX CDR PLL is locked to the reference clock. Bit <n> corresponds to channel <n>.                                                                                                                                                    |
| <b>XAUI PCS</b>                                           |           |     |                        |                                                                                                                                                                                                                                                                       |
| 0x084                                                     | [31:16]   | N/A | Reserved               | N/A                                                                                                                                                                                                                                                                   |
|                                                           | [15:8]    | R   | Reserved               | N/A                                                                                                                                                                                                                                                                   |

*continued...*

| Word Addr | Bits    | R/W | Register Name   | Description                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|---------|-----|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | [7:0]   |     | syncstatus[7:0] | Records the synchronization status of the corresponding bit. The RX sync status register has 1 bit per channel for a total of 4 bits per soft XAUI link; soft XAUI uses bits 0–3. Reading the value of the syncstatus register clears the bits.<br><b>From block:</b> Word aligner                                                                                                    |
| 0x085     | [31:16] | N/A | Reserved        | N/A                                                                                                                                                                                                                                                                                                                                                                                   |
|           | [15:8]  | R   | errdetect[7:0]  | When set, indicates that a received 10-bit code group has an 8B/10B code violation or disparity error. Use errdetect with disperr to differentiate between a code violation error, a disparity error, or both. There are 2 bits per RX channel for a total of 8 bits per XAUI link. Reading the value of the errdetect register clears the bits.<br><b>From block:</b> 8B/10B decoder |
|           | [7:0]   |     | disperr[7:0]    | Indicates that the received 10-bit code or data group has a disparity error. When set, the corresponding errdetect bits are also set. There are 2 bits per RX channel for a total of 8 bits per XAUI link. Reading the value of the errdetect register clears the bits.<br><b>From block:</b> 8B/10B decoder                                                                          |
| 0x08a     | [0]     | RW  | simulation_flag | Setting this bit to 1 shortens the duration of reset and loss timer when simulating. Intel recommends that you keep this bit set for simulation.                                                                                                                                                                                                                                      |

#### Related Information

[Avalon Interface Specifications](#)

#### 2.6.6.11. XAUI PHY Timing Analyzer SDC Constraint

Refer to the "Timing Constraints for Bonded PCS and PMA Channels" section for the Synopsis Design Constraints (SDC) for XAUI.

#### Related Information

[Timing Constraints for Bonded PCS and PMA Channels](#) on page 455

#### 2.6.7. Acronyms

This table defines some commonly used Ethernet acronyms.

**Table 182. Ethernet Acronyms**

| Acronym | Definition                                                                   |
|---------|------------------------------------------------------------------------------|
| AN      | Auto-Negotiation in Ethernet as described in Clause 73 of IEEE 802.3ap-2007. |
| BER     | Bit Error Rate.                                                              |
| DME     | Differential Manchester Encoding.                                            |
| FEC     | Forward error correction.                                                    |
| GMII    | Gigabit Media Independent Interface.                                         |
| KR      | Short hand notation for Backplane Ethernet with 64b/66b encoding.            |

*continued...*

| Acronym | Definition                                                                            |
|---------|---------------------------------------------------------------------------------------|
| LD      | Local Device.                                                                         |
| LT      | Link training in backplane Ethernet Clause 72 for 10GBASE-KR and 40GBASE-KR4.         |
| LP      | Link partner, to which the LD is connected.                                           |
| MAC     | Media Access Control.                                                                 |
| MII     | Media independent interface.                                                          |
| OSI     | Open System Interconnection.                                                          |
| PCS     | Physical Coding Sublayer.                                                             |
| PHY     | Physical Layer in OSI 7-layer architecture, also in Intel device scope is: PCS + PMA. |
| PMA     | Physical Medium Attachment.                                                           |
| PMD     | Physical Medium Dependent.                                                            |
| SGMII   | Serial Gigabit Media Independent Interface.                                           |
| WAN     | Wide Area Network.                                                                    |
| XAUI    | 10 Gigabit Attachment Unit Interface.                                                 |

## 2.7. PCI Express (PIPE)

You can use Arria 10 transceivers to implement a complete PCI Express solution for Gen1, Gen2, and Gen3, at data rates of 2.5, 5.0, and 8 Gbps, respectively.

Configure the transceivers for PCIe functionality using one of the following methods:

- **Arria 10 Hard IP for PCIe**

This is a complete PCIe solution that includes the Transaction, Data Link, and PHY/MAC layers. The Hard IP solution contains dedicated hard logic, which connects to the transceiver PHY interface.

*Note:* For more information, refer to the [Arria 10 Avalon-ST Interface for PCIe Solutions User Guide](#).

- **Native PHY IP Core in PIPE Gen1/Gen2/Gen3 Transceiver Configuration Rules**

Use the Native PHY IP (Native PHY IP Core) to configure the transceivers in PCIe mode, giving access to the PIPE interface (commonly called PIPE mode in transceivers). This mode enables you to connect the transceiver to a third-party MAC to create a complete PCIe solution.

The PIPE specification (version 3.0) provides implementation details for a PCIe-compliant physical layer. The Native PHY IP Core for PIPE Gen1, Gen2, and Gen3 supports x1, x2, x4, or x8 operation for a total aggregate bandwidth ranging from 2 to 64 Gbps. In a x1 configuration, the PCS and PMA blocks of each channel are clocked and reset independently. The x2, x4, and x8 configurations support channel bonding for two-lane, four-lane, and eight-lane links. In these bonded channel configurations, the PCS and PMA blocks of all bonded channels share common clock and reset signals.

Gen1 and Gen2 modes use 8B/10B encoding, which has a 20% overhead to overall link bandwidth. Gen3 modes use 128b/130b encoding, which has an overhead of less than 2%. Gen1 and Gen2 modes use the Standard PCS, and Gen3 mode uses the Gen3 PCS for its operation.

**Table 183. Transceiver Solutions**

| Support                               | Arria 10 Hard IP for PCI Express         | Native PHY IP Core for PCI Express (PIPE)                                                                                            |
|---------------------------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Gen1, Gen2, and Gen3 data rates       | Yes                                      | Yes                                                                                                                                  |
| MAC, data link, and transaction layer | Yes                                      | User implementation in FPGA fabric                                                                                                   |
| Transceiver interface                 | Hard IP through PIPE 3.0 based interface | <ul style="list-style-type: none"> <li>PIPE 2.0 for Gen1 and Gen2</li> <li>PIPE 3.0 based for Gen3 with Gen1/Gen2 support</li> </ul> |

**Related Information**

- Intel PHY Interface for the PCI Express (PIPE) Architecture PCI Express
- Arria 10 Hard IP for PCI Express User Guide for the Avalon Streaming Interface

**2.7.1. Transceiver Channel Datapath for PIPE****Figure 92. Transceiver Channel Datapath for PIPE Gen1/Gen2 Configurations**

**Figure 93.** Transceiver Channel Datapath for PIPE Gen1/Gen2/Gen3 Configurations


## 2.7.2. Supported PIPE Features

PIPE Gen1, Gen2, and Gen3 configurations support different features.

**Table 184.** Supported Features for PIPE Configurations

| Protocol Feature                                              | Gen1<br>(2.5 Gbps) | Gen2<br>(5 Gbps) | Gen3<br>(8 Gbps)                            |
|---------------------------------------------------------------|--------------------|------------------|---------------------------------------------|
| x1, x2, x4, x8 link configurations                            | Yes                | Yes              | Yes                                         |
| PCIe-compliant synchronization state machine                  | Yes                | Yes              | Yes                                         |
| ±300 ppm (total 600 ppm) clock rate compensation              | Yes                | Yes              | Yes                                         |
| Transmitter driver electrical idle                            | Yes                | Yes              | Yes                                         |
| Receiver detection                                            | Yes                | Yes              | Yes                                         |
| 8B/10B encoding/decoding disparity control                    | Yes                | Yes              | No                                          |
| 128b/130b encoding/decoding                                   | No                 | No               | Yes (supported through the Gearbox)<br>(39) |
| Scrambling/Descrambling                                       | No                 | No               | Yes<br>(implemented in FPGA fabric)<br>(39) |
| Power state management                                        | Yes                | Yes              | Yes                                         |
| Receiver PIPE status encoding <code>pipe_rxstatus[2:0]</code> | Yes                | Yes              | Yes                                         |
| Dynamic switching between 2.5 Gbps and 5 Gbps signaling rate  | No                 | Yes              | No                                          |

*continued...*

(39) You must enable scrambling/descrambling in Gen1/Gen2 when using Arria 10 PCIe Gen3 configurations.

| Protocol Feature                                                      | Gen1<br>(2.5 Gbps)       | Gen2<br>(5 Gbps)         | Gen3<br>(8 Gbps)         |
|-----------------------------------------------------------------------|--------------------------|--------------------------|--------------------------|
| Dynamic switching between 2.5 Gbps, 5 Gbps, and 8 Gbps signaling rate | No                       | No                       | Yes                      |
| Dynamic transmitter margining for differential output voltage control | No                       | Yes                      | Yes                      |
| Dynamic transmitter buffer de-emphasis of -3.5 dB and -6 dB           | No                       | Yes                      | Yes                      |
| Dynamic Gen3 transceiver pre-emphasis, de-emphasis, and equalization  | No                       | No                       | Yes                      |
| PCS PMA interface width (bits)                                        | 10                       | 10                       | 32                       |
| Receiver Electrical Idle Inference (EII)                              | Implement in FPGA fabric | Implement in FPGA fabric | Implement in FPGA fabric |

### Related Information

- [PCIe Gen3 PCS Architecture](#) on page 507  
For more information about PIPE Gen3.
- [Intel PHY Interface for the PCI Express\\* \(PIPE\) Architecture PCI Express 2.0](#)
- [Intel PHY Interface for the PCI Express \(PIPE\) Architecture PCI Express 3.0](#)

#### 2.7.2.1. Gen1/Gen2 Features

In a PIPE configuration, each channel has a PIPE interface block that transfers data, control, and status signals between the PHY-MAC layer and the transceiver channel PCS and PMA blocks. The PIPE configuration is based on the PIPE 2.0 specification. If you use a PIPE configuration, you must implement the PHY-MAC layer using soft IP in the FPGA fabric.

##### 2.7.2.1.1. Dynamic Switching Between Gen1 (2.5 Gbps) and Gen2 (5 Gbps)

In a PIPE configuration, Native PHY IP Core provides an input signal `pipe_rate [1:0]` that is functionally equivalent to the RATE signal specified in the PCIe specification. A change in value from 2'b00 to 2'b01 on this input signal `pipe_rate [1:0]` initiates a data rate switch from Gen1 to Gen2. A change in value from 2'b01 to 2'b00 on the input signal initiates a data rate switch from Gen2 to Gen1.

##### 2.7.2.1.2. Transmitter Electrical Idle Generation

The PIPE interface block in Arria 10 devices puts the transmitter buffer in an electrical idle state when the electrical idle input signal is asserted. During electrical idle, the transmitter buffer differential and common mode output voltage levels are compliant with the PCIe Base Specification 2.0 for both PCIe Gen1 and Gen2 data rates.

The PCIe specification requires the transmitter driver to be in electrical idle in certain power states.

**Note:** For more information about input signal levels required in different power states, refer to *Power State Management* in the next section.

### 2.7.2.1.3. Power State Management

**Table 185. Power States Defined in the PCIe Specification**

To minimize power consumption, the physical layer device must support the following power states.

| Power States    | Description                                                                             |
|-----------------|-----------------------------------------------------------------------------------------|
| P0              | Normal operating state during which packet data is transferred on the PCIe link.        |
| P0s, P1, and P2 | The PHY-MAC layer directs the physical layer to transition into these low-power states. |

The PIPE interface in Arria 10 transceivers provides a pipe\_powerdown input port for each transceiver channel configured in a PIPE configuration.

The PCIe specification requires the physical layer device to implement power-saving measures when the P0 power state transitions to the low power states. Arria 10 transceivers do not implement these power-saving measures except for putting the transmitter buffer in electrical idle mode in the lower power states.

### 2.7.2.1.4. 8B/10B Encoder Usage for Compliance Pattern Transmission Support

The PCIe transmitter transmits a compliance pattern when the Link Training and Status State Machine (LTSSM) enters the Polling.Compliance substate. The Polling.Compliance substate assesses if the transmitter is electrically compliant with the PCIe voltage and timing specifications.

### 2.7.2.1.5. Receiver Status

The PCIe specification requires the PHY to encode the receiver status on a 3-bit status signal pipe\_rx\_status[2:0]. This status signal is used by the PHY-MAC layer for its operation. The PIPE interface block receives status signals from the transceiver channel PCS and PMA blocks, and encodes the status on the pipe\_rx\_status[2:0] signal to the FPGA fabric. The encoding of the status signals on the pipe\_rx\_status[2:0] signal conforms to the PCIe specification.

### 2.7.2.1.6. Receiver Detection

The PIPE interface block in Arria 10 transceivers provides an input signal pipe\_tx\_detectrx\_loopback for the receiver detect operation. The PCIe protocol requires this signal to be high during the Detect state of the LTSSM. When the pipe\_tx\_detectrx\_loopback signal is asserted in the P1 power state, the PIPE interface block sends a command signal to the transmitter driver in that channel to initiate a receiver detect sequence. In the P1 power state, the transmitter buffer must always be in the electrical idle state. After receiving this command signal, the receiver detect circuitry creates a step voltage at the output of the transmitter buffer. The time constant of the step voltage on the trace increases if an active receiver that complies with the PCIe input impedance requirements is present at the far end. The receiver detect circuitry monitors this time constant to determine if a receiver is present.

**Note:** For the receiver detect circuitry to function reliably, the transceiver on-chip termination must be used. Also, the AC-coupling capacitor on the serial link and the receiver termination values used in your system must be compliant with the PCIe Base Specification 2.0.

The PIPE core provides a 1-bit PHY status signal `pipe_phy_status` and a 3-bit receiver status signal `pipe_rx_status[2:0]` to indicate whether a receiver is detected, as per the PIPE 2.0 specifications.

#### 2.7.2.1.7. Gen1 and Gen2 Clock Compensation

In compliance with the PIPE specification, Arria 10 receiver channels have a rate match FIFO to compensate for small clock frequency differences up to  $\pm 300$  ppm between the upstream transmitter and the local receiver clocks.

Consider the following guidelines for PIPE clock compensation:

- Insert or delete one SKP symbol in an SKP ordered set.
- Minimum limit is imposed on the number of SKP symbols in SKP ordered set after deletion. An ordered set may have an empty COM case after deletion.
- Maximum limit is imposed on the number of the SKP symbols in the SKP ordered set after insertion. An ordered set may have more than five symbols after insertion.
- For INSERT/DELETE cases: The flag status appears on the COM symbol of the SKP ordered set where insertion or deletion occurs.
- For FULL/EMPTY cases: The flag status appears where the character is inserted or deleted.

*Note:* When the PIPE interface is on, it translates the value of the flag to the appropriate `pipe_rx_status` signal.

- The PIPE mode also has a “0 ppm” configuration option that you can use in synchronous systems. The Rate Match FIFO Block is not expected to do any clock compensation in this configuration, but latency is minimized.

**Figure 94. Rate Match Deletion**

This figure shows an example of rate match deletion in the case where two /K28.0/ SKP symbols must be deleted. Only one /K28.0/ SKP symbol is deleted per SKP ordered set received.



### Figure 95. Rate Match Insertion

The figure below shows an example of rate match insertion in the case where two SKP symbols must be inserted. Only one /K28.0/ SKP symbol is inserted per SKP ordered set received.



### Figure 96. Rate Match FIFO Full

The rate match FIFO in PIPE mode automatically deletes the data byte that causes the FIFO to go full and drives `pipe_rx_status[2:0] = 3'b101` synchronous to the subsequent data byte. The figure below shows the rate match FIFO full condition in PIPE mode. The rate match FIFO becomes full after receiving data byte D4.



### Figure 97. Rate Match FIFO Empty

The rate match FIFO automatically inserts /K30.7/ (9'h1FE) after the data byte that causes the FIFO to become empty and drives `pipe_rx_status[2:0] = 3'b110` synchronous to the inserted /K30.7/ (9'h1FE). The figure below shows rate match FIFO empty condition in PIPE mode. The rate match FIFO becomes empty after reading out data byte D3.



### PIPE 0 ppm

The PIPE mode also has a "0 ppm" configuration option that can be used in synchronous systems. The Rate Match FIFO Block is not expected to do any clock compensation in this configuration, but latency is minimized.

#### 2.7.2.1.8. PCIe Reverse Parallel Loopback

PCIe reverse parallel loopback is only available in a PCIe functional configuration for Gen1, Gen2, and Gen3 data rates. The received serial data passes through the receiver CDR, deserializer, word aligner, and rate matching FIFO buffer. The data is then looped back to the transmitter serializer and transmitted out through the transmitter buffer. The received data is also available to the FPGA fabric through the `rx_parallel_data` port. This loopback mode is based on PCIe specification 2.0. Arria 10 devices provide an input signal `pipe_tx_detectrx_loopback` to enable this loopback mode.

**Note:** This is the only loopback option supported in PIPE configurations.

**Figure 98. PCIe Reverse Parallel Loopback Mode Datapath**



#### Related Information

- [Arria 10 Standard PCS Architecture](#) on page 491
- [Intel PHY Interface for the PCI Express\\* \(PIPE\) Architecture](#) [PCI Express 2.0](#)

### 2.7.2.2. Gen3 Features

The following subsections describes the Arria 10 transceiver block support for PIPE Gen3 features.

The PCS supports the PIPE 3.0 base specification. The 32-bit wide PIPE 3.0-based interface controls PHY functions such as transmission of electrical idle, receiver detection, and speed negotiation and control.

#### 2.7.2.2.1. Auto-Speed Negotiation

PIPE Gen3 mode enables ASN between Gen1 (2.5 Gbps), Gen2 (5.0 Gbps), and Gen3 (8.0 Gbps) signaling data rates. The signaling rate switch is accomplished through frequency scaling and configuration of the PMA and PCS blocks using a fixed 32-bit wide PIPE 3.0-based interface.

The PMA switches clocks between Gen1, Gen2, and Gen3 data rates. For a non bonded x1 channel, an ASN module facilitates speed negotiation in that channel. For bonded x2, x4, x8 and x16 channels, the ASN module selects the master channel to control the rate switch. The master channel distributes the speed change request to the other PMA and PCS channels.

The PCIe Gen3 speed negotiation process is initiated when Hard IP or the FPGA fabric requests a rate change. The ASN then places the PCS in reset, and dynamically shuts down the clock paths to disengage the current active state PCS (either Standard PCS or Gen3 PCS). If a switch to or from Gen3 is requested, the ASN automatically selects the correct PCS clock paths and datapath selection in the multiplexers. The ASN block then sends a request to the PMA block to switch the data rate, and waits for a rate change done signal for confirmation. When the PMA completes the rate change and sends confirmation to the ASN block, the ASN enables the clock paths to engage the new PCS block and releases the PCS reset. Assertion of the `pipe_phy_status` signal by the ASN block indicates the successful completion of this process.

**Note:** In Native PHY IP core - PIPE configuration, you must set `pipe_rate[1:0]` to initiate the transceiver datarate switch sequence.

### 2.7.2.2.2. Rate Switch

This section provides an overview of auto rate change between PIPE Gen1 (2.5 Gbps), Gen2 (5.0 Gbps), and Gen3 (8.0 Gbps) modes.

In Arria 10 devices, there is one ASN block common to the Standard PCS and Gen3 PCS, located in the PMA PCS interface that handles all PIPE speed changes. The PIPE interface clock rate is adjusted to match the data throughput when a rate switch is requested.

**Table 186. PIPE Gen3 32 bit PCS Clock Rates**

| PCIe Gen3 Capability Mode Enabled | Gen1     | Gen2    | Gen3    |
|-----------------------------------|----------|---------|---------|
| Lane data rate                    | 2.5 Gbps | 5 Gbps  | 8 Gbps  |
| PCS clock frequency               | 250 MHz  | 500 MHz | 250 MHz |
| FPGA fabric IP clock frequency    | 62.5 MHz | 125 MHz | 250 MHz |
| PIPE interface width              | 32-bit   | 32-bit  | 32-bit  |
| <code>pipe_rate [1:0]</code>      | 2'b00    | 2'b01   | 2'b10   |

**Figure 99. Rate Switch Change**

The block-level diagram below shows a high level connectivity between ASN and Standard PCS and Gen3 PCS.



The sequence of speed change between Gen1, Gen2, and Gen3 occurs as follows:

1. The PHY-MAC layer implemented in FPGA fabric requests a rate change through `pipe_rate[1:0]`.
2. The ASN block waits for the TX FIFO to flush out data. Then the ASN block asserts the PCS reset.
3. The ASN asserts the clock shutdown signal to the Standard PCS and Gen3 PCS to dynamically shut down the clock.
4. When the rate changes to or from the Gen3 speed, the ASN asserts the clock and data multiplexer selection signals.
5. The ASN uses a `pipe_sw[1:0]` output signal to send a rate change request to the PMA.
6. The ASN continuously monitors the `pipe_sw_done[1:0]` input signal from the PMA.
7. After the ASN receives the `pipe_sw_done[1:0]` signal, it deasserts the clock shut down signals to release the clock.
8. The ASN deasserts the PCS reset.
9. The ASN sends the speed change completion to the PHY-MAC interface. This is done through the `pipe_phy_status` signal to PHY-MAC interface.

**Figure 100. Speed Change Sequence**



#### 2.7.2.2.3. Gen3 Transmitter Electrical Idle Generation

In the PIPE 3.0-based interface, you can place the transmitter in electrical idle during low power states. Before the transmitter enters electrical idle, you must send the Electrical Idle ordered set, consisting of 16 symbols with value 0x66. During electrical idle, the transmitter differential and common mode voltage levels are based on the *PCIe Base Specification 3.0*.

#### 2.7.2.2.4. Gen3 Clock Compensation

Enable this mode from the Parameter Editor when using the Gen3 PIPE transceiver configuration rule.

To accommodate PCIe protocol requirements and to compensate for clock frequency differences of up to  $\pm 300$  ppm between source and termination equipment, receiver channels have a rate match FIFO. The rate match FIFO adds or deletes four SKP characters (32 bits) to keep the FIFO from becoming empty or full. If the rate match FIFO is almost full, the FIFO deletes four SKP characters. If the rate match FIFO is nearly empty, the FIFO inserts a SKP character at the start of the next available SKP ordered set. The `pipe_rx_status [2:0]` signal indicates FIFO full, empty, insertion and deletion.

**Note:** Refer to the Gen1 and Gen2 Clock Compensation section for waveforms.

#### Related Information

[Gen1 and Gen2 Clock Compensation](#) on page 241

#### 2.7.2.2.5. Gen3 Power State Management

The PCIe base specification defines low power states for PHY layer devices to minimize power consumption. The Gen3 PCS does not implement these power saving measures, except when placing the transmitter driver in electrical idle in the low power state. In the P2 low power state, the transceivers do not disable the PIPE block clock.

#### Figure 101. P1 to P0 Transition

The figure below shows the transition from P1 to P0 with completion provided by `pipe_phy_status`.



#### 2.7.2.2.6. CDR Control

The CDR control block performs the following functions:

- Controls the PMA CDR to obtain bit and symbol alignment
- Controls the PMA CDR to deskew within the allocated time
- Generates status signals for other PCS blocks

The PCIe base specification requires that the receiver L0s power state exit time be a maximum of 4 ms for Gen1, 2 ms for Gen2, and 4 ms for Gen3 signaling rates. The transceivers have an improved CDR control block to accommodate fast lock times. Fast lock times are necessary for the CDR to relock to the new multiplier/divider settings when entering or exiting Gen3 speeds.

#### 2.7.2.2.7. Gearbox

As per the PIPE 3.0 specification, for every 128 bits that are moved across the Gen3 PCS, the PHY must transmit 130 bits of data. Intel uses the `pipe_tx_data_valid` signal every 16 blocks of data to transmit the built-up backlog of 32 bits of data.

The 130-bit block is received as follows in the 32-bit data path: 34 (32+2-bit sync header), 32, 32, 32. During the first cycle, the gearbox converts the 34-bit input data to 32-bit data. During the next three clock cycles, the gearbox merges bits from adjacent cycles. For the gearbox to work correctly, a gap must be provided in the data for every 16 shifts because each shift contains two extra bits for converting the initial 34 bits to 32 bits in the gearbox. After 16 shifts, the gearbox has an extra 32 bits of data that are transmitted out. This requires a gap in the input data stream, which is achieved by driving `pipe_tx_data_valid` low for one cycle after every 16 blocks of data.

#### Figure 102. Gen3 Data Transmission



### 2.7.3. How to Connect TX PLLs for PIPE Gen1, Gen2, and Gen3 Modes

Figure 103. Use ATX PLL or fPLL for Gen1/Gen2 x1 Mode



Notes:

1. The figure shown is just one possible combination for the PCIe Gen1/Gen2 x1 mode.
2. Gen1/Gen2 x1 mode uses the ATX PLL or fPLL.
3. Gen1/Gen2 x1 can use any channel from the given bank for which the ATX PLL or fPLL is enabled.
4. Use the `pll_pcie_clk` from either the ATX PLL or fPLL. This is the hclk required by the PIPE interface.

**Figure 104. Use ATX PLL or fPLL for Gen1/Gen2 x4 Mode**

**Notes:**

1. The figure shown is just one possible combination for the PCIe Gen1/Gen2 x4 mode.
2. The x6 and xN clock networks are used for channel bonding applications.
3. Each master CGB drives one set of x6 clock lines.
4. Gen1/Gen2 x4 modes use the ATX PLL or fPLL only.
5. Use the `pll_pcie_clk` from either the ATX or fPLL. This is the hclk required by the PIPE interface.
6. In this case the Master PCS channel is logical channel 3 (physical channel 4).

**Figure 105. Use ATX PLL or fPLL for Gen1/Gen2 x8 Mode**



## Notes:

- Notes:

  1. Figure shown is just one possible combination for the PCIe Gen1/Gen2 x8 mode.
  2. The x6 and xN clock networks are used for channel bonding applications.
  3. Each master CGB drives one set of x6 clock lines. The x6 lines further drive the xN lines.
  4. Gen1/Gen2 x8 mode uses the ATX PLL or FPLL only.
  5. Use the `pll_pcie_clk` from either the ATX or FPLL. This is the hclk required by the PIPE interface.
  6. In this case the Master PCS channel is logical channel 4 (Ch 1 in the top bank).

**Figure 106. Use ATX PLL or fPLL for Gen1/Gen2/Gen3 x1 Mode**

**Notes:**

1. The figure shown is just one possible combination for the PCIe Gen1/Gen2/Gen3 x1 mode.
2. Gen1/Gen2 modes use the fPLL only.
3. Gen3 mode uses the ATX PLL only.
4. Use the `pll_pcie_clk` from the fPLL, configured as Gen1/Gen2. This is the hclk required by the PIPE interface.
5. Select the number of TX PLLs (2) in the Native PHY IP core wizard.

**Figure 107. Use ATX PLL or fPLL for Gen1/Gen2/Gen3 x4 Mode**



**Notes:**

1. The figure shown is just one possible combination for the PCIe Gen1/Gen2/Gen3 x4 mode.
2. The x6 and xN clock networks are used for channel bonding applications.
3. Each master CGB drives one set of x6 clock lines.
4. Gen1/Gen2 modes use the fPLL only.
5. Gen3 mode uses the ATX PLL only.
6. Use the `pll_pcie_clk` from the fPLL, configured as Gen1/Gen2. This is the hlk required by the PIPE interface.

**Figure 108. Use ATX PLL or fPLL for Gen1/Gen2/Gen3 x8 Mode**

**Notes:**

1. The figure shown is just one possible combination for the PCIe Gen1/Gen2/Gen3 x8 mode.
2. The x6 and xN clock networks are used for channel bonding applications.
3. Each master CGB drives one set of x6 clock lines. The x6 lines further drive the xN lines.
4. Gen1/Gen2 x8 modes use the fPLL only.
5. Gen3 mode uses the ATX PLL only.
6. Use the `pll_pcie_clk` from the fPLL, configured as Gen1/Gen2. This is the hclk required by the PIPE interface.

### Related Information

- [Using PLLs and Clock Networks](#) on page 410  
For more information about implementing clock configurations and configuring PLLs.
- [PIPE Design Example](#)  
For more information about the PLL configuration for PCIe.
- [Transmit PLL recommendation based on Data rates](#) on page 358  
For more information about ATX PLL placement restrictions

## 2.7.4. How to Implement PCI Express (PIPE) in Arria 10 Transceivers

You must be familiar with the Standard PCS architecture, Gen3 PCS architecture, PLL architecture, and the reset controller before implementing the PCI Express protocol.

1. Go to the IP Catalog and select the **Arria 10 Transceiver Native PHY IP Core**. Refer to [Select and Instantiate the PHY IP Core](#) on page 33 for more details.
2. Select **Gen1/Gen2/Gen3 PIPE** from the **Arria 10 Transceiver configuration rules** list, located under **Datapath Options**.
3. Use the parameter values in the tables in [Transceiver Native PHY IP Parameters for PCI Express Transceiver Configurations Rules](#) as a starting point. Alternatively, you can use **Arria 10 Transceiver Native PHY Presets**. You can then modify the settings to meet your specific requirements.
4. Click **Finish** to generate the Native PHY IP (this is your RTL file).
5. Instantiate and configure your PLL.
6. Create a transceiver reset controller. You can use your own reset controller or use the Transceiver PHY Reset Controller.
7. Connect the Native PHY IP to the PLL IP core and the reset controller. Use the information in [Transceiver Native PHY IP Ports for PCI Express Transceiver Configuration Rules](#) to connect the ports.
8. Simulate your design to verify its functionality.

**Figure 109. Connection Guidelines for a PIPE Gen3 Design**

**Notes:**

- (1). If you enable the input `pll_cal_busy` port in the Transceiver PHY Reset Controller, you can connect the `pll_cal_busy` output signals from the PLLs directly to the input port on the reset-controller without ORing the `tx_cal_busy` and `pll_cal_busy` signals.
- (2).
  - a. If you are using the Transceiver PHY Reset Controller, you must configure the TX digital reset mode and RX digital reset mode to Manual to avoid resetting the Auto Speed Negotiation (ASN) block which handles the rate switch whenever the channel PCS is reset.
  - b. When the TX digitalreset is in Auto mode, the associated `tx_digitalreset` controller automatically resets whenever the `pll_locked` signal is deasserted. When in Manual mode, the associated `tx_digitalreset` controller is not reset when the `pll_locked` signal is deasserted, allowing the user to choose what to do.
  - c. When the RX digitalreset is in Auto mode, the associated `rx_digitalreset` controller automatically resets whenever the `rx_is_lockedtodata` signal is deasserted. When in Manual mode, the associated `rx_digitalreset` controller is not reset when the `rx_is_lockedtodata` signal is deasserted, allowing the user to choose what to do.
  - d. If the resets are configured to Auto mode for PIPE designs, then the digital reset will get asserted automatically when the lock signal is deasserted.

### Recommendations:

Intel recommends that you not reset the PLL and channels (TX and RX) when using the PIPE mode of Native PHY. This is to avoid resetting the Auto Speed Negotiation (ASN) block in the PCS.

### Related Information

- [PLLs](#) on page 358  
For information about PLL architecture and implementation details.
- [Arria 10 Standard PCS Architecture](#) on page 491
- [Resetting Transceiver Channels](#) on page 428  
For information about the Reset controller and implementation details.

## 2.7.5. Native PHY IP Parameter Settings for PIPE

**Table 187. Parameters for Arria 10 Native PHY IP in PIPE Gen1, Gen2, Gen3 Modes**

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

|                                                          | Gen1 PIPE                                                                               | Gen2 PIPE                                                                               | Gen3 PIPE                                                                               |
|----------------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| <b>Parameter</b>                                         |                                                                                         |                                                                                         |                                                                                         |
| Message level for rule violations                        | Error                                                                                   | Error                                                                                   | Error                                                                                   |
| <b>Common PMA Options</b>                                |                                                                                         |                                                                                         |                                                                                         |
| VCCR_GXB and VCCT_GXB supply voltage for the Transceiver | Gen1: 1_1V, 1_0V, 0_9V                                                                  | Gen2: 1_1V, 1_0V, 0_9V                                                                  | Gen3: 1_1V, 1_0V, 0_9V                                                                  |
| Transceiver link type                                    | Gen1: sr,lr                                                                             | Gen2: sr,lr                                                                             | Gen3: sr,lr                                                                             |
| <b>Datapath Options</b>                                  |                                                                                         |                                                                                         |                                                                                         |
| Transceiver configuration rules                          | Gen1 PIPE                                                                               | Gen2 PIPE                                                                               | Gen3 PIPE                                                                               |
| PMA configuration rules                                  | Basic                                                                                   | Basic                                                                                   | Basic                                                                                   |
| Transceiver mode                                         | TX / RX Duplex                                                                          | TX / RX Duplex                                                                          | TX / RX Duplex                                                                          |
| Number of data channels                                  | Gen1 x1: 1 channel<br>Gen1 x2: 2 channels<br>Gen1 x4: 4 channels<br>Gen1 x8: 8 channels | Gen2 x1: 1 channel<br>Gen2 x2: 2 channels<br>Gen2 x4: 4 channels<br>Gen2 x8: 8 channels | Gen3 x1: 1 channel<br>Gen3 x2: 2 channels<br>Gen3 x4: 4 channels<br>Gen3 x8: 8 channels |
| Data rate                                                | 2.5 Gbps                                                                                | 5 Gbps                                                                                  | 5 Gbps <sup>(40)</sup>                                                                  |
| Enable datapath and interface reconfiguration            | Optional                                                                                | Optional                                                                                | Optional                                                                                |
| Enable simplified data interface                         | Optional <sup>(41)</sup>                                                                | Optional <sup>(41)</sup>                                                                | Optional <sup>(41)</sup>                                                                |
| Provide separate interface for each channel              | Optional                                                                                | Optional                                                                                | Optional                                                                                |

<sup>(40)</sup> The PIPE is configured in Gen1/Gen2 during Power Up. Gen3 PCS is configured for 8 Gbps.

<sup>(41)</sup> Refer to [Table 194](#) on page 270 for bit settings when simplified data interface is enabled.

**Table 188. Parameters for Arria 10 Native PHY IP in PIPE Gen1, Gen2, Gen3 Modes - TX PMA**

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

|                                           | <b>Gen1 PIPE</b>                                     | <b>Gen2 PIPE</b>                                     | <b>Gen3 PIPE</b>                                                                                              |
|-------------------------------------------|------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| <b>TX Bonding Options</b>                 |                                                      |                                                      |                                                                                                               |
| TX channel bonding mode                   | Nonbonded (x1)<br>PMA & PCS Bonding                  | Nonbonded (x1)<br>PMA & PCS Bonding                  | Nonbonded (x1)<br>PMA & PCS Bonding                                                                           |
| PCS TX channel bonding master             | Auto <sup>(42)</sup>                                 | Auto <sup>(42)</sup>                                 | Auto <sup>(42)</sup>                                                                                          |
| Default PCS TX channel bonding master     | Gen1 x1: 0<br>Gen1 x2: 1<br>Gen1 x4: 2<br>Gen1 x8: 4 | Gen1 x1: 0<br>Gen1 x2: 1<br>Gen1 x4: 2<br>Gen1 x8: 4 | Gen1 x1: 0<br>Gen1 x2: 1<br>Gen1 x4: 2<br>Gen1 x8: 4                                                          |
| <b>TX PLL Options</b>                     |                                                      |                                                      |                                                                                                               |
| TX local clock division factor            | 1                                                    | 1                                                    | 1                                                                                                             |
| Number of TX PLL clock inputs per channel | 1                                                    | 1                                                    | Gen3 x1: 2<br>All other modes: 1                                                                              |
| Initial TX PLL clock input selection      | 0                                                    | 0                                                    | Gen1 / Gen2 clock connection should be used for Initial clock input selection in Gen3x1<br>All other modes: 0 |
| <b>TX PMA Optional Ports</b>              |                                                      |                                                      |                                                                                                               |
| Enable tx_analog_reset_ack port           | Optional                                             | Optional                                             | Optional                                                                                                      |
| Enable tx_pma_clkout port                 | Optional                                             | Optional                                             | Optional                                                                                                      |
| Enable tx_pma_div_clkout port             | Optional                                             | Optional                                             | Optional                                                                                                      |
| tx_pma_div_clkout division factor         | Optional                                             | Optional                                             | Optional                                                                                                      |
| Enable tx_pma_elecidle port               | Off                                                  | Off                                                  | Off                                                                                                           |
| Enable tx_pma_qpipullup port (QPI)        | Off                                                  | Off                                                  | Off                                                                                                           |
| Enable tx_pma_qpipulldn port (QPI)        | Off                                                  | Off                                                  | Off                                                                                                           |
| Enable tx_pma_txdetectrx port (QPI)       | Off                                                  | Off                                                  | Off                                                                                                           |
| Enable tx_pma_rxfound port (QPI)          | Off                                                  | Off                                                  | Off                                                                                                           |
| Enable rx_serialppbken port               | Off                                                  | Off                                                  | Off                                                                                                           |

(42) Setting this parameter is placement-dependent. In AUTO mode, the Native PHY IP Parameter Editor selects the middle-most channel of the configuration as the default PCS TX channel bonding master. You must ensure that this selected channel is physically placed as Ch1 or Ch4 of the transceiver bank. Else, use the manual selection for the PCS TX channel bonding master to select a channel that can be physically placed as Ch1 or Ch4 of the transceiver bank. Refer to section How to place channels for PIPE configurations for more details.

**Table 189. Parameters for Arria 10 Native PHY IP in PIPE Gen1, Gen2, Gen3 Modes - RX PMA**

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

|                                                                                            | Gen1 PIPE          | Gen2 PIPE          | Gen3 PIPE          |
|--------------------------------------------------------------------------------------------|--------------------|--------------------|--------------------|
| <b>RX CDR Options</b>                                                                      |                    |                    |                    |
| Number of CDR reference clocks                                                             | 1                  | 1                  | 1                  |
| Selected CDR reference clock                                                               | 0                  | 0                  | 0                  |
| Selected CDR reference clock frequency                                                     | 100, 125 MHz       | 100, 125 MHz       | 100, 125 MHz       |
| PPM detector threshold                                                                     | 1000               | 1000               | 1000               |
| <b>Equalization</b>                                                                        |                    |                    |                    |
| CTLE adaptation mode<br><i>Note:</i> Triggered adaptation mode is used only for PCIe Gen3. | Manual / Triggered | Manual / Triggered | Manual / Triggered |
| DFE adaptation mode                                                                        | Disabled           | Disabled           | Disabled           |
| Number of fixed dfe taps                                                                   | NA                 | NA                 | NA                 |
| <b>RX PMA Optional Ports</b>                                                               |                    |                    |                    |
| Enable rx_analog_reset_ack port                                                            | Optional           | Optional           | Optional           |
| Enable rx_pma_clkout port                                                                  | Optional           | Optional           | Optional           |
| Enable rx_pma_div_clkout port                                                              | Optional           | Optional           | Optional           |
| rx_pma_div_clkout division factor                                                          | Optional           | Optional           | Optional           |
| Enable rx_pma_clkslip port                                                                 | Optional           | Optional           | Optional           |
| Enable rx_pma_qpipulldn port (QPI)                                                         | Off                | Off                | Off                |
| Enable rx_is_lockedtodata port                                                             | Optional           | Optional           | Optional           |
| Enable rx_is_lockedtoref port                                                              | Optional           | Optional           | Optional           |
| Enable rx_set_locktodata and rx_set_locktoref ports                                        | Optional           | Optional           | Optional           |
| Enable rx_serialpbken port                                                                 | Optional           | Optional           | Optional           |
| Enable PRBS Verifier Control and Status ports                                              | Optional           | Optional           | Optional           |

**Table 190. Parameters for Arria 10 Native PHY IP in PIPE Gen1, Gen2, Gen3 Modes - Standard PCS**

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

| Parameter                          | Gen1 PIPE | Gen2 PIPE | Gen3 PIPE   |
|------------------------------------|-----------|-----------|-------------|
| <b>Standard PCS configurations</b> |           |           |             |
| Standard PCS / PMA interface width | 10        | 10        | $10^{(43)}$ |
| <i>continued...</i>                |           |           |             |

(43) The PIPE is configured in Gen1/Gen2 during Power Up. Gen3 PCS is configured for PCS/PMA width of 32.

| Parameter                                       | Gen1 PIPE                      | Gen2 PIPE                      | Gen3 PIPE                      |
|-------------------------------------------------|--------------------------------|--------------------------------|--------------------------------|
| FPGA Fabric / Standard TX PCS interface width   | 8, 16                          | 16                             | 32                             |
| FPGA Fabric / Standard RX PCS interface width   | 8, 16                          | 16                             | 32                             |
| Enable Standard PCS low latency mode            | Off                            | Off                            | Off                            |
| <b>Standard PCS FIFO</b>                        |                                |                                |                                |
| TX FIFO mode                                    | low_latency                    | low_latency                    | low_latency                    |
| RX FIFO mode                                    | low_latency                    | low_latency                    | low_latency                    |
| Enable tx_std_pcfifo_full port                  | Optional                       | Optional                       | Optional                       |
| Enable tx_std_pcfifo_empty port                 | Optional                       | Optional                       | Optional                       |
| Enable rx_std_pcfifo_full port                  | Optional                       | Optional                       | Optional                       |
| Enable rx_std_pcfifo_empty port                 | Optional                       | Optional                       | Optional                       |
| <b>Byte Serializer and Deserializer</b>         |                                |                                |                                |
| TX byte serializer mode                         | Disabled, Serialize x2         | Serialize x2                   | Serialize x4                   |
| RX byte deserializer mode                       | Disabled, Serialize x2         | Serialize x2                   | Deserialize x4                 |
| <b>8B/10B Encoder and Decoder</b>               |                                |                                |                                |
| Enable TX 8B/10B encoder                        | Enabled                        | Enabled                        | Enabled                        |
| Enable TX 8B/10B disparity control              | Enabled                        | Enabled                        | Enabled                        |
| Enable RX 8B/10B decoder                        | Enabled                        | Enabled                        | Enabled                        |
| <b>Rate Match FIFO</b>                          |                                |                                |                                |
| Rate Match FIFO mode                            | PIPE, PIPE 0ppm                | PIPE, PIPE Oppm                | PIPE, PIPE Oppm                |
| RX rate match insert / delete -ve pattern (hex) | 0x0002f17c (K28.5/ K28.0/)     | 0x0002f17c (K28.5/ K28.0/)     | 0x0002f17c (K28.5/ K28.0/)     |
| RX rate match insert / delete +ve pattern (hex) | 0x000d0e83 (K28.5/ K28.0/)     | 0x000d0e83 (K28.5/ K28.0/)     | 0x000d0e83 (K28.5/ K28.0/)     |
| Enable rx_std_rmfifo_full port                  | Optional                       | Optional                       | Optional                       |
| Enable rx_std_rmfifo_empty port                 | Optional                       | Optional                       | Optional                       |
| PCI Express Gen 3 rate match FIFO mode          | Bypass                         | Bypass                         | 600                            |
| <b>Word Aligner and Bit Slip</b>                |                                |                                |                                |
| Enable TX bit slip                              | Off                            | Off                            | Off                            |
| Enable tx_std_bitslipboundarysel port           | Optional                       | Optional                       | Optional                       |
| RX word aligner mode                            | Synchronous State Machine      | Synchronous State Machine      | Synchronous State Machine      |
| RX word aligner pattern length                  | 10                             | 10                             | 10                             |
| RX word aligner pattern (hex)                   | 0x0000 00000000017c (/ K28.5/) | 0x0000 00000000017c (/ K28.5/) | 0x0000 00000000017c (/ K28.5/) |

continued...

| Parameter                                            | Gen1 PIPE | Gen2 PIPE | Gen3 PIPE |
|------------------------------------------------------|-----------|-----------|-----------|
| Number of word alignment patterns to achieve sync    | 3         | 3         | 3         |
| Number of invalid data words to lose sync            | 16        | 16        | 16        |
| Number of valid data words to decrement error count  | 15        | 15        | 15        |
| Enable rx_std_wa_patternalign port                   | Optional  | Optional  | Optional  |
| Enable rx_std_wa_ala2size port                       | Off       | Off       | Off       |
| Enable rx_std_bitslipboundarysel port                | Optional  | Optional  | Optional  |
| Enable rx_bitslip port                               | Off       | Off       | Off       |
| <b>Bit Reversal and Polarity Inversion</b>           |           |           |           |
| Enable TX bit reversal                               | Off       | Off       | Off       |
| Enable TX byte reversal                              | Off       | Off       | Off       |
| Enable TX polarity inversion                         | Off       | Off       | Off       |
| Enable tx_polinv port                                | Off       | Off       | Off       |
| Enable RX bit reversal                               | Off       | Off       | Off       |
| Enable rx_std_bitrev_ena port                        | Off       | Off       | Off       |
| Enable RX byte reversal                              | Off       | Off       | Off       |
| Enable rx_std_byterev_ena port                       | Off       | Off       | Off       |
| Enable RX polarity inversion                         | Off       | Off       | Off       |
| Enable rx_polinv port                                | Off       | Off       | Off       |
| Enable rx_std_signaldetect port                      | Optional  | Optional  | Optional  |
| <b>PCIe Ports</b>                                    |           |           |           |
| Enable PCIe dynamic datarate switch ports            | Off       | Enabled   | Enabled   |
| Enable PCIe pipe_hclk_in and pipe_hclk_out ports     | Enabled   | Enabled   | Enabled   |
| Enable PCIe Gen3 analog control ports                | Off       | Off       | Enabled   |
| Enable PCIe electrical idle control and status ports | Enabled   | Enabled   | Enabled   |
| Enable PCIe pipe_rx_polarity port                    | Enabled   | Enabled   | Enabled   |
| <b>Dynamic reconfiguration</b>                       |           |           |           |
| Enable dynamic reconfiguration                       | Disabled  | Disabled  | Disabled  |

**Note:** The signals in the left-most column are automatically mapped to a subset of a 128-bit tx\_parallel\_data word when the Simplified Interface is enabled.

### Related Information

- [How to Place Channels for PIPE Configurations](#) on page 275
- [Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45

- Bit Mappings When the Simplified Interface Is Disabled on page 270

## 2.7.6. fPLL IP Parameter Core Settings for PIPE

**Table 191. Parameter Settings for Arria 10 fPLL IP core in PIPE Gen1, Gen2, Gen3 modes**

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

| Parameter                                            | Gen1 PIPE                               | Gen2 PIPE                               | Gen3 PIPE (For Gen1/<br>Gen2 speeds)     |
|------------------------------------------------------|-----------------------------------------|-----------------------------------------|------------------------------------------|
| <b>PLL</b>                                           |                                         |                                         |                                          |
| <b>General</b>                                       |                                         |                                         |                                          |
| fPLL mode                                            | Transceiver                             | Transceiver                             | Transceiver                              |
| Protocol Mode                                        | PCIe Gen 1                              | PCIe Gen 2                              | PCIe Gen 2                               |
| Message level for rule violation                     | Error                                   | Error                                   | Error                                    |
| Number of PLL reference clocks                       | 1                                       | 1                                       | 1                                        |
| Selected reference clock source                      | 0                                       | 0                                       | 0                                        |
| Enable fractional mode                               | Disable                                 | Disable                                 | Disable                                  |
| Enable manual counter configuration                  | Disable                                 | Disable                                 | Disable                                  |
| Enable ATX to fPLL cascade clock input port          | Disable                                 | Disable                                 | Disable                                  |
| <b>Settings</b>                                      |                                         |                                         |                                          |
| Bandwidth                                            | Low, Medium, High                       | Low, Medium, High                       | Low, Medium, High                        |
| <b>Feedback</b>                                      |                                         |                                         |                                          |
| Operation mode                                       | Direct                                  | Direct                                  | Direct                                   |
| <b>Output frequency</b>                              |                                         |                                         |                                          |
| <b>Transceiver usage</b>                             |                                         |                                         |                                          |
| PLL output frequency                                 | 2500MHz                                 | 2500MHz                                 | 2500MHz                                  |
| PLL datarate                                         | 2500Mbps                                | 5000Mbps                                | 5000Mbps                                 |
| PLL integer reference clock frequency                | 100 MHz, 125 MHZ                        | 100 MHz, 125 MHZ                        | 100 MHz, 125 MHZ                         |
| <b>Master Clock Generation Block (MCGB)</b>          |                                         |                                         |                                          |
| Include master clock generation block                | Disable for x1<br>Enable for x2, x4, x8 | Disable for x1<br>Enable for x2, x4, x8 | Disable for x1<br>Disable for x2, x4, x8 |
| Clock division factor                                | N/A for x1<br>1 for x2, x4, x8          | N/A for x1<br>1 for x2, x4, x8          | N/A for x1<br>N/A for x2, x4, x8         |
| Enable x6/xN non-bonded high-speed clock output port | N/A for x1<br>Disable for x2, x4, x8    | N/A for x1<br>Disable for x2, x4, x8    | N/A for x1<br>N/A for x2,x4, x8          |
| Enable PCIe clock switch interface                   | N/A for x1<br>Disable for x2, x4, x8    | N/A for x1<br>Enable for x2, x4, x8     | N/A for x1<br>N/A for x2, x4, x8         |

*continued...*

| Parameter                                    | Gen1 PIPE                                   | Gen2 PIPE                                   | Gen3 PIPE (For Gen1/<br>Gen2 speeds) |
|----------------------------------------------|---------------------------------------------|---------------------------------------------|--------------------------------------|
| Number of auxiliary MCGB clock input ports   | N/A for x1<br>0 for x2, x4, x8              | N/A for x1<br>0 for x2, x4, x8              | N/A for x1<br>N/A for x2, x4, x8     |
| MCGB input clock frequency                   | 1250MHz                                     | 2500MHz                                     | 2500MHz                              |
| MCGB output data rate                        | 2500Mbps                                    | 5000Mbps                                    | 5000Mbps                             |
| <b>Bonding</b>                               |                                             |                                             |                                      |
| Enable bonding clock output ports            | N/A for x1 design<br>Enable for x2, x4, x8  | N/A for x1 design<br>Enable for x2, x4, x8  | N/A for x1<br>N/A for x2, x4, x8     |
| Enable feedback compensation bonding         | N/A for x1 design<br>Disable for x2, x4, x8 | N/A for x1 design<br>Disable for x2, x4, x8 | N/A for x1<br>N/A for x2, x4, x8     |
| PMA interface width                          | N/A for x1 design<br>10 for x2, x4, x8      | N/A for x1 design<br>10 for x2, x4, x8      | N/A for x1<br>N/A for x2, x4, x8     |
| <b>Dynamic Reconfiguration</b>               |                                             |                                             |                                      |
| Enable dynamic reconfiguration               | Disable                                     | Disable                                     | Disable                              |
| Enable Native PHY Debug Master Endpoint      | Disable                                     | Disable                                     | Disable                              |
| Separate avmm_busy from reconfig_waitrequest | N/A                                         | N/A                                         | N/A                                  |
| <b>Optional Reconfiguration Logic</b>        |                                             |                                             |                                      |
| Enable capability registers                  | N/A                                         | N/A                                         | N/A                                  |
| Set user-defined IP identifier               | N/A                                         | N/A                                         | N/A                                  |
| Enable control and status registers          | N/A                                         | N/A                                         | N/A                                  |
| <b>Configuration Files</b>                   |                                             |                                             |                                      |
| Configuration file prefix                    | N/A                                         | N/A                                         | N/A                                  |
| Generate SystemVerilog package file          | N/A                                         | N/A                                         | N/A                                  |
| Generate C Header file                       | N/A                                         | N/A                                         | N/A                                  |
| Generate MIF (Memory Initialize file)        | N/A                                         | N/A                                         | N/A                                  |
| <b>Generation Options</b>                    |                                             |                                             |                                      |
| Generate parameter documentation file        | Enable                                      | Enable                                      | Enable                               |

### Related Information

[Using the Arria 10 Transceiver Native PHY IP Core on page 45](#)

## 2.7.7. ATX PLL IP Parameter Core Settings for PIPE

**Table 192. Parameters for Arria 10 ATX PLL IP core in PIPE Gen1, Gen2, Gen3 modes**

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

| Parameter                                             | Gen1 PIPE                               | Gen2 PIPE                               | Gen3 PIPE (For Gen3 speed)                                                         |
|-------------------------------------------------------|-----------------------------------------|-----------------------------------------|------------------------------------------------------------------------------------|
| <b>PLL</b>                                            |                                         |                                         |                                                                                    |
| <b>General</b>                                        |                                         |                                         |                                                                                    |
| Message level for rule violations                     | Error                                   | Error                                   | Error                                                                              |
| Protocol Mode                                         | PCIe Gen 1                              | PCIe Gen 2                              | PCIe Gen 3                                                                         |
| Bandwidth                                             | Low, medium, high                       | Low, medium, high                       | Low, medium, high                                                                  |
| Number of PLL reference clocks                        | 1                                       | 1                                       | 1                                                                                  |
| Selected reference clock source                       | 0                                       | 0                                       | 0                                                                                  |
| <b>Ports</b>                                          |                                         |                                         |                                                                                    |
| Primary PLL clock output buffer                       | GX clock output buffer                  | GX clock output buffer                  | GX clock output buffer                                                             |
| Enable PLL GX clock output port                       | Enable                                  | Enable                                  | Enable                                                                             |
| Enable PLL GT clock output port                       | Disable                                 | Disable                                 | Disable                                                                            |
| Enable PCIe clock output port<br><b>pll_pcnie_clk</b> | Enable                                  | Enable                                  | Disable (Use the <b>pll_pcnie_clk output</b> port from the fPLL to drive the hclk) |
| Enable ATX to fPLL cascade clock output port          | Disable                                 | Disable                                 | Disable                                                                            |
| <b>Output Frequency</b>                               |                                         |                                         |                                                                                    |
| PLL output frequency                                  | 2500MHz                                 | 2500MHz                                 | 4000MHz                                                                            |
| PLL output datarate                                   | 2500Mbps                                | 5000Mbps                                | 8000Mbps                                                                           |
| Enable fractional mode                                | Disable                                 | Disable                                 | Disable                                                                            |
| PLL integer reference clock frequency                 | 100MHz, 125MHz                          | 100MHz, 125MHz                          | 100MHz, 125MHz                                                                     |
| Configure counters manually                           | Disable                                 | Disable                                 | Disable                                                                            |
| Multiple factor (M counter)                           | N/A                                     | N/A                                     | N/A                                                                                |
| Divide factor (N counter)                             | N/A                                     | N/A                                     | N/A                                                                                |
| Divide factor (L counter)                             | N/A                                     | N/A                                     | N/A                                                                                |
| <b>Master Clock Generation Block</b>                  |                                         |                                         |                                                                                    |
| MCGB                                                  |                                         |                                         |                                                                                    |
| Include master clock generation block                 | Disable for x1<br>Enable for x2, x4, x8 | Disable for x1<br>Enable for x2, x4, x8 | Disable for x1<br>Enable for x2, x4, x8                                            |
| Clock division factor                                 | N/A for x1<br>1 for x2, x4, x8          | N/A for x1<br>1 for x2, x4, x8          | N/A for x1<br>1 for x2, x4, x8                                                     |
| Enable x6/xN non-bnded high speed clock output port   | N/A for x1<br>Disable for x2, x4, x8    | N/A for x1<br>Disable for x2, x4, x8    | N/A for x1<br>Disable for x2, x4, x8                                               |
| Enable PCIe clock switch interface                    | N/A for x1<br>Disable for x2, x4, x8    | N/A for x1<br>Enable for x2, x4, x8     | N/A for x1<br>Enable for x2, x4, x8                                                |

*continued...*

| Parameter                                    | Gen1 PIPE                                   | Gen2 PIPE                                   | Gen3 PIPE (For Gen3 speed)               |
|----------------------------------------------|---------------------------------------------|---------------------------------------------|------------------------------------------|
| Number of auxiliary MCGB clock input ports   | N/A for x1<br>0 for x2, x4, x8              | N/A for x1<br>0 for x2, x4, x8              | N/A for x1<br>1 for x2, x4, x8           |
| MCGB input clock frequency                   | 1250 MHz                                    | 2500 MHz                                    | 4000 MHz                                 |
| MCGB output data rate                        | 2500 Mbps                                   | 5000 Mbps                                   | 8000 Mbps                                |
| <b>Bonding</b>                               |                                             |                                             |                                          |
| Enable bonding clock output ports            | N/A for x1<br>Enable for x2, x4, x8         | N/A for x1<br>Enable for x2, x4, x8         | N/A for x1<br>Enable for x2, x4, x8      |
| Enable feedback compensation bonding         | N/A for x1 design<br>Disable for x2, x4, x8 | N/A for x1 design<br>Disable for x2, x4, x8 | Disable for x1<br>Disable for x2, x4, x8 |
| PMA interface width                          | N/A for x1 design<br>10 for x2, x4, x8      | N/A for x1 design<br>10 for x2, x4, x8      | N/A for x1<br>10 for x2, x4, x8          |
| <b>Dynamic Reconfiguration</b>               |                                             |                                             |                                          |
| Enable dynamic reconfiguration               | Disable                                     | Disable                                     | Disable                                  |
| Enable Native PHY Debug Master Endpoint      | Disable                                     | Disable                                     | Disable                                  |
| Separate avmm_busy from reconfig_waitrequest | N/A                                         | N/A                                         | N/A                                      |
| <b>Optional Reconfiguration Logic</b>        |                                             |                                             |                                          |
| Enable capability registers                  | N/A                                         | N/A                                         | N/A                                      |
| Set user-defined IP identifier               | N/A                                         | N/A                                         | N/A                                      |
| Enable control and status registers          | N/A                                         | N/A                                         | N/A                                      |
| <b>Configuration Files</b>                   |                                             |                                             |                                          |
| Configuration file prefix                    | N/A                                         | N/A                                         | N/A                                      |
| Generate SystemVerilog package file          | N/A                                         | N/A                                         | N/A                                      |
| Generate C Header file                       | N/A                                         | N/A                                         | N/A                                      |
| Generate MIF (Memory Initialize file)        | N/A                                         | N/A                                         | N/A                                      |
| <b>Generation Options</b>                    |                                             |                                             |                                          |
| Generate parameter documentation file        | Enable                                      | Enable                                      | Enable                                   |

### Related Information

[Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45

## 2.7.8. Native PHY IP Ports for PIPE

**Figure 110.** Signals and Ports of Native PHY IP for PIPE



Note: N is the number of PCIe channels

**Table 193. Ports for Arria 10 Transceiver Native PHY in PIPE Mode**

This section contains the recommended settings for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter settings.

| Port                                        | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------------|-----------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Clocks</b>                               |           |              |                                                                                                                                                                                                                                                                                                                                                                                                                            |
| rx_cdr_refclk0                              | In        | N/A          | The 100/125 MHz input reference clock source for the PHY's TX PLL and RX CDR.                                                                                                                                                                                                                                                                                                                                              |
| tx_serial_clk0/<br>tx_serial_clk1           | In        | N/A          | The high speed serial clock generated by the PLL.<br>Note: For Gen3 x1 ONLY tx_serial_clk1 is used.                                                                                                                                                                                                                                                                                                                        |
| pipe_hclk_in[0]                             | In        | N/A          | The 500 MHz clock used for the ASN block. This clock is generated by the PLL, configured for Gen1/Gen2.<br>Note: For Gen3 designs, use from the fPLL that is used for Gen1/Gen2.                                                                                                                                                                                                                                           |
| pipe_hclk_out[0]                            | Out       | N/A          | The 500 MHz clock output provided to the PHY - MAC interface. The pipe_hclk_out [0] port can be left floating when you connect tx_clkout to the MAC clock input.                                                                                                                                                                                                                                                           |
| <b>PIPE Input from PHY - MAC Layer</b>      |           |              |                                                                                                                                                                                                                                                                                                                                                                                                                            |
| tx_parallel_data[31:0],<br>[15:0], or [7:0] | In        | tx_coreclkin | The TX parallel data driven from the MAC. For Gen1 this can be 8 or 16 bits. For Gen2 this is 16 bits. For Gen3 this is 32 bits.<br>Note: unused_tx_parallel_data should be tied to '0'.<br>Active High. Refer to table <i>Bit Mappings when the Simplified Interface is Disabled</i> for additional details.                                                                                                              |
| tx_data[3:0], [1:0], or<br>[0]              | In        | tx_coreclkin | The data and control indicator for the transmitted data.<br>For Gen1 or Gen2, when 0, indicates that tx_parallel_data is data, when 1, indicates that tx_parallel_data is control.<br>For Gen3, bit[0] corresponds to tx_parallel_data[7:0], bit[1] corresponds to tx_parallel_data[15:8], and so on.<br>Active High. Refer to table <i>Bit Mappings when the Simplified Interface is Disabled</i> for additional details. |
| pipe_tx_sync_hdr[(2N-1):0] <sup>(44)</sup>  | In        | tx_coreclkin | For Gen3, indicates whether the 130-bit block transmitted is a Data or Control Ordered Set Block.<br>The following encodings are defined:<br>2'b10: Data block<br>2'b01: Control Ordered Set Block<br>This value is read when pipe_tx_blk_start = 1b'1.                                                                                                                                                                    |

***continued...***


---

<sup>(44)</sup> N is the number of PCIe channels.

| Port                                | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                     |           |              | Refer to <i>Lane Level Encoding</i> in the <i>PCI Express Base Specification, Rev. 3.0</i> for a detailed explanation of data transmission and reception using 128b/130b encoding and decoding.<br>Not used for Gen1 and Gen2 data rates.<br>Active High                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| pipe_tx_blk_start[(N-1):0]          | In        | tx_coreclkin | For Gen3, specifies the start block byte location for TX data in the 128-bit block data. Used when the interface between the PCS and PHY-MAC (FPGA Core) is 32 bits.<br>Not used for Gen1 and Gen2 data rates.<br>Active High                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| pipe_tx_elecidle[(4N-1):0]          | In        | Asynchronous | Forces the transmit output to electrical idle. Refer to the <i>Intel PHY Interface for PCI Express (PIPE)</i> for timing diagrams.<br>Gen1 - Width of signal is 1 bit/lane.<br>Gen2 - Width of signal is 2 bits/lane. For example, if the MAC connected to PIPE Gen2x4 has 1bit/lane, then you can use the following mapping to connect to PIPE:<br>{pipe_tx_elecidle[7:0] = {{2{tx_elecidle_ch3}}, {2{tx_elecidle_ch2}}, {2{tx_elecidle_ch1}}, {2{tx_elecidle_ch0}}}} where tx_elecidle_* is the output signal from MAC.<br>Gen3 - Width of signal is 4 bits/lane. For example, if the MAC connected to PIPE Gen3x4 has 1bit/lane, then you can use the following mapping to connect to PIPE:<br>{pipe_tx_elecidle[15:0] = {{4{tx_elecidle_ch3}}, {4{tx_elecidle_ch2}}, {4{tx_elecidle_ch1}}, {4{tx_elecidle_ch0}}}} where tx_elecidle_* is the output signal from MAC.<br>Active High |
| pipe_tx_detectrx_loopback [(N-1):0] | In        | tx_coreclkin | Instructs the PHY to start a receive detection operation. After power-up, asserting this signal starts a loopback operation. Refer to section 6.4 of the <i>Intel PHY Interface for PCI Express (PIPE)</i> for a timing diagram.<br>Active High                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| pipe_tx_compliance[(4N-1):0]        | In        | tx_coreclkin | Asserted for one cycle to set the running disparity to negative. Used when transmitting the compliance pattern. Refer to section 6.11 of the <i>Intel PHY Interface for PCI Express (PIPE) Architecture</i> for more information.<br>Gen1 - Width of signal is 1 bit/lane.<br>Gen2 - Width of signal is 2 bits/lane.<br>For example, if the MAC connected to PIPE Gen2x4 has 1bit/lane, then you can use the following mapping to connect to PIPE:<br>{pipe_tx_compliance[7:0] = {{2{tx_compliance_ch3}}, {2{tx_compliance_ch2}}, {2{tx_compliance_ch1}}, {2{tx_compliance_ch0}}}}. Where tx_compliance_* is the output signal from MAC.<br>Gen3 - Width of signal is 4 bits/lane.                                                                                                                                                                                                      |

continued...

| Port                         | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              |           |              | For example, if the MAC connected to PIPE Gen3x4 has 1bit/lane, then you can use the following mapping to connect to PIPE:<br>$\{\text{pipe\_tx\_compliance}[15:0]\} = \{\{4\{\text{tx\_compliance\_ch3}\}\}, \{4\{\text{tx\_compliance\_ch2}\}\}, \{4\{\text{tx\_compliance\_ch1}\}\}, \{4\{\text{tx\_compliance\_ch0}\}\}\}$ . Where tx_compliance_* is the output signal from MAC.<br>Active High                                                                                                                                                                                                                  |
| pipe_rx_polarity[(N-1):0]    | In        | Asynchronous | When 1'b1, instructs the PHY layer to invert the polarity on the received data.<br>Active High                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| pipe_powerdown[(2N-1):0]     | In        | tx_coreclk   | Requests the PHY to change its power state to the specified state. The Power States are encoded as follows:<br>2'b00: P0 - Normal operation.<br>2'b01: P0s - Low recovery time, power saving state.<br>2'b10: P1 - Longer recovery time, lower power state .<br>2'b11: P2 - Lowest power state.                                                                                                                                                                                                                                                                                                                       |
| pipe_tx_margin[(3N-1):0]     | In        | tx_coreclk   | Transmit V <sub>OD</sub> margin selection. The PHY-MAC sets the value for this signal based on the value from the Link Control 2 Register. The following encodings are defined:<br>3'b000: Normal operating range<br>3'b001: Full swing: 800 - 1200 mV; Half swing: 400 - 700 mV.<br>3'b010:-3'b011: Reserved.<br>3'b100-3'b111: Full swing: 200 - 400mV; Half swing: 100 - 200 mV else reserved.                                                                                                                                                                                                                     |
| pipe_tx_swing[(N-1):0]       | In        | tx_coreclk   | Indicates whether the transceiver is using Full swing or Half swing voltage as defined by the pipe_tx_margin.<br>1'b0-Full swing.<br>1'b1-Half swing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| pipe_tx_deemph[(N-1):0]      | In        | Asynchronous | Transmit de-emphasis selection. In PCI Express Gen2 (5 Gbps) mode it selects the transmitter de-emphasis:<br>1'b0: -6 dB.<br>1'b1: -3.5 dB.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| pipe_g3_tx_deemph[(18N-1):0] | In        | Asynchronous | The pipe_g3_tx_deemph port is used to select the link partners transmitter de-emphasis during equalization. The 18 bits specify the following coefficients:<br>[5:0]: C <sub>1</sub><br>[11:6]: C <sub>0</sub><br>[17:12]: C <sub>+1</sub><br>Refer to <a href="#">Preset Mappings to TX De-emphasis</a> on page 274 for presets to TX de-emphasis mappings. In Gen3 capable designs, the TX de-emphasis for Gen2 data rate is always -6 dB. The TX de-emphasis for Gen1 data rate is always -3.5 dB.<br>Refer to section 6.6 of <i>Intel PHY Interface for PCI Express (PIPE) Architecture</i> for more information. |

*continued...*

| Port                                     | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------|-----------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                          |           |              | <i>Note:</i> Intel recommends transmitting Preset P8 coefficients for Arria 10 receiver to recover data successfully.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| pipe_g3_rxpresethint[(3 N-1):0]          | In        | Asynchronous | <p>This is used to trigger CTLE adaptation in Phase2 (EP) /Phase 3 (RP) to achieve receiver Bit Error Rate (BER) that is less than 10<sup>-12</sup>.</p> <p>Gen3 capable design at Gen1/Gen2 speeds: This should be set to 3'b000.</p> <p>Gen3 capable design at Gen3 speed: Refer to section "PHY IP Core for PCIe (PIPE) Link Equalization for Gen3 Data Rate" for details on when to set/reset this port.</p>                                                                                                                                                                                                                                                                                                                                                  |
| pipe_rx_eidleinfersel[(3N-1):0]          | In        | Asynchronous | <p>When asserted high, the electrical idle state is inferred instead of being identified using analog circuitry to detect a device at the other end of the link. The following encodings are defined:</p> <ul style="list-style-type: none"> <li>3'b0xx: Electrical Idle Inference not required in current LTSSM state.</li> <li>3'b100: Absence of COM/SKP OS in 128 ms.</li> <li>3'b101: Absence of TS1/TS2 OS in 1280 UI interval for Gen1 or Gen2.</li> <li>3'b110: Absence of Electrical Idle Exit in 2000 UI interval for Gen1 and 16000 UI interval for Gen2.</li> <li>3'b111: Absence of Electrical Idle exit in 128 ms window for Gen1.</li> </ul> <p><i>Note:</i> Recommended to implement Receiver Electrical Idle Inference (EII) in FPGA fabric.</p> |
| pipe_rate[1:0]                           | In        | Asynchronous | <p>The 2-bit encodings defined in the following list:</p> <ul style="list-style-type: none"> <li>2'b00: Gen1 rate (2.5 Gbps)</li> <li>2'b01: Gen2 rate (5.0 Gbps)</li> <li>2'b10: Gen3 rate (8.0 Gbps)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| pipe_sw_done[1:0]                        | In        | N/A          | <p>Signal from the Master clock generation buffer, indicating that the rate switch has completed. Use this signal for bonding mode only.</p> <p>For non-bonded applications, this signal is internally connected to the local CGB.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| pipe_tx_data_valid[(N-1):0]              | In        | tx_coreclk   | <p>For Gen3, this signal is deasserted by the MAC to instruct the PHY to ignore tx_parallel_data for current clock cycle. A value of 1'b1 indicates the PHY should use the data. A value of 0 indicates the PHY should not use the data.</p> <p>Active High</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>PIPE Output to PHY - MAC Layer</b>    |           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| rx_parallel_data[31:0], [15:0], or [7:0] | Out       | rx_coreclk   | <p>The RX parallel data driven to the MAC. For Gen1 this can be 8 or 16 bits. For Gen2 this is 16 bits only. For Gen3 this is 32 bits. Refer to <i>Bit Mappings When the Simplified Interface is Disabled</i> for more details.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

continued...

| Port                         | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_datak[3:0], [1:0], or [0] | Out       | rx_coreclk   | The data and control indicator. For Gen1 or Gen2, when 0, indicates that rx_parallel_data is data, when 1, indicates that rx_parallel_data is control. For Gen3, Bit[0] corresponds to rx_parallel_data[7:0], Bit[1] corresponds to rx_parallel_data[15:8], and so on. Refer to <i>tableBit Mappings When the Simplified Interface is Disabled</i> for more details.                                                                                                           |
| pipe_rx_sync_hdr[(2N-1):0]   | Out       | rx_coreclk   | For Gen3, indicates whether the 130-bit block being transmitted is a Data or Control Ordered Set Block. The following encodings are defined:<br>2'b10: Data block<br>2'b01: Control Ordered Set block<br>This value is read when pipe_rx_blk_start = 4'b0001. Refer to <i>Section 4.2.2.1. Lane Level Encoding</i> in the <i>PCI Express Base Specification, Rev. 3.0</i> for a detailed explanation of data transmission and reception using 128b/130b encoding and decoding. |
| pipe_rx_blk_start[(N-1):0]   | Out       | rx_coreclk   | For Gen3, specifies the start block byte location for RX data in the 128-bit block data. Used when the interface between the PCS and PHY-MAC (FPGA Core) is 32 bits. Not used for Gen1 and Gen2 data rates.<br>Active High                                                                                                                                                                                                                                                     |
| pipe_rx_data_valid[(N-1):0]  | Out       | rx_coreclk   | For Gen3, this signal is deasserted by the PHY to instruct the MAC to ignore rx_parallel_data for current clock cycle. A value of 1'b1 indicates the MAC should use the data. A value of 1'b0 indicates the MAC should not use the data.<br>Active High                                                                                                                                                                                                                        |
| pipe_rx_valid[(N-1):0]       | Out       | rx_coreclk   | Asserted when RX data and control are valid.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| pipe_phy_status[(N-1):0]     | Out       | rx_coreclk   | Signal used to communicate completion of several PHY requests.<br>Active High                                                                                                                                                                                                                                                                                                                                                                                                  |
| pipe_rx_elecidle[(N-1):0]    | Out       | Asynchronous | When asserted, the receiver has detected an electrical idle.<br>Active High                                                                                                                                                                                                                                                                                                                                                                                                    |
| pipe_rx_status[(3N-1):0]     | Out       | rx_coreclk   | Signal encodes receive status and error codes for the receive data stream and receiver detection. The following encodings are defined:<br>3'b000 - Receive data OK<br>3'b001 - 1 SKP added<br>3'b010 - 1 SKP removed<br>3'b011 - Receiver detected<br>3'b100 - Either 8B/10B or 128b/130b decode error and (optionally) RX disparity error<br>3'b101 - Elastic buffer overflow<br>3'b110 - Elastic buffer underflow                                                            |

*continued...*

| Port         | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                     |
|--------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |           |              | 3'b111 - Receive disparity error, not used if disparity error is reported using 3'b100.                                                                                                                                                                                                                                                                         |
| pipe_sw[1:0] | Out       | N/A          | <p>Signal to clock generation buffer indicating the rate switch request. Use this signal for bonding mode only.</p> <p>For non-bonded applications this signal is internally connected to the local CGB.</p> <p>Active High. Refer to <a href="#">Table 194</a> on page 270 <i>Bit Mappings When the Simplified Interface is Disabled</i> for more details.</p> |

**Table 194. Bit Mappings When the Simplified Interface Is Disabled**

This section contains the recommended settings for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

| Signal Name               | Gen1 (TX Byte Serializer and RX Byte Deserializer disabled) | Gen1 (TX Byte Serializer and RX Byte Deserializer in X2 mode), Gen2 (TX Byte Serializer and RX Byte Deserializer in X2 mode) | Gen3                                    |
|---------------------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| tx_parallel_data          | tx_parallel_data[7:0]                                       | tx_parallel_data[29:22,7:0]                                                                                                  | tx_parallel_data[40:33,29:22,18:11,7:0] |
| tx_datak                  | tx_parallel_data[8]                                         | tx_parallel_data[30,8]                                                                                                       | tx_parallel_data[41,30,19,8]            |
| pipe_tx_compliance        | tx_parallel_data[9]                                         | tx_parallel_data[31,9]                                                                                                       | tx_parallel_data[42,31,20,9]            |
| pipe_tx_elecidle          | tx_parallel_data[10]                                        | tx_parallel_data[32,10]                                                                                                      | tx_parallel_data[43,32,21,10]           |
| pipe_tx_detectrx_loopback | tx_parallel_data[46]                                        | tx_parallel_data[46]                                                                                                         | tx_parallel_data[46]                    |
| pipe_powerdown            | tx_parallel_data[48:47]                                     | tx_parallel_data[48:47]                                                                                                      | tx_parallel_data[48:47]                 |
| pipe_tx_margin            | tx_parallel_data[51:49]                                     | tx_parallel_data[51:49]                                                                                                      | tx_parallel_data[51:49]                 |
| pipe_tx_swing             | tx_parallel_data[53]                                        | tx_parallel_data[53]                                                                                                         | tx_parallel_data[53]                    |
| rx_parallel_data          | rx_parallel_data[7:0]                                       | rx_parallel_data[39:32,7:0]                                                                                                  | rx_parallel_data[55:48,39:32,23:16,7:0] |
| rx_datak                  | rx_parallel_data[8]                                         | rx_parallel_data[40,8]                                                                                                       | rx_parallel_data[56,40,24,8]            |
| rx_syncstatus             | rx_parallel_data[10]                                        | rx_parallel_data[42,10]                                                                                                      | rx_parallel_data[58,42,26,10]           |
| pipe_phy_status           | rx_parallel_data[65]                                        | rx_parallel_data[65]                                                                                                         | rx_parallel_data[65]                    |
| pipe_rx_valid             | rx_parallel_data[66]                                        | rx_parallel_data[66]                                                                                                         | rx_parallel_data[66]                    |
| pipe_rx_status            | rx_parallel_data[69:67]                                     | rx_parallel_data[69:67]                                                                                                      | rx_parallel_data[69:67]                 |

*continued...*

| Signal Name        | Gen1 (TX Byte Serializer and RX Byte Deserializer disabled) | Gen1 (TX Byte Serializer and RX Byte Deserializer in X2 mode), Gen2 (TX Byte Serializer and RX Byte Deserializer in X2 mode) | Gen3                    |
|--------------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| pipe_tx_deemph     | N/A                                                         | tx_parallel_data[52]                                                                                                         | N/A                     |
| pipe_tx_sync_hdr   | N/A                                                         | N/A                                                                                                                          | tx_parallel_data[55:54] |
| pipe_tx_blk_start  | N/A                                                         | N/A                                                                                                                          | tx_parallel_data[56]    |
| pipe_tx_data_valid | N/A                                                         | N/A                                                                                                                          | tx_parallel_data[60]    |
| pipe_rx_sync_hdr   | N/A                                                         | N/A                                                                                                                          | rx_parallel_data[71:70] |
| pipe_rx_blk_start  | N/A                                                         | N/A                                                                                                                          | rx_parallel_data[72]    |
| pipe_rx_data_valid | N/A                                                         | N/A                                                                                                                          | rx_parallel_data[76]    |

Refer to section 6.6 of *Intel PHY Interface for PCI Express (PIPE) Architecture* for more information.

#### Related Information

- [PHY IP Core for PCIe \(PIPE\) Link Equalization for Gen3 Data Rate](#) on page 281
- [Intel PHY Interface for PCI Express \(PIPE\) Architecture](#)
- [Bit Mappings When the Simplified Interface is Disabled](#) on page 270
- [Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45

#### 2.7.9. fPLL Ports for PIPE

**Table 195. fPLL Ports for PIPE**

This section contains the recommended settings for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter settings.

| Port          | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pll_powerdown | Input     | Asynchronous | Resets the PLL when asserted high. Needs to be connected to a dynamically controlled signal (the Transceiver PHY Reset Controller <code>pll_powerdown</code> output if using this Intel FPGA IP).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Pll_reflck0   | Input     | N/A          | Reference clock input port 0. There are five reference clock input ports. The number of reference clock ports available depends on the Number of PLL reference clocks parameter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| tx_serial_clk | Output    | N/A          | High speed serial clock output port for GX channels. Represents the x1 clock network.<br>For Gen1x1, Gen2x1, connect the output from this port to the <code>tx_serial_clk</code> input of the native PHY IP.<br>For Gen1x2, x4, x8, use the <code>tx_bonding_clocks</code> output port to connect to the Native PHY IP.<br>For Gen2x2, x4, x8, use the <code>tx_bonding_clocks</code> output port to connect to the Native PHY IP.<br>For Gen3x1, connect the output from this port to one of the two <code>tx_serial_clk</code> input ports on the native PHY IP.<br>For Gen3x2, x4, x8, connect the output from this port to the Auxiliary Master CGB clock input port of the ATX PLL IP. |

*continued...*

| <b>Port</b>               | <b>Direction</b> | <b>Clock Domain</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------|------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pll_locked                | Output           | Asynchronous        | Active high status signal which indicates if PLL is locked.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| pll_pcie_clk              | Output           | N/A                 | This is the hclk required for PIPE interface.<br>For Gen1x1, x2, x4, x8 use this port to drive the hclk for the PIPE interface.<br>For Gen2x1, x2, x4, x8 use this port to drive the hclk for the PIPE interface.<br>For Gen3x1, x2, x4, x8, use the <code>pll_pcie_clk</code> from fPLL (configured as Gen1/Gen2) as the hclk for the PIPE interface.                                                                                                                                                                                                                                                                                                                                     |
| pll_cal_busy              | Output           | Asynchronous        | Status signal which is asserted high when PLL calibration is in progress.<br>If this port is not enabled in Transceiver PHY Reset Controller, then perform logical OR with this signal and the <code>tx_cal_busy</code> output signal from Native PHY to input the <code>tx_cal_busy</code> on the reset controller IP.                                                                                                                                                                                                                                                                                                                                                                    |
| Mrgb_rst                  | Input            | Asynchronous        | Master CGB reset control.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| mgb_aux_clk0              | Input            | N/A                 | Used for Gen3 to switch between fPLL/ATX PLL during link speed negotiation. For gen3x2, x4, x8 use the <code>mgb_aux_clk</code> input port on the ATX PLL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| tx_bonding_clocks[6n-1:0] | Output           | N/A                 | Optional 6-bit bus which carries the low speed parallel clock outputs from the Master CGB. It is used for channel bonding, and represents the x6/xN clock network.<br>For Gen1x1, this port is disabled.<br>For Gen1x2, x4, x8 connect the output from this port to the <code>tx_bonding_clocks</code> input on Native PHY.<br>For Gen2x1, this port is disabled.<br>For Gen2x2, x4, x8 connect the output from this port to the <code>tx_bonding_clocks</code> input on Native PHY.<br>For Gen3x1, this port is disabled.<br>For Gen3x2, x4, x8, use the <code>tx_bonding_clocks</code> output from the ATX PLL to connect to the <code>tx_bonding_clocks</code> input of the Native PHY. |
| pcie_sw[1:0]              | Input            | Asynchronous        | 2-bit rate switch control input used for PCIe protocol implementation.<br>For Gen1, this port is N/A.<br>For Gen 2x2, x4, x8 connect the <code>pipe_sw</code> output from Native PHY to this port.<br>For Gen3x2, x4, x8 connect the <code>pipe_sw</code> output from the Native PHY to this port.<br>For Gen3x2, x4, x8, this port is not used. You must use the <code>pipe_sw</code> from Native PHY to drive the <code>pcie_sw</code> input port on the ATX PLL.                                                                                                                                                                                                                        |
| pcie_sw_done[1:0]         | Output           | Asynchronous        | 2-bit rate switch status output used for PCIe protocol implementation.<br>For Gen1, this port is N/A.<br>For Gen 2x2, x4, x8 connect the <code>pcie_sw_done</code> output from ATX PLL to the <code>pipe_sw_done</code> input of Native PHY.<br>For Gen3x2, x4, x8 connect the <code>pcie_sw_done</code> output from ATX PLL to the <code>pipe_sw_done</code> input of Native PHY.                                                                                                                                                                                                                                                                                                         |

### Related Information

[Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45

## 2.7.10. ATX PLL Ports for PIPE

**Table 196. ATX PLL Ports for PIPE**

This section contains the recommended settings for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter settings.

| Port                   | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------|-----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pl1_powerdown          | Input     | Asynchronous | Resets the PLL when asserted high. Needs to be connected to a dynamically controlled signal (the Transceiver PHY Reset Controller <code>pll_powerdown</code> output if using this Intel FPGA IP).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Pl1_reflck0            | Input     | N/A          | Reference clock input port 0. There are five reference clock input ports. The number of reference clock ports available depends on the Number of PLL reference clocks parameter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| tx_serial_clk          | Output    | N/A          | <p>High speed serial clock output port for GX channels. Represents the x1 clock network.</p> <p>For Gen1x1, Gen2x1, connect the output from this port to the <code>tx_serial_clk</code> input of the native PHY IP.</p> <p>For Gen1x2, x4, x8, use the <code>tx_bonding_clocks</code> output port to connect to the Native PHY.</p> <p>For Gen2x2, x4, x8, use the <code>tx_bonding_clocks</code> output port to connect to the Native PHY.</p> <p>For Gen3x1, connect the output from this port to one of the two <code>tx_serial_clk</code> input ports on the native PHY IP.</p> <p>For Gen3x2, x4, x8, this port is not used. Use the <code>tx_serial_clk</code> output from the fPLL to drive the Auxiliary Master CGB clock input port of the ATX PLL.</p> |
| pl1_locked             | Output    | Asynchronous | Active high status signal which indicates if PLL is locked.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| pl1_pcie_clk           | Output    | N/A          | <p>This is the hclk required for PIPE interface.</p> <p>For Gen1x1,x2,x4,x8 use this port to drive the hclk for the PIPE interface.</p> <p>For Gen2x1,x2,x4,x8 use this port to drive the hclk for the PIPE interface.</p> <p>For Gen3x1,x2,x4,x8, this port is not used. Use the <code>pl1_pcie_clk</code> from fPLL (configured as Gen1/Gen2) as the hclk for the PIPE interface.</p>                                                                                                                                                                                                                                                                                                                                                                          |
| Pl1_cal_busy           | Output    | Asynchronous | Status signal which is asserted high when PLL calibration is in progress. If this port is not enabled in the Transceiver PHY Reset Controller, then perform logical OR with this signal and the <code>tx_cal_busy</code> output signal from Native PHY to input the <code>tx_cal_busy</code> on the reset controller IP.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Mcgb_RST               | Input     | Asynchronous | Master CGB reset control.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| mcgb_aux_clk0          | Input     | N/A          | <p>Used for Gen3 to switch between fPLL/ATX PLL during link speed negotiation.</p> <p>For gen3x2,x4,x8 use the <code>tx_serial_clk</code> output port from fPLL (configured for Gen1/Gen2) to drive the <code>mcgb_aux_clk</code> input port on the ATX PLL.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| tx_bonding_clocks[5:0] | Output    | N/A          | <p>Optional 6-bit bus which carries the low speed parallel clock outputs from the Master CGB. Used for channel bonding, and represents the x6/xN clock network.</p> <p>For Gen1x1, this port is disabled.</p> <p>For Gen1x2,x4,x8 connect the output from this port to the <code>tx_bonding_clocks</code> input on Native PHY.</p> <p>For Gen2x1, this port is disabled</p> <p>For Gen2x2,x4,x8 connect the output from this port to <code>tx_bonding_clocks</code> input on Native PHY.</p> <p>For Gen3x1, this port is disabled.</p>                                                                                                                                                                                                                           |

*continued...*

| Port              | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                |
|-------------------|-----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |           |              | For Gen3x2,x4,x8 use the tx_bonding_clocks output from the ATX PLL to connect to the tx_bonding_clocks input of the Native PHY.                                                                                                                                                                            |
| pcie_sw[1:0]      | Input     | Asynchronous | 2-bit rate switch control input used for PCIe protocol implementation.<br>For Gen1, this port is N/A.<br>For Gen 2x2,x4,x8 connect the pipe_sw output from Native PHY to this port.<br>For Gen3x2,x4,x8 use the pipe_sw output from Native PHY to drive this port.                                         |
| pcie_sw_done[1:0] | Output    | Asynchronous | 2-bit rate switch status output used for PCIe protocol implementation.<br>For Gen1, this port is N/A.<br>For Gen2x2, x4, x8 connect the pcie_sw_done output from ATX PLL to pipe_sw_done input of Native PHY .<br>For Gen3x2, x4, x8 pcie_sw_done output from ATX PLL to pipe_sw_done input of Native PHY. |

#### Related Information

[Using the Arria 10 Transceiver Native PHY IP Core](#) on page 45

### 2.7.11. Preset Mappings to TX De-emphasis

**Table 197. Arria 10 Preset Mappings to TX De-emphasis**

| Preset | $C_{+1}$ | $C_0$  | $C_{-1}$ |
|--------|----------|--------|----------|
| 0      | 001111   | 101101 | 000000   |
| 1      | 001010   | 110010 | 000000   |
| 2      | 001100   | 110000 | 000000   |
| 3      | 001000   | 110100 | 000000   |
| 4      | 000000   | 111100 | 000000   |
| 5      | 000000   | 110110 | 000110   |
| 6      | 000000   | 110100 | 001000   |
| 7      | 001100   | 101010 | 000110   |
| 8      | 001000   | 101100 | 001000   |
| 9      | 000000   | 110010 | 001010   |
| 10     | 010110   | 100110 | 000000   |

The pipe\_g3\_txdeemph port is used to select the link partner's transmitter de-emphasis during equalization. The 18 bits specify the following coefficients:

[5:0]:  $C_{-1}$

[11:6]:  $C_0$

[17:12]:  $C_{+1}$

**Note:** Intel recommends transmitting Preset P8 coefficients for Arria 10 receiver to recover data successfully.

### 2.7.12. How to Place Channels for PIPE Configurations

Instead of the fitter or software model, the hardware dictates all the placement restrictions. The restrictions are listed below:

- The channels must be contiguous for bonded designs.
- The master CGB is the only way to access x6 lines and must be used in bonded designs. The local CGB cannot be used to route clock signals to slave channels because the local CGB does not have access to x6 lines.
- When implementing a Gen3-capable PIPE configuration in a -2 or -3 core speed grade, you cannot place the Logical PCS Master Channel in a location adjacent to the Hard IP (HIP).
- Non PCIe-Channels that are placed next to active banks with PIPE interfaces that are Gen3 capable have the following restrictions
  - When VCCR\_GXB and VCCT\_GXB are set to 1.03 V or 1.12 V, the maximum data rate supported for the non-PCIe channels in those banks is 12.5 Gbps for chip-to-chip applications. These channels cannot be used to drive backplanes or for GT rates.
  - When VCCR\_GXB and VCCT\_GXB are set to 0.95 V, the non-PCIe channels in those banks cannot be used.

For channel placement guidelines when using Arria 10 Hard IP for PCIe, refer to the *PCIe User Guide*.

For ATX PLL placement restrictions, refer to the section "Transmit PLL Recommendations Based on Data Rates" of *PLLs and Clock Networks* chapter.

#### Related Information

- [Arria 10 Avalon Memory-Mapped Interface for PCIe Solutions User Guide](#)
- [PLLs and Clock Networks](#) on page 356

#### 2.7.12.1. Master Channel in Bonded Configurations

For PCIe, both the PMA and PCS must be bonded. There is no need to specify the PMA Master Channel because of the separate Master CGB in the hardware. However, you must specify the PCS Master Channel through the Native PHY. You can choose any one of the data channels (part of the bonded group) as the logical PCS Master Channel.

**Note:** Whichever channel you pick as the PCS master, the fitter selects the physical CH1 or CH4 of a transceiver bank as the master channel. This is because the ASN and Master CGB connectivity only exists in the hardware of these two channels of the transceiver bank.

**Table 198. Logical PCS Master Channel for PIPE Configuration**

| PIPE Configuration | Logical PCS Master Channel # (default) |
|--------------------|----------------------------------------|
| x1                 | 0 <sup>(45)</sup>                      |
| x2                 | 1 <sup>(45)</sup>                      |
| x4                 | 2 <sup>(45)</sup>                      |
| x8                 | 4 <sup>(45)</sup>                      |

The following figures show the default configurations:

**Figure 111. x2 Configuration**


**Note:** The physical channel 0 aligns with logical channel 0. The logical PCS Master Channel 1 is specified as Physical Channel 1.

<sup>(45)</sup> Ensure that the Logical PCS Master Channel aligns with Physical Channel 1 or 4 in a given transceiver bank.

**Figure 112. x4 Configuration**

The figure below shows an alternate way of placing 4 bonded channels. In this case, the logical PCS Master Channel number 2 must be specified as Physical channel 4.



**Figure 113. x8 Configuration**

For x8 configurations, Intel recommends you choose a master channel that is a maximum of four channels away from the farthest slave channel.


**Note:**

The physical channel 0 aligns with logical channel 0. The logical PCS master channel 4 is specified as Physical channel 4.

**Figure 114. x4 Alternate Configuration**

The figure below shows an alternate way of placing 4 bonded channels. In this case, the logical PCS Master Channel number 2 must be specified as Physical channel 1.



As indicated in the figures above, the fitter picks either physical CH1 or CH4 as the PCS master in bonded configurations for PIPE.

**Figure 115. x4 Configuration with the Master Channel Adjacent to a Hard IP**

The figure below shows the placement of a x4 PIPE configuration with the Logical PCS Master Channel that is adjacent to a Hard IP.



**Figure 116.** x4 Configuration with the Master Channel not Adjacent to a Hard IP

The figure below shows the placement of a x4 PIPE configuration with the Logical PCS Master Channel that is not adjacent to a Hard IP.



### **2.7.13. PHY IP Core for PCIe (PIPE) Link Equalization for Gen3 Data Rate**

Gen3 mode requires TX and RX link equalization because of the data rate, the channel characteristics, receiver design, and process variations. The link equalization process allows the Endpoint and Root Port to adjust the TX and RX setup of each lane to improve signal quality. This process results in Gen3 links with a receiver Bit Error Rate (BER) that is less than  $10^{-12}$ .

For detailed information about the four-stage link equalization procedure for 8.0 GT/s data rate, refer to Section 4.2.3 in the *PCI Express Base Specification, Rev 3.0*. A new LTSSM state, Recovery.Equalization with Phases 0–3, reflects progress through Gen3 equalization. Phases 2 and 3 of link equalization are optional. Each link must progress through all four phases, even if no adjustments occur. If you skip Phases 2 and 3, you speed up link training at the expense of link BER optimization.

## Phase 0

Phase 0 includes the following steps:

1. The upstream component enters Phase 0 of equalization during Recovery.Rcvrconfig by sending EQ TS2 training sets with starting presets for the downstream component. EQ TS2 training sets may be sent at 2.5 GT/s or 5 GT/s.
2. The downstream component enters Phase 0 of equalization after exiting Recovery.Speed at 8 GT/s. It receives the starting presets from the training sequences and applies them to its transmitter. At this time, the upstream component has entered Phase 1 and is operating at 8 GT/s.
3. To move to Phase 1, the receiver must have a BER < 10<sup>-4</sup>. The receiver should be able to decode enough consecutive training sequences.
4. In order to move to Equalization Phase 1, the downstream component must detect training sets with Equalization Control (EC) bits set to 2'b01.

## Phase 1

During Phase 1 of the equalization process, the link partners exchange Full Swing (FS) and Low Frequency (LF) information. These values represent the upper and lower bounds for the TX coefficients. The receiver uses this information to calculate and request the next set of transmitter coefficients.

1. The upstream component moves to EQ Phase 2 when training sets with EC bits set to 1'b0 are captured on all lanes. It also sends EC=2'b10, starting pre-cursor, main cursor, and post-cursor coefficients.
2. The downstream component moves to EQ Phase 2 after detecting these new training sets.

Use the **pipe\_g3\_txdeemph[17:0]** port to select the transmitter de-emphasis. The 18 bits specify the following coefficients:

- [5:0]: C<sub>-1</sub>
- [11:6]: C<sub>0</sub>
- [17:12]: C<sub>+1</sub>

Refer to *Preset Mappings to TX De-emphasis* for the mapping between presets and TX de-emphasis.

## Phase 2 (Optional)

During Phase 2, the Endpoint tunes the TX coefficients of the Root Port. The TS1 Use Preset bit determines whether the Endpoint uses presets for coarse resolution or coefficients for fine resolution.

If you are using the PHY IP Core for PCI Express (PIPE) as the Root Port, the Endpoint can tune the Root Port TX coefficients.

The tuning sequence typically includes the following steps:

1. The Endpoint receives the starting presets from the Phase 2 training sets sent by the Root Port.
2. The circuitry in the Endpoint receiver determines the BER. It calculates the next set of transmitter coefficients using FS and LF. It also embeds this information in the Training Sets for the Link Partner to apply to its transmitter.

The Root Port decodes these coefficients and presets, performs legality checks for the three transmitter coefficient rules and applies the settings to its transmitter and also sends them in the Training Sets. The default Full Swing (FS) value advertised by the Intel device is 60 and Low Frequency (LF) is 20. The three rules for transmitter coefficients are:

- a.  $|C_{-1}| \leq \text{Floor}(\text{FS}/4)$
- b.  $|C_{-1}| + C_0 + |C_{+1}| = \text{FS}$
- c.  $C_0 - |C_{-1}| - |C_{+1}| \geq \text{LF}$

Where:  $C_0$  is the main cursor (boost),  $C_{-1}$  is the pre-cursor (pre-shoot), and  $C_{+1}$  is the post-cursor (de-emphasis).

3. This process is repeated until the downstream component's receiver achieves a BER of  $< 10^{-12}$

### Phase 3 (Optional)

During this phase, the Root Port tunes the Endpoint's transmitter. This process is analogous to Phase 2 but operates in the opposite direction.

After Phase 3 tuning is complete, the Root Port moves to Recovery.RcvrLock, sending EC=2'b00, and the final coefficients or preset agreed upon in Phase 2. The Endpoint moves to Recovery.RcvrLock using the final coefficients or preset agreed upon in Phase 3.

### Recommendations for Tuning Link

To improve the BER of the receiver, Intel recommends that you turn on CTLE in triggered mode during Phase 2 Equalization for Endpoints or Phase 3 Equalization for Root Ports.

Use the port `pipe_g3_txdeemph[17:0]` to transmit the coefficients corresponding to the Gen3 presets. Intel recommends transmitting Preset P8 coefficients for A10 receiver to recover data successfully. The `pipe_g3_txdeemph` is used to select the link partner's transmitter de-emphasis during equalization.

Use the port `pipe_g3_rxpresethint[2:0]` to turn on CTLE in triggered mode during equalization phases.

**Table 199. CTLE mode for Gen1/Gen2 speeds of Gen3 capable design**

Use this table to drive the `pipe_g3_rxpresethint` port and set the CTLE in manual mode when operating at Gen1/Gen2 speeds of a Gen3 capable design.

| Gen3 capable design running at Gen1/Gen2 speeds during                    | Supported CTLE - mode Manual. To use CTLE in manual mode                                                                                                                                                                                                           |
|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Power up                                                                  | <ul style="list-style-type: none"> <li>• During power up, set <code>pipe_g3_rxpresethint[2:0] = 3'b000</code></li> <li>• You can use the default CTLE 4S AC Gain set by Quartus (or)</li> <li>• Set the manual CTLE 4S AC Gain using QSF assignments</li> </ul>    |
| Down train to Gen1/Gen2 (directed or not) and subsequent re-entry to Gen3 | <ul style="list-style-type: none"> <li>• On entry to Gen1/2, set <code>pipe_g3_rxpresethint[2:0] = 3'b000</code></li> <li>• You can use the default CTLE 4S AC Gain set by Quartus (or)</li> <li>• Set the manual CTLE 4S AC Gain using QSF assignments</li> </ul> |
| Down train to Gen1/Gen2                                                   | <ul style="list-style-type: none"> <li>• On entry to Gen1/2, set <code>pipe_g3_rxpresethint[2:0] = 3'b000</code></li> <li>• You can use the default CTLE 4S AC Gain set by Quartus (or)</li> <li>• Set the manual CTLE 4S AC Gain using QSF assignments</li> </ul> |

**Note:** Intel does not support use of CTLE in adaptive mode for Gen1/Gen2 speeds. You must use CTLE in manual mode.

**Table 200. CTLE mode for Gen3 speed of Gen3 capable design**

Use this table to drive the `pipe_g3_rxpresethint` port and set the CTLE mode to adaptation mode when operating at Gen3 speed for Gen3 capable designs.

| Gen3 capable design running at Gen3 speed during                 | Supported CTLE - mode Triggered adaptation. To use CTLE in adaptation mode, Set                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1st time entry to Gen3                                           | <ul style="list-style-type: none"> <li>In EQ Phase2/3, after far end TX preset/coefficient requests are completed, set <code>pipe_g3_rxpresethint</code> = 3'b111 and link needs to stay in Recovery for at least 12ms for CTLE adaptation</li> <li>If there is not enough time in EQ phases, delay can be inserted in Recovery.RcvrLock after the EQ</li> <li>After that, <code>pipe_g3_rxpresethint</code> should remain 3'b111 for Gen3 even in Recovery</li> </ul> |
| Redoing EQ in Gen3                                               | <ul style="list-style-type: none"> <li><code>pipe_g3_rxpresethint</code> should be set to 3'b000 in EQ Phase2/3 entry</li> <li>Follow the same procedure as first time link up to Gen3</li> </ul>                                                                                                                                                                                                                                                                      |
| Re-entry to Gen3 after down train to Gen1/Gen2 (directed or not) | <ul style="list-style-type: none"> <li>On subsequent entry to Gen3, set <code>pipe_g3_rxpresethint[2:0]</code> = 3'b111 when there is valid data and wait for 12ms in Recovery state for CTLE adaptation</li> </ul>                                                                                                                                                                                                                                                    |

**Note:** Intel recommends that you use CTLE in adaptive mode for Gen3 speed. If you want to use CTLE in manual mode for Gen3 speed, then you must set `pipe_g3_rxpresethint[2:0]` = 3'b000 and set the CTLE 4S AC gain value

- You can use the default CTLE 4S AC Gain set by Quartus (or)
- Set the manual CTLE 4S AC Gain using QSF assignments

#### Related Information

- Preset Mappings to TX De-emphasis on page 274
- Continuous Time Linear Equalization (CTLE) on page 464
- PCI Express Base Specification
- PIPE Specification

### 2.7.14. Using Transceiver Toolkit (TTK)/System Console/Reconfiguration Interface to manually tune Arria 10 PCIe designs (Hard IP(HIP) and PIPE) (For debug only)

**Table 201. Manual tuning of TX analog settings for PCIe channels**

To manually tune TX channels of the Arria 10 PCIe designs using TTK/System Console/Reconfiguration Interface, you must set the following attributes

| Attribute                                      | Default value in PCIe mode | Value to be set to use TTK/ System Console | Description                                                                                                                                                                                                                    |
|------------------------------------------------|----------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>user_fir_coe_ff_ctrl_sel_0x105[7]</code> | 1'b1                       | 1'b0                                       | <p>Mux to select between static vs dynamic (port) control</p> <ul style="list-style-type: none"> <li>0 for static setting (to use TTK/ system console for manual tuning)</li> <li>1 for dynamic control (PCIe mode)</li> </ul> |

*continued...*

| Attribute                                        | Default value in PCIe mode                              | Value to be set to use TTK/ System Console                                   | Description                                                                                                                          |
|--------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
|                                                  |                                                         |                                                                              | Setting this mux affects VOD, pre tap and post tap attributes                                                                        |
| pre_emp_swit ching_ctrl_p re_tap_1t 0x107[4:0]   | Controlled by coefficients on the port pipe_g3_txdeemph | Depends on value set by pre_emp_switching_ctrl_pre_tap_1t register setting   | Sets 1st Pre tap value <ul style="list-style-type: none"> <li>• Direct mapped</li> </ul>                                             |
| pre_emp_sign _pre_tap_1t 0x107[5]                | negative                                                | Depends on value set by pre_emp_sign_pre_tap_1t register setting             | Sets 1st Pre tap sign <ul style="list-style-type: none"> <li>• -1 negative (default for PCIe mode)</li> <li>• 0 positive</li> </ul>  |
| vod_output_s wing_ctrl 0x109[4:0]                | Controlled by coefficients on the port pipe_g3_txdeemph | Depends on value set by vod_output_swing_ctrl register setting               | Output swing <ul style="list-style-type: none"> <li>• Direct mapped</li> </ul>                                                       |
| pre_emp_swit ching_ctrl_1 st_post_tap 0x105[4:0] | Controlled by coefficients on the port pipe_g3_txdeemph | Depends on value set by pre_emp_switching_ctrl_1st_post_tap register setting | Sets 1st Post tap value <ul style="list-style-type: none"> <li>• Direct mapped</li> </ul>                                            |
| pre_emp_sign _1st_post_ta p 0x105[6]             | Negative                                                | Depends on value set by pre_emp_sign_1st_post_tapregister setting            | Set 1st Post tap sign <ul style="list-style-type: none"> <li>• -1 negative (default for PCIe mode)</li> <li>• -0 positive</li> </ul> |

**Note:** You must set the attribute `user_fir_coeff_ctrl_sel` located at register address `0x105[7]` back to `1'b1` to allow the Arria 10 PCI Express PIPE design to listen to the port `pipe_g3_txdeemph[17:0]` on each channel for normal PCIe operation.

**Table 202. Manual tuning of RX analog settings for PCIe channels**

To manually tune RX channels of the Arria 10 PCI Express designs using TTK/System Console/Reconfiguration Interface, you must set the following attribute

| Attribute                   | Default value in PCIe mode | Value to be set to use TTK/ System Console                                                                                              | Description                                                                                                                                                                                                                                                |
|-----------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rrx_PCIE_EQZ 0x161[2]       | 1'b1                       | 1'b0                                                                                                                                    | Mux to select between static vs dynamic control <ul style="list-style-type: none"> <li>• 0 for static setting (use for manual tuning)</li> <li>• 1 for dynamic control (PCIe mode)</li> </ul> Setting this mux affects the CTLE 4s gain and 1s gain values |
| adp_4s_ctle_bypass 0x167[0] | 1'b0                       | <ul style="list-style-type: none"> <li>• 1'b0 for Gen3 for Adaptive 4S CTLE</li> <li>• 1'b1 for Gen1/Gen2 for Manual 4S CTLE</li> </ul> | Mux to select between CTLE 4S manual mode vs adaptive mode <ul style="list-style-type: none"> <li>• 0 for CTLE 4S adaptive mode</li> <li>• 1 for CTLE 4S manual mode</li> </ul>                                                                            |

*continued...*

| Attribute                      | Default value in PCIe mode                                 | Value to be set to use TTK/ System Console                      | Description                                                                                  |
|--------------------------------|------------------------------------------------------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| adp_ctle_acg ain_4s 0x167[5:1] | 5'b0                                                       | Depends on the value set by adp_ctle_acgain_4s Register setting | Set CTLE manual 4S AC gain <ul style="list-style-type: none"> <li>• Direct mapped</li> </ul> |
| Adp_status_s el 0x14C[5:0]     | Set the mux to 6'b011011                                   | Set the mux to 6'b011011                                        | Sets the test mux to read the CTLE converged values from 0x177[3:0]                          |
| Test_mux 0x177[3:0]            | Read values. Map 4 bit value read out to 5 bit gain values | Read values. Map 4 bit value read out to 5 bit gain values      | Reflects the converged values from CTLE adaptation                                           |

**Note:** You must set the attribute `rrx_pcie_eqz` located at register address 0x161[2] back to 1'b1 to allow the Arria 10 PCIe PIPE design to listen to the port `pipe_g3_rxpresethint[2:0]` on each channel for normal PCIe operation.

#### Related Information

- [Analog Parameter Settings](#) on page 597
- [Debugging Transceiver Links with Transceiver Toolkit](#)
- [Arria 10 Register Map](#)

## 2.8. CPRI

The common public radio interface (CPRI) is a high-speed serial interface developed for wireless network radio equipment controller (REC) to uplink and downlink data from available remote radio equipment (RE).

The CPRI protocol defines the interface of radio base stations between the REC and the RE. The physical layer supports both the electrical interfaces (for example, traditional radio base stations) and the optical interface (for example, radio base stations with a remote radio head). The scope of the CPRI specification is restricted to the link interface only, which is a point-to-point interface. The link has all the features necessary to enable a simple and robust usage of any given REC and RE network topology, including a direct interconnection of multiport REs.

## 2.8.1. Transceiver Channel Datapath and Clocking for CPRI

**Figure 117.** Transceiver Channel Datapath and Clocking for CPRI



**Table 203.** Channel Width Options for Supported Serial Data Rates

| Serial Data Rate (Mbps) | Channel Width (FPGA-PCS Fabric) |        |                 |        |     |
|-------------------------|---------------------------------|--------|-----------------|--------|-----|
|                         | 8/10 Bit Width                  |        | 16/20 Bit Width |        |     |
|                         | 8-Bit                           | 16-Bit | 16-Bit          | 32-Bit |     |
| 614.4 <sup>(46)</sup>   | Yes                             | Yes    | N/A             | N/A    |     |
| 1228.8                  | Yes                             | Yes    | Yes             | Yes    |     |
| 2457.6                  | Yes                             | Yes    | Yes             | Yes    |     |
| 3072                    | Yes                             | Yes    | Yes             | Yes    |     |
| 4915.2                  | N/A                             | N/A    | Yes             | Yes    |     |
| 6144                    | N/A                             | N/A    | Yes             | Yes    |     |
| 9830.4                  | N/A                             | N/A    | N/A             | N/A    | Yes |

**Table 204.** Interface Width Options for 10.1376 Gbps and 12.16512 Gbps Data Rates

| Serial Data Rate (Mbps) | Interface Width                  |                          |
|-------------------------|----------------------------------|--------------------------|
|                         | FPGA fabric - Enhanced PCS (bit) | Enhanced PCS - PMA (bit) |
| 10137.6                 | 66                               | 32, 40, 64               |
| 12165.12                | 66                               | 40, 64                   |

<sup>(46)</sup> Over-sampling is required to implement 614.4Mbps

### 2.8.1.1. TX PLL Selection for CPRI

Choose a transmitter PLL that fits your required data rate.

**Table 205. TX PLL Supported Data Rates**

ATX and fPLL support the clock bonding feature.

| TX PLLs | Supported Data Rate (Mbps)                                                    |
|---------|-------------------------------------------------------------------------------|
| ATX     | 614.4, 1228.8, 2457.6, 3072, 4915.2, 6144, 8110.08, 9830.4, 10137.6, 12165.12 |
| fPLL    | 614.4, 1228.8, 2457.6, 3072, 4915.2, 6144, 8110.08, 9830.4, 10137.6, 12165.12 |
| CMU     | 614.4, 1228.8, 2457.6, 3072, 4915.2, 6144, 8110.08, 9830.4, 10137.6           |

*Note:*

- Channels that use the CMU PLL cannot be bonded. The CMU PLL that provides the clock can only drive channels in the transceiver bank where it resides.
- Over-sampling is required to implement 614.4Mbps.

### 2.8.1.2. Auto-Negotiation

When auto-negotiation is required, the channels initialize at the highest supported frequency and switch to successively lower data rates if frame synchronization is not achieved. If your design requires auto-negotiation, choose a base data rate that minimizes the number of PLLs required to generate the clocks required for data transmission.

By selecting an appropriate base data rate, you can change data rates by changing the local clock generation block (CGB) divider. If a single base data rate is not possible, you can use an additional PLL to generate the required data rates.

**Table 206. Recommended Base Data Rates and Clock Generation Blocks for Available Data Rates**

| Data Rate (Mbps) | Base Data Rate (Mbps) | Local CGB Divider |
|------------------|-----------------------|-------------------|
| 1228.8           | 9830.4                | 8                 |
| 2457.6           | 9830.4                | 4                 |
| 3072.0           | 6144.0                | 2                 |
| 4915.2           | 9830.4                | 2                 |
| 6144.0           | 6144.0                | 1                 |
| 9830.4           | 9830.4                | 1                 |

### 2.8.2. Supported Features for CPRI

The CPRI protocol places stringent requirements on the amount of latency variation that is permissible through a link that implements these protocols.

CPRI (Auto) and CPRI (Manual) transceiver configuration rules are both available for CPRI designs. Both modes use the same functional blocks, but the configuration mode of the word aligner is different between the Auto and Manual modes. In CPRI (Auto) mode, the word aligner works in deterministic mode. In CPRI (Manual) mode, the word aligner works in manual mode.

To avoid transmission interference in time division multiplexed systems, every radio in a cell network requires accurate delay estimates with minimal delay uncertainty. Lower delay uncertainty is always desired for increased spectrum efficiency and bandwidth. The Arria 10 devices are designed with features to minimize the delay uncertainty for both RECs and REs.

### 2.8.2.1. Word Aligner in Deterministic Latency Mode for CPRI

The deterministic latency state machine in the word aligner reduces the known delay variation from the word alignment process. It automatically synchronizes and aligns the word boundary by slipping one half of a serial clock cycle (1UI) in the deserializer. Incoming data to the word aligner is aligned to the boundary of the word alignment pattern (K28.5).

**Figure 118. Deterministic Latency State Machine in the Word Aligner**



When using deterministic latency state machine mode, assert `rx_std_wa_patternalign` to initiate the pattern alignment after the reset sequence is complete. This is an edge-triggered signal in all cases except one: when the word aligner is in manual mode and the PMA width is 10, in which case `rx_std_wa_patternalign` is level sensitive.

**Figure 119. Word Aligner in Deterministic Mode Waveform**



#### Related Information

[Word Aligner](#) on page 497

### 2.8.2.1.1. Transmitter and Receiver Latency

The latency variation from the link synchronization function (in the word aligner block) is deterministic with the `rx_bitslipboundaryselectout` port. Additionally, you can use the `tx_bitslipboundaryselect` port to fix the round trip transceiver latency for port implementation in the remote radio head to compensate for latency variation in the word aligner block. The `tx_bitslipboundaryselect` port is available to control the number of bits to be slipped in the transmitter serial data stream. You can optionally use the `tx_bitslipboundaryselect` port to round the round-trip latency to a whole number of cycles.

When using the byte deserializer, additional logic is required in the FPGA fabric to determine if the comma byte is received in the lower or upper byte of the word. The delay is dependent on the word in which the comma byte appears.

### 2.8.3. Word Aligner in Manual Mode for CPRI

When configuring the word aligner in CPRI (Manual), the word aligner parses the incoming data stream for a specific alignment character. After `rx_digitalreset` deasserts, asserting the `rx_std_wa_patterncalign` triggers the word aligner to look for the predefined word alignment pattern or its complement in the received data stream. It is important to note that the behavior of the word aligner in Manual mode operates in different ways depending on the PCS-PMA interface width.

**Table 207. Word Aligner Signal Status Behaviors in Manual Mode**

| PCS-PMA Interface Width | <code>rx_std_wa_patterncalign</code> Behavior | <code>rx_syncstatus</code> Behavior                                             | <code>rx_patterndetect</code> Behavior |
|-------------------------|-----------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------|
| 10                      | Level sensitive                               | One parallel clock cycle (When three control patterns are detected)             | One parallel clock cycle               |
| 20                      | Edge sensitive                                | Remains asserted until next rising edge of <code>rx_std_wa_patterncalign</code> | One parallel clock cycle               |

#### PCS-PMA Width = 10

When the PCS-PMA interface width is 10, 3 consecutive word alignment patterns found after the initial word alignment in a different word boundary causes the word aligner to resynchronize to this new word boundary if the `rx_std_wa_patterncalign` remains asserted; `rx_std_wa_patterncalign` is level sensitive. If you deassert `rx_std_wa_patterncalign`, the word aligner maintains the current word boundary even when it finds the alignment pattern in a new word boundary. When the word aligner is synchronized to the new word boundary, `rx_patterndetect` and `rx_syncstatus` are asserted for one parallel clock cycle.

#### PCS-PMA Width = 20

When the PMA-PCS width is 20, any alignment pattern found after the initial alignment in a different word boundary causes the word aligner to resynchronize to this new word boundary on the rising edge of `rx_std_wa_patterncalign`; `rx_std_wa_patterncalign` is edge sensitive. The word aligner maintains the current word boundary until the next rising edge of `rx_std_wa_patterncalign`. When the word aligner is synchronized to the new word boundary, `rx_patterndetect` asserts for one parallel clock cycle and `rx_syncstatus` remains asserted until the next rising edge of `rx_std_wa_patterncalign`.

**Figure 120. Word Aligner in Manual Alignment Mode Waveform**



#### Related Information

[Word Aligner](#) on page 497

## 2.8.4. How to Implement CPRI in Arria 10 Transceivers

You should be familiar with the Standard PCS and PMA architecture, PLL architecture, and the reset controller before implementing your CPRI protocol.

1. Instantiate the **Arria 10 Transceiver Native PHY IP** from the IP Catalog. Refer to [Select and Instantiate the PHY IP Core](#) on page 33 for more details.
2. Select **CPRI (Auto)** or **CPRI (Manual)** from the **Transceiver configuration rules** list located under **Datapath Options**, depending on which protocol you are implementing.
3. Use the parameter values in the tables in [Native PHY IP Parameter Settings for CPRI](#) on page 292 as a starting point. Or, you can use the protocol presets described in [Preset Configuration Options](#). You can then modify the setting to meet your specific requirements.
4. Click **Generate** to generate the Native PHY IP (this is your RTL file).

**Figure 121. Signals and Ports of Native PHY IP for CPRI**



5. Instantiate and configure your PLL.
6. Create a transceiver reset controller.  
You can use your own reset controller or use the Native PHY Reset Controller IP.
7. Connect the Native PHY IP to the PLL IP core and the reset controller. Use the information in the following figure to connect the ports.

**Figure 122. Connection Guidelines for a CPRI PHY Design**


8. Simulate your design to verify its functionality.

#### Related Information

- [Arria 10 Standard PCS Architecture](#) on page 491  
For more information about Standard PCS architecture
- [Arria 10 PMA Architecture](#) on page 459  
For more information about PMA architecture
- [Using PLLs and Clock Networks](#) on page 410  
For more information about implementing PLLs and clocks
- [PLLs](#) on page 358  
PLL architecture and implementation details
- [Resetting Transceiver Channels](#) on page 428  
Reset controller general information and implementation details
- [Standard PCS Ports](#) on page 87  
Port definitions for the Transceiver Native PHY Standard Datapath

#### 2.8.5. Native PHY IP Parameter Settings for CPRI

**Table 208. General and Datapath Options**

The first two sections of the Parameter Editor for the Native PHY IP provide a list of general and datapath options to customize the transceiver.

| Parameter                                | Value        |
|------------------------------------------|--------------|
| <b>Message level for rule violations</b> | <b>error</b> |
| <i>continued...</i>                      |              |

| Parameter                                            | Value                                                                                                                                                               |
|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                      | <b>warning</b>                                                                                                                                                      |
| <b>Transceiver configuration rules</b>               | <b>CPRI (Auto)<br/>CPRI (Manual)</b>                                                                                                                                |
| <b>PMA configuration rules</b>                       | <b>basic</b>                                                                                                                                                        |
| <b>Transceiver mode</b>                              | <b>TX/RX Duplex</b>                                                                                                                                                 |
| <b>Number of data channels</b>                       | <b>1-36</b>                                                                                                                                                         |
| <b>Data rate</b>                                     | 1228.8 Mbps<br>2457.6 Mbps<br>3072 Mbps<br>4915.2 Mbps<br>6144 Mbps<br>8110.08 Mbps<br>9830.4 Mbps<br>10137.6 Mbps <sup>(47)</sup><br>12165.12 Mbps <sup>(47)</sup> |
| <b>Enable datapath and interface reconfiguration</b> | <b>Off</b>                                                                                                                                                          |
| <b>Enable simplified data interface</b>              | <b>On</b>                                                                                                                                                           |

**Table 209. TX PMA Parameters**

| Parameter                                        | Value                                                      |
|--------------------------------------------------|------------------------------------------------------------|
| <b>TX channel bonding mode</b>                   | <b>Not Bonded / PMA Bonding Only / PMA and PCS Bonding</b> |
| <b>TX local clock division factor</b>            | <b>1</b>                                                   |
| <b>Number of TX PLL clock inputs per channel</b> | <b>1</b>                                                   |
| <b>Initial TX PLL clock input selection</b>      | <b>0</b>                                                   |
| <b>Enable tx_pma_clkout port</b>                 | <b>Off</b>                                                 |
| <b>Enable tx_pma_div_clkout port</b>             | <b>On</b>                                                  |
| <b>tx_pma_div_clkout division factor</b>         | <b>2</b>                                                   |
| <b>Enable tx_pma_elecidle port</b>               | <b>Off</b>                                                 |
| <b>Enable tx_pma_qpipullup port (QPI)</b>        | <b>Off</b>                                                 |
| <b>Enable tx_pma_qpipulldn port (QPI)</b>        | <b>Off</b>                                                 |
| <b>Enable tx_pma_txdetectrx port (QPI)</b>       | <b>Off</b>                                                 |
| <b>Enable tx_pma_rxfound port (QPI)</b>          | <b>Off</b>                                                 |
| <b>Enable rx_seriallpbken port</b>               | <b>Off</b>                                                 |

<sup>(47)</sup> 10137.6 Mbps and 12165.12 Mbps are implemented by selecting 10GBase-R or 10GBase-R 1588 under Transceiver configuration rules. The Enhanced PCS is selected when the CPRI data rate is 10137.6 Mbps and above.

**Table 210. RX PMA Parameters**

| Parameter                                                  | Value                                                    |
|------------------------------------------------------------|----------------------------------------------------------|
| <b>Number of CDR reference clocks</b>                      | <b>1</b>                                                 |
| <b>Selected CDR reference clock</b>                        | <b>0</b>                                                 |
| <b>Selected CDR reference clock frequency</b>              | Select legal range defined by the Quartus Prime software |
| <b>PPM detector threshold</b>                              | <b>1000</b>                                              |
| <b>CTLE adaptation mode</b>                                | <b>manual</b>                                            |
| <b>DFE adaptation mode</b>                                 | <b>disabled</b>                                          |
| <b>Number of fixed dfe taps</b>                            | <b>3</b>                                                 |
| <b>Enable rx_pma_clkout port</b>                           | <b>Off</b>                                               |
| <b>Enable rx_pma_div_clkout port</b>                       | <b>On</b>                                                |
| <b>rx_pma_div_clkout division factor</b>                   | <b>2</b>                                                 |
| <b>Enable rx_pma_clkslip port</b>                          | <b>Off</b>                                               |
| <b>Enable rx_pma_qpipulldn port (QPI)</b>                  | <b>Off</b>                                               |
| <b>Enable rx_is_lockedtodata port</b>                      | <b>On</b>                                                |
| <b>Enable rx_is_lockedtoref port</b>                       | <b>On</b>                                                |
| <b>Enable rx_set_locktodata and rx_set_locktoref ports</b> | <b>Off</b>                                               |
| <b>Enable rx_serialpbken port</b>                          | <b>Off</b>                                               |
| <b>Enable PRBS verifier control and status ports</b>       | <b>Off</b>                                               |

**Table 211. Standard PCS Parameters**

| Parameters                                           | Value                 |
|------------------------------------------------------|-----------------------|
| <b>Standard PCS / PMA interface width</b>            | <b>20</b>             |
| <b>FPGA fabric / Standard TX PCS interface width</b> | <b>32</b>             |
| <b>FPGA fabric / Standard RX PCS interface width</b> | <b>32</b>             |
| <b>Enable 'Standard PCS' low latency mode</b>        | <b>Off</b>            |
| <b>TX FIFO mode</b>                                  | <b>register_fifo</b>  |
| <b>RX FIFO mode</b>                                  | <b>register_fifo</b>  |
| <b>Enable tx_std_pcfifo_full port</b>                | <b>Off</b>            |
| <b>Enable tx_std_pcfifo_empty port</b>               | <b>Off</b>            |
| <b>Enable rx_std_pcfifo_full port</b>                | <b>Off</b>            |
| <b>Enable rx_std_pcfifo_empty port</b>               | <b>Off</b>            |
| <b>TX byte serializer mode</b>                       | <b>Serialize x2</b>   |
| <b>RX byte deserializer mode</b>                     | <b>Deserialize x2</b> |
| <b>Enable TX 8B/10B encoder</b>                      | <b>On</b>             |
| <b>Enable TX 8B/10B disparity control</b>            | <b>Off</b>            |
| <b>Enable RX 8B/10B decoder</b>                      | <b>On</b>             |

*continued...*

| Parameters                                                            | Value                                                                                                                        |
|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| <b>RX rate match FIFO mode</b>                                        | <b>Disabled</b>                                                                                                              |
| <b>RX rate match insert / delete -ve pattern (hex)</b>                | 0x00000000                                                                                                                   |
| <b>RX rate match insert / delete +ve pattern (hex)</b>                | 0x00000000                                                                                                                   |
| <b>Enable rx_std_rmfifo_full port</b>                                 | <b>Off</b>                                                                                                                   |
| <b>Enable rx_std_rmfifo_empty port</b>                                | <b>Off</b>                                                                                                                   |
| <b>PCI Express Gen3 rate match FIFO mode</b>                          | <b>Bypass</b>                                                                                                                |
| <b>Enable TX bit slip</b>                                             | <b>Off</b> (CPRI Auto configuration)<br><b>On</b> (CPRI Manual configuration)                                                |
| <b>Enable tx_std_bitslipboundarysel port</b>                          | <b>Off</b> (CPRI Auto configuration)<br><b>On</b> (CPRI Manual configuration)                                                |
| <b>RX word aligner mode</b>                                           | <b>deterministic latency</b> (CPRI Auto configuration)<br><b>manual (FPGA fabric controlled)</b> (CPRI Manual configuration) |
| <b>RX word aligner pattern length</b>                                 | <b>10</b>                                                                                                                    |
| <b>RX word aligner pattern (hex)</b>                                  | 0x0000000000000017c                                                                                                          |
| <b>Number of word alignment patterns to achieve sync</b>              | <b>3</b> (48)                                                                                                                |
| <b>Number of invalid data words to lose sync</b>                      | <b>3</b> (48)                                                                                                                |
| <b>Number of valid data words to decrement error count</b>            | <b>3</b> (48)                                                                                                                |
| <b>Enable fast sync status reporting for deterministic latency SM</b> | <b>On / Off</b>                                                                                                              |
| <b>Enable rx_std_wa_patternalign port</b>                             | <b>On / Off</b>                                                                                                              |
| <b>Enable rx_std_wa_a1a2size port</b>                                 | <b>Off</b>                                                                                                                   |
| <b>Enable rx_std_bitslipboundarysel port</b>                          | <b>Off</b> (CPRI Auto configuration)<br><b>On</b> (CPRI Manual configuration)                                                |
| <b>Enable rx_bitslip port</b>                                         | <b>Off</b> (CPRI Auto configuration)<br><b>On</b> (CPRI Manual configuration)                                                |
| All options under <b>Bit Reversal and Polarity Inversion</b>          | <b>Off</b>                                                                                                                   |
| All options under <b>PCIe Ports</b>                                   | <b>Off</b>                                                                                                                   |

**Table 212. Dynamic Reconfiguration**

| Parameter                                      | Value      |
|------------------------------------------------|------------|
| <b>Enable dynamic reconfiguration</b>          | <b>Off</b> |
| <b>Share reconfiguration interface</b>         | <b>Off</b> |
| <b>Enable Native PHY Debug Master Endpoint</b> | <b>Off</b> |
| <b>Enable embedded debug</b>                   | <b>Off</b> |
| <b>Enable capability registers</b>             | <b>Off</b> |
| <b>Set user-defined IP identifier</b>          | <b>0</b>   |

*continued...*

(48) These are unused when the transceiver PHY is in CPRI mode.

| Parameter                                        | Value                  |
|--------------------------------------------------|------------------------|
| <b>Enable control and status registers</b>       | <b>Off</b>             |
| <b>Enable prbs soft accumulators</b>             | <b>Off</b>             |
| <b>Configuration file prefix</b>                 | altera_xcvr_native_a10 |
| <b>Generate SystemVerilog package file</b>       | <b>Off</b>             |
| <b>Generate C header file</b>                    | <b>Off</b>             |
| <b>Generate MIF (Memory Initialization File)</b> | <b>Off</b>             |

**Table 213. Generation Options**

| Parameter                                    | Value     |
|----------------------------------------------|-----------|
| <b>Generate parameter documentation file</b> | <b>On</b> |

## 2.9. Other Protocols

### 2.9.1. Using the "Basic (Enhanced PCS)" and "Basic with KR FEC" Configurations of Enhanced PCS

You can use Arria 10 transceivers to configure the Enhanced PCS to support other 10G or 10G-like protocols. The Basic (Enhanced PCS) transceiver configuration rule allows access to the Enhanced PCS with full user control over the transceiver interfaces, parameters, and ports.

You can configure the transceivers for Basic functionality using the **Native PHY IP Basic (Enhanced PCS)** transceiver configuration rule.

Basic with KR FEC is a KR FEC sublayer support with a low latency physical coding sublayer (PCS). The KR FEC sublayer increases the bit error rate (BER) performance of a link. This mode can run up to a data rate of 25.8 Gbps. Use this configuration to implement applications with low latency or low BER requirements or applications such as 10 Gbps, 40 Gbps or 100 Gbps Ethernet over backplane (10GBASE-KR protocol).

The Forward Error Correction (FEC) function is defined in Clause 74 of IEEE 802.3ap-2007. FEC provides an error detection and correction mechanism that allows noisy channels to achieve the Ethernet-mandated Bit Error Rate (BER) of  $10^{-12}$ . The FEC sublayer provides additional link margin by compensating for variations in manufacturing and environmental conditions. To distinguish it from other FEC mechanisms (for example, Optical Transport Network FEC), FEC as defined in Clause 74 of IEEE 802.3ap-2007 is called KR FEC.

**Note:** This configuration supports the FIFO in phase compensation and register modes, and KR FEC PCS blocks. You can implement all other required logic for your specific application, such as standard or proprietary protocol multi-channel alignment, either in the FPGA fabric in soft IP or use Intel's 10GBASE-KR PHY IP core product as full solutions in the FPGA.

**Figure 123. Transceiver Channel Datapath and Clocking for Basic (Enhanced PCS) Configuration**



**Figure 124. Transceiver Channel Datapath and Clocking for a Basic with KR FEC Configuration**

Clock frequencies in this figure are examples based on a 10.3125 Gbps data rate.



### 2.9.1.1. How to Implement the Basic (Enhanced PCS) and Basic with KR FEC Transceiver Configuration Rules in Arria 10 Transceivers

You should be familiar with the Basic (Enhanced PCS) and PMA architecture, PLL architecture, and the reset controller before implementing the Basic (Enhanced PCS) or Basic with KR FEC Transceiver Configuration Rule.

1. Open the IP Catalog and select the **Arria 10 Transceiver Native PHY IP**. Refer to [Select and Instantiate the PHY IP Core](#) on page 33 for more details.
2. Select **Basic (Enhanced PCS)** or **Basic with KR FEC** from the **Transceiver Configuration Rules** list located under **Datapath Options**.
3. Use the parameter values in the tables in [Transceiver Native PHY IP Parameters for Basic \(Enhanced PCS\) and Basic with KR FEC Transceiver Configuration Rules](#) as a starting point. Or, you can use the protocol presets described in [Transceiver Native PHY Presets](#). You can then modify the settings to meet your specific requirements.
4. Click **Finish** to generate the Native PHY IP (this is your RTL file).

**Figure 125. Signals and Ports of Native PHY IP for Basic (Enhanced PCS) and Basic with KR FEC Configurations**



5. Configure and instantiate the PLL.
6. Create a transceiver reset controller. You can use your own reset controller or use the Transceiver PHY Reset Controller.
7. Connect the Native PHY IP core to the PLL IP core and the reset controller.

**Figure 126. Connection Guidelines for a Basic (Enhanced PCS) Transceiver Design**



**Figure 127. Connection Guidelines for a Basic with KR FEC Transceiver Design**


8. Simulate your design to verify its functionality.

#### Related Information

- [Arria 10 Enhanced PCS Architecture](#) on page 473  
For more information about Enhanced PCS architecture
- [Arria 10 PMA Architecture](#) on page 459  
For more information about PMA architecture
- [Using PLLs and Clock Networks](#) on page 410  
For more information about implementing PLLs and clocks
- [PLLs](#) on page 358  
PLL architecture and implementation details
- [Resetting Transceiver Channels](#) on page 428  
Reset controller general information and implementation details
- [Enhanced PCS Ports](#) on page 77  
For detailed information about the available ports in the Basic protocol.

#### 2.9.1.2. Native PHY IP Parameter Settings for Basic (Enhanced PCS) and Basic with KR FEC

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

**Table 214. General and Datapath Parameters**

The first two sections of the Parameter Editor for the Transceiver Native PHY provide a list of general and datapath options to customize the transceiver.

| Parameter                         | Range                                                                                            |
|-----------------------------------|--------------------------------------------------------------------------------------------------|
| Message level for rule violations | error, warning                                                                                   |
| Transceiver configuration rules   | Basic (Enhanced PCS), Basic w/KR FEC                                                             |
| PMA configuration rules           | Basic, QPI, GPON                                                                                 |
| Transceiver mode                  | TX / RX Duplex, TX Simplex, RX Simplex                                                           |
| Number of data channels           | 1 to 96                                                                                          |
| Data rate                         | GX transceiver channel: <b>1 Gbps</b> <sup>(49)</sup> to <b>17.4 Gbps</b><br><i>continued...</i> |

| Parameter                                            | Range                                                                                     |
|------------------------------------------------------|-------------------------------------------------------------------------------------------|
|                                                      | GT transceiver channel: <b>1 Gbps</b> <sup>(49)</sup> to <b>25.8 Gbps</b> <sup>(50)</sup> |
| <b>Enable datapath and interface reconfiguration</b> | <b>On / Off</b>                                                                           |
| <b>Enable simplified data interface</b>              | <b>On / Off</b>                                                                           |

**Table 215. TX PMA Parameters**

| Parameter                                        | Range                                                            |
|--------------------------------------------------|------------------------------------------------------------------|
| <b>TX channel bonding mode</b>                   | <b>Not bonded, PMA only bonding, PMA and PCS bonding</b>         |
| <b>PCS TX channel bonding master</b>             | <b>Auto, 0 to n-1, n</b> (where n = the number of data channels) |
| <b>Actual PCS TX channel bonding master</b>      | <b>n-1</b> (where n = the number of data channels)               |
| <b>TX local clock division factor</b>            | <b>1, 2, 4, 8</b>                                                |
| <b>Number of TX PLL clock inputs per channel</b> | <b>1, 2, 3, 4</b>                                                |
| <b>Initial TX PLL clock input selection</b>      | <b>0</b>                                                         |
| <b>Enable tx_pma_clkout port</b>                 | <b>On / Off</b>                                                  |
| <b>Enable tx_pma_div_clkout port</b>             | <b>On / Off</b>                                                  |
| <b>tx_pma_div_clkout division factor</b>         | <b>Disabled, 1, 2, 33, 40, 66</b>                                |
| <b>Enable tx_pma_elecidle port</b>               | <b>On / Off</b>                                                  |
| <b>Enable tx_pma_qpipullup port (QPI)</b>        | <b>On / Off</b>                                                  |
| <b>Enable tx_pma_qpipulldn port (QPI)</b>        | <b>On / Off</b>                                                  |
| <b>Enable tx_pma_txdetectrx port (QPI)</b>       | <b>On / Off</b>                                                  |
| <b>Enable tx_pma_rxfound port (QPI)</b>          | <b>On / Off</b>                                                  |
| <b>Enable rx_serialpbken port</b>                | <b>On / Off</b>                                                  |

**Table 216. RX PMA Parameters**

| Parameter                                     | Range                                                                                                   |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------|
| <b>Number of CDR reference clocks</b>         | <b>1 to 5</b>                                                                                           |
| <b>Selected CDR reference clock</b>           | <b>0 to 4</b>                                                                                           |
| <b>Selected CDR reference clock frequency</b> | For Basic (Enhanced PCS): Depends on the data rate parameter<br>For Basic with KR FEC: <b>50 to 800</b> |
| <b>PPM detector threshold</b>                 | <b>100, 300, 500, 1000</b>                                                                              |
| <b>CTLE adaptation mode</b>                   | <b>manual</b>                                                                                           |
| <b>DFE adaptation mode</b>                    | <b>adaptation enabled, manual, disabled</b>                                                             |
| <b>Number of fixed dfe taps</b>               | <b>3, 7</b>                                                                                             |
| <b>Enable rx_pma_clkout port</b>              | <b>On / Off</b>                                                                                         |

*continued...*

<sup>(49)</sup> Applies when operating in reduced power modes. For standard power modes, the Enhanced PCS minimum data rate is 1600 Mbps.

<sup>(50)</sup> The Enhanced PCS must be configured in basic mode to support this data rate range.

| Parameter                                                  | Range                             |
|------------------------------------------------------------|-----------------------------------|
| <b>Enable rx_pma_div_clkout port</b>                       | <b>On / Off</b>                   |
| <b>rx_pma_div_clkout division factor</b>                   | <b>Disabled, 1, 2, 33, 40, 66</b> |
| <b>Enable rx_pma_clkslip port</b>                          | <b>On / Off</b>                   |
| <b>Enable rx_pma_qpipulldn port (QPI)</b>                  | <b>On / Off</b>                   |
| <b>Enable rx_is_lockedtodata port</b>                      | <b>On / Off</b>                   |
| <b>Enable rx_is_lockedtoref port</b>                       | <b>On / Off</b>                   |
| <b>Enable rx_set_locktodata and rx_set_locktoref ports</b> | <b>On / Off</b>                   |
| <b>Enable rx_serialpbken port</b>                          | <b>On / Off</b>                   |
| <b>Enable PRBS verifier control and status ports</b>       | <b>On / Off</b>                   |

**Table 217. Enhanced PCS Parameters**

| Parameter                                                  | Range                                                                                                                                                     |
|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enhanced PCS/PMA interface width</b>                    | <b>32, 40, 64</b><br>Note: Basic with KR FEC allows <b>64</b> only                                                                                        |
| <b>FPGA fabric/Enhanced PCS interface width</b>            | <b>32, 40, 50, 64, 66, 67</b><br>Note: Basic with KR FEC allows <b>66</b> only                                                                            |
| <b>Enable Enhanced PCS low latency mode</b>                | <b>On / Off</b>                                                                                                                                           |
| <b>Enable RX/TX FIFO double width mode</b>                 | <b>On / Off</b>                                                                                                                                           |
| <b>TX FIFO mode</b>                                        | <b>Phase compensation, Register, Interlaken, Basic, Fast register</b><br>Note: Only <b>Basic Enhanced</b> and <b>Basic Enhanced with KRFEC</b> are valid. |
| <b>TX FIFO partially full threshold</b>                    | <b>10, 11, 12, 13, 14, 15</b>                                                                                                                             |
| <b>TX FIFO partially empty threshold</b>                   | <b>1, 2, 3, 4, 5</b>                                                                                                                                      |
| <b>Enable tx_enh_fifo_full port</b>                        | <b>On / Off</b>                                                                                                                                           |
| <b>Enable tx_enh_fifo_pfull port</b>                       | <b>On / Off</b>                                                                                                                                           |
| <b>Enable tx_enh_fifo_empty port</b>                       | <b>On / Off</b>                                                                                                                                           |
| <b>Enable tx_enh_fifo_pempty port</b>                      | <b>On / Off</b>                                                                                                                                           |
| <b>RX FIFO mode</b>                                        | <b>Phase Compensation, Register, Basic</b>                                                                                                                |
| <b>RX FIFO partially full threshold</b>                    | <b>0 to 31</b>                                                                                                                                            |
| <b>RX FIFO partially empty threshold</b>                   | <b>0 to 31</b>                                                                                                                                            |
| <b>Enable RX FIFO alignment word deletion (Interlaken)</b> | <b>On / Off</b>                                                                                                                                           |
| <b>Enable RX FIFO control word deletion (Interlaken)</b>   | <b>On / Off</b>                                                                                                                                           |
| <b>Enable rx_enh_data_valid port</b>                       | <b>On / Off</b>                                                                                                                                           |
| <b>Enable rx_enh_fifo_full port</b>                        | <b>On / Off</b>                                                                                                                                           |
| <b>Enable rx_enh_fifo_pfull port</b>                       | <b>On / Off</b>                                                                                                                                           |
| <b>Enable rx_enh_fifo_empty port</b>                       | <b>On / Off</b>                                                                                                                                           |
| <b>Enable rx_enh_fifo_pempty port</b>                      | <b>On / Off</b>                                                                                                                                           |

*continued...*

| Parameter                                             | Range           |
|-------------------------------------------------------|-----------------|
| <b>Enable rx_enh_fifo_del port (10GBASE-R)</b>        | <b>On / Off</b> |
| <b>Enable rx_enh_fifo_insert port (10GBASE-R)</b>     | <b>On / Off</b> |
| <b>Enable rx_enh_fifo_rd_en port (Interlaken)</b>     | <b>On / Off</b> |
| <b>Enable rx_enh_fifo_align_val port (Interlaken)</b> | <b>On / Off</b> |
| <b>Enable rx_enh_fifo_align_cir port (Interlaken)</b> | <b>On / Off</b> |
| <b>Enable TX 64b/66b encoder</b>                      | <b>On / Off</b> |
| <b>Enable RX 64b/66b decoder</b>                      | <b>On / Off</b> |
| <b>Enable TX sync header error insertion</b>          | <b>On / Off</b> |
| <b>Enable RX block synchronizer</b>                   | <b>On / Off</b> |
| <b>Enable rx_enh_blk_lock port</b>                    | <b>On / Off</b> |
| <b>Enable TX data bitslip</b>                         | <b>On / Off</b> |
| <b>Enable TX data polarity inversion</b>              | <b>On / Off</b> |
| <b>Enable RX data bitslip</b>                         | <b>On / Off</b> |
| <b>Enable RX data polarity inversion</b>              | <b>On / Off</b> |
| <b>Enable tx_enh_bitslip port</b>                     | <b>On / Off</b> |
| <b>Enable rx_bitslip port</b>                         | <b>On / Off</b> |
| <b>Enable RX KR-FEC error marking</b>                 | <b>On / Off</b> |
| <b>Error marking type</b>                             | <b>10G, 40G</b> |
| <b>Enable KR-FEC TX error insertion</b>               | <b>On / Off</b> |
| <b>KR-FEC TX error insertion spacing</b>              | <b>On / Off</b> |
| <b>Enable tx_enh_frame port</b>                       | <b>On / Off</b> |
| <b>Enable rx_enh_frame port</b>                       | <b>On / Off</b> |
| <b>Enable rx_enh_frame_dian_status port</b>           | <b>On / Off</b> |

**Table 218. Dynamic Reconfiguration Parameters**

| Parameter                                      | Range           |
|------------------------------------------------|-----------------|
| <b>Enable dynamic reconfiguration</b>          | <b>On / Off</b> |
| <b>Share reconfiguration interface</b>         | <b>On / Off</b> |
| <b>Enable Native PHY Debug Master Endpoint</b> | <b>On / Off</b> |
| <b>Enable embedded debug</b>                   | <b>On / Off</b> |
| <b>Enable capability registers</b>             | <b>On / Off</b> |
| <b>Set user-defined IP identifier</b>          | number          |
| <b>Enable control and status registers</b>     | <b>On / Off</b> |
| <b>Enable prbs soft accumulators</b>           | <b>On / Off</b> |
| <b>Configuration file prefix</b>               | text string     |
| <b>Generate SystemVerilog package file</b>     | <b>On / Off</b> |
| <b>Generate C header file</b>                  | <b>On / Off</b> |

**Table 219. Generate Options Parameters**

| Parameter                             | Range    |
|---------------------------------------|----------|
| Generate parameter documentation file | On / Off |

#### Related Information

Using the Arria 10 Transceiver Native PHY IP Core on page 45

### 2.9.1.3. How to Enable Low Latency in Basic Enhanced PCS

In the Parameter Editor, use the following settings to enable low latency:

1. Select the **Enable 'Enhanced PCS' low latency mode** option.
2. Select one of the following gear ratios:
  - Single-width mode: **32:32, 40:40, 64:64, 66:40, 66:64, or 64:32**
  - Double-width mode: **40:40, 64:64, or 66:64**
3. Select **Phase\_compensation** in the TX and RX FIFO mode list.
4. If you need the Scrambler and Descrambler features, enable **Block Synchronize** and use the **66:32, 66:40, or 66:64** gear ratio.

### 2.9.1.4. Enhanced PCS FIFO Operation

#### Phase Compensation Mode

Phase compensation mode ensures correct data transfer between the core clock and parallel clock domains. The read and write sides of the TX Core or RX Core FIFO must be driven by the same clock frequency. The depth of the TX or RX FIFO is constant in this mode. Therefore, the TX Core or RX Core FIFO flag status can be ignored. You can tie tx\_fifo\_wr\_en or rx\_data\_valid to 1.

#### Basic Mode

Basic mode allows you to drive the write and read side of a FIFO with different clock frequencies. tx\_coreclk or rx\_coreclk must have a minimum frequency of the lane data rate divided by 66. The frequency range for tx\_coreclk or rx\_coreclk is (data rate/32) to (data rate/66). For best results, Intel recommends that tx\_coreclk or rx\_coreclk be set to (data rate/32). Monitor the FIFO flag to control write and read operations.

For TX FIFO, assert tx\_enh\_data\_valid with the tx\_fifo\_pfull signal going low. This can be done with the following example assignment:

```
assign tx_enh_data_valid = ~tx_fifo_pfull;
```

**Figure 128. TX FIFO Basic Mode Operation**



For RX FIFO, assert `rx_enh_read_en` with the `rx_fifo_pempty` signal going low. This can be done with the following example assignment:

```
assign rx_enh_read_en = ~rx_fifo_pempty;
```

**Figure 129. RX FIFO Basic Mode Operation**



If you are using even gear ratios, the `rx_enh_data_valid` signal is always high. For uneven gear ratios, `rx_enh_data_valid` toggles. RX parallel data is valid when `rx_enh_data_valid` is high. Discard invalid RX parallel data when the `rx_enh_datavalid` signal is low.

### Register and Fast Register Mode

This FIFO mode is used for protocols, which require deterministic latency. You can tie `tx_fifo_wr_en` to 1.

#### 2.9.1.5. TX Data Bitslip

The bit slip feature in the TX gearbox allows you to slip the transmitter bits before they are sent to the serializer.

The value specified on the TX bit slip bus indicates the number of bit slips. The minimum slip is one UI. The maximum number of bits slipped is equal to the FPGA fabric-to-transceiver interface width minus 1. For example, if the FPGA fabric-to-transceiver interface width is 64 bits, the bit slip logic can slip a maximum of 63 bits. Each channel has 6 bits to determine the number of bits to slip. The TX bit slip bus is a level-sensitive port, so the TX serial data is bit slipped statically by TX bit slip port

assignments. Each TX channel has its own TX bit slip assignment and the bit slip amount is relative to the other TX channels. You can improve lane-to-lane skew by assigning TX bit slip ports with proper values.

The following figure shows the effect of slipping tx\_serial\_data[0] by one UI to reduce the skew with tx\_serial\_data[1]. After the bit slip, tx\_serial\_data[0] and tx\_serial\_data[1] are aligned.

**Figure 130. TX Bit Slip**



### 2.9.1.6. TX Data Polarity Inversion

Use the TX data polarity inversion feature to swap the positive and negative signals of a serial differential link if they were erroneously swapped during board layout. To enable TX data polarity inversion, select the **Enable TX data polarity inversion** option in the **Gearbox** section of Platform Designer (Standard). It can also be dynamically controlled with dynamic reconfiguration. The Enhanced PCS only supports the static polarity inversion feature.

### 2.9.1.7. RX Data Bitslip

The RX data bit slip in the RX gearbox allows you to slip the recovered data. An asynchronous active high edge on the rx\_bitslip port changes the word boundary, shifting rx\_parallel\_data one bit at a time. Use the rx\_bitslip port with its own word aligning logic. Assert the rx\_bitslip signal for at least two parallel clock cycles to allow synchronization. You can verify the word alignment by monitoring rx\_parallel\_data. Using the RX data bit slip feature is optional.

**Figure 131. RX Bit Slip**



### 2.9.1.8. RX Data Polarity Inversion

Use the RX data polarity inversion feature to swap the positive and negative signals of a serial differential link if they were erroneously swapped during board layout. To enable RX data polarity inversion, select the **Enable RX data polarity inversion** option in the Gearbox section of Platform Designer (Standard). It can also be dynamically controlled with dynamic reconfiguration. The Enhanced PCS only supports the static polarity inversion feature.

## 2.9.2. Using the Basic/Custom, Basic/Custom with Rate Match Configurations of Standard PCS

Use one of the following transceiver configuration rules to implement protocols such as SONET/SDH, SDI/HD, SATA, or your own custom protocol:

- Basic protocol
- Basic protocol with low latency enabled
- Basic with rate match protocol

**Figure 132. Transceiver Channel Datapath and Clocking for the Basic and Basic with Rate Match Configurations**

The clocking calculations in this figure are for an example when the data rate is 1250 Mbps and the PMA width is 10 bits.



Notes:

1. The parallel clock (tx\_clkout or rx\_clkout) is calculated as data rate/PCS-PMA interface width =  $1250/10 = 125 MHz.$
2. When the Byte Serializer is set to Serialize x2 mode, tx\_clkout and rx\_clkout become  $1250/20 = 62.5 MHz.$
3. This block is only enabled when using the Basic with Rate Match transceiver configuration rule.

In low latency modes, the transmitter and receiver FIFOs are always enabled. Depending on the targeted data rate, you can optionally bypass the byte serializer and deserializer blocks.

**Figure 133. Transceiver Channel Datapath and Clocking for Basic Configuration with Low Latency Enabled**

The clocking calculations in this figure are for an example when the data rate is 1250 Mbps and the PMA width is 10 bits.



In low latency modes, the transmitter and receiver FIFOs are always enabled. Depending on the targeted data rate, you can optionally bypass the byte serializer and deserializer blocks.

### Related Information

[Arria 10 Standard PCS Architecture](#) on page 491

#### 2.9.2.1. Word Aligner Manual Mode

To use this mode:

1. Set the **RX word aligner mode** to **Manual (FPGA Fabric controlled)**.
2. Set the **RX word aligner pattern length** option according to the PCS-PMA interface width.
3. Enter a hexadecimal value in the **RX word aligner pattern (hex)** field.

This mode adds **rx\_patterndetect** and **rx\_syncstatus**. You can select the **Enable rx\_std\_wa\_patternalign port** option to enable **rx\_std\_wa\_patternalign**. An active high on **rx\_std\_wa\_patternalign** re-aligns the word aligner one time.

**Note:**

- `rx_patterndetect` is asserted whenever there is a pattern match.
- `rx_syncstatus` is asserted after the word aligner achieves synchronization.
- `rx_std_wa_patternalign` is asserted to re-align and resynchronize.
- If there is more than one channel in the design, `rx_patterndetect`, `rx_syncstatus` and `rx_std_wa_patternalign` become buses in which each bit corresponds to one channel.

You can verify this feature by monitoring `rx_parallel_data`.

The following timing diagrams demonstrate how to use the ports and show the relationship between the various control and status signals. In the top waveform, `rx_parallel_data` is initially misaligned. After asserting the `rx_std_wa_patternalign` signal, it becomes aligned. The bottom waveform shows the behavior of the `rx_syncstatus` signal when `rx_parallel_data` is already aligned.

**Figure 134. Manual Mode when the PCS-PMA Interface Width is 8 Bits**



In manual alignment mode, the word alignment operation is manually controlled with the `rx_std_wa_patternalign` input signal or the `rx_enapatternalign` register. The word aligner operation is level-sensitive to `rx_enapatternalign`. The word aligner asserts the `rx_syncstatus` signal for one parallel clock cycle whenever it re-aligns to the new word boundary.

**Figure 135. Manual Mode when the PCS-PMA Interface Width is 10 Bits**

**Figure 136. Manual Mode when the PCS-PMA Interface Width is 16 Bits**

**Figure 137. Manual Mode when the PCS-PMA Interface Width is 20 Bits**


### 2.9.2.2. Word Aligner Synchronous State Machine Mode

To use this mode:

- Select the **Enable TX 8B/10B encoder** option.
- Select the **Enable RX 8B/10B decoder** option.

The 8B/10B encoder and decoder add the following additional ports:

- tx\_datak
- rx\_datak
- rx\_errdetect
- rx\_disperr
- rx\_runningdisp

1. Set the **RX word aligner mode** to **synchronous state machine**.
2. Set the **RX word aligner pattern length** option according to the PCS-PMA interface width.
3. Enter a hexadecimal value in the **RX word aligner pattern (hex)** field.

The RX word aligner pattern is the 8B/10B encoded version of the data pattern. You can also specify the number of word alignment patterns to achieve synchronization, the number of invalid data words to lose synchronization, and the number of valid data words to decrement error count. This mode adds two additional ports: rx\_patterndetect and rx\_syncstatus.

**Note:**

- rx\_patterndetect is asserted whenever there is a pattern match.
- rx\_syncstatus is asserted after the word aligner achieves synchronization.
- rx\_std\_wa\_patternalign is asserted to re-align and re-synchronize.
- If there is more than one channel in the design, tx\_datak, rx\_datak, rx\_errdetect, rx\_disperr, rx\_runningdisp, rx\_patterndetect, and rx\_syncstatus become buses in which each bit corresponds to one channel.

You can verify this feature by monitoring rx\_parallel\_data.

**Figure 138. Synchronization State Machine Mode when the PCS-PMA Interface Width is 20 Bits**



### 2.9.2.3. RX Bit Slip

To use the RX bit slip, select **Enable rx\_bitslip port** and set the word aligner mode to **bit slip**. This adds rx\_bitslip as an input control port. An active high edge on rx\_bitslip slips one bit at a time. When rx\_bitslip is toggled, the word aligner slips one bit at a time on every active high edge. Assert the rx\_bitslip signal for at least two parallel clock cycles to allow synchronization. You can verify this feature by monitoring rx\_parallel\_data.

The RX bit slip feature is optional and may or may not be enabled.

**Figure 139. RX Bit Slip in 8-bit Mode**



**Figure 140. RX Bit Slip in 10-bit Mode**



**Figure 141. RX Bit Slip in 16-bit Mode**



**Figure 142. RX Bit Slip in 20-bit Mode**



#### 2.9.2.4. RX Polarity Inversion

Receiver polarity inversion can be enabled in low latency, basic, and basic rate match modes. The Standard PCS supports both the static and dynamic polarity inversion features.

To enable the RX polarity inversion feature, select the **Enable RX polarity inversion** and **Enable rx\_polinv port** options.

This mode adds rx\_polinv. If there is more than one channel in the design, rx\_polinv is a bus in which each bit corresponds to a channel. As long as rx\_polinv is asserted, the RX data received has a reverse polarity.

You can verify this feature by monitoring rx\_parallel\_data.

**Figure 143. RX Polarity Inversion**

|                  |                                         |                          |
|------------------|-----------------------------------------|--------------------------|
| rx_polinv        | [ ]                                     | [ ]                      |
| tx_parallel_data | 11111100001110111100                    |                          |
| rx_parallel_data | 11111100001... [ ] 00000011110001000011 | [ ] 11111100001110111100 |
| rx_patterndetect | 01                                      |                          |
| rx_syncstatus    | 11                                      |                          |

#### 2.9.2.5. RX Bit Reversal

The RX bit reversal feature can be enabled in low latency, basic, and basic rate match mode. The word aligner is available in any mode, bit slip, manual, or synchronous state machine.

To enable this feature, select the **Enable RX bit reversal** and **Enable rx\_std\_bitrev\_ena port** options. This adds `rx_std_bitrev_ena`. If there is more than one channel in the design, `rx_std_bitrev_ena` becomes a bus in which each bit corresponds to a channel. As long as `rx_std_bitrev_ena` is asserted, the RX data received by the core shows bit reversal.

You can verify this feature by monitoring `rx_parallel_data`.

**Figure 144. RX Bit Reversal**

|                   |                                               |                          |
|-------------------|-----------------------------------------------|--------------------------|
| rx_std_bitrev_ena | [ ]                                           | [ ]                      |
| tx_parallel_data  | 11111100001110111100                          |                          |
| rx_parallel_data  | 11111100001110111100 [ ] 00111101110000111111 | [ ] 11111100001110111100 |
| rx_patterndetect  | 01 [ ] 00                                     | [ ] 01                   |
| rx_syncstatus     | 11                                            |                          |

#### 2.9.2.6. RX Byte Reversal

The RX byte reversal feature can be enabled in low latency, basic, and basic rate match mode. The word aligner is available in any mode.

To enable this feature, select the **Enable RX byte reversal** and **Enable rx\_std\_byterev\_ena port** options. This adds `rx_std_byterev_ena`. If there is more than one channel in the design, `rx_std_byterev_ena` becomes a bus in which each bit corresponds to a channel. As long as `rx_std_byterev_ena` is asserted, the RX data received by the core shows byte reversal.

You can verify this feature by monitoring `rx_parallel_data`.

**Figure 145. RX Byte Reversal**

|                    |                                    |                          |
|--------------------|------------------------------------|--------------------------|
| rx_std_byterev_ena | [ ]                                | [ ]                      |
| tx_parallel_data   | 11111100001110111100               |                          |
| rx_parallel_data   | 111111... [ ] 11101111001111110000 | [ ] 11111100001110111100 |
| rx_patterndetect   | 01 [ ] 10                          | [ ] 01                   |
| rx_syncstatus      | 11                                 |                          |

#### 2.9.2.7. Rate Match FIFO in Basic (Single Width) Mode

Only the rate match FIFO operation is covered in these steps.

1. Select **basic (single width)** in the **RX rate match FIFO mode** list.
2. Enter values for the following parameters.

| Parameter                                            | Value                                             | Description                                                                                                                                            |
|------------------------------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RX rate match insert/delete +ve pattern (hex)</b> | 20 bits of data specified as a hexadecimal string | The first 10 bits correspond to the skip pattern and the last 10 bits correspond to the control pattern. The skip pattern must have neutral disparity. |
| <b>RX rate match insert/delete -ve pattern (hex)</b> | 20 bits of data specified as a hexadecimal string | The first 10 bits correspond to the skip pattern and the last 10 bits correspond to the control pattern. The skip pattern must have neutral disparity. |

**ve** (volt encodes) are NRZ\_L conditions where +ve encodes 0 and -ve encodes 1. ve is a running disparity (+/-RD) specifically used with the rate matcher. Depending on the ppm difference (which is defined by protocol) between the recovered clock and the local clock, the rate matcher adds or deletes a maximum of four skip patterns (neutral disparity). The net neutrality is conserved even after the skip word insertion or deletion because the control words alternate between positive and negative disparity.

In the following figure, the first skip cluster has a /K28.5/ control pattern followed by two /K28.0/ skip patterns. The second skip cluster has a /K28.5/ control pattern followed by four /K28.0/ skip patterns. The rate match FIFO deletes only one /K28.0/ skip pattern from the first skip cluster to maintain at least one skip pattern in the cluster after deletion. Two /K28.0/ skip patterns are deleted from the second cluster for a total of three skip patterns deletion requirement.

The rate match FIFO can insert a maximum of four skip patterns in a cluster, if there are no more than five skip patterns in the cluster after insertion.

**Figure 146. Rate Match FIFO Deletion with Three Skip Patterns Required for Deletion**



Note: /K28.5/ is the control pattern and /K28.0/ is the skip pattern

In the following figure, /K28.5/ is the control pattern and neutral disparity /K28.0/ is the skip pattern. The first skip cluster has a /K28.5/ control pattern followed by three /K28.0/ skip patterns. The second skip cluster has a /K28.5/ control pattern followed by two /K28.0/ skip patterns. The rate match FIFO inserts only two /K28.0/ skip patterns into the first skip cluster to maintain a maximum of five skip patterns in the cluster after insertion. One /K28.0/ skip pattern is inserted into the second cluster for a total of three skip patterns to meet the insertion requirement.

**Figure 147. Rate Match FIFO Insertion with Three Skip Patterns Required for Insertion**



The following figure shows the deletion of **D5** when the upstream transmitter reference clock frequency is greater than the local receiver reference clock frequency. It asserts `rx_std_rmfifo_full` for one parallel clock cycle while the deletion takes place.

**Figure 148. Rate Match FIFO Becoming Full After Receiving D5**



The following figure shows the insertion of skip symbols when the local receiver reference clock frequency is greater than the upstream transmitter reference clock frequency. It asserts `rx_std_rmfifo_empty` for one parallel clock cycle while the insertion takes place.

**Figure 149. Rate Match FIFO Becoming Empty After Receiving D3**



### 2.9.2.8. Rate Match FIFO Basic (Double Width) Mode

1. Select **basic (double width)** in the **RX rate match FIFO mode** list.
2. Enter values for the following parameters.

| Parameter                                            | Value                                             | Description                                                                                                                                            |
|------------------------------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RX rate match insert/delete +ve pattern (hex)</b> | 20 bits of data specified as a hexadecimal string | The first 10 bits correspond to the skip pattern and the last 10 bits correspond to the control pattern. The skip pattern must have neutral disparity. |
| <b>RX rate match insert/delete -ve pattern (hex)</b> | 20 bits of data specified as a hexadecimal string | The first 10 bits correspond to the skip pattern and the last 10 bits correspond to the control pattern. The skip pattern must have neutral disparity. |

The rate match FIFO can delete as many pairs of skip patterns from a cluster as necessary to avoid the rate match FIFO from overflowing. The rate match FIFO can delete a pair of skip patterns only if the two 10-bit skip patterns appear in the same clock cycle on the LSByte and MSByte of the 20-bit word. If the two skip patterns appear straddled on the MSByte of a clock cycle and the LSByte of the next clock cycle, the rate match FIFO cannot delete the pair of skip patterns.

In the following figure, the first skip cluster has a /K28.5/ control pattern in the LSByte and /K28.0/ skip pattern in the MSByte of a clock cycle followed by one /K28.0/ skip pattern in the LSByte of the next clock cycle. The rate match FIFO cannot delete the two skip patterns in this skip cluster because they do not appear in the same clock cycle. The second skip cluster has a /K28.5/ control pattern in the MSByte of a clock cycle followed by two pairs of /K28.0/ skip patterns in the next two cycles. The rate match FIFO deletes both pairs of /K28.0/ skip patterns (for a total of four skip patterns deleted) from the second skip cluster to meet the three skip pattern deletion requirement.

The rate match FIFO can insert as many pairs of skip patterns into a cluster necessary to avoid the rate match FIFO from under running. The 10-bit skip pattern can appear on the MSByte, the LSByte, or both, of the 20-bit word.

**Figure 150. Rate Match FIFO Deletion with Four Skip Patterns Required for Deletion**

/K28.5/ is the control pattern and neutral disparity /K28.0/ is the skip pattern.



In the following figure, /K28.5/ is the control pattern and neutral disparity /K28.0/ is the skip pattern. The first skip cluster has a /K28.5/ control pattern in the LSByte and /K28.0/ skip pattern in the MSByte of a clock cycle. The rate match FIFO inserts pairs of skip patterns in this skip cluster to meet the three skip pattern insertion requirement.

**Figure 151. Rate Match FIFO Insertion with Four Skip Patterns Required for Insertion**



The following figure shows the deletion of the 20-bit word D7D8.

**Figure 152. Rate Match FIFO Becoming Full After Receiving the 20-Bit Word D5D6**



The following figure shows the insertion of two skip symbols.

**Figure 153. Rate Match FIFO Becoming Empty After Reading out the 20-Bit Word D5D6**



#### 2.9.2.9. 8B/10B Encoder and Decoder

To enable the 8B/10B Encoder and the 8B/10B Decoder, select the **Enable TX 8B/10B Encoder** and **Enable RX 8B/10B Decoder** options on the **Standard PCS** tab in the IP Editor. Platform Designer (Standard) allows implementing the 8B/10B decoder in **RX-only** mode.

The following ports are added:

- `tx_dataak`
- `rx_dataak`
- `rx_runningdisp`
- `rx_dispperr`
- `rx_errdetect`

`rx_dataak` and `tx_dataak` indicate whether the parallel data is a control word or a data word. The incoming 8-bit data (`tx_parallel_data`) and the control identifier (`tx_dataak`) are converted into a 10-bit data. After a power on reset, the 8B/10B encoder takes the 10-bit data from the RD- column. Next, the encoder chooses the 10-bit data from the RD+ column to maintain neutral disparity. The running disparity is shown by `rx_runningdisp`.

#### 2.9.2.10. 8B/10B TX Disparity Control

The Disparity Control feature controls the running disparity of the output from the 8B/10B Decoder.

To enable TX Disparity Control, select the **Enable TX 8B/10B Disparity Control** option. The following ports are added:

- `tx_forcedisp`—a control signal that indicates whether a disparity value has to be forced or not
- `tx_dispval`—a signal that indicates the value of the running disparity that is being forced

When the number of data channels is more than 1, `tx_forcedisp` and `tx_dispval` are shown as buses in which each bit corresponds to one channel.

The following figure shows the current running disparity being altered in Basic single-width mode by forcing a positive disparity /K28.5/ when it was supposed to be a negative disparity /K28.5/. In this example, a series of /K28.5/ code groups are continuously being sent. The stream alternates between a positive running disparity (RD+) /K28.5/ and a negative running disparity (RD-) /K28.5/ to maintain a neutral overall disparity. The current running disparity at time n + 3 indicates that the /K28.5/ in time n + 4 should be encoded with a negative disparity. Because tx\_forcedisp is high at time n + 4, and tx\_dispval is low, the /K28.5/ at time n + 4 is encoded as a positive disparity code group.

**Figure 154. 8B/10B TX Disparity Control**



### 2.9.2.11. How to Enable Low Latency in Basic

In the Arria 10 Transceiver Native PHY IP Parameter Editor, use the following settings to enable low latency:

1. Select the **Enable 'Standard PCS' low latency mode** option.
2. Select either **low\_latency** or **register FIFO** in the **TX FIFO mode** list.
3. Select either **low\_latency** or **register FIFO** in the **RX FIFO mode** list.
4. Select either **Disabled** or **Serialize x2** in the **TX byte serializer mode** list.
5. Select either **Disabled** or **Serialize x2** in the **RX byte deserializer mode** list.
6. Ensure that **RX rate match FIFO mode is disabled**.
7. Set the **RX word aligner mode** to **bitslip**.
8. Set the **RX word aligner pattern length** to **7** or **16**.

*Note:* TX bitslip, RX bitslip, bit reversal, and polarity inversion modes are supported.

### 2.9.2.12. TX Bit Slip

To use the TX bit slip, select the **Enable TX bitslip** and **Enable tx\_std\_bitslipboundarysel port** options. This adds the tx\_std\_bitslipboundarysel input port. The TX PCS automatically slips the number of bits specified by tx\_std\_bitslipboundarysel. There is no port for TX bit slip. If there is more than one channel in the design, tx\_std\_bitslipboundarysel ports are multiplied by the number of channels. You can verify this feature by monitoring the tx\_parallel\_data port.

Enabling the TX bit slip feature is optional.

**Note:** The `rx_parallel_data` values in the following figures are based on the TX and RX bit reversal features being disabled.

**Figure 155. TX Bit Slip in 8-bit Mode**

`tx_parallel_data = 8'hbc. tx_std_bitslipboundarysel = 5'b00001 (bit slip by 1 bit).`

|                                        |       |
|----------------------------------------|-------|
| <code>tx_std_bitslipboundarysel</code> | 00001 |
| <code>tx_parallel_data</code>          | bc    |
| <code>rx_parallel_data</code>          | 79    |

**Figure 156. TX Bit Slip in 10-bit Mode**

`tx_parallel_data = 10'h3bc. tx_std_bitslipboundarysel = 5'b00011 (bit slip by 3 bits).`

|                                        |       |
|----------------------------------------|-------|
| <code>tx_std_bitslipboundarysel</code> | 00011 |
| <code>tx_parallel_data</code>          | 3bc   |
| <code>rx_parallel_data</code>          | 1e7   |

**Figure 157. TX Bit Slip in 16-bit Mode**

`tx_parallel_data = 16'hfcbc. tx_std_bitslipboundarysel = 5'b00011 (bit slip by 3 bits).`

|                                        |       |
|----------------------------------------|-------|
| <code>tx_std_bitslipboundarysel</code> | 00011 |
| <code>tx_parallel_data</code>          | fcbc  |
| <code>rx_parallel_data</code>          | 5e7f  |

**Figure 158. TX Bit Slip in 20-bit Mode**

`tx_parallel_data = 20'hF3CBC. tx_std_bitslipboundarysel = 5'b00111 (bit slip by 7 bits).`

|                                        |       |
|----------------------------------------|-------|
| <code>tx_std_bitslipboundarysel</code> | 00111 |
| <code>tx_parallel_data</code>          | f3cbc |
| <code>rx_parallel_data</code>          | e5e1f |

### 2.9.2.13. TX Polarity Inversion

The positive and negative signals of a serial differential link might accidentally be swapped during board layout. Solutions such as a board respin or major updates to the PLD logic can be expensive. The transmitter polarity inversion feature is provided to correct this situation. The Standard PCS supports both the static and dynamic polarity inversion features.

Transmitter polarity inversion can be enabled in low latency, basic, and basic rate match modes.

To enable TX polarity inversion, select the **Enable TX polarity inversion** and **Enable tx\_polinv port** options in Platform Designer (Standard). It can also be dynamically controlled with dynamic reconfiguration.

This mode adds `tx_polinv`. If there is more than one channel in the design, `tx_polinv` is a bus with each bit corresponding to a channel. As long as `tx_polinv` is asserted, the TX data transmitted has a reverse polarity.

#### 2.9.2.14. TX Bit Reversal

The TX bit reversal feature can be enabled in low latency, basic, and basic rate match mode. The word aligner is available in any mode. This feature is parameter-based, and creates no additional ports. If there is more than one channel in the design, all channels have TX bit reversals.

To enable TX bit reversal, select the **Enable TX bit reversal** option in Platform Designer (Standard). It can also be dynamically controlled with dynamic reconfiguration.

**Figure 159. TX Bit Reversal**

|                  |                               |
|------------------|-------------------------------|
| tx_parallel_data | 11111100001110111100          |
| rx_parallel_data | 00000... 00111101110000111111 |

#### 2.9.2.15. TX Byte Reversal

The TX byte reversal feature can be enabled in low latency, basic, and basic rate match mode. The word aligner is available in any mode. This feature is parameter-based, and creates no additional ports. If there is more than one channel in the design, all channels have TX byte reversals.

To enable TX byte reversal, select the **Enable TX byte reversal** option in Platform Designer (Standard). It can also be dynamically controlled with dynamic reconfiguration.

**Figure 160. TX Byte Reversal**

|                  |                                  |
|------------------|----------------------------------|
| tx_parallel_data | 11111100001110111100             |
| rx_parallel_data | 00000000... 11101111001111110000 |

#### 2.9.2.16. How to Implement the Basic, Basic with Rate Match Transceiver Configuration Rules in Arria 10 Transceivers

You should be familiar with the Standard PCS and PMA architecture, PLL architecture, and the reset controller before implementing your Basic protocol IP.

1. Open the IP Catalog and select the Native PHY IP. Refer to [Select and Instantiate the PHY IP Core](#) on page 33.
2. Select **Basic/Custom (Standard PCS)** or **Basic/Custom w/Rate Match (Standard PCS)** from the **Transceiver configuration rules** list located under **Datapath Options** depending on which configuration you want to use.
3. Use the parameter values in the tables in [Transceiver Native PHY IP Parameter Settings for the Basic Protocol](#) as a starting point. Or, you can use the protocol presets described in [Transceiver Native PHY Presets](#). You can then modify the setting to meet your specific requirements.
4. Click **Finish** to generate the Native PHY IP (this is your RTL file).

**Figure 161. Signals and Ports of Native PHY IP for Basic, Basic with Rate Match Configurations**



5. Instantiate and configure your PLL.
6. Create a transceiver reset controller.
7. Connect the Native PHY IP to the PLL IP and the reset controller. Use the information in [Transceiver Native PHY Ports for the Protocol](#) to connect the ports.

**Figure 162. Connection Guidelines for a Basic/Custom Design**



8. Simulate your design to verify its functionality.

### Related Information

- [Arria 10 Standard PCS Architecture](#) on page 491  
For more information about Standard PCS architecture
- [Arria 10 PMA Architecture](#) on page 459  
For more information about PMA architecture
- [Using PLLs and Clock Networks](#) on page 410  
For more information about implementing PLLs and clocks
- [PLLs](#) on page 358  
PLL architecture and implementation details
- [Resetting Transceiver Channels](#) on page 428  
Reset controller general information and implementation details
- [Standard PCS Ports](#) on page 87  
Port definitions for the Transceiver Native PHY Standard Datapath

### 2.9.2.17. Native PHY IP Parameter Settings for Basic, Basic with Rate Match Configurations

This section contains the recommended parameter values for this protocol. Refer to *Using the Arria 10 Transceiver Native PHY IP Core* for the full range of parameter values.

**Table 220. General and Datapath Options Parameters**

| Parameter                                            | Range                                                                                 |
|------------------------------------------------------|---------------------------------------------------------------------------------------|
| <b>Message level for rule violations</b>             | <b>error</b><br><b>warning</b>                                                        |
| <b>Transceiver configuration rules</b>               | <b>Basic/Custom (Standard PCS)</b><br><b>Basic/Custom w/Rate Match (Standard PCS)</b> |
| <b>PMA configuration rules</b>                       | <b>basic</b>                                                                          |
| <b>Transceiver mode</b>                              | <b>TX/RX Duplex</b><br><b>TX Simplex</b><br><b>RX Simplex</b>                         |
| <b>Number of data channels</b>                       | 1 to 96                                                                               |
| <b>Data rate</b>                                     | 611 Mbps to 12 Gbps                                                                   |
| <b>Enable datapath and interface reconfiguration</b> | <b>On/Off</b>                                                                         |
| <b>Enable simplified data interface</b>              | <b>On/Off</b>                                                                         |

**Table 221. TX PMA Parameters**

| Parameter                                   | Range                                                                      |
|---------------------------------------------|----------------------------------------------------------------------------|
| <b>TX channel bonding mode</b>              | <b>Not bonded</b><br><b>PMA-only bonding</b><br><b>PMA and PCS bonding</b> |
| <b>PCS TX channel bonding master</b>        | <b>Auto, n-1</b> (where n = the number of data channels)                   |
| <b>Actual PCS TX channel bonding master</b> | <b>n-1</b> (where n = the number of data channels)                         |

*continued...*

| Parameter                                        | Range                                                                            |
|--------------------------------------------------|----------------------------------------------------------------------------------|
| <b>TX local clock division factor</b>            | <b>1, 2, 4, 8</b>                                                                |
| <b>Number of TX PLL clock inputs per channel</b> | <b>1, 2, 3, 4</b>                                                                |
| <b>Initial TX PLL clock input selection</b>      | <b>0</b> (Depends on the <b>Number of TX PLL clock inputs per channel</b> value) |
| <b>Enable tx_pma_clkout port</b>                 | <b>On/Off</b>                                                                    |
| <b>Enable tx_pma_div_clkout port</b>             | <b>On/Off</b>                                                                    |
| <b>tx_pma_div_clkout division factor</b>         | <b>Disabled, 1, 2, 33, 40, 66</b>                                                |
| <b>Enable tx_pma_elecidle port</b>               | <b>On/Off</b>                                                                    |
| <b>Enable tx_pma_qpipullup port (QPI)</b>        | <b>On/Off</b>                                                                    |
| <b>Enable tx_pma_qpipulldn port (QPI)</b>        | <b>On/Off</b>                                                                    |
| <b>Enable tx_pma_txdetectrx port (QPI)</b>       | <b>On/Off</b>                                                                    |
| <b>Enable tx_pma_rxfound port (QPI)</b>          | <b>On/Off</b>                                                                    |
| <b>Enable rx_serialpbken port</b>                | <b>On/Off</b>                                                                    |

**Table 222. RX PMA Parameters**

| Parameter                                                  | Range                                         |
|------------------------------------------------------------|-----------------------------------------------|
| <b>Number of CDR reference clocks</b>                      | <b>1, 2, 3, 4, 5</b>                          |
| <b>Selected CDR reference clock</b>                        | <b>0, 1, 2, 3, 4</b>                          |
| <b>Selected CDR reference clock frequency</b>              | Legal range defined by Quartus Prime software |
| <b>PPM detector threshold</b>                              | <b>100, 300, 500, 1000</b>                    |
| <b>CTLE adaptation mode</b>                                | <b>manual</b>                                 |
| <b>DFE adaptation mode</b>                                 | <b>disabled</b>                               |
| <b>Number of fixed dfe taps</b>                            | <b>3, 7</b>                                   |
| <b>Enable rx_pma_clkout port</b>                           | <b>On/Off</b>                                 |
| <b>Enable rx_pma_div_clkout port</b>                       | <b>On/Off</b>                                 |
| <b>rx_pma_div_clkout division factor</b>                   | <b>Disabled, 1, 2, 33, 40, 50, 66</b>         |
| <b>Enable rx_pma_clkslip port</b>                          | <b>On/Off</b>                                 |
| <b>Enable rx_pma_qpipulldn port (QPI)</b>                  | <b>On/Off</b>                                 |
| <b>Enable rx_is_lockedtodata port</b>                      | <b>On/Off</b>                                 |
| <b>Enable rx_is_lockedtoref port</b>                       | <b>On/Off</b>                                 |
| <b>Enable rx_set_locktodata and rx_set_locktoref ports</b> | <b>On/Off</b>                                 |
| <b>Enable rx_serialpbken port</b>                          | <b>On/Off</b>                                 |
| <b>Enable PRBS verifier control and status ports</b>       | <b>On/Off</b>                                 |

**Table 223. Standard PCS Parameters**

| Parameter                                                | Range                                                                                                                         |
|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| <b>Standard PCS / PMA interface width</b>                | <b>8, 10, 16, 20</b>                                                                                                          |
| <b>FPGA fabric / Standard TX PCS interface width</b>     | <b>8, 10, 16, 20, 32, 40</b>                                                                                                  |
| <b>FPGA fabric / Standard RX PCS interface width</b>     | <b>8, 10, 16, 20, 32, 40</b>                                                                                                  |
| <b>Enable 'Standard PCS' low latency mode</b>            | <b>On/Off</b><br><b>Off</b> (for Basic with Rate Match)                                                                       |
| <b>TX FIFO mode</b>                                      | <b>low_latency</b><br><b>register_fifo</b><br><b>fast_register</b>                                                            |
| <b>RX FIFO Mode</b>                                      | <b>low_latency</b><br><b>register_fifo</b>                                                                                    |
| <b>Enable tx_std_pcfifo_full port</b>                    | <b>On/Off</b>                                                                                                                 |
| <b>Enable tx_std_pcfifo_empty port</b>                   | <b>On/Off</b>                                                                                                                 |
| <b>Enable rx_std_pcfifo_full port</b>                    | <b>On/Off</b>                                                                                                                 |
| <b>Enable rx_std_pcfifo_empty port</b>                   | <b>On/Off</b>                                                                                                                 |
| <b>TX byte serializer mode</b>                           | <b>Disabled</b><br><b>Serialize x2</b><br><b>Serialize x4</b>                                                                 |
| <b>RX byte deserializer mode</b>                         | <b>Disabled</b><br><b>Deserialize x2</b><br><b>Deserialize x4</b>                                                             |
| <b>Enable TX 8B/10B encoder</b>                          | <b>On/Off</b>                                                                                                                 |
| <b>Enable TX 8B/10B disparity control</b>                | <b>On/Off</b>                                                                                                                 |
| <b>Enable RX 8B/10B decoder</b>                          | <b>On/Off</b>                                                                                                                 |
| <b>RX rate match FIFO mode</b>                           | <b>Disabled</b><br><b>Basic 10-bit PMA</b> (for Basic with Rate Match)<br><b>Basic 20-bit PMA</b> (for Basic with Rate Match) |
| <b>RX rate match insert/delete -ve pattern (hex)</b>     | User-defined value                                                                                                            |
| <b>RX rate match insert/delete +ve pattern (hex)</b>     | User-defined value                                                                                                            |
| <b>Enable rx_std_rmfifo_full port</b>                    | <b>On/Off</b>                                                                                                                 |
| <b>Enable rx_std_rmfifo_empty port</b>                   | <b>On/Off</b>                                                                                                                 |
| <b>PCI Express* Gen 3 rate match FIFO mode</b>           | <b>Bypass</b>                                                                                                                 |
| <b>Enable TX bit slip</b>                                | <b>On/Off</b>                                                                                                                 |
| <b>Enable tx_std_bitslipboundarysel port</b>             | <b>On/Off</b>                                                                                                                 |
| <b>RX word aligner mode</b>                              | <b>bitslip</b><br><b>manual (PLD controlled)</b><br><b>synchronous state machine</b>                                          |
| <b>RX word aligner pattern length</b>                    | <b>7, 8, 10, 16, 20, 32, 40</b>                                                                                               |
| <b>RX word aligner pattern (hex)</b>                     | User-defined value                                                                                                            |
| <b>Number of word alignment patterns to achieve sync</b> | 0-255                                                                                                                         |

*continued...*

| Parameter                                                             | Range  |
|-----------------------------------------------------------------------|--------|
| <b>Number of invalid data words to lose sync</b>                      | 0-63   |
| <b>Number of valid data words to decrement error count</b>            | 0-255  |
| <b>Enable fast sync status reporting for deterministic latency SM</b> | On/Off |
| <b>Enable rx_std_wa_patternalign port</b>                             | On/Off |
| <b>Enable rx_std_wa_a1a2size port</b>                                 | On/Off |
| <b>Enable rx_std_bitslipboundarysel port</b>                          | On/Off |
| <b>Enable rx_bitslip port</b>                                         | On/Off |
| <b>Enable TX bit reversal</b>                                         | On/Off |
| <b>Enable TX byte reversal</b>                                        | On/Off |
| <b>Enable TX polarity inversion</b>                                   | On/Off |
| <b>Enable tx_polinv port</b>                                          | On/Off |
| <b>Enable RX bit reversal</b>                                         | On/Off |
| <b>Enable rx_std_bitrev_ena port</b>                                  | On/Off |
| <b>Enable RX byte reversal</b>                                        | On/Off |
| <b>Enable rx_std_byterev_ena port</b>                                 | On/Off |
| <b>Enable RX polarity inversion</b>                                   | On/Off |
| <b>Enable rx_polinv port</b>                                          | On/Off |
| <b>Enable rx_std_signaldetect port</b>                                | On/Off |
| <b>Enable PCIe dynamic datarate switch ports</b>                      | Off    |
| <b>Enable PCIe pipe_hclk_in and pipe_hclk_out ports</b>               | Off    |
| <b>Enable PCIe Gen 3 analog control ports</b>                         | Off    |
| <b>Enable PCIe electrical idle control and status ports</b>           | Off    |
| <b>Enable PCIe pipe_rx_polarity port</b>                              | Off    |

**Table 224. Dynamic Reconfiguration Parameters**

| Parameter                                      | Range  |
|------------------------------------------------|--------|
| <b>Enable dynamic reconfiguration</b>          | On/Off |
| <b>Share reconfiguration interface</b>         | On/Off |
| <b>Enable Native PHY Debug Master Endpoint</b> | On/Off |

**Table 225. Generation Options Parameters**

| Parameter                                    | Range  |
|----------------------------------------------|--------|
| <b>Generate parameter documentation file</b> | On/Off |

### Related Information

Using the Arria 10 Transceiver Native PHY IP Core on page 45

### 2.9.3. Design Considerations for Implementing Arria 10 GT Channels

This section provides information on using the Arria 10 GT transceiver channels.

GT channels can be used in Enhanced PCS basic mode and PCS-Direct configuration to support 25.8 Gbps. When GT channels are used in PCS-Direct configuration, the PCS blocks are bypassed. The serializer/deserializer in GT channels supports 64 bit and 128 bit serialization factors.

#### 2.9.3.1. Transceiver PHY IP

Arria 10 GT transceiver channels are implemented using the Native PHY IP with the Basic (Enhanced PCS) transceiver configuration rule.

- To support 25.8 Gbps, the Enhanced PCS must be configured in basic mode with the low latency check box unselected. To configure the Enhanced PCS, do not enable any functional blocks in the Enhanced PCS (that is, disable Block Synchronizer, Gearbox, Scrambler, and Encoder).
- You can also use the PCS-Direct mode for 25.8 Gbps.

You can bundle several GT transceiver channels with one Native PHY IP instantiation, but you must instantiate a separate ATX PLL IP for every ATX PLL used.

#### 2.9.3.2. PLL and GT Transceiver Channel Clock Lines

The ATX PLL is used to provide the clock source for the GT transceiver channels. Each ATX PLL has two dedicated GT clock lines which connect the PLL directly to the GT transceiver channels within a transceiver bank. The top ATX PLL drives channels 3 and 4, and the bottom ATX PLL drives channels 0 and 1. These connections bypass the rest of the clock network for higher performance.

Figure 163. GT Channel Configuration



When both the channels 0 and 1 are configured as GT channels, they are driven by the same ATX PLL and have to be configured to run at the same data rates. This is also true for channels 3 and 4 when they are configured as GT channels.

**Note:**

- GT channel bonding is not supported.
- For optimum performance of GT channel, the reference clock of ATX PLL is recommended to be from a dedicated reference clock pin in the same bank.

**Related Information**

[Input Reference Clock Sources](#) on page 382

### 2.9.3.3. Reset Controller

Each GT channel instantiated has independent analog and digital reset ports. Refer to the *Resetting Transceiver Channels* chapter for more details on designing a reset controller to reset these ports.

**Related Information**

[Resetting Transceiver Channels](#) on page 428

Reset controller general information and implementation details

### 2.9.3.4. How to Implement Designs for Data Rates Above 17.4 Gbps Using Enhanced PCS in Low Latency Mode

- You should be familiar with the Enhanced PCS and PMA architecture, PLL architecture, and the reset controller.
  - Make sure you have selected an Arria 10 GT device for the project
1. Select **Tools > IP Catalog > Interface Protocols > Transceiver PHY > Arria 10 Transceiver Native PHY**. Refer to [Select and Instantiate the PHY IP Core](#) on page 33 for detailed steps.
  2. Set **VCCR\_GXB** and **VCCT\_GXB** to 1.1V. Note these settings are overridden by the QSF file settings which should also be set to 1.1V. QII makes sure the actual voltage prescribed is in line with pin connection guidelines and the Arria10 Data Sheet.
  3. Select **Basic (Enhanced PCS)** from the **Transceiver configuration rules** list located under **Datapath Options**.
  4. Use the parameter values in the tables in [Transceiver Native PHY IP Parameters Settings for Basic \(Enhanced PCS\) and Basic with KR FEC](#) for each input of the Arria 10 Transceiver Native PHY Parameter Editor as a starting point. Or, you can use the protocol presets described in [Transceiver Native PHY Presets](#). You can then modify the settings to meet your specific requirements.
    - Ensure that the data rate is set to 25781.25 Mbps. To achieve the higher data rates, use Enhanced PCS basic mode with the low latency option unchecked. Select a CDR reference clock to match your data rate. Use Phase compensation FIFO modes.
    - Make sure DFE is disabled from Rx PMA settings.
    - Set the Enhanced PCS / PMA interface width to 64 bits.
    - Set the FPGA fabric / Enhanced PCS interface width to 64 bits.
    - You can enable RX/TX FIFO double width mode to create a FPGA fabric / PCS interface width of 128 bits.
    - Click **Finish** to generate the Native PHY IP (this is your RTL file).

**Figure 164. Signals and Ports of the Native PHY for Basic (Enhanced PCS) Transceiver Configuration Rule for Data Rates Above 17.4 Gbps and FPGA Fabric / PCS Interface width of 128 bits**



5. Select **Tools > IP Catalog > Basic Functions > Clocks > PLLs and Resets > PLL > Arria 10 Transceiver ATX PLL**. Refer to [Instantiating the ATX PLL IP Core](#) on page 363 for detailed steps.
6. Configure the ATX PLL IP using the Parameter Editor.
  - Select the GT clock output buffer.
  - Enable the PLL GT clock output port.
  - Set the PLL output clock frequency to the Native PHY IP recommended frequency.

**Figure 165. ATX PLL IP with GT Clock Lines Enabled**


7. Create a transceiver reset controller. Refer to [Resetting Transceiver Channels](#) on page 428 for more details about configuring the reset IP core.
8. Connect the Native PHY IP core to the PLL IP core and the reset controller.

The ATX PLL's port `tx_serial_clk_gt` represents the dedicated GT clock lines. Connect this port to the Native PHY IP core's `tx_serial_clk0` port. The Quartus Prime software automatically uses the dedicated GT clocks instead of the x1 clock network.

### 2.9.3.5. Arria 10 GT Channel Usage

All Arria 10 GT devices have a total of six GT transceiver channels to support 25.8 Gbps.

Arria 10 GT devices have three transceiver banks that support up to two GT channels. Each channel can operate as a duplex channel, TX only, or RX only channel. Transceiver banks GXBL1E and GXBL1H each contain two GT transceiver channels: Ch3 and Ch4. Transceiver bank GXBL1G contains two GT transceiver channels: Ch0 and Ch1. Channels 2 and 5 on any bank can only be configured as GX transceiver channels.

**Table 226. Valid Permutations for GT and GX Channel Configuration in Transceiver Bank GXBL1G for Channels 0, 1, and 2**

| GT Transceiver Channel | Configuration A | Configuration B | Configuration C | Configuration D |
|------------------------|-----------------|-----------------|-----------------|-----------------|
| Ch2                    | Unusable        | Unusable        | Unusable        | GX              |
| Ch1                    | GT              | GT              | Unusable        | GX              |
| Ch0                    | GT              | Unusable        | GT              | GX              |

**Notes on grouping channels Ch0, Ch1, and Ch2:**

- If channels 0 and 1 are configured as GT channels, channel 2 is unusable (Configuration A).
- If either channel 0 or 1 is configured as a GT channel, the remaining channels are unusable (Configurations B and C).
- If channels 0 and 1 are not configured as GT channels, this grouping can be all configured as GX channels (Configuration D).
- If either channel 0 or 1 is used as a GT channel, then the ATX PLL adjacent to channel 0 and 1 must be reserved for GT channel configurations.

**Table 227. Valid Permutations for GT and GX Channel Configuration in Transceiver Banks GXBL1E and GXBL1H for Channels 3, 4, and 5**

| GT Transceiver Channel | Configuration A | Configuration B | Configuration C | Configuration D |
|------------------------|-----------------|-----------------|-----------------|-----------------|
| Ch5                    | Unusable        | Unusable        | Unusable        | GX              |
| Ch4                    | GT              | GT              | Unusable        | GX              |
| Ch3                    | GT              | Unusable        | GT              | GX              |

**Notes on grouping channels Ch3, Ch4, and Ch5:**

- If channels 3 and 4 are configured as GT channels, channel 5 is unusable (Configuration A).
- If either channel 3 or 4 is configured as a GT channel, the remaining channels are unusable (Configurations B and C).
- If channels 3 and 4 are not configured as GT channels, this grouping can be all configured as GX channels (Configuration D).
- If either channel 3 or 4 is used as a GT channel, then the ATX PLL adjacent to channel 3 and 4 must be reserved for GT channel configurations.

## 2.9.4. How to Implement PCS Direct Transceiver Configuration Rule

You should be familiar with PCS Direct architecture, PMA architecture, PLL architecture, and the reset controller before implementing PCS Direct Transceiver Configuration Rule.

1. Open the IP Catalog and select **Arria 10 Transceiver Native PHY IP**. Refer to [Select and Instantiate the PHY IP Core](#) on page 33 for detailed steps.
2. Select **PCS Direct** from the **Transceiver configuration rules** list located under **Datapath Options**.
3. Configure your Native PHY IP.
4. Click **Generate** to generate the Native PHY IP (this is your RTL file).

5. Instantiate and configure your PLL.
6. Create a transceiver reset controller. You can use your own controller or use the Transceiver PHY Reset Controller.
7. Connect the Native PHY IP to the PLL IP and the reset controller.

**Figure 166. Connection Guidelines for a PCS Direct PHY Design**



8. Simulate your design to verify its functionality.

## 2.10. Simulating the Transceiver Native PHY IP Core

Use simulation to verify the Native PHY transceiver functionality. The Quartus Prime software supports register transfer level (RTL) and gate-level simulation in both ModelSim - Intel FPGA Edition and third-party simulators. You run simulations using your Quartus Prime project files.

The following simulation flows are available:

- NativeLink—This flow simplifies simulation by allowing you to start a simulation from the Quartus Prime software. This flow automatically creates a simulation script and compiles design files, IP simulation model files, and Intel simulation library models.  
*Note:* The Quartus Prime Pro Edition software does not support NativeLink RTL simulation
- Scripting IP Simulation—In this flow you perform the following actions:
  - Run the ip-setup-simulation utility to generate a single simulation script that compiles simulation files for all the underlying IPs in your design. This script needs to be regenerated whenever you upgrade or modify IPs in the design.
  - You create a top-level simulation script for compiling your testbench files and simulating the testbench. It sources the script generated in the first action. You do not have to modify this script even if you upgrade or modify the IPs in your design.
- Custom Flow—This flow allows you to customize simulation for more complex requirements. You can use this flow to compile design files, IP simulation model files, and Intel simulation library models manually.

You can simulate the following netlist:

- The RTL functional netlist—This netlist provides cycle-accurate simulation using Verilog HDL, SystemVerilog, and VHDL design source code. Intel and third-party EDA vendors provide the simulation models.

### Prerequisites to Simulation

Before you can simulate your design, you must have successfully passed Quartus Prime Analysis and Synthesis.

### Related Information

[Simulating Intel FPGA Designs](#)

## 2.10.1. NativeLink Simulation Flow

The NativeLink settings available in the Quartus Prime software allow you to specify your simulation environment, simulation scripts, and testbenches. The Quartus Prime software saves these settings in your project. After you specify the NativeLink settings, you can start simulations easily from the Quartus Prime software.

### 2.10.1.1. How to Use NativeLink to Specify a ModelSim Simulation

Complete the following steps to specify the directory path and testbench settings for your simulator:

- On the **Tools** menu, click **Options**, and then click **EDA Tool Options**.
- Browse to the directory for your simulator. The following table lists the directories for supported simulators:

**Table 228. Simulator Path**

| Simulator                                      | Path                                                   |
|------------------------------------------------|--------------------------------------------------------|
| Mentor Graphics* ModelSim - Intel FPGA Edition | <drive>:\<simulator install path>\win32aloem (Windows) |

| Simulator | Path                                   |
|-----------|----------------------------------------|
|           | /<simulator install path>/bin (Linux*) |

3. On the **Assignments** menu, click **Settings**.
4. In the **Category** list, under **EDA Tool Settings** select **Simulation**.
5. In the **Tool name** list, select your simulator.

**Note:** ModelSim refers to ModelSim SE and PE. These simulators use the same commands as QuestaSim. ModelSim - Intel FPGA Edition refers to ModelSim - Intel FPGA Edition Starter Edition and ModelSim - Intel FPGA Edition Subscription Edition.
6. In the **Output directory**, browse to the directory for your output files.
7. To map illegal HDL characters, turn on **Map illegal HDL characters**.
8. To filter netlist glitches , turn on **Enable glitch filtering**.
9. Complete the following steps to specify additional options for NativeLink automation:
  - a. Turn on **Compile test bench**.
  - b. Click **Test Benches**.  
The **Test Benches** dialog box appears.
  - c. Click **New**.
  - d. Under **Create new test bench settings**, for **Test bench name** type the test bench name. For Top level module in the test bench, type the top-level module name. These names should match the actual test bench module names.
  - e. Select **Use test bench to perform VHDL timing simulation** and specify the name of your design instance under **Design instance name in test bench**.
  - f. Under the **Simulation period**, turn on **Run simulation until all vector stimuli are used**.
  - g. Under **Test bench and simulation files**, select your test bench file from your folder. Click **Add**.
  - h. Click **OK**.

### 2.10.1.2. How to Use NativeLink to Run a ModelSim RTL Simulation

Figure 167. NativeLink Simulation Flow Diagram



Complete the following steps to run an RTL functional simulation:

1. Open your Quartus Prime project.
2. On the Tools menu, select **Run Simulation Tool**, then select **RTL Simulation** or **Gate Level Simulation**.
3. Run Quartus Prime Analysis and Elaboration and re-instantiate control signals that you defined using the In-System Sources and Probe Editor. The In-System Sources and Probe Editor can only access the pins of the device. Consequently, you must route any signal that you want to observe to the top-level of your design.
4. To monitor additional signals, highlight the desired instances or nodes in **Instance**, and right-click **Add wave**.
5. Select **Simulate** and then **Run**.
6. Specify the simulation duration.
7. Complete the following steps to restart the simulation:
  - a. On the Simulate menu, select **restart**, then click **ok**.  
This action clears the existing waves.
  - b. Highlight **run** and select the appropriate options to run the simulation.

#### Related Information

[Simulating the Transceiver Native PHY IP Core](#) on page 332

#### 2.10.1.3. How to Use NativeLink to Specify Third-Party RTL Simulators

The following figure illustrates the high-level steps for using the NativeLink with Third-Party EDA RTL simulator.

**Figure 168. Using NativeLink with Third-Party Simulators**



Complete the following steps to specify the directory path and testbench settings for your simulator:

1. On the **Tools** menu, click **Options**, and then click **EDA Tool Options**.
2. Browse to the directory for your simulator. The following table lists the directories for supported third-party simulators:

**Table 229. Simulator Path**

| Simulator                   | Path                                              |
|-----------------------------|---------------------------------------------------|
| Mentor Graphics ModelSim    | <drive>:\<simulator install path>\win32 (Windows) |
| Mentor Graphics QuestaSim*  | /\<simulator install path>/bin (Linux)            |
| Synopsys VCS/VCS MX         | /\<simulator install path>/bin (Linux)            |
| Cadence Incisive Enterprise | /\<simulator install path>/tools/bin (Linux)      |
| Aldec Active-HDL            | <drive>:\<simulator install path>\bin (Windows)   |
| Aldec Riviera-Pro           | /\<simulator install path>/bin (Linux)            |

3. On Assignments menu, click **Settings**.

4. In the **Category** list, under **EDA Tool Settings**, select **Simulation**.
5. In the **Tool name** list, select your simulator.
6. To enable your simulator, on the **Tools** menu, click **Options** and then click **License Setup**. Make necessary changes for EDA tool licenses.
7. Compile your design and testbench files.
8. Load the design and run the simulation in the EDA tool.

To learn more about third-party simulators, click on the appropriate link below.

#### Related Information

- [Mentor Graphics ModelSim and QuestaSim Support](#)
- [Synopsys VCS and VCS MX Support](#)
- [Cadence Incisive Enterprise Simulator Support](#)
- [Aldec Active-HDL and Riviera-Pro Support](#)

### 2.10.2. Scripting IP Simulation

The Intel Quartus Prime software supports the use of scripts to automate simulation processing in your preferred simulation environment. You can use your preferred scripting methodology to control simulation.

Intel recommends the use of a version-independent top-level simulation script to control design, testbench, and IP core simulation. Because Quartus Prime-generated simulation file names may change.

You can use the ip-setup simulation utility to generate or regenerate underlying setup scripts after any software or IP version upgrade or regeneration. Use of a top-level script and ip-setup-simulation eliminates the requirement to manually update simulation scripts.

#### 2.10.2.1. Generating a Combined Simulator Setup Script

Platform Designer (Standard) system generation creates the interconnect between components. It also generates files for synthesis and simulation, including the **.spd** files necessary for the ip-setup-simulation utility.

The Intel Quartus Prime software provides utilities to help you generate and update IP simulation scripts. You can use the ip-setup-simulation utility to generate a combined simulator setup script, for all Intel FPGA IP in your design, for each supported simulator. You can subsequently rerun ip-setup-simulation to automatically update the combined script. Each simulator's combined script file contains a rudimentary template that you can adapt for integration of the setup script into a top-level simulation script.

#### Related Information

##### [Intel Quartus Prime Standard Edition Handbook Volume 3: Verification](#)

Provides more information about the steps to generate top-level simulation script.

### 2.10.3. Custom Simulation Flow

The custom simulation flow allows you to customize the simulation process for more complex simulation requirements. This flow allows you to control the following aspects of your design:

- Component binding
- Compilation order
- Run commands
- IP cores
- Simulation library model files

The following figure illustrates the steps for custom flow simulation. If you use a simulation script, you can automate some of the steps.

**Figure 169. Custom flow Simulation**


#### 2.10.3.1. How to Use the Simulation Library Compiler

The Simulation Library Compiler compiles Intel simulation libraries for supported simulation tools, and saves the simulation files in the output directory you specify.

**Note:** Because the ModelSim - Intel FPGA Edition software provides precompiled simulation libraries, you do not have to compile simulation libraries if you are using the software.

Complete the following steps to compile the simulation model libraries using the Simulation Library Compiler:

1. On the Tools menu, click **Launch Simulation Library Compiler**.
2. Under **EDA simulation tool**, for the **Tool name**, select your simulation tool.
3. Under **Executable location**, browse to the location of the simulation tool you specified. You must specify this location before you can run the EDA Simulation Library Compiler.
4. Under **Library families**, select one or more family names and move them to the **Selected families** list.
5. Under **Library language**, select **Verilog**, **VHDL**, or both.
6. In the **Output directory** field, specify a location to store the compiled libraries.
7. Click **Start Compilation**.

Complete the following steps to add the simulation files to your project:

1. On the Assignments menu, click **Settings**.
2. In the **Category** list, select **Files**.
3. Click **Browse** to open the **Select File** dialog box and select one or more files in the **Files** list to add to your project.
4. Click **Open**, and then **Add** to add the selected file(s) to your project.
5. Click **OK** to close the **Settings** dialog box.

#### Related Information

- [Preparing for EDA Simulation](#)
- [Intel FPGA Simulation Models](#)

### 2.10.3.2. Custom Simulation Scripts

You can automate simulations by creating customized scripts. You can generate scripts manually. In addition, you can use NativeLink to generate a simulation script as a template and then make the necessary changes. The following table shows a list of script directories NativeLink generates.

**Table 230. Custom Simulation Scripts for Third Party RTL Simulation**

| Simulator                             | Simulation File                                                                          | Use                                                                                                                                                                                                                                                                             |
|---------------------------------------|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mentor Graphics ModelSim or QuestaSim | /simulation/ modelsim/<br><b>modelsim_setup.do</b><br>Or<br><b>mentor/msim_setup.tcl</b> | Source directly with your simulator. Run do msim_setup.tcl, followed by ld_debug. If you have more than one IP, each IP has a dedicated msim_setup.tcl file. Make sure that you combine all the files included in the msim_setup.tcl files into one common msim_setup.tcl file. |
| Aldec Riviera Pro                     | /simulation/ aldec/<br><b>rivierapro_setup.tcl</b>                                       | Source directly with your simulator                                                                                                                                                                                                                                             |

*continued...*

| Simulator                | Simulation File                                        | Use                                                                                                                                                                                                                                         |
|--------------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Synopsys VCS             | <code>/simulation/synopsis/vcs/vcs_setup.sh</code>     | Add your testbench file name to this file to pass the testbench file to VCS using the <code>-file</code> option. If you specify a testbench file for NativeLink and do not choose to simulate, NativeLink generates a script that runs VCS. |
| Synopsys VCS MX          | <code>/simulation/synopsis/vcsmx/vcsmx_setup.sh</code> | Run this script at the command line using <code>quartus_sh -t &lt;script&gt;</code> . Any testbench you specify with NativeLink is included in this script.                                                                                 |
| Cadence Incisive (NCSim) | <code>/simulation/cadence/ncsim_setup.sh</code>        | Run this script at the command line using <code>quartus_sh -t &lt;script&gt;</code> . Any testbench you specify with NativeLink is included in this script.                                                                                 |

## 2.11. Implementing Protocols in Intel Arria 10 Transceivers

### Revision History

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2021.06.10       | <ul style="list-style-type: none"> <li>Updated description for <code>Enable tx_pma_div_clkout port</code> parameter in the <i>TX PMA Optional Ports</i> table.</li> <li>Updated the reference for Soft Enhanced PCS FIFO for IEEE 1588v2 in the <i>1G/10GbE PHY Functional Description</i> section.</li> <li>Updated the Intel Quartus Prime subdirectory and links in the <i>Design Example</i> section.</li> </ul>                             |
| 2021.01.29       | Made the following change: <ul style="list-style-type: none"> <li>Clarified that the <code>rx_pma_clkslip</code> falling edge makes the RX deserializer bit slip the serial data by one UI.</li> </ul>                                                                                                                                                                                                                                           |
| 2020.05.08       | Made the following change: <ul style="list-style-type: none"> <li>Confirmed that the XAUI PHY support model is final in the "Device Family Support" table.</li> </ul>                                                                                                                                                                                                                                                                            |
| 2019.12.13       | Made the following changes to the "1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP Core" section: <ul style="list-style-type: none"> <li>Updated the Clocking and Reset Sequence topic to state that the 1G/ 2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP core for Intel Cyclone® 10 GX devices supports up to ±100 ppm clock frequency difference for a maximum packet length of 16,000 bytes.</li> </ul>                             |
| 2019.11.04       | Made the following change: <ul style="list-style-type: none"> <li>Clarified which counters are cleared by 0x481 in <i>Enhanced PCS Registers</i>.</li> </ul>                                                                                                                                                                                                                                                                                     |
| 2019.06.12       | Made the following change: <ul style="list-style-type: none"> <li>Clarified that the Enhanced PCS only supports the static polarity inversion feature, but the Standard PCS supports both the static and dynamic polarity inversion features.</li> </ul>                                                                                                                                                                                         |
| 2019.05.13       | Made the following change: <ul style="list-style-type: none"> <li>Renamed Altera Debug Master Endpoint (ADME) to Native PHY DebugMaster Endpoint (NPDM).</li> </ul>                                                                                                                                                                                                                                                                              |
| 2019.01.30       | Made the following change to the 1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP Core section: <ul style="list-style-type: none"> <li>Updated Table: <i>Clock and Reset Signals</i> to update the description for <code>rx_pma_clkout</code>.</li> </ul>                                                                                                                                                                                    |
| 2018.10.16       | Made the following change: <ul style="list-style-type: none"> <li>For <code>PRESERVE_UNUSED_XCVR_CHANNEL</code>, clarified that an example of <code>&lt;pin_name&gt;</code> is U34, not PIN_U34.</li> </ul>                                                                                                                                                                                                                                      |
| 2018.09.24       | Made the following changes to the 1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP Core section: <ul style="list-style-type: none"> <li>Added <i>Functional Description</i> section.</li> <li>Updated the note in <i>About the 1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP Core</i> topic.</li> <li>For the 1G/2.5G/5G/10G Multi-rate Ethernet status signal, added a Clock Domain values for <code>led_char_err</code>.</li> </ul> |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>• Added 10M and 100M speed support for 1G/2.5G/5G/10G (USXGMII) variant for 1G/2.5G/5G/10G Multi-rate Ethernet PHY Intel FPGA IP core.</li> <li>• Updated the <i>Device Family Support</i> section: <ul style="list-style-type: none"> <li>— Removed the description on <i>Definition: Device Support Level</i>.</li> <li>— Added a new Table: <i>Intel FPGA Core Device Support Levels</i>.</li> </ul> </li> <li>• Updated Table: <i>Resource Utilization</i>.</li> <li>• Updated <i>Timing Constraints</i> section.</li> <li>• Updated <i>Configuration Registers</i> section: <ul style="list-style-type: none"> <li>— Added <i>Register Access</i> section.</li> <li>— Removed <i>Definition: Register Access</i> section.</li> </ul> </li> <li>• Updated Figure: <i>PHY Interface Signals</i>.</li> <li>• Updated Table: <i>XGMII Signals</i>: <ul style="list-style-type: none"> <li>— Corrected the direction of <code>xgmii_tx_valid</code>.</li> <li>— Updated the toggle rate of 10G speed for <code>xgmii_tx_valid</code> and <code>xgmii_rx_valid</code>.</li> </ul> </li> <li>• Updated for latest Intel branding standards.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2018.06.15       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>• For the 1G/2.5G/5G/10G Multi-rate Ethernet status signal, added a Clock Domain column and values for all except <code>led_char_err</code>.</li> <li>• Changed the Gen1 PIPE PLL output frequency from 1250MHz to 2500MHz in <i>fPLL IP Parameter Core Settings for PIPE</i> and <i>ATX PLL IP Parameter Core Settings for PIPE</i>.</li> <li>• Updated <i>Disabling/Enabling PRBS Pattern Inversion</i> to address the hard PRBS generator and checker pattern being inverted.</li> <li>• Updated the description of 0x4C0 bit 5 Override AN Parameters Enable to refer to 0x4C3 and changed the start address of the reserved space to 0x4D7 in <i>10GBASE-KR PHY Register Definitions</i>.</li> <li>• Changed the start address of the reserved space to 0x4D7 in <i>1G/10GbE Register Definitions</i>.</li> <li>• Added a frequency to the description of and added a footnote to the <b>Selected CDR reference clock frequency</b> parameter in the "RX PMA Parameters" table.</li> <li>• Added a note about bit slipping after the "Gearbox Parameters" table.</li> <li>• Added a reference and a link to <i>Clock and Reset Interfaces</i> in the "1-Gigabit/10-Gigabit Ethernet (GbE) PHY IP Core" section.</li> <li>• Clarified the description of the <b>Enable PCIe pipe_hclk_in and pipe_hclk_out ports</b> parameter in the "PCIe Ports" table.</li> <li>• Clarified the description of the <code>pipe_hclk_out[0]</code> port in the "Ports for Arria 10 Transceiver Native PHY in PIPE Mode" table.</li> <li>• Changed the values for the <b>Number of fixed dfe taps</b> parameter in the "RX PMA Parameters" table of the <i>Interlaken</i> section.</li> <li>• Changed the description of bit 15 of register address 0x4D0 in the "1G/10GbE Register Definitions" table.</li> <li>• Changed the description of bit 5 of register address 0x4C0 in the "1G/10GbE Register Definitions" table.</li> </ul> |
| 2017.11.06       | <p>Made the following changes to the CPRI section:</p> <ul style="list-style-type: none"> <li>• Removed a note from the "Transmitter and Receiver Latency" section.</li> </ul> <p>Made the following changes to the 1G/2.5G/5G/10G Multi-rate Ethernet PHY IP Core section:</p> <ul style="list-style-type: none"> <li>• Added the "Register Map" section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2016.10.31       | <p>Made the following changes to the 1G/10 Gbps Ethernet PHY IP Core section:</p> <ul style="list-style-type: none"> <li>• Added MII Interface signals to the "1G/10GbE PHY Top-Level Signals" figure.</li> <li>• Added the MII section.</li> <li>• Added the <code>tx_pcfifo_error_1g</code> and <code>rx_pcfifo_error_1g</code> signals to the "Control and Status Signals" table.</li> <li>• Removed bit addresses from the 0x494 register in the "GMII PCS Registers" table.</li> <li>• Changed the read/write description for the 0x495 register in the "GMII PCS Registers" table.</li> <li>• Changed the note for <code>COPPER_DUPLEX_OPERATION</code> in the "GMII PCS Registers" table.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Made the following changes to the Gigabit Ethernet (GbE) and GbE with IEEE 1588v2 section:</p> <ul style="list-style-type: none"> <li>Added description about the RX FIFO and TX FIFO in the "GbE with IEEE 1588v2" section.</li> <li>Added a note to the <code>pll_powerdown</code> signal in the "Connection Guidelines for a GbE/GbE with IEEE 1588v2 PHY Design" figure.</li> <li>Updated the parameter descriptions for in the "Standard PCS Parameters" table.</li> </ul> <p>Made the following changes to the XAUI PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Added further description to the <code>rx_channelaligned</code> signal in the "Optional Control and Status Signals—Soft IP Implementation" table.</li> </ul> <p>Made the following changes to the Using the Arria 10 Transceiver Native PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Added "Synchronous to <code>rx_clkout</code>" for <code>rx_std_wa_patterncolumn[&lt;n&gt;-1:0]</code> in the clock domain column in Word Aligner and Bitslip table.</li> <li>Added "Unused Transceiver Channels" section.</li> </ul> <p>Made the following changes to the CPR1 section:</p> <ul style="list-style-type: none"> <li>New table "Interface Width Options for 10.1376 Gbps and 12.16512 Gbps Data Rates" added.</li> <li>Supported data rates updated for TX PLLs.</li> <li>Data rate values updated in table "General and Datapath Options".</li> </ul> <p>Made the following changes to the PCI Express section:</p> <ul style="list-style-type: none"> <li>Added PIPE Interface width number in the Port column in table "Ports for Arria 10 Transceiver Native PHY in PIPE Mode".</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2016.05.02       | <p>Made the following changes to the 10GBASE-KR PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Updated the version and release date in the "10GBASE-KR PHY Release Information" table.</li> <li>Changed the definitions and parameters in the "General Options Parameters" table.</li> <li>Added the "Speed Detection Parameters" table.</li> <li>Added and removed parameters in the "Auto Negotiation and Link Training Settings" table.</li> <li>Removed parameter from the "10GBASE-R Parameters" table.</li> <li>Changed descriptions in the "10GBASE-KR Register Definitions" table for 0x4B0 and 0x4D0.</li> <li>Added signals to the "Control and Status Signals" table.</li> <li>Added a new bit field for 0x4D1 in the "10GBASE-KR Register Definitions" table.</li> <li>Changed the default value for INITPOSTVAL Init Post tap Value in the "10GBASE-KR Optional Parameters" table.</li> </ul> <p>Made the following changes to the 1G/2.5G/5G/10G Multi-rate Ethernet PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Changed the "Block Diagram of the PHY IP Core" figure.</li> <li>Updated the version and release date in the "PHY Release Information" table.</li> <li>Updated the "Resource Utilization" table.</li> <li>Updated the "PHY Features" table.</li> <li>Changed the "1G/2.5G/5G/10G Multi-rate Ethernet PHY IP Core Parameters" table.</li> <li>Added signals to the "PHY Interface Signals" figure.</li> <li>Added descriptions in the "Clock and Reset Signals" table.</li> <li>Added descriptions in the "Transceiver Mode and Operating Speed Signals" table.</li> <li>Changed the "Avalon Memory-Mapped Interface Signals" table.</li> <li>Added signals to the "XGMII Signals" table.</li> <li>Added registers to the "PHY Register Definitions" table.</li> <li>Added parameters to the "1G/2.5G/5G/10G Multi-rate Ethernet PHY IP Core Parameters" table.</li> </ul> <p>Made the following changes to the 1-Gigabit/10-Gigabit Ethernet (GbE) PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Updated the version and release date in the "1G/10GbE Release Information" table.</li> <li>Added signals to the "1G/10GbE PHY Top-Level Signals" figure.</li> <li>Added signals to the "PHY Interface Signals" figure.</li> <li>Added signals to the "Control and Status Signals" table.</li> <li>Changed descriptions in the "GMII Interface Ports" table.</li> </ul> |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Made the following changes to the Simulating the Transceiver Native PHY IP section:</p> <ul style="list-style-type: none"> <li>Added a footnote to inform that the "NativeLink" mode is not supported by the "Quartus Prime Pro" edition.</li> <li>Added the "Scripting IP Simulation" flow..</li> <li>Replaced the "Generation Version Agnostic IP" and "Platform DesignerPlatform Designer Simulation Scripts", "Use the ip-make-simscript Utility", and "How to Generate Scripts" sections with the "Scripting IP Simulation" section.</li> </ul> <p>Made the following changes to the PCI Express section:</p> <ul style="list-style-type: none"> <li>Updated the "How to Place Channels for PIPE Configuration" section.</li> <li>Updated the "x4 Configuration with Master Channel Adjacent to a HIP", "x4 Configuration with Master Channel not Adjacent to a HIP", "Rate Switch Change" figures.</li> </ul> <p>Made the following changes to the Other Protocols section:</p> <ul style="list-style-type: none"> <li>Replaced the "Design Considerations for Data Rates above 17.4 Gbps Using Arria 10 GT Channels" section.</li> <li>Changed the title from "Design Considerations for Data Rates above 17.4 Gbps Using Arria 10 GT Channels" to "Design Considerations for implementing Arria 10 GT Channels".</li> <li>Changed the data rate from a range of "17.4 Gbps to 28.3 Gbps" to 25.78125 Gbps.</li> <li>Changed the titles of "Valid Permutations for GT and GX Channel Configuration in Transceiver Bank GXBL1G for Channels 0, 1, and 2" and "Valid Permutations for GT and GX Channel Configuration in Transceiver Banks GXBL1E and GXBL1H for Channels 3, 4, and 5".</li> <li>Removed the "Native PHY IP Parameter Settings for PCS Direct Transceiver Configuration Rules" section.</li> <li>Changed "How to Implement Designs for Data Rates Above 17.4 Gbps Using Enhanced PCS in Low Latency Mode" section.</li> <li>Changed the "ATX PLL IP with GT Clock Lines Enabled" figure.</li> <li>Updated the "Valid Permutations for GT and GX Channel Configuration in Transceiver Bank GXBL1G for Channels 0, 1, and 2" and "Valid Permutations for GT and GX Channel Configuration in Transceiver Banks GXBL1E, and GXBL1H for Channels 3, 4, and 5"" tables.</li> </ul> <p>Made the following changes to the CPRI section:</p> <ul style="list-style-type: none"> <li>Updated the "Transceiver Channel Datapath and Clocking for CPRI" figure.</li> <li>Added a note in the "Channel Width Options for Supported Serial Data Rates" table.</li> <li>Changed the fPLL supported data rate in the "TX PLL Supported Data Rates" table.</li> <li>Changed the "General and Datapath Options" table in the "Native PHY IP Parameter Settings for CPRI" section.</li> </ul> <p>Made the following changes to the Arria 10 Transceiver Protocols and PHY IP Support section:</p> <ul style="list-style-type: none"> <li>Moved the 19th footnote from "Protocol Preset" column to "Transceiver PHY IP Core" column.</li> <li>Changed the footnote 14 to the following: "Link training, auto speed negotiation and sequencer functions are not included in the Native PHY IP. The user would have to create soft logic to implement these functions when using Native PHY IP".</li> </ul> |
| 2016.02.11       | <p>Made the following changes to the Other Protocols section:</p> <ul style="list-style-type: none"> <li>Removed the "Design Considerations for Data Rates Above 17.4 Gbps Using Arria 10 GT Channels" section.</li> <li>Updated the maximum data rate for GT channels to 25.8 Gbps.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2015.12.18       | <p>Made the following changes to the 1G/2.5G/10G Multi-rate Ethernet PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Removed signals from the "XGMII Signals" table.</li> <li>Removed signals from the "PHY Interface Signals" figure.</li> <li>Changed the ordering code in the "PHY Release Information" table.</li> </ul> <p>Made the following changes to the XAUI PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Added a description to the "Implementation of the XGMII Specification in Arria 10 Devices Configuration" figure.</li> </ul> <p>Made the following changes to the 10GBASE-KR PHY IP with FEC Option section:</p> <ul style="list-style-type: none"> <li>Added a note to the "Parameterizing the 10GBASE-KR PHY" section.</li> <li>Added new signals to the "Control and Status Signals" table.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Made the following changes to the 1G/10 Gbps Ethernet PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Added a note to the "Parameterizing the 1G/10GbE PHY" section.</li> <li>Added new signals to the "Control and Status Signals" table.</li> <li>Changed the description for calc_clk_1g in the "Clock and Reset Signals" table.</li> </ul> <p>Made the following changes to the PCI Express (PIPE) section:</p> <ul style="list-style-type: none"> <li>Updated the "Rate Switch Change" figure in the Gen3 features section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2015.11.02       | <p>Made the following changes to the Using the Arria 10 Transceiver Native PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Changed the title of "TX and RX FIFO" to "Standard PCS FIFO" in the Standard PCS Ports table.</li> <li>Updated the description and range for "Enable fast sync status reporting for deterministic Latency SM" parameter in the Standard PCS Parameters table.</li> <li>Changed the title of "TX and RX FIFO Parameters" to "Standard PCS FIFO Parameters" in the Standard PCS Parameters table.</li> <li>Updated the "Error marking type" range in the KR-FEC Parameters table in the Enhanced PCS Parameters section.</li> <li>Updated the "Number of fixed DFE taps" value in the Equalization table in the PMA Parameters section.</li> <li>Added a new parameter "Provide separate interface for each channel" in the General and Datapath Options table in the General and Datapath Parameters section.</li> <li>Updated the "PMA configuration rules" value in the General and Datapath Options table in the General and Datapath Parameters section.</li> <li>Removed footnote and added "Hard IP for PCI Express to Native PHY IP" in the "Arria 10 Transceiver Protocols and PHY IP Support" table.</li> <li>Updated the description for "Enable tx_pma_rxfound port (QPI)" parameter in the TX PMA Optional Ports table in the PMA Parameters section.</li> <li>Updated the descriptions for "TX FIFO Mode", "Enable tx_enh_fifo_full port", "Enable tx_enh_fifo_empty port" parameters in the Enhanced PCS TX FIFO Parameters table in the Enhanced PCS Parameters section.</li> <li>Updated the descriptions for "Enable rx_enh_fifo_full port", "Enable rx_enh_fifo_empty port" parameters in the Enhanced PCS RX FIFO Parameters table in the Enhanced PCS Parameters section.</li> <li>Updated the description for "Enable RX byte deserializer" parameter in the Byte Serializer and Deserializer Parameters table in the Standard PCS Parameters section.</li> <li>Updated the description for "Share reconfiguration interface" parameter in the Dynamic Reconfiguration table in the Dynamic Reconfiguration Parameters section.</li> <li>Updated the values and descriptions in the Configuration Profiles table in the Dynamic Reconfiguration Parameters section.</li> <li>Updated the foot note for "tx_pma_clkout" clock to suggest what to do with the clock.</li> <li>Updated the description for "tx_dispval[&lt;n&gt;(&lt;w&gt;/&lt;s&gt;-1:0]" signal in the 8B/10B Encoder and Decoder table in the Standard PCS Ports section.</li> <li>Updated the values and descriptions in the Configuration Profiles table in the Dynamic Reconfiguration Parameters section.</li> <li>Updated the descriptions for "Enable tx_std_pcfifo_full port", "Enable tx_std_pcfifo_empty port", "Enable rx_std_pcfifo_full port", "Enable rx_std_pcfifo_empty port" in the TX and RX FIFO Parameters table in the Standard PCS Parameters section.</li> <li>Added links to other sections which describe the RX rate match FIFO in Basic, GBE and Transceiver channel datapath modes in the Rate Match FIFO Parameters table in the Standard PCS Parameters section.</li> <li>Updated value for Transceiver Configuration rules parameter in the " General and Datapath Options" table in the General and Datapath Parameters section.</li> <li>Added a new parameter "Provide separate interface for each channel" in the " General and Datapath Options" table in the General and Datapath Parameters section.</li> <li>Updated "Transceiver Native PHY IP Core Parameter Editor" figure.</li> <li>Updated "General, Common PMA Options, and Datapath Options" table.</li> <li>Added parameter "Enable tx_pma_analog_reset_ackport" in "TX PMA Optional Ports" table.</li> <li>Updated parameter "Number of fixed DFE taps" in "Equalization" table.</li> <li>Added parameter "Enable rx_analog_reset_ack port" in "RX PMA Optional Ports" table.</li> </ul> |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>Added parameter <b>Separate reconfig_wairequest from the status of AVMM arbitration with PreSICE</b> in "Dynamic Reconfiguration" table.</li> <li>Added parameter "Include PMA analog settings in configuration Files" in "Configuration Files".</li> <li>Added "Analog PMA Settings (Optional) in Dynamic Reconfiguration" table.</li> </ul> <p>Made the following changes to the 1G/10 Gbps Ethernet PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Changed the release date and version in the "1G/10GbE Release Information" table.</li> <li>Changed the descriptions for tx_serial_clk_1g and rx_cdr_refclk_1g in the "Clock and Reset Signals" table.</li> <li>Changed descriptions in the "General Options Parameters" table.</li> <li>Added the "1G Data Mode" table to the <i>PMA Registers</i> section.</li> <li>Removed the "1G Data Mode" rows from the <i>Arria 10 GMII PCS Registers</i> section.</li> </ul> <p>Made the following changes to the 10GBASE-KR PHY IP Core with FEC Option section:</p> <ul style="list-style-type: none"> <li>Added bit 12 to the 0x4B0 word address in the "10GBASE-KR Register Definitions" table.</li> </ul> <p>Made the following changes to the Gigabit Ethernet (GbE) and GbE with IEEE 1588v2 section:</p> <ul style="list-style-type: none"> <li>Added a note to the "Transceiver Channel Datapath and Clocking at 1250 Mbps for GbE, GbE with IEEE 1588v2" figure.</li> <li>Changed the note in the "Gigabit Ethernet (GbE) and GbE with IEEE 1588v2" section.</li> <li>Changed some signal names in the "Signals and Ports for Native PHY IP Configured for GbE or GbE with IEEE 1588v2" figure.</li> <li>Changed the values in the "TX PMA Parameters" table.</li> <li>Added a parameter to and updated values in the "RX PMA Parameters" table.</li> <li>Changed the values in the "Standard PCS Parameters" table.</li> </ul> <p>Made the following changes to the 10GBASE-R section:</p> <ul style="list-style-type: none"> <li>Added description text to the "10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC Variants" section.</li> <li>Changed steps in the "How to Implement 10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC in Arria 10 Transceivers" section.</li> <li>Changed signal names in the "Signals and Ports of Native PHY IP Core for the 10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC" figure.</li> <li>Updated parameters in the "General and Datapath Parameters" table.</li> <li>Updated parameters in the "RX PMA Parameters" table.</li> <li>Updated parameters in the "Enhanced PCS Parameters" table.</li> <li>Updated parameters in the "Block Sync Parameters" table.</li> <li>Updated parameters in the "Dynamic Reconfiguration Parameters" table.</li> </ul> <p>Made the following changes to the XAUI PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Changed the release date and version in the "XAUI Release Information" table.</li> <li>Changed the descriptions in the "XAUI PHY IP Core Registers" table.</li> <li>Added description in the "XAUI PHY IP Core" section.</li> </ul> <p>Made the following changes to the 1G/2.5G/10G Multi-rate Ethernet PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Added this section.</li> </ul> <p>Made the following changes to the PCI Express (PIPE) section:</p> <ul style="list-style-type: none"> <li>Updated description for port "pipe_g3_txdeemph[17:0]" in the "Ports for Arria 10 Transceiver Native PHY in PIPE Mode" table.</li> <li>Updated "Ports for Arria 10 Transceiver Native PHY in PIPE Mode" table for presets to TX De-emphasis mappings.</li> <li>Updated x4 Configuration and x4 Alternate Configuration figures in the "Master Channel in Bonded Configurations section".</li> <li>Updated "PHY IP Core for PCIe (PIPE) Link Equalization for Gen3 Data Rate" section.</li> <li>Updated "Connection Guidelines for a PIPE Gen3 Design" figure.</li> <li>Added recommendations in the "How to Implement PCI Express (PIPE) in Arria 10 Transceivers" section.</li> <li>Updated description of parameter "PCS TX channel bonding master" in the "Parameters for Arria 10 Native PHY IP in PIPE Gen1, Gen2, Gen3 Modes - TX PMA" table.</li> <li>Added table "Parameter Settings for Arria 10 fPLL IP in PIPE Gen1, Gen2, Gen3 modes" in the "fPLL IP Parameter Settings for PIPE" section.</li> </ul> |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>• Added table "Parameters for Arria 10 ATX PLL IP in PIPE Gen1, Gen2, Gen3 modes" in the "ATX PLL IP Parameter Settings for PIPE" section.</li> <li>• Updated description of port pipe_tx_elecidle in the "Ports for Arria 10 Transceiver Native PHY in PIPE Mode" table.</li> <li>• Updated description of port pipe_tx_compliance in the "Ports for Arria 10 Transceiver Native PHY in PIPE Mode" table.</li> <li>• Updated description of port pipe_g3_txdeemph[17:0] in the "Ports for Arria 10 Transceiver Native PHY in PIPE Mode" table.</li> <li>• Added table "fPLL Ports for PIPE" in the section "fPLL Ports for PIPE" section.</li> <li>• Added table "ATX PLL Ports for PIPE" in the "ATX PLL Ports for PIPE" section.</li> <li>• Added table "Arria 10 Preset Mappings to TX De-emphasis" in the "Preset Mappings to TX De-emphasis" section.</li> <li>• Updated figure "Alternate Configuration" figure in the "How to Place Channels for PIPE Configurations" section.</li> <li>• Updated the "PHY IP Core for PCIe (PIPE) Link Equalization for Gen3 Data Rate" section.</li> </ul> <p>Made the following changes to the Other Protocols section:</p> <ul style="list-style-type: none"> <li>• Added the "Enhanced PCS FIFO Operation" section.</li> <li>• Changed the minimum data rate from 960 Mbps to 1.0 Gbps in the "General and Datapath Parameters" table.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2015.05.11       | <p>Made the following changes to the 10GBASE-KR PHY IP Core section:</p> <ul style="list-style-type: none"> <li>• Changed the register definitions for word address 0x4D0 in the "10GBASE-KR PHY Register Definitions" section.</li> </ul> <p>Made the following changes to the 10GBASE-R section:</p> <ul style="list-style-type: none"> <li>• Added a parameter to the "RX PMA Parameters" table.</li> </ul> <p>Made the following changes to the 10GBASE-KR PHY IP Core section:</p> <ul style="list-style-type: none"> <li>• Changed the following bits and descriptions in the "10GBASE-KR PHY Register Definitions" section: <ul style="list-style-type: none"> <li>— Changed the bit and description for address 0x4D0[21:20].</li> <li>— Added address 0x4D0[22].</li> <li>— Removed address 0x4D0[26:24].</li> <li>— Added address 0x4D0[28:24].</li> <li>— Removed addresses 0x4D0[27] and 0x4D0[28].</li> </ul> </li> </ul> <p>Made the following changes to the Interlaken section:</p> <ul style="list-style-type: none"> <li>• Added available preset variations to the "Interlaken" and "How to Implement Interlaken in Arria 10 Transceivers" sections.</li> <li>• Updated the values for some parameters in the "TX PMA Parameters", "RX PMA Parameters", "Enhanced PCS Parameters", "Interlaken Frame Generator Parameters", and "Interlaken Frame Synchronizer Parameters" tables.</li> </ul> <p>Made the following changes to the 1G/10 Gbps Ethernet PHY IP Core section:</p> <ul style="list-style-type: none"> <li>• Changed the product ID in the "1G/10GbE Release Information" table.</li> <li>• Changed the descriptions in the "Clock and Reset Signals" table.</li> <li>• Removed the following bits from address 0x4D0 in the "Register Definitions" table: <ul style="list-style-type: none"> <li>— 19:18</li> <li>— 26:24</li> <li>— 27</li> </ul> </li> </ul> <p>Made the following changes to the PCI Express section:</p> <ul style="list-style-type: none"> <li>• Updated the "Transceiver Channel Datapath for PIPE Gen1/Gen2 Configurations", "PIPE Gen1/Gen2/Gen3 Configurations", "PCIe Reverse Parallel Loopback Mode Datapath", and "Signals and Ports of Native PHY IP for PIPE" figures.</li> <li>• Updated "Rate Switch" Gen3 features.</li> <li>• Updated the "Enable simplified interface" and "Provide separate interface for each channel" parameters in the "Parameters for Arria 10 Native PHY IP in PIPE Gen1, Gen2, Gen3 Modes" table.</li> <li>• Updated the "PCS TX channel; bonding master" parameters in the table "Parameters for Arria 10 Native PHY IP in PIPE Gen1, Gen2, Gen3 Modes - TX PMA" table.</li> <li>• Updated the "Selected CDR reference clock frequency" parameter in the "Parameters for Arria 10 Native PHY IP in PIPE Gen1, Gen2, Gen3 Modes - RX PMA" table.</li> <li>• Updated "How to place channels for PIPE configurations" section to include placement guidelines for using Arria 10 PCIe Hard IP.</li> </ul> |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Made the following changes to the CPRI section:</p> <ul style="list-style-type: none"> <li>Updated the "Connection Guidelines for a CPRI PHY Design" figure.</li> <li>Added table for the "Behavior of word aligner status signals for varying interface widths", when in Manual Mode.</li> </ul> <p>Made the following changes to the Other Protocols section:</p> <ul style="list-style-type: none"> <li>Updated the "Connection Guidelines for a PCS Direct PHY Design" figure.</li> <li>Updated the "Connection Guidelines for an Enhanced PCS in Low Latency Mode Design" figure.</li> <li>Updated the description following the "Rate Match FIFO Insertion with Four Skip Patterns Required for Insertion" figure.</li> <li>Added a Note to the "TX Bit Slip" section.</li> <li>Changed the value for rx_parallel_data in the "TX Bit Slip in 8-bit Mode" and "TX Bit Slip in 16-bit Mode" figures.</li> </ul> <p>Made the following changes to the XAUI PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Removed the set_max_skew constraint from the "XAUI PHY Timing Analyzer SDC Constraints" section.</li> </ul> <p>Made the following changes to the Using the Arria 10 Transceiver Native PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Updated the figure for Transceiver Native PHY IP Core Parameter Editor.</li> <li>PMA parameters <ul style="list-style-type: none"> <li>Updated the PMA parameter categorization in the TX PMA and RX PMA "Equalization" section.</li> <li>Added parameters Enable tx_pma_iqtxrx_clkout port and Enable tx_serialpbken port in "TX PMA Optional Ports" table.</li> <li>Added parameters Enable rx_pma_iqtxrx_clkout port in "RX PMA Optional Ports" table.</li> <li>Updated "RX PMA Parameters" table into "RX CDR Options" and "Equalization" sections.</li> <li>Removed the option Enable rx_pma_div_clkout division factor from RX PMA optional ports table.</li> <li>Updated the description of "CTLE Adaptation Mode" and "DFE Adaptation Mode" in "RX PMA" parameter table.</li> <li>Updated value and description for parameter Enable tx_pma_clkout port and Enable tx_pma_div_clkout port in "TX Bonding Options" table.</li> <li>Updated value and description for parameter Enable rx_pma_clkout port and Enable rx_pma_div_clkout port in "RX PMA Optional Ports" table.</li> </ul> </li> </ul> |
| 2014.12.15       | <p>Made the following changes to the Using the Arria 10 Transceiver Native PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Updated the description of tx_cal_busy and rx_cal_busy signals in the PMA Ports section.</li> <li>Added a new section <i>Enhanced PCS TX and RX Control Ports</i> to better describe the tx_control and rx_control bit encodings used for different protocols. Removed the bit encodings for tx_control and rx_control signals from <i>Enhanced PCS Ports</i> section.</li> <li>Updated the clock domain information about signals mentioned in Enhanced PCS Ports section.</li> <li>Updated the description of rx_std_wa_patteralign signal in Standard PCS Ports section.</li> <li>Updated the parameter descriptions in General Datapath Parameters and PMA Parameters sections.</li> <li>Updated the port descriptions in PMA Ports section.</li> </ul> <p>Made the following changes to the Interlaken section:</p> <ul style="list-style-type: none"> <li>Added another value to the "TX channel bonding mode" parameter in the "TX PMA Parameters" table.</li> <li>Added values to the "PCS TX channel bonding master" and "Actual PCS TX channel bonding master" parameters in the "TX PMA Parameters" table.</li> <li>Corrected the values to the "CTLE adaptation mode" parameter in the "RX PMA Parameters" table.</li> <li>Added the "Enable Interlaken TX random disparity bit" parameter to the "Interlaken Disparity Generator and Checker Parameters" table.</li> <li>Changed the values to four parameters to "Off" in the "Gearbox Parameters" table.</li> <li>Removed the "Enable embedded debug" parameter from the "Dynamic Reconfiguration Parameters" table.</li> </ul> <p>Made the following changes to the Gigabit Ethernet (GbE) and GvE with IEEE 1588v2 section:</p> <ul style="list-style-type: none"> <li>Added a figure description to the "Signals and Ports for Native PHY IP Configured for GbE or GbE with IEEE 1588v2" figure.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                            |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Made the following changes to the 10GBASE-R section:</p> <ul style="list-style-type: none"> <li>Added a figure description to the "Signals and Ports of Native PHY IP Core for the 10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC" figure.</li> </ul> <p>Made the following changes to the 10GBASE-KR PHY IP with FEC Option section:</p> <ul style="list-style-type: none"> <li>Changed the "10GBASE-KR PHY IP Core Block Diagram" figure to activate the Standard TX PCS, Standard RX PCS, and GbE PCS blocks.</li> <li>Added a note to the "10GBASE-KR Functional Description" section.</li> <li>Added new parameters to the "General Options" table.</li> <li>Changed the default values for VPOSTRULE, VPRERULE, INITPOSTVAL, and INITPREVAL in the "Optional Parameters" table.</li> <li>"10GBASE-KR PHY Register Definitions" table: <ul style="list-style-type: none"> <li>Changed the default value for register address 0x4D0[7:4]</li> <li>Changed the default value for register address 0x4D0[17].</li> <li>Changed the descriptions for register address 0x4B2.</li> <li>Changed the descriptions for register addresses 0x4D5 and 0x4D6.</li> </ul> </li> <li>Changed the descriptions for the following signals in the in the "Clock and Reset Signals" table. <ul style="list-style-type: none"> <li>tx_pma_clkout</li> <li>rx_pma_clkout</li> <li>tx_pma_div_clkout</li> <li>rx_pma_div_clkout</li> </ul> </li> <li>Changed the descriptions for the following signals in the in the "XGMII Signals" table. <ul style="list-style-type: none"> <li>xgmii_tx_clk</li> <li>xgmii_rx_clk</li> </ul> </li> <li>Removed the 1588 Soft FIFOs block from the "PHY-Only Design Example with Two Backplane Ethernet and Two Line-Side (1G/10G) Ethernet Channels" figure</li> </ul> <p>Made the following changes to the 1G/10 Gbps Ethernet PHY IP Core section:</p> <ul style="list-style-type: none"> <li>Changed the descriptions for register address 0x4D5 in the "1G/10GbE Register Definitions" table.</li> <li>Removed the Daisy Chain and μP I/F lines from the Link Training block in the "1G/10GbE PHY Block Diagram" figure.</li> <li>Changed the descriptions for 0x494 and 0x495, and added 0x4a4 bit 4 to the "GMII PCS Registers" section.</li> </ul> <p>Made the following changes to the XAUI section:</p> <ul style="list-style-type: none"> <li>Added a PMA width requirement in the "Transceiver Clocking and Channel Placement Guidelines in XAUI Configuration" section.</li> <li>Changed the figure description for the "Transceiver Clocking for XAUI Configuration" figure.</li> <li>Changed the note in the "Transceiver Clocking and Channel Placement Guidelines in XAUI Configuration" section.</li> <li>Added a note to the "Transceiver Clocking for XAUI Configuration With Phase Compensation FIFO Enabled" figure.</li> <li>Added the "Transceiver Clocking for XAUI Configuration With Phase Compensation FIFO Enabled" figure.</li> <li>Removed the Data rate parameter from the "General Options" table.</li> <li>Removed the tx_digitalreset signal from the "Clock and Reset Signals" table.</li> <li>Changed the available signals in the "PMA Channel Controller Signals" table.</li> <li>Added the <b>Enable phase compensation FIFO</b> parameter to the "Advanced Options" table.</li> <li>Added the pll_cal_busy_i signal to the "XAUI Top-Level Signals—Soft PCS and PMA" figure.</li> <li>Added the xgmii_rx_inclk port to the "XAUI Top-Level Signals—Soft PCS and PMA" figure.</li> <li>Changed the description in the "Clock and Reset Signals" table.</li> <li>Removed the following signals from the "PMA Channel Controller Signals" table: <ul style="list-style-type: none"> <li>tx_bonding_clocks[5:0]</li> <li>pll_cal_busy_i</li> <li>pll_powerdown_o</li> <li>pll_locked_i</li> </ul> </li> </ul> |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>• Made the following changes to the "XAUI PHY IP Core Registers" table:           <ul style="list-style-type: none"> <li>— Removed cal_blk_powerdown</li> <li>— Removed pma_tx_pll_is_locked</li> <li>— Removed Word Addresses 0x082, 0x083, 0x086, 0x087, 0x088, 0x089</li> <li>— Removed patterndetect[7:0]</li> <li>— Changed the description for syncstatus [7:0]</li> </ul> </li> <li>• Added the xgmii_rx_inclk port to the "SDR RX XGMII Interface" table.</li> <li>• Added the pll_cal_busy_i port to the "PMA Channel Controller Signals" table.</li> <li>• Added the "XAUI PHY Timing Analyzer SDC Constraint" section.</li> </ul> <p>Made the following changes to the PCI Express section:</p> <ul style="list-style-type: none"> <li>• Added PIPE Gen3 32 bit PCS Clock Rates table in the <i>Gen3 Rate Switch</i> section.</li> <li>• Updated the <i>Rate Switch Change</i> figure.</li> <li>• Updated the <i>Bit Mappings When the Simplified Interface Is Disableable</i>.</li> <li>• Updated the figures in <i>How to Place Channels for PIPE Configurations</i>.</li> <li>• Updated the <i>Parameters for Arria 10 Native PHY IP in PIPE Gen1, Gen2, Gen3 Modes - TX PMA</i> table.</li> <li>• Updated the clock domains in <i>Signals and Ports of Native PHY IP for PIPE</i> figure.</li> <li>• Updated the <i>Ports for Arria 10 Transceiver Native PHY in PIPE Mode</i> table.</li> <li>• Updated <i>Logical PCS Master Channel for PIPE Configuration</i> table.</li> <li>• Updated the PCIe Reverse Parallel Loopback in Gen1/Gen2 features with input signal name.</li> <li>• Updated the <i>Rate Switch Change</i> figure.</li> <li>• Updated the Gearbox Gen3 Transmission signals in the <i>Gen3 Data Transmission</i> figure.</li> <li>• Updated the PIPE Design Example section.</li> <li>• Updated the <i>Gen3 Power State Management P1 to P0 Transition</i> signals.</li> <li>• Updated the <i>Supported Features for PIPE Configurations</i> table.</li> <li>• Updated the <i>Gen1/Gen2 Features</i> section.</li> </ul> <p>Made the following changes to the CPRI section:</p> <ul style="list-style-type: none"> <li>• Updated the parameter values for "RX word aligner mode".</li> <li>• Added a new option for Interlaken in the GUI "Enable Interlaken TX random disparity bit".</li> <li>• For PMA configuration rules changed the option "SATA" to "SATA/SAS".</li> <li>• Changed the GUI option "CTLE adaptation mode" to "DFE adaptation mode".</li> </ul> <p>Made the following changes to the Other Protocols section:</p> <ul style="list-style-type: none"> <li>• Added four new sections: "TX Bit Slip", "TX Polarity Inversion", "RX Bit Slip", and "RX Polarity Inversion".</li> <li>• Changed the initial value of tx_parallel_data in the "Manual Mode when the PCS-PMA Interface Width is 10 Bits" and "Manual Mode when the PCS-PMA Interface Width is 16 Bits" figures.</li> <li>• Changed the minimum value for the "Data rate" parameter to 1 Gbps in the "General and Datapath Options Parameters" table.</li> </ul> <p>Made the following changes to the Simulating the Native Transceiver PHY section:</p> <ul style="list-style-type: none"> <li>• In the introductory section, removed the third bullet in the list of netlists you can simulate because gate-level timing simulation is no longer supported.</li> <li>• Removed mention of the ModelSim DE simulator in the "How to Use NativeLink to Specify a ModelSim Simulation" section.</li> </ul> |
| 2014.10.08       | <p>Made the following changes to the Ethernet section:</p> <ul style="list-style-type: none"> <li>• Changed the frequency for mgmt_clk in the "Avalon Memory-Mapped Interface Signals" table for Document Version 10GBASE-KR PHY IP Core with FEC Option and for 1G/10 Gbps Ethernet PHY IP Core.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**continued...**

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Made the following changes to the Other Protocols section:</p> <ul style="list-style-type: none"> <li>Removed an erroneous note regarding Quartus II software legality check restrictions.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2014.08.15       | <p>Made the following changes to the Transceiver Design Flow section:</p> <ul style="list-style-type: none"> <li>Added "Make Pin Assignments Using Pin Planner and Assignment Editor" block to figure "Transceiver Design Flow"</li> <li>Updated <i>Select and Instantiate PHY IP</i>, <i>Generate PHY IP</i>, <i>Select and Instantiate PLL IP</i>, and <i>Generate PLL IP</i> sections to indicate the new IP instantiation flow per ACDS 14.0A10 release.</li> <li>Added a new section for <i>Make Pin Assignments Using Pin Planner and Assignment Editor</i></li> </ul> <p>Made the following changes to the Arria 10 Transceiver Protocols and PHY IP Support section:</p> <ul style="list-style-type: none"> <li>Updated table "Arria 10 Transceiver Protocols and PHY IP Support" <ul style="list-style-type: none"> <li>Removed SFIS and 10G SDI from the table.</li> <li>Updated Protocol Preset, Transceiver Configuration Rule, and PCS Support for protocols in the table.</li> </ul> </li> </ul> <p>Made the following changes to the Using the Arria 10 Transceiver Native PHY IP section:</p> <ul style="list-style-type: none"> <li>Updated references of <b>MegaWizard Plug-In Manager</b> to <b>IP Catalog</b> and <b>Parameter Editor</b>.</li> <li>Added PCS Direct block in figure "Transceiver Native PHY IP Top Level Interfaces and Functional Blocks".</li> <li>Updated figure "Transceiver Native PHY IP GUI" for 14.0A10 release IP GUI.</li> <li>Updated <i>General and Datapath Parameters</i> section <ul style="list-style-type: none"> <li>Updated parameter descriptions in table "General and Datapath Options".</li> <li>Updated parameter descriptions in table "Transceiver Configuration Rule Parameters".</li> </ul> </li> <li>Updated PMA Parameters section <ul style="list-style-type: none"> <li>Updated parameter descriptions in tables "TX PMA Bonding options", "TX PLL Options", "RX PMA Parameters".</li> <li>Added description for <b>CTLE adaptation mode</b> and updated description for <b>DFE adaptation mode</b>.</li> </ul> </li> <li>Enhanced PCS Parameters section <ul style="list-style-type: none"> <li>Added a new table "Enhanced PCS Parameters"</li> <li>Updated the parameter descriptions in tables "Enhanced PCS TX FIFO Parameters", "Enhanced PCS RX FIFO Parameters", "Interlaken Frame Generator Parameters", "Interlaken Frame Synchronizer Parameters", "10GBASE-R BER Checker Parameters", "Scrambler-Descrambler Parameters", "Block Synchronizer Parameters", "Gearbox Parameters".</li> <li>Added descriptions in "KR-FEC Parameters" table.</li> </ul> </li> <li>Standard PCS Parameters <ul style="list-style-type: none"> <li>Updated the descriptions in tables "TX and RX FIFO Parameters", "Rate Match FIFO Parameters", "Word Aligner and Bitslip Parameters", and "PCIe Ports".</li> </ul> </li> <li>Dynamic Reconfiguration Parameters <ul style="list-style-type: none"> <li>Removed <b>Enable Embedded JTAG Avalon-MM Master</b> parameter and added <b>Native PHY Debug Master Endpoint</b> parameter and updated its description.</li> <li>Added a table for "Embedded Debug Parameters".</li> </ul> </li> <li>Updated the figure "Directory Structure for Generated Files" in <i>IP Core File Locations</i> section.</li> <li>Changed "one-time" to "triggered" adaptation mode for DFE and CTLE.</li> </ul> <p>Made the following changes to the Interlaken section:</p> <ul style="list-style-type: none"> <li>Changed parameter name in the "Signals and Ports of Native PHY IP for Interlaken" figure from tx_bonding_clock to tx_bonding_clock[5:0].</li> <li>Updated tables in the "Native PHY IP Parameter Settings for Interlaken" section: <ul style="list-style-type: none"> <li>Added new tables: "10GBASE-R BER Checker Parameters", "KR-FEC Parameters".</li> <li>Deleted table: "Configuration Profiles Parameters".</li> <li>Added new parameters and updated existing ones to tables: "General and Datapath Parameters", "TX PMA Parameters", "RX PMA Parameters", "Enhanced PCS Parameters", "Dynamic Reconfiguration Parameters".</li> <li>Updated existing parameters to tables: "Interlaken Frame Generator Parameters", "Interlaken CRC-32 Generator and Checker Parameters".</li> </ul> </li> </ul> |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Made the following changes to the Ethernet section:</p> <ul style="list-style-type: none"> <li>• Initial release of the XAUI PHY IP Core section.</li> <li>• Changed the bus width between the FPGA fabric and PCS, and added notes 3 and 4 to the "Transceiver Channel Datapath and Clocking at 1250 Mbps for GbE, GbE with IEEE 1588v2" figure.</li> <li>• Provided the full hexadecimal values for rx_parallel_data, rx_patterndetect, and rx_runningdisp in the "Decoding for GbE" figure description.</li> <li>• Changed the note in the <i>Rate Match FIFO for GbE</i> section to clarify the case where 200 ppm total is valid.</li> <li>• Added the pll_cal_busy circuitry, updated signals, and added a note to the "Connection Guidelines for a GbE/GbE with IEEE 1588v2 PHY Design" figure.</li> <li>• Removed the Device and speed grade parameter from the "General and Datapath Options" table.</li> <li>• Changed the values for the PPM detector threshold parameter and removed the Decision feedback equalization parameter in the "RX PMA Parameters" table.</li> <li>• Changed the 10GBASE-R PHY grouping in the "10GBASE-R PHY as Part of the IEEE802.3-2008 Open System Interconnection (OSI)" figure.</li> <li>• Added that 10GBASE-R is compatible with the 10-Gbps Ethernet MAC Intel FPGA IP Core Function in the <i>10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC Variants</i> section.</li> <li>• Added the "Transceiver Channel Datapath and Clocking for 10GBASE-R with IEEE 1588v2" figure.</li> <li>• Changed steps 1 and 4 in the <i>How to Implement 10GBASE-R, 10GBASE-R with IEEE 1588v2, and 10GBASE-R with FEC in Arria 10 Transceivers</i> section to match the GUI.</li> <li>• Specified the target BER of <math>10^{-12}</math> in the <i>10GBASE-KR PHY IP Core</i> section.</li> <li>• Removed the "Top Level Modules of the 1G/10GbE PHY Intel FPGA IP Core Function" figure.</li> <li>• Removed the 10GBASE-KR PHY with 1588 variant from the "10GBASE-KR PHY Performance and Resource Utilization" table. This is not supported.</li> <li>• Replaced the "10GBASE-KR PHY IP Block Diagram" figure.</li> <li>• Added the <i>Auto Negotiation, IEEE 802.3 Clause 73</i> section.</li> <li>• Substantially rewrote the <i>Link Training (LT), IEEE 802.3 Clause 72</i> section.</li> <li>• Removed the "TX Equalization for Link Partners" figure.</li> <li>• Removed the "TX Equalization in Daisy Chain Mode" figure. Daisy chain is not supported.</li> <li>• Removed the <i>Auto Negotiation</i> section.</li> <li>• Replaced the "Reconfiguration Block Details" figure.</li> <li>• Removed the <b>Initial Datapath, Enable internal PCS reconfiguration logic, and Enable IEEE 1588 Precision time Protocol</b> parameters from the "General Options Parameters" table.</li> <li>• Added the <b>Reference clock frequency, Enable additional control and status pins, Include FEC sublayer, Set FEC_ability bit on power up and reset, and Set FEC_Enable bit on power up and reset</b> parameters to the "General Options Parameters" table.</li> <li>• Removed the <i>10GBASE-R Parameters</i> section.</li> <li>• Removed the <i>10M/100M/1Gb Ethernet Parameters</i> section.</li> <li>• Removed the <i>Speed Detection Parameters</i> section.</li> <li>• Substantially changed the "Auto Negotiation and Link Training Settings" table, adding the <b>AN_PAUSE Pause Ability, CAPABLE_FEC ENABLE_FEC (request), AN_TECH Technology Ability, AN_SELECTOR Selector Field, and Width of the Training Wait Counter</b> parameters.</li> <li>• Updated all parameter names, values, and descriptions in the "Optional Parameters" table.</li> <li>• Updated the signals in the "10GBASE-KR Top-Level Signals" figure.</li> <li>• Removed the rx_serial_clk_1g and tx_serial_clk_1g signals, and removed all references to "1G" from all descriptions in the "Clock and Reset Signals" table.</li> <li>• Removed references to GMII and MII interfaces from the <i>Data Interfaces</i> section.</li> <li>• Removed GMII and MII signals from the "XGMII Signals" table.</li> <li>• Updated the list of signals in the "Control and Status Signals" table.</li> <li>• Removed the <i>Daisy-Chain Interface Signals</i> section.</li> <li>• Removed the <i>Embedded Processor Interface Signals</i> section.</li> <li>• Updated the list of signals in the "Dynamic Reconfiguration Interface Signals" table.</li> <li>• Added new registers and updated descriptions of existing registers in the "10GBASE-KR Register Definitions" table.</li> <li>• Updated the 0x482 registers in the "PCS Registers" table.</li> <li>• Updated and removed some addresses in the "PMA Registers" table.</li> </ul> |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>• Added the <i>Speed Change Summary</i> section.</li> <li>• Removed the <i>10GBASE-KR, Backplane, FEC, GMII PCS Registers</i> section.</li> <li>• Removed the <i>1588 Delay Requirement</i> section.</li> <li>• Removed the <i>Channel Placement Guidelines</i> section.</li> <li>• Removed the introductory paragraph from the <i>Design Example</i> section.</li> <li>• Removed the 1588 FIFO block from the "Top Level Modules of the 1G/10GbE PHY Intel FPGA IP Core Function" figure.</li> <li>• Updated all values for ALMs, ALUTs, Registers, and M20K in the "1G/10GbE PHY Performance and Resource Utilization" table.</li> <li>• Updated the blocks in the "Reconfiguration Block Details" figure.</li> <li>• Changed the blocks and clock connections in the "Clocks for Standard and 10G PCS and TX PLLs" figure.</li> <li>• Changed signal names and descriptions in the "Clock and Reset Signals" table.</li> <li>• Changed the parameter name for <b>10GbE Reference Clock frequency</b> and added the <b>1G Reference clock frequency</b> parameter in the "10GBASE-R Parameters" table.</li> <li>• Removed the <b>Set FEC_ability bit on power up and reset</b> and <b>Set FEC_enable bit on power up and reset</b> parameters from the "FEC Options" table.</li> <li>• Updated the list of available signals in the "1G/10GbE PHY Top-Level Signals" figure.</li> <li>• Added new registers and updated descriptions of existing registers in the "10GBASE-KR Register Definitions" table.</li> <li>• Added the 0x4A8 and 0x4A9 addresses and updated the name for address 0x4A2 and 0x4A3 in the "10GBASE-KR, Backplane, FEC GMII PCS Registers" table.</li> <li>• Added the <i>Speed Change Summary</i> section.</li> </ul> <p>Made the following changes to the PCI Express section:</p> <ul style="list-style-type: none"> <li>• Added a new topic Pipe link equalization for Gen 3 data rate.</li> <li>• Changed "MegaWizard Plugin Manager" to "Parameter Editor"/"IP Catalog" in the <i>How to Connect TX PLLs for PIPE Gen1, Gen2 and Gen3 Mode</i> section.</li> <li>• Changed "MegaWizard Plugin Manager" to "Parameter Editor"/"IP Catalog" in the <i>How to Implement PCI Express in Arria 10 Transceivers</i> section.</li> <li>• Changed "MegaWizard Plugin Manager" to "Parameter Editor"/"IP Catalog" in the <i>Supported Pipe Features</i> section.</li> </ul> <p>Made the following changes to the CPRI section:</p> <ul style="list-style-type: none"> <li>• Added new values to each row in the "TX PLL Supported Data Rates" table.</li> </ul> <p>Made the following changes to the Other Protocols section:</p> <ul style="list-style-type: none"> <li>• Updated the "How to Use NativeLink to Specify a ModelSim Simulation" section.</li> <li>• Updated the "NativeLink Generated Scripts for Third-Party RTL Simulation" table.</li> <li>• Changed references from MegaWizard to IP Catalog or Parameters Editor.</li> <li>• Using the Basic and Basic with KR FEC Configurations of Enhanced PCS <ul style="list-style-type: none"> <li>— Updated the "Transceiver Channel Datapath and Clocking for Basic (Enhanced PCS) Configuration" figure and added footnote 3.</li> <li>— Updated the "General and Datapath Parameters", "TX PMA Parameters", "RX PMA Parameters", and "Enhanced PCS Parameters" tables.</li> <li>— Added the "Equalization" table.</li> <li>— Added the "How to Enable Low Latency in Basic Enhanced PCS" section.</li> </ul> </li> </ul> |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>• Using the Basic/Custom, Basic/Custom with Rate Match Configurations of Standard PCS           <ul style="list-style-type: none"> <li>— Updated the values in the "Manual Mode when the PCS-PMA Interface is 8 Bits", "Manual Mode when the PCS-PMA Interface is 10 Bits", and "Manual Mode when the PCS-PMA Interface is 16 Bits" figures.</li> <li>— Added the "8B/10B Encoder and Decoder" and "8B/10B TX Disparity Control" sections.</li> <li>— Updated the "Connection Guidelines for a Basic/Custom Design" figure.</li> <li>— Updated the "General and Datapath Options Parameters", "TX PMA Parameters", "RX PMA Parameters", and "Standard PCS Parameters" tables.</li> </ul> </li> <li>• Design Considerations for Data Rates Above 17.4 Gbps Using Arria 10 GT Channels           <ul style="list-style-type: none"> <li>— Updated the maximum data rate for GT channels to 25.4 Gbps.</li> <li>— Added information about PCS Direct mode.</li> <li>— Updated "ATX PLL IP with GT Clock Lines Enabled" figure.</li> </ul> </li> <li>• Updated the <i>How to Implement the Basic, Basic with Rate Match Transceiver Configuration Rules in Arria 10 Transceivers</i> section.</li> </ul> <p>Made the following changes to the Simulating the Transceiver Native PHY IP Core section:</p> <ul style="list-style-type: none"> <li>• Updated the "How to Use NativeLink to Specify a ModelSim Simulation" section.</li> <li>• Updated the "NativeLink Generated Scripts for Third-Party RTL Simulation" table.</li> </ul> |
| 2013.12.02       | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

## 3. PLLs and Clock Networks

---

This chapter describes the transceiver phase locked loops (PLLs), internal clocking architecture, and the clocking options for the transceiver and the FPGA fabric interface.

As shown in the following figure, transceiver banks can have either three or six transceiver channels. For every three channels, you get one advanced transmit (ATX) PLL, one fractional PLL (fPLL), and one Master clock generation block (CGB). Refer to the *Device Transceiver Layout* section to identify which devices have three channel transceiver banks.

The Arria 10 transceiver clocking architecture supports both bonded and non-bonded transceiver channel configurations. Channel bonding is used to minimize the clock skew between multiple transceiver channels. For Arria 10 transceivers, the term bonding can refer to PMA bonding as well as PMA and PCS bonding. Refer to the *Channel Bonding* section for more details.

Figure 170. Arria 10 PLLs and Clock Networks



#### Related Information

- [Channel Bonding](#) on page 399
- [Device Transceiver Layout](#) on page 9

- [Using PLLs and Clock Networks on page 410](#)  
 Information on how to use PLL IP to implement bonded and non-bonded transceiver designs.

### 3.1. PLLs

**Table 231. Transmit PLLs in Arria 10 Devices**

| PLL Type                                                       | Characteristics                                                                                                                                                                                                                                                                     |
|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Advanced Transmit (ATX) PLL                                    | <ul style="list-style-type: none"> <li>• Best jitter performance</li> <li>• LC tank based voltage controlled oscillator (VCO)</li> <li>• Supports fractional synthesis mode (in cascade mode only)</li> <li>• Used for both bonded and non-bonded channel configurations</li> </ul> |
| Fractional PLL (fPLL)                                          | <ul style="list-style-type: none"> <li>• Ring oscillator based VCO</li> <li>• Supports fractional synthesis mode</li> <li>• Used for both bonded and non-bonded channel configurations</li> </ul>                                                                                   |
| Clock Multiplier Unit (CMU) PLL or Channel PLL <sup>(51)</sup> | <ul style="list-style-type: none"> <li>• Ring oscillator based VCO</li> <li>• Used as an additional clock source for non-bonded applications</li> </ul>                                                                                                                             |

**Figure 171. Transmit PLL Recommendation Based on Data Rates**



#### Related Information

Refer to [Using PLL and Clock Networks](#) section for guidelines and usage on page 410

### 3.1.1. Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs

#### ATX PLL-to-ATX PLL Spacing Guidelines

For ATX PLL VCO frequencies between 7.2 GHz and 11.4 GHz, when two ATX PLLs operate at the same VCO frequency (within 100 MHz), they must be placed 7 ATX PLLs apart (skip 6).

---

<sup>(51)</sup> The CMU PLL or Channel PLL of channel 1 and channel 4 can be used as a transmit PLL or as a clock data recovery (CDR) block. The channel PLL of all other channels (0, 2, 3, and 5) can only be used as a CDR.

For ATX PLL VCO frequencies between 11.4 GHz and 14.4 GHz, when two ATX PLLs operate at the same VCO frequency (within 100 MHz) and drive GX channels, they must be placed 4 ATX PLLs apart (skip 3).

For ATX PLL VCO frequencies between 11.4 GHz and 14.4 GHz, when two ATX PLLs operate at the same VCO frequency (within 100 MHz) and drive GT channels, they must be placed 3 ATX PLLs apart (skip 2).

For two ATX PLLs providing the serial clock for PCIe/PIPE Gen3, they must be placed 4 ATX PLL apart (skip 3).

**Note:** If these spacing rules are violated, Intel Quartus Prime issues a critical warning.

When two ATX PLLs are being used, and you meet the following two conditions in your applications:

- One of the ATX PLL re-calibration process is triggered.
- The other channel (that is clocked by another ATX PLL) is in data transmission mode.

You must place the two ATX PLLs 7 ATX PLLs apart (skip 6). ATX PLLs between the 2 active ATX PLLs should not be used.

### ATX PLL-to-fPLL Spacing Guidelines

If you are using both ATX PLL and fPLL, and you meet the below two conditions in your applications:

- When ATX PLL VCO frequency and fPLL VCO frequency is within 50MHz.
- ATX PLL is used to drive protocol which includes OTU2, OTU2e, SDH/Sonet\_9953/OC192/STM64, 10G GPON or protocol that has jitter integration start range <1MHz and data rate > 3Gbps.

The ATX PLL and fPLL must be separated at least by 1 ATX PLL in between.

If you are using both ATX PLL and fPLL, and you meet the below two conditions in your applications:

- fPLL user re-calibration process is triggered.
- ATX PLL is used to drive protocol which includes OTU2, OTU2e, SDH/Sonet\_9953/OC192/STM64, 10G GPON or protocol that has jitter integration start range <1MHz and data rate > 3Gbps.

then the ATX PLL and fPLL must be separated at least by 1 ATX PLL in between (regardless of the ATX PLL and fPLL VCO frequency offset).

#### 3.1.2. ATX PLL

The ATX PLL contains LC tank-based voltage controlled oscillators (VCOs). These LC VCOs have different frequency ranges to support a continuous range of operation. When driving the Transceiver directly, the ATX PLL only supports the integer mode. In cascade mode, the ATX PLL only supports fractional mode.

**Figure 172. ATX PLL Block Diagram**



Note(1) The Delta Sigma Modulator is engaged only when the ATX PLL is used in fractional mode.

### Input Reference Clock

This is the dedicated input reference clock source for the PLL.

The input reference clock can be sourced from one of the following:

- Dedicated reference clock pin
- Reference clock network
- Receiver input pin
- Output of another PLL with PLL cascading
- Global clock or the core clock network

The input reference clock to the dedicated reference clock pin is a differential signal. Intel recommends using the dedicated reference clock pin as the input reference clock source for the best jitter performance. The input reference clock must be stable and free-running at device power-up for proper PLL operation and PLL calibration. If the reference clock is not available at device power-up, then you must recalibrate the PLL when the reference clock is available.

**Note:**

Sourcing reference clock from a cascaded PLL output, global clock or core clock network introduces additional jitter to the ATX PLL output. Refer to KDB "How do I compensate for the jitter of PLL cascading or non-dedicated clock path for Arria 10 PLL reference clock?" for more details.

The ATX PLL calibration is clocked by the CLKUSR clock which must be stable and available for calibration to proceed. Refer to the *Calibration* section for more details about the CLKUSR clock.

### Reference Clock Multiplexer

The reference clock (`refclk`) multiplexer selects the reference clock to the PLL from the various reference clock sources available.

### N Counter

The N counter divides the `refclk` mux's output. The division factors supported are 1, 2, 4, and 8.

### Phase Frequency Detector (PFD)

The reference clock (`refclk`) signal at the output of the N counter block and the feedback clock (`fbcclk`) signal at the output of the M counter block are supplied as inputs to the PFD. The output of the PFD is proportional to the phase difference between the `refclk` and `fbcclk` inputs. It is used to align the `refclk` signal at the output of the N counter to the feedback clock (`fbcclk`) signal. The PFD generates an "Up" signal when the reference clock's falling edge occurs before the feedback clock's falling edge. Conversely, the PFD generates a "Down" signal when the feedback clock's falling edge occurs before the reference clock's falling edge.

### Charge Pump and Loop Filter

The PFD output is used by the charge pump and loop filter (CP and LF) to generate a control voltage for the VCO. The charge pump translates the "Up" or "Down" pulses from the PFD into current pulses. The current pulses are filtered through a low pass filter into a control voltage that drives the VCO frequency. The charge pump, loop filter, and VCO settings determine the bandwidth of the ATX PLL.

### Lock Detector

The lock detector block indicates when the reference clock and the feedback clock are phase aligned. The lock detector generates an active high `pll_locked` signal to indicate that the PLL is locked to its input reference clock.

### Voltage Controlled Oscillator

The voltage controlled oscillator (VCO) used in the ATX PLL is LC tank based. The output of charge pump and loop filter serves as an input to the VCO. The output frequency of the VCO depends on the input control voltage. The output frequency is adjusted based on the output voltage of the charge pump and loop filter.

### L Counter

The L counter divides the differential clocks generated by the ATX PLL. The L counter is not in the feedback path of the PLL.

### M Counter

The M counter's output is the same frequency as the N counter's output. The VCO frequency is governed by the equation:

$$\text{VCO freq} = 2 * \text{M} * \text{input reference clock/N}$$

An additional divider divides the high speed serial clock output of the VCO by 2 before it reaches the M counter.

The M counter supports division factors in a continuous range from 8 to 127 in integer frequency synthesis mode and 11 to 123 in fractional mode.

### Delta Sigma Modulator

The fractional mode is only supported when the ATX PLL is configured as a cascade source for OTN and SDI protocols. The delta sigma modulator is used in fractional mode. It modulates the M counter divide value over time so that the PLL can perform fractional frequency synthesis. In fractional mode, the M value is as follows: .

M (integer) + K/2<sup>32</sup>, where K is the Fractional multiply factor (K) in the ATX PLL IP Parameter Editor

K legal values are 1 through 2<sup>32</sup>-1 and can only be manually entered in the ATX PLL IP Parameter Editor in Quartus Prime software.

The output frequencies can be exact when the ATX PLL is configured in fractional mode. Due to the K value 32-bit resolution, translating to 1.63 Hz step for a 7 GHz VCO frequency, not all desired fractional values can be achieved exactly. The lock signal is not available, when configured in fractional mode in k-precision mode (K < 0.1 or K > 0.9).

### Multiple Reconfiguration Profiles

Under the ATX PLL IP Parameter Editor Dynamic Reconfiguration tab, in the Configuration Profiles section, multiple reconfiguration profiles can be enabled. This allows to create, store, and analyze the parameter settings for multiple configurations or profiles of the ATX PLL IP.

The ATX PLL IP GUI can generate configuration files (SystemVerilog, C header or MIF) for a given configuration. With the multi reconfiguration profile options enabled, the ATX PLL IP Parameter Editor can produce configuration files for all of the profiles simultaneously. In addition, by enabling the reduced reconfiguration files generation, the IP Parameter Editor produces a reduced configuration file by internally comparing the corresponding parameter settings of all the profiles and identifying the differences.

### Embedded Reconfiguration Streamer

This option enables a push-button flow to reconfigure between multiple configurations or profiles. Here are the steps to follow:

1. Multiple reconfiguration profiles creation
  - In the ATX PLL IP GUI, create configurations for each profiles using the multi-profile feature.
2. Reconfiguration report files
  - The IP GUI generates the reconfiguration report files that contain parameter and register settings for all the selected profiles. If the reduced reconfiguration files option is selected, the IP parameter editor compares the settings between the profiles and generate reduced report files which only contain the differences.
3. Select “Enable embedded reconfiguration streamer logic” in the GUI to generate the following:
  - Necessary HDL files to perform streaming.
  - The individual report files for each profile, an SystemVerilog package file with configuration data for all the profiles concatenated together which is used to initialize the configuration ROM
4. Generate the ATX PLL IP and control the reconfiguration streamer using the Avalon memory-mapped interface master.

### Related Information

- [Calibration](#) on page 579
- [How do I compensate for the jitter of PLL cascading or non-dedicated clock path for Arria 10 PLL reference clock?](#)

### 3.1.2.1. Instantiating the ATX PLL IP Core

The Arria 10 transceiver ATX PLL IP core provides access to the ATX PLLs in the hardware. One instance of the PLL IP core represents one ATX PLL in the hardware.

1. Open the Quartus Prime software.
2. Click **Tools > IP Catalog**.
3. In **IP Catalog**, under **Library > Transceiver PLL >**, select **Arria 10 Transceiver ATX PLL** and click **Add**.
4. In the **New IP Instance** dialog box, provide the IP instance name.
5. Select the **Arria 10** device family.
6. Select the appropriate device and click **OK**.

The ATX PLL IP core **Parameter Editor** window opens.

### 3.1.2.2. ATX PLL IP Core

**Table 232. ATX PLL Configuration Options, Parameters, and Settings**

| Parameter                                | Range                                                                                                         | Description                                                                                                                                                                                                                                                                                     |
|------------------------------------------|---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Message level for rule violations</b> | <b>Error<br/>Warning</b>                                                                                      | Specifies the messaging level to use for parameter rule violations. <ul style="list-style-type: none"> <li>• Error—Causes all rule violations to prevent IP generation.</li> <li>• Warning—Displays all rule violations as warnings and allows IP generation in spite of violations.</li> </ul> |
| <b>Protocol mode</b>                     | <b>Basic<br/>PCIe* Gen1<br/>PCIe Gen2<br/>PCIe Gen3<br/>SDI_cascade<br/>OTN_cascade<br/>UPI TX<br/>SAS TX</b> | Governs the internal setting rules for the VCO. This parameter is not a preset. You must set all other parameters for your protocol.                                                                                                                                                            |
| <b>Bandwidth</b>                         | <b>Low<br/>Medium<br/>High</b>                                                                                | Specifies the VCO bandwidth. Higher bandwidth reduces PLL lock time, at the expense of decreased jitter rejection.                                                                                                                                                                              |
| <b>Number of PLL reference clocks</b>    | <b>1 to 5</b>                                                                                                 | Specifies the number of input reference clocks for the ATX PLL. You can use this parameter for data rate reconfiguration.                                                                                                                                                                       |
| <b>Selected reference clock source</b>   | <b>0 to 4</b>                                                                                                 | Specifies the initially selected reference clock input to the ATX PLL.                                                                                                                                                                                                                          |
| <b>Primary PLL clock output buffer</b>   | <b>GX clock output<br/>buffer<br/>GT clock output<br/>buffer</b>                                              | Specifies which PLL output is active initially. <ul style="list-style-type: none"> <li>• If GX is selected, turn ON "<b>Enable PLL GX clock output port</b>".</li> <li>• If GT is selected, turn ON "<b>Enable PLL GT clock output port</b>".</li> </ul>                                        |

*continued...*

| Parameter                                              | Range                                                                        | Description                                                                                                                                                                                                                                                                                       |
|--------------------------------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable PLL GX clock output port</b> <sup>(52)</sup> | <b>On/Off</b>                                                                | Enables the GX output port which feeds x1 clock lines. You must select this parameter for PLL output frequency less than 8.7 GHz, or if you intend to reconfigure the PLL to a frequency below 8.7 GHz.<br>Turn ON this port if GX is selected in the " <b>Primary PLL clock output buffer</b> ". |
| <b>Enable PCIe clock output port</b>                   | <b>On/Off</b>                                                                | Exposes the <code>pll_PCIE_clk</code> port used for PCI Express. The port should be connected to the <code>pipe_hclk_input</code> port.                                                                                                                                                           |
| <b>Enable ATX to FPLL cascade clock output port</b>    | <b>On/Off</b>                                                                | Enables the ATX to FPLL cascade clock output port.                                                                                                                                                                                                                                                |
| <b>Enable fref and clklow port</b> <sup>(53)</sup> .   | <b>On/Off</b>                                                                | Enables <code>fref</code> and <code>clklow</code> ports for external lock detector.                                                                                                                                                                                                               |
| <b>PLL output frequency</b>                            | Refer to <i>Intel Arria 10 Device Datasheet</i> .                            | Use this parameter to specify the target output frequency for the PLL.                                                                                                                                                                                                                            |
| <b>PLL integer reference clock frequency</b>           | Refer to the GUI                                                             | Selects the input reference clock frequency for the PLL.                                                                                                                                                                                                                                          |
| <b>Multiply factor (M-Counter)</b>                     | <b>Read only</b><br><b>For OTN_cascade or SDI_cascade, refer to the GUI.</b> | Displays the M-counter value.<br>Specifies the M-counter value (In SDI_cascade or OTN_cascade Protocol mode only).                                                                                                                                                                                |
| <b>Divide factor (N-Counter)</b>                       | <b>Read only</b><br><b>For SDI_cascade or OTN_cascade, refer to the GUI.</b> | Displays the N-counter value.<br>For SDI_cascade or OTN_cascade, refer to the GUI.                                                                                                                                                                                                                |
| <b>Divide factor (L-Counter)</b>                       | <b>Read only</b>                                                             | Displays the L-counter value.                                                                                                                                                                                                                                                                     |
| <b>Predivide factor (L-Cascade Predivider)</b>         | <b>Refer to the GUI</b>                                                      | Specifies the L-cascade predivider value. This value must be 2 for a VCO frequency greater than 10.46 GHz and 1 for a VCO frequency less than 10.46GHz. (In SDI_cascade or OTN_cascade Protocol mode only).                                                                                       |
| <b>Fractional multiply factor (K)</b>                  | <b>Read only</b>                                                             | Displays the actual K-counter value. This parameter is only available in fractional mode.                                                                                                                                                                                                         |

**Table 233. ATX PLL—Master Clock Generation Block Parameters and Settings**

| Parameter                                                    | Range         | Description                                                                                                 |
|--------------------------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------|
| <b>Include Master Clock Generation Block</b> <sup>(54)</sup> | <b>On/Off</b> | When enabled, includes a master CGB as a part of the ATX PLL IP core. The PLL output drives the Master CGB. |

*continued...*

- 
- (52) You can enable both the GX clock output port and the GT clock output port. However, only one port can be in operation at any given time. You can switch between the two ports using PLL reconfiguration.
- (53) The fPLL `fref` and `clklow` signals should only be used with the Intel external soft lock detection logic.
- (54) Manually enable the MCGB for bonding applications.

| Parameter                                                   | Range                            | Description                                                                                                                                                                                                       |
|-------------------------------------------------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                             |                                  | This is used for x6/xN bonded and non-bonded modes.                                                                                                                                                               |
| <b>Clock division factor</b>                                | <b>1, 2, 4, 8</b>                | Divides the master CGB clock input before generating bonding clocks.                                                                                                                                              |
| <b>Enable x6/xN non-bonded high-speed clock output port</b> | <b>On/Off</b>                    | Enables the master CGB serial clock output port used for x6/xN non-bonded modes.                                                                                                                                  |
| <b>Enable PCIe clock switch interface</b>                   | <b>On/Off</b>                    | Enables the control signals for the PCIe clock switch circuitry. Used for PCIe clock rate switching.                                                                                                              |
| <b>Number of auxiliary MCGB clock input ports</b>           | <b>0, 1</b>                      | Auxiliary input is used to implement the PCIe Gen3 protocol.                                                                                                                                                      |
| <b>MCGB input clock frequency</b>                           | <b>Read only</b>                 | Displays the master CGB's input clock frequency.                                                                                                                                                                  |
| <b>MCGB output data rate.</b>                               | <b>Read only</b>                 | Displays the master CGB's output data rate.                                                                                                                                                                       |
| <b>Enable bonding clock output ports</b>                    | <b>On/Off</b>                    | Enables the tx_bonding_clocks output ports of the master CGB used for channel bonding.<br>This option should be turned ON for bonded designs.                                                                     |
| <b>Enable feedback compensation bonding</b>                 | <b>On/Off</b>                    | Enables this setting when using feedback compensation bonding. For more details about feedback compensation bonding, refer to the <i>PLL Feedback Compensation Bonding</i> section later in the document.         |
| <b>PMA interface width</b>                                  | <b>8, 10, 16, 20, 32, 40, 64</b> | Specifies PMA-PCS interface width.<br>Match this value with the PMA interface width selected for the Native PHY IP core. You must select a proper value for generating bonding clocks for the Native PHY IP core. |

**Table 234. ATX PLL—Dynamic Reconfiguration**

| Parameter                                                                             | Range               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------------------------------------------------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable reconfiguration</b>                                                         | <b>On/Off</b>       | Enables the PLL reconfiguration interface. Enables the simulation models and adds Avalon compliant ports for reconfiguration.                                                                                                                                                                                                                                                                                                                                                                 |
| <b>Enable Native PHY Debug Master Endpoint</b>                                        | <b>On/Off</b>       | When you turn on this option, the Transceiver PLL IP core includes an embedded Native PHY Debug Master Endpoint (NPDME) that connects internally to the Avalon memory-mapped interface slave interface for dynamic reconfiguration. The NPDME can access the reconfiguration space of the transceiver. It can perform certain test and debug functions via JTAG using the System Console. Refer to the <i>Reconfiguration Interface and Dynamic Reconfiguration</i> chapter for more details. |
| <b>Separate reconfig_waitrequest from the status of AVMM arbitration with PreSICE</b> | <b>On/Off</b>       | When enabled, the reconfig_waitrequest does not indicate the status of Avalon memory-mapped interface arbitration with PreSICE. The Avalon memory-mapped interface arbitration status is reflected in a soft status register bit. (Only available if "Enable control and status registers feature" is enabled).                                                                                                                                                                               |
| <b>Enable capability registers</b>                                                    | <b>On/Off</b>       | Enables capability registers that provide high-level information about the ATX PLL's configuration.                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>Set user-defined IP identifier</b>                                                 | <b>User-defined</b> | Sets a user-defined numeric identifier that can be read from the user_identifier offset when the capability registers are enabled.                                                                                                                                                                                                                                                                                                                                                            |
| <b>Enable control and status registers</b>                                            | <b>On/Off</b>       | Enables soft registers for reading status signals and writing control signals on the PLL interface through the embedded debug logic.                                                                                                                                                                                                                                                                                                                                                          |

*continued...*

| Parameter                                       | Range         | Description                                                                                                                                                             |
|-------------------------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Configuration file prefix</b>                |               | Enter the prefix name for the configuration files to be generated.                                                                                                      |
| <b>Generate SystemVerilog package file</b>      | <b>On/Off</b> | Generates a SystemVerilog package file containing all relevant parameters used by the PLL.                                                                              |
| <b>Generate C header file</b>                   | <b>On/Off</b> | Generates a C header file containing all relevant parameters used by the PLL.                                                                                           |
| <b>Enable multiple reconfiguration profiles</b> | <b>On/Off</b> | Enables multiple configuration profiles to be stored.                                                                                                                   |
| <b>Enable embedded reconfiguration streamer</b> | <b>On/Off</b> | Enables embedded reconfiguration streamer which automates the dynamic reconfiguration process between multiple predefined configuration profiles.                       |
| <b>Generate reduced reconfiguration files</b>   | <b>On/Off</b> | When enabled, the IP generates reconfiguration report files containing only the setting differences between the multiple reconfiguration profiles                       |
| <b>Number of reconfiguration profiles</b>       | <b>1 to 8</b> | Specifies the number of reconfiguration profiles                                                                                                                        |
| <b>Store current configuration to profile</b>   | <b>0 to 7</b> | Specifies which configuration profile to modify (store, load, clear or refresh) when clicking the corresponding action button.                                          |
| <b>Generate MIF (Memory Initialize File)</b>    | <b>On/Off</b> | Generates a MIF file which contains the current configuration.<br>Use this option for reconfiguration purposes in order to switch between different PLL configurations. |

**Table 235. ATX PLL—Generation Options**

| Parameter                                    | Range         | Description                                                                                 |
|----------------------------------------------|---------------|---------------------------------------------------------------------------------------------|
| <b>Generate parameter documentation file</b> | <b>On/Off</b> | Generates a .csv file which contains descriptions of ATX PLL IP core parameters and values. |

**Table 236. ATX PLL IP Core Ports**

| Port                 | Direction     | Clock Domain        | Description                                                                                                                                                                                        |
|----------------------|---------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>pll_powerdown</b> | <b>Input</b>  | <b>Asynchronous</b> | Resets the PLL when asserted high. Needs to be connected to a dynamically controlled signal (the Transceiver PHY Reset Controller pll_powerdown output if using this Intel FPGA IP).               |
| <b>pll_refclk0</b>   | <b>Input</b>  | <b>N/A</b>          | Reference clock input port 0. There are a total of five reference clock input ports. The number of reference clock ports available depends on the <b>Number of PLL reference clocks</b> parameter. |
| <b>pll_refclk1</b>   | <b>Input</b>  | <b>N/A</b>          | Reference clock input port 1.                                                                                                                                                                      |
| <b>pll_refclk2</b>   | <b>Input</b>  | <b>N/A</b>          | Reference clock input port 2.                                                                                                                                                                      |
| <b>pll_refclk3</b>   | <b>Input</b>  | <b>N/A</b>          | Reference clock input port 3.                                                                                                                                                                      |
| <b>pll_refclk4</b>   | <b>Input</b>  | <b>N/A</b>          | Reference clock input port 4.                                                                                                                                                                      |
| <b>tx_serial_clk</b> | <b>Output</b> | <b>N/A</b>          | High speed serial clock output port for GX channels. Represents the x1 clock network.                                                                                                              |

*continued...*

| Port                             | Direction     | Clock Domain         | Description                                                                                                                                                                                                                                                       |
|----------------------------------|---------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>tx_serial_clk_gt</b>          | <b>Output</b> | <b>N/A</b>           | High speed serial clock output port for GT channels. Represents the GT clock network.                                                                                                                                                                             |
| <b>pll_locked</b>                | <b>Output</b> | <b>Asynchronous</b>  | Active high status signal which indicates if the PLL is locked.                                                                                                                                                                                                   |
| <b>pll_pcie_clk</b>              | <b>Output</b> | <b>N/A</b>           | Used for PCIe. (55)                                                                                                                                                                                                                                               |
| <b>reconfig_clk0</b>             | <b>Input</b>  | <b>N/A</b>           | Optional Avalon interface clock. Used for PLL reconfiguration. The reconfiguration ports appear only if the <b>Enable Reconfiguration</b> parameter is selected in the PLL IP Core GUI. When this parameter is not selected, the ports are set to OFF internally. |
| <b>reconfig_reset0</b>           | <b>Input</b>  | <b>reconfig_clk0</b> | Used to reset the Avalon interface. Asynchronous to assertion and synchronous to deassertion.                                                                                                                                                                     |
| <b>reconfig_write0</b>           | <b>Input</b>  | <b>reconfig_clk0</b> | Active high write enable signal.                                                                                                                                                                                                                                  |
| <b>reconfig_read0</b>            | <b>Input</b>  | <b>reconfig_clk0</b> | Active high read enable signal.                                                                                                                                                                                                                                   |
| <b>reconfig_address0[9:0]</b>    | <b>Input</b>  | <b>reconfig_clk0</b> | 10-bit address bus used to specify address to be accessed for both read and write operations.                                                                                                                                                                     |
| <b>reconfig_writedata0[31:0]</b> | <b>Input</b>  | <b>reconfig_clk0</b> | 32-bit data bus. Carries the write data to the specified address.                                                                                                                                                                                                 |
| <b>reconfig_readdata0[31:0]</b>  | <b>Output</b> | <b>reconfig_clk0</b> | 32-bit data bus. Carries the read data from the specified address.                                                                                                                                                                                                |
| <b>reconfig_waitrequest0</b>     | <b>Output</b> | <b>reconfig_clk0</b> | Indicates when the Avalon interface signal is busy. When asserted, all inputs must be held constant.                                                                                                                                                              |
| <b>pll_cal_busy</b>              | <b>Output</b> | <b>Asynchronous</b>  | Status signal which is asserted high when PLL calibration is in progress. OR this signal with tx_cal_busy port before connecting to the reset controller IP.                                                                                                      |
| <b>mrgb_rst</b>                  | <b>Input</b>  | <b>Asynchronous</b>  | Master CGB reset control. Deassert this reset at the same time as <b>pll_powerdown</b> .                                                                                                                                                                          |
| <b>mrgb_aux_clk0</b>             | <b>Input</b>  | <b>N/A</b>           | Used for PCIe implementation to switch between fPLL and ATX PLL during link speed negotiation.                                                                                                                                                                    |
| <b>tx_bonding_clocks[5:0]</b>    | <b>Output</b> | <b>N/A</b>           | Optional 6-bit bus which carries the low speed parallel clock outputs from the master CGB. Each transceiver channel in a bonded group has this 6-bit bus.<br>Used for channel bonding, and represents the x6/xN clock network.                                    |
| <b>mrgb_serial_clk</b>           | <b>Output</b> | <b>N/A</b>           | High speed serial clock output for x6/xN non-bonded configurations.                                                                                                                                                                                               |

*continued...*(55) Connect this clock to `hclk` in PCIe applications.

| Port                                   | Direction | Clock Domain | Description                                                                                                                        |
|----------------------------------------|-----------|--------------|------------------------------------------------------------------------------------------------------------------------------------|
| pcie_sw[1:0]                           | Input     | Asynchronous | 2-bit rate switch control input used for PCIe protocol implementation.                                                             |
| pcie_sw_done[1:0]                      | Output    | Asynchronous | 2-bit rate switch status output used for PCIe protocol implementation.                                                             |
| atx_to_fpll_cascade_clk                | Output    | N/A          | The ATX PLL output clock is used to drive fPLL reference clock input (only available in SDI_cascade or OTN_cascade protocol mode). |
| ext_lock_detect_clklow <sup>(56)</sup> | Output    | N/A          | Clklow output for external lock detection. It can be exposed by selecting the <b>Enable clklow</b> and <b>fref port</b>            |
| ext_lock_detect_fref <sup>(56)</sup>   | Output    | N/A          | Fref output for external lock detection. It can be exposed by selecting the <b>Enable clklow</b> and <b>fref port</b> .            |

### Related Information

- [Calibration](#) on page 29
- [Avalon Interface Specifications](#)  
The ports related to reconfiguration are compliant with the Avalon specification. Refer to the Avalon specification for more details about these ports.
- [Intel Arria 10 Device Datasheet](#)  
Refer to the Intel Arria 10 Device Datasheet for more details about the PLL output frequency range.
- [Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514
- [Reconfiguring Channel and PLL Blocks](#) on page 515
- [Steps to Perform Dynamic Reconfiguration](#) on page 528
- [Intel Arria 10 device fPLL reports an unlocked condition](#)

### 3.1.3. fPLL

There are two fPLLs in each transceiver bank with six channels (one located at the top and the other at the bottom of the bank). Transceiver banks with three channels have only one fPLL.

**Figure 173. fPLL Block Diagram**



<sup>(56)</sup> The fPLL fref and clklow signals should only be used with the Intel external soft lock detection logic.

When in core mode, for the fPLL to generate output clocks with a fixed frequency and phase relation to an input reference clock, the **Enable phase alignment** option must be selected. In the fractional frequency mode, the fPLL supports data rates from 1 Gbps to 12.5 Gbps.

### Input Reference Clock

This is the dedicated input reference clock source for the PLL.

The input reference clock can be sourced from one of the following:

- Dedicated reference clock pin
- Reference clock network
- Receiver input pin
- Output of another PLL with PLL cascading
- Global clock or the core clock network

The input reference clock is a differential signal. Intel recommends using the dedicated reference clock pin as the input reference clock source for best jitter performance. For protocol jitter compliance at data rates > 10 Gbps, Intel recommends using the dedicated reference clock pin in the same triplet with the fPLL as the input reference clock source. The input reference clock must be stable and free-running at device power-up for proper PLL operation. If the reference clock is not available at device power-up, then you must recalibrate the PLL when the reference clock is available.

**Note:** Sourcing reference clock from a cascaded PLL output, global clock or core clock network introduces additional jitter to the fPLL output. Refer to KDB "How do I compensate for the jitter of PLL cascading or non-dedicated clock path for Arria 10 PLL reference clock?" for more details.

The fPLL calibration is clocked by the CLKUSR clock, which must be stable and available for the calibration to proceed. Refer to the [Calibration](#) on page 579 section for details about PLL calibration and CLKUSR clock.

### Reference Clock Multiplexer

The `refclk` mux selects the reference clock to the PLL from the various available reference clock sources.

### N Counter

The N counter divides the reference clock (`refclk`) mux's output. The N counter division helps lower the loop bandwidth or reduce the frequency within the phase frequency detector's (PFD) operating range. The N counter supports division factors from 1 to 32.

### Phase Frequency Detector

The reference clock (`refclk`) signal at the output of the N counter block and the feedback clock (`fbcclk`) signal at the output of the M counter block are supplied as inputs to the PFD. The output of the PFD is proportional to the phase difference between the `refclk` and `fbcclk` inputs. The PFD aligns the `fbcclk` to the `refclk`. The PFD generates an "Up" signal when the reference clock's falling edge occurs.

before the feedback clock's falling edge. Conversely, the PFD generates a "Down" signal when the feedback clock's falling edge occurs before the reference clock's falling edge.

### Charge Pump and Loop Filter (CP + LF)

The PFD output is used by the charge pump and loop filter to generate a control voltage for the VCO. The charge pump translates the "Up"/"Down" pulses from the PFD into current pulses. The current pulses are filtered through a low pass filter into a control voltage that drives the VCO frequency.

### Voltage Controlled Oscillator

The fPLL has a ring oscillator based VCO. The VCO transforms the input control voltage into an adjustable frequency clock.

VCO freq =  $2 * M * \text{Input reference clock}/N$ . (N and M are the N counter and M counter division factors.)

### L Counter

The L counter divides the VCO's clock output. When the fPLL acts as a transmit PLL, the output of the L counter drives the clock generation block (CGB) and the TX PMA via the X1 clock lines.

### M Counter

The M counter divides the VCO's clock output. The M counter can select any VCO phase. The outputs of the M counter and N counter have same frequency. M counter range is 8 to 127 in integer mode and 11 to 123 in fractional mode.

### Delta Sigma Modulator

The delta sigma modulator is used in fractional mode. It modulates the M counter divide value over time so that the PLL can perform fractional frequency synthesis.

In fractional mode, the M value is as follows:

$M (\text{integer}) + K/2^{32}$ , where K is the fractional multiply factor (K) in the fPLL IP Parameter Editor. The legal values of K are greater than 1% and less than 99% of the full range of  $2^{32}$  and can only be manually entered in the fPLL IP Parameter Editor in the Quartus Prime software.

The output frequencies can be exact when the fPLL is configured in fractional mode. Due to the K value 32-bit resolution, translating to 1.63 Hz step for a 7 GHz VCO frequency, not all desired fractional values can be achieved exactly. The lock signal is not available, when configured in fractional mode in the K-precision mode ( $K < 0.1$  or  $K > 0.9$ ).

### C Counter

The fPLL C counter division factors range from 1 to 512.

### Dynamic Phase Shift

The dynamic phase shift block allows you to adjust the phase of the C counters in user mode. In fractional mode, dynamic phase shift is only available for the C counters.

## Latency

The C counters can be configured to select any VCO phase and a delay of up to 128 clock cycles. The selected VCO phase can be changed dynamically.

### Related Information

- [Calibration on page 579](#)
- [Calibration on page 579](#)  
Details about PLL calibration
- [How do I compensate for the jitter of PLL cascading or non-dedicated clock path for Arria 10 PLL reference clock?](#)

### 3.1.3.1. Instantiating the fPLL IP Core

The fPLL IP core for Arria 10 transceivers provides access to fPLLs in hardware. One instance of the fPLL IP core represents one fPLL in the hardware.

1. Open the Quartus Prime software.
2. Click **Tools > IP Catalog**.
3. In **IP Catalog**, under **Library > Transceiver PLL**, select **Arria 10 Transceiver fPLL** IP core and click **Add**.
4. In the **New IP Instance** dialog box, provide the IP instance name.
5. Select the **Arria 10** device family.
6. Select the appropriate device and click **OK**.

The fPLL IP core **Parameter Editor** window opens.

### 3.1.3.2. fPLL IP Core

**Table 237. fPLL IP Core Configuration Options, Parameters, and Settings**

| Parameters                    | Range                                                                                                                                                                                                                | Description                                                                                                                                                                                                                                                                                                              |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>fPLL Mode</b>              | <b>Core</b><br><b>Cascade Source</b><br><b>Transceiver</b>                                                                                                                                                           | Specifies the fPLL mode of operation.<br>Select <b>Core</b> to use fPLL as a general purpose PLL to drive the FPGA core clock network.<br>Select <b>Cascade Source</b> to connect an fPLL to another PLL as a cascading source.<br>Select <b>Transceiver</b> to use an fPLL as a transmit PLL for the transceiver block. |
| <b>Protocol Mode</b>          | <b>Basic</b><br><b>PCIe* Gen1</b><br><b>PCIe Gen2</b><br><b>PCIe Gen3</b><br><b>SDI_cascade</b><br><b>OTN_cascade</b><br><b>SDI_direct</b><br><b>SATA TX</b><br><b>OTN_direct</b><br><b>SATA_Gen3</b><br><b>HDMI</b> | Governs the internal setting rules for the VCO.<br>This parameter is not a preset. You must set all parameters for your protocol.                                                                                                                                                                                        |
| <b>Enable fractional mode</b> | <b>On/Off</b>                                                                                                                                                                                                        | Enables the fractional frequency mode.                                                                                                                                                                                                                                                                                   |

*continued...*

| Parameters                                            | Range                                                                  | Description                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                       |                                                                        | This enables the PLL to output frequencies which are not integral multiples of the input reference clock.                                                                                                                                                                                                    |
| <b>Enable physical output clock parameters</b>        | <b>On/Off</b>                                                          | Selecting this option allows you to manually specify M, N, C and L counter values.                                                                                                                                                                                                                           |
| <b>Enable clklow and fref ports<sup>(57)</sup></b>    | <b>On/Off</b>                                                          | Enables <b>fref</b> and <b>clklow</b> clock ports for external lock detector. In Transceiver mode when "enable fractional mode" and "SDI_direct" prot_mode are selected, <b>pll_locked port</b> is not available and user can create external lock detector using <b>fref</b> and <b>clklow</b> clock ports. |
| <b>Desired Reference clock frequency</b>              | <b>Refer to the GUI</b>                                                | Specifies the desired PLL input reference clock frequency.                                                                                                                                                                                                                                                   |
| <b>Actual reference clock frequency</b>               | <b>Read-only</b>                                                       | Displays the actual PLL input reference clock frequency.                                                                                                                                                                                                                                                     |
| <b>Number of PLL reference clocks</b>                 | <b>1 to 5</b>                                                          | Specify the number of input reference clocks for the fPLL.                                                                                                                                                                                                                                                   |
| <b>New parameter: Selected reference clock source</b> | <b>0 to 4</b>                                                          | Specifies the initially selected reference clock input to the fPLL.                                                                                                                                                                                                                                          |
| <b>Bandwidth</b>                                      | <b>Low<br/>Medium<br/>High</b>                                         | Specifies the VCO bandwidth.<br>Higher bandwidth reduces PLL lock time, at the expense of decreased jitter rejection.                                                                                                                                                                                        |
| <b>Operation mode</b>                                 | <b>Direct<br/>Feedback<br/>compensation<br/>bonding</b>                | Specifies the feedback operation mode for the fPLL.                                                                                                                                                                                                                                                          |
| <b>Multiply factor (M-counter)</b>                    | <b>8 to 127<br/>(integer mode)<br/>11 to 123<br/>(fractional mode)</b> | Specifies the multiply factor (M-counter).                                                                                                                                                                                                                                                                   |
| <b>Divide factor (N-counter)</b>                      | <b>1 to 31</b>                                                         | Specifies the divide factor (N-counter).                                                                                                                                                                                                                                                                     |
| <b>Divide factor (L-counter)</b>                      | <b>1, 2, 4, 8</b>                                                      | Specifies the divide factor (L-counter).                                                                                                                                                                                                                                                                     |
| <b>Divide factor (K-counter)</b>                      | <b>User defined</b>                                                    | Specifies the divide factor (K-counter).                                                                                                                                                                                                                                                                     |
| PLL output frequency                                  | Read-only                                                              | Displays the target output frequency for the PLL.                                                                                                                                                                                                                                                            |
| PLL Datarate                                          | Read-only                                                              | Displays the PLL datarate.                                                                                                                                                                                                                                                                                   |

**Table 238. fPLL—Master Clock Generation Block Parameters and Settings**

| Parameters                                                  | Range             | Description                                                                                                                                                  |
|-------------------------------------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Include Master Clock Generation Block</b>                | <b>On/Off</b>     | When enabled, includes a master CGB as a part of the fPLL IP core. The PLL output drives the master CGB. This is used for x6/xN bonded and non-bonded modes. |
| <b>Clock division factor</b>                                | <b>1, 2, 4, 8</b> | Divides the master CGB clock input before generating bonding clocks.                                                                                         |
| <b>Enable x6/xN non-bonded high-speed clock output port</b> | <b>On/Off</b>     | Enables the master CGB serial clock output port used for x6/xN non-bonded modes.                                                                             |
| <b>Enable PCIe clock switch interface</b>                   | <b>On/Off</b>     | Enables the control signals used for PCIe clock switch circuitry.                                                                                            |

*continued...*

<sup>(57)</sup> The fPLL **fref** and **clklow** signals should only be used with the Intel external soft lock detection logic.

| Parameters                                  | Range                            | Description                                                                                                                                                                                                           |
|---------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MCGB input clock frequency</b>           | <b>Read only</b>                 | Displays the master CGB's required input clock frequency. You cannot set this parameter.                                                                                                                              |
| <b>MCGB output data rate</b>                | <b>Read only</b>                 | Displays the master CGB's output data rate. You cannot set this parameter.<br>This value is calculated based on MCGB input clock frequency and MCGB clock division factor.                                            |
| <b>Enable bonding clock output ports</b>    | <b>On/Off</b>                    | Enables the <code>tx_bonding_clocks</code> output ports of the Master CGB used for channel bonding.<br>You must enable this parameter for bonded designs.                                                             |
| <b>Enable feedback compensation bonding</b> | <b>On/Off</b>                    | Enables the feedback output path of the master CGB used for feedback compensation bonding. When enabled, the feedback connections are automatically handled by the PLL IP.                                            |
| <b>PMA interface width</b>                  | <b>8, 10, 16, 20, 32, 40, 64</b> | Specifies the PMA-PCS interface width.<br>Match this value with the PMA interface width selected for the Native PHY IP core. You must select a proper value for generating bonding clocks for the Native PHY IP core. |

**Table 239. fPLL—Dynamic Reconfiguration Parameters and Settings**

| Parameter                                                                             | Range         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------------------------------------------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable reconfiguration</b>                                                         | <b>On/Off</b> | Enables the PLL reconfiguration interface. Enables the simulation models and adds more ports for reconfiguration.                                                                                                                                                                                                                                                                                                                                                                             |
| <b>Enable Native PHY Debug Master Endpoint</b>                                        | <b>On/Off</b> | When you turn this option ON, the transceiver PLL IP core includes an embedded Native PHY Debug Master Endpoint (NPDME) that connects internally to the Avalon memory-mapped interface slave interface for dynamic reconfiguration. The NPDME can access the reconfiguration space of the transceiver. It can perform certain test and debug functions via JTAG using the System Console. Refer to the <i>Reconfiguration Interface and Dynamic Reconfiguration</i> chapter for more details. |
| <b>Separate reconfig_waitrequest from the status of AVMM arbitration with PreSICE</b> | <b>On/Off</b> | When enabled, the <code>reconfig_waitrequest</code> does not indicate the status of Avalon memory-mapped interface arbitration with PreSICE. The Avalon memory-mapped interface arbitration status is reflected in a soft status register bit. (Only available if "Enable control and status registers feature" is enabled).                                                                                                                                                                  |
| <b>Enable capability registers</b>                                                    | <b>On/Off</b> | Enables capability registers that provide high-level information about the fPLL's configuration.                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>Set user-defined IP identifier</b>                                                 |               | Sets a user-defined numeric identifier that can be read from the <code>user_identifier</code> offset when the capability registers are enabled.                                                                                                                                                                                                                                                                                                                                               |
| <b>Enable control and status registers</b>                                            | <b>On/Off</b> | Enables soft registers for reading status signals and writing control signals on the PLL interface through the embedded debug logic.                                                                                                                                                                                                                                                                                                                                                          |
| <b>Configuration file prefix</b>                                                      |               | Enter the prefix name for the configuration files to be generated.                                                                                                                                                                                                                                                                                                                                                                                                                            |

*continued...*

| Parameter                                    | Range         | Description                                                                                                                                                         |
|----------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Generate SystemVerilog package file</b>   | <b>On/Off</b> | Generates a SystemVerilog package file containing all relevant parameters used by the PLL.                                                                          |
| <b>Generate C header file</b>                | <b>On/Off</b> | Generates a C header file containing all relevant parameters used by the PLL.                                                                                       |
| <b>Generate MIF (Memory Initialize File)</b> | <b>On/Off</b> | Generates a MIF file that contains the current configuration. Use this option for reconfiguration purposes in order to switch between different PLL configurations. |

**Table 240. Clock Switchover (between Dynamic Reconfiguration and General Options)**

| Clock Switchover Parameter                                            | Range                                                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Create a second input clock pllrefclk1</b>                         | <b>On/Off</b>                                                                                 | Turn on this parameter to have a backup clock attached to your fPLL that can switch with your original reference clock                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>Second Reference Clock Frequency</b>                               | <b>User Defined</b>                                                                           | Specifies the second reference clock frequency for fPLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>Switchover Mode</b>                                                | <b>Automatic Switchover</b><br>Manual Switchover<br>Automatic Switchover with Manual Override | Specifies how Input frequency switchover is handled. Automatic Switchover uses built in circuitry to detect if one of your input clocks has stopped toggling and switch to the other.<br>Manual Switchover creates an EXTSWITCH signal which can be used to manually switch the clock by asserting high for at least 3 cycles.<br>Automatic Switchover with Manual Override acts as Automatic Switchover until the EXTSWITCH goes high, in which case it switches and ignores any automatic switches as long as EXTSWITCH stays high. |
| <b>Switchover Delays</b>                                              | <b>0 to 7</b>                                                                                 | Adds a specific amount of cycle delay to the Switchover Process.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>Create an active_clk signal to indicate the input clock in use</b> | <b>On/Off</b>                                                                                 | This parameter creates an output that indicates which input clock is currently in use by the PLL. Low indicates refclk, High indicates refclk1.                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Create a clkbad signal for each of the input clocks</b>            | <b>On/Off</b>                                                                                 | This parameter creates two clkbad outputs, one for each input clock. Low indicates the CLK is working, High indicates the CLK is not working.                                                                                                                                                                                                                                                                                                                                                                                         |

**Table 241. fPLL - Generation Options**

| Parameter                                     | Direction     | Description                                                                             |
|-----------------------------------------------|---------------|-----------------------------------------------------------------------------------------|
| <b>Generates parameter documentation file</b> | <b>On/Off</b> | Generates a .csv file that contains descriptions of all the fPLL parameters and values. |

**Table 242.** fPLL IP Core Ports

| Port                             | Direction     | Clock Domain         | Description                                                                                                                                                                                       |
|----------------------------------|---------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>pll_powerdown</b>             | <b>input</b>  | <b>Asynchronous</b>  | Resets the PLL when asserted high. Needs to be connected to a dynamically controlled signal (the Transceiver PHY Reset Controller <code>pll_powerdown</code> output if using this Intel FPGA IP). |
| <b>pll_refclk0</b>               | <b>input</b>  | <b>N/A</b>           | Reference clock input port 0. There are five reference clock input ports. The number of reference clock ports available depends on the <b>Number of PLL reference clocks</b> parameter.           |
| <b>pll_refclk1</b>               | <b>input</b>  | <b>N/A</b>           | Reference clock input port 1.                                                                                                                                                                     |
| <b>pll_refclk2</b>               | <b>input</b>  | <b>N/A</b>           | Reference clock input port 2.                                                                                                                                                                     |
| <b>pll_refclk3</b>               | <b>input</b>  | <b>N/A</b>           | Reference clock input port 3.                                                                                                                                                                     |
| <b>pll_refclk4</b>               | <b>input</b>  | <b>N/A</b>           | Reference clock input port 4.                                                                                                                                                                     |
| <b>tx_serial_clk</b>             | <b>output</b> | <b>N/A</b>           | High speed serial clock output port for GX channels. Represents the x1 clock network.                                                                                                             |
| <b>pll_locked</b>                | <b>output</b> | <b>Asynchronous</b>  | Active high status signal which indicates if PLL is locked.                                                                                                                                       |
| <b>hssi_pll_cascade_clk</b>      | <b>output</b> | <b>N/A</b>           | fPLL cascade clock output port                                                                                                                                                                    |
| <b>pll_PCIE_clk</b>              | <b>output</b> | <b>N/A</b>           | Used for PCIe.                                                                                                                                                                                    |
| <b>reconfig_clk0</b>             | <b>input</b>  | <b>N/A</b>           | Optional Avalon interface clock. Used for PLL reconfiguration.                                                                                                                                    |
| <b>reconfig_reset0</b>           | <b>input</b>  | <b>reconfig_clk0</b> | Used to reset the Avalon interface. Asynchronous to assertion and synchronous to deassertion.                                                                                                     |
| <b>reconfig_write0</b>           | <b>input</b>  | <b>reconfig_clk0</b> | Active high write enable signal.                                                                                                                                                                  |
| <b>reconfig_read0</b>            | <b>input</b>  | <b>reconfig_clk0</b> | Active high read enable signal.                                                                                                                                                                   |
| <b>reconfig_address0[9:0]</b>    | <b>input</b>  | <b>reconfig_clk0</b> | 10-bit address bus used to specify address to be accessed for both read and write operations.                                                                                                     |
| <b>reconfig_writedata0[31:0]</b> | <b>input</b>  | <b>reconfig_clk0</b> | 32-bit data bus. Carries the write data to the specified address.                                                                                                                                 |
| <b>reconfig_readdata0[31:0]</b>  | <b>output</b> | <b>reconfig_clk0</b> | 32-bit data bus. Carries the read data from the specified address.                                                                                                                                |
| <b>reconfig_waitrequest0</b>     | <b>output</b> | <b>reconfig_clk0</b> | Indicates when the Avalon interface signal is busy. When asserted, all inputs must be held constant.                                                                                              |
| <b>pll_cal_busy</b>              | <b>output</b> | <b>Asynchronous</b>  | Status signal which is asserted high when PLL calibration is in progress. Perform logical OR with this signal and the <code>tx_cal_busy</code> port on the reset controller IP.                   |
| <b>mcbg_rst</b>                  | <b>input</b>  | <b>Asynchronous</b>  | Master CGB reset control. Deassert this reset at the same time as <code>pll_powerdown</code> .                                                                                                    |

*continued...*

| Port                                          | Direction     | Clock Domain        | Description                                                                                                                                                                                                                                  |
|-----------------------------------------------|---------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>mcgb_aux_clk0</b>                          | <b>input</b>  | <b>N/A</b>          | Used for PCIe to switch between fPLL/ATX PLL during link speed negotiation.                                                                                                                                                                  |
| <b>tx_bonding_clocks[5:0]</b>                 | <b>output</b> | <b>N/A</b>          | Optional 6-bit bus which carries the low speed parallel clock outputs from the Master CGB.<br>Used for channel bonding, and represents the x6/xN clock network.                                                                              |
| <b>mcgb_serial_clk</b>                        | <b>output</b> | <b>N/A</b>          | High speed serial clock output for x6/xN non-bonded configurations.                                                                                                                                                                          |
| <b>pcie_sw[1:0]</b>                           | <b>input</b>  | <b>Asynchronous</b> | 2-bit rate switch control input used for PCIe protocol implementation.                                                                                                                                                                       |
| <b>pcie_sw_done[1:0]</b>                      | <b>output</b> | <b>Asynchronous</b> | 2-bit rate switch status output used for PCIe protocol implementation.                                                                                                                                                                       |
| <b>atx_to_fpll_cascade_clk</b>                | <b>input</b>  | <b>N/A</b>          | Enables fPLL to ATX PLL cascading clock input port.                                                                                                                                                                                          |
| <b>fpll_to_fpll_cascade_clk</b>               | <b>output</b> | <b>N/A</b>          | fPLL to fPLL cascade output port (only in Core mode)                                                                                                                                                                                         |
| <b>active_clk</b>                             | <b>output</b> | <b>N/A</b>          | Creates an output signal that indicates the input clock being used by the PLL. A logic Low on this signal indicates refclk0 is being used and a logic High indicates refclk1 is being used (only in Core mode with Clock Switchover enabled) |
| <b>outclk0</b>                                | <b>output</b> | <b>N/A</b>          | Core output clock 0. (only in Core mode)<br>There are four core fPLL output clock output ports. The number of output clock available depends on the <b>Selected reference clock source</b>                                                   |
| <b>outclk1</b>                                | <b>output</b> | <b>N/A</b>          | Core output clock 1. (only in Core mode)                                                                                                                                                                                                     |
| <b>outclk2</b>                                | <b>output</b> | <b>N/A</b>          | Core output clock 2. (only in Core mode)                                                                                                                                                                                                     |
| <b>outclk3</b>                                | <b>output</b> | <b>N/A</b>          | Core output clock 3. (only in Core mode)                                                                                                                                                                                                     |
| <b>ext_lock_detect_clklow</b> <sup>(58)</sup> | <b>output</b> | <b>N/A</b>          | Clklow output for external lock detection. It can be exposed by selecting the <b>Enable clklow and fref port</b> .                                                                                                                           |
| <b>ext_lock_detect_fref</b> <sup>(58)</sup>   | <b>output</b> | <b>N/A</b>          | Fref output for external lock detection. It can be exposed by selecting the <b>Enable clklow and fref port</b> .                                                                                                                             |
| <b>phase_reset</b>                            | <b>input</b>  | <b>N/A</b>          | Dynamic phase shift reset input signal. To be connected to DPS soft IP phase_reset output.                                                                                                                                                   |

*continued...*

(58) The fPLL fref and clklow signals should only be used with the Intel external soft lock detection logic.

| Port               | Direction    | Clock Domain | Description                                                                              |
|--------------------|--------------|--------------|------------------------------------------------------------------------------------------|
| <b>phase_en</b>    | <b>input</b> | <b>N/A</b>   | Dynamic phase shift enable input signal. To be connected to DPS soft IP phase_en output. |
| <b>updn</b>        | <b>input</b> | <b>N/A</b>   | Dynamic phase shift updn input signal. To be connected to DPS soft IP updn output.       |
| <b>cntsel[3:0]</b> | <b>input</b> | <b>N/A</b>   | Dynamic phase shift counter bus. To be connected to DPS soft IP cntsel output bus.       |

#### Related Information

- Calibration on page 29
- Reconfiguration Interface and Dynamic Reconfiguration on page 514
- Avalon Interface Specifications  
The ports related to reconfiguration are compliant with the Avalon Specification. Refer to the Avalon Specification for more details about these ports.
- Intel Arria 10 device fPLL reports an unlocked condition

#### 3.1.4. CMU PLL

The clock multiplier unit (CMU) PLL resides locally within each transceiver channel. The channel PLL's primary function is to recover the receiver clock and data in the transceiver channel. In this case the PLL is used in clock and data recovery (CDR) mode.

When the channel PLL of channels 1 or 4 is configured in the CMU mode, the channel PLL can drive the local clock generation block (CGB) of its own channel, then the channel cannot be used as a receiver.

The CMU PLL from transceiver channel 1 and channel 4 can also be used to drive other transceiver channels within the same transceiver bank. The CDR of channels 0, 2, 3, and 5 cannot be configured as a CMU PLL.

For datarates lower than 6 Gbps, the local CGB divider has to be engaged (TX local division factor in transceiver PHY IP under the TX PMA tab).

Figure 174. CMU PLL Block Diagram



#### Input Reference Clock

The input reference clock for a CMU PLL can be sourced from either the reference clock network or a receiver input pin. The input reference clock is a differential signal. For protocol jitter compliance at data rates > 10 Gbps, Intel recommends using the dedicated reference clock pin in the same triplet with the CMU PLL as the input reference clock source. The input reference clock must be stable and free-running at device power-up for proper PLL operation. If the reference clock is not available at device power-up, then you must recalibrate the PLL when the reference clock is available. Refer to the *Calibration* section for details about PLL calibration and the CLKUSR clock requirement.

**Note:** The CMU PLL calibration is clocked by the CLKUSR clock which must be stable and available for calibration to proceed. Refer to the *Calibration* section for more details about the CLKUSR clock.

### Reference Clock Multiplexer (Refclk Mux)

The refclk mux selects the input reference clock to the PLL from the various reference clock sources available.

### N Counter

The N counter divides the refclk mux's output. The N counter division helps lower the loop bandwidth or reduce the frequency to within the phase frequency detector's (PFD) operating range. Possible divide ratios are 1 (bypass), 2, 4, and 8.

### Phase Frequency Detector (PFD)

The reference clock (refclk) signal at the output of the N counter block and the feedback clock (fbclk) signal at the output of the M counter block is supplied as an input to the PFD. The PFD output is proportional to the phase difference between the two inputs. It aligns the input reference clock (refclk) to the feedback clock (fbclk). The PFD generates an "Up" signal when the reference clock's falling edge occurs before the feedback clock's falling edge. Conversely, the PFD generates a "Down" signal when feedback clock's falling edge occurs before the reference clock's falling edge.

### Charge Pump and Loop Filter (CP + LF)

The PFD output is used by the charge pump and loop filter to generate a control voltage for the VCO. The charge pump translates the "Up"/"Down" pulses from the PFD into current pulses. The current pulses are filtered through a low pass filter into a control voltage which drives the VCO frequency.

### Voltage Controlled Oscillator (VCO)

The CMU PLL has a ring oscillator based VCO. For VCO frequency range, refer to the datasheet.

### L Counter

The L counter divides the differential clocks generated by the CMU PLL.

### M Counter

The M counter is used in the PFD's feedback path. The output of the L counter is connected to the M counter. The combined division ratios of the L counter and the M counter determine the overall division factor in the PFD's feedback path.

### Lock Detector (LD)

The lock detector indicates when the CMU PLL is locked to the desired output's phase and frequency. The lock detector XORs the "Up"/"Down" pulses and indicates when the M counter's output and N counter's output are phase-aligned.

The reference clock (`refclk`) and feedback clock (`fbcclk`) are sent to the PCS's ppm detector block. There is a pre-divider to lower the frequency in case the frequency is too high.

#### Related Information

- [Calibration on page 579](#)
- [IntelArria 10 Device Datasheet](#)

### 3.1.4.1. Instantiating CMU PLL IP Core

The CMU PLL IP core for Arria 10 transceivers provides access to the CMU PLLs in hardware. One instance of the CMU PLL IP core represents one CMU PLL in hardware.

1. Open the Quartus Prime software.
2. Click **Tools > IP Catalog**.
3. In **IP Catalog**, under **Library > Transceiver PLL**, select **Arria 10 Transceiver CMU PLL** and click **Add**.
4. In the **New IP Instance Dialog Box**, provide the IP instance name.
5. Select **Arria 10** device family.
6. Select the appropriate device and click **OK**.

The CMU PLL IP core **Parameter Editor** window opens.

### 3.1.4.2. CMU PLL IP Core

**Table 243. CMU PLL Parameters and Settings**

| Parameters                               | Range                 | Description                                                                                                                                                                                                                                                                                      |
|------------------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Message level for rule violations</b> | Error<br>Warning      | Specifies the messaging level to use for parameter rule violations. <ul style="list-style-type: none"><li>• Error - Causes all rule violations to prevent IP generation.</li><li>• Warning - Displays all rule violations as warnings and allows IP generation in spite of violations.</li></ul> |
| <b>Bandwidth</b>                         | Low<br>Medium<br>High | Specifies the VCO bandwidth.<br>Higher bandwidth reduces PLL lock time, at the expense of decreased jitter rejection.                                                                                                                                                                            |
| <b>Number of PLL reference clocks</b>    | 1 to 5                | Specifies the number of input reference clocks for the CMU PLL.<br>You can use this parameter for data rate reconfiguration.                                                                                                                                                                     |
| <b>Selected reference clock source</b>   | 0 to 4                | Specifies the initially selected reference clock input to the CMU PLL.                                                                                                                                                                                                                           |
| <b>TX PLL Protocol mode</b>              | BASIC<br>PCIe         | This parameter governs the rules for correct protocol specific settings. Certain features of the PLL are only available for specific protocol configuration rules. This parameter is not a preset .                                                                                              |

*continued...*

| Parameters                           | Range            | Description                                              |
|--------------------------------------|------------------|----------------------------------------------------------|
|                                      |                  | You must set all the other parameters for your protocol. |
| <b>PLL reference clock frequency</b> | Refer to the GUI | Selects the input reference clock frequency for the PLL. |
| <b>PLL output frequency</b>          | Refer to the GUI | Specify the target output frequency for the PLL.         |
| <b>Multiply factor (M-Counter)</b>   | Read only        | Displays the M-multiplier value.                         |
| <b>Divide factor (N-Counter)</b>     | Read only        | Displays the N-counter value.                            |
| <b>Divide factor (L-Counter)</b>     | Read only        | Displays the L-counter value.                            |

**Table 244. CMU PLL—Dynamic Reconfiguration**

| Parameters                                                                            | Range  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable dynamic reconfiguration</b>                                                 | On/Off | Enables the PLL reconfiguration interface. Enables the simulation models and adds more ports for reconfiguration.                                                                                                                                                                                                                                                                                                                                                                             |
| <b>Enable Native PHY Debug Master Endpoint</b>                                        | On/Off | When you turn this option On, the transceiver PLL IP core includes an embedded Native PHY Debug Master Endpoint (NPDME) that connects internally to the Avalon memory-mapped interface slave interface for dynamic reconfiguration. The NPDME can access the reconfiguration space of the transceiver. It can perform certain test and debug functions via JTAG using the System Console. Refer to the <i>Reconfiguration Interface and Dynamic Reconfiguration</i> chapter for more details. |
| <b>Separate reconfig_waitrequest from the status of AVMM arbitration with PreSICE</b> | On/Off | When enabled, the reconfig_waitrequest does not indicate the status of Avalon memory-mapped interface arbitration with PreSICE. The Avalon memory-mapped interface arbitration status is reflected in a soft status register bit. (Only available if "Enable control and status registers feature" is enabled).                                                                                                                                                                               |
| <b>Enable capability registers</b>                                                    | On/Off | Enables capability registers that provide high-level information about the CMU PLL's configuration.                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>Set user-defined IP identifier</b>                                                 |        | Sets a user-defined numeric identifier that can be read from the user_identifier offset when the capability registers are enabled.                                                                                                                                                                                                                                                                                                                                                            |
| <b>Enable control and status registers</b>                                            | On/Off | Enables soft registers for reading status signals and writing control signals on the PLL interface through the embedded debug logic.                                                                                                                                                                                                                                                                                                                                                          |
| <b>Configuration file prefix</b>                                                      |        | Enter the prefix name for the configuration files to be generated.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>Generate SystemVerilog package file</b>                                            | On/Off | Generates a SystemVerilog package file containing all relevant parameters used by the PLL.                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>Generate C header file</b>                                                         | On/Off | Generates a C header file containing all relevant parameters used by the PLL.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>Generate MIF (Memory Initialize File)</b>                                          | On/Off | Generates a MIF file that contains the current configuration. Use this option for reconfiguration purposes in order to switch between different PLL configurations.                                                                                                                                                                                                                                                                                                                           |

**Table 245. CMU PLL—Generation Options**

| Parameters                                   | Range  | Description                                                                                 |
|----------------------------------------------|--------|---------------------------------------------------------------------------------------------|
| <b>Generate parameter documentation file</b> | On/Off | Generates a .csv file which contains the descriptions of all CMU PLL parameters and values. |

**Table 246. CMU PLL IP Ports**

| <b>Port</b>               | <b>Range</b> | <b>Clock Domain</b> | <b>Description</b>                                                                                                                                                                                                                                                |
|---------------------------|--------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pll_powerdown             | input        | Asynchronous        | Resets the PLL when asserted high.                                                                                                                                                                                                                                |
| pll_refclk0               | input        | N/A                 | Reference clock input port 0. There are 5 reference clock input ports. The number of reference clock ports available depends on the <b>Number of PLL reference clocks</b> parameter.                                                                              |
| pll_refclk1               | input        | N/A                 | Reference clock input port 1.                                                                                                                                                                                                                                     |
| pll_refclk2               | input        | N/A                 | Reference clock input port 2.                                                                                                                                                                                                                                     |
| pll_refclk3               | input        | N/A                 | Reference clock input port 3.                                                                                                                                                                                                                                     |
| pll_refclk4               | input        | N/A                 | Reference clock input port 4.                                                                                                                                                                                                                                     |
| tx_serial_clk             | output       | N/A                 | High speed serial clock output port for GX channels. Represents the x1 clock network.                                                                                                                                                                             |
| pll_locked                | output       | Asynchronous        | Active high status signal which indicates if PLL is locked.                                                                                                                                                                                                       |
| reconfig_clk0             | input        | N/A                 | Optional Avalon interface clock. Used for PLL reconfiguration. The reconfiguration ports appear only if the <b>Enable Reconfiguration</b> parameter is selected in the PLL IP Core GUI. When this parameter is not selected, the ports are set to OFF internally. |
| reconfig_reset0           | input        | reconfig_clk0       | Used to reset the Avalon interface. Asynchronous to assertion and synchronous to deassertion.                                                                                                                                                                     |
| reconfig_write0           | input        | reconfig_clk0       | Active high write enable signal.                                                                                                                                                                                                                                  |
| reconfig_read0            | input        | reconfig_clk0       | Active high read enable signal.                                                                                                                                                                                                                                   |
| reconfig_address0[9:0]    | input        | reconfig_clk0       | 10-bit address bus used to specify address to be accessed for both read and write operations.                                                                                                                                                                     |
| reconfig_writedata0[31:0] | input        | reconfig_clk0       | 32-bit data bus. Carries the write data to the specified address.                                                                                                                                                                                                 |
| reconfig_readdata0[31:0]  | output       | reconfig_clk0       | 32-bit data bus. Carries the read data from the specified address.                                                                                                                                                                                                |
| reconfig_waitrequest0     | output       | reconfig_clk0       | Indicates when the Avalon interface signal is busy. When asserted, all inputs must be held constant.                                                                                                                                                              |
| pll_cal_busy              | output       | Asynchronous        | Status signal that is asserted high when PLL calibration is in progress. Perform logical OR with this signal and the tx_cal_busy port on the reset controller IP.                                                                                                 |

**Related Information**

- [Calibration on page 29](#)
- [Reconfiguration Interface and Dynamic Reconfiguration on page 514](#)

- [Avalon Interface Specifications](#)

The ports related to reconfiguration are compliant with the Avalon Specification. Refer to the Avalon Specification for more details about these ports.

## 3.2. Input Reference Clock Sources

The transmitter PLL and the clock data recovery (CDR) block need an input reference clock source to generate the clocks required for transceiver operation. The input reference clock must be stable and free-running at device power-up for proper PLL calibrations.

Arria 10 transceiver PLLs have five possible input reference clock sources, depending on jitter requirements:

- Dedicated reference clock pins
- Reference clock network
- The output of another fPLL with PLL cascading <sup>(59)</sup>
- Receiver input pins
- Global clock or core clock <sup>(59)</sup>

For the best jitter performance, Intel recommends placing the reference clock as close as possible, to the transmit PLL. For protocol jitter compliance at data rates > 10 Gbps, place the reference clock pin in the same triplet as the transmit PLL.

The following protocols require the reference clock to be placed in same bank as the transmit PLL:

- OTU2e, OTU2, OC-192 and 10G PON
- 6G and 12G SDI

**Note:** Sourcing a reference clock from a cascaded PLL output, global clock or core clock network introduces additional jitter to transmit PLL output. Refer to KDB "How do I compensate for the jitter of PLL cascading or non-dedicated clock path for Arria 10 PLL reference clock?" for more details.

For optimum performance of GT channel, the reference clock of transmit PLL is recommended to be from a dedicated reference clock pin in the same bank.

---

<sup>(59)</sup> Not available for CMU.

Figure 175. Input Reference Clock Sources



Note : (1) You can choose only one of the three RX pins to be used as an input reference clock source. Any RX pin on the same side of the device can be used as an input reference clock.

(2) Dedicated refclk pin can be used as an input reference clock source only for ATX or fPLL or to the reference clock network. Reference clock network can then drive the CMU PLL.

(3) The output of another PLL can be used as an input reference clock source during PLL cascading. Arria 10 transceivers support fPLL to fPLL cascading.

Note:

- In Arria 10 devices, the FPGA fabric core clock network can be used as an input reference source for any PLL type.
- To successfully complete the calibration process, the reference clocks driving the PLLs (ATX PLL, fPLL, CDR/CMU PLL) must be stable and free running at start of FPGA configuration. Otherwise, recalibration is necessary.

**Related Information**

[Calibration](#) on page 579

For more information about the calibration process

### 3.2.1. Dedicated Reference Clock Pins

To minimize the jitter, the advanced transmit (ATX) PLL and the fractional PLL (fPLL) can source the input reference clock directly from the reference clock buffer without passing through the reference clock network. The input reference clock is also fed into the reference clock network.

**Figure 176. Dedicated Reference Clock Pins**

There are two dedicated reference clock (`refclk`) pins available in each transceiver bank. The bottom `refclk` pin feeds the bottom ATX PLL, fPLL, and CMU PLL. The top `refclk` pin feeds the top ATX PLL, fPLL, and CMU PLL. The dedicated reference clock pins can also drive the reference clock network.



### 3.2.2. Receiver Input Pins

Receiver input pins can be used as an input reference clock source to transceiver PLLs. However, they cannot be used to drive core fabric.

The receiver input pin drives the feedback and cascading clock network, which can then feed any number of transmitter PLLs on the same side of the device. When a receiver input pin is used as an input reference clock source, the clock data recovery (CDR) block of that channel is not available. As indicated in [Figure 175](#) on page 383, only one RX differential pin pair per three channels can be used as an input reference clock source at any given time.

### 3.2.3. PLL Cascading as an Input Reference Clock Source

In PLL cascading, PLL outputs are connected to the feedback and cascading clock network. The input reference clock to the first PLL can be sourced from the same network. In this mode, the output of one PLL drives the reference clock input of another PLL. PLL cascading can generate frequency outputs not normally possible with

a single PLL solution. The transceiver in Arria 10 devices support fPLL to fPLL cascading, with only maximum two fPLLs allowed in the cascading chain. ATX PLL to fPLL cascading is available to OTN and SDI protocols only.

**Note:**

- To successfully complete the calibration process, the reference clocks driving the PLLs (ATX PLL, fPLL, CDR/CMU PLL) must be stable and free running at start of FPGA configuration. Otherwise, recalibration is necessary.
- When the fPLL is used as a cascaded fPLL (downstream fPLL), a user recalibration on the fPLL is required. Refer to "User Recalibration" section in "Calibration" chapter for more information.

#### **Related Information**

[Calibration](#) on page 579

For more information about the calibration process

### **3.2.4. Reference Clock Network**

The reference clock network distributes a reference clock source to either the entire left or right side of the FPGA where the transceivers reside. This allows any reference clock pin to drive any transmitter PLL on the same side of the device. Designs using multiple transmitter PLLs which require the same reference clock frequency and are located along the same side of the device, can share the same dedicated reference clock (refclk) pin.

### **3.2.5. Global Clock or Core Clock as an Input Reference Clock**

The global clock or the core clock can be used as an input reference clock for any PLL type.

The global or core clock network routes the clock directly to the PLL. In this case the PLL reference clock network is not used. For best performance, use the dedicated reference clock pins or the reference clock network.

## **3.3. Transmitter Clock Network**

The transmitter clock network routes the clock from the transmitter PLL to the transmitter channel. It provides two types of clocks to the transmitter channel:

- High Speed Serial clock—high-speed clock for the serializer.
- Low Speed Parallel clock—low-speed clock for the serializer and the PCS.

In a bonded channel configuration, both the serial clock and the parallel clock are routed from the transmitter PLL to the transmitter channel. In a non-bonded channel configuration, only the serial clock is routed to the transmitter channel, and the parallel clock is generated locally within the channel. To support various bonded and non-bonded clocking configurations, four types of transmitter clock network lines are available:

- x1 clock lines
- x6 clock lines
- xN clock lines
- GT clock lines

### Related Information

[Unused/Idle Clock Line Requirements](#) on page 399

For more information about unused or idle transceiver clock lines in the design.

### 3.3.1. x1 Clock Lines

The x1 clock lines route the high speed serial clock output of a PLL to any channel within a transceiver bank. The low speed parallel clock is then generated by that particular channel's local clock generation block (CGB). Non-bonded channel configurations use the x1 clock network.

The x1 clock lines can be driven by the ATX PLL, fPLL, or by either one of the two channel PLLs (channel 1 and 4 when used as a CMU PLL) within a transceiver bank.

Figure 177. x1 Clock Lines



### 3.3.2. x6 Clock Lines

The x6 clock lines route the clock within a transceiver bank. The x6 clock lines are driven by the master CGB. The master CGB can only be driven by the ATX PLL or the fPLL. Because the CMU PLLs cannot drive the master CGB, the CMU PLLs cannot be used for bonding purposes. There are two x6 clock lines per transceiver bank, one for each master CGB. Any channel within a transceiver bank can be driven by the x6 clock lines.

For bonded configuration mode, the low speed parallel clock output of the master CGB is used and the local CGB within each channel is bypassed. For non-bonded configurations, the master CGB also provides a high speed serial clock output to each channel without bypassing the local CGB within each channel.

The x6 clock lines also drive the xN clock lines which route the clocks to the neighboring transceiver banks.

**Figure 178. x6 Clock Lines**



### 3.3.3. xN Clock Lines

The xN clock lines route the transceiver clocks across multiple transceiver banks.

The master CGB drives the x6 clock lines and the x6 clock lines drive the xN clock lines. There are two xN clock lines: xN Up and xN Down. xN Up clock lines route the clocks to transceiver banks located above the master CGB and xN Down clock lines route the clocks to transceiver banks located below the master CGB. The xN clock lines can be used in both bonded and non-bonded configurations. For bonded configurations, the low speed parallel clock output of the master CGB is used, and the local CGB within each channel is bypassed. For non-bonded configurations, the master CGB provides a high speed serial clock output to each channel.

**Figure 179. xN Clock Network**



The maximum channel span of a xN clock network is two transceiver banks above and two transceiver banks below the bank that contains the driving PLL and the master CGB. A maximum of 30 channels can be used in a single bonded or non-bonded xN group.

The maximum data rate supported by the xN clock network while driving channels in either the bonded or non-bonded mode depends on the voltage used to drive the transceiver banks.

### Related Information

- [Implementing x6/xN Bonding Mode](#) on page 416
- [x6/xN Bonding](#) on page 399
- [IntelArria 10 Device Datasheet](#)

#### 3.3.4. GT Clock Lines

GT clock lines are dedicated clock lines available only in Arria 10 GT devices.

Each ATX PLL has two dedicated GT clock lines that connect the PLL directly to the transceiver channels within a transceiver bank. The top ATX PLL drives channels 3 and 4, and the bottom ATX PLL drives channels 0 and 1. These connections bypass the rest of the clock network for higher performance. These channels can be used only for non-bonded configurations.

**Figure 180. GT Clock Lines**


### 3.4. Clock Generation Block

In Arria 10 devices, there are two types of clock generation blocks (CGBs)

- Local clock generation block (local CGB)
- Master clock generation block (master CGB)

Each transmitter channel has a local clock generation block (CGB). For non-bonded channel configurations, the serial clock generated by the transmit PLL drives the local CGB of each channel. The local CGB generates the parallel clock used by the serializer and the PCS.

There are two standalone master CGBs within each transceiver bank. The master CGB provides the same functionality as the local CGB within each transceiver channel. The output of the master CGB can be routed to other channels within a transceiver bank using the x6 clock lines. The output of the master CGB can also be routed to channels in other transceiver banks using the xN clock lines. Each transmitter channel has a multiplexer to select its clock source from either the local CGB or the master CGB.

**Figure 181. Clock Generation Block and Clock Network**

The local clock for each transceiver channel can be sourced from either the local CGB via the x1 network, or the master CGB via the x6/xN network. For example, as shown by the red highlighted path, the fPLL 1 drives the x1 network which in turn drives the master CGB. The master CGB then drives the x6 clock network which routes the clocks to the local channels. As shown by the blue highlighted path, the ATX PLL 0 can also drive the x1 clock network which can directly feed a channel's local CGB. In this case, the low speed parallel clock is generated by the local CGB.



### 3.5. FPGA Fabric-Transceiver Interface Clocking

The FPGA fabric-transceiver interface consists of clock signals from the FPGA fabric into the transceiver and clock signals from the transceiver into the FPGA fabric. These clock signals use the global (GCLK), regional (RCLK), and periphery (PCLK) clock

networks in the FPGA core. If the Global Signal is set to Off, it does not choose any of the previously mentioned clock networks. Instead, it chooses directly from the local routing between transceiver and FPGA fabric.

The transmitter channel forwards a parallel output clock `tx_clkout` to the FPGA fabric to clock the transmitter data and control signals. The receiver channel forwards a parallel output clock `rx_clkout` to the FPGA fabric to clock the data and status signals from the receiver into the FPGA fabric. Based on the receiver channel configuration, the parallel output clock is recovered from either the receiver serial data or the `rx_clkout` clock (in configurations without the rate matcher) or the `tx_clkout` clock (in configurations with the rate matcher).

**Figure 182. FPGA Fabric - Transceiver Interface Clocking**



The divided versions of the `tx_clkout` and `rx_clkout` are available as `tx_pma_div_clkout` and `rx_pma_div_clkout`, respectively.

The output frequency of `tx_pma_div_clkout` and `rx_pma_div_clkout` can be one of the following:

- A divided down version of the `tx_clkout` or `rx_clkout` respectively, where divide by 1 and divide by 2 ratios are available.
- A divided down version of the serializer clock where divide by 33, 40, and 66 ratios are available.

**Note:** Refer to the "TX PMA Optional Ports" table in *PMA Parameters* section for details about selecting the division factor.

These clocks can be used to meet core timing by operating the TX and RX FIFO in double-width mode, as this halves the required clock frequency at the PCS to/from FPGA interface. These clocks can also be used to clock the core side of the TX and RX FIFOs when the Enhanced PCS Gearbox is used.

For example, if you use the Enhanced PCS Gearbox with a 66:40 ratio, then you can use `tx_pma_div_clkout` with a divide-by-33 ratio to clock the write side of the TX FIFO, instead of using a PLL to generate the required clock frequency, or using an external clock source.

#### Related Information

[PMA Parameters on page 51](#)

## 3.6. Transmitter Data Path Interface Clocking

The clocks generated by the PLLs are used to clock the channel PMA and PCS blocks. The clocking architecture is different for the standard PCS and the enhanced PCS.

**Figure 183. Transmitter Standard PCS and PMA Clocking**

The master or the local CGB provides the high speed serial clock to the serializer of the transmitter PMA, and the low speed parallel clock to the transmitter PCS.



In the Standard PCS, for configurations that do not use the byte serializer, the parallel clock is used by all the blocks up to the read side of the TX phase compensation FIFO. For configurations that use the byte serializer block, the clock divided by 2 or 4 is used by the byte serializer and the read side of the TX phase compensation FIFO. The clock used to clock the read side of the TX phase compensation FIFO is also forwarded to the FPGA fabric to provide an interface between the FPGA fabric and the transceiver.

If the tx\_clkout that is forwarded to the FPGA fabric is used to clock the write side of the phase compensation FIFO, then both sides of the FIFO have 0 ppm frequency difference because it is the same clock that is used.

If you use a different clock than the tx\_clkout to clock the write side of the phase compensation FIFO, then you must ensure that the clock provided has a 0 ppm frequency difference with respect to the tx\_clkout.

**Figure 184. Transmitter Enhanced PCS and PMA Clocking**

The master or local CGB provides the serial clock to the serializer of the transmitter PMA, and the parallel clock to the transmitter PCS.



In the Enhanced PCS, the parallel clock is used by all the blocks up to the read side of the TX phase compensation FIFO. The clocks of all channels in bonded configuration are forwarded. You can pick tx\_clkout[0] as the source for clocking their TX logic in core.

For the enhanced PCS, the transmitter PCS forwards the following clocks to the FPGA fabric:

tx\_clkout for each transmitter channel in non-bonded and bonded configuration. In bonded configuration, any tx\_clkout can be used depending on your core timing requirements.

You can clock the transmitter datapath interface using one of the following methods:

- Quartus Prime selected transmitter datapath interface clock
- User-selected transmitter datapath interface clock

### 3.7. Receiver Data Path Interface Clocking

The CDR block present in the PMA of each channel recovers the serial clock from the incoming data. The CDR block also divides the recovered serial clock to generate the recovered parallel clock. Both the recovered serial and the recovered parallel clocks are used by the deserializer. The receiver PCS can use the following clocks based on the configuration of the receiver channel:

- Recovered parallel clock from the CDR in the PMA.
- Parallel clock from the clock divider used by the transmitter PCS (if enabled) for that channel.

For configurations that use the byte deserializer block, the clock divided by 2 or 4 is used by the byte deserializer and the write side of the RX phase compensation FIFO.

**Figure 185. Receiver Standard PCS and PMA Clocking**



All configurations that use the standard PCS channel must have a 0 ppm phase difference between the receiver datapath interface clock and the read side clock of the RX phase compensation FIFO.

**Figure 186. Receiver Enhanced PCS and PMA Clocking**



The receiver PCS forwards the following clocks to the FPGA fabric:

- rx\_clkout — for each receiver channel when the rate matcher is not used.
- tx\_clkout — for each receiver channel when the rate matcher is used.

You can clock the receiver datapath interface using one of the following methods:

- Quartus Prime selected receiver datapath interface clock
- User-selected receiver datapath interface clock

#### Related Information

[Unused or Idle Clock Line Requirements](#) on page 399

For more information about unused or idle transceiver clock lines in design.

## 3.8. Unused/Idle Clock Line Requirements

Unused or idle transceiver clock lines can degrade if the devices are powered up to normal operating conditions and not configured. This affects designs that configure transceiver RX channels to use the idle clock lines at a later date by using dynamic reconfiguration or a new device programming file. Clock lines affected are unused, or idle RX serial clock lines. Active RX serial clock lines and non-transceiver circuits are not impacted by this issue.

In order to prevent the performance degradation, for idle transceiver RX channels, recompile designs with Intel Quartus Prime version 16.1 or later with the assignment described in the link shown below. The CLKUSR pin must be assigned a 100-125 MHz clock. For used transceiver TX and RX channels, do not assert the analog reset signals indefinitely.

### Related Information

[Unused Transceiver channels Settings](#) on page 618

For more information about unused or idle transceiver clock lines in the design. It describes the unused or idle RX serial clock lines assignments in the qsf file.

## 3.9. Channel Bonding

For Arria 10 devices, two types of bonding modes are available:

- PMA bonding
- PMA and PCS bonding

*Note:* Channel bonding is not supported by GT channels.

### Related Information

[Resetting Transceiver Channels](#) on page 428

Refer to the *Timing Constraints for Bonded PCS and PMA Channels* section in the *Resetting Transceiver Channels* chapter for additional details.

### 3.9.1. PMA Bonding

PMA bonding reduces skew between PMA channels. In PMA bonding, only the PMA portion of the transceiver datapath is skew compensated and the PCS is not skew compensated.

In Arria 10 devices, there are two PMA bonding schemes:

- x6/xN bonding
- PLL feedback compensation bonding

In either case, the channels in the bonded group need not be placed contiguously.

#### 3.9.1.1. x6/xN Bonding

In x6/xN bonding mode, a single transmit PLL is used to drive multiple channels.

The steps below explain the x6/xN bonding process:

1. The ATX PLL or the fPLL generates a high speed serial clock.
2. The PLL drives the high speed serial clock to the master CGB via the x1 clock network.
3. The master CGB drives the high speed serial and the low speed parallel clock into the x6 clock network.
4. The x6 clock network feeds the TX clock multiplexer for the transceiver channels within the same transceiver bank. The local CGB in each transceiver channel is bypassed.
5. To drive the channels in adjacent transceiver banks, the x6 clock network drives the xN clock network. The xN clock network feeds the TX clock multiplexer for the transceiver channels in these adjacent transceiver banks.

### **x6/xN Bonding Disadvantages**

x6/xN Bonding has the following disadvantages:

- The maximum data rate is restricted based on the transceiver supply voltage. Refer to *Arria 10 Device Data Sheet*.
- The maximum channel span is limited to two transceiver banks above and below the bank containing the transmit PLL. Thus, the maximum span of 30 channels is supported.

### **Related Information**

- [xN Clock Lines](#) on page 389
- [Arria 10 Device Datasheet](#)

#### **3.9.1.2. PLL Feedback Compensation Bonding**

In PLL feedback compensation bonding, channels are divided into bonded groups based on physical location with a three-channel or six-channel transceiver bank. All channels within the same six-channel transceiver bank are assigned to the same bonded group.

In PLL feedback compensation bonding, each bonded group is driven by its own set of high-speed serial and low-speed parallel clocks. Each bonded group has its own PLL and master CGB. To maintain the same phase relationship, the PLL and master CGB for different groups share the same reference clocks.

The steps below explain the PLL feedback compensation bonding process:

1. The same input reference clock drives the local PLL in each three-channel or six-channel transceiver bank.
2. The local PLL for the bonding group drives the master CGB.
3. The master CGB feeds the x6 clock lines. The master CGB drives the transceiver channels in the bonding group via the x6 clock network.
4. The parallel output of the master CGB is the feedback input to the PLL.
5. In this mode, all channels are phase aligned to the same input reference clock.

### **PLL Feedback Compensation Bonding Advantages over x6/xN Bonding Mode**

- There is no data rate restriction. The x6 clock network used for PLL feedback compensation bonding can run up to the maximum data rate of the device used.
- There is no channel span limitation. It is possible to bond the entire side of the device using PLL feedback compensation.

### **PLL Feedback Compensation Bonding Disadvantages over x6/xN Bonding Mode**

- It uses more resources compared to x6/xN bonding. One PLL and one master CGB are used per transceiver bank. This causes higher power consumption compared to x6/xN bonding.
- The skew is higher compared to x6/xN bonding. The reference clock skew between each transceiver bank is higher than the skew contributed by the xN clock network in x6/xN bonding.
- Because the feedback clock for the PLL comes from the master CGB and not from the PLL, the PLL feedback compensation bonding mode has a reference clock limitation. The PLL's N-counter (reference clock divider) is bypassed resulting in only one valid reference clock frequency for a given data rate.
- Feedback compensation bonding only supports integer mode.

**Note:** In order to minimize the reference clock skew for PLL feedback compensation bonding, use a reference clock input near the center of the bonded group.

### **x6/xN Bonding Advantages over PLL Feedback Compensation Bonding**

- x6/xN uses less resources compared to PLL feedback compensation bonding. Only one PLL and one master CGB are required to drive all channels in the bonded group.
- x6/xN has lower skew compared to PLL feedback compensation bonding.

### **Related Information**

[Implementing PLL Feedback Compensation Bonding Mode](#) on page 417

## **3.9.2. PMA and PCS Bonding**

PMA and PCS bonding reduces skew between both the PMA and PCS outputs within a group of channels.

For PMA bonding, either x6/xN or PLL feedback compensation bonding is used. For PCS bonding, some of the PCS control signals within the bonded group are skew aligned using dedicated hardware inside the PCS.

**Figure 187. PMA and PCS Bonding**


For PMA and PCS bonding, the concept of master and slave channels is used. One PCS channel in the bonded group is selected as the master channel and all others are slave channels. To ensure that all channels start transmitting data at the same time and in the same state, the master channel generates a start condition. This condition is transmitted to all slave channels. The signal distribution of this start condition incurs a two parallel clock cycle delay. Because this signal travels sequentially through each PCS channel, this delay is added per channel. The start condition used by each slave channel is delay compensated based on the slave channel's distance from the master channel. This results in all channels starting on the same clock cycle.

The transceiver PHY IP automatically selects the center channel to be the master PCS channel. This minimizes the total starting delay for the bonded group. For PLL feedback compensation bonding up to all channels on one side can be bonded if the master PCS channel is placed in the center of the bonded group.

**Note:** Because the PMA and PCS bonding signals travel through each PCS block, the PMA and PCS bonded groups must be contiguously placed. The channel order needs to be maintained when doing the pin assignments to the dedicated RX serial inputs and TX serial outputs (for example: PIN\_BC7 and PIN\_BC8 for GXBR4D\_TX\_CH0p and GXBR4D\_TX\_CH0n TX serial outputs). Channels need to be placed in an ascending order from bottom to top. Swapping of channels, when doing pin assignments, leads to errors.

### 3.9.3. PCS Bonding Channels Placement Restrictions

There are some placement restrictions for the bonded channels.

### Scenario 1

The hard PCS bonding channels span across channels adjacent to PCIe HIP and channels not adjacent to PCIe HIP as shown in the following figure. The master channel of the PCS bonding channels must be assigned to a channel that is adjacent to PCIe HIP.

**Figure 188. Hard PCS Bonding Channels Span Across Channels Adjacent to PCIe HIP and Channels Not Adjacent to PCIe HIP**



### Scenario 2

The hard PCS bonding channels are not allowed to span across two HIPs as shown in the following figure. You must not use the hard PCS bonding. Implement the soft bonding logic in the core if the bonding channels must span across two HIPs.

**Figure 189. Hard PCS Bonding Channels are Not Allowed to Span Across Two HIPs**



### 3.9.4. Selecting Channel Bonding Schemes

In Arria 10 devices, select PMA and PCS bonding for bonded protocols that are explicitly supported by the hard PCS blocks. For example, PCI Express, SFI-S, and 40GBASE-KR.

Select PMA-only bonding when a bonded protocol is not explicitly supported by the hard PCS blocks. For example, for Interlaken protocol, PMA-only bonding is used and a soft PCS bonding IP is implemented in the FPGA fabric.

### 3.9.5. Skew Calculations

To calculate the maximum skew between the channels, the following parameters are used:

- PMA to PCS datapath interface width (S)
- Maximum difference in number of parallel clock cycles between deassertion of each channel's FIFO reset (N).

To calculate the channel skew, the following five scenarios are considered:

- Non-bonded

In this case, both the PMA and PCS are non-bonded. Skew ranges from 0 UI to  $[(S-1) + N*S]$  UI.

- PMA bonding using x6 / xN clock network

In this case, the PCS is non-bonded. Skew ranges from [0 to  $(N*S)$ ] UI + x6/xN clock skew.

- PMA bonding using the PLL feedback compensation clock network

In this case, the PCS is non-bonded. Skew ranges from [0 to  $(N*S)$ ] UI + (reference clock skew) + (x6 clock skew).

- PMA and PCS bonding using the x6 / xN clock network

Skew = x6 / xN clock skew.

- PMA and PCS bonding using PLL feedback compensation clock network

Skew = (reference clock skew) + (x6 clock skew).

### 3.10. PLL Feedback and Cascading Clock Network

The PLL feedback and cascading clock network spans the entire side of the device, and is used for PLL feedback compensation bonding and PLL cascading.

**Figure 190. PLL Feedback and Cascading Clock Network**



To support PLL feedback compensation bonding and PLL cascading, the following connections are present:

1. The C counter output of the fPLL drives the **feedback and cascading clock** network.
2. The **feedback and cascading clock** network drives the **feedback clock** input of all PLLs.
3. The **feedback and cascading clock** network drives the **reference clock** input of all PLLs.
4. The **master CGB's parallel clock output** drives the **feedback and cascading clock** network.

For PLL cascading, connections (1) and (3) are used to connect the output of one PLL to the reference clock input of another PLL.

**The transceivers in Arria 10 devices support fPLL to fPLL, and ATX PLL to fPLL (via dedicated ATX PLL to fPLL cascade path) cascading. Only maximum two PLLs allowed in the cascading chain.**

**Note:** When the fPLL is used as a cascaded fPLL (downstream fPLL), a user recalibration on the fPLL is required. Refer to "User Recalibration" section in "Calibration" chapter for more information.

For PLL feedback compensation bonding, connections (2) and (4) are used to connect the master CGB's parallel clock output to the PLL feedback clock input port.

PLL feedback compensation bonding can be used instead of xN bonding. The primary difference between PLL feedback compensation and xN bonding configurations, is for PLL feedback compensation, the bonded interface is broken down into smaller groups of 6 bonded channels within a transceiver bank. A PLL within each transceiver bank (ATX PLL or fPLL) is used as a transmit PLL. All the transmit PLLs share the same input reference clock.

In xN bonding configurations, one PLL is used for each bonded group. In PLL feedback compensation bonding, one PLL is used for each transceiver bank that the bonded group spans. There are no data rate limitations in PLL feedback compensation bonding, other than the natural data rate limitations of the transceiver channel and the PLL.

For feedback compensation bonding, the low-speed parallel clock must be the same frequency as the reference clock for the PLL.

#### fPLL Driving the Core

The fPLL can be used to drive the FPGA fabric. To ensure phase alignment between the input reference clock and the fPLL output clock, the fPLL needs to be configured in integer mode. Refer to the following figures when doing dynamic reconfiguration.

**Figure 191. Fractional and not Phase Aligned**

**Figure 192. Integer and Phase Aligned**


**Figure 193. Integer Mode phase aligned and external feedback**



Note: (1) RX pin used as reference clock

You must recalibrate the fPLL when you enable the phase alignment option.

1. Modify the fPLL IP to enable fPLL reconfiguration
  - Under the **Dynamic Reconfiguration** Tab, turn **ON** Enable dynamic reconfiguration.
2. Create logics in the core to perform following steps:

- Read-Modify-Write 0x1 to offset address 0x126[0] of the fPLL to select internal feedback.
  - Read-Modify-Write 0x1 to offset address 0x100 of the fPLL, then Read-Modify-Write 0x1 to offset address 0x000 of the fPLL to request PreSICE to recalibrate the fPLL.
  - Monitor bit 1 of offset address of 0x280 of the fPLL and wait until this bit changes to zero. This indicates recalibration is completed. Ensure the fPLL achieves lock.
  - Read-Modify-Write 0x0 to offset address 0x126[0] of the fPLL to select the external feedback path.
3. Monitor the fPLL lock signal, wait until the fPLL achieves lock.

#### Related Information

- [User Recalibration](#) on page 588
- [Implementing PLL Cascading](#) on page 420

### 3.11. Using PLLs and Clock Networks

In Arria 10 devices, PLLs are not integrated in the Native PHY IP core. You must instantiate the PLL IP cores separately. Unlike in previous device families, PLL merging is no longer performed by the Quartus Prime software. This gives you more control, transparency, and flexibility in the design process. You can specify the channel configuration and PLL usage.

#### Related Information

- [PLLs and Clock Networks](#) on page 356

#### 3.11.1. Non-bonded Configurations

In a non-bonded configuration, only the high speed serial clock is routed from the transmitter PLL to the transmitter channel. The low speed parallel clock is generated by the local clock generation block (CGB) present in the transceiver channel. For non-bonded configurations, because the channels are not related to each other and the feedback path is local to the PLL, the skew between channels cannot be calculated. Also, the skew introduced by the clock network is not compensated.

##### 3.11.1.1. Implementing Single Channel x1 Non-Bonded Configuration

In x1 non-bonded configuration, the PLL source is local to the transceiver bank and the x1 clock network is used to distribute the clock from the PLL to the transmitter channel.

For a single channel design, a PLL is used to provide the clock to a transceiver channel.

**Figure 194. PHY IP Core and PLL IP Core Connection for Single Channel x1 Non-Bonded Configuration Example**



To implement this configuration, instantiate a PLL IP core and a PHY IP core and connect them together as shown in the above figure.

#### Steps to implement a Single Channel x1 Non-Bonded Configuration

1. Instantiate the PLL IP core (ATX PLL, fPLL, or CMU PLL) you want to use in your design.
  - Refer to [Instantiating the ATX PLL IP Core](#) on page 363 or [Instantiating CMU PLL IP Core](#) on page 379 or [Instantiating the fPLL IP Core](#) on page 371 for detailed steps.
2. Configure the PLL IP core using the **IP Parameter Editor**.
  - For ATX PLL IP core, do not include the Master CGB.
  - For fPLL IP core, set the PLL feedback operation mode to **direct**.
  - For CMU PLL IP core, specify the reference clock and the data rate. No special configuration rule is required.
3. Configure the Native PHY IP core using the **IP Parameter Editor**.
  - Set the **Native PHY IP Core TX Channel bonding mode** to **Non Bonded**.
4. Connect the PLL IP core to the Native PHY IP core. Connect the `tx_serial_clk` output port of the PLL to IP to the corresponding `tx_serial_clk0` input port of the Native PHY IP core. This port represents the input to the local CGB of the channel. The `tx_serial_clk` for the PLL represents the high speed serial clock generated by the PLL.

#### 3.11.1.2. Implementing Multi-Channel x1 Non-Bonded Configuration

This configuration is an extension of the x1 non-bonded case. In the following example, 10 channels are connected to two instances of the PLL IP core. Two PLL instances are required because PLLs using the x1 clock network can only span the 6 channels within the same transceiver bank. A second PLL instance is required to provide the clock to the remaining 4 channels.

Because 10 channels are not bonded and are unrelated, you can use a different PLL type for the second PLL instance. It is also possible to use more than two PLL IP cores and have different PLLs driving different channels. If some channels are running at different data rates, then you need different PLLs driving different channels.

**Figure 195. PHY IP Core and PLL IP Core Connection for Multi-Channel x1 Non-Bonded Configuration**



#### Steps to implement a Multi-Channel x1 Non-Bonded Configuration

1. Choose the PLL IP core (ATX PLL, fPLL, or CMU PLL) you want to instantiate in your design and instantiate the PLL IP core.
  - Refer to [Instantiating the ATX PLL IP Core](#) on page 363 or [Instantiating CMU PLL IP Core](#) on page 379 or [Instantiating the fPLL IP Core](#) on page 371 for detailed steps.
2. Configure the PLL IP core using the **IP Parameter Editor**
  - For the ATX PLL IP core do not include the Master CGB. If your design uses the ATX PLL IP core and more than 6 channels, the x1 Non-Bonded Configuration is not a suitable option. Multi-channel xN Non-Bonded or Multi-Channel x1/xN Non-Bonded are the required configurations when using the ATX PLL IP core and more than 6 channels in the Native PHY IP core.
  - Refer to [Figure 196](#) on page 413 Implementing Multi-Channel xN Non-Bonded Configuration section or the [Figure 197](#) on page 415 Multi-Channel x1/xN Non-Bonded Example.
  - For the fPLL IP core, set the PLL feedback operation mode to **direct**.
  - For the CMU PLL IP core, specify the reference clock and the data rate. No special configuration rule is required.
3. Configure the Native PHY IP core using the **IP Parameter Editor**

- Set the **Native PHY IP core TX Channel bonding mode** to **Non-Bonded**.
  - Set the number of channels as per your design requirement. In this example, the number of channels is set to 10.
4. Create a top level wrapper to connect the PLL IP core to the Native PHY IP core.
- The `tx_serial_clk` output port of the PLL IP core represents the high speed serial clock.
  - The Native PHY IP core has 10 (for this example) `tx_serial_clk` input ports. Each port corresponds to the input of the local CGB of the transceiver channel.
  - As shown in the figure above, connect the first 6 `tx_serial_clk` input to the first transceiver PLL instance.
  - Connect the remaining 4 `tx_serial_clk` input to the second transceiver PLL instance.

### 3.11.1.3. Implementing Multi-Channel xN Non-Bonded Configuration

Using the  $xN$  non-bonded configuration reduces the number of PLL resources and the reference clock sources used.

**Figure 196. PHY IP Core and PLL IP Core Connection for Multi-Channel xN Non-Bonded Configuration**

In this example, the same PLL is used to drive 10 channels across two transceiver banks.



### Steps to implement a multi-channel xN non-bonded configuration

1. You can use either the ATX PLL or fPLL for multi-channel xN non-bonded configuration.
  - Refer to [Instantiating the ATX PLL IP Core](#) on page 363 or [Instantiating the fPLL IP Core](#) on page 371 for detailed steps.
  - Because the CMU PLL cannot drive the master CGB, only the ATX PLL or fPLL can be used for this example.
2. Configure the PLL IP core using the **IP Parameter Editor**. Enable **Include Master Clock Generation Block**.
3. Configure the Native PHY IP core using the **IP Parameter Editor**
  - Set the **Native PHY IP core TX Channel bonding mode** to **Non-Bonded**.
  - Set the number of channels as per your design requirement. In this example, the number of channels is set to 10.
4. Create a top level wrapper to connect the PLL IP core to the Native PHY IP core.
  - In this case, the PLL IP core has `mrgb_serial_clk` output port. This represents the xN clock line.
  - The Native PHY IP core has 10 (for this example) `tx_serial_clk` input ports. Each port corresponds to the input of the local CGB of the transceiver channel.
  - As shown in the figure above, connect the `mrgb_serial_clk` output port of the PLL IP core to the 10 `tx_serial_clk` input ports of the Native PHY IP core.

**Figure 197. Multi-Channel x1/xN Non-Bonded Example**

The ATX PLL IP core has a `tx_serial_clk` output port. This port can optionally be used to clock the six channels within the same transceiver bank as the PLL. These channels are clocked by the  $x1$  network. The remaining four channels outside the transceiver bank are clocked by the  $xN$  clock network.



### 3.11.2. Bonded Configurations

In a bonded configuration, both the high speed serial and low speed parallel clocks are routed from the transmitter PLL to the transmitter channel. In this case, the local CGB in each channel is bypassed and the parallel clocks generated by the master CGB are used to clock the network.

In bonded configurations, the transceiver clock skew between the channels is minimized. Use bonded configurations for channel bonding to implement protocols such as PCIe and XAUI.

### 3.11.2.1. Implementing x6/xN Bonding Mode

**Figure 198. PHY IP Core and PLL IP Core Connection for x6/xN Bonding Mode**



#### Steps to implement a x6/xN bonded configuration

1. You can instantiate either the ATX PLL or the fPLL for x6/xN bonded configuration.
  - Refer to [Instantiating the ATX PLL IP Core](#) on page 363 or [Instantiating the fPLL IP Core](#) on page 371 for detailed steps. Because the CMU PLL cannot drive the Master CGB, only the ATX PLL or fPLL can be used for bonded configurations.
2. Configure the PLL IP core using the **IP Parameter Editor**. Enable **Include Master Clock Generation Block** and **Enable bonding** clock output ports.
3. Configure the Native PHY IP core using the **IP Parameter Editor**.
  - Set the **Native PHY IP core TX Channel bonding mode** to either **PMA bonding** or **PMA/PCS bonding** .
  - Set the number of channels required by your design. In this example, the number of channels is set to 10.
4. Create a top level wrapper to connect the PLL IP core to Native PHY core.

- In this case, the PLL IP core has `tx_bonding_clocks` output bus with width [5:0].
  - The Native PHY IP core has `tx_bonding_clocks` input bus with width [5:0] multiplied by the number of transceiver channels (10 in this case). For 10 channels, the bus width is [59:0].
- Note:* While connecting `tx_bonding_clocks`, leave `tx_serial_clk` open to avoid any Intel Quartus Prime software fitter errors.
- Connect the PLL IP core to the PHY IP core by duplicating the output of the `PLL[5:0]` for the number of channels. For 10 channels, the Verilog syntax for the input port connection is `.tx_bonding_clocks ({10{tx_bonding_clocks_output}})`.

**Note:** Although the above diagram looks similar to the 10-channel non-bonded configuration example, the clock input ports on the transceiver channels bypass the local CGB in  $x6/xN$  bonding configuration. This internal connection is taken care of when the **Native PHY channel bonding mode** is set to **Bonded**.

**Figure 199.  $x6/xN$  Bonding Mode –Internal Channel Connections**



*Note:* (1) The local CGB is bypassed by the clock input ports in bonded mode.

#### Related Information

[xN Clock Lines on page 389](#)

Information on xN Clock Network Span.

#### 3.11.2.2. Implementing PLL Feedback Compensation Bonding Mode

In this bonding mode, the channel span limitations of xN bonding mode are removed. This is achieved by dividing all channels into multiple bonding groups.

**Figure 200. PHY IP Core and PLL IP Core Connection for PLL Feedback Compensation Bonding**



The data rate is limited by the x6 network speed limit. A disadvantage of using PLL feedback compensation bonding is that it consumes more PLL resources. Each transceiver bank consumes one PLL and one master CGB.

In PLL feedback compensation bonding mode, the N counter (reference clock divider) is bypassed in order to ensure that the reference clock skew is minimized between the PLLs in the bonded group. Because the N counter is bypassed, the PLL reference clock has a fixed value for any given data rate.

The **PLL IP Core Parameter Editor** window displays the required data rate in the **PLL reference clock frequency** drop down menu.

#### Steps to implement a PLL Feedback Compensation Bonding Configuration

1. Instantiate the PLL IP core (ATX PLL or fPLL) you want to use in your design. Refer to [Instantiating the ATX PLL IP Core](#) on page 363 or [Instantiating the fPLL IP Core](#) on page 371 for detailed steps. Because the CMU PLL cannot drive the master CGB, only the ATX PLL or fPLL can be used for feedback compensation bonding.
2. Configure the PLL IP core using the **IP Parameter Editor**.

- If you use the ATX PLL, set the following configuration settings:
    - Under the **Master Clock Generation Block Tab**
      - Enable **Include Master Clock Generation Block**.
      - Turn ON **Enable Bonding Clock output ports**.
      - Turn ON **Enable feedback compensation bonding**.
    - Under the **Dynamic Reconfiguration Tab**
      - Turn ON **Enable dynamic reconfiguration**
  - If you use the fPLL, set the following configuration settings:
    - Under the **PLL Tab**
      - Set the **PLL Feedback type** to **feedback compensation bonding**.
    - Under the **Master Clock Generation Block Tab**
      - Turn ON **Enable Bonding Clock output ports**.
    - Under the **Dynamic Reconfiguration Tab**
      - Turn ON **Enable dynamic reconfiguration**
3. Configure the Native PHY IP core using the **IP Parameter Editor**
    - Set the **Native PHY IP core TX Channel bonding mode** to either **PMA bonding** or **PMA/PCS bonding**.
    - Turn ON **Enable dynamic reconfiguration**
  4. Create a top level wrapper to connect the PLL IP cores to Native PHY IP core.
    - In this case, the PLL IP core has `tx_bonding_clocks` output bus with width [5:0].
    - The Native PHY IP core has `tx_bonding_clocks` input bus with width [5:0] multiplied by the number of channels in a transceiver bank. (six channels in the transceiver bank).
    - Unlike the x6/xN bonding mode, for this mode, the PLL should be instantiated multiple times. (One PLL is required for each transceiver bank that is a part of the bonded group.) Instantiate a PLL for each transceiver bank used.
    - Connect the `tx_bonding_clocks` output from each PLL to (up to) six channels in the same transceiver bank.
    - Connect the PLL IP core to the PHY IP core by duplicating the output of the PLL[5:0] for the number of transceiver channels used in the bonding group.

#### Steps to recalibrate the PLL after power up calibration

1. Dynamic reconfigure the PLL to change the feedback from the master CGB to feedback from PLL.
  - For ATX PLL, Read-Modify-Write 0x1 to offset address 0x110[2] of the ATX PLL.
  - For fPLL, Read-Modify-Write 0x1 to offset address 0x126[0] of the fPLL.
2. Recalibrate the PLL.
3. After recalibration completes, ensure the PLL achieves lock. Dynamic reconfigure the PLL to change the feedback to master CGB.

- For ATX PLL, Read-Modify-Write 0x0 to offset address 0x110[2] of the ATX PLL.
  - For fPLL, Read-Modify-Write 0x0 to offset address 0x126[0] of the fPLL.
4. Recalibrate TX PMA of all the bonded channels driven by the ATX PLL or the fPLL.

**Note:** For this 10-channel example, two ATX PLLs are instantiated. Six channels of the tx\_bonding\_clocks on the Native PHY IP core are connected to the first ATX PLL and the remaining four channels are connected to the second ATX PLL's tx\_bonding\_clock outputs.

#### Related Information

- [ATX PLL Recalibration](#) on page 593
- [Fractional PLL Recalibration](#) on page 593
- [PMA Recalibration](#) on page 594

### 3.11.3. Implementing PLL Cascading

In PLL cascading, the output of the first PLL feeds the input reference clock to the second PLL.

For example, if the input reference clock has a fixed frequency, and the desired data rate was not an integer multiple of the input reference clock, the first PLL can be used to generate the correct reference clock frequency. This output is fed as the input reference clock to the second PLL. The second PLL generates the clock frequency required for the desired data rate.

The transceivers in Arria 10 devices support fPLL to fPLL cascading. For OTN and SDI applications, there is a dedicated clock path for cascading ATX PLL to fPLL in Arria 10 production silicon. Only maximum two PLLs are allowed in the cascading chain.

**Note:** When the fPLL is used as a cascaded fPLL (downstream fPLL), a user recalibration on the fPLL is required. Refer to "User Recalibration" section in "Calibration" chapter for more information.

**Figure 201. PLL Cascading**



#### Steps to implement fPLL to fPLL cascading:

1. Instantiate the fPLL IP core. Refer to [Instantiating the fPLL IP Core](#) on page 371 for detailed steps.
2. Set the following configuration settings for the fPLL IP core in the **Parameter Editor**:
  - Set the **fPLL Mode** to **Cascade Source**.
  - Set the **Desired output clock frequency**.
3. Instantiate the fPLL IP core (the second PLL in PLL cascading configuration). Refer to [Instantiating the fPLL IP Core](#) on page 371 for detailed steps.
4. Configure the second fPLL IP core for the desired data rate and the reference clock frequency. Set reference clock frequency for the second fPLL same as the output frequency of the first fPLL.
5. Connect the fPLL IP core (cascade source) to fPLL IP core (transceiver PLL) as shown in the above figure. Ensure the following connections:
  - The fPLL has an output port `hssi_pll_cascade_clk`. Connect this port to the second fPLL's `pll_refclk0` port.
6. Set the source (upstream) fPLL bandwidth to Low setting and the destination (downstream) fPLL bandwidth to Low setting.
7. If the input reference clock is available at device power-up, the first PLL is calibrated during the power-up calibration. The second PLL need to be recalibrated. Refer to the *User Recalibration* section. If the input reference clock is not available at device power-up, then re-run the calibration for the first PLL. After the first PLL has been calibrated, re-calibrate the second PLL.

#### Notes:

- No special configuration is required for the Native PHY instance.
- ATX PLL to fPLL cascading mode is added to address the OTN and SDI jitter requirement. In this mode, ATX PLL generates a relatively high and clean reference frequency in fractional mode. The reference is driving the fPLL, which is running in integer mode. Overall cascaded two PLLs, synthesize a needed frequency for a given data rate.

#### Related Information

[User Recalibration](#) on page 588

### 3.11.4. Mix and Match Example

In the Arria 10 transceiver architecture, the separate Native PHY IP core and the PLL IP core scheme allows great flexibility. It is easy to share PLLs and reconfigure data rates. The following design example illustrates PLL sharing and both bonded and non-bonded clocking configurations.

**Figure 202. Mix and Match Design Example**



### PLL Instances

In this example, two ATX PLL instances and five fPLL instances are used. Choose an appropriate reference clock for each PLL instance. The **IP Catalog** lists the available PLLs.

Use the following data rates and configuration settings for PLL IP cores:

- Transceiver PLL Instance 0: ATX PLL with output clock frequency of 6.25 GHz
  - Enable the Master CGB and bonding output clocks.
- Transceiver PLL instance 1: fPLL with output clock frequency of 5.1625 GHz
- Transceiver PLL instance 2: fPLL with output clock frequency of 5.1625 GHz
- Transceiver PLL instance 3: fPLL with output clock frequency of 0.625 GHz
  - Select the **Use as Transceiver PLL** option.
- Transceiver PLL instance 4: fPLL with output clock frequency of 2.5 GHz
  - Select **Enable PCIe\* clock output port** option.
  - Select **Use as Transceiver PLL** option.
    - Set Protocol Mode to PCIe Gen2.
  - Select the **Use as Core PLL** option
    - Set the **Desired frequency** to 500 MHz with a phase shift of 0 ps.
- Transceiver PLL instance 6: ATX PLL with output clock frequency of 4 GHz
  - Enable Master CGB and bonding output clocks.
  - Select **Enable PCIe clock switch interface** option.
  - Set **Number of Auxiliary MCGB Clock Input ports** to 1.

## Native PHY IP Core Instances

In this example, four Transceiver Native PHY IP core instances and four 10GBASE-KR PHY IP instances are used. Use the following data rates and configuration settings for the PHY IPs:

- 12.5 Gbps Interlaken with a bonded group of 10 channels
  - Set the Interlaken 10x12.5 Gbps preset from the Arria 10 Transceiver Native PHY IP core GUI.
  - Refer to [Interlaken](#) on page 94 for more details.
- Custom multi-data rate 1.25G/9.8G/10.3125 Gbps non-bonded group of four channels
  - Set the **Number of data channels** to 4.
  - Set **TX channel bonding** to Not Bonded.
  - Under the **TX PMA** tab, set the **Number of TX PLL clock inputs per channel** to 3.
  - Under the **RX PMA** tab, set the **Number of CDR reference clocks** to 3.
- 1.25 Gbps Gigabit Ethernet with a non-bonded group of two channels
  - Set the **GIGE-1.25Gbps** preset from the Arria 10 Transceiver Native PHY IP core GUI.
  - Change the **Number of data channels** to 2.
- PCIe Gen3 with a bonded group of 8 channels
  - Set the **PCIe PIPE Gen3x8** preset from the Arria 10 Transceiver Native PHY IP core GUI.
  - Under **TX Bonding options**, set the **PCS TX channel bonding master** to channel 5.

*Note:* The PCS TX channel bonding master must be physically placed in channel 1 or channel 4 within a transceiver bank. In this example, the 5th channel of the bonded group is physically placed at channel 1 in the transceiver bank.

- Refer to [PCI Express \(PIPE\)](#) on page 236 for more details.
- 10.3125 Gbps 10GBASE-KR non-bonded group of 4 channels
  - Instantiate the Arria 10 1G/10GbE and 10GBASE-KR PHY IP four times, with one instance for each channel.
  - Refer to [10GBASE-KR PHY IP Core](#) on page 135 for more details.

### Connection Guidelines for PLL and Clock Networks

- For 12.5 Gbps Interlaken with a bonded group of 10 channels, connect the `tx_bonding_clocks` to the transceiver PLL's `tx_bonding_clocks` output port. Make this connection for all 10 bonded channels. This connection uses a master CGB and the `x6 / xN` clock line to reach all the channels in the bonded group.
- Connect the `tx_serial_clk` port of the first two instances of the 10GBASE-KR PHY IP to the `tx_serial_clk` port of PLL instance 1 (fPLL at 5.1625 GHz). This connection uses the `x1` clock line within the transceiver bank.
- Connect the `tx_serial_clk` port of the remaining two instances of the 10GBASE-KR PHY IP to the `tx_serial_clk` port of the PLL instance 2 (fPLL at 5.1625 GHz). This connection uses the `x1` clock line within the transceiver bank.
- Connect the three `tx_serial_clk` ports for the custom multi-data rate PHY IP as follows:
  - Connect `tx_serial_clk0` port to the `tx_serial_clk` port of PLL instance 2 (fPLL at 5.1625 GHz). This PLL instance is shared with the two 10GBASE-KR PHY IP channels and also uses the `x1` clock line within the transceiver bank.
- Connect the 1.25 Gbps Gigabit Ethernet non-bonded PHY IP instance to the `tx_serial_clk` port of the PLL instance 5. Make this connection twice, one for each channel. This connection uses the `x1` clock line within the transceiver bank.
- Connect the PCIe Gen3 bonded group of 8 channels as follows:
  - Connect the `tx_bonding_clocks` of the PHY IP to the `tx_bonding_clocks` port of the Transceiver PLL Instance 6. Make this connection for each of the 8 bonded channels.
  - Connect the `pipe_sw_done` of the PHY IP to the `pipe_sw` port of the transceiver PLL instance 6.
  - Connect the `pll_PCIE_clk` port of the PLL instance 5 to the PHY IP's `pipe_hclk_in` port.
  - Connect `tx_serial_clk` port of the PLL instance 5 to the `mcgb_aux_clk0` port of the PLL instance 6. This connection is required as a part of the PCIe speed negotiation protocol.

#### 3.11.5. Timing Closure Recommendations

Register mode is harder to close timing in Arria 10 devices. Intel recommends using negative edge capture on the RX side for periphery to core transfers greater than 240 MHz. To be specific, capture on a negative edge clock in the core and then immediately transfer to a positive edge clock.

- Use PCLK clock network for frequencies up to 250 MHz.
- Local routing is recommended for higher frequencies.

For core to periphery transfers on TX targeting higher frequencies (beyond 250 MHz), Intel recommends using TX Fast Register mode as the PCS FIFO mode. This is the mode with PCLK that should be used by default for most 10GbE 1588 modes and 9.8 Gbps/10.1376 Gbps CPRI mode.

- You can use local routing to get up to 320 MHz in Register mode for the highest speed grade.

## 3.12. PLLs and Clock Networks Revision History

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2021.06.10       | Added the <i>PCS Bonding Channels Placement Restrictions</i> section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2021.01.29       | Made the following change: <ul style="list-style-type: none"> <li>• To implement fPLL to fPLL cascading, set the destination (downstream) fPLL bandwidth to Low.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2019.05.13       | Made the following change: <ul style="list-style-type: none"> <li>• Renamed Altera Debug Master Endpoint (ADME) to Native PHY DebugMaster Endpoint (NPDME).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2018.06.15       | Made the following change: <ul style="list-style-type: none"> <li>• For <i>fPLL IP Core</i>, added <b>OTN_direct</b>, <b>SATA_Gen3</b> and <b>HDMI</b> to the range for <b>Protocol Mode</b>.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2017.11.06       | Made the following changes: <ul style="list-style-type: none"> <li>• Updated the "ATX PLL-to-ATX PLL Spacing Guidelines" section with GT channels information.</li> <li>• Added note "Sourcing reference clock from a cascaded PLL output, global clock or core clock network will introduce additional jitter to transmit PLL output. Refer to KDB "How do I compensate for the jitter of PLL cascading or non-dedicated clock path for Arria 10 PLL reference clock?" for more details."</li> <li>• Added guidance for jitter compliance for data rates &gt;10 Gbps in the following sections:<ul style="list-style-type: none"> <li>— "fPLL"</li> <li>— "CMU PLL"</li> <li>— "Input Reference Clock Sources"</li> </ul></li> </ul> |
| 2016.10.31       | Made the following change: <ul style="list-style-type: none"> <li>• New section <i>Unused/Idle Clock Line Requirements</i> added.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2016.05.02       | <ul style="list-style-type: none"> <li>• Updated ATX PLL, fPLL and CMU PLL parameters.</li> <li>• Updated ATX PLL and fPLL ports.</li> <li>• Added new parameters and ports when fPLL is used in core mode.</li> <li>• Provided additional details for ATX PLL and fPLL fractional mode usage in the "Delta Sigma Modulator" section.</li> <li>• Added a new section describing "ATX PLL multi-profile and embedded reconfiguration".</li> </ul>                                                                                                                                                                                                                                                                                      |
| 2016.02.11       | Made the following changes: <ul style="list-style-type: none"> <li>• Updated the optimal performance placement guidelines for ATX PLL VCO frequencies.</li> <li>• Updated placement recommendations for different protocols - OTU2e, OTU2, OC-192, 6G and 12G SDI.</li> <li>• Updated the "FPGA Fabric - Transceiver Interface Clocking" figure.</li> <li>• Updated the maximum data rate to 25.8 Gbps.</li> </ul>                                                                                                                                                                                                                                                                                                                    |
| 2015.12.18       | Made the following changes: <ul style="list-style-type: none"> <li>• Updated the "PLL Cascading" figure.</li> <li>• Updated the "Dedicated Reference Clock Pins" in the "Input Reference Clock Sources" section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2015.11.02       | Made the following changes: <ul style="list-style-type: none"> <li>• Updated ATX PLL, CMU PLL and fPLL Configuration Options, Parameters and Settings.</li> <li>• Updated ATX PLL placement in figures and examples.</li> <li>• Clarified PLL to PLL cascade support.</li> <li>• Created TX PLL Recommendations based on datarates.</li> <li>• Updated ATX PLL, fPLL and CMU PLL Quartus settings.</li> <li>• Added details and figures for the fPLL driving the fabric use cases.</li> <li>• Updated PLL Feedback and Cascading Clock Network figure.</li> <li>• Updated steps to implement PLL cascading.</li> </ul>                                                                                                                |
| 2015.05.11       | Made the following changes:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

continued...

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>Updated ATX PLL, CMU PLL and FPLL Configuration Options, Parameters and Settings.</li> <li>Modified Transmit PLLs Data Rate Range in Arria 10 Devices.</li> <li>Increased xN clock network channel span.</li> <li>Added ATX PLL to fPLL cascading details.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2014.12.15       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Added a note about PLL cascading support in ACDS 14.1 version of Quartus II software.</li> <li>Corrected the minimum data rate supported by ATX PLL in Table: Transmit PLLs in Arria 10 Devices.</li> <li>Corrected the error in <b>PLL output frequency</b> range for ATX PLL and CMU PLL IP cores.</li> <li>Corrected the <b>PLL reference clock frequency</b> range for ATX PLL IP core.</li> <li>Added a note about jitter performance in <i>Input Reference Clock Sources</i> section.</li> <li>Updated the <i>Mix and Match Design Example</i> figure to indicate that MCGB is used in the example.</li> <li>Changed the minimum data rate supported by the PLLs to 1 Gbps.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2014.08.15       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Changed the maximum data rate for GT channels to 25.8 Gbps.</li> <li>Changed figure "Arria 10 PLLs and Clock Networks" to indicate channel 0,1,3, and 5 have only the CDR PLL.</li> <li>Updated figure "x1 Clock Lines" to indicate that the channel PLL of channel 1 and channel 4 can be used as CMU PLL or as a CDR.</li> <li>Updated <i>ATX PLL, fPLL, and CMU PLL</i> section with a clarification about input reference clock frequency stability at device power-up.</li> <li>Updated <i>Instantiating ATX PLL, fPLL, and CMU PLL</i> topics with new IP instantiation flow.</li> <li>Updated ATX PLL and fPLL architecture block diagrams to show global clock or core clock as an input reference clock.</li> <li>Updated <i>ATX PLL IP</i> section with 14.0 A10 release changes <ul style="list-style-type: none"> <li>Added fractional mode support.</li> <li>Added embedded debug parameters in table ATX PLL Dynamic Reconfiguration.</li> </ul> </li> <li>Updated <i>fPLL IP</i> section with 14.0A10 release changes <ul style="list-style-type: none"> <li>Removed "fPLL -Clock Switch over Parameter and Settings" table.</li> <li>Updated table "fPLL Parameter and Settings".</li> <li>Added embedded debug parameters in table "fPLL - Dynamic Reconfiguration Parameters and Settings".</li> <li>Removed <b>Number of auxiliary MCGB clock input ports from fPLL IP</b> parameters.</li> </ul> </li> <li>Added global clock or core clock as an input reference clock source.</li> <li>Added a new section for <i>Global Clock or Core Clock as an Input Reference Clock</i>.</li> <li>Updated figure "Input Reference Clock Sources".</li> <li>Updated <i>Dedicated Reference Clock Pins</i> section "Dedicated Reference Clock Pins". <ul style="list-style-type: none"> <li>Added a connection to indicate that dedicated refclk pins can drive the reference clock network.</li> <li>Removed a wrong connection from the diagram.</li> </ul> </li> <li>Updated <i>xN Clock Lines</i> section with maximum channel span limitations and added a exception for QPI protocols.</li> <li>Added a new image in the <i>FPGA Fabric-Transceiver Interface Clocking</i> section.</li> <li>Added a new section for <i>Channel Bonding</i> describing PMA bonding, PMA and PCS bonding in detail.</li> <li>Removed xN Clock Network Data Rate Restrictions table.</li> <li>Updated chapter to indicate Arria 10 Transceivers support fPLL to fPLL, fPLL to ATX PLL, and fPLL to CMU PLL cascading.</li> <li>Updated <i>Using PLLs and Clock Networks</i> section <ul style="list-style-type: none"> <li>Changed MegaWizard references to IP Catalog and Parameter Editor.</li> <li>Updated the valid configurations for PLL IP and Native PHY IP per 14.0A10 release change.</li> </ul> </li> <li>Removed Table "xN Clock Network Data Rate Restrictions".</li> <li>Updated the chapter to indicate Arria 10 transceivers support to fPLL to fPLL, fPLL to ATX PLL, and fPLL to CMU PLL cascading.</li> </ul> |
| 2013.12.02       | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

## 4. Resetting Transceiver Channels

To ensure that transceiver channels are ready to transmit and receive data, you must properly reset the transceiver PHY. Intel recommends a reset sequence that ensures the physical coding sublayer (PCS) and physical medium attachment (PMA) in each transceiver channel initialize and function correctly. You can either use the Transceiver PHY Reset Controller or create your own reset controller.

### 4.1. When Is Reset Required?

You can reset the transmitter (TX) and receiver (RX) data paths independently or together. The recommended reset sequence requires reset and initialization of the PLL driving the TX or RX channels, as well as the TX and RX datapaths. A reset is required after any of the following events:

**Table 247. Reset Conditions**

| Event                                | Reset Requirement                                                                                                                                                                    |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device power up and configuration    | Requires reset to the transceiver PHY and the associated PLLs to a known initialize state.                                                                                           |
| PLL reconfiguration                  | Requires reset to ensure that the PLL acquires lock and also to reset the PHY. Both the PLL and the transmitter channel must be held in reset before performing PLL reconfiguration. |
| PLL reference clock frequency change | Requires reset to the PLL to ensure PLL lock. You must also reset the PHY.                                                                                                           |
| PLL recalibration                    | Requires reset to the PLL to ensure PLL lock. You must also reset the PHY. Both the PLL and the transmitter channel must be held in reset before performing PLL recalibration.       |
| PLL lock loss or recovery            | Requires reset after a PLL acquired lock from a momentary loss of lock. You must also reset the PHY.                                                                                 |
| Channel dynamic reconfiguration      | Requires holding the channel in reset before performing a dynamic reconfiguration that causes rate change. A PLL reset is not required during channel reconfiguration.               |
| Optical module connection            | Requires reset of RX to ensure lock of incoming data.                                                                                                                                |
| RX CDR lock mode change              | Requires reset of the RX channel any time the RX clock and data recovery (CDR) block switches from lock-to-reference to lock-to-data RX channel.                                     |

## 4.2. Transceiver PHY Implementation

**Figure 203. Typical Transceiver PHY Implementation**



**Transceiver Reset Endpoints**—The Transceiver PHY IP core contains Transceiver Reset Endpoints (TREs)<sup>(60)</sup>.

**Transceiver Reset Sequencer**—The Quartus Prime software detects the presence of TREs and automatically inserts only one Transceiver Reset Sequencer (TRS)<sup>(60)</sup>. The tx\_analogreset and rx\_analogreset requests from the reset controller (User coded or Transceiver PHY Reset Controller) is received by the TREs. The TRE sends the reset request to the TRS for scheduling. TRS schedules all the requested PMA resets and sends them back to TREs. You can use either Transceiver PHY Reset Controller or your own reset controller. However, for the TRS to work correctly, the required timing duration must be followed. See [Figure 204](#) on page 431 for required timing duration.

**Note:**

- The TRS IP is an inferred block and is not visible in the RTL. You have no control over this block.

**CLKUSR connection**—The clock to the TRS must be stable and free-running (100-125 MHz). By default, the Quartus Prime software automatically connects the TRS clock input to the CLKUSR pin on the device. If you are using the CLKUSR pin for your own logic (feeding it to the core), you must instantiate `altera_a10_xcvr_clock_module`:

```
altera_a10_xcvr_clock_module reset_clock (.clk_in(mgmt_clk));
```

For more information about the CLKUSR pin, refer to the *Arria 10 Pin Connection Guidelines*.

<sup>(60)</sup> There is only one centralized TRS instantiated for one or more Native PHY.

**Note:** To successfully complete the calibration process, the reference clocks driving the PLLs (ATX PLL, fPLL, CDR/CMU PLL) must be stable and free running at start of FPGA configuration. Otherwise, recalibration is necessary.

#### Related Information

- [Arria 10 Pin Connection Guidelines](#)
- [Calibration](#) on page 579  
For more information about the calibration process

### 4.3. How Do I Reset?

You reset a transceiver PHY or PLL by integrating a reset controller in your system design to initialize the PCS and PMA blocks. You can save time by using the Intel-provided Transceiver PHY Reset Controller IP core, or you can implement your own reset controller that follows the recommended reset sequence. You can design your own reset controller if you require individual control of each signal for reset or need additional control or status signals as part of the reset functionality.

You can choose from two models for resetting the transceivers, based on your applications:

- Model 1—Default model (Minimum Assertion Time Requirement)  
Choose the **Arria 10 Default Settings** preset for the Transceiver PHY Reset Controller IP.  
The chapter *Transceiver Reset Control in Arria 10 Devices* explains the default model in detail.
- Model 2—Acknowledgment model  
This model uses an event-driven mechanism. The model is used for applications with strict timing requirements.

#### 4.3.1. Model 1: Default Model

##### 4.3.1.1. Recommended Reset Sequence

###### How to Enable Model 1

Choose the [Figure 204](#) on page 431 for the Transceiver PHY Reset Controller IP. This populates the reset duration fields with the correct values required by the transceiver reset sequencer (TRS).

Figure 204. Arria 10 Default Settings Preset



**Figure 205. Transmitter and Receiver Reset Sequence**



#### 4.3.1.2. Resetting the Transmitter During Device Operation

Follow this reset sequence to reset the PLL or the analog or digital blocks of the transmitter at any point during the device operation. Use this reset sequence to reestablish a link or after dynamic reconfiguration. The following steps detail the transmitter reset sequence during device operation. The step numbers correspond to the numbers in the following figure.

1. Perform the following steps:

- a. Assert `tx_analogreset`, `pll_powerdown`, and `tx_digitalreset` while `pll_cal_busy` and `tx_cal_busy` are low.
  - b. Deassert `pll_powerdown` after a minimum duration of 1  $\mu$ s. This step can be delayed and deasserted at the same time you deassert `tx_analogreset`.
  - c. Deassert `tx_analogreset` after a minimum duration of 70  $\mu$ s.
2. The `pll_locked` signal goes high after the TX PLL acquires lock. Wait for a minimum of 70  $\mu$ s after deasserting `tx_analogreset` to monitor the `pll_locked` signal.
  3. Deassert `tx_digitalreset`, after `pll_locked` goes high. The `tx_digitalreset` signal must stay asserted for a minimum  $t_{tx\_digitalreset}$  duration after `tx_analogreset` is deasserted.

*Note:* You must reset the PCS blocks by asserting `tx_digitalreset`, every time you assert `pll_powerdown` and `tx_analogreset`.

**Figure 206. Transmitter Reset Sequence During Device Operation**



*Note:*

(1) The Arria 10 Default setting presets `tx_digitalreset` to 70  $\mu$ s.

(2) Area in gray is don't care logic state.

### Related Information

[Arria 10 Device Datasheet](#)

#### 4.3.1.3. Resetting the Receiver During Device Operation

Follow this reset sequence to reset the analog or digital blocks of the receiver at any point during the device operation. Use this reset to re-establish a link or after dynamic reconfiguration.

#### 4.3.1.3.1. Clock Data Recovery in Auto Lock Mode

The step numbers correspond to the numbers in the following figure:

1. Assert `rx_analogreset` and `rx_digitalreset`. Ensure that `rx_cal_busy` is low. You must reset the PCS by asserting `rx_digitalreset` every time you assert `rx_analogreset`.
2. Deassert `rx_analogreset` after a minimum duration of 70  $\mu$ s.
3. Ensure `rx_is_lockedtodata` is asserted for  $t_{LTD}$  (minimum of 4  $\mu$ s) before deasserting `rx_digitalreset`.

**Figure 207. Resetting the Receiver During Device Operation (Auto Mode)**



**Note:** `rx_is_lockedtodata` will toggle when there is no data at the receiver input.  
`rx_is_lockedtoref` is a don't care when `rx_is_lockedtodata` is asserted.

#### 4.3.1.3.2. Clock Data Recovery in Manual Lock Mode

Use the clock data recovery (CDR) manual lock mode to override the default CDR automatic lock mode depending on your design requirements.

##### Related Information

[Transceiver PHY Reset Controller IP Core chapter of the V-Series Transceiver PHY IP Core User Guide](#).

Refer to the description of the `rx_digitalreset` signal in the "Top-Level Signals" table for information about using the manual lock mode.

##### Control Settings for CDR Manual Lock Mode

Use the following control settings to set the CDR lock mode:

**Table 248. Control Settings for the CDR in Manual Lock Mode**

| <code>rx_set_locktoref</code> | <code>rx_set_locktodata</code> | CDR Lock Mode     |
|-------------------------------|--------------------------------|-------------------|
| 0                             | 0                              | Automatic         |
| 1                             | 0                              | Manual-RX CDR LTR |
| X                             | 1                              | Manual-RX CDR LTD |

## Resetting the Transceiver in CDR Manual Lock Mode

The numbers in this list correspond to the numbers in the following figure, which guides you through the steps to put the CDR in manual lock mode.

1. Make sure that the calibration is complete (`rx_cal_busy` is low) and the transceiver goes through the initial reset sequence. The `rx_digitalreset` and `rx_analogreset` signals should be low. The `rx_is_lockedtoref` is a don't care and can be either high or low. The `rx_is_lockedtodata` and `rx_ready` signals should be high, indicating that the transceiver is out of reset. Alternatively, you can start directly with the CDR in manual lock mode after the calibration is complete.
2. Assert the `rx_set_locktoref` signal high to switch the CDR to the lock-to-reference mode. The `rx_is_lockedtodata` status signal is deasserted. Assert the `rx_digitalreset` signal high at the same time or after `rx_set_locktoref` is asserted if you use the user-coded reset. When the Transceiver PHY reset controller is used, the `rx_digitalreset` is automatically asserted.
3. After the `rx_digitalreset` signal gets asserted, the `rx_ready` status signal is deasserted.
4. Assert the `rx_set_locktodata` signal high,  $t_{LTR\_LTD\_Manual}$  (minimum 15  $\mu$ s) after the CDR is locked to reference. `rx_is_locktoref` should be high and stable for a minimum  $t_{LTR\_LTD\_Manual}$  (15  $\mu$ s), before asserting `rx_set_locktodata`. This is required to filter spurious glitches on `rx_is_lockedtoref`. The `rx_is_lockedtodata` status signal gets asserted, which indicates that the CDR is now set to LTD mode.  
The `rx_is_lockedtoref` status signal can be a high or low and can be ignored after asserting `rx_set_locktodata` high after the CDR is locked to reference.
5. Deassert the `rx_digitalreset` signal after a minimum of  $t_{LTD\_Manual}$  (4  $\mu$ s).
6. If you are using the Transceiver PHY Reset Controller, the `rx_ready` status signal gets asserted after the `rx_digitalreset` signal is deasserted. This indicates that the receiver is now ready to receive data with the CDR in manual mode.

**Figure 208. Reset Sequence Timing Diagram for Receiver when CDR is in Manual Lock Mode**



#### 4.3.1.4. Resetting the Transceiver Channel During Device Operation

The numbers in this list correspond to the numbers in the following figure.

1. Assert `tx_analogreset`, `pll_powerdown`, `tx_digitalreset`, `rx_analogreset`, and `rx_digitalreset`. Ensure that `pll_cal_busy`, `tx_cal_busy`, and `rx_cal_busy` are low.
2. Deassert `pll_powerdown` and `tx_analogreset` at the same time, after a minimum duration of 70  $\mu$ s.
3. The `pll_locked` signal goes high after the TX PLL acquires lock. Wait for a minimum 70  $\mu$ s after deasserting `tx_analogreset` to monitor the `pll_locked` signal.
4. Deassert `tx_digitalreset` after `pll_locked` goes high. The `tx_digitalreset` signal must stay asserted for a minimum  $t_{tx_digitalreset}$  (minimum of 70  $\mu$ s) duration after `tx_analogreset` is deasserted.
5. Deassert `rx_analogreset` after deasserting `tx_analogreset`.
6. Ensure `rx_is_lockedtodata` is asserted for  $t_{LTD}$  (minimum of 4  $\mu$ s) before deasserting `rx_digitalreset`.

**Figure 209. Resetting the Transceiver Channel During Device Operation**



#### 4.3.1.5. Dynamic Reconfiguration of Channel Using the Default Model

##### TX Channel

The numbers in this list correspond to the numbers in the following figure.

1. Assert `tx_analogreset`, `pll_powerdown`, and `tx_digitalreset`, while `pll_cal_busy` and `tx_cal_busy` are low.
2. Perform dynamic reconfiguration after minimum 70  $\mu s$  of asserting `tx_analogreset`.
3. Deassert `pll_powerdown` after performing a dynamic reconfiguration.

Deassert `tx_analogreset`. This step can be done at the same time or after you deassert `pll_powerdown`.

4. The `pll_locked` signal goes high after the TX PLL acquires lock. Wait for minimum 70  $\mu$ s after deasserting `tx_analogreset` to monitor the `pll_locked` signal.
5. Deassert `tx_digitalreset` after `pll_locked` goes high. The `tx_digitalreset` signal must stay asserted for a minimum  $t_{tx\_digitalreset}$  duration after `tx_analogreset` is deasserted.

**Figure 210. Dynamic Reconfiguration of Transmitter Channel During Device Operation**



**Note:**

- (1) The Arria 10 Default setting presets `ttx_digitalreset` to 70  $\mu$ s.
- (2) Area in gray is don't care zone.

### RX Channel

The numbers in this list correspond to the numbers in the following figure.

1. Assert `rx_analogreset` and `rx_digitalreset`. Ensure that `rx_cal_busy` is low. You must reset the PCS by asserting `rx_digitalreset` every time you assert `rx_analogreset`.
2. Perform dynamic reconfiguration after minimum 70  $\mu$ s of asserting `rx_analogreset`.
3. Deassert `rx_analogreset` after performing dynamic reconfiguration.
4. The `rx_is_lockedtodata` signal goes high after the CDR acquires lock.
5. Ensure `rx_is_lockedtodata` is asserted for  $t_{LTd}$  (minimum of 4  $\mu$ s) before deasserting `rx_digitalreset`.

**Figure 211. Dynamic Reconfiguration of Receiver Channel During Device Operation**

### 4.3.2. Model 2: Acknowledgment Model

The acknowledgment model uses an event-driven mechanism. It is used for applications with strict timing requirements. Instead of waiting for a minimum assertion time of  $70 \mu\text{s}$  for `tx_analogreset` and `rx_analogreset`, you must wait to receive the acknowledgment from the Transceiver Native PHY IP core to ensure successful assertion and deassertion of the analog resets.

To enable the acknowledgment model, enable the following ports in the Transceiver Native PHY IP core:

- Enable the `tx_analog_reset_ack` port in the TX PMA

**Figure 212. Enabling the tx\_analog\_reset\_ack Port**

- Enable the `rx_analog_reset_ack` port in the RX PMA

**Figure 213. Enabling the rx\_analog\_reset\_ack Port**

**Note:** tx\_analog\_reset\_ack and rx\_analog\_reset\_ack must be treated as asynchronous signals. You must pass them through a synchronizer before sending them to control logic.

#### 4.3.2.1. Recommended Reset Sequence

#### 4.3.2.2. Resetting the Transmitter During Device Operation

The numbers in this list correspond to the numbers in the following figure.

1. Assert tx\_analogreset, pll\_powerdown, and tx\_digitalreset, while pll\_cal\_busy and tx\_cal\_busy are low.
2. Wait for tx\_analogreset\_ack to go high, to ensure successful assertion of tx\_analogreset. tx\_analogreset\_ack goes high when TRS has successfully completed the reset request for assertion. After both pll\_locked and tx\_analogreset\_ack are asserted, deassert tx\_analogreset. This step can be done at the same time or after you deassert pll\_powerdown.
3. Wait for tx\_analogreset\_ack to go low, to ensure successful deassertion of tx\_analogreset. tx\_analogreset\_ack goes low when TRS has successfully completed the reset request for deassertion.
4. The pll\_locked signal goes high after the TX PLL acquires lock. Wait for tx\_analogreset\_ack to go low before monitoring the pll\_locked signal.
5. Deassert tx\_digitalreset a minimum  $t_{tx\_digitalreset}$  time after pll\_locked goes high.

**Figure 214. Transmitter Reset Sequence During Device Operation**



**Note:**

(1) Area in gray is don't care logic state.

### 4.3.2.3. Resetting the Receiver During Device Operation

The numbers in this list correspond to the numbers in the following figure.

1. Assert `rx_analogreset` and `rx_digitalreset` while `rx_cal_busy` is low.
2. Wait for `rx_analogreset_ack` to go high, to ensure successful assertion of `rx_analogreset`. `rx_analogreset_ack` goes high when TRS has successfully completed the reset request for assertion.
  - a. Deassert `rx_analogreset`.
3. Wait for `rx_analogreset_ack` to go low, to ensure successful deassertion of `rx_analogreset`. `rx_analogreset_ack` goes low when TRS has successfully completed the reset request for deassertion.
4. The `rx_is_lockedtodata` signal goes high after the CDR acquires lock.
5. Ensure `rx_is_lockedtodata` is asserted for  $t_{LTD}$  (minimum of 4  $\mu$ s) before deasserting `rx_digitalreset`.

**Figure 215. Receiver Reset Sequence During Device Operation**



### 4.3.2.4. Dynamic Reconfiguration of Transmitter Channel Using the Acknowledgment Model

The numbers in this list correspond to the numbers in the following figure.

1. Assert `tx_analogreset`, `pll_powerdown`, and `tx_digitalreset`, while `pll_cal_busy` and `tx_cal_busy` are low.
2. Wait for `tx_analogreset_ack` to go high, to ensure successful assertion of `tx_analogreset`. `tx_analogreset_ack` goes high when TRS has successfully completed the reset request for assertion.

- a. Perform dynamic reconfiguration.
  - b. Deassert `pll_powerdown` after  $t_{PLL\_powerdown}$ .
  - c. Deassert `tx_analogreset`. This step can be done at the same time or after you deassert `pll_powerdown`.
3. Wait for `tx_analogreset_ack` to go low, to ensure successful deassertion of `tx_analogreset`. `tx_analogreset_ack` goes low when TRS has successfully completed the reset request for deassertion.
  4. The `pll_locked` signal goes high after the TX PLL acquires lock. Wait for `tx_analogreset_ack` to go low before monitoring the `pll_locked` signal.
  5. Deassert `tx_digitalreset` a minimum  $t_{tx_digitalreset}$  time after `pll_locked` goes high.

**Figure 216. Dynamic Reconfiguration of Transmitter Channel During Device Operation**



Note:

(1) Area in gray is don't care zone.

#### 4.3.2.5. Dynamic Reconfiguration of Receiver Channel Using the Acknowledgment Model

The numbers in this list correspond to the numbers in the "Dynamic Reconfiguration of Receiver Channel During Device Operation" figure below.

1. Assert `rx_analogreset` and `rx_digitalreset` while `rx_cal_busy` is low.

- a. To ensure successful assertion of `rx_analogreset`, wait for `rx_analogreset_ack` to go high. `rx_analogreset_ack` goes high when the TRS has successfully completed the reset request for assertion.
- b. Deassert `rx_analogreset`.
2. To ensure successful deassertion of `rx_analogreset`, wait for `rx_analogreset_ack` to go low. `rx_analogreset_ack` goes low when the TRS has successfully completed the reset request for deassertion. <sup>(61), (62)</sup>
3. Wait for `rx_analogreset_ack` to go low; then ensure `rx_is_lockedtodata` signal goes high after the CDR (automatic lock mode) is locked to data.
4. After `rx_is_lockedtodata` goes high, wait a minimum of  $t_{LTD}$  (minimum of 4  $\mu s$ ). Then deassert `rx_digitalreset`.

**Figure 217. Dynamic Reconfiguration of Receiver Channel During Device Operation**



- 
- (61) If the CDR operates in manual lock mode, step 3 on page 443 and step 4 on page 443 are not applicable. After `rx_analogreset_ack` goes low, apply the reset sequence from the "Reset Sequence Timing Diagram for Receiver when CDR is in Manual Lock Mode" figure below.
- (62) If the receiver signal detector is enabled and the CDR operates in manual lock mode, step 3 on page 443 and step 4 on page 443 are not applicable. After `rx_analogreset_ack` goes low, wait for `rx_std_sigmadetect` to go high. When `rx_std_sigmadetect` is high continuously for 1  $\mu s$  or more, apply the reset sequence from the "Reset Sequence Timing Diagram for Receiver when CDR is in Manual Lock Mode" figure below.

**Figure 218. Reset Sequence Timing Diagram for Receiver when CDR is in Manual Lock Mode**



#### 4.3.3. Transceiver Blocks Affected by Reset and Powerdown Signals

You must reset the digital PCS each time you reset the analog PMA or PLL. However, you can reset the digital PCS block alone.

**Table 249. Transceiver Blocks Affected by Specified Reset and Powerdown Signals**

| Transceiver Block         | pll_powerdown | tx_analogreset | tx_digitalreset | rx_analogreset | rx_digitalreset |
|---------------------------|---------------|----------------|-----------------|----------------|-----------------|
| CMU PLL                   | Yes           |                |                 |                |                 |
| ATX PLL                   | Yes           |                |                 |                |                 |
| fPLL                      | Yes           |                |                 |                |                 |
| CDR                       |               |                |                 | Yes            |                 |
| Receiver Standard PCS     |               |                |                 |                | Yes             |
| Receiver Enhanced PCS     |               |                |                 |                | Yes             |
| Receiver PMA              |               |                |                 | Yes            |                 |
| Receiver PCIe Gen3 PCS    |               |                |                 |                | Yes             |
| Transmitter Standard PCS  |               |                | Yes             |                |                 |
| Transmitter Enhanced PCS  |               |                | Yes             |                |                 |
| Transmitter PMA           |               | Yes            |                 |                |                 |
| Transmitter PCIe Gen3 PCS |               |                | Yes             |                |                 |

### Related Information

[User Recalibration](#) on page 588

## 4.4. Using the Transceiver PHY Reset Controller

Transceiver PHY Reset Controller is a configurable IP core that resets transceivers mainly in response to PLL lock activity. You can use this IP core rather than creating your own user-coded reset controller. You can define a custom reset sequence for the IP core. You can also modify the IP cores's generated clear text Verilog HDL file to implement custom reset logic.

The Transceiver PHY Reset Controller handles all transceiver reset sequencing and supports the following options:

- Separate or shared reset controls per channel in response to PLL lock activity
- Separate controls for the TX and RX channels and PLLs
- Synchronization of the reset inputs
- Hysteresis for PLL locked status inputs
- Configurable reset timing
- Automatic or manual reset recovery mode in response to loss of PLL lock

You should create your own reset controller if the Transceiver PHY Reset Controller IP does not meet your requirements, especially when you require independent transceiver channel reset. The following figure illustrates the typical use of the Transceiver PHY Reset Controller in a design that includes a transceiver PHY instance and the transmit PLL.

**Figure 219. Transceiver PHY Reset Controller System Diagram**


Note:

- (1) You can logical OR the **pll\_cal\_busy** and **tx\_cal\_busy** signals.
- pll\_tx\_cal\_busy** connects to the controller's **tx\_cal\_busy** input port.
- (2) The ports are inputs for user logic that implement Model 2. The ports can be used as status monitoring for Model 1 implementation.

Optional

The Transceiver PHY Reset Controller IP core connects to the Transceiver PHY and the Transmit PLL. The Transceiver PHY Reset Controller IP core receives status from the Transceiver PHY and the Transmit PLL. Based on the status signals or the reset input, it generates TX and RX reset signals to the Transceiver PHY and TX PLL.

The `tx_ready` signal indicates whether the TX PMA exits the reset state, and if the TX PCS is ready to transmit data. The `rx_ready` signal indicates whether the RX PMA exits the reset state, and if the RX PCS is ready to receive data. You must monitor these signals to determine when the transmitter and receiver are out of the reset sequence.

#### 4.4.1. Parameterizing the Transceiver PHY Reset Controller IP

This section lists steps to configure the Transceiver PHY Reset Controller IP Core in the IP Catalog. You can customize the following Transceiver PHY Reset Controller parameters for different modes of operation by clicking **Tools > IP Catalog**.

To parameterize and instantiate the Transceiver PHY Reset Controller IP core:

1. For **Device Family**, select your target device from the list.
2. Click **Installed IP > Library > Interface Protocols > Transceiver PHY > Transceiver PHY Reset Controller**.
3. Select the options required for your design. For a description of these options, refer to the **Transceiver PHY Reset Controller Parameters**.
4. Click **Finish**. The wizard generates files representing your parameterized IP variation for synthesis and simulation.

#### 4.4.2. Transceiver PHY Reset Controller Parameters

The Quartus Prime software provides a GUI to define and instantiate a Transceiver PHY Reset Controller to reset transceiver PHY and external PLL.

**Table 250. General Options**

| Name                                  | Range          | Description                                                                                                                                                                                                                            |
|---------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Number of transceiver channels</b> | 1–1000         | Specifies the number of channels that connect to the Transceiver PHY Reset Controller IP core. The upper limit of the range is determined by your FPGA architecture.                                                                   |
| <b>Number of TX PLLs</b>              | 1–1000         | Specifies the number of TX PLLs that connect to the Transceiver PHY Reset Controller IP core.                                                                                                                                          |
| <b>Input clock frequency</b>          | 1–500 MHz      | Input clock to the Transceiver PHY Reset Controller IP core. The frequency of the input clock in MHz. The upper limit on the input clock frequency is the frequency achieved in timing closure.                                        |
| <b>Synchronize reset input</b>        | <b>On /Off</b> | When <b>On</b> , the Transceiver PHY Reset Controller synchronizes the reset to the Transceiver PHY Reset Controller input clock before driving it to the internal reset logic. When <b>Off</b> , the reset input is not synchronized. |
| <b>Use fast reset for simulation</b>  | <b>On /Off</b> | When <b>On</b> , the Transceiver PHY Reset Controller uses reduced reset counters for simulation.                                                                                                                                      |

*continued...*

| Name                                             | Range                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------------------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Separate interface per channel/PLL</b>        | <b>On /Off</b>                   | When <b>On</b> , the Transceiver PHY Reset Controller provides a separate reset interface for each channel and PLL.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>TX PLL</b>                                    |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Enable TX PLL reset control</b>               | <b>On /Off</b>                   | When <b>On</b> , the Transceiver PHY Reset Controller IP core enables the reset control of the TX PLL. When <b>Off</b> , the TX PLL reset control is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>pll_powerdown duration</b>                    | 1-999999999                      | Specifies the duration of the PLL powerdown period in ns. The value is rounded up to the nearest clock cycle. The default value is 1000 ns.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Synchronize reset input for PLL powerdown</b> | <b>On /Off</b>                   | When <b>On</b> , the Transceiver PHY Reset Controller synchronizes the PLL powerdown reset with the Transceiver PHY Reset Controller input clock. When <b>Off</b> , the PLL powerdown reset is not synchronized.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>TX Channel</b>                                |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Enable TX channel reset control</b>           | <b>On /Off</b>                   | When <b>On</b> , the Transceiver PHY Reset Controller enables the control logic and associated status signals for TX reset. When <b>Off</b> , disables TX reset control and status signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Use separate TX reset per channel</b>         | <b>On /Off</b>                   | When <b>On</b> , each TX channel has a separate reset. When <b>Off</b> , the Transceiver PHY Reset Controller uses a shared TX reset controller for all channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>TX digital reset mode</b>                     | <b>Auto, Manual, Expose Port</b> | Specifies the Transceiver PHY Reset Controller behavior when the <code>pll_locked</code> signal is deasserted. The following modes are available: <ul style="list-style-type: none"> <li><b>Auto</b>—The associated <code>tx_digitalreset</code> controller automatically resets whenever the <code>pll_locked</code> signal is deasserted. Intel recommends this mode.</li> <li><b>Manual</b>—The associated <code>tx_digitalreset</code> controller is not reset when the <code>pll_locked</code> signal is deasserted, allowing you to choose corrective action.</li> <li><b>Expose Port</b>—The <code>tx_manual</code> signal is a top-level signal of the IP core. You can dynamically change this port to Auto or Manual. (1= Manual , 0 = Auto)</li> </ul> |
| <b>tx_analogreset duration</b>                   | 1-999999999                      | Specifies the time in ns to continue to assert <code>tx_analogreset</code> after the reset input and all other gating conditions are removed. The value is rounded up to the nearest clock cycle.<br><i>Note:</i> Model 1 requires this to be set to 70 µs.<br>Select the <b>Arria 10 Default Settings</b> preset.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>tx_digitalreset duration</b>                  | 1-999999999                      | Specifies the time in ns to continue to assert the <code>tx_digitalreset</code> after the reset input and all other gating conditions are removed. The value is rounded up to the nearest clock cycle.<br><i>Note:</i> Model 1 requires this to be set to 70 µs.<br>Select the <b>&lt;Device&gt; Default Settings</b> preset. The default value for Model 2 is 20 ns.                                                                                                                                                                                                                                                                                                                                                                                             |
| <b>pll_locked input hysteresis</b>               | 0-999999999                      | Specifies the amount of hysteresis in ns to add to the <code>pll_locked</code> status input to filter spurious unreliable assertions of the <code>pll_locked</code> signal. A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

*continued...*

| Name                                     | Range                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                          |                                  | value of 0 adds no hysteresis. A higher value filters glitches on the <code>pll_locked</code> signal. Intel recommends that the amount of hysteresis be longer than $t_{req} = 70 \mu s$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>RX Channel</b>                        |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>Enable RX channel reset control</b>   | <b>On /Off</b>                   | When enabled, the IP enables control logic and status signals for the RX reset signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <b>Use separate RX reset per channel</b> | <b>On /Off</b>                   | When <b>On</b> , each RX channel has a separate reset input. When <b>Off</b> , uses a shared RX reset controller for all channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>RX digital reset mode</b>             | <b>Auto, Manual, Expose Port</b> | Specifies the Transceiver PHY Reset Controller behavior when the PLL lock signal is deasserted. The following modes are available: <ul style="list-style-type: none"> <li><b>Auto</b>—The associated <code>rx_digitalreset</code> controller automatically resets whenever the <code>rx_is_lockedtodata</code> signal is deasserted.</li> <li><b>Manual</b>—The associated <code>rx_digitalreset</code> controller is not reset when the <code>rx_is_lockedtodata</code> signal is deasserted, allowing you to choose corrective action.</li> <li><b>Expose Port</b>—The <code>rx_manual</code> signal is a top-level signal of the IP core. If the core includes separate reset control for each RX channel, each RX channel uses its respective <code>rx_is_lockedtodata</code> signal for automatic reset control; otherwise, the inputs are ANDed to provide internal status for the shared reset controller.</li> </ul> |
| <b>rx_analogreset duration</b>           | 1–999999999                      | Specifies the time in ns to continue to assert the <code>rx_analogreset</code> after the reset input and all other gating conditions are removed. The value is rounded up to the nearest clock cycle. The default value is 40 ns. <p><i>Note:</i> Model 1 requires this to be set to 70 <math>\mu s</math>. Select the <b>&lt;Device&gt; Default Settings</b> preset.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>rx_digitalreset duration</b>          | 1–999999999                      | Specifies the time in ns to continue to assert the <code>rx_digitalreset</code> after the reset input and all other gating conditions are removed. The value is rounded up to the nearest clock cycle. The default value is 4000 ns.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

#### 4.4.3. Transceiver PHY Reset Controller Interfaces

This section describes the top-level signals for the Transceiver PHY Reset Controller IP core.

The following figure illustrates the top-level signals of the Transceiver PHY Reset Controller IP core. Many of the signals in the figure become buses if you choose separate reset controls. The variables in the figure represent the following parameters:

- $<n>$ —The number of lanes
- $<p>$ —The number of PLLs

### Figure 220. Transceiver PHY Reset Controller IP Core Top-Level Signals

Generating the IP core creates signals and ports based on your parameter settings.



pll\_select signal width when a single TX reset sequence is used for all channels.

**Note:** PLL control is available when you enable the **Expose Port** parameter.

### Table 251. Top-Level Signals

This table describes the signals in the above figure in the order that they are shown in the figure.

| Signal Name                 | Direction | Clock Domain                                                                                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------|-----------|------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pll_locked[<p>-1:0]         | Input     | Asynchronous                                                                                               | Provides the PLL locked status input from each PLL. When asserted, indicates that the TX PLL is locked. When deasserted, the PLL is not locked. There is one signal per PLL.                                                                                                                                                                                                                                                                |
| pll_select[<p*n>-1:0]       | Input     | Synchronous to the Transceiver PHY Reset Controller input clock. Set to zero when not using multiple PLLs. | When you select <b>Use separate TX reset per channel</b> , this bus provides enough inputs to specify an index for each pll_locked signal to listen to for each channel. When <b>Use separate TX reset per channel</b> is disabled, the pll_select signal is used for all channels.<br>n=1 when a single TX reset sequence is used for all channels.                                                                                        |
| tx_cal_busy[<n>-1:0]        | Input     | Asynchronous                                                                                               | This is the calibration status signal that results from the logical OR of pll_cal_busy and tx_cal_busy signals. The signal goes high when either the TX PLL or Transceiver PHY initial calibration is active. It is not asserted if you manually re-trigger the calibration IP. The signal goes low when calibration is completed. This signal gates the TX reset sequence. The width of this signals depends on the number of TX channels. |
| rx_cal_busy[<n>-1:0]        | Input     | Asynchronous                                                                                               | This is calibration status signal from the Transceiver PHY IP core. When asserted, the initial calibration is active. When deasserted, calibration has completed. This signal gates the RX reset sequence. The width of this signals depends on the number of RX channels.                                                                                                                                                                  |
| rx_is_lockedtodata[<n>-1:0] | Input     | Synchronous to CDR                                                                                         | Provides the rx_is_lockedtodata status from each RX CDR. When asserted, indicates that a particular RX CDR is ready to receive input data. If you do not choose separate controls for the RX channels, these inputs are ANDed together internally to provide a single status signal.                                                                                                                                                        |
| tx_manual[<n>-1:0]          | Input     | Asynchronous                                                                                               | This optional signal places tx_digitalreset controller under automatic or manual control. When asserted, the associated tx_digitalreset controller                                                                                                                                                                                                                                                                                          |

*continued...*

| Signal Name                                 | Direction | Clock Domain                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------------|-----------|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |           |                                                                  | logic does not automatically respond to deassertion of the <code>pll_locked</code> signal. However, the initial <code>tx_digitalreset</code> sequence still requires a one-time rising edge on <code>pll_locked</code> before proceeding. When deasserted, the associated <code>tx_digitalreset</code> controller automatically begins its reset sequence whenever the selected <code>pll_locked</code> signal is deasserted.                                                                                                                                                                                                                                                                                             |
| <code>rx_manual[&lt;n&gt;-1:0]</code>       | Input     | Asynchronous                                                     | This optional signal places <code>rx_digitalreset</code> logic controller under automatic or manual control. In manual mode, the <code>rx_digitalreset</code> controller does not respond to the assertion or deassertion of the <code>rx_is_lockedtodata</code> signal. The <code>rx_digitalreset</code> controller asserts <code>rx_ready</code> when the <code>rx_is_lockedtodata</code> signal is asserted.                                                                                                                                                                                                                                                                                                           |
| <code>clock</code>                          | Input     | N/A                                                              | A free running system clock input to the Transceiver PHY Reset Controller from which all internal logic is driven. If a free running clock is not available, hold reset until the system clock is stable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <code>reset</code>                          | Input     | Asynchronous                                                     | Asynchronous reset input to the Transceiver PHY Reset Controller. When asserted, all configured reset outputs are asserted. Holding the reset input signal asserted holds all other reset outputs asserted. An option is available to synchronize with the system clock. In synchronous mode, the reset signal needs to stay asserted for at least (2) clock cycles by default.                                                                                                                                                                                                                                                                                                                                           |
| <code>tx_digitalreset[&lt;n&gt;-1:0]</code> | Output    | Synchronous to the Transceiver PHY Reset Controller input clock. | Digital reset for TX channels. The width of this signal depends on the number of TX channels. This signal is asserted when any of the following conditions is true: <ul style="list-style-type: none"> <li>• <code>reset</code> is asserted</li> <li>• <code>pll_powerdown</code> is asserted</li> <li>• <code>pll_cal_busy</code> is asserted</li> <li>• <code>tx_cal_busy</code> is asserted</li> <li>• PLL has not reached the initial lock (<code>pll_locked</code> deasserted)</li> <li>• <code>pll_locked</code> is deasserted and <code>tx_manual</code> is deasserted</li> </ul> When all of these conditions are false, the reset counter begins its countdown for deassertion of <code>tx_digitalreset</code> . |
| <code>tx_analogreset[&lt;n&gt;-1:0]</code>  | Output    | Synchronous to the Transceiver PHY Reset Controller input clock. | Analog reset for TX channels. The width of this signal depends on the number of TX channels. This signal is asserted when <code>reset</code> is asserted.<br>This signal follows <code>pll_powerdown</code> , which is deasserted after <code>pll_locked</code> goes high.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <code>tx_ready[&lt;n&gt;-1:0]</code>        | Output    | Synchronous to the Transceiver PHY Reset Controller input clock. | Status signal to indicate when the TX reset sequence is complete. This signal is deasserted while the TX reset is active. It is asserted a few clock cycles after the deassertion of <code>tx_digitalreset</code> . Some protocol implementations may require you to monitor this signal prior to sending data. The width of this signal depends on the number of TX channels.                                                                                                                                                                                                                                                                                                                                            |
| <code>rx_digitalreset[&lt;n&gt;-1:0]</code> | Output    | Synchronous to the Transceiver PHY Reset Controller input clock. | Digital reset for RX. The width of this signal depends on the number of channels. This signal is asserted when any of the following conditions is true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

*continued...*

| Signal Name                                | Direction | Clock Domain                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------------------|-----------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                            |           |                                                                  | <ul style="list-style-type: none"> <li>• <code>reset</code> is asserted</li> <li>• <code>rx_analogreset</code> is asserted</li> <li>• <code>rx_cal_busy</code> is asserted</li> <li>• <code>rx_is_lockedtodata</code> is deasserted and <code>rx_manual</code> is deasserted</li> </ul> <p>When all of these conditions are false, the reset counter begins its countdown for deassertion of <code>rx_digitalreset</code>.</p> |
| <code>rx_analogreset[&lt;n&gt;-1:0]</code> | Output    | Synchronous to the Transceiver PHY Reset Controller input clock. | <p>Analog reset for RX. When asserted, resets the RX CDR and the RX PMA blocks of the transceiver PHY. This signal is asserted when any of the following conditions is true:</p> <ul style="list-style-type: none"> <li>• <code>reset</code> is asserted</li> <li>• <code>rx_cal_busy</code> is asserted</li> </ul> <p>The width of this signal depends on the number of channels.</p>                                         |
| <code>rx_ready[&lt;n&gt;-1:0]</code>       | Output    | Synchronous to the Transceiver PHY Reset Controller input clock. | <p>Status signal to indicate when the RX reset sequence is complete. This signal is deasserted while the RX reset is active. It is asserted a few clock cycles after the deassertion of <code>rx_digitalreset</code>. Some protocol implementations may require you to monitor this signal prior to sending data. The width of this signal depends on the number of RX channels.</p>                                           |
| <code>pll_powerdown[&lt;p&gt;-1:0]</code>  | Output    | Synchronous to the Transceiver PHY Reset Controller input clock. | Asserted to power down a transceiver PLL circuit. When asserted, the selected TX PLL is reset.                                                                                                                                                                                                                                                                                                                                 |

### Usage Examples for `pll_select`

- If a single channel can switch between three TX PLLs, the `pll_select` signal indicates which one of the selected three TX PLL's `pll_locked` signal is used to communicate the PLL lock status to the TX reset sequence. In this case, to select the 3-bits wide `pll_locked` port, the `pll_select` port is 2-bits wide.
- If three channels are instantiated with three TX PLLs and with a separate TX reset sequence per channel, the `pll_select` field is 6-bits wide (2-bits per channel). In this case, `pll_select[1:0]` represents channel 0, `pll_select[3:2]` represents channel 1, and `pll_select[5:4]` represents channel 2. For each channel, a separate `pll_locked` signal indicates the PLL lock status.
- If three channels are instantiated with three TX PLLs and with a single TX reset sequence for all three channels, then `pll_select` field is 2-bits wide. In this case, the same `pll_locked` signal indicates the PLL lock status for all three channels.
- If one channel is instantiated with one TX PLL, `pll_select` field is 1-bit wide. Connect `pll_select` to logic 0.
- If three channels are instantiated with only one TX PLL and with a separate TX reset sequence per channel, the `pll_select` field is 3-bits wide. In this case, `pll_select` should be set to 0 since there is only one TX PLL available.

#### 4.4.4. Transceiver PHY Reset Controller Resource Utilization

This section describes the estimated device resource utilization for two configurations of the transceiver PHY reset controller. The exact resource count varies by Quartus Prime version number, as well as by optimization options.

**Table 252. Reset Controller Resource Utilization**

| Configuration                                                  | Combination ALUTs | Logic Registers   |
|----------------------------------------------------------------|-------------------|-------------------|
| Single transceiver channel                                     | approximately 50  | approximately 50  |
| Four transceiver channels, shared TX reset, separate RX resets | approximately 100 | approximately 150 |

### 4.5. Using a User-Coded Reset Controller

You can design your own user-coded reset controller instead of using Transceiver PHY Reset Controller. Your user-coded reset controller must provide the following functionality for the recommended reset sequence:

- A clock signal input for your reset logic
- Holds the transceiver channels in reset by asserting the appropriate reset control signals
- Checks the PLL status (for example, checks the status of `pll_locked` and `pll_cal_busy`)

*Note:* You must ensure a stable reference clock is present at the PLL transmitter before releasing `pll_powerdown`.

#### 4.5.1. User-Coded Reset Controller Signals

Refer to the signals in the following figure and table for implementation of a user-coded reset controller.

**Figure 221. User-Coded Reset Controller, Transceiver PHY, and TX PLL Interaction**



**Table 253. User-coded Reset Controller, Transceiver PHY, and TX PLL Signals**

| Signal Name        | Direction | Description                                                                                                                                                                                                                  |
|--------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pll_powerdown      | Output    | Resets the TX PLL when asserted high.                                                                                                                                                                                        |
| tx_analogreset     | Output    | Resets the TX PMA when asserted high.                                                                                                                                                                                        |
| tx_digitalreset    | Output    | Resets the TX PCS when asserted high.                                                                                                                                                                                        |
| rx_analogreset     | Output    | Resets the RX PMA when asserted high.                                                                                                                                                                                        |
| rx_digitalreset    | Output    | Resets the RX PCS when asserted high.                                                                                                                                                                                        |
| clock              | Input     | Clock signal for the user-coded reset controller. You can use the system clock without synchronizing it to the PHY parallel clock. The upper limit on the input clock frequency is the frequency achieved in timing closure. |
| pll_cal_busy       | Input     | A high on this signal indicates the PLL is being calibrated.                                                                                                                                                                 |
| pll_locked         | Input     | A high on this signal indicates that the TX PLL is locked to the ref clock.                                                                                                                                                  |
| tx_cal_busy        | Input     | A high on this signal indicates that TX calibration is active. If you have multiple PLLs, you can OR their pll_cal_busy signals together.                                                                                    |
| rx_is_lockedtodata | Input     | A high on this signal indicates that the RX CDR is in the lock-to-data (LTD) mode.                                                                                                                                           |
| rx_cal_busy        | Input     | A high on this signal indicates that RX calibration is active.                                                                                                                                                               |
| rx_is_lockedtoref  | Input     | A high on this signal indicates that the RX CDR is in the lock-to-reference (LTR) mode. This signal may toggle or be deasserted when the CDR is in LTD mode.                                                                 |

## 4.6. Combining Status or PLL Lock Signals

You can combine multiple PHY status signals before feeding into the reset controller as shown below.

**Figure 222. Combining Multiple PHY Status Signals**

**Note:** This configuration also applies to the rx\_cal\_busy signals.

When using multiple PLLs, you can logical AND the pll\_locked signals feeding the reset controller. Similarly, you can logical OR the pll\_cal\_busy signals to the reset controller tx\_cal\_busy port as shown below.

**Figure 223. Multiple PLL Configuration**

Resetting different channels separately requires multiple reset controllers. For example, a group of channels configured for Interlaken requires a separate reset controller from another group of channels that are configured for optical communication.

## 4.7. Timing Constraints for Bonded PCS and PMA Channels

For designs that use **TX PMA and PCS Bonding**, the digital reset signal (tx\_digitalreset) to all TX channels within a bonded group must meet a maximum skew tolerance imposed by physical routing. This skew tolerance is one-half the TX parallel clock cycle (tx\_clkout). This requirement is not necessary for **TX PMA Bonding** or for RX PCS channels.

**Note:** If the design is not able to meet the maximum skew tolerance requirement with a positive margin, Intel recommends reassigning the channels locations that are not adjacent to the PCIe Hard IP block.

**Figure 224. Physical Routing Delay Skew in Bonded Channels**


You must provide a Synopsys Design Constraint (SDC) for the reset signals to guarantee that your design meets timing requirements. The Quartus Prime software generates an .sdc file when you generate the Transceiver Native PHY IP core.

This .sdc contains basic false paths for most asynchronous signals, including resets. In the case of bonded designs, this file contains examples for maximum skew on bonded designs. This .sdc file contains an example `false_path` and an example `max_skew` constraint for the `tx_digitalreset` signals.

All modified IP constraints from a generated .sdc file must be moved to the project's main .sdc file, because changes are lost if the IP is regenerated.

This skew is present whether you tie all `tx_digitalresets` together, or you control them separately. If your design includes the Transceiver PHY Reset Controller IP core, you can substitute your instance and interface names for the generic names shown in the example.

#### **Example 1. SDC Constraint for TX Digital Reset When Bonded Clocks Are Used**

```
set_max_skew -from *<IP_INSTANCE_NAME> *tx_digitalreset*r_reset
-to *pld_pcs_interface* <1/2 coreclk period in ps>
```

In the above example, you must make the following substitutions:

- `<IP_INSTANCE_NAME>`—substitute the name of your reset controller IP instance or PHY IP instance
- `<1/2 coreclk period in ps>`—substitute half of the clock period of your design in picoseconds

If your design has custom reset logic, replace the `*<IP_INSTANCE_NAME>*tx_digitalreset*r_reset` with the source register for the TX PCS reset signal, `tx_digitalreset`.

For more information about the `set_max_skew` constraint, refer to the *SDC and Timing Analyzer API Reference Manual*.

#### Related Information

[SDC and Timing Analyzer API Reference Manual](#)

## 4.8. Resetting Transceiver Channels Revision History

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2021.06.10       | <ul style="list-style-type: none"> <li>Removed the step on deasserting <code>pll_powerdown</code> after <code>tpll_powerdown</code> in the <i>Resetting the Transmitter During Device Operation</i> section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2020.05.08       | <p>Made the following change:</p> <ul style="list-style-type: none"> <li>Updated <b>pll_locked input hysteresis</b> in reference to <math>t_{req} = 70 \mu s</math> in the "General Options" table.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2018.06.15       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Clarified the <i>Dynamic Reconfiguration of Receiver Channel Using the Acknowledgment Model</i> instructions for when the CDR is in manual lock mode.</li> <li>Updated the description for the "Enable RX channel reset control" parameter.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                         |
| 2017.11.06       | <p>Made the following change:</p> <ul style="list-style-type: none"> <li>Added a note "If the design is not able to meet the maximum skew tolerance requirement with a positive margin, Intel recommends reassigning the channels locations that are not adjacent to the PCIe Hard IP block."</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2016.05.02       | <p>Made the following changes</p> <ul style="list-style-type: none"> <li>Added port "user reset" in "Typical Transceiver PHY Implementation" diagram.</li> <li>Added note number 50.</li> <li>Updated "Transceiver and Receiver Reset Sequence" diagram.</li> <li>Added a note "Area in gray is don't care zone" in every diagram that has gray area in it.</li> <li>Changes "tLTD" to "trx_digitalreset" in all the diagrams.</li> </ul>                                                                                                                                                                                                                                                                |
| 2015.12.18       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Added description to the "Recommended Reset Sequence" section.</li> <li>Added the "Arria 10 Default Settings Preset" figure.</li> <li>Changed the signals and added a note in the "Typical Transceiver PHY Implementation" figure.</li> <li>Added a parameter to the "General Options" table.</li> <li>Updated the "Reset Sequence Timing Diagram for Receiver when CDR is in Manual Lock Mode" figure.</li> <li>Updated the steps in the "Resetting the Transceiver in CDR Manual Lock Mode" section.</li> </ul>                                                                                                              |
| 2015.11.02       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Updated the "Reset Conditions" table.</li> <li>Created the "Transceiver PHY Implementation" section.</li> <li>Updated the "Typical Transceiver PHY Implementation" figure and moved it to the "Transceiver PHY Implementation" section.</li> <li>Added the "Model 1: Default Model" and "Model 2: Acknowledgment Model" sections to the "How Do I Reset?" section.</li> <li>Updated the "Transceiver PHY Reset Controller System Diagram" in the "Using the Transceiver PHY Reset Controller" section.</li> <li>Added "Usage Examples for pll_select" to the "Transceiver PHY Reset Controller Interfaces" section.</li> </ul> |
| 2014.12.15       | Made the following changes:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"><li>Updated the "Transmitter Reset Sequence After Power-Up" and "Transmitter Reset Sequence During Device Operation" figures.</li><li>Improved formatting in the "Transceiver PHY Reset Controller IP Core Top-Level Signals" figure.</li><li>Updated the description of the <b>reset</b>, <b>tx_analogreset</b>, and <b>rx_analogreset</b> parameters in the "Top-Level Signals" table.</li></ul> |
| 2014.08.15       | Made the following changes: <ul style="list-style-type: none"><li>Updated the "Transmitter Reset Sequence After Power-Up" and "Receiver Reset Sequence Following Power-Up" figures.</li><li>Updated the "Resetting the Receiver During Device Operation" procedure and associated figure.</li><li>Updated the "Reset Sequence Timing Diagram for Transceiver when CDR is in Manual Lock Mode" figure.</li></ul>                      |
| 2013.12.02       | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                     |

## 5. Arria 10 Transceiver PHY Architecture

### 5.1. Arria 10 PMA Architecture

The Physical Medium Attachment (PMA) acts as the analog front end for the Arria 10 transceivers.

The PMA receives and transmits high-speed serial data depending on the transceiver channel configuration. All serial data transmitted and received passes through the PMA.

#### 5.1.1. Transmitter

The transmitter takes the parallel data and serializes it to create a high-speed serial data stream. The transmitter portion of the PMA is composed of the transmitter serializer and the transmitter buffer. The serializer clock is provided from the transmitter PLL.

**Figure 225. Transmitter PMA Block Diagram**



#### 5.1.2. Serializer

The serializer converts the incoming low-speed parallel data from the transceiver PCS or FPGA fabric to high-speed serial data and sends the data to the transmitter buffer.

The channel serializer supports the following serialization factors: 8, 10, 16, 20, 32, 40, and 64.

**Figure 226. Serializer Block**

The serializer block sends out the least significant bit (LSB) of the input data first.



### 5.1.3. Transmitter Buffer

The transmitter buffer includes the following circuitry:

- High Speed Differential I/O
- Programmable differential output voltage ( $V_{OD}$ )
  - Main tap
- Programmable four-tap pre-emphasis circuitry
  - Two pre-cursor taps
  - Two post-cursor taps
- Power distribution network (PDN) induced inter-symbol interference (ISI) compensation
- Internal termination circuitry
- Receiver detect capability to support PCI Express and Quick Path Interconnect (QPI) configurations

**Figure 227. Transmitter Buffer**



R1\* - Half of the actual on-chip termination selected.

### 5.1.3.1. High Speed Differential I/O

To improve performance, the Arria 10 transmitter uses a new architecture in the output buffer—a high speed differential I/O. Select **High Speed Differential I/O** for the I/O standard of the Intel Arria 10 transmitter pin in Intel Quartus Prime Assignment Editor or QSF file.

### 5.1.3.2. Programmable Output Differential Voltage

You can program the differential output voltage (output swing) to handle different channel losses and receiver requirements. There are 31 differential V<sub>OD</sub> settings up to VCCT power supply level. The step size is 1/30 of the VCCT power supply level.

**Figure 228. V<sub>OD</sub> (Differential) Signal Level**



$$V_{OD} (\text{Differential}) = V_P - V_N$$

#### Related Information

- [XCVR\\_A10\\_RX\\_TERM\\_SEL](#) on page 601
- For more information, refer to [Arria 10 Pre-Emphasis and Output Swing Settings](#)

### 5.1.3.3. Programmable Pre-Emphasis

Pre-emphasis can maximize the eye at the far-end receiver. The programmable pre-emphasis module in each transmit buffer amplifies high frequencies in the transmit data signal, to compensate for attenuation in the transmission media.

The pre-tap pre-emphasizes the bit before the transition and de-emphasizes the remaining bits. A different polarity on pre-tap does the opposite.

**Table 254. Pre-Emphasis Taps**

All four pre-emphasis taps provide inversion control, shown by negative values.

| Pre-Emphasis Tap | Number of Settings |
|------------------|--------------------|
| Second pre-tap   | 15                 |
| First pre-tap    | 33                 |
| First post-tap   | 51                 |
| Second post-tap  | 25                 |

You can set pre-emphasis taps through the Quartus Assignment Editor, the Avalon memory-mapped interface registers, and the QSF settings.

#### Related Information

For more information, refer to Arria 10 Pre-Emphasis and Output Swing Settings

### 5.1.3.4. Power Distribution Network (PDN) induced Inter-Symbol Interference (ISI) compensation

Arria 10 Transmitter driver includes a compensation circuitry to reduce PDN induced ISI jitter. You can enable this compensation circuitry to reduce jitter through QSF setting, Quartus Assignment Editor or Avalon memory-mapped interface. The power consumption increases when you enable the compensation.

### 5.1.3.5. Programmable Transmitter On-Chip Termination (OCT)

Transmitter buffers include programmable on-chip differential termination of  $85\Omega$  or  $100\Omega$ . You can set the OCT value through the Quartus Assignment Editor and the Avalon memory-mapped interface registers.

#### Related Information

Arria 10 Register Map

## 5.1.4. Receiver

The receiver deserializes the high-speed serial data, creates a parallel data stream for either the receiver PCS or the FPGA fabric, and recovers the clock information from the received data.

The receiver portion of the PMA is comprised of the receiver buffer, the clock data recovery (CDR) unit, and the deserializer.

**Figure 229. Receiver PMA Block Diagram**

### 5.1.5. Receiver Buffer

The receiver input buffer receives serial data from `rx_serial_data` and feeds the serial data to the clock data recovery (CDR) unit and deserializer. Select **High Speed Differential I/O, CML, Differential LVPECL, and LVDS** for the I/O standard of the Intel Arria 10 receiver pin in Intel Quartus Prime Assignment Editor or QSF file. **CML, Differential LVPECL, and LVDS** are only used on AC coupled links.

**Figure 230. Receiver Buffer**

The receiver buffer supports the following features:

- Programmable common mode voltage ( $V_{CM}$ )
- Programmable differential On-Chip Termination (OCT)
- Signal Detector
- Continuous Time Linear Equalization (CTLE)
- Variable Gain Amplifiers (VGA)
- Adaptive Parametric Tuning Engine
- Decision Feedback Equalization (DFE)

#### 5.1.5.1. Programmable Common Mode Voltage ( $V_{CM}$ )

The receiver buffer has on-chip biasing circuitry to establish the required  $V_{CM}$  at the receiver input.

The Quartus Prime software automatically chooses the optimal setting for RX  $V_{CM}$ .

**Note:** On-chip biasing circuitry is available only if you select OCT. If you select external termination, you must implement off-chip biasing circuitry to establish the  $V_{CM}$  at the receiver input buffer.

Manual  $V_{CM}$  adjustment is not supported and is only adjusted by calibrations.

### 5.1.5.2. Programmable Differential On-Chip Termination (OCT)

Receiver buffers include programmable on-chip differential termination of  $85\Omega$ ,  $100\Omega$ , or OFF.

You can disable OCT and use external termination. If you select external termination, the receiver common mode is tri-stated. Common mode is based on the external termination connection. You also need to implement off-chip biasing circuitry to establish the  $V_{CM}$  at the receiver buffer.

### 5.1.5.3. Signal Detector

You can enable the optional signal threshold detection circuitry. If enabled, this option senses whether the signal level present at the receiver input buffer is above the signal detect threshold voltage that you specified in the assignment editor.

### 5.1.5.4. Continuous Time Linear Equalization (CTLE)

The CTLE boosts the signal that is attenuated due to channel characteristics. Each receiver buffer has independently programmable equalization circuits. These equalization circuits amplify the high-frequency component of the incoming signal by compensating for the low-pass characteristics of the physical medium. The CTLE can support both DC and AC gain.

DC gain circuitry provides an equal amplification to the incoming signal across the low frequency spectrum. AC gain circuitry provides amplification to the high-frequency spectrum gain of the incoming signal.

Arria 10 transceivers support dual mode CTLE.

#### 5.1.5.4.1. High Gain Mode

High gain mode supports data rate up to 17.4 Gbps. This mode provides both AC and DC gain. There are two bandwidth settings available for this mode.

- Full Bandwidth—This mode has a peaking frequency of 6.25 GHz offering AC gain at 17 dB.
- Medium Bandwidth—This mode has a peaking frequency of 3.125 GHz offering AC gain at 21 dB.

**Figure 231. CTLE DC and AC Gain Conceptualization**

*Note:* Final equalization curves will be available in the Arria 10 device datasheet.

#### 5.1.5.4.2. High Data Rate Mode

High Data Rate Mode is a low power mode that supports data rates up to 25.8 Gbps. It is the default mode if none of the modes are selected in the Intel Quartus Prime Assignment Editor or Intel Quartus Prime Settings File (.qsf). This mode provides an alternative path for high gain mode. High Data Rate Mode can be used to compensate for the loss similar to CEI 28G VSR. High data rate mode supports four bandwidth modes: Full, three-fourths, one-half, and one-fourth bandwidth modes. Full bandwidth mode can provide AC peaking at approximately 8 dB at a peaking frequency of 14 GHz. High data rate mode can be operated in three-fourths, one-half, and one-fourth bandwidth with 9 GHz, 5 GHz, and 2.5 GHz peaking frequencies. In high data rate

mode, AC gain values and DC gain values cannot be controlled individually as done in high gain mode. The recommended AC gain values in high data rate mode include the appropriate setting of DC gain to get the required peaking at respective peaking frequencies.

CTLE can only be supported in manual mode with the exception of PCIe Gen3, which supports triggered mode. CTLE mode and CTLE gain can be set through Intel Quartus Prime Assignment Editor or Intel Quartus Prime Settings File and Avalon memory-mapped interface registers.

#### Related Information

- [CTLE Settings in Triggered Adaptation Mode](#) on page 543
- [PHY IP Core for PCIe \(PIPE\) Link Equalization for Gen3 Data Rate](#) on page 281
- [How to Enable CTLE and DFE](#) on page 468
- [Arria 10 Device Datasheet](#)
- [Arria 10 Register Map](#)

#### 5.1.5.5. Variable Gain Amplifier (VGA)

Arria 10 channels have a variable gain amplifier to optimize the signal amplitude prior to the CDR sampling. VGA can only be operated in manual mode. VGA gain can be selected through Intel Quartus Prime Assignment Editor or Intel Quartus Prime Setting File (qsf) or the Avalon memory-mapped interface register. You must set VGA manually for all combinations of CTLE and DFE modes.

**Figure 232. VGA Frequency Response for Different Gain Settings**



#### Related Information

- [How to Enable CTLE and DFE](#) on page 468

#### 5.1.5.6. Decision Feedback Equalization (DFE)

DFE amplifies the high frequency components of a signal without amplifying the noise content. It compensates for inter-symbol interference (ISI). DFE minimizes post-cursor ISI by adding or subtracting weighted versions of the previously received bits from the current bit. DFE works in synchronization with the TX pre-emphasis and downstream RX CTLE. This enables the RX CDR to receive the correct data that was transmitted through a lossy and noisy backplane.

The DFE advantage over CTLE is improved Signal to Noise Ratio (SNR). DFE amplifies the power of the high frequency components without amplifying the noise power.

**Figure 233. Signal ISI**



Notes:

- An ideal pulse response is a single data point at the cursor.
- Real world pulse response is non-zero before the cursor (precursor) and after the cursor (postcursor).
- ISI occurs when the data sampled at precursor or postcursor is not zero.

The DFE circuit stores delayed versions of the data. The stored bit is multiplied by a coefficient and then summed with the incoming signal. The polarity of each coefficient is programmable.

The DFE architecture supports eleven fixed taps.

The eleven fixed taps translate to the DFE capable of removing the ISI from the next 11 bits, beginning from the current bit.

**Figure 234. Channel Pulse Response**

**Note:**

The pulse at the output of the channel shows a long decaying tail. Frequency-dependent losses and quality degradation affects other signals.

**Supported modes for DFE:**

- Disabled Mode:
  - DFE disabled mode is similar to DFE manual mode, except all DFE tap values in this mode are set to zero. DFE tap values can be set in Assignment Editor/.qsf or using Avalon memory-mapped interface.
- Manual Mode:
  - In this mode, manual DFE tap values can be set in Assignment Editor/.qsf or using Avalon memory-mapped interface.
- Adaptation Enabled Mode:
  - In this adaptation mode, DFE tap values are controlled by the Adaptive Parametric Tuning Engine. This mode uses the converged DFE tap values given by the Adaptive Parametric Tuning Engine.

**Related Information**

[How to Enable CTLE and DFE](#) on page 468

### 5.1.5.7. How to Enable CTLE and DFE

**Table 255. Summary of Receiver Equalization Modes**

| Receiver Equalization    | Modes                                                         |
|--------------------------|---------------------------------------------------------------|
| CTLE adaptation mode     | Manual, Triggered (use the triggered mode for PCIe Gen3 only) |
| DFE adaptation mode      | Adaptation enabled, Manual, Disabled                          |
| Number of fixed DFE taps | 3, 7, 11                                                      |

Follow these steps to trigger DFE adaptation:

1. Request user access to the internal configuration bus by writing 0x2 to offset address 0x0[1:0].
2. Monitor and wait for avmm\_waitrequest to be deasserted (logic low) if "Separate reconfig\_waitrequest from PreCISE" option is disabled. Otherwise, monitor and wait for register bit 0x281 bit[2] to go low if "Separate reconfig\_waitrequest from PreCISE" and "Enable control and status registers" option is enabled.
3. Select adaptation control by Read-Modify-Write 0x1 to bit[4] of address 0x149.
4. Enable adaptation trigger by Read-Modify-Write 0x1 to bit[6] of address 0x100.
5. Release the internal configuration bus to PreSICE by writing 0x3 to offset address 0x0[1:0].
6. Repeat step 2.
7. Monitor DFE adaptation completion by checking register bit 0x100 bit[6] to go low. This confirms DFE trigger adaptation routine is complete.

#### Related Information

[Analog Parameter Settings](#) on page 597

##### 5.1.5.7.1. Configuration Methods

Configure the modes using one of the following methods:

###### Method 1 - Using Arria 10 Transceiver Native PHY IP Core

1. Select the CTLE/DFE mode in the RX PMA tab of the PHY IP Core
2. Compile the design
3. Choose one the following:
  - If CTLE or DFE is in Manual mode, set the CTLE gain value or DFE taps using one of the following ways:
    - a. Assignment Editor/.qsf- Recompile the design to make these values effective.  
Refer to *Analog Parameter Settings* for more details about *Receiver Equalization Settings*.
    - b. Avalon memory-mapped interface - Value written through Avalon memory-mapped interface take precedence over values defined in Assignment Editor. Use this method to dynamically set values and hence avoid re-compilation.  
Refer to *Arria 10 Transceiver Register Map* for more details on Avalon memory-mapped interface and to perform dynamic read/write.

###### Method 2 - Using Avalon Memory-Mapped Interface

1. Any changes you make using Avalon memory-mapped interface take precedence over what was configured in Native PHY IP GUI and/or Assignment Editor.
  - a. For CTLE and DFE in Manual mode, set the CTLE gain value or DFE Taps using the reconfiguration interface. The values are written dynamically and do not require design re-compilation.

Refer to *Arria 10 Register Map* for details on the specific registers that set the CTLE gain values/DFE taps.

- b. For dynamically changing DFE and CTLE Adaptation modes, refer to *CTLE Settings in Triggered Adaptation Mode*, *Arria 10 Register Map* and *Arria 10 DFE Adaptation Tool* for the list of adaptation registers. Use the reconfiguration interface to change the register settings.

*Note:* You must set VGA manually for all combinations of CTLE mode and DFE modes.

### Related Information

- [CTLE Settings in Triggered Adaptation Mode](#) on page 543
- [Arria 10 Register Map](#)  
*Arria 10 DFE Adaptation Tool* is a separate tab in the *Arria 10 Register Map*.

## 5.1.6. Clock Data Recovery (CDR) Unit

The PMA of each channel includes a channel PLL that you can configure as a receiver clock data recovery (CDR) for the receiver. You can also configure the channel PLL of channels 1 and 4 as a clock multiplier unit (CMU) PLL for the transmitter in the same bank.

**Figure 235. Channel PLL Configured as CDR**



Note:

1. The Quartus® Prime Pro Edition software automatically chooses the optimal values.

### 5.1.6.1. Lock-to-Reference Mode

In LTR mode, the phase frequency detector (PFD) in the CDR tracks the receiver input reference clock. The PFD controls the charge pump that tunes the VCO in the CDR. The *rx\_is\_lockedtoref* status signal is asserted active high to indicate that the CDR has locked to the phase and frequency of the receiver input reference clock.

*Note:* The phase detector (PD) is inactive in LTR mode.

### 5.1.6.2. Lock-to-Data Mode

During normal operation, the CDR must be in LTD mode to recover the clock from the incoming serial data. In LTD mode, the PD in the CDR tracks the incoming serial data at the receiver input. Depending on the phase difference between the incoming data and the CDR output clock, the PD controls the CDR charge pump that tunes the VCO.

**Note:** The PFD is inactive in LTD mode. The `rx_is_lockedtoref` status signal toggles randomly and is not significant in LTD mode.

After switching to LTD mode, the `rx_is_lockedtodata` status signal is asserted. The actual lock time depends on the transition density of the incoming data and the parts per million (ppm) difference between the receiver input reference clock and the upstream transmitter reference clock. The `rx_is_lockedtodata` signal toggles until the CDR sees valid data; therefore, you should hold receiver PCS logic in reset (`rx_digitalreset`) for a minimum of 4 µs after `rx_is_lockedtodata` remains continuously asserted.

### 5.1.6.3. CDR Lock Modes

You can configure the CDR in either automatic lock mode or manual lock mode. By default, the Quartus Prime software configures the CDR in automatic lock mode.

#### 5.1.6.3.1. Automatic Lock Mode

In automatic lock mode, the CDR initially locks to the input reference clock (LTR mode). After the CDR locks to the input reference clock, the CDR locks to the incoming serial data (LTD mode) when the following conditions are met:

- The signal threshold detection circuitry indicates the presence of valid signal levels at the receiver input buffer when `rx_std_signaldetect` is enabled.
- The CDR output clock is within the configured ppm frequency threshold setting with respect to the input reference clock (frequency locked).
- The CDR output clock and the input reference clock are phase matched within approximately 0.08 unit interval (UI) (phase locked).

If the CDR does not stay locked to data because of frequency drift or severe amplitude attenuation, the CDR switches back to LTR mode.

#### 5.1.6.3.2. Manual Lock Mode

The PPM detector and phase relationship detector reaction times can be too long for some applications that require faster CDR lock time. You can manually control the CDR to reduce its lock time using two optional input ports (`rx_set_locktoref` and `rx_set_locktodata`).

**Table 256. Relationship Between Optional Input Ports and the CDR Lock Mode**

| <code>rx_set_locktoref</code> | <code>rx_set_locktodata</code> | CDR Lock Mode     |
|-------------------------------|--------------------------------|-------------------|
| 0                             | 0                              | Automatic         |
| 1                             | 0                              | Manual-RX CDR LTR |
| X                             | 1                              | Manual-RX CDR LTD |

### 5.1.7. Deserializer

The deserializer block clocks in serial input data from the receiver buffer using the high-speed serial recovered clock and deserializes the data using the low-speed parallel recovered clock. The deserializer forwards the deserialized data to the receiver PCS or FPGA fabric, and sends out the LSB of the input data first.

The deserializer supports the following deserialization factors: 8, 10, 16, 20, 32, 40, and 64.

**Figure 236. Deserializer Block Diagram**



### 5.1.8. Loopback

The PMA supports serial, diagnostic, and reverse loopback paths.

**Figure 237. Serial Loopback Path**

The serial loopback path sets the CDR to recover the data from the serializer while data from receiver serial input pin is ignored by the CDR. The transmitter buffer sends data normally. Adjusting the TX VOD, TX pre-emphasis, and RX CTLE settings does not have an effect on the serial data that goes through the serial loopback path. Adjusting the RX VGA and RX DFE settings has an effect on the serial data that goes through the serial loopback path.



**Figure 238. Reverse Serial Loopback Path/Pre CDR**

The reverse serial loopback path sets the transmitter buffer to transmit data fed directly from the VGA output. Adjusting the RX CTLE, and RX VGA settings has an effect on the serial data that goes through the diagnostic loopback path.

**Figure 239. Reverse Serial Loopback Path/Post CDR**

The reverse serial loopback path sets the transmitter buffer to transmit data fed directly from the CDR recovered data. Adjusting the RX CTLE, RX VGA, and RX DFE settings has an effect on the serial data that goes through the reverse loopback path. Adjusting TX VOD and TX pre-emphasis has an effect on the transmitter serial differential output data.



## 5.2. Arria 10 Enhanced PCS Architecture

You can use the Enhanced PCS to implement multiple protocols that operate at around 10 Gbps or higher line rates.

The Enhanced PCS provides the following functions:

- Performs functions common to most serial data industry standards, such as word alignment, block synchronization, encoding/decoding, and framing, before data is sent or received off-chip through the PMA
- Handles data transfer to and from the FPGA fabric
- Internally handles data transfer to and from the PMA
- Provides frequency compensation
- Performs channel bonding for multi-channel low skew applications

**Figure 240. Enhanced PCS Datapath Diagram**



### Related Information

[Implementing Protocols in Arria 10 Transceivers](#) on page 32

## 5.2.1. Transmitter Datapath

### 5.2.1.1. Enhanced PCS TX FIFO

The Enhanced PCS TX FIFO provides an interface between the transmitter channel PCS and the FPGA fabric. The TX FIFO can operate for phase compensation between the channel PCS and FPGA fabric. You can also use the TX FIFO as an elastic buffer to control the input data flow, using `tx_enh_data_valid`. The TX FIFO also allows channel bonding. The TX FIFO has a width of 73 bits and a depth of 16 words.

You can set the TX FIFO partially full and empty thresholds through the Transceiver and PLL Address Map. Refer to the *Reconfiguration Interface and Dynamic Reconfiguration* chapter for more details.

The TX FIFO supports the following operating modes:

- Phase Compensation mode
- Register mode
- Interlaken mode
- Basic mode

### Related Information

[Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514

#### 5.2.1.1.1. Phase Compensation Mode

In Phase Compensation mode, the TX Core FIFO decouples phase variations between `tx_coreclk` and `PCS_clkout_x2(tx)`. In this mode, read and write of the TX Core FIFO can be driven by clocks from asynchronous clock sources but must be same frequency. You can use `tx_coreclk` (FPGA fabric clock) or `tx_clkout1` (TX parallel clock) to clock the write side of the TX Core FIFO.

**Note:** Phase Compensation mode, TX parallel data is valid for every low speed clock cycle, and `tx_enh_data_valid` signal should be tied with 1'b1.

**Note:** Phase Compensation can also be used in double rate transfer mode, where the FPGA fabric data width is doubled to allow the FPGA fabric clock to run at half rate. The double rate transfer mode is set in the Native PHY IP Parameter Editor. Refer to the "Transmitter Data Path Interface Clocking" and "Receiver Data Path Interface Clocking" sections in the *PLLs and Clock Networks* chapter for details about the clock frequencies, when using FIFO single and double rate transfer mode.

#### Related Information

- [Transmitter Data Path Interface Clocking](#) on page 396
- [Receiver Data Path Interface Clocking](#) on page 397

#### 5.2.1.1.2. Register Mode

The Register Mode bypasses the FIFO functionality to eliminate the FIFO latency uncertainty for applications with stringent latency requirements. This is accomplished by tying the read clock of the FIFO with its write clock.

In Register mode, `tx_parallel_data` (data), `tx_control` (indicates whether `tx_parallel_data` is a data or control word), and `tx_enh_data_valid` (data valid) are registered at the FIFO output.

**Note:** Intel recommends that you implement a soft FIFO in the FPGA fabric with a minimum of 32 words under the following conditions:

- When the Enhanced PCS TX FIFO is set to register mode.
- When using the recovered clock to drive the core logic.
- When there is no soft FIFO being generated along with the IP Catalog.

#### 5.2.1.1.3. Interlaken Mode

In Interlaken mode, the TX Core FIFO operates as an elastic buffer. In this mode, you have additional signals to control the data flow into the FIFO. Therefore, the FIFO write clock frequency does not have to be the same as the read clock frequency. You control the writing to the TX Core FIFO with `tx_fifo_wr_en` by monitoring the FIFO flags. The goal is to prevent the FIFO from becoming full or empty. On the read side, read enable is controlled by the Interlaken frame generator.

#### 5.2.1.1.4. Basic Mode

In Basic mode, the TX Core FIFO operates as an elastic buffer, where buffer depths can vary. This mode allows driving write and read side of TX Core FIFO with different clock frequencies. Monitor the FIFO flag to control write and read operations. For TX Core FIFO, assert `tx_fifo_wr_en` with `tx_fifo_pempty` signal going low.

### 5.2.1.2. Interlaken Frame Generator

The Interlaken frame generator block takes the data from the TX FIFO and encapsulates the payload and burst/idle control words from the FPGA fabric with the framing layer's control words (synchronization word, scrambler state word, skip word, and diagnostic word) to form a metaframe. The Native PHY IP Parameter Editor allows you to set the metaframe length from five 8-byte words to a maximum value of 8192 (64Kbyte words).

Use the same value on frame generator metaframe length for the transmitter and receiver.

**Figure 241. Interlaken Frame Generator**

The Interlaken frame generator implements the Interlaken protocol.



### 5.2.1.3. Interlaken CRC-32 Generator

The Interlaken CRC-32 generator block receives data from the Interlaken frame generator and calculates the cyclic redundancy check (CRC) code for each block of data. This CRC code value is stored in the CRC32 field of the diagnostic word. CRC-32 provides a diagnostic tool for each lane. This helps to trace the errors on the interface back to an individual lane.

The CRC-32 calculation covers most of the metaframe, including the diagnostic word, except the following:

- Bits [66:64] of each word
- 58-bit scrambler state within the scrambler state word
- 32-bit CRC-32 field within the diagnostic word

**Figure 242. Interlaken CRC-32 Generator**

The Interlaken CRC-32 generator implements the Interlaken protocol.



#### 5.2.1.4. 64B/66B Encoder and Transmitter State Machine (TX SM)

The 64B/66B encoder is used to achieve DC-balance and sufficient data transitions for clock recovery. It encodes 64-bit XGMII data and 8-bit XGMII control into 10GBASE-R 66-bit control or data blocks in accordance with Clause 49 of the IEEE802.3-2008 specification.

The 66-bit encoded data contains two overhead sync header bits that the receiver PCS uses for block synchronization and bit-error rate (BER) monitoring. The sync header is 01 for data blocks and 10 for control blocks. Sync headers are not scrambled and are used for block synchronization. (The sync headers 00 and 11 are not used, and generate an error if seen.) The remainder of the block contains the payload. The payload is scrambled and the sync header bypasses the scrambler.

The encoder block also has a state machine (TX SM) designed in accordance with the IEEE802.3-2008 specification. The TX SM ensures valid packet construction on data sent from the MAC layer. It also performs functions such as transmitting local faults under reset, as well as transmitting error codes when the 10GBASE-R PCS rules are violated.

**Note:** The 64B/66B encoder is available to implement the 10GBASE-R protocol.

**Figure 243. Example Data Pattern for 64B/66B Encoding**



### 64B/66B Encoder Reset Condition

The `tx_digitalreset` signal resets the 64B/66B encoder. During the reset condition, the 64B/66B encoder does not output any signal in contrast with the 8B/10B encoder.

#### 5.2.1.5. Pattern Generators

The Arria 10 transceivers contain hardened generators and checkers to provide a simple and easy way to verify and characterize high speed links. Hardening the pattern generators and checkers save FPGA core logic resources. The following pattern generator blocks are supported in Arria 10:

- Pseudo Random Binary Sequence (PRBS)
- Pseudo Random Pattern (PRP)

*Note:* The pattern generators and checkers are supported for non-bonded channels only.

The pattern generators or checkers are enabled by writing to the respective register bits of the Transceiver. Refer to the *Reconfiguration Interface and Dynamic Reconfiguration* chapter for configuration details.

#### Related Information

[Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514

##### 5.2.1.5.1. PRBS Pattern Generator (Shared between Enhanced PCS and Standard PCS)

You can use Arria 10 pseudo-random bit sequence PRBS generator to simulate traffic without developing or fully implementing any upper layer of a protocol stack. The PRBS generator in Arria 10 devices is a shared hardened block between the Standard and Enhanced datapaths through the PCS instead of being two unique instances: one for Standard PCS and one for the Enhanced PCS. There is only one set of control signals and registers for using this feature. The data lines from the various PCSes and shared PRBS, are muxed before they are sent to the PMA. When the PRBS generator is enabled, the data on the PRBS data lines is selected to be sent to the PMA. At any instant, either the data from the PCS or the data generated from the PRBS generator, is sent to the PMA.

The PRBS generator can be configured for two widths of the PCS-PMA interface: 10 bits and 64 bits. PRBS9 is available in 10-bit and 64-bit PCS-PMA widths. All other PRBS patterns are available in 64-bit PCS-PMA width only. The PRBS generator patterns can only be used when PCS-PMA interface width is configured to 10 bits or 64 bits.

**Table 257. Supported PRBS Patterns**

| PRBS Pattern                  | 10 bit PCS-PMA width | 64 bit PCS-PMA width |
|-------------------------------|----------------------|----------------------|
| PRBS7: $x^7 + x^6 + 1$        |                      | Yes                  |
| PRBS9: $x^9 + x^5 + 1$        | Yes                  | Yes                  |
| PRBS15: $x^{15} + x^{14} + 1$ |                      | Yes                  |
| PRBS23: $x^{23} + x^{18} + 1$ |                      | Yes                  |
| PRBS31: $x^{31} + x^{28} + 1$ |                      | Yes                  |

PRBS test patterns may be considered equivalent to "noise". Use these patterns to test the transceiver link with a noisy signal by placing the transceiver in loopback mode.

Use PRBS7 and PRBS9 to test transceiver links with linear impairments, and with 8B/10B.

Use PRBS15 for jitter evaluation.

Use PRBS23 or PRBS31 for jitter evaluation (data-dependent jitter) of non-8B/10B links, such as SDH/SONET/OTN jitter testers. Most 40G, 100G, and 10G applications use PRBS31 for link evaluation.

**Figure 244. PRBS Generator for Serial Implementation of PRBS9 Pattern**



**Note:** All supported PRBS generators are similar to the PRBS9 generator.

Refer to the *Reconfiguration Interface and Dynamic Reconfiguration* chapter for configuration details.

#### Related Information

[Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514

##### 5.2.1.5.2. Pseudo-Random Pattern Generator

The pseudo-random pattern (PRP) generator is specifically designed for the 10GBASE-R and 1588 protocols. The PRP generator block operates in conjunction with the scrambler to generate pseudo-random patterns for the TX and RX tests in the 10G Ethernet mode. You can use the Arria 10 Pseudo Random Pattern (PRP) generator in the scrambler to generate random data pattern and seed that the scrambler can use. The PRP mode is a test mode of the scrambler. Two seeds are available to seed the scrambler: all 0s or two local fault-ordered sets. The seed is used in the scrambler to produce the pattern. PRP is only available when the scrambler is enabled.

Refer to the *Reconfiguration Interface and Dynamic Reconfiguration* chapter for configuration details.

#### Related Information

[Reconfiguration Interface and Dynamic Reconfiguration](#) on page 514

### 5.2.1.6. Scrambler

The scrambler randomizes data to create transitions to DC-balance the signal and help CDR circuits. The scrambler uses a  $x^{58} + x^{39} + 1$  polynomial and supports both synchronous scrambling used for Interlaken and asynchronous (also called self-synchronized) scrambling used for the 10GBASE-R protocol.

The asynchronous (self-synchronizing) mode does not require an initialization seed. Except for the two sync header bits in each 66-bit data block, the entire 64-bit payload is scrambled by feeding it into a linear feedback shift register (LFSR) continuously to generate scrambled data while the sync-header bits bypass the scrambler. The initial seed is set to all 1s. You can change the seed for the 10GBASE-R protocol using the Native PHY IP Parameter Editor.

**Figure 245. Asynchronous Scrambler in Serial Implementation**



In synchronous mode, the scrambler is initially reset to different programmable seeds on each lane. The scrambler then runs by itself. Its current state is XOR'd with the data to generate scrambled data. A data checker in the scrambler monitors the data to determine if it should be scrambled or not. If a synchronization word is found, it is transmitted without scrambling. If a Scrambler State Word is detected, the current scramble state is written into the 58-bit scramble state field in the Scrambler State Word and sent over the link. The receiver uses this scramble state to synchronize the descrambler. The seed is automatically set for Interlaken protocol.

**Figure 246. Synchronous Scrambler Showing Different Programmable Seeds**



### 5.2.1.7. Interlaken Disparity Generator

The Interlaken disparity generator block is in accordance with the Interlaken protocol specification and provides a DC-balanced data output.

The Interlaken protocol solves the unbounded baseline wander, or DC imbalance, of the 64B/66B coding scheme used in 10Gb Ethernet by inverting the transmitted data. The disparity generator monitors the transmitted data and makes sure that the running disparity always stays within a  $\pm 96$ -bit bound. It adds the 67th bit (bit 66) to signal the receiver whether the data is inverted or not.

**Table 258. Inversion Bit Definition**

| Bit 66 | Interpretation                                                                      |
|--------|-------------------------------------------------------------------------------------|
| 0      | Bits [63:0] are not inverted; the receiver processes this word without modification |
| 1      | Bits [63:0] are inverted; the receiver inverts the bits before processing this word |

**Note:** The Interlaken disparity generator is available to implement the Interlaken protocol.

### 5.2.1.8. TX Gearbox, TX Bitslip and Polarity Inversion

The TX gearbox adapts the PCS data width to the smaller bus width of the PCS-PMA interface (Gearbox Reduction). It supports different ratios (FPGA fabric-PCS Interface Width: PCS-PMA Interface Width) such as 66:32, 66:40, 64:32, 40:40, 32:32, 64:64, 67:64, and 66:64. The gearbox mux selects a group of consecutive bits from the input data bus depending on the gearbox ratio and the data valid control signals.

The TX gearbox also has a bit slipping feature to adjust the data skew between channels. The TX parallel data is slipped on the rising edge of tx\_enh\_bitslip before it is passed to the PMA. The maximum number of the supported bitslips is PCS data width-1 and the slip direction is from MSB to LSB and from current to previous word.

**Figure 247. TX Bitslip**

tx\_enh\_bitslip = 2 and PCS width of gearbox is 67

| Bit Index | Current Word |    |    |     |   |   |   | Previous Word |    |    |     |   |   |   |
|-----------|--------------|----|----|-----|---|---|---|---------------|----|----|-----|---|---|---|
|           | 66           | 65 | 64 | ... | 2 | 1 | 0 | 66            | 65 | 64 | ... | 2 | 1 | 0 |

You can use transmitter data polarity inversion to invert the polarity of every bit of the input data word to the serializer in the transmitter path. The inversion has the same effect as swapping the positive and negative signals of the differential TX buffer. This is useful if these signals are reversed on the board or backplane layout. Enable polarity inversion through the Native PHY IP Parameter Editor.

### 5.2.1.9. KR FEC Blocks

The KR FEC blocks in the Enhanced PCS are designed in accordance with the 10G-KRFEC and 40G-KRFEC of the IEEE 802.3 specification. The KR FEC implements the Forward Error Correction (FEC) sublayer, a sublayer between the PCS and PMA sublayers.

Most data transmission systems, such as Ethernet, have minimum requirements for the bit error rate (BER). However, due to channel distortion or noise in the channel, the required BER may not be achievable. In these cases, adding a forward error control correction can improve the BER performance of the system.

The FEC sublayer is optional and can be bypassed. When used, it can provide additional margin to allow for variations in manufacturing and environmental conditions. FEC can achieve the following objectives:

- Support a forward error correction mechanism for the 10GBASE-R/KR and 40GBASE-R/KR protocols.
- Support the full duplex mode of operation of the Ethernet MAC.
- Support the PCS, PMA, and Physical Medium Dependent (PMD) sublayers defined for the 10GBASE-R/KR and 40GBASE-R/KR protocols.
- Support up to the maximum transceiver data rate on any protocol that is 64/66-bit encoded.

With KR FEC, the BER performance of the system can be improved.

### Transcode Encoder

The KR forward error correction (KR FEC) transcode encoder block performs the 64B/66B to 65-bit transcoder function by generating the transcode bit. The transcode bit is generated from a combination of 66 bits after the 64B/66B encoder which consists of a 2-bit synchronization header (S0 and S1) and a 64-bit payload (D0, D1, ..., D63). To ensure a DC-balanced pattern, the transcode word is generated by performing an XOR function on the second synchronization bit S1 and payload bit D8. The transcode bit becomes the LSB of the 65-bit pattern output of the transcode encoder.

**Figure 248. Transcode Encoder**



### KR FEC Encoder

FEC (2112,2080) is an FEC code specified in Clause 74 of the IEEE 802.3 specification. The code is a shortened cyclic code (2112, 2080). For each block of 2080 message bits, another 32 parity checks are generated by the encoder to form a total of 2112 bits. The generator polynomial is:

$$g(x) = x^{32} + x^{23} + x^{21} + x^{11} + x^2 + 1$$

### KR FEC Scrambler

The KR FEC scrambler block performs scrambling based on the generation polynomial  $x^{58} + x^{39} + 1$ , which is necessary for establishing FEC block synchronization in the receiver and to ensure DC balance.

### KR FEC TX Gearbox

The KR FEC TX gearbox converts 65-bit input words to 64-bit output words to interface the KR FEC encoder with the PMA. This gearbox is different from the TX gearbox used in the Enhanced PCS. The KR FEC TX gearbox aligns with the FEC block. Because the encoder output (also the scrambler output) has its unique word size pattern, the gearbox is specially designed to handle that pattern.

## 5.2.2. Receiver Datapath

### 5.2.2.1. RX Gearbox, RX Bitslip, and Polarity Inversion

The RX gearbox adapts the PMA data width to the larger bus width of the PCS channel (Gearbox Expansion). It supports different ratios (PCS-PMA interface width : FPGA fabric-PCS interface width) such as 32:66, 40:66, 32:67, 32:64, 40:40, 32:32, 64:64, 67:64, and 66:64 and a bit slipping feature.

RX bitslip is engaged when the RX block synchronizer or `rx_bitslip` is enabled to shift the word boundary. On the rising edge of the bitslip signal of the RX block synchronizer or `rx_bitslip` from the FPGA fabric, the word boundary is shifted by one serial bit or 1UI. Each bit slip removes the earliest received bit from the received data.

**Figure 249. RX Bitslip**



The receiver gearbox can invert the polarity of the incoming data. This is useful if the receiver signals are reversed on the board or backplane layout. Enable polarity inversion through the Native PHY IP Parameter Editor.

Data valid generation logic is essential for gearbox operation. Each block of data is accompanied by `rx_enh_data_valid` data valid signal which “qualifies” the block as valid or not. The data valid toggling pattern is dependent on the data width conversion ratio. For example, if the ratio is 66:40, the data valid signal is high in 20 out of 33 cycles or approximately 2 out of 3 cycles and the pattern repeats every 33 `rx_clkout` RX low-speed parallel clock cycles.

**Note:** If a design is slipping more bits than the PCS/PMA width, the Enhanced RX PCS FIFO could overflow. To clear the overflow, assert `rx_digitalreset`.

### 5.2.2.2. Block Synchronizer

The block synchronizer determines the block boundary of a 66-bit word in the case of the 10GBASE-R protocol or a 67-bit word in the case of the Interlaken protocol. The incoming data stream is slipped one bit at a time until a valid synchronization header (bits 65 and 66) is detected in the received data stream. After the predefined number of synchronization headers (as required by the protocol specification) is detected, the block synchronizer asserts `rx_enh_blk_lock` (block lock status signal) to other receiver PCS blocks down the receiver datapath and to the FPGA fabric.

*Note:* The block synchronizer is designed in accordance with Interlaken Protocol specification (as described in Figure 13 of Interlaken Protocol Definition v1.2) and 10GBASE-R protocol specification (as described in IEEE 802.3-2008 clause-49).

### 5.2.2.3. Interlaken Disparity Checker

The Interlaken disparity checker examines the received inversion bit inserted by the far end disparity generator, to determine whether to reverse the inversion process of the Interlaken disparity generation.

*Note:* The Interlaken disparity checker is available to implement the Interlaken protocol.

### 5.2.2.4. Descrambler

The descrambler block descrambles received data to regenerate unscrambled data using the  $x^{58} + x^{39} + 1$  polynomial. Like the scrambler, it operates in asynchronous mode or synchronous mode.

#### Related Information

[Scrambler](#) on page 480

### 5.2.2.5. Interlaken Frame Synchronizer

The Interlaken frame synchronizer delineates the metaframe boundaries and searches for each of the framing layer control words: Synchronization, Scrambler State, Skip, and Diagnostic. When four consecutive synchronization words have been identified, the frame synchronizer achieves the frame locked state. Subsequent metaframes are then checked for valid synchronization and scrambler state words. If four consecutive invalid synchronization words or three consecutive mismatched scrambler state words are received, the frame synchronizer loses frame lock. In addition, the frame synchronizer provides `rx_enh_frame_lock` (receiver metaframe lock status) to the FPGA fabric.

*Note:* The Interlaken frame synchronizer is available to implement the Interlaken protocol.

### 5.2.2.6. 64B/66B Decoder and Receiver State Machine (RX SM)

The 64B/66B decoder reverses the 64B/66B encoding process. The decoder block also contains a state machine (RX SM) designed in accordance with the IEEE802.3-2008 specification. The RX SM checks for a valid packet structure in the data sent from the remote side. It also performs functions such as sending local faults to the Media Access Control (MAC)/Reconciliation Sublayer (RS) under reset and substituting error codes when the 10GBASE-R and 10GBASE-KR PCS rules are violated.

*Note:* The 64B/66B decoder is available to implement the 10GBASE-R protocol.

#### **5.2.2.6.1. PRBS Checker**

You can use Arria 10 pseudo-random bit stream (PRBS) checker to easily characterize high-speed links without developing or fully implementing any upper layer of a protocol stack. The PRBS checker in Arria 10 devices is a shared hardened block between the Standard and Enhanced datapaths. Hence, there is only one set of control signals and registers for this feature.

You can use the PRBS checker block to verify the pattern generated by the PRBS generator. The PRBS checker can be configured for two widths of the PCS-PMA interface: 10 bits and 64 bits. PRBS9 is available in both 10-bit and 64-bit PCS-PMA widths. All other PRBS patterns are available in 64-bit PCS-PMA width only. The PRBS checker patterns can only be used when the PCS-PMA interface width is configured to 10 bits or 64 bits.

The pseudo-random bit stream (PRBS) block verifies the pattern generated by the PRBS generator. The verifier supports the 64-bit PCS-PMA interface. PRBS7 supports 64-bit width only. PRBS9 supports 10-bit PMA data width to allow testing at a lower data rate.

**Table 259. Supported PRBS Patterns**

| <b>PRBS Pattern</b>           | <b>10 bit PCS-PMA width</b> | <b>64 bit PCS-PMA width</b> |
|-------------------------------|-----------------------------|-----------------------------|
| PRBS7: $x^7 + x^6 + 1$        |                             | Yes                         |
| PRBS9: $x^9 + x^5 + 1$        | Yes                         | Yes                         |
| PRBS15: $x^{15} + x^{14} + 1$ |                             | Yes                         |
| PRBS23: $x^{23} + x^{18} + 1$ |                             | Yes                         |
| PRBS31: $x^{31} + x^{28} + 1$ |                             | Yes                         |

**Figure 250. PRBS9 Verify Serial Implementation**



The PRBS checker has the following control and status signals available to the FPGA fabric:

- `rx_prbs_done`—Indicates the PRBS sequence has completed one full cycle. It stays high until you reset it with `rx_prbs_err_clr`.
- `rx_prbs_err`—Goes high if an error occurs. This signal is pulse-extended to allow you to capture it in the RX FPGA CLK domain.
- `rx_prbs_err_clr`—Used to reset the `rx_prbs_err` signal.

Enable the PRBS checker control and status ports through the Native PHY IP Parameter Editor in the Quartus Prime software.

### 5.2.2.7. Pseudo Random Pattern Verifier

The Pseudo Random Pattern (PRP) verifier is available for 10GBASE-R and 10GBASE-R 1588 protocol modes. The PRP verifier block operates in conjunction with the descrambler. The PRP verifier monitors the output of the descrambler when block synchronization is achieved.

The `rx_prbs_err` error signal is shared between the PRBS checker and the PRP verifier.

The PRP verifier:

- Searches for a test pattern (two local faults, or all 0s) or its inverse
- Tracks the number of mismatches with a 16-bit error counter

**Figure 251. PRP Verifier**



Refer to the *Reconfiguration Interface and Dynamic Reconfiguration* chapter for configuration details.

#### Related Information

[Reconfiguration Interface and Dynamic Reconfiguration on page 514](#)

### 5.2.2.8. 10GBASE-R Bit-Error Rate (BER) Checker

The 10GBASE-R BER checker block is designed in accordance with the 10GBASE-R protocol specification as described in IEEE 802.3-2008 clause-49. After block lock synchronization is achieved, the BER checker starts to count the number of invalid synchronization headers within a 125- $\mu$ s period. If more than 16 invalid synchronization headers are observed in a 125- $\mu$ s period, the BER checker provides the status signal `rx_enh_highber` to the FPGA fabric, indicating a high bit error rate condition.

When the optional control input `rx_enh_highber_clr_cnt` is asserted, the internal counter for the number of times the BER state machine has entered the "BER\_BAD\_SH" state is cleared.

When the optional control input `rx_enh_clr_errblk_count` is asserted, the internal counter for the number of times the RX state machine has entered the "RX\_E" state for the 10GBASE-R protocol is cleared. In modes where the FEC block is enabled, the assertion of this signal resets the status counters within the RX FEC block.

*Note:* The 10GBASE-R BER checker is available to implement the 10GBASE-R protocol.

### 5.2.2.9. Interlaken CRC-32 Checker

The Interlaken CRC-32 checker verifies that the data transmitted has not been corrupted between the transmit PCS and the receive PCS. The CRC-32 checker calculates the 32-bit CRC for the received data and compares it against the CRC value that is transmitted within the diagnostic word. `rx_enh_crc32_err` (CRC error signal) is sent to the FPGA fabric.

### 5.2.2.10. Enhanced PCS RX FIFO

The Enhanced PCS RX FIFO is designed to compensate for the phase, clock, or phase and clock difference between the receiver channel PCS and the FPGA fabric. It can operate as a phase-compensation, clock-compensation, elastic buffer, or a deskew FIFO in Interlaken mode. The RX FIFO has a width of 74 bits and a depth of 32 words for all protocols.

The RX FIFO supports the following modes:

- Phase Compensation mode
- Register mode
- Interlaken mode (deskew FIFO)
- 10GBASE-R mode (clock compensation FIFO)
- Basic mode (elastic buffer FIFO)

#### 5.2.2.10.1. Phase Compensation Mode

The RX FIFO compensates for the phase difference between the read clock and write clocks. `rx_clkout` (RX parallel low-speed clock) clocks the write side of the RX FIFO. `rx_coreclkin` (FPGA fabric clock) or `rx_clkout` clocks the read side of the RX FIFO.

When phase compensation is used in double-width mode, the FPGA data width is doubled to allow the FPGA fabric clock to run at half rate, similar to the TX FIFO phase compensation in double-width mode.

Depth of RX FIFO is constant in this mode, therefore RX FIFO flag status can be ignored. You can tie `tx_enh_data_valid` with one.

#### 5.2.2.10.2. Register Mode

The Register Mode bypasses the FIFO functionality to eliminate the FIFO latency uncertainty for applications with stringent latency requirements. This is accomplished by tying the read clock of the FIFO with its write clock.

In Register mode, `rx_parallel_data` (data), `rx_control` indicates whether `rx_parallel_data` is a data or control word, and `rx_enh_data_valid` (data valid) are registered at the FIFO output. The RX FIFO in register mode has one register stage or one parallel clock latency.

**Note:** Intel recommends that you implement a soft FIFO in the FPGA fabric with minimum of 32 words under the following conditions:

- When the Enhanced PCS RX FIFO is set to register mode.
- When using the recovered clock to drive the core logics.
- When there is no soft FIFO being generated along with the IP Catalog.

#### 5.2.2.10.3. Interlaken Mode

In Interlaken mode, the RX FIFO operates as an Interlaken deskew FIFO. To implement the deskew process, implement an FSM that controls the FIFO operation based on available FPGA input and output flags.

For example, after frame lock is achieved, data is written after the first alignment word (SYNC word) is found on that channel. As a result, `rx_enh_fifo_pempty` (FIFO partially empty flag) of that channel goes low. You must monitor the `rx_enh_fifo_pempty` and `rx_enh_fifo_pfull` flags of all channels. If `rx_enh_fifo_pempty` flags from all channels deassert before any `rx_enh_fifo_pfull` flag asserts, which implies alignment word has been found on all lanes of the link, you start reading from all the FIFOs by asserting `rx_enh_fifo_rd_en`. Otherwise, if a `rx_enh_fifo_pfull` flag from any channel goes high before a `rx_enh_fifo_pempty` flag deassertion on all channels, you must reset the FIFO by toggling the `rx_enh_fifo_align_clr` signal and repeating the process.

**Figure 252. RX FIFO as Interlaken Deskew FIFO**

#### 5.2.2.10.4. 10GBASE-R Mode

In 10GBASE-R mode, the RX FIFO operates as a clock compensation FIFO. When the block synchronizer achieves block lock, data is sent through the FIFO. Idle ordered sets (OS) are deleted and Idles are inserted to compensate for the clock difference between the RX low speed parallel clock and the FPGA fabric clock ( $\pm 100$  ppm for a maximum packet length of 64,000 bytes).

##### Idle OS Deletion

Deletion of Idles occurs in groups of four OS (when there are two consecutive OS) until the `rx_enh_fifo_pfull` flag deasserts. Every word—consisting of a lower word (LW) and an upper word (UW)—is checked for whether it can be deleted by looking at both the current and previous words.

For example, the current LW can be deleted if it is Idle and the previous UW is not a Terminate.

**Table 260. Conditions Under Which a Word Can be Deleted**

In this table X=don't care, T=Terminate, I=Idle, and OS=order set.

| Deletable  | Case | Word | Previous | Current | Output |    |
|------------|------|------|----------|---------|--------|----|
| Lower Word | 1    | UW   | !T       | X       | !T     | X  |
|            |      | LW   | X        | I       | X      | X  |
|            | 2    | UW   | OS       | X       | OS     | X  |
|            |      | LW   | X        | OS      | X      | X  |
| Upper Word | 1    | UW   | X        | I       | X      | X  |
|            |      | LW   | X        | !T      | X      | !T |
|            | 2    | UW   | X        | OS      | X      | X  |
|            |      | LW   | X        | OS      | X      | OS |

If only one word is deleted, data shifting is necessary because the datapath is two words wide. After two words have been deleted, the FIFO stops writing for one cycle and a synchronous flag (`rx_control[8]`) appears on the next block of 8-byte data. There is also an asynchronous status signal `rx_enh_fifo_del`, which does not go through the FIFO.

**Figure 253. IDLE Word Deletion**

This figure shows the deletion of IDLE words from the receiver data stream.


**Figure 254. OS Word Deletion**

This figure shows the deletion of Ordered set words in the receiver data stream.



### Idle Insertion

Idle insertion occurs in groups of 8 Idles when the `rx_enh_fifo_pempty` flag is deasserted. Idles can be inserted following Idles or OS. Idles are inserted in groups of 8 bytes. Data shifting is not necessary. There is a synchronous status `rx_enh_fifo_insert` signal that is attached to the 8-byte Idles being inserted.

**Table 261. Cases Where Two Idle Words are Inserted**

In this table X=don't care, S=start, OS=order set, I-DS=idle in data stream, and I-In=idle inserted. In cases 3 and 4, the Idles are inserted between the LW and UW.

| Case | Word | Input | Output |      |
|------|------|-------|--------|------|
| 1    | UW   | I-DS  | I-DS   | I-In |
|      | LW   | X     | X      | I-In |
| 2    | UW   | OS    | OS     | I-In |
|      | LW   | X     | X      | I-In |
| 3    | UW   | S     | I-In   | S    |
|      | LW   | I-DS  | I-DS   | I-In |
| 4    | UW   | S     | I-In   | S    |
|      | LW   | OS    | OS     | I-In |

**Figure 255. IDLE Word Insertion**

This figure shows the insertion of IDLE words in the receiver data stream.



### 5.2.2.10.5. Basic Mode

In Basic mode, the RX FIFO operates as an elastic buffer, where buffer depths can vary. This mode allows driving write and read side of RX FIFO with different clock frequencies. Monitor the FIFO flag to control write and read operations. For RX FIFO, assert `rx_enh_read_en` signal with `rx_fifo_pfull` signal going low.

### 5.2.2.11. RX KR FEC Blocks

#### KR FEC Block Synchronization

You can obtain FEC block delineation for the RX KR FEC by locking onto correctly received FEC blocks with the KR FEC block synchronization. You can also use the KR FEC up to the maximum transceiver data rate on any protocol that is 64/66-bit encoded.

**Note:** The KR FEC block synchronization is available to implement the 10GBASE-KR protocol.

#### KR FEC Descrambler

The KR FEC descrambler block descrambles received data to regenerate unscrambled data using the  $x^{58} + x^{39} + 1$  polynomial. Before the block boundary in the KR FEC sync block is detected, the data at the input of the descrambler is sent directly to the KR FEC decoder. When the boundary is detected, the aligned word from the KR FEC sync block is descrambled with the Pseudo Noise (PN) sequence and then sent to the KR FEC decoder.

#### KR FEC Decoder

The KR FEC decoder block performs the FEC (2112, 2080) decoding function by analyzing the received 32 65-bit blocks for errors. It can correct burst errors of 11 bits or less per FEC block.

#### KR FEC RX Gearbox

The KR FEC RX gearbox block adapts the PMA data width to the larger bus width of the PCS channel. It supports a 64:65 ratio.

#### Transcode Decoder

The transcode decoder block performs the 65-bit to 64B/66B reconstruction function by regenerating the 64B/66B synchronization header.

## 5.3. Arria 10 Standard PCS Architecture

The standard PCS can operate at a data rate of up to 10.8 Gbps. Protocols such as PCI Express, CPRI 4.2+, GigE, IEEE 1588 are supported in Hard PCS while the other protocols can be implemented using Basic/Custom (Standard PCS) transceiver configuration rules.

**Figure 256. Standard PCS Datapath Diagram**


### 5.3.1. Transmitter Datapath

#### 5.3.1.1. TX FIFO (Shared with Enhanced PCS and PCIe Gen3 PCS)

The TX FIFO interfaces between the transmitter PCS and the FPGA fabric and ensures reliable transfer of data and status signals. It compensates for the phase difference between the FPGA fabric clock and tx\_clkout (the low-speed parallel clock). The TX FIFO has a depth of 8 and operates in low latency mode, register mode, and fast register mode.

**Figure 257. TX FIFO Block Diagram**


You can control the write port using tx\_clkout or tx\_coreclk. Use the tx\_clkout signal for a single channel and tx\_coreclk when using multiple channels. The TX FIFO is shared with PCIe Gen3 and Enhanced PCS data paths.

### 5.3.1.1.1. TX FIFO Low Latency Mode

The low latency mode incurs two to three cycles of latency (latency uncertainty) when connecting it with the FPGA fabric. The FIFO empty and the FIFO full threshold values are made closer so that the depth of the FIFO decreases, which in turn decreases the latency.

### 5.3.1.1.2. TX FIFO Register Mode

The register mode bypasses the FIFO functionality to eliminate the FIFO latency uncertainty for applications with stringent latency requirements. This is accomplished by tying the read clock of the FIFO with its write clock. The register mode incurs only one clock cycle of latency when interfacing to the FPGA fabric.

### 5.3.1.1.3. TX FIFO Fast Register Mode

This mode allows a higher maximum frequency ( $f_{MAX}$ ) between the FPGA fabric and the TX PCS by enabling the optional fast register interface with additional latency.

## 5.3.1.2. Byte Serializer

In certain applications, the FPGA fabric cannot operate at the same clock rate as the transmitter channel (PCS) because the transmitter channel is capable of operating at higher clock rates compared to the FPGA fabric. The byte serializer allows the transmitter channel to operate at higher data rates while keeping the FPGA fabric interface clock rate below its maximum limit. This is accomplished by increasing the channel width two or four times (FPGA fabric-to-PCS interface width) and dividing the clock (tx\_clkout) rate by 2 or 4. The byte serializer can be disabled, or operate in Serialize x2 or Serialize x4 modes.

**Figure 258. Byte Serializer Block Diagram**



### Related Information

- [Resetting Transceiver Channels](#) on page 428
- [Implementing Protocols in Arria 10 Transceivers](#) on page 32

### 5.3.1.2.1. Bonded Byte Serializer

The bonded byte serializer is available in Arria 10 devices, and is used in applications such as PIPE, CPRI, and custom applications where multiple channels are grouped together. The bonded byte serializer is implemented by bonding all the control signals to prevent skew induction between channels during byte serialization. In this configuration, one of the channels acts as master and the remaining channels act as slaves.

### 5.3.1.2.2. Byte Serializer Disabled Mode

In disabled mode, the byte serializer is bypassed. The data from the TX FIFO is directly transmitted to the 8B/10B encoder, TX Bitslip, or Serializer, depending on whether or not the 8B/10B encoder and TX Bitslip are enabled. Disabled mode is used in low speed applications such as GigE, where the FPGA fabric and the TX standard PCS can operate at the same clock rate.

### 5.3.1.2.3. Byte Serializer Serialize x2 Mode

The serialize x2 mode is used in high-speed applications such as the PCIe Gen1 or Gen2 protocol implementation, where the FPGA fabric cannot operate as fast as the TX PCS.

In serialize x2 mode, the byte serializer serializes 16-bit, 20-bit (when 8B/10B encoder is not enabled), 32-bit, and 40-bit (when 8B/10B encoder is not enabled) input data into 8-bit, 10-bit, 16-bit, and 20-bit data, respectively. As the parallel data width from the TX FIFO is halved, the clock rate is doubled.

After byte serialization, the byte serializer forwards the least significant word first followed by the most significant word. For example, if the FPGA fabric-to-PCS Interface width is 32, the byte serializer forwards `tx_parallel_data[15:0]` first, followed by `tx_parallel_data[31:16]`.

#### Related Information

[PCI Express \(PIPE\)](#) on page 236

For more information about using the Serialize x2 mode in the PCIe protocol.

### 5.3.1.2.4. Byte Serializer Serialize x4 Mode

The serialize x4 mode is used in high-speed applications such as the PCIe Gen3 protocol mode, where the FPGA fabric cannot operate as fast as the TX PCS.

In serialize x4 mode, the byte serializer serializes 32-bit data into 8-bit data. As the parallel data width from the TX FIFO is divided four times, the clock rate is quadrupled.

After byte serialization, the byte serializer forwards the least significant word first followed by the most significant word. For example, if the FPGA fabric-to-PCS Interface width is 32, the byte serializer forwards `tx_parallel_data[7:0]` first, followed by `tx_parallel_data[15:8]`, `tx_parallel_data[23:16]` and `tx_parallel_data[31:24]`.

#### Related Information

[PCI Express \(PIPE\)](#) on page 236

For more information about using the Serialize x4 mode in the PCIe protocol.

### 5.3.1.3. 8B/10B Encoder

The 8B/10B encoder takes in 8-bit data and 1-bit control as input and converts them into a 10-bit output. The 8B/10B encoder automatically performs running disparity check for the 10-bit output. Additionally, the 8B/10B encoder can control the running disparity manually using the `tx_forcedisp` and `tx_dispval` ports.

**Figure 259. 8B/10B Encoder Block Diagrams**

When the PCS-PMA interface width is 10 bits, one 8B/10B encoder is used to convert the 8-bit data into a 10-bit output. When the PCS-PMA interface width is 20 bits, two cascaded 8B/10B encoders are used to convert the 16-bit data into a 20-bit output. The first eight bits (LSByte) is encoded by the first 8B/10B encoder and the next eight bits (MSByte) is encoded by the second 8B/10B encoder. The running disparity of the LSByte is calculated first and passed on to the second encoder to calculate the running disparity of the MSByte.

**Note:** You cannot enable the 8B/10B encoder when the PCS-PMA interface width is 8 bits or 16 bits.

### 5.3.1.3.1. 8B/10B Encoder Control Code Encoding

**Figure 260. Control Code Encoding Diagram**

The tx\_datak signal indicates whether the 8-bit data being sent at the tx\_parallel\_data port should be a control word or a data word. When tx\_datak is high, the 8-bit data is encoded as a control word (Kx.y). When tx\_datak is low, the 8-bit data is encoded as a data word (Dx.y). Depending upon the PCS-PMA interface width, the width of tx\_datak is either 1 bit or 2 bits. When the PCS-PMA interface width is 10 bits, tx\_datak is a 1-bit word. When the PCS-PMA interface width is 20 bits, tx\_datak is a 2-bit word. The LSB of tx\_datak corresponds to the LSByte of the input data sent to the 8B/10B encoder and the MSB corresponds to the MSByte of the input data sent to the 8B/10B encoder.

### Related Information

Refer to *Specifications & Additional Information* for more information about 8B/10B encoder codes.

#### 5.3.1.3.2. 8B/10B Encoder Reset Condition

The tx\_digitalreset signal resets the 8B/10B encoder. During the reset condition, the 8B/10B encoder outputs K28.5 continuously until tx\_digitalreset goes low.

#### 5.3.1.3.3. 8B/10B Encoder Idle Character Replacement Feature

The idle character replacement feature is used in protocols such as Gigabit Ethernet, which requires the running disparity to be maintained during idle sequences. During these idle sequences, the running disparity has to be maintained such that the first byte of the next packet always starts when the running disparity of the current packet is negative.

When an ordered set, which consists of two code-groups, is received by the 8B/10B encoder, the second code group is converted into /I1/ or /I2/ so that the final running disparity of the data code-group is negative. The first code group is /K28.5/ and the second code group is a data code-group other than /D21.5/ or /D2.2/. The ordered set /I1/ (/K28.5/D5.6/) is used to flip the running disparity and /I2/ (/K28.5/D16.2/) is used to preserve the running disparity.

#### 5.3.1.3.4. 8B/10B Encoder Current Running Disparity Control Feature

The 8B/10B encoder performs a running disparity check on the 10-bit output data. The running disparity can also be controlled using tx\_forcedisp and tx\_dispval. When the PCS-PMA interface width is 10 bits, tx\_forcedisp and tx\_dispval are one bit each. When the PCS-PMA interface width is 20 bits, tx\_forcedisp and tx\_dispval are two bits each. The LSB of tx\_forcedisp and tx\_dispval corresponds to the LSByte of the input data and the MSB corresponds to the MSByte of the input data.

#### 5.3.1.3.5. 8B/10B Encoder Bit Reversal Feature

**Figure 261. 8B/10B Encoder Bit Reversal Feature**



The bit reversal feature reverses the order of the bits of the input data. Bit reversal is performed at the output of the 8B/10B Encoder and is available even when the 8B/10B Encoder is disabled. For example, if the input data is 20-bits wide, bit reversal switches bit [0] with bit [19], bit [1] with bit [18] and so on.

### 5.3.1.3.6. 8B/10B Encoder Byte Reversal Feature

Figure 262. 8B/10B Encoder Byte Reversal Feature



The byte reversal feature is available only when the PCS-PMA interface width is 16 bits or 20 bits. Byte reversal is performed at the output of the 8B/10B Encoder and is available even when the 8B/10B Encoder is disabled. This feature swaps the LSByte with the MSByte. For example, when the PCS-PMA interface width is 16-bits, [7:0] bits (LSByte) gets swapped with [15:8] bits (MSByte).

### 5.3.1.4. Polarity Inversion Feature

The polarity inversion feature is used in situations where the positive and the negative signals of a serial differential link are erroneously swapped during board layout. You can control this feature through `tx_polinv` port, by enabling the **Enable TX Polarity Inversion** option under the Standard PCS tab of the Native PHY IP Core. The polarity inversion feature inverts the value of each bit of the input data. For example, if the input data is 00101001, then the data gets changed to 11010110 after polarity inversion.

### 5.3.1.5. Pseudo-Random Binary Sequence (PRBS) Generator

**Note:** Refer to the PRBS Generator section in the Enhanced PCS Architecture chapter.

#### Related Information

[Arria 10 Enhanced PCS Architecture](#) on page 473

### 5.3.1.6. TX Bit Slip

The TX bit slip allows the word boundary to be controlled by `tx_std_bitslipboundarysel`. The TX bit slip feature is used in applications, such as CPRI, which has a data rate greater than 6 Gbps. The maximum number of the supported bit slips is PCS data width-1 and the slip direction is from MSB to LSB and from current to previous word.

## 5.3.2. Receiver Datapath

### 5.3.2.1. Word Aligner

The word aligner receives the serial data from the PMA and realigns the serial data to have the correct word boundary according to the word alignment pattern configured. This word alignment pattern can be 7, 8, 10, 16, 20, 32 and 40 bits in length.

Depending on your PCS-PMA interface width, the word aligner can be configured in one of the following modes:

- Bit slip
- Manual alignment
- Synchronous state machine
- Deterministic latency

**Figure 263. Word Aligner Conditions and Modes**



### 5.3.2.1.1. Word Aligner Bit Slip Mode

In bit slip mode, the word aligner operation is controlled by `rx_bitslip`, which has to be held for two parallel clock cycles. At every rising edge of `rx_bitslip`, the bit slip circuitry slips one bit into the received data stream, effectively shifting the word boundary by one bit. Pattern detection is not used in bit slipping mode; therefore, `rx_syncstatus` is not valid in this mode.

### 5.3.2.1.2. Word Aligner Manual Mode

In manual alignment mode, the word aligner operation is controlled by `rx_std_wa_patternalign`. The word aligner operation is edge-sensitive or level-sensitive to `rx_std_wa_patternalign`, depending upon the PCS-PMA interface width selected.

**Table 262. Word Aligner `rx_std_wa_patternalign` Behavior**

| PCS-PMA Interface Width | <code>rx_std_wa_patternalign</code> Behavior |
|-------------------------|----------------------------------------------|
| 8                       | Rising edge sensitive                        |
| 10                      | Level sensitive                              |
| 16                      | Rising edge sensitive                        |
| 20                      | Rising edge sensitive                        |

If `rx_std_wa_patternalign` is asserted, the word aligner looks for the programmed word alignment pattern in the received data stream. It updates the word boundary if it finds the word alignment pattern in a new word boundary. If `rx_std_wa_patternalign` is deasserted, the word aligner maintains the current word boundary even when it sees the word alignment pattern in a new word boundary.

The `rx_syncstatus` and `rx_patterndetect` signals, with the same latency as the datapath, are forwarded to the FPGA fabric to indicate the word aligner status.

After receiving the first word alignment pattern after `rx_std_wa_patternalign` is asserted, both `rx_syncstatus` and `rx_patterndetect` are driven high for one parallel clock cycle. Any word alignment pattern received thereafter in the same word boundary causes only `rx_patterndetect` to go high for one clock cycle. Any word alignment pattern received thereafter in a different word boundary causes the word aligner to re-align to the new word boundary only if `rx_std_wa_patternalign` is asserted. The word aligner asserts `rx_syncstatus` for one parallel clock cycle whenever it re-aligns to the new word boundary.

#### 5.3.2.1.3. Word Aligner Synchronous State Machine Mode

In synchronous state machine mode, when the programmed number of valid synchronization code groups or ordered sets is received, `rx_syncstatus` is driven high to indicate that synchronization is acquired. The `rx_syncstatus` signal is constantly driven high until the programmed number of erroneous code groups is received without receiving intermediate good groups, after which `rx_syncstatus` is driven low.

The word aligner indicates loss of synchronization (`rx_syncstatus` remains low) until the programmed number of valid synchronization code groups are received again.

#### 5.3.2.1.4. Word Aligner Deterministic Latency Mode

In deterministic latency mode, the state machine removes the bit level latency uncertainty. The deserializer of the PMA creates the bit level latency uncertainty as it comes out of reset.

The PCS performs pattern detection on the incoming data from the PMA. The PCS aligns the data, after it indicates to the PMA the number of serial bits to clock slip the boundary.

If the incoming data has to be realigned, `rx_std_wa_patternalign` must be reasserted to initiate another pattern alignment. Asserting `rx_std_wa_patternalign` can cause the word align to lose synchronization if already achieved. This may cause `rx_syncstatus` to go low.

**Table 263. PCS-PMA Interface Widths and Protocol Implementations**

| PCS-PMA Interface Width | Protocol Implementations                                                                                                                      |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 8                       | Basic                                                                                                                                         |
| 10                      | <ul style="list-style-type: none"><li>• Basic</li><li>• Basic rate match</li><li>• CPRI</li><li>• PCIe Gen1 and Gen2</li><li>• GigE</li></ul> |
| 16                      | Basic                                                                                                                                         |
| 20                      | <ul style="list-style-type: none"><li>• CPRI</li><li>• Basic</li><li>• Basic rate match</li></ul>                                             |

### 5.3.2.1.5. Word Aligner Pattern Length for Various Word Aligner Modes

**Table 264. Word Aligner Pattern Length for Various Word Aligner Modes**

| PCS-PMA Interface Width | Supported Word Aligner Modes           | Supported Word Aligner Pattern Lengths | rx_std_wa_patternalign behavior                                                                                                                                                                                             | rx_syncstatus behavior                                                                     | rx_patterndetect behavior                                                                                        |
|-------------------------|----------------------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| 8                       | Bit slip                               | 8                                      | rx_std_wa_patternalign has no effect on word alignment. The single width word aligner updates the word boundary, only when the FPGA fabric asserted BITSLIP signal toggles.                                                 | N/A                                                                                        | N/A                                                                                                              |
|                         | Manual                                 | 8, 16                                  | Word alignment is controlled by rx_std_wa_patternalign and is edge-sensitive to this signal.                                                                                                                                | Asserted high for one parallel clock cycle when the word aligner aligns to a new boundary. | Asserted high for one parallel clock cycle when the word alignment pattern appears in the current word boundary. |
| 10                      | Bit slip                               | 7                                      | rx_std_wa_patternalign has no effect on word alignment. The single width word aligner updates the word boundary, only when the FPGA fabric asserted BITSLIP signal toggles.                                                 | N/A                                                                                        | N/A                                                                                                              |
|                         | Manual                                 | 7, 10                                  | Word alignment is controlled by rx_std_wa_patternalign and is level-sensitive to this signal.                                                                                                                               | Asserted high for one parallel clock cycle when the word aligner aligns to a new boundary. | Asserted high for one parallel clock cycle when the word alignment pattern appears in the current word boundary. |
|                         | Deterministic latency (CPRI mode only) | 10                                     | Word alignment is controlled by rx_std_wa_patternalign (edge-sensitive to this signal) and the state machine works in conjunction with PMA to achieve deterministic latency on the RX path for CPRI and OBSAI applications. | —                                                                                          | —                                                                                                                |
|                         | Synchronous State Machine              | 7, 10                                  | rx_std_wa_patternalign has no effect on word alignment.                                                                                                                                                                     | Stays high as long as the synchronization conditions are satisfied.                        | Asserted high for one parallel clock cycle when the word alignment pattern                                       |

*continued...*

| <b>PCS-PMA Interface Width</b> | <b>Supported Word Aligner Modes</b>    | <b>Supported Word Aligner Pattern Lengths</b> | <b><code>rx_std_wa_paternalign</code> behavior</b>                                                                                                                                      | <b><code>rx_syncstatus</code> behavior</b>                                                                                                                                                        | <b><code>rx_patterndetect</code> behavior</b>                                                                    |
|--------------------------------|----------------------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
|                                |                                        |                                               |                                                                                                                                                                                         |                                                                                                                                                                                                   | appears in the current word boundary.                                                                            |
| 16                             | Bit slip                               | 16                                            | <code>rx_std_wa_paternalign</code> has no effect on word alignment. The double width word aligner updates the word boundary, only when the FPGA fabric-asserted BITSLIP signal toggles. | N/A                                                                                                                                                                                               | N/A                                                                                                              |
|                                | Manual                                 | 8, 16, 32                                     | Word alignment is controlled by rising-edge of <code>rx_std_wa_paternalign</code> .                                                                                                     | Stays high after the word aligner aligns to the word alignment pattern. Goes low on receiving a rising edge on <code>rx_std_wa_paternalign</code> until a new word alignment pattern is received. | Asserted high for one parallel clock cycle when the word alignment pattern appears in the current word boundary. |
| 20                             | Bit slip                               | 7                                             | <code>rx_std_wa_paternalign</code> has no effect on word alignment. The double width word aligner updates the word boundary, only when the FPGA fabric-asserted BITSLIP signal toggles. | N/A                                                                                                                                                                                               | N/A                                                                                                              |
|                                | Manual                                 | 7, 10, 20, 40                                 | Word alignment is controlled by rising edge of <code>rx_std_wa_paternalign</code> .                                                                                                     | Stays high after the word aligner aligns to the word alignment pattern. Goes low on receiving a rising edge on <code>rx_std_wa_paternalign</code> until a new word alignment pattern is received. | Asserted high for one parallel clock cycle when the word alignment pattern appears in the current word boundary. |
|                                | Deterministic latency (CPRI mode only) | 10                                            | Word alignment is controlled by <code>rx_std_wa_paternalign</code> (edge-sensitive to this signal) and the deterministic latency state machine which controls the PMA to                | —                                                                                                                                                                                                 | —                                                                                                                |

*continued...*

| <b>PCS-PMA Interface Width</b> | <b>Supported Word Aligner Modes</b> | <b>Supported Word Aligner Pattern Lengths</b> | <b>rx_std_wa_patterncalign behavior</b>                                            | <b>rx_syncstatus_behavior</b>                                       | <b>rx_patterndetect behavior</b>                                                                                 |
|--------------------------------|-------------------------------------|-----------------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
|                                | Synchronous State Machine           | 7, 10, 20                                     | achieve deterministic latency on the RX path for CPRI and OBSAI applications.      |                                                                     |                                                                                                                  |
|                                |                                     |                                               | FPGA fabric-driven rx_std_wa_patterncalign signal has no effect on word alignment. | Stays high as long as the synchronization conditions are satisfied. | Asserted high for one parallel clock cycle when the word alignment pattern appears in the current word boundary. |

### 5.3.2.1.6. Word Aligner RX Bit Reversal Feature

The RX bit reversal feature reverses the order of the data received from the PMA. It is performed at the output of the Word Aligner and is available even when the Word Aligner is disabled. If the data received from the PMA is a 10-bit data width, the bit reversal feature switches bit [0] with bit [9], bit [1] with bit [8], and so on. For example, if the 10-bit data is 1000010011, the bit reversal feature, when enabled, changes the data to 1100100001.

### 5.3.2.1.7. Word Aligner RX Byte Reversal Feature

The RX byte reversal feature is available only when the PCS-PMA interface width is 16 bits or 20 bits. This feature reverses the order of the data received from the PMA. RX byte reversal reverses the LSByte of the received data with its MSByte and vice versa. If the data received is 20-bits, bits[0..9] are swapped with bits[10..20] so that the resulting 20-bit data is [[10..20],[0..9]]. For example, if the 20-bit data is 11001100001000011111, the byte reversal feature changes the data to 1000011111100110000.

### 5.3.2.2. RX Polarity Inversion Feature

The RX polarity inversion feature inverts each bit of the data received from the PMA. If the data received is a 10-bit data. Bit[0] content is inverted to its complement, ~bit[0], bit[1] is inverted to its complement, ~bit[1], bit[2] is inverted to its complement, ~bit[2], and so on. For example, if the 10-bit data is 1111100000, the polarity inversion feature inverts it to 0000011111.

### 5.3.2.3. Rate Match FIFO

The rate match FIFO compensates for the frequency differences between the local clock and the recovered clock up to  $\pm 300$  ppm by inserting and deleting skip/idle characters in the data stream. The rate match FIFO has several different protocol specific modes of operation. All of the protocol specific modes depend upon the following parameters:

- Rate match deletion—occurs when the distance between the write and read pointers exceeds a certain value due to write clock having a higher frequency than the read clock.
- Rate match insertion—occurs when the distance between the write and the read pointers becomes less than a certain value due to the read clock having a higher frequency than the write clock.
- Rate match full—occurs when the write pointer wraps around and catches up to the slower-advancing read pointer.
- Rate match empty—occurs when the read pointer catches up to the slower-advancing write pointer.

Rate match FIFO operates in six modes:

- Basic single width
- Basic double width
- GigE
- PIPE
- PIPE 0 ppm
- PCIe

#### Related Information

- [Rate Match FIFO in Basic \(Single Width\) Mode](#) on page 313  
For more information about implementing rate match FIFO in basic single width mode.
- [Rate Match FIFO Basic \(Double Width\) Mode](#) on page 315  
For more information about implementing rate match FIFO in basic double width mode.
- [How to Implement GbE, GbE with IEEE 1588v2 in Arria 10 Transceivers](#) on page 118  
For more information about implementing rate match FIFO in GigE mode.
- [PCI Express \(PIPE\)](#) on page 236  
For more information about implementing rate match FIFO in PCIe mode.
- [How to Implement PCI Express \(PIPE\) in Arria 10 Transceivers](#) on page 253  
For more information about implementing rate match FIFO in PIPE mode.
- [Using the Basic/Custom, Basic/Custom with Rate Match Configurations of Standard PCS](#) on page 307
- [How to Implement the Basic Rate Match Protocol Using the Arria 10 Transceiver Native PHY IP Core](#) on page 307  
For more information about implementing rate match FIFO for each mode.

### 5.3.2.4. 8B/10B Decoder

The general functionality for the 8B/10B decoder is to take a 10-bit encoded value as input and produce an 8-bit data value and a 1-bit control value as output. In configurations with the rate match FIFO enabled, the 8B/10B decoder receives data from the rate match FIFO. In configurations with the rate match FIFO disabled, the 8B/10B decoder receives data from the word aligner. The 8B/10B decoder operates in two conditions:

- When the PCS-PMA interface width is 10 bits and FPGA fabric-PCS interface width is 8 bits
- When the PCS-PMA interface width is 20 bits and FPGA fabric-PCS interface width is 16 bits

**Figure 264. 8B/10B Decoder in Single-Width and Double-Width Mode**



When the PCS-PMA interface width is 10 bits, only one 8B/10B decoder is used to perform the conversion. When the PCS-PMA interface width is 20 bits, two cascaded 8B/10B decoders are used. The 10-bit LSByte of the received 20-bit encoded data is decoded first and the ending running disparity is forwarded to the 8B/10B decoder responsible for decoding the 10-bit MSByte. The cascaded 8B/10B decoder decodes the 20-bit encoded data into 16-bit data + 2-bit control identifier. The MSB and LSB of the 2-bit control identifier correspond to the MSByte and LSByte of the 16-bit decoded data code group. The decoded data is fed to the byte deserializer or the RX FIFO.

### 5.3.2.4.1. 8B/10B Decoder Control Code Encoding

**Figure 265. 8B/10B Decoder in Control Code Group Detection**



The 8B/10B decoder indicates whether the decoded 8-bit code group is a data or control code group on `rx_dataak`. If the received 10-bit code group is one of the 12 control code groups ( $/Kx.y/$ ) specified in the IEEE 802.3 specification, `rx_dataak` is driven high. If the received 10-bit code group is a data code group ( $/Dx.y/$ ), `rx_dataak` is driven low.

### 5.3.2.4.2. 8B/10B Decoder Running Disparity Checker Feature

Running disparity checker resides in 8B/10B decoder module. This checker checks the current running disparity value and error based on the rate match output. `rx_runningdisp` and `rx_dispperr` indicate positive or negative disparity and disparity errors, respectively.

### 5.3.2.5. Pseudo-Random Binary Sequence (PRBS) Checker

**Note:** Refer to the PRBS Checker section in the Enhanced PCS Architecture chapter.

#### Related Information

[Arria 10 Enhanced PCS Architecture](#) on page 473

### 5.3.2.6. Byte Deserializer

The byte deserializer allows the transceiver to operate at data rates higher than those supported by the FPGA fabric. It deserializes the recovered data by multiplying the data width two or four times, depending upon the deserialization mode selected. The byte deserializer is optional in designs that do not exceed the FPGA fabric interface frequency upper limit. You can bypass the byte deserializer by disabling it in the Quartus Prime Transceiver Native PHY. The byte deserializer operates in disabled, deserialize x2, or deserialize x4 modes.

**Figure 266. Byte Deserializer Block Diagram**


#### 5.3.2.6.1. Byte Deserializer Disabled Mode

In disabled mode, the byte deserializer is bypassed. The data from the 8B/10B decoder, rate match FIFO, or word aligner is directly transmitted to the RX FIFO, depending on whether or not the 8B/10B decoder and rate match FIFO are enabled. Disabled mode is used in low speed applications such as GigE, where the FPGA fabric and the PCS can operate at the same clock rate.

#### 5.3.2.6.2. Byte Deserializer Deserialize x2 Mode

The deserialize x2 mode is used in high-speed applications such as the PCIe Gen1 or Gen2 protocol implementation, where the FPGA fabric cannot operate as fast as the TX PCS.

In deserialize x2 mode, the byte deserializer deserializes 8-bit, 10-bit (when the 8B/10B encoder is not enabled), 16-bit, and 20-bit (when the 8B/10B encoder is not enabled) input data into 16-bit, 20-bit, 32-bit, and 40-bit data, respectively. As the parallel data width from the word aligner is doubled, the clock rate is halved.

#### 5.3.2.6.3. Byte Deserializer Deserialize x4 Mode

The deserialize x4 mode is used in high-speed applications where the FPGA fabric cannot operate as fast as the TX PCS.

In deserialize x4 mode, the byte deserializer deserializes 8-bit data into 32-bit data. As the parallel data width from the word aligner is quadrupled, the clock rate is divided four times.

#### 5.3.2.6.4. Bonded Byte Deserializer

The bonded byte deserializer is also available for channel-bundled applications such as PIPE. In this configuration, the control signals of the byte deserializers of all the channels are bonded together. A master channel controls all the other channels to prevent skew between the channels.

### 5.3.2.7. RX FIFO (Shared with Enhanced PCS and PCIe Gen3 PCS)

The RX FIFO interfaces between the PCS on the receiver side and the FPGA fabric and ensures reliable transfer of data and status signals. It compensates for the phase difference between the FPGA fabric and the PCS on the receiver side. The RX FIFO has a depth of 8. It operates in register FIFO and low latency modes.

**Figure 267. RX FIFO Block Diagram**



#### 5.3.2.7.1. RX FIFO Low Latency Mode

The low latency mode incurs two to three cycles of latency when connecting it with the FPGA fabric. The FIFO empty and the FIFO full threshold values are made closer so that the depth of the FIFO decreases, which in turn decreases the latency.

#### 5.3.2.7.2. RX FIFO Register Mode

The register mode bypasses the FIFO functionality to eliminate the FIFO latency uncertainty for applications with stringent latency requirements. This is accomplished by tying the read clock of the FIFO with its write clock. The register mode incurs only one clock cycle of latency when interfacing to the FPGA fabric.

## 5.4. Arria 10 PCI Express Gen3 PCS Architecture

Arria 10 architecture supports the PCIe Gen3 specification. Intel provides two options to implement the PCI Express solution:

- You can use the Intel Hard IP solution. This complete package provides both the MAC layer and the physical (PHY) layer functionality.
- You can implement the MAC in the FPGA core and connect this MAC to the transceiver PHY through the PIPE interface.

This section focuses on the basic blocks of PIPE 3.0-based Gen3 PCS architecture. The PIPE 3.0-based Gen3 PCS uses a 128b/130b block encoding/decoding scheme, which is different from the 8B/10B scheme used in Gen1 and Gen2. The 130-bit block contains a 2-bit sync header and a 128-bit data payload. For this reason, Arria 10 devices include a separate Gen3 PCS that supports functionality at Gen3 speeds. This PIPE interface supports the seamless switching of Data and Clock between the Gen1, Gen2, and Gen3 data rates, and provides support for PIPE 3.0 features. The PCIe Gen3 PCS supports the PIPE interface with the Hard IP enabled, as well as with the Hard IP bypassed.

**Figure 268. Gen3 PCS Block Diagram**


### Related Information

- [PCI Express \(PIPE\)](#) on page 236  
For more information about PCIe Gen1, Gen2, and Gen3 implementation and configuration, refer to "Supported PIPE Features."
- [Intel Arria 10 Avalon Streaming Interface for PCIe Solutions User Guide](#)
- [Intel Arria 10 Avalon Memory-Mapped Interface for PCIe Solutions User Guide](#)
- [Intel Arria 10 Avalon Memory-Mapped Interface DMA for PCIe Solutions User Guide](#)
- [Intel Arria 10 Avalon Streaming Interface with SR-IOV PCIe Solutions User Guide](#)

### 5.4.1. Transmitter Datapath

This section describes the TX FIFO and the Gearbox of the Gen3 PCS transmitter.

#### 5.4.1.1. TX FIFO (Shared with Standard and Enhanced PCS)

The TX FIFO in each channel ensures a reliable transfer of data and status signals between the PCS channel and the FPGA fabric. The TX FIFO compensates for the phase difference between the low speed parallel PCS clock and the FPGA fabric clock. The RX and TX FIFOs are shared with standard and enhanced PCS. In Hard IP mode, the TX FIFO works in register mode. In PIPE mode, the TX FIFO works in low latency mode.

The TX FIFO operates in low latency mode in PIPE Gen1, Gen2, and Gen3 configurations. The Low Latency mode incurs 3-4 cycles of latency when connecting with the FPGA fabric. The FIFO empty and the FIFO full threshold values are made closer so that the depth of the FIFO decreases, which decreases the latency.

#### Related Information

[Arria 10 Standard PCS Architecture](#) on page 491  
For more information about TX FIFO.

### 5.4.1.2. Gearbox

The PCIe 3.0 base specification specifies a block size of 130 bits, with the exception of the SKP Ordered Sets, which can be of variable length. An implementation of a 130-bit data path takes significant resources, so the PCIe Gen3 PCS data path is implemented as 32-bits wide. Because the TX PMA data width is fixed to 32 bits, and the block size is 130 bits with variations, a gearbox is needed to convert 130 bits to 32 bits.

The gearbox block in the TX PCS converts the 130-bit data (`tx_parallel_data[127:0] + pipe_tx_sync_hdr[1:0]`) to 32-bit data required by the TX PMA as the datapath implementation is 32 bits to reduce usage of resources. The 130-bit data is received as follows in the 32-bit datapath: 34 (32 + 2-bit sync header), 32, 32, 32. During the first cycle the gearbox converts the 34-bit input data to 32-bit data. During the next 3 clock cycles the gearbox merges bits from adjacent cycles to form the 32-bit data. In order for the gearbox to work correctly, a gap must be provided in the data for every 16 shifts as each shift is 2 bits for converting the initial 34-bit to 32-bit in the gearbox. After 16 shifts the gearbox has an extra 32-bit data that was transmitted out, and thus a gap is required in the input data stream. This gap is achieved by driving `pipe_tx_data_valid` low for one cycle after every 16 blocks of input data(`tx_parallel_data`).

#### Related Information

[Gearbox](#) on page 246

### 5.4.2. Receiver Datapath

This section describes the Block Synchronizer, Rate Match FIFO, and RX FIFO of the Gen3 PCS receiver.

#### 5.4.2.1. Block Synchronizer

PMA parallelization occurs at arbitrary word boundaries. Consequently, the parallel data from the RX PMA CDR must be realigned to meaningful character boundaries. The PCI Express 3.0 base specification outlines that the data is formed using 130-bit blocks, with the exception of SKP blocks.

The SKP Ordered Set can be 66, 98, 130, 162, or 194 bits long. The block synchronizer searches for the Electrical Idle Exit Sequence Ordered Set (or the last number of fast training sequences (NFTS) Ordered Set) or skip (SKP) Ordered Set to identify the correct boundary for the incoming stream and to achieve the block alignment. The block is realigned to the new block boundary following the receipt of a SKP Ordered Set, as it can be of variable length.

### 5.4.2.2. Rate Match FIFO

In asynchronous systems, the upstream transmitter and local receiver can be clocked with independent reference clocks. Frequency differences in the order of a few hundred PPM can corrupt the data when latching from the recovered clock domain to the local receiver reference clock domain. The rate match FIFO compensates for small clock frequency differences between these two clock domains by inserting or removing SKP symbols in the data stream to keep the FIFO from going empty or full respectively.

The PCI Express 3.0 base specification defines that the SKP Ordered Set (OS) can be 66, 98, 130, 162, or 194 bits long. The SKP OS has the following fixed bits: 2-bit Sync, 8-bit SKP END, and a 24-bit LFSR = 34 Bits. The Rate Match/Clock compensation block adds or deletes the 4 SKP characters (32-bit) to keep the FIFO from going empty or full, respectively. If the FIFO is nearly full, it deletes the 4 SKP characters (32-bit) by disabling write whenever a SKP is found. If the FIFO is nearly empty, the design waits for a SKP Ordered Set to start and then stops reading the data from the FIFO, and inserts a SKP in the outgoing data. The actual FIFO core (memory element) is in the Shared Memory block in the PCS channel.

**Figure 269. Rate Match FIFO**



### 5.4.2.3. RX FIFO (Shared with Standard and Enhanced PCS)

The RX FIFO in each channel ensures a reliable transfer of data and status signals between the PCS channel and the FPGA fabric. The RX FIFO compensates for the phase difference between the parallel PCS clock and the FPGA fabric clock. In PIPE mode, the RX FIFO works in low latency mode.

#### Related Information

[Arria 10 Standard PCS Architecture](#) on page 491  
For more information about RX FIFO.

### 5.4.3. PIPE Interface

This section describes the Auto Speed Negotiation and the Clock Data Recovery Control of the PIPE interface.

#### 5.4.3.1. Auto Speed Negotiation

Auto speed negotiation controls the operating speed of the transceiver when operating under PIPE 3.0 modes. By monitoring the `pipe_rate` signal from the PHY-MAC, this feature changes the transceiver from PIPE Gen1 operation mode to Gen2 operation mode, or from PIPE Gen1 operation mode to Gen2 operation mode to Gen3 operation mode, or vice versa. The PIPE interface clock rate is adjusted to match the data throughput.

### Related Information

Rate Switch on page 244

#### 5.4.3.2. Clock Data Recovery Control

The CDR control feature is used for the L0s fast exit when operating in PIPE Gen3 mode. Upon detecting an Electrical Idle Ordered Set (EIOS), this feature takes manual control of the CDR by forcing it into a lock-to-reference mode. When an exit from electrical idle is detected, this feature moves the CDR into lock-to-data mode to achieve fast data lock.

## 5.5. Intel Arria 10 Transceiver PHY Architecture Revision History

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2020.05.15       | Made the following change: <ul style="list-style-type: none"><li>Removed OFF as an option in the "Transmitter Buffer" figure and Programmable Transmitter On-Chip Termination (OCT).</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2020.05.08       | Made the following change: <ul style="list-style-type: none"><li>Added the receiver pin I/O standards.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2019.11.04       | Made the following changes to <i>How to Enable CTLE and DFE</i> : <ul style="list-style-type: none"><li>Changed step #1 to, "Request user access to the internal configuration bus by writing 0x2 to offset address 0x0[1:0]."</li><li>Changed step #5 to, "Release the internal configuration bus to PreSICE by writing 0x3 to offset address 0x0[1:0]."</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2018.06.15       | Made the following changes: <ul style="list-style-type: none"><li>Changed the AC gain settings for high bandwidth and medium bandwidth mode in the "High Gain Mode" section.</li><li>Added a note about bit slipping to the "RX Gearbox, RX Bitslip, and Polarity Inversion" section.</li><li>Clarified the description of DC gain circuitry in the "Continuous Time Linear Equalization (CTLE)" section.</li><li>Clarified the description of CTLE manual mode in the "High Data Rate Mode" section.</li><li>Removed the Channel Loss Compensation column from the "Pre-Emphasis Taps" table.</li><li>Updated Serial Loopback Path and Reverse Serial Loopback Path/Pre CDR figures and their notes.</li><li>Changed the instruction in step 1 of the "How to Enable CTLE and DFE" section.</li></ul> |
| 2016.10.31       | Made the following changes: <ul style="list-style-type: none"><li>Added a note below the diagram "Diagnostic Loopback Path/Pre CDR" saying "TX pre-emp is not supported in pre-CDR loopback. TX pre-emp is recommended to set to zero for all taps."</li><li>"Idle OS Deletion" description updated to "Deletion of Idles occurs in groups of four OS (when there are two consecutive OS) until the rx_enh_fifo_pfull flag deasserts".</li><li>Removed square wave pattern generator.</li></ul>                                                                                                                                                                                                                                                                                                        |
| 2015.05.02       | Made the following changes: <ul style="list-style-type: none"><li>Updated the configuration methods for the CTLE, and DFE schemes in the Arria 10 PMA Architecture section.</li><li>Removed a signal in the "Gen3 PCS Block Diagram" in the Arria 10 PCI Express Architecture section.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2015.12.18       | Made the following changes: <ul style="list-style-type: none"><li>Updated the configuration methods for the CTLE, DFE, and adaptation schemes in the Arria 10 PMA Architecture section.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2015.11.02       | Made the following changes to the PMA Architecture section: <ul style="list-style-type: none"><li>Updated "Channel Pulse Response" figure in the Decision Feedback Equalization (DFE) section.</li><li>Updated the value for the "Number of fixed DFE taps" in the Equalization table in the PMA Parameters section.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Made the following changes to the Enhanced PCS Architecture section:</p> <ul style="list-style-type: none"> <li>• Updated Phase Compensation Mode and Basic Mode sections.</li> <li>• Added 64B/66B Encoder Reset Condition section.</li> <li>• Updated TX Gearbox, TX Bitslip and Polarity Inversion sections.</li> <li>• Updated RX Bitslip in RX Gearbox, RX Bitslip, and Polarity Inversion figure.</li> <li>• Added "block synchronization" in Enhanced PCS introduction note.</li> <li>• Updated Enhanced PCS TX FIFO section.</li> <li>• Updated reference link for TX Phase Compensation Mode section.</li> <li>• Updated TX Register Mode description.</li> <li>• Updated Interlaken Frame Generator section description.</li> <li>• Updated 64B/66B Encoder and Transmitter State Machine section title.</li> <li>• Updated PRBS Pattern Generator (Shared between Enhanced and Standard) title</li> <li>• Updated Square Wave Pattern Generator (Shared between Enhanced and Standard)</li> <li>• Updated RX Register Mode description.</li> </ul> <p>Made the following changes to the Standard PCS Architecture section:</p> <ul style="list-style-type: none"> <li>• Updated the Byte Serializer section for Serialize x2 and x4 modes.</li> <li>• Added new figures for 8B/10B Encoder Bit and Byte Reversal features.</li> </ul>                                                                                       |
| 2015.05.11       | <p>Made the following changes to the PMA Architecture section:</p> <ul style="list-style-type: none"> <li>• Updated link to XCVR_A10_RX_TERM_SEL in the "Transmitter Buffer".</li> <li>• Updated ODI vertical steps to 63 (0 and +/-32) in the "Receiver Buffer".</li> <li>• Updated CTLE section for adaptation modes. Moved CTLE in the "How to Enable CTLE and DFE" section.</li> <li>• Updated VGA section for adaptation modes.</li> <li>• Updated DFE section for adaptation modes. Moved DFE to the new "How to Enable CTLE and DFE" section.</li> <li>• Removed Triggered DFE mode.</li> <li>• Removed all references related to floating taps.</li> </ul> <p>Made the following changes to the Enhanced PCS Architecture section:</p> <ul style="list-style-type: none"> <li>• Updated pattern generators (PRBS, Square Wave and PRP), PRBS Checker and PRP Verifier sections.</li> <li>• Revised the descriptions of TX FIFO Fast Register Mode.</li> <li>• Changed the title and descriptions in "Enhanced PCS Pattern Generators".</li> <li>• Added new sections for "PRBS Pattern Generator (Shared between Enhanced and Standard PCSEs)", "Square Wave Pattern Generator (Shared between Enhanced and Standard PCSEs)", and "Pseudo-Random Pattern Generator."</li> <li>• Changed sub title "PRBS Verifier" to "PRBS Checker" and changed their descriptions.</li> <li>• Changed descriptions in "PRP Verifier".</li> </ul> |
| 2014.12.15       | <p>Made the following changes to the Enhanced PCS Architecture section:</p> <ul style="list-style-type: none"> <li>• Added PRBS7 Generator to support 64-bit width only.</li> <li>• Updated the rule for <code>tx_enh_data_valid</code> control signal when TX FIFO is used in phase compensation mode.</li> </ul> <p>Made the following changes to the PCI Express Gen3 PCS Architecture section:</p> <ul style="list-style-type: none"> <li>• Updated TX FIFO in Transmitter Datapath.</li> <li>• Changed the Standard PCS data rate from 12.5 Gbps to 12 Gbps.</li> </ul> <p>Made the following changes to the Standard PCS Architecture section:</p> <ul style="list-style-type: none"> <li>• Changed the Standard PCS data rate from 12.5 Gbps to 12 Gbps.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Made the following changes to the PMA Architecture section:</p> <ul style="list-style-type: none"> <li>Added High Speed Differential I/O and Power Distribution Network to the <i>Transmitter Buffer</i> circuitry.</li> <li>Added Power Distribution Network induced Inter-Symbol Interference compensation.</li> <li>Replaced the figures related to Programmable Pre Emphasis with a link to Pre Emphasis and Output Swing Settings Estimator.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2014.08.15       | <p>Made the following changes to the PCI Express Gen3 PCS Architecture section:</p> <ul style="list-style-type: none"> <li>Corrected the low latency mode cycles of latency in the TX FIFO (Shared with Standard and Enhanced PCS).</li> </ul> <p>Made the following changes to the Standard PCS Architecture section:</p> <ul style="list-style-type: none"> <li>Removed the features not supported by <i>8B/10B Decoder</i>.</li> <li>Changed the description of TX FIFO to include the depth of the TX FIFO.</li> <li>Updated the description of Polarity Inversion feature to include how to enable Polarity Inversion.</li> <li>Updated the description of Pseudo-Random Binary Sequence (PRBS) Generator on the supported PCS-PMA interface widths.</li> <li>Changed the value for Supported Word Aligner Pattern Lengths for Bitslip Mode when the PCS-PMA Interface Width is 8 in Table 5-8 Word Aligner Pattern Length for Various Word Aligner Modes.</li> <li>Changed the description of RX FIFO to include the depth of the RX FIFO.</li> <li>Changed the RX Word Aligner pattern length for PCS-PMA interface width 8 in Bitslip Mode.</li> </ul> <p>Made the following changes to the Enhanced PCS Architecture section:</p> <ul style="list-style-type: none"> <li>Changed references from MegaWizard to Parameters Editor.</li> </ul> <p>Made the following changes to the PMA Architecture section:</p> <ul style="list-style-type: none"> <li>Added <i>2nd post-tap and pre-tap Pre-Emphasis signals</i>.</li> <li>Updated DFE and CTLE modes of operation and Use Models.</li> <li>Added new sections on <i>How to Enable CTLE</i> and <i>How to Enable DFE</i>.</li> <li>Changed max data rate for GT channels to 25.8 Gbps in the <i>Receiver Buffer CTLE</i> section.</li> <li>Updated Receiver Buffer figure by adding and modifying <i>Adaptive Parametric Tuning Engine</i> to include CDR and DFE.</li> <li>Updated VGA section that includes <i>VGA Frequency</i> response for different gain settings.</li> </ul> |
| 2013.12.02       | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

## 6. Reconfiguration Interface and Dynamic Reconfiguration

---

This chapter explains the purpose and the use of the Arria 10 reconfiguration interface that is part of the Transceiver Native PHY IP core and the Transceiver PLL IP cores.

Dynamic reconfiguration is the process of dynamically modifying transceiver channels and PLLs to meet changing requirements during device operation. Arria 10 transceiver channels and PLLs are fully customizable, allowing a system to adapt to its operating environment. You can customize channels and PLLs by dynamically triggering reconfiguration during device operation or following power-up. Dynamic reconfiguration is available for Arria 10 Transceiver Native PHY, fPLL, ATX PLL, and CMU PLL IP cores.

Use the reconfiguration interface to dynamically change the transceiver channel or PLL settings for the following applications:

- Fine tuning signal integrity by adjusting TX and RX analog settings
- Enabling or disabling transceiver channel blocks, such as the PRBS generator and the checker
- Changing data rates to perform auto negotiation in CPRI, SATA, or SAS applications
- Changing data rates in Ethernet (1G/10G) applications by switching between standard and enhanced PCS datapaths
- Changing TX PLL settings for multi-data rate support protocols such as CPRI
- Changing RX CDR settings from one data rate to another
- Switching between multiple TX PLLs for multi-data rate support

The Native PHY and Transmit PLL IP cores provide the following features that allow dynamic reconfiguration:

- Reconfiguration interface
- Configuration files
- Feature to add PMA analog settings (optional) to the Configuration files (Native PHY only)
- Multiple reconfiguration profiles (Native PHY and ATX PLL)
- Embedded reconfiguration streamer (Native PHY and ATX PLL)
- Native PHY Debug Master Endpoint (NPDME)
- Optional reconfiguration logic

## 6.1. Reconfiguring Channel and PLL Blocks

The following table lists some of the available dynamic reconfiguration features in Arria 10 devices.

**Table 265. Arria 10 Dynamic Reconfiguration Feature Support**

| Reconfiguration         | Features                                                                                                                                                                                                     |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Channel Reconfiguration | PMA analog features <ul style="list-style-type: none"><li>• V<sub>OD</sub></li><li>• Pre-emphasis</li><li>• Continuous Time Linear Equalizer (CTLE)</li><li>• Decision Feedback Equalization (DFE)</li></ul> |
|                         | TX PLL <ul style="list-style-type: none"><li>• TX local clock dividers</li><li>• TX PLL switching</li></ul>                                                                                                  |
|                         | RX CDR <ul style="list-style-type: none"><li>• RX CDR settings</li><li>• RX CDR reference clock switching</li></ul>                                                                                          |
|                         | Reconfiguration of PCS blocks within the datapath                                                                                                                                                            |
|                         | Datapath switching <ul style="list-style-type: none"><li>• Standard, Enhanced, PCS Direct</li></ul>                                                                                                          |
| PLL Reconfiguration     | PLL settings <ul style="list-style-type: none"><li>• Counters</li></ul>                                                                                                                                      |
|                         | PLL reference clock switching                                                                                                                                                                                |

### Related Information

[Unsupported Features](#) on page 575

## 6.2. Interacting with the Reconfiguration Interface

Each transceiver channel and PLL contains Avalon memory-mapped interface reconfiguration. The reconfiguration interface provides direct access to the programmable space of each channel and PLL. Communication with the channel and PLL reconfiguration interface requires an Avalon memory-mapped interface master. Because each channel and PLL has its own dedicated Avalon memory-mapped interface, you can dynamically modify channels either concurrently or sequentially, depending on how the Avalon memory-mapped interface master is connected to the Avalon memory-mapped interface reconfiguration.

**Figure 270. Reconfiguration Interface in Arria 10 Transceiver IP Cores**



A transmit PLL instance has a maximum of one reconfiguration interface. Unlike PLL instances, a Native PHY IP core instance can specify multiple channels. You can use a dedicated reconfiguration interface for each channel or share a single reconfiguration interface across all channels to perform dynamic reconfiguration.

Avalon memory-mapped interface masters interact with the reconfiguration interface by performing Avalon read and write operations to initiate dynamic reconfiguration of specific transceiver parameters. All read and write operations must comply with Avalon memory-mapped interface specifications.

**Figure 271. Top-Level Signals of the Reconfiguration Interface**



The user-accessible Avalon memory-mapped interface reconfiguration and PreSICE Avalon memory-mapped interface share a single internal configuration bus. This bus is arbitrated to get access to the Avalon memory-mapped interface of the channel or PLL. Refer to the *Arbitration* section for more details about requesting access to and returning control of the internal configuration bus from PreSICE.

#### Related Information

- [Arbitration](#) on page 524

- Reconfiguration Interface and Arbitration with PreSICE Calibration Engine on page 579
- *Avalon Interface Specifications*

### 6.2.1. Reading from the Reconfiguration Interface

Reading from the reconfiguration interface of the Transceiver Native PHY IP core or Transceiver PLL IP core retrieves the current value at a specific address.

**Figure 272. Reading from the Reconfiguration Interface**



1. The master asserts `reconfig_address` and `reconfig_read` after the rising edge of `reconfig_clk`.
2. The slave asserts `reconfig_waitrequest`, stalling the transfer.
3. The master samples `reconfig_waitrequest`. Because `reconfig_waitrequest` is asserted, the cycle becomes a wait state and `reconfig_address`, `reconfig_read`, and `reconfig_write` remain constant.
4. The slave presents valid `reconfig_readdata` and deasserts `reconfig_waitrequest`.
5. The master samples `reconfig_waitrequest` and `reconfig_readdata`, completing the transfer.

After the `reconfig_read` signal is asserted, the `reconfig_waitrequest` signal asserts for a few `reconfig_clock` cycles, then deasserts. This deassertion indicates the `reconfig_readdata` bus contains valid data.

**Note:**

You must check for the internal configuration bus arbitration before performing reconfiguration. Refer to the *Arbitration* section for more details about requesting access to and returning control of the internal configuration bus from PreSICE.

#### Related Information

[Arbitration](#) on page 524

### 6.2.2. Writing to the Reconfiguration Interface

Writing to the reconfiguration interface of the Transceiver Native PHY IP core or TX PLL IP core changes the data value at a specific address. All writes to the reconfiguration interface must be read-modify-writes, because two or more features may share the same reconfiguration address. When two or more features share the same reconfiguration address, one feature's data bits are interleaved with another feature's data bits.

**Figure 273. Writing to the Reconfiguration Interface**



1. The master asserts the reconfig\_address, reconfig\_write, and reconfig\_writedata signals.
2. The slave (channel or PLL) captures reconfig\_writedata, ending the transfer.

**Note:**

You must check for the internal configuration bus arbitration before performing reconfiguration. Refer to the *Arbitration* section for more details about requesting access to and returning control of the internal configuration bus from PreSICE.

#### Related Information

- [Arbitration](#) on page 524
- [Ports and Parameters](#) on page 547

### 6.3. Configuration Files

The Arria 10 Transceiver Native PHY and Transmit PLL IP cores optionally allow you to save the parameters you specify for the IP instances as configuration files. The configuration file stores addresses and data values for that specific IP instance.

The configuration files are generated during IP generation. They are located in the <IP instance name>\altera\_xcvr\_<IP type>\_a10\_<quartus version>\synth\reconfig subfolder of the IP instance. The configuration data is available in the following formats:

- **SystemVerilog packages:** <name>.sv
- **C Header files:** <name>.h
- **Memory Initialization File (MIF):** <name>.mif

Select one or more of the configuration file formats on the **Dynamic Reconfiguration** tab of the Transceiver Native PHY or Transmit PLL parameter editor to store the configuration data. All configuration files generated for a particular IP instance contain the same address and data values. The contents of the configuration files can be used to reconfigure from one transceiver /PLL configuration to another.

You can optionally allow the Native PHY IP core to include PMA Analog settings in the configuration files by enabling the feature **Include PMA Analog settings in configuration files** in the **Dynamic Reconfirmation** tab of the Transceiver Native PHY IP Parameter Editor. This feature is disabled by default. Enabling this feature adds the PMA analog settings specified in the **Analog PMA settings (Optional)** tab of the Native PHY IP Parameter Editor to the configuration files. Even with this option enabled in the Native PHY IP Parameter Editor, you must still specify Quartus Settings File (QSF) assignments for your analog settings when compiling your static design. The analog settings selected in the Native PHY IP Parameter Editor are used only to include these settings and their dependent settings in the selected configuration files. Refer to the *Analog Parameter Settings* chapter for details about QSF assignments for the analog settings.

### Example 2. SystemVerilog Configuration File

```

26'h008FF04,
// [25:16]-DPRIO address=0x008;
// [15:8]-bit mask=0xFF;
// [7:0]- hssi_tx_pcs_pma_interface_pldif_datawidth_mode=pldif_data_10bit(1'h0);
// [6:5]-hssi_tx_pcs_pma_interface_tx_pma_data_sel=ten_g_pcs(2'h0);
// [4:4]-hssi_tx_pcs_pma_interface_prbs_gen_pat=prbs_gen_dis(1'h0);
// [3:0]-hssi_tx_pcs_pma_interface_sq_wave_num=sq_wave_default(4'h4);
...

localparam HSSI_TX_PCS_PMA_INTERFACE_PLDIF_DATAWIDTH_MODE_VALUE = "pldif_data_10bit";
localparam HSSI_TX_PCS_PMA_INTERFACE_PLDIF_DATAWIDTH_MODE_ADDR_OFST = 8;
localparam HSSI_TX_PCS_PMA_INTERFACE_PLDIF_DATAWIDTH_MODE_ADDR_FIELD_OFST = 7;
localparam HSSI_TX_PCS_PMA_INTERFACE_PLDIF_DATAWIDTH_MODE_ADDR_FIELD_HIGH = 7;
localparam HSSI_TX_PCS_PMA_INTERFACE_PLDIF_DATAWIDTH_MODE_ADDR_FIELD_SIZE = 1;
localparam HSSI_TX_PCS_PMA_INTERFACE_PLDIF_DATAWIDTH_MODE_ADDR_FIELD_BITMASK =
    32'h00000080;
localparam HSSI_TX_PCS_PMA_INTERFACE_PLDIF_DATAWIDTH_MODE_ADDR_FIELD_VALMASK =
    32'h00000000;
localparam HSSI_TX_PCS_PMA_INTERFACE_PLDIF_DATAWIDTH_MODE_ADDR_FIELD_VALUE = 1'h0;

```

The SystemVerilog configuration files contain two parts. The first part consists of a data array of 26-bit hexadecimal values. The second part consists of parameter values. For the data array, each 26-bit hexadecimal value is associated with a comment that describes the various bit positions.

**Table 266. Mapping of SystemVerilog Configuration File Line**

| Bit Position | Description                                                                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| [25:16]      | DPRIO address. Refer to Intel Arria 10 Transceiver Register Map for details of the address.                                                       |
| [15:8]       | The channel or PLL bit mask. The bit mask exposes the bits that are configured in either the Transceiver Native PHY or the transmit PLL IP cores. |
| [7:0]        | Feature bit values.                                                                                                                               |

For example, a value of 26'h008FF04 represents an address of 0x008 and a bit mask of 0xFF. The four features that reside at address 0x008 are:

- hssi\_tx\_pcs\_pma\_interface\_pldif\_datawidth\_mode with a value of 1'h0
- hssi\_tx\_pcs\_pma\_interface\_tx\_pma\_data\_sel with a value of 2'h0
- hssi\_tx\_pcs\_pma\_interface\_prbs\_gen\_pat with a value of 1'h0
- hssi\_tx\_pcs\_pma\_interface\_sq\_wave\_num with a value of 4'h4

Writing to bit 7 of address 0x008 changes the hssi\_tx\_pcs\_pma\_interface\_pldif\_datawidth\_mode feature.

The MIF file and C header file are set up similarly to the SystemVerilog package file. Multiple transceiver features may reside at the same address. Also, a single transceiver feature may span across multiple addresses.

Dynamic reconfiguration requires at least two configurations of the Transceiver Native PHY IP core or PLL IP core. One configuration defines the base transceiver or PLL configuration and the other configurations define the modified or target configurations. Use the IP Parameter Editor to create base and modified configurations of the Transceiver Native PHY or PLL IP core, according to the following table.

**Table 267. Transceiver Native PHY or PLL IP Parameters (Base and Modified Configurations)**

| Native PHY or PLL Instance | Required Parameter Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Saved In                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Base Configuration         | <ul style="list-style-type: none"> <li>Click <b>Interfaces &gt; Transceiver PHY &gt; Arria 10 Transceiver Native PHY</b> for the Native PHY IP core. Or, select one of the supported transmit PLL IP cores under <b>PLL</b>. Enable all options required for the base configuration, such as data rate, PCS options, and PMA options.</li> <li>Enable all ports to be used by the modified configuration. For example, if the bitslip feature is not required in the base configuration, but required in modified configuration, then you must enable the <code>tx_std_bitslipboundarysel</code> port. Reconfiguring between Standard PCS, Enhanced PCS, and PCS Direct requires that you turn on <b>Enable datapath and interface reconfiguration</b>. The <b>Transceiver configuration rules</b> define the initial mode of the PHY instance.</li> <li>On the <b>Dynamic Reconfiguration</b> tab, turn on <b>Enable dynamic reconfiguration</b> and specify the <b>Configuration Options</b>.</li> </ul> <p>This flow requires that you turn on <b>Configuration file</b> option.</p> | <ul style="list-style-type: none"> <li>&lt;<i>Native PHY Base Instance Name</i>&gt;/reconfig/<br/><code>altera_xcvr_native_a10_reconfig_parameters.sv</code> contains all transceiver register addresses and their bit value for that transceiver configuration.</li> </ul> <p>Or</p> <ul style="list-style-type: none"> <li>&lt;<i>PLL Base Instance Name</i>&gt;/reconfig/<br/><code>altera_xcvr_&lt;type&gt;_pll_a10_reconfig_parameters.sv</code> contains all PLL register addresses and their bit value for that PLL configuration.</li> </ul>         |
| Modified Configuration     | <ul style="list-style-type: none"> <li>Click <b>Interfaces &gt; Transceiver PHY &gt; Arria 10 Transceiver Native PHY</b>. Or, select one of the supported transmit PLL IP cores under <b>PLL</b>. Enable all options required for the modified configuration, such as data rate, PCS options, and PMA options.</li> <li>Enable all ports that are used by the modified configuration. Reconfiguring between Standard PCS, Enhanced PCS, and PCS Direct requires <b>Enable datapath and interface reconfiguration</b> be enabled. The <b>Transceiver configuration rules</b> define the mode of the PHY instance.</li> <li>On the <b>Dynamic Reconfiguration</b> tab, turn on <b>Enable dynamic reconfiguration</b> and specify the same <b>Configuration Options</b> as the base instance.</li> </ul>                                                                                                                                                                                                                                                                                   | <ul style="list-style-type: none"> <li>&lt;<i>Native PHY Modified Instance Name</i>&gt;/reconfig/<br/><code>altera_xcvr_native_a10_reconfig_parameters.sv</code> contains all transceiver register addresses and their bit value for that transceiver configuration.</li> </ul> <p>Or</p> <ul style="list-style-type: none"> <li>&lt;<i>PLL Modified Instance Name</i>&gt;/reconfig/<br/><code>altera_xcvr_&lt;type&gt;_pll_a10_reconfig_parameters.sv</code> contains all PLL register addresses and their bit value for that PLL configuration.</li> </ul> |

**Note:** You can generate the base and modified configuration files in the same or different folders. If you use the same folder, each configuration name must be unique.

Intel recommends following the flow described in the *Steps to Perform Dynamic Reconfiguration* section when performing dynamic reconfiguration of either the Native PHY IP core or transmit PLL IP core.

### Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528

- [Analog Parameter Settings](#) on page 597
- [Arria 10 Transceiver Register Map](#)

## 6.4. Multiple Reconfiguration Profiles

You can optionally enable multiple configurations or profiles in the same Native PHY IP or ATX PLL IP core Parameter Editor (or both) for performing dynamic reconfiguration. This allows the IP Parameter Editor to create, store, and analyze the parameter settings for multiple configurations or profiles.

When you enable the multiple reconfiguration profiles feature, the Native PHY IP Core, ATX PLL IP core, or both can generate configuration files for all the profiles in the format desired (SystemVerilog package, MIF, or C header file). The configuration files are located in the `<IP instance name>\altera_xcvr_<IP type>_a10_<quartus version>\synth\reconfig` subfolder of the IP instance with the configuration profile index added to the filename. For example, the configuration file for Profile 0 is stored as `<filename_CFG0.sv>`. The Intel Quartus Prime Timing Analyzer Timing Analyzer includes the necessary timing paths for all the configurations based on initial and target profiles. You can also generate reduced configuration files that contain only the attributes that differ between the multiple configured profiles. You can create up to eight reconfiguration profiles (Profile 0 to Profile 7) at a time for each instance of the Native PHY/ATX PLL IP core.

You can optionally allow the Native PHY IP core to include PMA Analog settings in the configuration files by enabling the feature **Include PMA Analog settings in configuration files** in the **Dynamic Reconfiguration** tab of the Transceiver Native PHY IP Parameter Editor. This feature is disabled by default. Enabling this feature adds the PMA analog settings specified in the **Analog PMA settings (Optional)** tab of the Native PHY IP Parameter Editor to the configuration files. Even with this option enabled in the Native PHY IP Parameter Editor, you must still specify QSF assignments for your analog settings when compiling your static design. The analog settings selected in the Native PHY IP Parameter Editor are used only to include these settings and their dependent settings in the selected configuration files. Refer to the *Analog Parameter Settings* chapter for details about QSF assignments for the analog settings.

Refer to *Steps to Perform Dynamic Reconfiguration* for a complete list of steps to perform dynamic reconfiguration using the IP guided reconfiguration flow with multiple reconfiguration profiles enabled.

The Quartus Prime Timing Analyzer only includes the necessary PCS timing paths for all the profiles. To perform a PMA reconfiguration such as TX PLL switching, CGB divider switching, or reference clock switching, you must use the flow described in *Steps to Perform Dynamic Reconfiguration*. Refer to *Timing Closure Recommendations* for more details about enabling multiple profiles and running timing analyses.

You can use the multiple reconfiguration profiles feature without using the embedded reconfiguration streamer feature. When using the multiple reconfiguration profiles feature by itself, you must write the user logic to reconfigure all the entries that are different between the profiles while moving from one profile to another.

**Note:** You must ensure that none of the profiles in the Native PHY IP and ATX PLL IP Parameter Editor gives error messages, or else IP generation fails. The Native PHY IP core and ATX PLL IP only validates the current active profile dynamically. For example, if you store a profile with error messages in the Native PHY IP or ATX PLL IP Parameter Editor and load another profile without any error messages, the error messages disappear in the IP. You are then allowed to generate the IP, but the generation fails.

#### Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528
- [Timing Closure Recommendations](#) on page 572
- [Analog Parameter Settings](#) on page 597

## 6.5. Embedded Reconfiguration Streamer

You can optionally enable the embedded reconfiguration streamer in the Native PHY IP core, ATX PLL IP core, or both to automate the reconfiguration operation.

The embedded reconfiguration streamer is a feature block that can perform Avalon memory-mapped interface transactions to access channel/ATX PLL configuration registers in the transceiver.

When you enable the embedded streamer, the Native PHY/ATX PLL IP cores embed the reconfiguration profiles and reconfiguration control logic in the IP files.

For the ATX PLL IP, you can control the embedded streamer block through the reconfiguration interface. Control and status signals of the streamer block are memory mapped in the PLL's soft control and status registers.

**Table 268. Control and Status Register Memory Map for Embedded Reconfiguration Streamer in ATX PLL IP**

| Reconfiguration Address (hex) | Reconfiguration Bit | Attribute Name | Attribute Description        | Bit Encoding  | Transceiver Block                 | Description                                                                                                                         |
|-------------------------------|---------------------|----------------|------------------------------|---------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 340                           | 7                   | cfg_load       | Start streaming              | 1'b1          | Embedded Reconfiguration Streamer | Set to 1'b1 to initiate streaming, self-clearing bit                                                                                |
|                               | [2:0]               | cfg_sel        | Configuration profile select | Direct mapped | Embedded Reconfiguration Streamer | Binary encoding of the configuration Profile to stream                                                                              |
| 341                           | 0                   | rcfg_busy      | Busy Status bit              | 1'b1          | Embedded Reconfiguration Streamer | Bit is set to: <ul style="list-style-type: none"><li>• 1'b1—streaming is in progress</li><li>• 1'b0—streaming is complete</li></ul> |

**Note:** The soft control and status registers at x340 and x341 are enabled when you enable the embedded reconfiguration streamer in the ATX PLL IP core.

Refer to [Steps to Perform Dynamic Reconfiguration](#) for a complete list of steps to perform dynamic reconfiguration using the IP guided reconfiguration flow with embedded streamer enabled. To perform a reference clock switching, use the reconfiguration flow for special cases described in [Steps to Perform Dynamic Reconfiguration](#).

For the Native PHY IP, you can control the embedded streamer block through the reconfiguration interface. Control and status signals of the streamer block are memory mapped in the PHY's soft control and status registers. These embedded reconfiguration control and status registers are replicated for each channel. You cannot merge reconfiguration interfaces across multiple IP cores when the embedded reconfiguration streamer is enabled because the embedded reconfiguration streamer makes use of soft logic for control and status registers.

You can optionally allow the Native PHY IP core to include PMA Analog settings in the configuration files by enabling the feature **Include PMA Analog settings in configuration files** in the **Dynamic Reconfirmation** tab of the Transceiver Native PHY IP Parameter Editor. This feature is disabled by default. Enabling this feature adds the PMA analog settings specified in the **Analog PMA settings (Optional)** tab of the Native PHY IP Parameter Editor to the configuration files. Even with this option enabled in the Native PHY IP Parameter Editor, you must still specify QSF assignments for your analog settings when compiling your static design. The analog settings selected in the Native PHY IP Parameter Editor are used only to include these settings and their dependent settings in the selected configuration files. For details about QSF assignments for the analog settings, refer to the *Analog Parameter Settings* chapter.

For example, if the Native PHY IP core has four channels—logical channel 0 to logical channel 3—and you want to reconfigure logical channel 3 using the embedded reconfiguration streamer, you must write to the control register of logical channel 3 using the reconfiguration interface with the appropriate bit settings.

**Note:** The soft control and status registers at x340 and x341 are enabled when you enable the embedded reconfiguration streamer in the Native PHY IP core.

Refer to *Steps to Perform Dynamic Reconfiguration* for a complete list of steps to perform dynamic reconfiguration using the IP guided reconfiguration flow with embedded streamer enabled. To perform a PMA reconfiguration such as TX PLL switching, CGB divider switching, or reference clock switching, use the reconfiguration flow for special cases described in *Steps to Perform Dynamic Reconfiguration*.

**Table 269. Control and Status Register Memory Map for Embedded Reconfiguration Streamer in Native PHY IP**

| Reconfiguration Address (hex) | Reconfiguration Bit | Attribute Name | Attribute Description        | Bit Encoding  | Transceiver Block                 | Description                                                                                                                                       |
|-------------------------------|---------------------|----------------|------------------------------|---------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 340                           | 7                   | cfg_load       | Start streaming              | 1'b1          | Embedded Reconfiguration Streamer | Set to 1'b1 to initiate streaming, self-clearing bit                                                                                              |
|                               | 6                   | bcast_en       | Broadcast enable             | 1'b1          | Embedded Reconfiguration Streamer | Set to 1'b1 to broadcast the same profile to all the channels                                                                                     |
|                               | [2:0]               | cfg_sel        | Configuration profile select | Direct mapped | Embedded Reconfiguration Streamer | Binary encoding of the configuration Profile to stream                                                                                            |
| 341                           | 0                   | rcfg_busy      | Busy Status bit              | 1'b1          | Embedded Reconfiguration Streamer | Bit is set to: <ul style="list-style-type: none"><li>• <b>1'b1</b>—streaming is in progress</li><li>• <b>1'b0</b>—streaming is complete</li></ul> |

You can write to the address 0x340 at the same time to start the streaming, enable broadcasting, and select the profile to be streamed. Different requests to multiple channels can be made simultaneously by writing to the addresses of the desired channels through the user reconfiguration interface (shared or independent). The `reconfig_waitrequest` signal remains asserted after the reconfiguration streaming is complete.

#### Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528
- [Analog Parameter Settings](#) on page 597

## 6.6. Arbitration

**Figure 274. Arria 10 ATX PLL with Embedded Streamer**



**Figure 275. Arria 10 Native PHY with Embedded Streamer**

In Arria 10 devices, there are two levels of arbitration:

- Reconfiguration interface arbitration with the PreSICE calibration engine

When you have control over the internal configuration bus, refer to the second level of arbitration: Arbitration between multiple masters within the Native PHY/PLL IPs.

For more details about arbitration between the reconfiguration interface and PreSICE, refer to the *Calibration* chapter.

- Arbitration between multiple masters within the Native PHY/PLL IPs

Below are the feature blocks that can access the programmable registers:

- Embedded reconfiguration streamer (Available in the Native PHY and ATX PLL IPs only)
- NPDME
- User reconfiguration logic connected to the reconfiguration interface

When the internal configuration bus is not owned by the PreSICE, which feature block has access depends on which of them are enabled.

These feature blocks arbitrate for control over the programmable space of each transceiver channel/PLL. Each of these feature blocks can request access to the programmable registers of a channel/PLL by performing a read or write operation to that channel/PLL. For any of these feature blocks to be used, you must first have control over the internal configuration bus. You must ensure that these feature blocks have completed all the read/write operations before you return the bus access to PreSICE.

The embedded reconfiguration streamer has the highest priority, followed by the reconfiguration interface, followed by the NPDME. When two feature blocks are trying to access the same transceiver channel on the same clock cycle, the feature block with the highest priority is given access. The only exception is when a lower-priority feature block is in the middle of a read/write operation and a higher-priority feature block tries to access the same channel. In this case, the higher priority feature block is made to wait until the lower priority feature block has finished the read/write operation.

*Note:* When you enable NPDME in your design, you must

- connect an Avalon memory-mapped interface master to the reconfiguration interface
- OR connect the `reconfig_clock`, `reconfig_reset` signals and ground the `reconfig_write`, `reconfig_read`, `reconfig_address` and `reconfig_writedata` signals of the reconfiguration interface. If the reconfiguration interface signals are not connected appropriately, there is no clock or reset for the NPDME, and the NPDME does not function as expected.

## Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528
- [Calibration](#) on page 579
- [Arria 10 Transceiver Register Map](#)

## 6.7. Recommendations for Dynamic Reconfiguration

### Recommendations for TX PLLs

Intel recommends you control `pll_powerdown` for the fPLL through the soft registers in the following cases:

- Reconfiguring fPLL from integer mode to fractional mode
- Reconfiguring fPLL within fractional mode from one rate to another

For all other reconfiguration scenarios, do not hold the PLL in reset before and during reconfiguration.

When reconfiguring across data rates or protocol modes, Intel recommends that you hold the channel transmitter (analog and digital) associated with the PLL in reset during reconfiguration and recalibration of the PLL. You can use the `tx_digitalreset`, `rx_digitalreset`, `tx_analogreset`, and `rx_analogreset` ports or use the channel soft register for digital and analog resets. For details about placing the channel in analog reset, refer to the "Model 1: Default Model" and "Model 2: Acknowledgment Model" sections of the *Resetting Transceiver Channels* chapter.

**Note:** If you need to reconfigure the ATX PLL, use TX PLL switching mode or use local clock divider to achieve new data rate to avoid recalibrating the ATX PLL. Refer to "ATX PLL Usage Guideline" in the "PLLs and Clock Networks" chapter for more details.

### Recommendations for Channels

- When reconfiguring across data rates or protocol modes, Intel recommends that you hold the channel transmitter (analog and digital) in reset during reconfiguration and recalibration of the channel transmitter. You can use the `tx_digitalreset`, `rx_digitalreset`, `tx_analogreset`, and `rx_analogreset` ports or use the channel soft register for digital and analog resets. For details about placing the channel in analog reset, refer to the "Model 1: Default Model" and "Model 2: Acknowledgment Model" sections of the *Resetting Transceiver Channels* chapter.
- When reconfiguring across data rates or protocol modes, Intel recommends that you hold the channel receiver (analog and digital) in reset during reconfiguration and recalibration of the channel receiver. You can use the `tx_digitalreset`, `rx_digitalreset`, `tx_analogreset`, and `rx_analogreset` ports or use the channel soft register for digital and analog resets. For details about placing the channel in analog reset, refer to the "Model 1: Default Model" and "Model 2: Acknowledgment Model" sections of the *Resetting Transceiver Channels* chapter.
- When performing reconfiguration on channels not involving data rate or protocol mode change, Intel recommends that you hold the channel transmitter (digital only) in reset during reconfiguration.
- When performing reconfiguration on channels not involving data rate or protocol mode change, Intel recommends that you hold the channel receiver (digital only) in reset during reconfiguration.

Refer to the *Arria 10 Transceiver Register Map* for detailed information about the soft registers for PLL powerdown.

### Related Information

- [Model 1: Default Model](#) on page 430

- [Model 2: Acknowledgment Model](#) on page 439
- [PLLs and Clock Networks](#) on page 356
- [Arria 10 Transceiver Register Map](#)

## 6.8. Steps to Perform Dynamic Reconfiguration

You can dynamically reconfigure blocks in the transceiver channel or PLL through the reconfiguration interface.

The following procedure shows the steps required to reconfigure the channel and PLL blocks.

1. Enable dynamic reconfiguration in the IP.
2. Enable the desired configuration file formats in the IP.
3. Enable the desired dynamic reconfiguration features (such as multiple reconfiguration profiles, including PMA analog settings in configuration files) or feature blocks (such as embedded reconfiguration streamer and NPDME).
4. If you are using:
  - Direct reconfiguration flow—Refer to the register map for feature address and valid value of write data for the feature.
  - IP guided reconfiguration flow—Note the settings of the base configuration and generate the corresponding configuration files. Note the settings of the modified configuration and generate the corresponding configuration files. Find out the differences in settings between the base and modified configurations.
  - IP guided reconfiguration flow using multiple profiles—Create and store the parameter settings between the various configurations or profiles using configuration files. Find out the differences in settings between the various configurations or profiles using configuration files.
  - IP guided reconfiguration flow using the embedded streamer—Refer to the control and status register map of the embedded reconfiguration streamer to stream the desired profile settings.
  - Reconfiguration flow for special cases—Refer to the lookup registers to be accessed for each special case, such as TX PLL switching, TX PLL reference clock switching, and RX CDR reference clock switching.
5. Place the channels in digital reset either simultaneously or one after another. For details about placing the channel in reset, refer to "Model 1: Default Model" and "Model 2: Acknowledgment Model" in the *Resetting Transceiver Channels* chapter.

If you are reconfiguring:

  - PLLs—Place the channel transmitter associated with the PLL in reset (digital).
  - TX simplex channels—Place the TX channels being reconfigured in reset (digital).
  - RX simplex channels—Place the RX channels being reconfigured in reset (digital).
  - Duplex channels—Place the channel TX and RX being reconfigured in reset (digital).

6. If you are reconfiguring across data rates or protocol modes or enabling/disabling PRBS, place the channels in analog reset. For details about placing the channel in analog reset, refer to "Model 1: Default Model" and "Model 2: Acknowledgment Model" in the *Resetting Transceiver Channels* chapter.

If you are reconfiguring:

  - PLLs—Place the channel transmitter associated with the PLL in reset (analog).
  - TX simplex channels—Place the TX channels being reconfigured in reset (analog).
  - RX simplex channels—Place the RX channels being reconfigured in reset (analog).
  - Duplex channels—Place the channel TX and RX being reconfigured in reset (analog).
7. Check for internal configuration bus arbitration. If PreSICE has control, request bus arbitration, otherwise go to the next step. For more details, refer to the "Arbitration" section.
8. Perform the necessary reconfiguration using the flow described in the following sections:
  - *Direct Reconfiguration Flow*
  - *Native PHY or PLL IP Guided Reconfiguration Flow*
  - *Reconfiguration Flow for Special Cases*
9. Perform all necessary reconfiguration. If reconfiguration involved data rate or protocol mode changes, then you may have to reconfigure the PMA analog parameters of the channels. Refer to the *Changing PMA Analog Parameters* section for more details.
10. If reconfiguration involved data rate or protocol mode change, then request recalibration and wait for the calibration to complete. Calibration is complete when \*\_cal\_busy is deasserted. For more details about calibration registers and the steps to perform recalibration, refer to the *Calibration* chapter.

If you reconfigured:

  - PLL for data rate change—you must recalibrate the PLL and the channel TX.
  - TX simplex channel for data rate change—you must recalibrate the channel TX.
  - RX simplex channel for data rate change—you must recalibrate the channel RX.
  - Duplex channel for data rate change—you must recalibrate the channel TX and RX.
11. Release the channel analog resets. For details about placing the channel in reset, refer to "Model 1: Default Model" and "Model 2: Acknowledgment Model" in the *Resetting Transceiver Channels* chapter.

If you reconfigured:

- PLLs—Release the reset (analog) of the channel transmitters associated with the PLL reconfigured.
- TX simplex channels—Release the reset (analog) of the TX channels reconfigured.
- RX simplex channels—Release the reset (analog) of the RX channels reconfigured.
- Duplex channels—Release the reset (analog) of the TX and RX channels reconfigured.

12. Release the channel digital resets either simultaneously or one after another. For details about releasing the channel resets, refer to "Model 1: Default Model" and "Model 2: Acknowledgment Model" in the *Resetting Transceiver Channels* chapter. (The figures in these sections are for analog resets, but they also contain timing information about digital resets.)

If you reconfigured:

- PLLs—Release the reset (digital) of the channel transmitters associated with the PLL reconfigured.
- TX simplex channels—Release the reset (digital) of the TX channels reconfigured.
- RX simplex channels—Release the reset (digital) of the RX channels reconfigured.
- Duplex channels—Release the reset (digital) of the TX and RX channels reconfigured.

**Note:**

You cannot merge multiple reconfiguration interfaces across multiple IP blocks (merging independent instances of simplex TX/RX into the same physical location or merging separate CMU PLL and TX channel into the same physical location) when you use the optional reconfiguration logic soft control registers.

#### Related Information

- [Resetting Transceiver Channels](#) on page 428
- [Model 1: Default Model](#) on page 430
- [Model 2: Acknowledgment Model](#) on page 439
- [Direct Reconfiguration Flow](#) on page 531
- [Native PHY IP or PLL IP Core Guided Reconfiguration Flow](#) on page 531
- [Reconfiguration Flow for Special Cases](#) on page 533
- [Changing PMA Analog Parameters](#) on page 539
- [Calibration](#) on page 579
- [Arbitration](#) on page 524
- [Arria 10 Transceiver Register Map](#)

## 6.9. Direct Reconfiguration Flow

Use this flow to perform dynamic reconfiguration when you know exactly which parameter and value to change for the transceiver channel or PLL. You can use this flow to change the PMA analog settings, enable/disable PRBS generator, and checker hard blocks of the transceiver channel.

To perform dynamic reconfiguration using direct reconfiguration flow:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Read from the desired feature address.
3. Perform a read-modify-write to feature address with a valid value.
4. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

### Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528
- [Changing PMA Analog Parameters](#) on page 539
- [Using Data Pattern Generators and Checkers](#) on page 562
- [Resetting Transceiver Channels](#) on page 428
- [Calibration](#) on page 579
- [Arria 10 Transceiver Register Map](#)

## 6.10. Native PHY IP or PLL IP Core Guided Reconfiguration Flow

Use the Native PHY IP core or PLL IP core guided reconfiguration flow to perform dynamic reconfiguration when you need to change multiple parameters or parameters in multiple addresses for the transceiver channel or PLL. You can use this flow to change data rates, change clock divider values, or switch from one PCS datapath to another. You must generate the required configuration files for the base and modified Transceiver Native PHY IP core or PLL IP core configurations.

The configuration files contain addresses and bit values of the corresponding configuration. Compare the differences between the base and modified configuration files. The differences between these files indicate the addresses and bit values that must change to switch from one configuration to another. Perform read-modify-writes for the bit values that are different from the base configuration to obtain the modified configuration.

To perform dynamic reconfiguration using the IP Guided Reconfiguration Flow:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to all addresses and bit values that are different from the base configuration.
3. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

**Note:**

If reconfiguration involved data rate or protocol mode changes, you may need to reconfigure the PMA analog parameters of the channels. Refer to the *Changing PMA Analog Parameters* section for more details.

The bit values that must be changed to obtain the new configuration may span across multiple addresses, such as when switching between Standard, Enhanced, and PCS Direct data paths. It is difficult to manually compare these values for the base and modified configurations and then build logic to stream the different values in the modified configuration. You can use the multiple profiles feature of the Native PHY/ATX PLL IP cores to store the parameter settings (MIF configuration file) to memory. With the configuration content saved, you can read from the memory and write the content to the target channel for reconfiguration. Optionally, you can also use the embedded reconfiguration streamer feature of the Native PHY/ATX PLL IP cores, which includes the logic to store the individual profile information and logic to perform streaming. Using the embedded reconfiguration streamer, you can reduce the number of read-modify-write operations to obtain the modified configuration.

To perform dynamic reconfiguration using the Embedded Reconfiguration Streamer:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address x340 with the desired profile select, broadcast bit (applicable for Native PHY only), and configuration load bit set accordingly. For example, to stream profile 1 to a channel, perform a read-modify-write to bits x340[2:0] with 3'b001, bit x340[6] with 1'b0 to disable broadcasting, and bit x340[7] with 1'b1 to initiate streaming.
3. Poll the streamer busy bit at address x341 (x341[0]) at regular intervals. When the busy bit is 1'b0, the reconfiguration is complete.
4. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

**Note:**

If reconfiguration involved data rate or protocol mode changes, you may need to reconfigure the PMA analog parameters of the channels. Refer to the *Changing PMA Analog Parameters* section for more details.

**Figure 276. Timing Diagram for Embedded Streamer Reconfiguration**



### Related Information

- [Arbitration](#) on page 524
- [Changing PMA Analog Parameters](#) on page 539
- [Steps to Perform Dynamic Reconfiguration](#) on page 528

- [Resetting Transceiver Channels](#) on page 428
- [Calibration](#) on page 579

## 6.11. Reconfiguration Flow for Special Cases

Dynamic reconfiguration can be performed on logical operations such as switching between multiple transmit PLLs or multiple reference clocks. In these cases, configuration files alone cannot be used. Configuration files are generated during IP generation and do not contain information on the placement of PLLs or reference clocks.

To perform dynamic reconfiguration on logical operations, you must use lookup registers that contain information about logical index to physical index mapping. Lookup registers are read-only registers. Use these lookup registers to perform a read-modify-write to the selection MUXes to switch between PLLs or reference clocks.

To perform dynamic reconfiguration using reconfiguration flow for special cases:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Read from the desired lookup register. Refer to the *Switching Transmitter PLL* and *Switching Reference Clocks* sections for information about lookup registers.
3. Perform Logical Encoding (only required for Transmitter PLL switching).
4. Perform read-modify-write to the required feature address with the desired/encoded value.
5. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

### Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528
- [Switching Transmitter PLL](#) on page 533
- [Switching Reference Clocks](#) on page 535
- [Resetting Transceiver Channels](#) on page 428
- [Calibration](#) on page 579

### 6.11.1. Switching Transmitter PLL

Dynamically switching data rates increases system flexibility to support multiple protocols. You can change the transceiver channel data rate by switching from one transmit PLL to another. To switch between transmit PLLs, you must reconfigure the local CGB MUX select lines of the channel by performing a channel reconfiguration. You can clock transceiver channels with up to four different transmitter PLLs. You can use the reconfiguration interface on the Native PHY IP core to specify which PLL drives the transceiver channel. The PLL switching method is the same, regardless of the number of transmitter PLLs involved.

Before initiating the PLL switch procedure, ensure that your Transceiver Native PHY instance defines more than one transmitter PLL input. Specify the **Number of TX PLL clock inputs per channel** parameter on the **TX PMA** tab during Transceiver Native PHY parameterization.

The following table shows the addresses and bits for transmitter PLL switching. The number of exposed tx\_serial\_clk bits varies according to the number of transmitter PLLs you specify. Use the Native PHY reconfiguration interface for this operation.

**Table 270. Register Map for Switching Transmitter PLLs**

| Transceiver Native PHY Port | Description                                                                                                  | Address                 | Bits  |
|-----------------------------|--------------------------------------------------------------------------------------------------------------|-------------------------|-------|
| tx_serial_clk0              | Represents logical PLL0. Lookup register x117[3:0] stores the mapping from logical PLL0 to the physical PLL. | 0x117 (Lookup Register) | [3:0] |
| tx_serial_clk1              | Represents logical PLL1. Lookup register x117[7:4] stores the mapping from logical PLL1 to the physical PLL. | 0x117 (Lookup Register) | [7:4] |
| tx_serial_clk2              | Represents logical PLL2. Lookup register x118[3:0] stores the mapping from logical PLL2 to the physical PLL. | 0x118 (Lookup Register) | [3:0] |
| tx_serial_clk3              | Represents logical PLL3. Lookup register x118[7:4] stores the mapping from logical PLL3 to the physical PLL. | 0x118 (Lookup Register) | [7:4] |
| N/A                         | PLL selection MUX                                                                                            | 0x111                   | [7:0] |

When performing a PLL switch, you must specify the lookup register address and bit values you want to switch to. The following procedure describes selection of a specific transmitter PLL when more than one PLL is connected to a channel. To change the data rate of the CDR, follow the detailed steps for reconfiguring channel and PLL blocks. After determining the logical PLL to switch to, follow this procedure to switch to the desired transmitter PLL:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Read from the appropriate lookup register address (refer to [Table 270](#) on page 534) and save the required 4-bit pattern. For example, switching to logical PLL1 requires saving bits [7:4] of address 0x117.
3. Encode the 4-bit value read in the previous step into an 8-bit value according to the following table:

**Table 271. Logical PLL Encoding**

| 4-bit Logical PLL Bits | 8-bit Mapping to Address 0x111                                                                                                              |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| [3..0]                 | {~logical_PLL_offset_readdata[3],<br>logical_PLL_offset_readdata[1:0],logical_PLL_offset_readdata[3],<br>logical_PLL_offset_readdata[3:0] } |
| [7..4]                 | {~logical_PLL_offset_readdata[7],<br>logical_PLL_offset_readdata[5:4],logical_PLL_offset_readdata[7],<br>logical_PLL_offset_readdata[7:4] } |

**Note:** For example, if reconfiguring to logical PLL1 then bits [7:4] are encoded to an 8-bit value {~bit[7], bit[5:4], bit[7], bit[7:4]}.

4. Perform a read-modify-write to bits[7:0] of address 0x111 using the encoded 8-bit value.
5. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

#### Related Information

[Steps to Perform Dynamic Reconfiguration](#) on page 528

### 6.11.2. Switching Reference Clocks

You can dynamically switch the input clock source for the ATX PLL, the fPLL, the CDR, and the CMU.

#### 6.11.2.1. ATX Reference Clock Switching

You can use the reconfiguration interface on the ATX PLL instance to specify which reference clock source drives the ATX PLL. The ATX PLL supports clocking up to five different reference clock sources. The flow to select between the different reference clock sources is independent of the number of transmitter PLLs specified in the Parameter Editor.

Before initiating a reference clock switch, ensure that your ATX PLL instance defines more than one reference clock source. Specify the **Number of PLL reference clocks** parameter on the **PLL** tab during ATX PLL parameterization.

The following table shows the addresses and bits for switching between ATX PLL reference clock inputs. The number of exposed `pll_refclk` ports varies according to the number of reference clocks you specify. Use the ATX PLL reconfiguration interface for this operation.

**Table 272. Register Map for Switching ATX PLL Reference Clock Inputs**

| Transceiver ATX PLL Port | Description                                                                                                                                                                 | Address                 | Bits  |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------|
| <code>pll_refclk0</code> | Represents logical <code>refclk0</code> . Lookup register <code>x113[7:0]</code> stores the mapping from logical <code>refclk0</code> to the physical <code>refclk</code> . | 0x113 (Lookup Register) | [7:0] |
| <code>pll_refclk1</code> | Represents logical <code>refclk1</code> . Lookup register <code>x114[7:0]</code> stores the mapping from logical <code>refclk1</code> to the physical <code>refclk</code> . | 0x114 (Lookup Register) | [7:0] |
| <code>pll_refclk2</code> | Represents logical <code>refclk2</code> . Lookup register <code>x115[7:0]</code> stores the mapping from logical <code>refclk2</code> to the physical <code>refclk</code> . | 0x115 (Lookup Register) | [7:0] |
| <code>pll_refclk3</code> | Represents logical <code>refclk3</code> . Lookup register <code>x116[7:0]</code> stores the mapping from logical <code>refclk3</code> to the physical <code>refclk</code> . | 0x116 (Lookup Register) | [7:0] |
| <code>pll_refclk4</code> | Represents logical <code>refclk4</code> . Lookup register <code>x117[7:0]</code> stores the mapping from logical <code>refclk4</code> to the physical <code>refclk</code> . | 0x117 (Lookup Register) | [7:0] |
| N/A                      | ATX refclk selection MUX.                                                                                                                                                   | 0x112                   | [7:0] |

When performing a reference clock switch, you must specify the lookup register address and respective bits of the replacement clock. After determining the ATX PLL, follow this procedure to switch to the selected reference clock:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Read from the lookup register address and save the required 8-bit pattern. For example, switching to logical `refclk2` requires use of bits[7:0] at address 0x115.
3. Perform a read-modify-write to bits [7:0] at address 0x112 using the 8-bit value obtained from the lookup register.
4. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

#### Related Information

[Steps to Perform Dynamic Reconfiguration](#) on page 528

#### 6.11.2.2. fPLL Reference Clock Switching

You can use the reconfiguration interface on the fPLL instance to specify which reference clock source drives the fPLL. The fPLL supports clocking by up to five different reference clock sources. The flow to select between the different reference clock sources is independent of the number of transmitter PLLs specified in the reconfiguration interface.

Before initiating a reference clock switch, ensure that your fPLL instance defines more than one reference clock source. Specify the **Number of PLL reference clocks** parameter on the **PLL** tab during fPLL parameterization.

The following table shows the addresses and bits for switching between fPLL reference clock inputs. The number of exposed `pll_refclk` ports varies according to the number of reference clocks you specify. Use the fPLL reconfiguration interface for this operation.

**Table 273. Register Map for Switching fPLL Reference Clock Inputs**

| Transceiver fPLL Port    | Description                                                                                                                                                                                   | Address                 | Bits  |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------|
| <code>pll_refclk0</code> | Represents logical <code>refclk0</code> for MUX_0. Lookup register <code>x117[7:0]</code> stores the mapping from logical <code>refclk0</code> to the physical <code>refclk</code> for MUX_0. | 0x117 (Lookup Register) | [7:0] |
| <code>pll_refclk1</code> | Represents logical <code>refclk1</code> for MUX_0. Lookup register <code>x118[7:0]</code> stores the mapping from logical <code>refclk1</code> to the physical <code>refclk</code> for MUX_0. | 0x118 (Lookup Register) | [7:0] |
| <code>pll_refclk2</code> | Represents logical <code>refclk2</code> for MUX_0. Lookup register <code>x119[7:0]</code> stores the mapping from logical <code>refclk2</code> to the physical <code>refclk</code> for MUX_0. | 0x119 (Lookup Register) | [7:0] |
| <code>pll_refclk3</code> | Represents logical <code>refclk3</code> for MUX_0. Lookup register <code>x11A[7:0]</code> stores the mapping from logical <code>refclk3</code> to the physical <code>refclk</code> for MUX_0. | 0x11A (Lookup Register) | [7:0] |
| <code>pll_refclk4</code> | Represents logical <code>refclk4</code> for MUX_0. Lookup register <code>x11B[7:0]</code> stores the mapping from logical <code>refclk4</code> to the physical <code>refclk</code> for MUX_0. | 0x11B (Lookup Register) | [7:0] |
| <i>continued...</i>      |                                                                                                                                                                                               |                         |       |

| Transceiver fPLL Port | Description                                                                                                                               | Address                 | Bits  |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------|
| N/A                   | fPLL refclk selection MUX_0.                                                                                                              | 0x114                   | [7:0] |
| pll_refclk0           | Represents logical refclk0 for MUX_1. Lookup register x11D[7:0] stores the mapping from logical refclk0 to the physical refclk for MUX_1. | 0x11D (Lookup Register) | [7:0] |
| pll_refclk1           | Represents logical refclk1 for MUX_1. Lookup register x11E[7:0] stores the mapping from logical refclk1 to the physical refclk for MUX_1. | 0x11E (Lookup Register) | [7:0] |
| pll_refclk2           | Represents logical refclk2 for MUX_1. Lookup register x11F[7:0] stores the mapping from logical refclk2 to the physical refclk for MUX_1. | 0x11F (Lookup Register) | [7:0] |
| pll_refclk3           | Represents logical refclk3 for MUX_1. Lookup register x120[7:0] stores the mapping from logical refclk3 to the physical refclk for MUX_1. | 0x120 (Lookup Register) | [7:0] |
| pll_refclk4           | Represents logical refclk4 for MUX_1. Lookup register x121[7:0] stores the mapping from logical refclk4 to the physical refclk for MUX_1. | 0x121 (Lookup Register) | [7:0] |
| N/A                   | fPLL refclk selection MUX_1.                                                                                                              | 0x11C                   | [7:0] |

Specify the logical reference clock and respective address and bits of the replacement clock when performing a reference clock switch. Follow this procedure to switch to the selected reference clock:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Read from the lookup register for MUX 0 and save the required 8-bit pattern. For example, switching to logical refclk3 requires use of bits[7:0] at lookup register 0x11A.
3. Perform a read-modify-write to bits [7:0] at address 0x114 using the 8-bit value obtained from the lookup register.
4. Read from the lookup register for MUX 1 and save the required 8-bit pattern. For example, switching to logical refclk3 requires use of bits[7:0] at lookup register 0x120.
5. Perform a read-modify-write to bits [7:0] at address 0x11C using the 8-bit value obtained from the lookup register.
6. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

#### Example 1:

Switching from pll\_refclk0 to pll\_refclk1, you need to read-modify-write to both fPLL refclk selection MUX\_0 and MUX\_1:

1. Modify MUX\_0 value:
  - Read from 0x118[7:0]
  - Write the value from 0x118 [7:0] to 0x114 [7:0]
2. Modify MUX\_1 value:
  - Read from 0x11E [7:0]
  - Write the value read from 0x11E [7:0] to 0x11C [7:0]

### Example 2:

Switching from `pll_refclk2` to `pll_refclk3`, you need to read-modify-write to both fPLL refclk selection MUX\_0 and MUX\_1:

1. Modify MUX\_0 value:
  - Read from `0x11A [7:0]`
  - Write the value read from `0x11A [7:0]` to `0x114 [7:0]`
2. Modify MUX\_1 value:
  - Read from `0x120 [7:0]`
  - Write the value read from `0x120 [7:0]` to `0x11C [7:0]`

### Related Information

[Steps to Perform Dynamic Reconfiguration](#) on page 528

#### 6.11.2.3. CDR and CMU Reference Clock Switching

You can use the reconfiguration interface to specify which reference clock source drives the CDR and CMU PLL. The CDR and CMU support clocking by up to five different reference clock sources.

Before initiating a reference clock switch, ensure that your CDR and CMU defines more than one reference clock source. For the CDR, specify the parameter on the **RX PMA** tab during the Native PHY IP parameterization. For the CMU, specify the **Number of PLL reference clocks** under the **PLL** tab when parameterizing the CMU PLL.

The following table describes the addresses and bits for switching CDR and CMU reference clock inputs. The number of exposed `rx_cdr_refclk` (CDR) or `pll_refclk` (CMU) varies according to the number of reference clocks you specify. Use the CMU reconfiguration interface for switching the CMU reference clock.

**Table 274. Register Map for Switching CDR Reference Clock Inputs**

| Native PHY Port          | Description                                                                                                                                                                 | Address                 | Bits  |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------|
| <code>cdr_refclk0</code> | Represents logical <code>refclk0</code> . Lookup register <code>x16A[7:0]</code> stores the mapping from logical <code>refclk0</code> to the physical <code>refclk</code> . | 0x16A (Lookup Register) | [7:0] |
| <code>cdr_refclk1</code> | Represents logical <code>refclk1</code> . Lookup register <code>x16B[7:0]</code> stores the mapping from logical <code>refclk1</code> to the physical <code>refclk</code> . | 0x16B (Lookup Register) | [7:0] |
| <code>cdr_refclk2</code> | Represents logical <code>refclk2</code> . Lookup register <code>x16C[7:0]</code> stores the mapping from logical <code>refclk2</code> to the physical <code>refclk</code> . | 0x16C (Lookup Register) | [7:0] |

*continued...*

| Native PHY Port | Description                                                                                                              | Address                 | Bits  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------|-------------------------|-------|
| cdr_refclk3     | Represents logical refclk3.<br>Lookup register x16D[7:0] stores the mapping from logical refclk3 to the physical refclk. | 0x16D (Lookup Register) | [7:0] |
| cdr_refclk4     | Represents logical refclk4.<br>Lookup register x16E[7:0] stores the mapping from logical refclk4 to the physical refclk. | 0x16E (Lookup Register) | [7:0] |
| N/A             | CDR refclk selection MUX.                                                                                                | 0x141                   | [7:0] |

When performing a reference clock switch, note the logical reference clock to switch to and the respective address and bits. After determining the logical reference clock, follow this procedure to switch to the selected CDR reference clock:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Read from the lookup register and save the required 8-bit pattern. For example, switching to logical refclk3 requires saving bits[7:0] at address 0x16D.
3. Perform a read-modify-write to bits [7:0] at address 0x141 using the 8-bit value obtained from the lookup register.
4. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

#### Related Information

[Steps to Perform Dynamic Reconfiguration on page 528](#)

## 6.12. Changing PMA Analog Parameters

You can use the reconfiguration interface on the Transceiver Native PHY IP core to change the value of PMA analog features.

The PMA analog settings can be broadly divided into the following groups:

- PMA analog settings that are channel or system dependent:
  - These settings may vary from channel to channel based on channel loss or other factors
  - You can set these PMA analog settings based on IBIS-AMI or Advanced Link Analyzer simulations
  - You can set these PMA analog settings using QSF assignments or by performing RMWs to the respective registers
  - These PMA analog settings are not included in the configuration files by default. To include these PMA analog settings in the configuration files, you must enable the **Include PMA Analog settings in configuration files** option in the **Dynamic Reconfirmation** tab of the Transceiver Native PHY IP Parameter Editor. Enabling this feature adds the PMA analog settings specified in the **Analog PMA settings (Optional)** tab of the Native PHY IP Parameter Editor to the configuration files. Even with this option enabled in the Native PHY IP Parameter Editor, you must still specify QSF assignments for your analog settings when compiling your static design. The analog settings selected in the Native PHY IP Parameter Editor are used only to include these settings and their dependent settings in the selected configuration files. For details about optional analog settings, refer to the "Analog PMA Settings (Optional) for Dynamic Reconfiguration" table in the *Ports and Parameters* section. For details about QSF assignments for the analog settings, refer to the *Analog Parameter Settings* chapter.
  - If you do not enable the **Include PMA Analog settings in configuration files** option, then you can change these analog settings by performing RMWs using direct reconfiguration flow

**Table 275. PMA Analog Settings that are Channel or System Dependent**

| PMA Analog Feature | Fitter Report Name                  | Arria 10 Transceiver Register Map Attribute Name |
|--------------------|-------------------------------------|--------------------------------------------------|
| VOD                | vod_output_swing_ctrl               | vod_output_swing_ctrl                            |
| Pre-emphasis       | pre_emp_sign_1st_post_tap           | pre_emp_sign_1st_post_tap                        |
|                    | pre_emp_sign_2nd_post_tap           | pre_emp_sign_2nd_post_tap                        |
|                    | pre_emp_sign_pre_tap_1t             | pre_emp_sign_pre_tap_1t                          |
|                    | pre_emp_sign_pre_tap_2t             | pre_emp_sign_pre_tap_2t                          |
|                    | pre_emp_switching_ctrl_1st_post_tap | pre_emp_switching_ctrl_1st_post_tap              |
|                    | pre_emp_switching_ctrl_2nd_post_tap | pre_emp_switching_ctrl_2nd_post_tap              |
|                    | pre_emp_switching_ctrl_pre_tap_1t   | pre_emp_switching_ctrl_pre_tap_1t                |
|                    | pre_emp_switching_ctrl_pre_tap_2t   | pre_emp_switching_ctrl_pre_tap_2t                |
| CTLE               | eq_dc_gain_trim                     | eq_dc_gain_trim                                  |
|                    | one_stage_enable                    | one_stage_enable                                 |
|                    | eq_bw_sel                           | eq_bw_sel                                        |
|                    | adp_ctle_eqz_1s_sel                 | adp_ctle_eqz_1s_sel                              |
|                    | adp_ctle_acgain_4s                  | adp_ctle_acgain_4s                               |
| VGA                | adp_vga_sel                         | adp_vga_sel                                      |

- PMA analog settings that are device dependent
  - These settings may vary for each transceiver protocol-type and data rate in your design
  - These settings are not included in the configuration files by default. To include these analog settings in the configuration files, you must enable the feature **Include PMA Analog settings in configuration files** under the **Dynamic Reconfiguration** tab of the Transceiver Native PHY IP Parameter Editor. Enabling this feature adds the PMA analog settings specified in the **Analog PMA settings (Optional)** tab of Native PHY IP Parameter Editor to the configuration files. Even with this option enabled in the Native PHY IP Parameter Editor, you must still specify QSF assignments for your analog settings when compiling your static design. The analog settings selected in the Native PHY IP Parameter Editor are used only to include these settings and their dependent settings in the selected configuration files. For details about optional analog settings, refer to the "Analog PMA Settings (Optional) for Dynamic Reconfiguration" table in the *Ports and Parameters* section. For details about QSF assignments for the analog settings, refer to the *Analog Parameter Settings* chapter.
  - If the **Include PMA analog settings in configuration files** option is disabled, then you must set these PMA analog settings. In addition to streaming the configuration files generated by the Native PHY IP Parameter Editor, you must perform RMWs using Direct Reconfiguration Flow to change these PMA analog settings through the Avalon memory-mapped interface reconfiguration
  - The values of all these PMA analog settings that change when changing protocol-type or data rates must be obtained from the respective Fitter reports by performing full compilation for each of the base and target configurations
  - For example, when changing the data rate from A to B, you must first perform a full compile with the data rate configured to A and note the PMA analog settings from the fitter report. Next, you must perform a full compile with data rate configured to B and note the PMA analog settings from the fitter report. If any of these PMA analog settings changed values between the two compiles, you must perform RMWs with the target values to the respective registers after streaming the configuration files.
  - Examples: Slew rate, Equalizer Bandwidth, Compensation Enable

**Table 276. PMA Analog Settings that are Device Dependent**

| PMA Analog Feature              | Fitter Report Name | Arria 10 Transceiver Register Map Attribute Name |
|---------------------------------|--------------------|--------------------------------------------------|
| Slew Rate (TX Buffer)           | Slew_rate_ctrl     | Slew_rate_ctrl                                   |
| Equalizer Bandwidth (RX Buffer) | Eq_bw_sel          | Eq_bw_sel                                        |
| Compensation Enable (TX Buffer) | Compensation_en    | Compensation_en                                  |
| One Stage Enable (RX CTLE)      | One_stage_enable   | One_stage_enable                                 |

#### Related Information

- [Ports and Parameters](#) on page 547
- [Analog Parameter Settings](#) on page 597

### 6.12.1. Changing VOD, Pre-emphasis Using Direct Reconfiguration Flow

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Read from the PMA analog feature address of the channel you want to change. For example, to change pre-emphasis 1st post-tap, read and store the value of address 0x105.
3. Select a valid value for the feature according to the Arria 10 register map. For example, a valid setting for pre-emphasis 1st post-tap has a bit encoding of 5'b00001.
4. Perform a read-modify-write to the address of the PMA analog feature using the valid value. For example, to change the pre-emphasis 1st post-tap, write 5'b00001 to address 0x105.
5. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

**Table 277. Register Map for PMA Analog Feature**

| PMA Analog Feature                       | Address | Bit   | Values                             |
|------------------------------------------|---------|-------|------------------------------------|
| Pre-emphasis 1st post-tap                | 0x105   | [4:0] | 5'b00000 - 5'b11001                |
| Pre-emphasis 1st post-tap polarity       | 0x105   | [6]   | 1'b0 = positive<br>1'b1 = negative |
| Pre-emphasis 2nd post-tap                | 0x106   | [3:0] | 4'b0000 - 4'b1100                  |
| Pre-emphasis 2nd post-tap polarity       | 0x106   | [5]   | 1'b0 = positive<br>1'b1 = negative |
| Pre-emphasis 1st pre-tap                 | 0x107   | [4:0] | 5'b00000 - 5'b10000                |
| Pre-emphasis 1st pre-tap polarity        | 0x107   | [5]   | 1'b0 = positive<br>1'b1 = negative |
| Pre-emphasis 2nd pre-tap                 | 0x108   | [2:0] | 3'b000 - 3'b111                    |
| Pre-emphasis 2nd pre-tap polarity        | 0x108   | [4]   | 1'b0 = positive<br>1'b1 = negative |
| Differential output voltage ( $V_{OD}$ ) | 0x109   | [4:0] | 5'b00000 - 5'b11111                |

The PMA analog settings are governed by a set of rules. Not all combinations of  $V_{OD}$  and pre-emphasis are valid. Please refer to *Arria 10 Pre-Emphasis and Output Swing Settings* for current valid settings. Also, refer to "Analog Parameter Settings" and setup guidelines on post\_tap polarity settings.

#### Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528
- [Arria 10 PMA Architecture](#) on page 459
- [Arria 10 Pre-Emphasis and Output Swing Settings](#)

### 6.12.2. Changing CTLE Settings in Manual Mode Using Direct Reconfiguration Flow

You can use the reconfiguration interface on the Transceiver Native PHY IP core to change the CTLE settings in manual mode.

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Read from the CTLE feature address of the channel you want to change. For example, to change CTLE AC gain in high gain mode, read and store the value of address 0x167[5:1].
3. Select a valid value for the feature according to the Arria 10 register map. For example, a valid setting for CTLE AC Gain has a bit encoding of 5'b00000.
4. Perform a read-modify-write to the address of the CTLE feature using the valid value. For example, to change the CTLE AC gain in high gain mode, write 5'b00000 to address 0x167[5:1].
5. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

**Table 278. Register Map for CTLE Settings**

| CTLE Feature            | Address         | Bits         | Values                                                                                           | Description                                                                                                                               |
|-------------------------|-----------------|--------------|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| One Stage Enable        | 0x11B           | [3]          | 1'b0- Selects Four Stage<br>1'b1- Selects One Stage                                              | Selects the equalizer path as either One Stage or Four Stage mode.                                                                        |
| DC Gain                 | 0x11C,<br>0x11A | [3:0], [7:0] | 12'b000000000000<br>12'b111000000000<br>12'b111111000000<br>12'b111111111000<br>12'b111111111111 | Sets the DC gain values. This register can only be controlled when in Four stage mode.                                                    |
| CTLE AC Gain One Stage  | 0x166           | [4:1]        | 4'b0000- 4'b1111                                                                                 | Sets the AC gain value when one stage mode (High data rate mode) is selected. A higher value means higher peaking by suppressing DC gain. |
| CTLE AC Gain Four Stage | 0x167           | [5:1]        | 5'b00000 – 5'b11100                                                                              | Sets the AC gain value when four stage mode (High gain mode) is selected.                                                                 |
| VGA SEL                 | 0x160           | [3:1]        | 3'b000 – 3'b111                                                                                  | Sets the VGA Gain value                                                                                                                   |

#### Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528
- [Arria 10 PMA Architecture](#) on page 459

### 6.12.3. CTLE Settings in Triggered Adaptation Mode

CTLE triggered adaptation mode should only be used for PCIe Gen3. Refer to the section "How to enable CTLE and DFE" in Chapter *Arria 10 Transceiver PHY Architecture of Arria 10 Transceiver PHY User Guide* for details on using the triggered adaptation mode of CTLE.

User need to change the register bit settings accordingly when moving from PCIe Gen1/2 (CTLE manual, DFE disabled) to PCIe Gen3 (CTLE triggered, DFE disabled) or vice versa. Refer to [Table 279](#) on page 544 for the difference in register bit settings

when moving from CTLE manual, DFE disabled to CTLE triggered, DFE disabled. User need to perform read modify writes to all the register bits that differ through dynamic reconfiguration Avalon memory-mapped interface.

**Table 279. Register Map for CTLE triggered and CTLE manual settings**

| Register Address | Register Bit | Description                           | Value                        |                           |
|------------------|--------------|---------------------------------------|------------------------------|---------------------------|
|                  |              |                                       | CTLE Triggered, DFE Disabled | CTLE Manual, DFE Disabled |
| 0x123            | 1:1          | Enable Adaptation Slicers             | 1'b1                         | 1'b0                      |
|                  | 2:2          | Enable DFE Fix Tap 8 to 11            | 1'b0                         |                           |
|                  | 3:3          | Enable DFE Fix Tap 4 to 7             | 1'b0                         |                           |
| 0x148            | 0:0          | Enable DFE Fix TAP 1 to 7 Adaptation  | 1'b0                         |                           |
|                  | 1:1          | Enable DFE Fix TAP 8 to 11 Adaptation | 1'b0                         |                           |
|                  | 2:2          | Enable VREF Adaptation                | 1'b1                         | 1'b0                      |
|                  | 3:3          | Enable VGA Adaptation                 | 1'b1                         | 1'b0                      |
|                  | 4:4          | Enable CTLE Adaptation                | 1'b1                         | 1'b0                      |
| 0x14B            | 7:7          | Enable CTLE Adaptation                | 1'b1                         | 1'b0                      |
| 0x15B            | 4:4          | Enable CTLE Adaptation                | 1'b1                         | 1'b0                      |
| 0x15B            | 0:0          | Bypass DFE Fix TAP 1 to 7 Adaptation  | 1'b1                         |                           |
|                  | 2:2          | Bypass DFE Fix TAP 8 to 11 Adaptation | 1'b1                         |                           |
| 0x15E            | 0:0          | Bypass VREF Adaptations               | 1'b0                         | 1'b1                      |
| 0x160            | 0:0          | Bypass VGA Adaptations                | 1'b1                         |                           |
| 0x166            | 0:0          | Bypass Single Stage CTLE              | 1'b0                         | 1'b1                      |
| 0x167            | 0:0          | Bypass 4 Stage CTLE                   | 1'b0                         | 1'b1                      |
| 0x163            | 7:5          | CTLE Adaptation Timer Window          | 3'b111                       |                           |
| 0x14D            | 2:0          | DFE Adaptation Mode                   | 3'b100                       | 3'b111                    |
| 0x124            | 5:5          | Enable DFT                            | 1'b1                         |                           |
| 0x11F            | 5:4          | Eq_bw_sel                             | 2'b01 (Gen3)                 | 2'b00 (Gen1/2)            |

Refer to the "Arria 10 Register Map" and "Arria 10 Adaptation Tool" for details on adaptation registers.

#### Related Information

- [How to Enable CTLE and DFE](#) on page 468
- [Arria 10 Transceiver Register Map](#) on page 576

### 6.12.4. Enabling and Disabling Loopback Modes Using Direct Reconfiguration Flow

Arria 10 devices have three loopback modes:

- Serial Loopback
- Reverse Serial Loopback (Pre-CDR)
- Reverse Serial Loopback (Post-CDR)

The loopback mode can be dynamically reconfigured by accessing the register space.

#### Serial Loopback Mode

In serial loopback mode, a path exists between the serializer of the transmitter and the CDR of the receiver, so that the data from the CDR is recovered from the serializer while the data from the receiver serial input pin is ignored. You can enable or disable this mode.

**Figure 277. Serial Loopback Mode**



To enable serial loopback mode:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address 0x2E1 to set bit 0 to 1'b1
3. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

To disable serial loopback mode:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address 0x2E1 to set bit 0 to 1'b0
3. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

You can also enable the serial loopback mode by turning on **Enable rx\_serialpbken port** in the Native PHY IP Parameter Editor and driving the port to 1'b1.

### Reverse Serial Loopback Mode (Pre-CDR)

In the pre-CDR mode, data received through the RX input buffer is looped back to the TX output buffer. You can enable the reverse serial loopback mode by performing read-modify-write to the following registers.

**Figure 278. Reverse Serial Loopback Mode (Pre-CDR)**



**Table 280. Bit Values to Be Set**

| Address    | Bit Values |
|------------|------------|
| 0x137[7]   | 1'b1       |
| 0x13C[7]   | 1'b0       |
| 0x132[5:4] | 2'b00      |
| 0x142[4]   | 1'b1       |
| 0x11D[0]   | 1'b1       |

### Reverse Serial Loopback Mode (Post-CDR)

In the post-CDR mode, received data passes through the RX CDR and then loops back to the TX output buffer. Perform read-modify-write to the following registers to enable this mode.

**Figure 279. Reverse Serial Loopback Mode (Post-CDR)**



**Table 281. Bit Values to Be Set**

| Address    | Bit Values |
|------------|------------|
| 0x137[7]   | 1'b0       |
| 0x13C[7]   | 1'b1       |
| 0x132[5:4] | 2'b01      |
| 0x142[4]   | 1'b0       |
| 0x11D[0]   | 1'b0       |

#### Disabling Reverse Serial Loopback Mode (Pre-CDR and Post-CDR)

To disable reverse-serial loopback mode, set the address bits to the following values, by performing read-modify-write.

**Table 282. Bit Values to Be Set**

| Address    | Bit Values |
|------------|------------|
| 0x137[7]   | 1'b0       |
| 0x13C[7]   | 1'b0       |
| 0x132[5:4] | 2'b00      |
| 0x142[4]   | 1'b0       |
| 0x11D[0]   | 1'b0       |

#### Related Information

[Steps to Perform Dynamic Reconfiguration](#) on page 528

## 6.13. Ports and Parameters

The reconfiguration interface is integrated in the Native PHY instance and the TX PLL instances. Instantiate the Native PHY and the TX PLL IP cores in Qsys by clicking **Tools > IP Catalog**. You can define parameters for IP cores by using the IP core-specific parameter editor. To expose the reconfiguration interface ports, select the **Enable dynamic reconfiguration** option when parameterizing the IP core.

You can share the reconfiguration interface among all the channels by turning on **Share reconfiguration interface** when parameterizing the IP core. When this option is enabled, the IP core presents a single reconfiguration interface for dynamic reconfiguration of all channels. Address bits [9:0] provide the register address in the reconfiguration space of the selected channel. The remaining address bits of the reconfiguration address specify the selected logical channel. For example, if there are four channels in the Native PHY IP instance, `reconfig_address[9:0]` specifies the address and `reconfig_address[11:10]` are binary encoded to specify the four channels. For example, 2'b01 in `reconfig_address[11:10]` specifies logical channel 1.

The following figure shows the signals available when the Native PHY IP core is configured for four channels and the **Share reconfiguration interface** option is enabled.

**Figure 280. Signals Available with Shared Native PHY Reconfiguration Interface**

**Table 283. Reconfiguration Interface Ports with Shared Native PHY Reconfiguration Interface**

The reconfiguration interface ports when **Share reconfiguration interface** is enabled. <N> represents the number of channels.

| Port Name                     | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| reconfig_clk                  | Input     | N/A          | Avalon clock. The clock frequency is 100-125 MHz.                                                                                                                                                                                                                                                                                                                                                   |
| reconfig_reset                | Input     | reconfig_clk | Resets the Avalon interface. Asynchronous to assertion and synchronous to deassertion.                                                                                                                                                                                                                                                                                                              |
| reconfig_write                | Input     | reconfig_clk | Write enable signal. Signal is active high.                                                                                                                                                                                                                                                                                                                                                         |
| reconfig_read                 | Input     | reconfig_clk | Read enable signal. Signal is active high.                                                                                                                                                                                                                                                                                                                                                          |
| reconfig_address[log2<N>+9:0] | Input     | reconfig_clk | Address bus. The lower 10 bits specify address and the upper bits specify the channel.                                                                                                                                                                                                                                                                                                              |
| reconfig_writedata[31:0]      | Input     | reconfig_clk | A 32-bit data write bus. Data to be written into the address indicated by reconfig_address.                                                                                                                                                                                                                                                                                                         |
| reconfig_readdata[31:0]       | Output    | reconfig_clk | A 32-bit data read bus. Valid data is placed on this bus after a read operation. Signal is valid after reconfig_waitrequest goes high and then low.                                                                                                                                                                                                                                                 |
| reconfig_waitrequest          | Output    | reconfig_clk | A one-bit signal that indicates the Avalon interface is busy. Keep the Avalon command asserted until the interface is ready to proceed with the read/write transfer. The behavior of this signal depends on whether the feature <b>Separate reconfig_waitrequest from the status of AVMM arbitration with PreSICE</b> is enabled or not. For more details, refer to the <i>Arbitration</i> section. |

When **Share reconfiguration interface** is off, the Native PHY IP core provides an independent reconfiguration interface for each channel. For example, when a reconfiguration interface is not shared for a four-channel Native PHY IP instance, reconfig\_address[9:0] corresponds to the reconfiguration address bus of logical channel 0, reconfig\_address[19:10] correspond to the reconfiguration address bus of logical channel 1, reconfig\_address[29:20] corresponds to the reconfiguration address bus of logical channel 2, and reconfig\_address[39:30] correspond to the reconfiguration address bus of logical channel 3.

The following figure shows the signals available when the Native PHY is configured for four channels and the **Share reconfiguration interface** option is not enabled.

**Figure 281. Signals Available with Independent Native PHY Reconfiguration Interfaces**



**Table 284. Reconfiguration Interface Ports with Independent Native PHY Reconfiguration Interfaces**

The reconfiguration interface ports when **Share reconfiguration interface** is disabled. <N> represents the number of channels.

| Port Name                    | Direction | Clock Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------|-----------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| reconfig_clk[N-1:0]          | Input     | N/A          | Avalon clock for each channel. The clock frequency is 100-125 MHz.                                                                                                                                                                                                                                                                                                                                                   |
| reconfig_reset[N-1:0]        | Input     | reconfig_clk | Resets the Avalon interface for each channel. Asynchronous to assertion and synchronous to deassertion.                                                                                                                                                                                                                                                                                                              |
| reconfig_write[N-1:0]        | Input     | reconfig_clk | Write enable signal for each channel. Signal is active high.                                                                                                                                                                                                                                                                                                                                                         |
| reconfig_read[N-1:0]         | Input     | reconfig_clk | Read enable signal for each channel. Signal is active high.                                                                                                                                                                                                                                                                                                                                                          |
| reconfig_address[N*10-1:0]   | Input     | reconfig_clk | A 10-bit address bus for each channel.                                                                                                                                                                                                                                                                                                                                                                               |
| reconfig_writedata[N*32-1:0] | Input     | reconfig_clk | A 32-bit data write bus for each channel. Data to be written into the address indicated by the corresponding address field in reconfig_address.                                                                                                                                                                                                                                                                      |
| reconfig_readdata[N*32-1:0]  | Output    | reconfig_clk | A 32-bit data read bus for each channel. Valid data is placed on this bus after a read operation. Signal is valid after waitrequest goes high and then low.                                                                                                                                                                                                                                                          |
| reconfig_waitrequest[N-1:0]  | Output    | reconfig_clk | A one-bit signal for each channel that indicates the Avalon interface is busy. Keep the Avalon command asserted until the interface is ready to proceed with the read/write transfer. The behavior of this signal depends on whether the feature <b>Separate reconfig_waitrequest from the status of AVMM arbitration with PreSICE</b> is enabled or not. For more details, refer to the <i>Arbitration</i> section. |

**Table 285. Avalon Interface Parameters**

The following parameters are available in the **Dynamic Reconfiguration** tab of the Transceiver Native PHY and TX PLL parameter editors.

**Note:** The Native PHY and the PLL IP Parameter Editors give an error or warning message if any of the parameter selections violate the legality checks.

| Parameter                                                                             | Value          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------------------------------------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable dynamic reconfiguration</b>                                                 | On / Off       | Available in Native PHY and TX PLL IP parameter editors. Enables the reconfiguration interface. Off by default. The reconfiguration interface is exposed when this option is enabled.                                                                                                                                                                                                                                                                                                                                        |
| <b>Share reconfiguration interface</b>                                                | On / Off       | Available in Native PHY IP parameter editor only. Enables you to use a single reconfiguration interface to control all channels. Off by default. If enabled, the uppermost bits of <code>reconfig_address</code> identifies the active channel. The lower 10 bits specify the reconfiguration address. Binary encoding is used to identify the active channel (available only for Transceiver Native PHY). Enable this option if the Native PHY is configured with more than one channel.                                    |
| <b>Enable Native PHY Debug Master Endpoint</b>                                        | On / Off       | Available in Native PHY and TX PLL IP parameter editors. When enabled, the Native PHY Debug Master Endpoint (NPDME) is instantiated and has access to the Avalon memory-mapped interface of the Native PHY. You can access certain test and debug functions using System Console with the NPDME. Refer to the <i>Embedded Debug Features</i> section for more details about NPDME.                                                                                                                                           |
| <b>Separate reconfig_waitrequest from the status of AVMM arbitration with Presice</b> | On / Off       | When enabled, <code>reconfig_waitrequest</code> do not indicate the status of Avalon memory-mapped interface arbitration with PreSICE. The Avalon memory-mapped interface arbitration status is reflected in a soft status register bit. This feature requires that the <b>Enable control and status registers</b> feature under <b>Optional Reconfiguration Logic</b> be enabled. Refer to <i>Arbitration</i> for more details on this feature. Refer to the <i>Calibration</i> chapter for more details about calibration. |
| <b>Enable capability registers</b>                                                    | On / Off       | Available in Native PHY and TX PLL IP parameter editors. Enables capability registers. These registers provide high-level information about the transceiver channel's /PLL's configuration.                                                                                                                                                                                                                                                                                                                                  |
| <b>Set user-defined IP identifier</b>                                                 | User-specified | Available in Native PHY and TX PLL IP parameter editors. Sets a user-defined numeric identifier that can be read from the <code>user_identifier</code> offset when the capability registers are enabled.                                                                                                                                                                                                                                                                                                                     |
| <b>Enable control and status registers</b>                                            | On / Off       | Available in Native PHY and TX PLL IP parameter editors. Enables soft registers for reading status signals and writing control signals on the PHY/PLL interface through the NPDME or reconfiguration interface.                                                                                                                                                                                                                                                                                                              |
| <b>Enable PRBS soft accumulators</b>                                                  | On / Off       | Available in Native PHY IP parameter editor only. Enables soft logic to perform PRBS bit and error accumulation when using the hard PRBS generator and checker.                                                                                                                                                                                                                                                                                                                                                              |
| <b>Configuration file prefix</b>                                                      | User-specified | Available in Native PHY and TX PLL IP parameter editors. Specifies the file prefix used for generating configuration files. Use a unique prefix for configuration files for each variant of the Native PHY and PLL.                                                                                                                                                                                                                                                                                                          |
| <b>Generate SystemVerilog package file</b>                                            | On / Off       | Available in Native PHY and TX PLL IP parameter editors. Creates a SystemVerilog package file that contains the current configuration data values for all reconfiguration addresses. Disabled by default.                                                                                                                                                                                                                                                                                                                    |
| <b>Generate C header file</b>                                                         | On / Off       | Available in Native PHY and TX PLL IP parameter editors. Creates a C header file that contains the current configuration data values for all reconfiguration addresses. Disabled by default.                                                                                                                                                                                                                                                                                                                                 |

*continued...*

| Parameter                                                     | Value    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Generate MIF (Memory Initialize File)</b>                  | On / Off | Available in Native PHY and TX PLL IP parameter editors. Creates a MIF file that contains the current configuration data values for all reconfiguration addresses. Disabled by default.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Include PMA analog settings in the configuration files</b> | On / Off | Available in Native PHY IP parameter editor only. When enabled, the IP allows you to configure the analog settings for the PMA. These settings are included in your generated configuration files.<br><i>Note:</i> Even with this option enabled in the Native PHY IP Parameter Editor, you must still specify QSF assignments for your analog settings when compiling your static design. The analog settings selected in the Native PHY IP Parameter Editor are used only to include these settings and their dependent settings in the selected configuration files. For details about QSF assignments for the analog settings, refer to the <i>Analog Parameter Settings</i> chapter. |
| <b>Enable multiple reconfiguration profiles</b>               | On / Off | Available in Native PHY and ATX PLL IP parameter editors only. Use the Parameter Editor to store multiple configurations. The parameter settings for each profile are tabulated in the Parameter Editor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Enable embedded reconfiguration streamer</b>               | On / Off | Available in Native PHY and ATX PLL IP parameter editors only. Embeds the reconfiguration streamer into the Native PHY/ATX PLL IP cores and automates the dynamic reconfiguration process between multiple predefined configuration profiles.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <b>Generate reduced reconfiguration files</b>                 | On / Off | Available in Native PHY and ATX PLLIP parameter editors only. Enables the Native PHY and ATX PLL IP cores to generate reconfiguration files that contain only the attributes that differ between multiple profiles.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Number of reconfiguration profiles</b>                     | 1 to 8   | Available in Native PHY and ATX PLL IP parameter editors only. Specifies the number of reconfiguration profiles to support when multiple reconfiguration profiles are enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>Selected reconfiguration profile</b>                       | 0 to 7   | Available in Native PHY and ATX PLL IP parameter editors only. Selects which reconfiguration profile to store when you click <b>Store profile</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Store configuration to selected profile</b>                | N/A      | Available in Native PHY and ATX PLL IP parameter editors only. Stores the current Native PHY and ATX PLL parameter settings to the profile specified by the <b>Selected reconfiguration profile</b> parameter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>Load configuration from selected profile</b>               | N/A      | Available in Native PHY and ATX PLL IP parameter editors only. Loads the current Native PHY/ATX PLL IP with parameter settings from the stored profile specified by the <b>Selected reconfiguration profile</b> parameter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>Clear selected profile</b>                                 | N/A      | Available in Native PHY and ATX PLL IP parameter editors only. Clears the stored Native PHY/ATX PLL IP parameter settings for the profile specified by the <b>Selected reconfiguration profile</b> parameter. An empty profile defaults to the current parameter settings of the Native PHY/ATX PLL. In other words, an empty profile reflects the Native PHY/ATX PLL current parameter settings.                                                                                                                                                                                                                                                                                         |
| <b>Clear all profiles</b>                                     | N/A      | Available in Native PHY and ATX PLL IP parameter editors only. Clears the Native PHY/ATX PLL IP parameter settings for all the profiles.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Refresh selected_profile</b>                               | N/A      | Available in Native PHY and ATX PLL IP parameter editors only. Equivalent to clicking the <b>Load configuration from selected profile</b> and <b>Store configuration to selected profile</b> buttons in sequence. This operation loads the parameter settings from stored profile specified by the <b>Selected reconfiguration profile</b> parameter and then stores the parameters back to the profile.                                                                                                                                                                                                                                                                                  |

**Table 286. Analog PMA Settings (Optional) for Dynamic Reconfiguration**

The following parameters are available in the **Analog PMA Settings (Optional)** tab of the Transceiver Native PHY parameter editor. Refer to *Changing PMA Analog Parameters* for more details. Refer to the *Analog Parameter Settings* chapter for details about using the QSF assignments.

| Parameter                                                      | Value                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TX Analog PMA Settings</b>                                  |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>Analog Mode (Load Intel-recommended Default settings)</b>   | <b>cei_11100_1r to xfp_9950</b>  | Selects the analog protocol mode to pre-select the TX pin swing settings (VOD, Pre-emphasis, and Slew Rate). After loading the pre-selected values in the Parameter Editor, if one or more of the individual TX pin swing settings need to be changed, then enable the option to override the Intel-recommended defaults to individually modify the settings. For details about QSF assignments for the analog settings, refer to the <i>Analog Parameter Settings</i> chapter. |
| <b>Override Intel-recommended Analog Mode Default settings</b> | On / Off                         | Enables the option to override the Intel-recommended settings for the selected TX Analog Mode for one or more TX analog parameters.                                                                                                                                                                                                                                                                                                                                             |
| <b>Output Swing Level (VOD)</b>                                | 0-31                             | Selects the transmitter programmable output differential voltage swing.                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>Pre-Emphasis First Pre-Tap Polarity</b>                     | Fir_pre_1t_neg, Fir_pre_1t_pos   | Selects the polarity of the first pre-tap for pre-emphasis.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>Pre-Emphasis First Pre-Tap Magnitude</b>                    | 0-16                             | Selects the magnitude of the first pre-tap for pre-emphasis.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>Pre-Emphasis Second Pre-Tap Polarity</b>                    | Fir_pre_2t_neg, Fir_pre_2t_pos   | Selects the polarity of the second pre-tap for pre-emphasis.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>Pre-Emphasis Second Pre-Tap Magnitude</b>                   | 0-7                              | Selects the magnitude of the second pre-tap for pre-emphasis.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Pre-Emphasis First Post-Tap Polarity</b>                    | Fir_post_1t_neg, Fir_post_1t_pos | Selects the polarity of the first post-tap for pre-emphasis.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <b>Pre-Emphasis First Post-Tap Magnitude</b>                   | 0-25                             | Selects the magnitude of the first post-tap for pre-emphasis.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Pre-Emphasis Second Post-Tap Polarity</b>                   | Fir_post_2t_neg, Fir_post_2t_pos | Selects the polarity of the second post-tap for pre-emphasis.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Pre-Emphasis Second Post-Tap Magnitude</b>                  | 0-12                             | Selects the magnitude of the second post-tap for pre-emphasis.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>Slew Rate Control</b>                                       | slew_r0 to slew_r5               | Selects the slew rate of the TX output signal. Valid values span from slowest to the fastest rate.                                                                                                                                                                                                                                                                                                                                                                              |
| <b>High-Speed Compensation</b>                                 | Enable / Disable                 | Enables the power-distribution network (PDN) induced inter-symbol interference (ISI) compensation in the TX driver. When enabled, it reduces the PDN induced ISI jitter, but increases the power consumption.                                                                                                                                                                                                                                                                   |
| <b>On-Chip termination</b>                                     | r_r1, r_r2                       | Selects the on-chip TX differential termination.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <b>RX Analog PMA settings</b>                                  |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <b>Override Intel-recommended Default settings</b>             | On / Off                         | Enables the option to override the Intel-recommended settings for one or more RX analog parameters. For details about QSF assignments for the analog settings, refer to the <i>Analog Parameter Settings</i> chapter.                                                                                                                                                                                                                                                           |
| <b>CTLE (Continuous Time Linear Equalizer) mode</b>            | non_s1_mode, s1_mode             | Selects between the RX high gain mode (non_s1_mode) or RX high data rate mode (s1_mode) for the Continuous Time Linear Equalizer (CTLE).                                                                                                                                                                                                                                                                                                                                        |

*continued...*

| Parameter                                                         | Value                                             | Description                                                                                                           |
|-------------------------------------------------------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| <b>DC gain control of high gain mode CTLE</b>                     | no_dc_gain to stg4_gain7                          | Selects the DC gain of the Continuous Time Linear Equalizer (CTLE) in high gain mode                                  |
| <b>AC Gain Control of High Gain Mode CTLE</b>                     | radp_ctle_acgain_4s_0 to radp_ctle_acgain_4s_28   | Selects the AC gain of the Continuous Time Linear Equalizer (CTLE) in high gain mode when CTLE is in manual mode      |
| <b>AC Gain Control of High Data Rate Mode CTLE</b>                | radp_ctle_eqz_1s_sel_0 to radp_ctle_eqz_1s_sel_15 | Selects the AC gain of the Continuous Time Linear Equalizer (CTLE) in high data rate mode when CTLE is in manual mode |
| <b>Variable Gain Amplifier (VGA) Voltage Swing Select</b>         | radp_vga_sel_0 to radp_vga_sel_7                  | Selects the Variable Gain Amplifier (VGA) output voltage swing when both the CTLE and DFE blocks are in manual mode.  |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 1 Coefficient</b>  | radp_dfe_fxtap1_0 to radp_dfe_fxtap1_127          | Selects the coefficient of the fixed tap 1 of the Decision Feedback Equalizer (DFE) when operating in manual mode.    |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 2 Coefficient</b>  | radp_dfe_fxtap2_0 to radp_dfe_fxtap2_127          | Selects the coefficient of the fixed tap 2 of the Decision Feedback Equalizer (DFE) when operating in manual mode.    |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 3 Coefficient</b>  | radp_dfe_fxtap3_0 to radp_dfe_fxtap3_127          | Selects the coefficient of the fixed tap 3 of the Decision Feedback Equalizer (DFE) when operating in manual mode.    |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 4 Coefficient</b>  | radp_dfe_fxtap4_0 to radp_dfe_fxtap4_63           | Selects the coefficient of the fixed tap 4 of the Decision Feedback Equalizer (DFE) when operating in manual mode.    |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 5 Coefficient</b>  | radp_dfe_fxtap5_0 to radp_dfe_fxtap5_63           | Selects the coefficient of the fixed tap 5 of the Decision Feedback Equalizer (DFE) when operating in manual mode.    |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 6 Coefficient</b>  | radp_dfe_fxtap6_0 to radp_dfe_fxtap6_31           | Selects the coefficient of the fixed tap 6 of the Decision Feedback Equalizer (DFE) when operating in manual mode.    |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 7 Coefficient</b>  | radp_dfe_fxtap7_0 to radp_dfe_fxtap7_31           | Selects the coefficient of the fixed tap 7 of the Decision Feedback Equalizer (DFE) when operating in manual mode.    |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 8 Coefficient</b>  | radp_dfe_fxtap8_0 to radp_dfe_fxtap8_31           | Selects the coefficient of the fixed tap 8 of the Decision Feedback Equalizer (DFE) when operating in manual mode.    |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 9 Coefficient</b>  | radp_dfe_fxtap9_0 to radp_dfe_fxtap9_31           | Selects the coefficient of the fixed tap 9 of the Decision Feedback Equalizer (DFE) when operating in manual mode.    |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 10 Coefficient</b> | radp_dfe_fxtap10_0 to radp_dfe_fxtap10_31         | Selects the coefficient of the fixed tap 10 of the Decision Feedback Equalizer (DFE) when operating in manual mode.   |
| <b>Decision Feedback Equalizer (DFE) Fixed Tap 11 Coefficient</b> | radp_dfe_fxtap11_0 to radp_dfe_fxtap11_31         | Selects the coefficient of the fixed tap 11 of the Decision Feedback Equalizer (DFE) when operating in manual mode.   |
| <b>On-Chip termination</b>                                        | r_ext0, r_r1, r_r2                                | Selects the on-chip RX differential termination.                                                                      |

### Related Information

- [Analog Parameter Settings](#) on page 597
- [Embedded Debug Features](#) on page 556
- [Arbitration](#) on page 524
- [Changing PMA Analog Parameters](#) on page 539
- [Calibration](#) on page 579

## 6.14. Dynamic Reconfiguration Interface Merging Across Multiple IP Blocks

Dynamic reconfiguration interfaces may need to be shared between multiple IP blocks to maximize transceiver channel utilization. The Native PHY provides the ability to create channels that are either simplex or duplex instances. However, each physical transceiver channel in Arria 10 devices is fully duplex.

You can share the reconfiguration interfaces across different IP blocks by manually making a QSF assignment. There are two cases where a dynamic reconfiguration interface might need to be shared between multiple IP blocks:

- Independent instances of simplex receivers and transmitters in the same physical location
- Separate CMU PLL and TX channel in the same physical location

The following example shows one Native PHY IP instance of a TX-only channel and another instance of an RX-only channel.

**Figure 282. Independent Instances of Simplex TX/RX in the Same Physical Location**



The following example shows one Native PHY IP instance of a TX-only channel and an instance of a CMU PLL.

**Figure 283. Separate CMU PLL and TX Channel in the Same Physical Location**



## Rules for Merging Reconfiguration Interfaces Across Multiple IP Cores

To merge reconfiguration interfaces across multiple IP blocks, you must follow these rules:

1. The control signals for the reconfiguration interfaces of the IP blocks must be driven by the same source. The `reconfig_clk`, `reconfig_reset`, `reconfig_write`, `reconfig_read`, `reconfig_address`, and `reconfig_writedata` ports of the two interfaces to be merged must be driven from the same source.
2. You must make a QSF assignment to manually specify which two reconfiguration interfaces are to be merged.
  - a. Use the **XCVR\_RECONFIG\_GROUP** assignment.
  - b. Set the **To** field of the assignment to either the reconfiguration interfaces of the instances to be merged or to the pin names. The reconfiguration interface has the string **twentynm\_hssi\_avmm\_if\_inst**.
  - c. Assign the two instances to be merged to the same reconfiguration group.

You cannot merge multiple reconfiguration interfaces when NPDME, optional reconfiguration logic, or embedded reconfiguration streamer are enabled in the Native PHY IP core. <sup>(63)</sup>

You cannot merge the TX and RX channels when the **Shared reconfiguration interface** parameter is enabled in the Native PHY IP core Parameter Editor. You can merge channels only if the reconfiguration interfaces are independent.

Refer to the following two examples to merge reconfiguration interfaces.

### Example 3. Using reconfiguration interface names

This example shows how to merge a transmit-only Native PHY instance with a receive-only instance using the reconfiguration interface names. These instances are assigned to reconfiguration group 0.

For Native PHY 0—transmit-only instance:

```
set_instance_assignment -name XCVR_RECONFIG_GROUP 0 -to  
topdesign:topdesign_inst|<TX only instance name>*twentynm_hssi_avmm_if_inst*
```

For Native PHY 1—receive-only instance to be merged with Native PHY 0:

```
set_instance_assignment -name XCVR_RECONFIG_GROUP 0 -to  
topdesign:topdesign_inst|<RX only instance name>*twentynm_hssi_avmm_if_inst*
```

### Example 4. Using pin names

This example shows how to merge a transmit-only Native PHY instance with a receive-only instance using pin names. These instances are assigned to reconfiguration group 1.

For Native PHY 0—transmit-only instance:

```
set_instance_assignment -name XCVR_RECONFIG_GROUP 1 -to tx[0]
```

---

<sup>(63)</sup> Please refer to *Calibration* section on how to calibrate when those features are not available.

For Native PHY 1—receive-only instance to be merged with Native PHY 0:

```
set_instance_assignment -name XCVR_RECONFIG_GROUP 1 -to rx[0]
```

#### Related Information

[Calibration](#) on page 579

## 6.15. Embedded Debug Features

**Note:** For details on TTK usage refer to the *Debugging Transceiver Toolkit* chapter.

The Arria 10 Transceiver Native PHY, ATX PLL, fPLL, and CMU PLL IP cores provide the following optional debug features to facilitate embedded test and debug capability:

- Native PHY Debug Master Endpoint (NPDME)
- Optional Reconfiguration Logic

#### Related Information

[Debugging Transceiver Toolkit](#) on page 620

### 6.15.1. Native PHY Debug Master Endpoint

The NPDME is a JTAG-based Avalon memory-mapped interface master that provides access to the transceiver and PLL registers through the system console. You can enable NPDME using the **Enable Native PHY Debug Master Endpoint** option available under the **Dynamic Reconfiguration** tab in the Native PHY and PLL IP cores. When using NPDME, the Quartus Prime software inserts the debug interconnect fabric to connect with USB, JTAG, or other net hosts. Select the **Share Reconfiguration Interface** parameter when the Native PHY IP instance has more than one channel.

When you enable NPDME in your design, you must

- connect an Avalon memory-mapped interface master to the reconfiguration interface.
- OR connect the, `reconfig_reset` signals and ground the `reconfig_write`, `reconfig_read`, `reconfig_address` and `reconfig_write` data signals of the reconfiguration interface. If the reconfiguration interface signals are not connected appropriately, there is no clock or reset for the NPDME, and the NPDME does not function as expected.

### 6.15.2. Optional Reconfiguration Logic

The Arria 10 Transceiver Native PHY, ATX PLL, fPLL, and CMU PLL IP cores contain soft logic for debug purposes known as the Optional Reconfiguration Logic. This soft logic provides a set of registers that enable you to determine the state of the Native PHY and PLL IP cores.

You can enable the following optional reconfiguration logic options in the transceiver Native PHY and PLL IP cores:

- Capability registers
- Control and status registers
- PRBS soft accumulators (Native PHY IP core only)

### 6.15.2.1. Capability Registers

The capability registers provide high level information about the transceiver channel and PLL configuration.

The capability registers capture a set of chosen capabilities of the PHY that cannot be reconfigured. The following capability registers are available for the Native PHY IP core.

**Table 287. Capability Registers for the Native PHY IP Core**

| Address    | Type | Name                     | Description                                                                                                                                                          |
|------------|------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x200[7:0] | RO   | IP Identifier            | Unique identifier for the Native PHY IP instance.                                                                                                                    |
| 0x204[0]   | RO   | Status Register Enabled  | Indicates whether the status registers have been enabled. 1'b1 indicates that the status registers are enabled.                                                      |
| 0x205[0]   | RO   | Control Register Enabled | Indicates whether the control registers have been enabled. 1'b1 indicates that the control registers are enabled.                                                    |
| 0x210[7:0] | RO   | Number of Channels       | Shows the number of channels specified for the Native PHY IP instance.                                                                                               |
| 0x211[7:0] | RO   | Channel Number           | Shows the unique channel number.                                                                                                                                     |
| 0x212[7:0] | RO   | Duplex                   | Shows the transceiver mode: <ul style="list-style-type: none"> <li>• 2'b00 = Unused</li> <li>• 2'b01 = TX</li> <li>• 2'b10 = RX</li> <li>• 2'b11 = Duplex</li> </ul> |
| 0x213[0]   | RO   | PRBS Soft Enabled        | Indicates whether the PRBS soft accumulators are enabled. 1'b1 indicates the accumulators are enabled.                                                               |

The following capability registers are available for the PLL IP cores.

**Table 288. Capability Registers for the PLL IP Cores**

| Address    | Type | Name                     | Description                                                                                                               |
|------------|------|--------------------------|---------------------------------------------------------------------------------------------------------------------------|
| 0x200[7:0] | RO   | IP Identifier            | Unique identifier for the PLL IP instance.                                                                                |
| 0x204[0]   | RO   | Status Register Enabled  | Indicates if the status registers have been enabled or not. 1'b1 indicates that the status registers have been enabled.   |
| 0x205[0]   | RO   | Control Register Enabled | Indicates if the control registers have been enabled or not. 1'b1 indicates that the control registers have been enabled. |
| 0x210[7:0] | RO   | Master CGB Enabled       | Indicates if the Master Clock Generation Block has been enabled. 1'b1 indicates the master CGB is enabled.                |

### 6.15.2.2. Control and Status Registers

Control and status registers are optional registers that memory-map some of the status outputs from and control inputs to the Native PHY and PLL.

The following control and status registers are available for the Native PHY IP core.

**Table 289. Control Registers for the Native PHY IP Core**

| Address  | Type | Register                   | Description                                                                                                                                                                                   |
|----------|------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x2E0[0] | RW   | set_rx_locktodata          | Asserts the set_rx_locktodata signal to the receiver. 1'b1 sets the NPDME set_rx_locktodata register. See override_set_rx_locktodata.                                                         |
| 0x2E0[1] | RW   | set_rx_locktoref           | Asserts the set_rx_locktoref signal to the receiver. 1'b1 sets the NPDME set_rx_locktoref register. See override_set_rx_locktoref row below.                                                  |
| 0x2E0[2] | RW   | override_set_rx_locktodata | Selects whether the receiver listens to the NPDME set_rx_locktodata register or the rx_set_locktodata port. 1'b1 indicates that the receiver listens to the NPDME set_rx_locktodata register. |
| 0x2E0[3] | RW   | override_set_rx_locktoref  | Selects whether the receiver is listens to the NPDME set_rx_locktoref register or the rx_set_locktoref port. 1'b1 indicates that the receiver listens to the NPDME set_rx_locktoref register. |
| 0x2E1[0] | RW   | rx_serialpbken             | Enables the rx_serialpbken feature in the transceiver. 1'b1 enables reverse serial loopback.                                                                                                  |
| 0x2E2[0] | RW   | rx_analogreset             | Drives rx_analogreset when the override is set.                                                                                                                                               |
| 0x2E2[1] | RW   | rx_digitalreset            | Drives rx_digitalreset when the override is set.                                                                                                                                              |
| 0x2E2[2] | RW   | tx_analogreset             | Drives tx_analogreset when the override is set.                                                                                                                                               |
| 0x2E2[3] | RW   | tx_digitalreset            | Drives tx_digitalreset when the override is set.                                                                                                                                              |
| 0x2E2[4] | RW   | override_rx_analogreset    | Selects whether the receiver listens to the NPDME rx_analogreset register or the rx_analogreset port. 1'b1 indicates the receiver listens to the NPDME rx_analogreset register.               |
| 0x2E2[5] | RW   | override_rx_digitalreset   | Selects whether the receiver listens to the NPDME rx_digitalreset register or the rx_digitalreset port. 1'b1 indicates the receiver listens to the NPDME rx_digitalreset register.            |
| 0x2E2[6] | RW   | override_tx_analogreset    | Selects whether the receiver listens to the NPDME tx_analogreset register or the tx_analogreset port. 1'b1 indicates the receiver listens to the NPDME tx_analogreset register.               |
| 0x2E2[7] | RW   | override_tx_digitalreset   | Selects whether the receiver listens to the NPDME tx_digitalreset register or the tx_digitalreset port. 1'b1 indicates the receiver listens to the NPDME tx_digitalreset register.            |

**Table 290. Status Registers for the Native PHY IP Core**

| Address  | Type | Register           | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x280[0] | RO   | rx_is_lockedtodata | Shows the status of the current channel's rx_is_lockedtodata signal. 1'b1 indicates the receiver is locked to the incoming data.                                                                                                                                                                                                                                                                |
| 0x280[1] | RO   | rx_is_lockedtoref  | Shows the status of the current channel's rx_is_lockedtoref signal. 1'b1 indicates the receiver is locked to the reference clock.                                                                                                                                                                                                                                                               |
| 0x281[0] | RO   | tx_cal_busy        | Shows the status of the transmitter calibration status. 1'b1 indicates the transmitter calibration is in progress.                                                                                                                                                                                                                                                                              |
| 0x281[1] | RO   | rx_cal_busy        | Shows the status of the receiver calibration status. 1'b1 indicates the receiver calibration is in progress.                                                                                                                                                                                                                                                                                    |
| 0x281[2] | RO   | avmm_busy          | Shows the status of the internal configuration bus arbitration. 1'b1 indicates PreSICE has control of the internal configuration bus. 1'b0 indicates the user has control of the internal configuration bus. Refer to the <i>Arbitration</i> section for more details. For more details about calibration registers and performing user recalibration, refer to the <i>Calibration</i> chapter. |

The following control and status registers are available for the PLL IP cores.

**Table 291. Control Registers for the PLL IP Cores**

| Address  | Type | Register               | Description                                                                                                                                                         |
|----------|------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x2E0[0] | RW   | pll_powerdown          | Drives the PLL powerdown when the Override is set.                                                                                                                  |
| 0x2E0[1] | RW   | override_pll_powerdown | Selects whether the receiver listens to the NPDME pll_powerdown register or the pll_powerdown port. 1'b1 indicates the receiver listens to the NPDME pll_powerdown. |

**Table 292. Status Registers for the PLL IP Cores**

| Address  | Type | Register     | Description                                                                                                                                                                                                                                                            |
|----------|------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x280[0] | RO   | pll_locked   | Indicates if the PLL is locked. 1'b1 indicates the PLL is locked.                                                                                                                                                                                                      |
| 0x280[1] | RO   | pll_cal_busy | Indicates the calibration status. 1'b1 indicates the PLL is currently being calibrated.                                                                                                                                                                                |
| 0x280[2] | RO   | avmm_busy    | Shows the status of the internal configuration bus arbitration. 1'b1 indicates PreSICE has control of the internal configuration bus. 1'b0 indicates the user has control of the internal configuration bus. Refer to the <i>Arbitration</i> section for more details. |

### Related Information

[Arbitration](#) on page 524

#### 6.15.2.3. PRBS Soft Accumulators

The Pseudo Random Binary Sequence (PRBS) soft accumulators are used in conjunction with the hard PRBS blocks in the transceiver channel. This section describes the soft logic that can be added to the Native PHY IP core. To enable this option, turn on the **Enable PRBS Soft Accumulators** option in the Native PHY IP Parameter Editor.

The PRBS soft accumulator has three control bits (Enable, Reset, and Snapshot) and one status bit (PRBS Done).

- **Enable** bit—used to turn on the accumulation logic. This bit is also used for selective error accumulation and to pause the sequence.
- **Reset** bit—resets the PRBS polynomial and the bit and error accumulators. It also resets the snapshot registers if independent channel snapshots are used.
- **Snapshot** bit—captures the current value of the accumulated bits and the errors simultaneously. This neutralizes the impact of the added read time when the Avalon memory-mapped interface is used. Capturing a snapshot provides an accurate error count with respect to the bit count at a specific time.
- **PRBS Done** bit—indicates the PRBS checker has had sufficient time to lock to the incoming pattern.

For example, to capture the accumulated errors at any instance of time and read them back, you can perform the following operations.

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform read-modify-write to address 0x300 and set bit 0 to 1'b1. This action enables the error and bit counters.
3. To capture the errors accumulated at a particular instant, perform read-modify-write to address 0x300 and set bit 2 to 1'b1. This takes a snapshot of the error counters and stores the value to the error count registers.
4. To read the number of errors accumulated when the snapshot was captured, perform a read from the corresponding error registers 0x301 to 0x307.
5. To reset the bit and error accumulators, perform a read-modify-write to address 0x300 bit 1.
6. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

**Note:**

You can enable the error and bit counters (0x300[0]) and capture the accumulated bits and errors at different times. The error count registers and bit count registers are updated with the latest counter values as long as the counter enable bit is set.

Use the PRBS soft accumulators to count the number of accumulated bits and errors when the hard PRBS blocks are used. PRBS soft accumulators are word-based counter. The value read out from the PRBS soft accumulators represent the number of words counted. Hence, in order to obtain the total accumulated bit, user needs to multiply the value read out from the Accumulated bit pass through count [49:0] registers with the width of PCS-PMA interface. For Accumulated error count [49:0] registers, it counts one as long as there are bit errors in a word (be it one bit error in a word or all the bits in a word are erroneous). Hence, the Accumulated error count [49:0] registers do not give absolute bit errors counted. For each count, the absolute bit errors could range from one to the width of PCS-PMA interface.

For more information about using the hard PRBS blocks, refer to the "Using Data Pattern Generators and Checkers" section.

**Table 293. PRBS Accumulator Registers**

| Address    | Type | Name                                                 | Description                                                                                                                    |
|------------|------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 0x300[0]   | RW   | Counter enable (enables both error and bit counters) | Counter enable (enables both error and bit counters)                                                                           |
| 0x300[1]   | RW   | Reset                                                | Reset the error accumulators                                                                                                   |
| 0x300[2]   | RW   | Error Count Snapshot                                 | Snapshot captures the current value of accumulated bits and the errors at that time instance                                   |
| 0x300[3]   | RO   | PRBS Done                                            | PRBS Done when asserted indicates the verifier has captured consecutive PRBS patterns and first pass of polynomial is complete |
| 0x301[7:0] | RO   | Accumulated error count [7:0]                        | Accumulated error count [7:0]                                                                                                  |
| 0x302[7:0] | RO   | Accumulated error count [15:8]                       | Accumulated error count [15:8]                                                                                                 |
| 0x303[7:0] | RO   | Accumulated error count [23:16]                      | Accumulated error count [23:16]                                                                                                |
| 0x304[7:0] | RO   | Accumulated error count [31:24]                      | Accumulated error count [31:24]                                                                                                |
| 0x305[7:0] | RO   | Accumulated error count [39:32]                      | Accumulated error count [39:32]                                                                                                |
| 0x306[7:0] | RO   | Accumulated error count [47:40]                      | Accumulated error count [47:40]                                                                                                |
| 0x307[1:0] | RO   | Accumulated error count [49:48]                      | Accumulated error count [49:48]                                                                                                |
| 0x30D[7:0] | RO   | Accumulated bit pass through count[7:0]              | Accumulated bit pass through count[7:0]                                                                                        |
| 0x30E[7:0] | RO   | Accumulated bit pass through count[15:8]             | Accumulated bit pass through count[15:8]                                                                                       |
| 0x30F[7:0] | RO   | Accumulated bit pass through count[23:16]            | Accumulated bit pass through count[23:16]                                                                                      |
| 0x310[7:0] | RO   | Accumulated bit pass through count[31:24]            | Accumulated bit pass through count[31:24]                                                                                      |
| 0x311[7:0] | RO   | Accumulated bit pass through count[39:32]            | Accumulated bit pass through count[39:32]                                                                                      |
| 0x312[7:0] | RO   | Accumulated bit pass through count[47:40]            | Accumulated bit pass through count[47:40]                                                                                      |
| 0x313[1:0] | RO   | Accumulated bit pass through count[49:48]            | Accumulated bit pass through count[49:48]                                                                                      |

**Note:** Intel recommends that you disable the byte serializer and deserializer blocks when using the soft PRBS accumulators. When the byte serializer and deserializer blocks are enabled, the number of bits counted are halved because the clock is running at half the rate.

#### Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528
- [Arbitration](#) on page 524
- [Using Data Pattern Generators and Checkers](#) on page 562

## 6.16. Using Data Pattern Generators and Checkers

The Arria 10 transceivers contain hardened data generators and checkers to provide a simple and easy way to verify and characterize high speed links. Hardening the data generators and verifiers saves FPGA fabric logic resources. The pattern generator block supports the following patterns:

- Pseudo Random Binary Sequence (PRBS)
- Pseudo Random Pattern (PRP)

The pattern generators and checkers are supported only for non-bonded channels.

### 6.16.1. Using PRBS Data Pattern Generator and Checker

Use the Arria 10 PRBS generator and checker to simulate traffic and easily characterize high-speed links without fully implementing any upper protocol stack layer. The PRBS generator generates a self-aligning pattern and covers a known number of unique sequences. Because the PRBS pattern is generated by a Linear Feedback Shift Register (LFSR), the next pattern can be determined from the previous pattern. When the PRBS checker receives a portion of the received pattern, it can generate the next sequence of bits to verify whether the next data sequence received is correct.

The PRBS generator and checker are shared between the Standard and Enhanced datapaths through the PCS. Therefore, they have only one set of control signals and registers. The data lines from the various PCSs and shared PRBS generator are MUXed before they are sent to the PMA. When the PRBS generator is enabled, the data on the PRBS data lines is selected to be sent to the PMA. Either the data from the PCS or the data generated from the PRBS generator can be sent to the PMA at any time.

The PRBS generator and checker can be configured for two widths of the PCS-PMA interface: 10 bits and 64 bits. PRBS9 is available in both 10-bit and 64-bit PCS-PMA widths. All other PRBS patterns are available in 64-bit PCS-PMA width only. The PRBS generator and checker patterns can only be used when the PCS-PMA interface width is configured to 10 bits or 64 bits. For any other PCS-PMA width, to ensure the correct clocks are provided to the PRBS blocks you must first reconfigure the width to either 10 or 64 bits before using the PRBS generator and checker. For example, when the transceiver is configured to a 20-bit PCS/PMA interface, you must first reconfigure the PCS-PMA width to 10 bits before setting up the PRBS generator and checker. The PRBS setup does not automatically change the PCS/PMA width.

The 10-bit PCS-PMA width for PRBS9 is available for lower frequency testing. You can configure PRBS9 in either 10-bit or 64-bit width, based on the data rate. The FPGA fabric-PCS interface must run in the recommended speed range of the FPGA core. Therefore, you must configure PRBS9 in one of the two bit width modes, so that the FPGA fabric-PCS interface parallel clock runs in this operating range.

Examples:

- If you want to use PRBS9 and the data rate is 2.5 Gbps, you can use the PRBS9 in 10-bit mode (PCS-PMA width = 10). In this case, the parallel clock frequency = Data rate / PCS-PMA width = 2500 Mbps/10 = 250 MHz.
- If you want to use PRBS9 and the data rate is 6.4 Gbps, you can use the PRBS9 in 64-bit mode (PCS-PMA width = 64). In this case, the parallel clock frequency = Data rate / PCS-PMA width = 6400 Mbps/64 = 100 MHz.
- If you want to use PRBS9 and the data rate is 12.5 Gbps, you can use the PRBS9 in 64 bit mode (PCS-PMA width = 64). In this case, the parallel clock frequency = Data rate / PCS-PMA width = 12500 Mbps/64 = 195.3125 MHz.

**Table 294. PRBS Supported Polynomials and Data Widths**

Use the 10-bit mode of PRBS9 when the data rate is lower than 3 Gbps.

| Pattern | Polynomial                   | 64-Bit | 10-Bit |
|---------|------------------------------|--------|--------|
| PRBS7   | $G(x) = 1 + x^6 + x^7$       | X      |        |
| PRBS9   | $G(x) = 1 + x^5 + x^9$       | X      | X      |
| PRBS15  | $G(x) = 1 + x^{14} + x^{15}$ | X      |        |
| PRBS23  | $G(x) = 1 + x^{18} + x^{23}$ | X      |        |
| PRBS31  | $G(x) = 1 + x^{28} + x^{31}$ | X      |        |

The PRBS checker has the following control and status signals available to the FPGA fabric:

- `rx_prbs_done`—Indicates the PRBS sequence has completed one full cycle. It stays high until you reset it with `rx_prbs_err_clr`.
- `rx_prbs_err`—Goes high if an error occurs. This signal is pulse-extended to allow you to capture it in the RX FPGA CLK domain.
- `rx_prbs_err_clr`—Used to reset the `rx_prbs_err` signal.

Enable the PRBS checker control and status ports through the Native PHY IP Parameter Editor in the Quartus Prime software.

Use the PRBS soft accumulators to count the number of accumulated bits and errors when the hard PRBS blocks are used. For more information about using the accumulators and reading the error values, refer to the *PRBS Soft Accumulators* section.

**Table 295. Register Map for PRBS Generators for bonded and non bonded designs**

| Reconfiguration Address (HEX) | Reconfiguration Bit | Attribute Name  | Related Addresses | Attribute Encoding | Bit Encoding | Description                 |
|-------------------------------|---------------------|-----------------|-------------------|--------------------|--------------|-----------------------------|
| 0x006                         | [2:0]               | tx_pma_data_sel | 0x8               | prbs_pat           | 3'b100       | Select PRBS Generator Block |
|                               | [3]                 | prbs9_dwidth    |                   | prbs9_10b          | 1'b1         | Enable PRBS9 in 10-bit mode |
|                               |                     |                 |                   | prbs9_64b          | 1'b0         | Enable PRBS9 in 64-bit mode |

*continued...*

| <b>Reconfiguration Address (HEX)</b> | <b>Reconfiguration Bit</b> | <b>Attribute Name</b> | <b>Related Addresses</b> | <b>Attribute Encoding</b>     | <b>Bit Encoding</b> | <b>Description</b>           |
|--------------------------------------|----------------------------|-----------------------|--------------------------|-------------------------------|---------------------|------------------------------|
|                                      | [6]                        | prbs_clken            |                          | prbs_clk_dis                  | 1'b0                | Disable PRBS generator clock |
|                                      |                            |                       |                          | prbs_clk_en                   | 1'b1                | Enable PRBS generator clock  |
| 0x007                                | [7:4]                      | prbs_gen_pat          | 0x8                      | prbs_7                        | 4'b0001             | Enable PRBS7 pattern         |
|                                      |                            |                       |                          | prbs_9                        | 4'b0010             | Enable PRBS9 pattern         |
|                                      |                            |                       |                          | prbs_15                       | 4'b0100             | Enable PRBS15 pattern        |
|                                      |                            |                       |                          | prbs_23                       | 4'b1000             | Enable PRBS23 pattern        |
|                                      |                            |                       |                          | prbs_31                       | 4'b0000             | Enable PRBS31 pattern        |
| 0x008                                | [4]                        | prbs_gen_pat          | 0x7                      | prbs_7                        | 1'b0                | Enable PRBS7 pattern         |
|                                      |                            |                       |                          | prbs_9                        | 1'b0                | Enable PRBS9 pattern         |
|                                      |                            |                       |                          | prbs_15                       | 1'b0                | Enable PRBS15 pattern        |
|                                      |                            |                       |                          | prbs_23                       | 1'b0                | Enable PRBS23 pattern        |
|                                      |                            |                       |                          | prbs_31                       | 1'b1                | Enable PRBS31 pattern        |
| 0x110                                | [6:5]                      | tx_pma_data_sel       | 0x6                      | prbs_pat                      | 2'b00               | Enable PRBS generator        |
|                                      |                            |                       |                          | sixty_four_bit                | 3'b011              | 64-bit mode                  |
| 0x111                                | [4:0]                      | x1_clock_source_sel   | 0x119                    | xn_non_bonding <sup>(6)</sup> | 5'b11000            | Enables xn non bonding       |

**Table 296. Register Map for PRBS Checker for bonded and non bonded designs**

| <b>Reconfiguration Address (HEX)</b> | <b>Reconfiguration Bit</b> | <b>Attribute Name</b> | <b>Related Addresses</b> | <b>Attribute Encoding</b> | <b>Bit Encoding</b> | <b>Description</b>         |
|--------------------------------------|----------------------------|-----------------------|--------------------------|---------------------------|---------------------|----------------------------|
| 0x00A                                | [7]                        | prbs_clken            |                          | prbs_clk_dis              | 1'b0                | Disable PRBS checker clock |
|                                      |                            |                       |                          | prbs_clk_en               | 1'b1                | Enable PRBS checker clock  |
| 0x00B                                | [3:2]                      | rx_prbs_mask          |                          | prbsmask1024              | 2'b11               | Counter threshold to 1023  |
|                                      |                            |                       |                          | prbsmask128               | 2'b00               | Counter threshold to 127   |
|                                      |                            |                       |                          | prbsmask256               | 2'b01               | Counter threshold to 255   |
|                                      |                            |                       |                          | prbsmask512               | 2'b10               | Counter threshold to 511   |
|                                      | [7:4]                      | prbs_ver              | 0xC                      | prbs_7                    | 4'b0001             | Enable PRBS7 pattern       |

*continued...*

(64) You must read and save the value in the register 0x111[5:0] before changing the x1\_clock\_source\_sel setting to xN non bonding. To disable the PRBS generator, write the original values back into the read-modify-write address.

| Reconfiguration Address (HEX) | Reconfiguration Bit | Attribute Name | Related Addresses | Attribute Encoding | Bit Encoding | Description           |
|-------------------------------|---------------------|----------------|-------------------|--------------------|--------------|-----------------------|
|                               |                     |                |                   | prbs_9             | 4'b0010      | Enable PRBS9 pattern  |
|                               |                     |                |                   | prbs_15            | 4'b0100      | Enable PRBS15 pattern |
|                               |                     |                |                   | prbs_23            | 4'b1000      | Enable PRBS23 pattern |
|                               |                     |                |                   | prbs_31            | 4'b0000      | Enable PRBS31 pattern |
| 0x00C                         | [0]                 | prbs_ver       | 0xB               | prbs_7             | 1'b0         | Enable PRBS7 pattern  |
|                               |                     |                |                   | prbs_9             | 1'b0         | Enable PRBS9 pattern  |
|                               |                     |                |                   | prbs_15            | 1'b0         | Enable PRBS15 pattern |
|                               |                     |                |                   | prbs_23            | 1'b0         | Enable PRBS23 pattern |
|                               |                     |                |                   | prbs_31            | 1'b1         | Enable PRBS31 pattern |
|                               | [3]                 | prbs9_dwidth   |                   | prbs9_10b          | 1'b1         | PRBS9 10-bit          |
|                               |                     |                |                   | prbs9_64b          | 1'b0         | PRBS9 64-bit          |
| 0x13F                         | [3:0]               | deser_factor   |                   | 10                 | 4'b0001      | 10-bit mode           |
|                               |                     |                |                   | 64                 | 4'b1110      | 64-bit mode           |

### Related Information

[PRBS Soft Accumulators](#) on page 559

#### 6.16.1.1. Enabling the PRBS Data Generator in non bonded designs

You must perform a sequence of read-modify-writes to addresses 0x006, 0x007, 0x008, and 0x110 to enable either the PRBS data generator. To enable either the PRBS data generator, follow these steps:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address 0x006 according to [Register Map for PRBS Generators for bonded and non bonded designs](#).
3. Perform a read-modify-write to address 0x007 according to [Register Map for PRBS Generators for bonded and non bonded designs](#).
4. Perform a read-modify-write to address 0x008 according to [Register Map for PRBS Generators for bonded and non bonded designs](#).
5. Perform a read-modify-write to address 0x110 with the specified width. This data width is either 64-bit or 10-bit.
6. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

To disable the PRBS generator, write the original values back into the read-modify-write addresses in [Register Map for PRBS Generators for bonded and non bonded designs](#).

### Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528
- [Arbitration](#) on page 524

#### 6.16.1.1.1. Examples of Enabling the PRBS9 and PRBS31 Pattern Generators in non bonded designs

##### Example 5. Enabling the PRBS9 pattern generator in 10-bit mode

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address x006[7:0] with the following bits: 8'b01- - 1100
3. Perform a read-modify-write to address x007[7:0] with the following bits: 8'b00010 - - - -
4. Perform a read-modify-write to address x008[7:0] with the following bits: 8'b - 000 - - - -
5. Perform a read-modify-write to address x110[7:0] with the following bits: 8'b - - - - 100
6. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

**Note:** A dash (-) indicates that the corresponding bit value should not be modified during read-modify-write.

##### Example 6. Enabling the PRBS31 pattern generator in 64-bit mode

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address x006[7:0] with the following bits: 8'b01- - 0100
3. Perform a read-modify-write to address x007[7:0] with the following bits: 8'b00000 - - - -
4. Perform a read-modify-write to address x008[7:0] with the following bits: 8'b - 001 - - - -
5. Perform a read-modify-write to address x110[7:0] with the following bits: 8'b - - - - 011
6. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

**Note:** A dash (-) indicates that the corresponding bit value should not be modified during read-modify-write.

### Related Information

- [Steps to Perform Dynamic Reconfiguration](#) on page 528

#### 6.16.1.2. Enabling the PRBS Data Generator in bonded designs

You must perform a sequence of read-modify-writes to addresses 0x006, 0x007, 0x008, and 0x110, 0x111 and to enable either the PRBS data generator in bonded designs. To enable either the PRBS data generator, follow these steps:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address 0x006 according to [Register Map for PRBS Generators for bonded and non bonded designs](#).
3. Perform a read-modify-write to address 0x007 according to [Register Map for PRBS Generators for bonded and non bonded designs](#).
4. Perform a read-modify-write to address 0x008 according to [Register Map for PRBS Generators for bonded and non bonded designs](#).
5. Perform a read-modify-write to address 0x110 with the specified width. This data width is either 64-bit or 10-bit.
6. Perform a read-modify-write to address 0x111 according to [Register Map for PRBS Generators for bonded and non bonded designs](#). You must read and save the value in the register 0x111[5:0] before changing the `x1_clock_source_sel` setting to xN non bonding.
7. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

To disable the PRBS generator, write the original values back into the read-modify-write addresses in [Register Map for PRBS Generators for bonded and non bonded designs](#).

#### **6.16.1.2.1. Examples of Enabling the PRBS9 and PRBS31 Pattern Generators in bonded designs**

##### **Example 7. Enabling the PRBS9 pattern generator in 10-bit mode**

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address x006[7:0] with the following bits: 8'b01- - 1100
3. Perform a read-modify-write to address x007[7:0] with the following bits: 8'b0010 - - - -
4. Perform a read-modify-write to address x008[7:0] with the following bits: 8'b - 000 - - - -
5. Perform a read-modify-write to address x110[7:0] with the following bits: 8'b - - - - 100
6. Perform a read-modify-write to address x111[5:0] with the following bits: 8'b---11000. You must read and save the value in the register 0x111[5:0] before changing the `x1_clock_source_sel` setting to xN non bonding.
7. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

**Note:** A dash (-) indicates that the corresponding bit value should not be modified during read-modify-write.

#### Example 8. Enabling the PRBS31 pattern generator in 64-bit mode

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address x006[7:0] with the following bits: 8'b01- - 0100
3. Perform a read-modify-write to address x007[7:0] with the following bits: 8'b0000 - - - -
4. Perform a read-modify-write to address x008[7:0] with the following bits: 8'b - 001 - - - -
5. Perform a read-modify-write to address x110[7:0] with the following bits: 8'b - - - - 011
6. Perform a read-modify-write to address x111[5:0] with the following bits: 8'b---11000. You must read and save the value in the register 0x111[5:0] before changing the x1\_clock\_source\_sel setting to xN non bonding.
7. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

**Note:** A dash (-) indicates that the corresponding bit value should not be modified during read-modify-write.

#### 6.16.1.3. Enabling the PRBS Data Checker in non bonded design

You must perform a sequence of read-modify-writes to the Transceiver Native PHY reconfiguration interface to enable the PRBS checker. You must perform read-modify-writes to addresses 0x00A, 0x00B, 0x00C, and 0x13F. To enable the PRBS checker, follow these steps:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address 0x00A with a value of 1'b1 to bit[7].
3. Perform a read-modify-write to address 0x00B according to [Register Map for PRBS Checker for bonded and non bonded designs](#).
4. Perform a read-modify-write to address 0x00C according to [Register Map for PRBS Checker for bonded and non bonded designs](#).
5. Perform a read-modify-write to address 0x13F according to [Register Map for PRBS Checker for bonded and non bonded designs](#).
6. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

To disable the PRBS verifier write the original values back into the read-modify-write addresses listed above.

#### Related Information

[Steps to Perform Dynamic Reconfiguration](#) on page 528

#### 6.16.1.3.1. Examples of Enabling the PRBS Data Checker

##### Example 9. Enabling the PRBS9 pattern checker in 10-bit mode

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address x00A[7:0] with the following bits: 8'b1- - - - -
3. Perform a read-modify-write to address x00B[7:0] with the following bits: 8'b0010 00 - -
4. Perform a read-modify-write to address x00C[7:0] with the following bits: 8'b - - - - 1 - - 0
5. Perform a read-modify-write to address x13F[7:0] with the following bits: 8'b - - - - 0001
6. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

Note: A dash (-) indicates that the corresponding bit value should not be modified

##### Example 10. Enabling the PRBS31 pattern checker in 64-bit mode

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address x00A[7:0] with the following bits: 8'b1- - - - -
3. Perform a read-modify-write to address x00B[7:0] with the following bits: 8'b0000 11 - -
4. Perform a read-modify-write to address x00C[7:0] with the following bits: 8'b - - - - - 1
5. Perform a read-modify-write to address x13F[7:0] with the following bits: 8'b - - - - 1110
6. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

Note: A dash (-) indicates that the corresponding bit value should not be modified

Use the PRBS soft accumulators to count the number of accumulated bits and errors when the hard PRBS blocks are used. For more details about using the accumulators and reading the error values, refer to the "PRBS Soft Accumulators" section.

##### Related Information

- [PRBS Soft Accumulators](#) on page 559
- [Steps to Perform Dynamic Reconfiguration](#) on page 528

#### 6.16.1.4. Enabling the PRBS Checker in bonded designs

You must perform a sequence of read-modify-writes to addresses 0x00A, 0x00B, 0x00C, 0x13F, 0x111 and to enable the PRBS data checker in bonded designs. To enable the PRBS checker, follow these steps:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
  2. Perform a read-modify-write to address 0x00A with a value of 1'b1 to bit[7].
  3. Perform a read-modify-write to address 0x00B according to [Register Map for PRBS Checker for bonded and non bonded designs](#).
  4. Perform a read-modify-write to address 0x00C according to [Register Map for PRBS Checker for bonded and non bonded designs](#).
  5. Perform a read-modify-write to address 0x13F according to [Register Map for PRBS Checker for bonded and non bonded designs](#).
  6. Perform a read-modify-write to address 0x111 according to [Register Map for PRBS Checker for bonded and non bonded designs](#).
  7. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.
- To disable the PRBS verifier write the original values back into the read-modify-write addresses listed above.

#### **6.16.1.5. Disabling/Enabling PRBS Pattern Inversion**

The default PRBS pattern is inverted for both the PRBS generator and checker. You can disable pattern inversion for PRBS data leaving or entering the PRBS data pattern generator and checker, respectively. [Table 297](#) on page 570 shows the addresses and bits to control the inversion of the PRBS generator or checker. To disable the PRBS pattern inversion for the PRBS generator or checker, follow these steps:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. To disable the inverted PRBS pattern leaving the PRBS generator, perform a read-modify-write to bit[2] with a value of 1'b1 to address 0x7.
3. To disable the inverted PRBS pattern entering the PRBS checker, perform a read-modify-write to bit[4] with a value of 1'b1 to address 0xA.
4. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

**Table 297. Register Map for PRBS Pattern Inversion**

| Reconfiguration Address (HEX) | Reconfiguration Bit | Attribute Name               | Bit Encoding | Description                      |
|-------------------------------|---------------------|------------------------------|--------------|----------------------------------|
| 0x7                           | [2]                 | tx_static_polarity_inversion | 1'b1         | Disables PRBS inversion          |
|                               |                     |                              | 1'b0         | Enables PRBS inversion (default) |
| 0xA                           | [4]                 | rx_static_polarity_inversion | 1'b1         | Disables PRBS inversion          |
|                               |                     |                              | 1'b0         | Enables PRBS inversion (default) |

#### **Related Information**

[Steps to Perform Dynamic Reconfiguration](#) on page 528

## 6.16.2. Using Pseudo Random Pattern Mode

You can use the Arria 10 Pseudo Random Pattern (PRP) generator and verifier in the scrambler and descrambler to generate random data pattern and seed that the scrambler can use. PRP mode is a test mode of the scrambler. Two seeds are available to seed the scrambler: all 0s or two local fault-ordered sets. The seed is used in the scrambler to produce the pattern. The `r_tx_data_pat_sel` is the data pattern that the scrambler will scramble. PRP is only available when the scrambler is enabled. The PRP verifier shares the `rx_prbs_err` error signal with PRBS. The error count can be read out from the corresponding registers.

### 6.16.2.1. Enabling Pseudo Random Pattern Mode

You must perform a sequence of read-modify-writes to the reconfiguration interface to enable the Pseudo Random Pattern. The read-modify-writes are required to addresses 0x082, 0x097, and 0x0AC. To enable the Pseudo Random Pattern, complete the following steps:

1. Perform the necessary steps from steps 1 to 7 in *Steps to Perform Dynamic Reconfiguration*.
2. Perform a read-modify-write to address 0x082 according to [Table 298](#) on page 571.
3. Perform a read-modify-write to address 0x097 according to [Table 298](#) on page 571.
4. Perform a read-modify-write to address 0x0AC according to [Table 298](#) on page 571.
5. Perform the necessary steps from steps 9 to 12 in *Steps to Perform Dynamic Reconfiguration*.

To disable the PRP verifier, write the original values back to the read-modify-write addresses listed above.

**Table 298. Register Map for Pseudo Random Pattern Mode**

| Reconfiguration Address (HEX) | Reconfiguration Bit | Attribute Name                  | Bit Encoding | Description             |
|-------------------------------|---------------------|---------------------------------|--------------|-------------------------|
| 0x72                          | [7:0]               | <code>r_tx_seed_a[7:0]</code>   |              | Seed A value bit[7:0]   |
| 0x73                          | [7:0]               | <code>r_tx_seed_a[15:8]</code>  |              | Seed A value bit[15:8]  |
| 0x74                          | [7:0]               | <code>r_tx_seed_a[23:16]</code> |              | Seed A value bit[23:16] |
| 0x75                          | [7:0]               | <code>r_tx_seed_a[31:24]</code> |              | Seed A value bit[31:24] |
| 0x76                          | [7:0]               | <code>r_tx_seed_a[39:32]</code> |              | Seed A value bit[39:32] |
| 0x77                          | [7:0]               | <code>r_tx_seed_a[47:40]</code> |              | Seed A value bit[47:40] |
| 0x78                          | [7:0]               | <code>r_tx_seed_a[55:48]</code> |              | Seed A value bit[55:48] |
| 0x79                          | [1:0]               | <code>r_tx_seed_a[57:56]</code> |              | Seed A value bit[57:56] |

*continued...*

| <b>Reconfiguration Address (HEX)</b> | <b>Reconfiguration Bit</b> | <b>Attribute Name</b> | <b>Bit Encoding</b> | <b>Description</b>      |
|--------------------------------------|----------------------------|-----------------------|---------------------|-------------------------|
| 0x7A                                 | [7:0]                      | r_tx_seed_b[7:0]      |                     | Seed B value bit[7:0]   |
| 0x7B                                 | [7:0]                      | r_tx_seed_b[15:8]     |                     | Seed B value bit[15:8]  |
| 0x7C                                 | [7:0]                      | r_tx_seed_b[23:16]    |                     | Seed B value bit[23:16] |
| 0x7D                                 | [7:0]                      | r_tx_seed_b[31:24]    |                     | Seed B value bit[31:24] |
| 0x7E                                 | [7:0]                      | r_tx_seed_b[39:32]    |                     | Seed B value bit[39:32] |
| 0x7F                                 | [7:0]                      | r_tx_seed_b[47:40]    |                     | Seed B value bit[47:40] |
| 0x80                                 | [7:0]                      | r_tx_seed_b[55:48]    |                     | Seed B value bit[55:48] |
| 0x81                                 | [1:0]                      | r_tx_seed_b[57:56]    |                     | Seed B value bit[57:56] |
| 0x82                                 | [0]                        | r_tx_data_pat_sel     | 1'b0                | 2 local faults          |
|                                      |                            |                       | 1'b1                | 0's                     |
|                                      | [1]                        | r_tx_test_pat_sel     | 1'b0                | Pseudo Random           |
|                                      | [3]                        | r_tx_test_en          | 1'b1                |                         |
| 0x97                                 | [2]                        | r_rx_test_en          | 1'b1                |                         |
| 0xAC                                 | [0]                        | r_rx_test_pat_sel     | 1'b0                | Pseudo random           |
| 0xD7                                 | [7:0]                      | random_err_cnt[7:0]   |                     | Error count             |
| 0xD8                                 | [7:0]                      | random_err_cnt[7:0]   |                     |                         |

### Related Information

[Steps to Perform Dynamic Reconfiguration](#) on page 528

## 6.17. Timing Closure Recommendations

Intel recommends that you enable the multiple reconfiguration profiles feature in the Native PHY IP core if any of the modified or target configurations involve changes to PCS settings. Using multiple reconfiguration profiles is optional if the reconfiguration involves changes to only PMA settings such as PLL switching, CGB divider switching, and refclk switching. When you enable multiple reconfiguration profiles, the Quartus Prime TimeQuest Timing Analyzer includes the necessary PCS timing arcs for all profiles (initial profile and target profiles) during timing driven compilation. These timing arcs make the timing more accurate.

When performing a dynamic reconfiguration, you must:

- Include constraints to create the extra clocks for all modified or target configurations at the PCS-FPGA fabric interface. Clocks for the base configuration are created by the Quartus Prime software. These clocks enable the Quartus Prime software to perform static timing analysis for all the transceiver configurations and their corresponding FPGA fabric core logic blocks.
- Include the necessary false paths between the PCS – FPGA fabric interface and the core logic.

For example, you can perform dynamic reconfiguration to switch the datapath from Standard PCS to Enhanced PCS using the multiple reconfiguration profiles feature. In the following example, the base configuration uses the Standard PCS (data rate = 1.25 Gbps, PCS-PMA width = 10) and drives core logic A in the FPGA fabric. The target or modified configuration is configured to use the Enhanced PCS (data rate = 12.5 Gbps, PCS-PMA width = 64) and drives core logic B in the FPGA fabric.

**Figure 284. Using Multiple Reconfiguration Profiles**



To enable the Quartus Prime software to close timing more accurately in this example, the following constraints must be created:

- ```
create_clock -name tx_clkout_enh -period 5.12 [get_pins {native_inst|xcvr_native_a10_0|g_xcvr_native_insts[0].twentynm_xcvr_native_inst|twentynm_xcvr_native_inst|inst_twentynm_pcs|gen_twentynm_hssi_tx_pld_pcs_interface.inst_twentynm_hssi_tx_pld_pcs_interface|pld_pcs_tx_clk_out}] -add
```

This constraint creates the `tx_clkout` clock that is used to clock the core logic B in the FPGA fabric.

- ```
create_clock -name rx_clkout_enh -period 5.12 [get_pins {native_inst|xcvr_native_a10_0|g_xcvr_native_insts[0].twentynm_xcvr_native_inst|twentynm_xcvr_native_inst|inst_twentynm_pcs|gen_twentynm_hssi_rx_pld_pcs_interface.inst_twentynm_hssi_rx_pld_pcs_interface|pld_pcs_rx_clk_out}] -add
```

This constraint creates the `rx_clkout` clock that is used to clock the core logic B in the FPGA fabric.

- ```
set_false_path -from [get_clocks {tx_clkout_enh}] -to [get_registers <Core Logic A>]
```

Based on how the clocks are connected in the design, you might have to include additional constraints to set false paths from the registers in the core logic to the clocks.

- ```
set_false_path -from [get_clocks {rx_clkout_enh}] -to [get_registers <Core Logic A>]
```

Based on how the clocks are connected in the design, you may have to include additional constraints to set false paths from the registers in the core logic to the clocks.

- ```
set_false_path -from [get_clocks {tx_clkout}] -to [get_registers <Core Logic B>]
```

Based on how the clocks are connected in the design, you may have to include additional constraints to set false paths from the registers in the core logic to the clocks.

- ```
set_false_path -from [get_clocks {rx_clkout}] -to [get_registers <Core Logic B>]
```

Based on how the clocks are connected in the design, you may have to include additional constraints to set false paths from the registers in the core logic to the clocks.

**Note:** If any of the profile or configuration switch involves switching from FIFO to the register mode, then the false paths should be set between the PCS-PMA interface register and the core logic because the common clock point is within the PCS-PMA interface.

For example, if the base configuration of the above case is configured for the TX and RX FIFOs in the Register Mode, the following constraint needs to be created:

- `set_false_path -from [get_registers {native:native_inst|native_altera_xcvr_native_a10_150_lzjn6xi:xcvr_native_a10_0|twentynm_xcvr_native:g_xcvr_native_insts[0].twentynm_xcvr_native_inst|twentynm_xcvr_native_rev_20nm5es:twentynm_xcvr_native_inst|twentynm_pcs_rev_20nm5es:inst_twentynm_pcs|gen_twentynm_hssi_tx_pld_pcs_interface.inst_twentynm_hssi_tx_pld_pcs_interface~pma_tx_pma_clk_reg.reg}] -to [get_registers <Core Logic B>]`
- `set_false_path -from [get_registers {native:native_inst|native_altera_xcvr_native_a10_150_lzjn6xi:xcvr_native_a10_0|twentynm_xcvr_native:g_xcvr_native_insts[0].twentynm_xcvr_native_inst|twentynm_xcvr_native_rev_20nm5es:twentynm_xcvr_native_inst|twentynm_pcs_rev_20nm5es:inst_twentynm_pcs|gen_twentynm_hssi_rx_pld_pcs_interface.inst_twentynm_hssi_rx_pld_pcs_interface~pma_rx_pma_clk_reg.reg}] -to [get_registers <Core Logic B>]`

**Note:** When the dynamic reconfiguration (multi profiles) is enabled, do not move or rename the IP directory. Moving the IP location causes Quartus to fail to pick up the configuration profiles. If the IP directory is changed, the default configuration can be successfully time constrained and analyzed, but the non-default configuration has timing issues as the timing arc may be missing.

## 6.18. Unsupported Features

The following features are not supported by either the Transceiver Native PHY IP core or the PLL IP reconfiguration interface:

- Reconfiguration from a bonded configuration to a non-bonded configuration, or vice versa
- Reconfiguration from a bonded protocol to another bonded protocol
- Reconfiguration from PCIe (with Hard IP) to PCIe (without Hard IP) or non PCIe bonded protocol switching
- Switching between bonding schemes, such as xN to feedback compensation
- Master CGB reconfiguration
- Switching between two master CGBs
- Serialization factor changes on bonded channels
- TX PLL switching on bonded channels

**Note:** Transceiver Native PHY IP non-bonded configuration to another Transceiver Native PHY IP non-bonded configuration is supported.

## 6.19. Arria 10 Transceiver Register Map

The transceiver register map provides a list of available PCS, PMA, and PLL addresses that are used in the reconfiguration process.

Use the register map in conjunction with a transceiver configuration file generated by the Arria 10 Native PHY IP core. This configuration file includes details about the registers that are set for a specific transceiver configuration. Do not use the register map to locate and modify specific registers in the transceiver. Doing so may result in an illegal configuration. Refer to a valid transceiver configuration file for legal register values and combinations.

The register map is provided as an Excel spreadsheet for easy search and filtering.

### Related Information

[Arria 10 Transceiver Register Map](#)

## 6.20. Reconfiguration Interface and Dynamic Revision History

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2021.06.10       | Updated the <i>Embedded Debug Features</i> section.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2019.05.31       | Made the following change: <ul style="list-style-type: none"><li>Updated the link to the Arria 10 Pre-Emphasis and Output Swing Settings tool.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2019.05.13       | Made the following change: <ul style="list-style-type: none"><li>Renamed Altera Debug Master Endpoint (ADME) to Native PHY DebugMaster Endpoint (NPDME).</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2018.06.15       | Made the following change: <ul style="list-style-type: none"><li>Added instructions on how to enable the Transceiver Toolkit capability in the Native PHY IP to <i>Dynamic Reconfiguration Parameters</i>.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2017.11.06       | Made the following changes: <ul style="list-style-type: none"><li>Updated the note in "Changing VOD, Pre-emphasis Using Direct Reconfiguration Flow" topic to "The PMA analog settings are governed by a set of rules. Not all combinations of <math>V_{OD}</math> and pre-emphasis are valid. Please refer to <i>Arria 10 Pre-Emphasis and Output Swing Settings</i> for current valid settings. Also, refer to "Analog Parameter Settings" and setup guidelines on post_tap polarity settings."</li><li>Updated the description of bit [25:16] in table "Mapping of SystemVerilog Configuration File Line" to "DPRIO address. Refer to Intel Arria 10 Transceiver Register Map for details of the address."</li><li>Changes the configurations file path to "&lt;IP instance name&gt;\altera_xcvr_&lt;IP type&gt;_a10_&lt;quartus version&gt;\synth\reconfig".</li><li>Added Examples 1 and 2 in "fPLL Reference Clock Switching" topic.</li></ul> |
| 2016.10.31       | Made the following changes: <ul style="list-style-type: none"><li>"VGA" PMA Analog Feature added in "PMA Analog Settings that are Channel or System Dependent" table.</li><li>Updated the value of <b>AC Gain Control of High Gain Mode CTLE</b> parameter to <b>radp_ctle_acgain_4s_0 to radp_ctle_acgain_4s_28</b> in the "Analog PMA Settings (Optional) for Dynamic Reconfiguration" table.</li><li>Updated the value of <b>Slew Rate Control</b> parameter to <b>slew_r0 to slew_r5</b> in the "Analog PMA Settings (Optional) for Dynamic Reconfiguration" table.</li></ul>                                                                                                                                                                                                                                                                                                                                                                    |
| 2016.05.02       | Made the following changes <ul style="list-style-type: none"><li>Removed the topic "On-Die Instrumentation" and related information from the user guide.</li><li>Edited "Native PHY IP" with "Native PHY IP and ATX PLL IP" wherever necessary.</li><li>Edited "Embedded Reconfiguration Steamer" topic.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>Edited the "Arbitration" topic.</li> <li>Edited the "Using PRBS and Square Wave Data Pattern Generator and Checker" for bonded as well as non bonded designs. Also added all the examples for each case.</li> <li>Updated "Changing CTLE Settings in Manual Mode Using Direct Reconfiguration Flow" topic.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2015.12.18       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Updated the switching bit register definitions in the "Register Map for Switching fPLL Reference Clock Inputs" table</li> <li>Updated the "Bit Values to Be Set" table in the "Enabling and Disabling Loopback Modes Using Direct Reconfiguration Flow" section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2015.11.02       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Changed the procedure in the "Steps to Perform Dynamic Reconfiguration" section to be more general, allowing procedures in other sections to refer to it.</li> <li>Added the "Changing VOD, Pre-emphasis Using Direct Reconfiguration Flow" section.</li> <li>Added the "Analog PMA Settings (Optional) for Dynamic Reconfiguration" table.</li> <li>Removed four tables from the "On-Die Instrumentation" section.</li> <li>Changed the procedure in the "Using ODI to Build On-chip Eye Process" section.</li> <li>Added entry to "Arria 10 Dynamic Reconfiguration Feature Support" table</li> <li>Improved description of access requests in the "Interacting with the Reconfiguration Interface" section</li> <li>Updated the "Configuration Files" section</li> <li>Added information to the "Embedded Reconfiguration Streamer" section</li> <li>Modified the "Arria 10 Native PHY with Embedded Streamer" figure</li> <li>Described the two levels of arbitration in the "Arbitration" section</li> <li>Converted the "Steps to Perform Dynamic Reconfiguration" figure in the "Steps to Perform Dynamic Reconfiguration" section to a set of procedures</li> <li>Added the "Reset Recommendations for Dynamic Reconfiguration" section</li> <li>Added information about the PMA analog settings to the "Changing PMA Analog Parameters" section</li> <li>Added steps to the procedure in the "Changing CTLE Settings in Manual Mode" section</li> <li>Updated the steps in the procedures in the "Serial Loopback Mode" section</li> <li>Changed title of "IP Guided Reconfiguration Flow" to "Native PHY or PLL IP Guided Reconfiguration Flow"</li> <li>Updated the steps in the procedures in the "Native PHY or PLL IP Guided Reconfiguration Flow" and added a note following the first procedure</li> <li>Updated the steps in the procedure in the "Switching Transmitter PLL" section</li> <li>Updated the steps in the procedures in the "ATX Reference Clock," "fPLL Reference Clock," and "CDR and CMU Reference Clock," sections</li> <li>Updated the "Avalon Interface Parameters" table to show which parameter editors are valid for each parameter</li> <li>Corrected values in step 1a in the "Start Pattern Checker" section</li> <li>Added information about hard PRBS blocks to the "PRBS Soft Accumulators" section</li> <li>Added list of PRBS checker control and status signals to the "Using PRBS and Square Wave Data Pattern Generator and Checker" section</li> <li>Updated the steps in the procedures in the "Enabling the PRBS and Square Wave Data Generator" and the "Enabling the PRBS and Data Checker" sections</li> <li>Updated the steps in the procedures in the "Examples of Enabling the PRBS9 and PRBS31 Pattern Generators" and the "Examples of Enabling the PRBS Data Checker" sections</li> <li>Updated the steps in the procedure in the "Enabling Pseudo Random Pattern Mode" section</li> </ul> |
| 2015.05.11       | <p>Made the following changes:</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>• Completely revised, updated, and reorganized the chapter.</li> <li>• Added the following new sections: <ul style="list-style-type: none"> <li>— Multiple Reconfiguration Profiles</li> <li>— Embedded Reconfiguration Streamer</li> <li>— Arbitration</li> <li>— Enabling and Disabling Loopback Modes</li> <li>— IP Guided Reconfiguration Flow</li> <li>— On-Die Instrumentation</li> <li>— Native PHY Debug Master Endpoint</li> <li>— ODI Acceleration Logic</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2014.12.15       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>• Re-organized the chapter outline to better match the reconfiguration flow.</li> <li>• Updated the introduction section of the chapter to better explain dynamic reconfiguration use cases.</li> <li>• Added figures <i>Reconfiguration Interface in Arria 10 Transceiver IP Cores</i> and <i>Top Level Signals of the Reconfiguration Interface</i>.</li> <li>• Added <i>Timing Closure Recommendations</i> section.</li> <li>• Changed Max Vod Value in Table: <i>PMA Analog Feature Offsets</i>.</li> <li>• Updated Table: Valid Maximum Pre-Emphasis Settings.</li> <li>• Updated the Ports and Parameters section: <ul style="list-style-type: none"> <li>— Updated the description to better indicate the difference between "Shared" and "Not Shared" reconfiguration interface.</li> <li>— Updated Avalon clock frequency to 100 MHz.</li> <li>— Updated the signal names in Table: <i>Reconfiguration Interface Ports with Shared Reconfiguration Interface Enabled</i> and <i>Reconfiguration Interface Ports with Shared Reconfiguration Interface Disabled</i>.</li> </ul> </li> <li>• Added a description in <i>Interfacing with Reconfiguration Interface</i> section to indicate the steps to request access of the Avalon memory-mapped interface.</li> <li>• Updated steps in <i>Performing a Read to the Reconfiguration Interface</i> and <i>Performing a Write to the Reconfiguration Interface</i> sections.</li> <li>• Updated <i>Using Configuration Files</i> section to with a detailed description of when to use configuration files.</li> <li>• Updated the steps in <i>Switching Transmitter PLL</i>, <i>Switching Reference Clocks</i>, and <i>Changing PMA Analog Parameters</i> sections.</li> </ul> |
| 2014.10.08       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>• Minor editorial changes. Corrected typographical errors in <i>Ports and Parameters</i> and <i>Native PHY IP Core Embedded Debug</i> sections.</li> <li>• Corrected an error in "Example 6-1: Steps to Merge Transceiver Channels" in <i>Document Channel Merging Requirements</i> section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2014.08.15       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>• Updated MegaWizard references to IP Catalog or Parameter Editor.</li> <li>• Updated table "Avalon Interface Parameters" <ul style="list-style-type: none"> <li>— Added description for Native PHY Debug Master Endpoint.</li> <li>— Added Embedded Debug Parameters.</li> </ul> </li> <li>• Corrected typos and updated values in table "PMA Analog Feature Offsets".</li> <li>• Added a new table "Valid Maximum Pre-Emphasis Settings" in <i>Changing Analog Parameters Section</i>.</li> <li>• Updated the description for 0xB reconfiguration address bit[7:5] in table "PRBS Checker Offsets".</li> <li>• Updated the <i>Unsupported Features</i> section and removed some unsupported features.</li> <li>• Changed the name of <i>Transceiver and PLL Address Map</i> to <i>Arria 10 Transceiver Register Map</i>. Updated the description to better explain the scope of the register map.</li> <li>• Added a new section for Embedded Debug feature.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2013.12.02       | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

## 7. Calibration

---

Transceivers include both analog and digital blocks that require calibration to compensate for process, voltage, and temperature (PVT) variations. Arria 10 transceiver uses hardened Precision Signal Integrity Calibration Engine (PreSICE) to perform calibration routines.

Power-up Calibration and User Recalibration are the main types of calibration.

- Power-up calibration occurs automatically at device power-up. It runs during device configuration.
- If you perform dynamic reconfiguration, then you must perform User Recalibration. In this case, you are responsible for enabling the required calibration sequence.

**Note:** If you are recalibrating your ATX PLL or fPLL, follow the ATX PLL-to-ATX PLL or fPLL-to-ATX PLL spacing guideline as stated in the "Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs" chapter.

Arria 10 devices use CLKUSR for transceiver calibration. To successfully complete the calibration process, the CLKUSR clock must be stable and free running at the start of FPGA configuration. Also, all reference clocks driving transceiver PLLs (ATX PLL, fPLL, CDR/CMU PLL) must be stable and free running at start of FPGA configuration. For more information about CLKUSR pin requirements, refer to the *Arria 10 GX, GT, and SX Device Family Pin Connection Guidelines*.

### Related Information

- [Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs](#) on page 358
- [Intel Arria 10 GX, GT, and SX Device Family Pin Connection Guidelines](#)

### 7.1. Reconfiguration Interface and Arbitration with PreSICE Calibration Engine

In Arria 10 devices, calibration is performed using the Precision Signal Integrity Calibration Engine (PreSICE). The PreSICE includes an Avalon memory-mapped interface to access the transceiver channel and PLL programmable registers. This Avalon memory-mapped interface includes a communication mechanism that enables you to request specific calibration sequences from the calibration controller.

The PreSICE Avalon memory-mapped interface and user Avalon memory-mapped interface reconfiguration both share an internal configuration bus. This bus is arbitrated to gain access to the transceiver channel and PLL programmable registers, and the calibration registers.

There are two ways to check who has the access to the internal configuration bus:

- Use reconfig\_waitrequest
- Use capability registers

The Native PHY IP core and PLL default setting is to use reconfig\_waitrequest. When PreSICE controls the internal configuration bus, the reconfig\_waitrequest from the internal configuration bus is high. When user access is granted, the reconfig\_waitrequest from the internal configuration bus goes low. At the Avalon memory-mapped interface reconfiguration, the reconfig\_waitrequest can come from a few places inside Native PHY IP core. For example, it can come from the internal configuration bus, streamer, and so on. They are bundled together and become single reconfig\_waitrequest at the Avalon memory-mapped interface reconfiguration. The reconfig\_address determines which reconfig\_waitrequest to show at the Avalon memory-mapped interface reconfiguration. After you return the internal configuration bus to PreSICE, the reconfig\_waitrequest from the internal configuration bus is high. If you set the reconfig\_address to the streamer offset address at the Avalon memory-mapped interface reconfiguration during calibration, the reconfig\_waitrequest can be low before calibration is finished. If you keep the reconfig\_address the same as the internal configuration bus offset address during calibration, the reconfig\_waitrequest at the Avalon memory-mapped interface reconfiguration is high until PreSICE returns the internal configuration bus to you. It is important to keep reconfig\_address static during calibration.

To use capability registers to check bus arbitration, you do the following to generate the IP:

1. Select **Enable dynamic reconfiguration** from the **Dynamic Reconfiguration** tab.
2. Select both the **Separate reconfig\_waitrequest from the status of AVMM arbitration with PreSICE** and **Enable control and status registers** options.

You can read the capability register 0x281[2] to check who is controlling the channel access, and read the capability register 0x280[2] to check who is controlling the PLL access. When **Separate reconfig\_waitrequest from the status of AVMM arbitration with PreSICE** and **Enable control and status registers** are enabled, the reconfig\_waitrequest is not asserted high when PreSICE controls the internal configuration bus.

#### To return the internal configuration bus to PreSICE:

- In order to trigger user re-calibration:
  - Write 0x01 to offset address 0x000 [7:0], user re-calibration has to request through offset address 0x100.
- In order to trigger DFE adaptation:
  - Write 0x03 to offset address 0x000 [7:0], DFE adaptation triggering has to enable through 0x100[6].
- If you no longer need to use the internal reconfiguration bus:
  - Write 0x03 to offset address 0x000 [7:0].

To check if the calibration process is running, do one of the following:

- Monitor the `pll_cal_busy`, `tx_cal_busy`, and `rx_cal_busy` signals.
- Read the `*_cal_busy` signal status from the capability registers.

The `*_cal_busy` signals remain asserted as long as the calibration process is running. To check whether or not calibration is done, you can read the capability registers or check the `*_cal_busy` signals. The `reconfig_waitrequest` from the Avalon memory-mapped interface reconfiguration is not a reliable indicator to check whether or not calibration is done. If you write 0x2 to 0x0 during calibration, PreSICE can stop the calibration process and return the internal configuration bus back to you; therefore, calibration is not done while the `reconfig_waitrequest` is low. The PMA `tx_cal_busy` and `rx_cal_busy` are from the same internal node which cannot be separated from the hardware. Configure the capability register 0x281[5:4] to enable or disable `tx_cal_busy` or `rx_cal_busy` individually through the Avalon memory-mapped interface reconfiguration.

#### Related Information

- [Arbitration on page 524](#)
- [Avalon Interface Specifications](#)
- [Reconfiguration Interface and Dynamic Reconfiguration Chapter on page 514](#)

## 7.2. Calibration Registers

The Arria 10 transceiver PMA and PLLs include the following types of registers for calibration:

- Avalon memory-mapped interface arbitration registers
- Calibration enable registers
- Capability registers
- Rate switch flag registers

The Avalon memory-mapped interface arbitration registers enable you to request internal configuration bus access.

The PMA and PLL calibration enable registers for user recalibration are mapped to offset address 0x100. All calibration enable registers are self-cleared after the calibration process is completed.

The `tx_cal_busy`, `rx_cal_busy`, ATX PLL `pll_cal_busy`, and fPLL `pll_cal_busy` signals are available from the capability registers.

The rate switch flag registers are only used for CDR rate change.

### 7.2.1. Avalon Memory-Mapped Interface Arbitration Registers

Table 299. Avalon Memory-Mapped Interface Arbitration Registers

| Bit | Offset Address      | Description                                                                               |
|-----|---------------------|-------------------------------------------------------------------------------------------|
| [0] | 0x0 <sup>(65)</sup> | This bit arbitrates the control of Avalon memory-mapped interface.<br><i>continued...</i> |

| Bit | Offset Address | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                | <ul style="list-style-type: none"> <li>Set this bit to 0 to request control of the internal configuration bus by user.</li> <li>Set this bit to 1 to pass the internal configuration bus control to PreSICE.</li> </ul>                                                                                                                                                                                                                                                                                                                                                             |
| [1] | 0x0            | <p>This bit indicates whether or not calibration is done. This is the inverted cal_busy signal. You can write to this bit; however, if you accidentally write 0x0 without enabling any calibration bit in 0x100, PreSICE may not set this bit to 0x1, and cal_busy remain high. Channel reset is triggered if cal_busy is connected to the reset controller.</p> <ul style="list-style-type: none"> <li>0x1 = calibration completed.</li> <li>0x0 = calibration not completed.</li> </ul> <p>The cal_busy signal is activated two clock cycles after you write 0x0 to this bit.</p> |

**Note:** During calibration when Nios is controlling the internal configuration bus, you can not read offset address 0x0. However, you can write 0x0 to offset address 0x0[0] to request bus access.

## 7.2.2. Transceiver Channel Calibration Registers

**Table 300. Transceiver Channel PMA Calibration Registers**

| Bit | PMA Calibration Enable Register Offset Address 0x100                                                                    |
|-----|-------------------------------------------------------------------------------------------------------------------------|
| 0   | Reserved                                                                                                                |
| 1   | PMA RX calibration enable                                                                                               |
| 2   | Reserved                                                                                                                |
| 3   | Reserved                                                                                                                |
| 4   | Reserved                                                                                                                |
| 5   | PMA TX calibration enable                                                                                               |
| 6   | Write 1'b0 to 0x100 [6] when you enable any PMA channel calibration to ensure adaptation triggering request is disable. |
| 7   | Reserved                                                                                                                |

## 7.2.3. Fractional PLL Calibration Registers

**Table 301. Fractional PLL Calibration Registers**

| Bit | fPLL Calibration Enable Register Offset Address 0x100 |
|-----|-------------------------------------------------------|
| 0   | Reserved                                              |
| 1   | fPLL calibration enable. Set 1 to enable calibration. |

(65) The transceiver channel, ATX PLL, and fPLL use the same offset address.

## 7.2.4. ATX PLL Calibration Registers

Table 302. ATX PLL Calibration Registers

| Bit | ATX PLL Calibration Enable Register Offset Address 0x100 |
|-----|----------------------------------------------------------|
| 0   | ATX PLL calibration enable. Set 1 to enable calibration. |
| 1   | Reserved                                                 |

During calibration when `reconfig_waitrequest` is high, you cannot read or write calibration enable registers.

To enable calibration, you must perform a read-modify-write on offset address 0x100. The following steps are an example of how to enable the ATX PLL calibration enable bit:

1. Read the offset address 0x100.
2. Keep the value from MSB[7:1] and set LSB[0] to 1.
3. Write new value to offset address 0x100.

## 7.2.5. Capability Registers

Capability registers allow you to read calibration status through the Avalon memory-mapped interface reconfiguration. They are soft logic and reside in the FPGA fabric.

Reading capability registers does not require bus arbitration. You can read them during the calibration process.

To use capability registers to check calibration status, you must enable the capability registers when generating the Native PHY or PLL IP cores. To enable the capability registers, select the **Enable capability registers** option in the **Dynamic Reconfiguration** tab.

The `tx_cal_busy` and `rx_cal_busy` signals from the hard PHY are from the same hardware and change state (high/low) concurrently during calibration. The register bits 0x281[5:4] are defined to solve this issue. This prevents a TX channel being affected by RX calibration, or an RX channel being affected by TX calibration. This feature cannot be enabled, when a Simplex TX and Simplex RX channel merging is involved. To merge a Simplex TX and a Simplex RX channel into one physical channel, refer to [Dynamic Reconfiguration Interface Merging Across Multiple IP Blocks](#) on page 554.

### Rules to Build Customized Gating Logic to Separate tx\_cal\_busy and rx\_cal\_busy signals

**Figure 285. An Example of an AND Gate used as Customized Logic**

The customized gates shown in the following figure are an example and not a unique solution



The capability register is not available for merging a Simplex TX and a Simplex RX signal into the same physical channel. The tx\_cal\_busy\_out and rx\_cal\_busy\_out signals share the same port. So, you should build customized gating logic to separate them.

- The tx\_cal\_busy\_out\_en signal enables the tx\_cal\_busy output.
- The rx\_cal\_busy\_out\_en signal enables the rx\_cal\_busy output.
- At power up, tx\_cal\_busy\_out\_en and rx\_cal\_busy\_out\_en should be set to "1".
- At normal operation:
  - When the RX is calibrating, setting tx\_cal\_busy\_out\_en to "0" and rx\_cal\_busy\_out\_en to "1" disables tx\_cal\_busy, so the TX does not reset while RX is calibrating.
  - When the TX is calibrating, setting rx\_cal\_busy\_out\_en to "0" and tx\_cal\_busy\_out\_en to "1" disables rx\_cal\_busy, so the RX does not reset while TX is calibrating.

**Table 303. PMA Capability Registers for Calibration Status**

| Bit      | Description                                                                                                                                                                                                                                                                                                        |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x281[5] | PMA channel rx_cal_busy output enable. The power up default value is 0x1.<br>0x1: The rx_cal_busy output and 0x281[1] are asserted high whenever PMA TX or RX calibration is running.<br>0x0: The rx_cal_busy output or 0x281[1] is never asserted high.                                                           |
| 0x281[4] | PMA channel tx_cal_busy output enable. The power up default value is 0x1.<br>0x1: The tx_cal_busy output and 0x281[0] are asserted high whenever PMA TX or RX calibration is running.<br>0x0: The tx_cal_busy output or 0x281[0] is never asserted high.                                                           |
| 0x281[2] | PreSICE Avalon memory-mapped interface control. This register is available to check who controls the bus, no matter if, separate reconfig_waitrequest from the status of Avalon memory-mapped interface arbitration with PreSICE is enabled or not.<br>0x1: PreSICE is controlling the internal configuration bus. |

*continued...*

| Bit      | Description                                                                                                  |
|----------|--------------------------------------------------------------------------------------------------------------|
|          | 0x0: The user has control of the internal configuration bus.                                                 |
| 0x281[1] | PMA channel rx_cal_busy active high<br>0x1: PMA RX calibration is running<br>0x0: PMA RX calibration is done |
| 0x281[0] | PMA channel tx_cal_busy active high<br>0x1: PMA TX calibration is running<br>0x0: PMA TX calibration is done |

The PMA 0x281[5:4] is used to isolate the TX and RX calibration busy status. If you want rx\_cal\_busy unchanged during the TX calibration, you must set 0x281[5] to 0x0 before returning the bus to PreSICE. The channel RX is not reset due to the TX calibration. If you want tx\_cal\_busy unchanged during the RX calibration, you must set 0x281[4] to 0x0 before returning the bus to PreSICE. The channel TX is not reset due to the RX calibration. If you accidentally write 0x00 to 0x281[5:4], tx\_cal\_busy and rx\_cal\_busy are never activated to high in the user interface. Neither of the 0x281[1:0] registers go high either.

**Table 304. ATX PLL Capability Registers for Calibration Status**

| Bit      | Description                                                                                                                                                                                                                                                                                                                                                                        |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x280[2] | PreSICE Avalon memory-mapped interface control. This register is available to check who controls the bus, no matter if, separate reconfig_waitrequest from the status of Avalon memory-mapped interface arbitration with PreSICE is enabled or not.<br>0x1: PreSICE is controlling the internal configuration bus.<br>0x0: The user has control of the internal configuration bus. |
| 0x280[1] | ATX PLL pll_cal_busy<br>0x1: ATX PLL calibration is running<br>0x0: ATX PLL calibration is done                                                                                                                                                                                                                                                                                    |

**Table 305. fPLL Capability Registers for Calibration Status**

| Bit      | Description                                                                                                                                                                                                                                                                                                                                                                       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x280[2] | PreSICE Avalon memory-mapped interface control<br>0x1: PreSICE is controlling the internal configuration bus. This register is available to check who controls the bus, no matter if, separate reconfig_waitrequest from the status of Avalon memory-mapped interface arbitration with PreSICE is enabled or not.<br>0x0: The user has control of the internal configuration bus. |
| 0x280[1] | fPLL_pll_cal_busy<br>0x1: fPLL calibration is running<br>0x0: fPLL calibration is done                                                                                                                                                                                                                                                                                            |

## 7.2.6. Rate Switch Flag Register

The rate switch flag is for CDR charge pump calibration. Each SOF has CDR default charge pump settings. After power up, these settings are loaded into the PreSICE memory space. If you change the line rate, it may require new charge pump settings, which are stored into the Avalon memory-mapped interface reconfiguration register space. During RX PMA calibration (including CDR), PreSICE needs to know which set of CDR charge pump setting to use.

If you set  $0x166[7] = 0x1$ , PreSICE assumes the setting in its memory space is still valid. If after a rate change you set  $0x166[7]=0x0$ , PreSICE uses the setting from the Avalon memory-mapped interface reconfiguration register uploaded from the dynamic reconfiguration interface or MIF streamed in. After calibration,  $0x166[7] = 0x1$  is set automatically and PreSICE uses the settings in its memory space. The rate switch flag only tells PreSICE where to obtain the CDR charge pump settings for CDR calibration. The rate switch flag should be used only when there is a rate change.

Multiple MIF files are required for rate change and reconfiguration. When the MIF, which you want to stream in, has CDR charge pump setting  $0x139[7]$  and  $0x133[7:5]$  that is different from the previous MIF, you need to recalibrate with  $0x166[7]=0x0$ . If you stream in the whole MIF, the  $0x166[7]$  is set to the correct value inside the MIF. If you stream in reduced MIF, you need to check if CDR charge pump setting  $0x139[7]$  and  $0x133[7:5]$  are inside the reduced MIF or not. If the reduced MIF has CDR charge pump setting  $0x139[7]$  and  $0x133[7:5]$  updated, you need to set  $0x166[7]=0x0$ , if the reduced MIF does not include  $0x139[7]$  and  $0x133[7:5]$ , you need to set  $0x166[7]=0x1$ .

**Table 306. Rate Switch Flag Register for CDR Calibration**

| Bit        | Description                                                                                                                                                                                                                                            |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $0x166[7]$ | Rate switch flag register. Power up default value is $0x1$ .<br>$0x1$ , PreSICE uses the default CDR charge pump bandwidth from the default memory space.<br>$0x0$ , PreSICE uses the CDR charge pump bandwidth setting from the DPRIO register space. |

If you use the Avalon memory-mapped interface reconfiguration to perform a rate change, you must write  $0x0$  to  $0x166[7]$  before returning the bus to PreSICE.

### 7.3. Power-up Calibration

After the device is powered up and programmed, PreSICE automatically initiates the calibration process. The calibration process may continue during device programming. The time required after device power-up to complete the calibration process can vary by device. The total time taken can extend into the user-mode. The `cal_busy` signals deassert to indicate the completion of the calibration process. You must ensure that the transceiver reset sequence in your design waits for the calibration to complete before resetting the transceiver PLL and the transceiver channel.

The PreSICE may still control the internal configuration bus even after power-up calibration is complete. You can request access when needed. If a system has an fPLL, an ATX PLL, and channels, the fPLL `cal_busy` signal goes low first. The ATX PLL `cal_busy` signal goes low after the channels' `tx_cal_busy` and `rx_cal_busy` signals. Intel recommends that you wait until all `*_cal_busy` signals are low before requesting any access.

All power-up calibration starts from Vreg calibration for all banks and channels.

PCIe link does not allow user recalibration, so you must perform power-up calibration.

Furthermore, power-up calibration for channels configured with the PCIe protocol require a reference clock. Without the presence of a reference clock, power-up calibration does not start but waits indefinitely, so supply a reference clock to the PCIe `refclk` pin for the power-up calibration process.

**Figure 286. Power-up Calibration Sequence for Non-PCIe Hard IP (HIP) Channels**

For applications not using PCIe Hard IP, the power-up calibration starts from Vreg calibration for all banks and channels. Then, PreSICE calibration is done in the sequence as shown in the following figure.



(1) CDR and CMU PLL calibration are part of RX PMA calibration.

For applications using both PCIe Hard IP and non-PCIe channels, the power-up calibration sequence is:

1. Vreg calibration for all banks and channels.
2. Wait for PCIe reference clock toggle.
3. PCIe Hard IP 0 calibration (if used).
4. PCIe Hard IP 1 calibration (if used).
5. Calibration of all non-PCIe Hard IP channels in calibration sequence.

**Figure 287. Power-up Calibration Sequence for PCIe Hard IP and non-PCIe Channels**



(1) CDR and CMU PLL calibration are part of RX PMA calibration.

## 7.4. User Recalibration

User Recalibration is needed if below conditions are met:

- **During Device Power Up:**
  - During device power up, CLKUSR is asserted and running, but the transceiver reference clock remains deasserted until after the power up process is complete.
  - During device power up, CLKUSR and the transceiver reference clock are asserted and running. When the device power up process is complete, the transceiver reference clock changes frequency. Either the transceiver reference clock could become unstable, or your application requires a different transceiver reference clock during normal operation, which could cause a data rate change.
- **After a dynamic reconfiguration process that triggers a data rate change:**

After device power up in normal operation, you reconfigure the transceiver data rate by changing the channel configurations or the PLLs, recalibrate the:

  - ATX PLL if ATX PLL has new VCO frequency to support new data rate.
  - fPLL if the fPLL has new VCO frequency to support new data rate.

*Note:* fPLL recalibration is not needed if the dynamic reconfiguration method used to achieve new data rate (new VCO frequency) is done using the fPLL L counter /1,2,4,8 division factor.

  - CDU/CMU as TX PLL. You must recalibrate the RX PMA of the channel which uses the CMU as TX PLL.
  - RX PMA and TX PMA channel if the transceiver configuration changes to support new data rates.
- **Other conditions that require a user recalibration:**
  - Recalibrate the fPLL if the fPLL is connected as a second PLL (downstream cascaded PLL). The downstream fPLL received the reference clock from the upstream PLL (could be from fPLL/ CDR). Recalibrating the second fPLL is important especially if the upstream PLL output clock (which is the downstream fPLL's reference clock) is not present or stable during power-up calibration.
  - For ATX PLL or fPLL used to drive PLL feedback compensation bonding, recalibrate the PLL after power up calibration.

*Note:* If you are recalibrating your ATX PLL or fPLL, follow the ATX PLL-to-ATX PLL or fPLL-to-ATX PLL spacing guideline as stated in the "Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs" chapter.

You can initiate the recalibration process by writing to the specific recalibration registers. You must also reset the transceivers after performing user recalibration. For example, if you perform data rate auto-negotiation that involves PLL reconfiguration, and PLL and channel interface switching, then you must reset the transceivers.

The proper reset sequence is required after calibration. Intel recommends you use the Transceiver PHY Reset Controller which has `tx_cal_busy` and `rx_cal_busy` inputs and follow Intel's recommended reset sequence. You need to connect `tx_cal_busy` and `rx_cal_busy` from the Native PHY IP core outputs to the reset controller inputs in your design. Reset upon calibration is automatically processed when you perform user recalibration.

Follow these steps to perform user recalibration:

1. Request internal configuration bus user access to the calibration registers by writing 0x2 to offset address 0x0[7:0].
2. Wait for `reconfig_waitrequest` to be deasserted (logic low). Or wait until capability register of PreSICE Avalon memory-mapped interface control =0x0. The `avmm_busy` status register is 0x281[2] for PMA channel calibration and 0x280[2] for ATX PLL and fPLL calibration.
3. Set the required calibration enable bits by doing Read-Modify-Write the proper value to offset address 0x100. You must also set the 0x100 [6] to 0x0 when you enable any PMA channel calibration to ensure adaptation triggering is disabled.
4. Set rate switch flag register for PMA calibration, skip this step for ATX PLL and fPLL calibration.
  - Read-Modify-Write 0x1 to offset address 0x166[7] if no CDR rate switch.
  - Read-Modify-Write 0x0 to offset address 0x166[7] if switched rate with different CDR bandwidth setting.
5. Set the proper value to capability register 0x281[5:4] for PMA calibration to enable/disable `tx_cal_busy` or `rx_cal_busy` output.
  - To enable `rx_cal_busy`, Read-Modify-Write 0x1 to 0x281[5].
  - To disable `rx_cal_busy`, Read-Modify-Write 0x0 to 0x281[5].
  - To enable `tx_cal_busy`, Read-Modify-Write 0x1 to 0x281[4].
  - To disable `tx_cal_busy`, Read-Modify-Write 0x0 to 0x281[4].
6. Release the internal configuration bus to PreSICE to perform recalibration by writing 0x1 to offset address 0x0[7:0]. Recalibration is in progress until the `cal_busy` signals are deasserted (logic low).
7. Periodically check the `*cal_busy` output signals or read the capability registers to check `*cal_busy` status until calibration is complete.

#### Related Information

- [Recommended Reset Sequence](#) on page 430
- [Implementing PLL Feedback Compensation Bonding Mode](#) on page 417
- [Implementing PLL Cascading](#) on page 420
- [Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs](#) on page 358

### 7.4.1. Recalibration After Transceiver Reference Clock Frequency or Data Rate Change

**Figure 288. Recalibration Sequence when the Transceiver Reference Clock or Data Rate Changes**



Note:

- (1) If you are using the CDR/CMU PLL, you need to trigger RX PMA recalibration.
- (2) If you are using the CMU PLL, you need to trigger RX PMA recalibration followed by a TX PMA recalibration.

#### 7.4.1.1. User Recalibration

User recalibration requires access to the internal configuration bus and calibration registers through the Avalon memory-mapped interface reconfiguration. Follow the steps below to perform a user recalibration.

1. Proceed to the next step if ATX PLL is not used in your application, otherwise perform the ATX PLL calibration process:
  - a. Request access to the internal configuration bus by writing 0x2 to offset address 0x0[7:0].
  - b. Wait for `reconfig_waitrequest` to deassert (logic low), or wait until capability register of PreSICE Avalon memory-mapped interface control `0x280[2]=0x0`.
  - c. Read-Modify-Write 0x1 to the offset address 0x100[0] of the ATX PLL.
  - d. Release the internal configuration bus to PreSICE to perform recalibration by writing 0x1 to offset address 0x0[7:0].
  - e. Periodically check the `*cal_busy` output signals or read the capability registers `0x280[1]` to check `*cal_busy` status until calibration is complete.If you are recalibrating your ATX PLL and have adjacent ATX PLL used on the same side of the device, follow the ATX PLL-to-ATX PLL spacing guideline as stated in the "Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs" chapter.
2. Proceed to the next step if fPLL is not used in your application, otherwise perform the fPLL user recalibration process:

- a. Access the internal configuration bus by writing 0x2 to offset address 0x0[7:0].
- b. Wait for reconfig\_waitrequest to deassert (logic low), or wait until capability register of PreSICE Avalon memory-mapped interface control 0x280[2]=0x0.
- c. Read-Modify-Write 0x1 to the offset address 0x100[1] of the fPLL.
- d. Release the internal configuration bus to PreSICE to perform recalibration by writing 0x1 to offset address 0x0[7:0].
- e. Periodically check the \*cal\_busy output signals or read the capability registers 0x280[1] to check \*cal\_busy status until calibration is complete.

If you are recalibrating your fPLL and have ATX PLL used on the same side of the device, follow the fPLL-to-ATX PLL spacing guideline as stated in the "Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs" chapter.

3. Perform the PMA user recalibration process:
  - a. Request access to the internal configuration bus by writing 0x2 to offset address 0x0[7:0].
  - b. Wait for reconfig\_waitrequest to deassert (logic low), or wait until capability register of PreSICE Avalon memory-mapped interface control 0x281[2]=0x0.
  - c. Configure the PMA calibration enable register 0x100. You must set 0x0 to 0x100[6] to enable any calibration.
    - Read-Modify-Write 0x1 to 0x100[1] to start PMA RX calibration.
    - Read-Modify-Write 0x1 to 0x100[5] to start PMA TX calibration.
  - d. Do Read-Modify-Write on the rate switch flag register if you switched rates with a different CDR bandwidth setting.
  - e. Do Read-Modify-Write on 0x281[5:4] to disable/enable rx\_cal\_busy and tx\_cal\_busy.
    - To enable rx\_cal\_busy, write 0x1 to 0x281[5].
    - To disable rx\_cal\_busy, write 0x0 to 0x281[5].
    - To enable tx\_cal\_busy, write 0x1 to 0x281[4].
    - To disable tx\_cal\_busy, write 0x0 to 0x281[4].
  - f. Release the internal configuration bus to PreSICE to perform recalibration by writing 0x1 to offset address 0x0[7:0].
  - g. Perform a loop to check the tx\_cal\_busy and rx\_cal\_busy output signals or read the capability registers 0x281[1:0] to check \*cal\_busy status until calibration is complete.

### Related Information

[Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs](#) on page 358

## 7.5. Calibration Example

### 7.5.1. ATX PLL Recalibration

When you use the ATX PLL in your application, and it requires a line rate or clock frequency change, you must recalibrate the ATX PLL after you have made the changes.

Follow these steps to recalibrate the ATX PLL:

1. Request user access to the internal configuration bus by writing 0x2 to offset address 0x0[7:0].
2. Wait for `reconfig_waitrequest` to be deasserted (logic low) or wait until capability register of PreSICE Avalon memory-mapped interface control 0x280[2]=0x0.
3. To calibrate the ATX PLL, doing Read-Modify-Write 0x1 to bit[0] of address 0x100 of the ATX PLL.
4. Release the internal configuration bus to PreSICE to perform recalibration by writing 0x1 to offset address 0x0[7:0].
5. Periodically check the `*cal_busy` output signals or read the capability registers 0x280[1] to check `*cal_busy` status until calibration is complete.

**Note:** If you are recalibrating your ATX PLL and have adjacent ATX PLL used on the same side of the device, follow the ATX PLL-to-ATX PLL spacing guideline as stated in the "Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs" chapter.

#### Related Information

[Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs](#) on page 358

### 7.5.2. Fractional PLL Recalibration

Follow these steps to recalibrate the fPLL:

1. Request user access to the internal configuration bus by writing 0x2 to offset address 0x0[7:0].
2. Wait for `reconfig_waitrequest` to be deasserted (logic low) or wait until capability register of PreSICE Avalon memory-mapped interface control 0x280[2]=0x0.
3. To calibrate the fPLL, Read-Modify-Write 0x1 to bit[1] of address 0x100 of the fPLL.
4. Release the internal configuration bus to PreSICE to perform recalibration by writing 0x1 to offset address 0x0[7:0].
5. Periodically check the `*cal_busy` output signals or read the capability registers 0x280[1] to check `*cal_busy` status until calibration is complete.

**Note:** If you are recalibrating your fPLL and have ATX PLL used on the same side of the device, follow the fPLL-to-ATX PLL spacing guideline as stated in the "Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs" chapter.

#### Related Information

[Transmit PLLs Spacing Guideline when using ATX PLLs and fPLLs](#) on page 358

### 7.5.3. CDR/CMU PLL Recalibration

CDR/CMU PLL user recalibration is integrated into the PMA RX user recalibration. Enabling 0x100[1] PMA RX calibration recalibrates the CDR/CMU PLL.

### 7.5.4. PMA Recalibration

PMA calibration includes:

- PMA TX calibration
- PMA RX calibration

The PMA RX calibration includes CDR/CMU PLL calibration, offset cancellation calibration, and  $V_{CM}$  calibration. The TX PMA calibration includes TX termination,  $V_{od}$ , and DCD calibration.

Follow these steps to recalibrate the PMA:

1. Request access to the internal configuration bus by writing 0x2 to offset address 0x0[7:0].
2. Wait for `reconfig_waitrequest` to be deasserted (logic low), or wait until capability register of PreSICE Avalon memory-mapped interface control 0x281[2]=0x0.
3. Set the proper value to offset address 0x100 to enable PMA calibration. You must also set the 0x100 [6] to 0x0 when you enable any PMA channel calibration to ensure adaptation triggering is disabled.
4. Set the rate switch flag register for PMA RX calibration after the rate change.
  - Read-Modify-Write 0x1 to offset address 0x166[7] if no rate switch.
  - Read-Modify-Write 0x0 to offset address 0x166[7] if switched rate with different CDR bandwidth setting.
5. Do Read-Modify-Write the proper value to capability register 0x281[5:4] for PMA calibration to enable/disable `tx_cal_busy` or `rx_cal_busy` output.
  - To enable `rx_cal_busy`, Read-Modify-Write 0x1 to 0x281[5].
  - To disable `rx_cal_busy`, Read-Modify-Write 0x0 to 0x281[5].
  - To enable `tx_cal_busy`, Read-Modify-Write 0x1 to 0x281[4].
  - To disable `tx_cal_busy`, Read-Modify-Write 0x0 to 0x281[4].
6. Release the internal configuration bus to PreSICE to perform recalibration by writing 0x1 to offset address 0x0[7:0].
7. Periodically check the `*cal_busy` output signals or read the capability registers 0x281[1:0] to check `*cal_busy` status until calibration is complete.

#### Related Information

[Transceiver Channel Calibration Registers](#) on page 582  
For more details about PMA recalibration

## 7.6. Calibration Revision History

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2018.09.24       | Made the following change: <ul style="list-style-type: none"><li>• Noted that PCIe requires power-up calibration, and the power-up calibration requires a reference clock.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2018.06.15       | Made the following change: <ul style="list-style-type: none"><li>• Added a footnote: CDR and CMU PLL calibration are part of RX PMA calibration.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2017.11.06       | Made the following changes: <ul style="list-style-type: none"><li>• Updated the flow of "User Recalibration" topic.</li><li>• Updated "<ul style="list-style-type: none"><li>— In order to trigger user re-calibration:<ul style="list-style-type: none"><li>• Write 0x01 to offset address 0x000 [7:0], user re-calibration has to request through offset address 0x100.</li></ul></li><li>— In order to trigger DFE adaptation:<ul style="list-style-type: none"><li>• Write 0x03 to offset address 0x000 [7:0], DFE adaptation triggering has to enable through 0x100[6].</li></ul></li><li>— If you no longer need to use the internal reconfiguration bus:<ul style="list-style-type: none"><li>• Write 0x03 to offset address 0x000 [7:0].</li></ul></li></ul>" in the "Reconfiguration Interface and Arbitration with PreSICE Calibration Engine" topic.</li><li>• Updated "You must also set the 0x100 [6] to 0x0 when you enable any PMA channel calibration to ensure adaptation triggering is disabled." in "User Recalibration" topic.</li><li>• Updated "PMA Calibration Enable Register Offset Address 0x100" to "Write 1'b0 to 0x100 [6] when you enable any PMA channel calibration to ensure adaptation triggering request is disable." for bit 6 in "Transceiver Channel PMA Calibration Registers" table.</li></ul> |
| 2016.10.31       | Made the following change: <ul style="list-style-type: none"><li>• In table "Avalon Memory-Mapped Interface Arbitration Registers" the description for bit [1] is changed to "0x1=calibration completed and 0x0=calibration not started".</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2016.05.02       | <ul style="list-style-type: none"><li>• Changed the "user calibration" flow.</li><li>• Changed the "power up calibration" sequence.</li><li>• Added descriptions for "Simplex calibration".</li><li>• Added a new section "Rules to Build Customized Gating Logic to Separate tx_cal_busy and rx_cal_busy signals".</li><li>• Updated the "Power-up Calibration Sequence for Non-PCIe Hard IP (HIP) Channels", "Power-up Calibration Sequence for PCIe Hard IP and non-PCIe Channels", and "Recalibration Sequence when the Transceiver Reference Clock or Data Rate Changes" figures.</li><li>• Changed the order of the "User Recalibration" steps in the "Recalibration After Transceiver Reference Clock Frequency or Data Rate Change" section.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2015.12.18       | Made the following changes: <ul style="list-style-type: none"><li>• Changed the description in the "Rate Switch Flag Register" section.</li><li>• Added more description to the "User Recalibration" section.</li><li>• Added information in the "PMA Recalibration" section.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2015.11.02       | Made the following changes: <ul style="list-style-type: none"><li>• Changed the description in the "Reconfiguration Interface and Arbitration with PreSICE Calibration Engine" section.</li><li>• Changed the description in the "Calibration Registers" section.</li><li>• Changed the "Transceiver Channel PMA Calibration Registers for Production Devices" table.</li><li>• Removed description from the "Transceiver Channel Calibration Registers" section.</li><li>• Changed values in the "Fractional PLL Calibration Registers" table.</li><li>• Changed the "PMA Capability Registers for Calibration Status" table.</li><li>• Added the "ATX PLL Capability Registers for Calibration Status" table.</li><li>• Added the "fPLL Capability Registers for Calibration Status" table.</li><li>• Added description to the "Capability Registers" section.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>• Added the "Rate Switch Flag Register" section.</li> <li>• Added steps to the "User Recalibration" section.</li> <li>• Changed the description in the "CDR/CMU PLL Recalibration" section.</li> <li>• Added steps to the "PMA Recalibration" section.</li> <li>• Changed the "Recalibration Sequence when the Transceiver Reference Clock or Data Rate Changes" figure.</li> <li>• Added steps to the "User Recalibration" section.</li> <li>• Updated the "Transceiver Channel PMA Calibration Registers for Production Devices" table.</li> <li>• Updated the "Fractional PLL Calibration Registers" table.</li> <li>• Updated the "ATX PLL Calibration Registers" table.</li> <li>• Changed the description in the "ATX PLL Calibration Registers" section.</li> <li>• Added description to the "Capability Registers" section.</li> <li>• Changed the "Power-up Calibration Sequence for Non-PCIe Hard IP (HIP) Channels" figure.</li> <li>• Changed the "Power-up Calibration Sequence for PCIe HIP and non-PCIe Channels" figure.</li> <li>• Removed some steps from the "User Recalibration" section.</li> <li>• Removed some steps from the "ATX PLL Recalibration" section.</li> <li>• Removed some steps from the "Fractional PLL Recalibration" section.</li> <li>• Removed some steps from the "PMA Recalibration" section.</li> <li>• Removed the "Check Calibration Status" section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2015.05.11       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>• Changed register offsets globally.</li> <li>• Changed the description in the "Reconfiguration Interface and Arbitration with PreSICE Calibration Engine" section.</li> <li>• Changed the description in the "Calibration Registers" section.</li> <li>• Changed the descriptions and added a bit in the "Avalon Memory-Mapped Interface Arbitration Registers" table.</li> <li>• Changed the descriptions in the "Transceiver Channel Calibration Registers" table.</li> <li>• Changed the descriptions in the "Fractional PLL Calibration Registers" table.</li> <li>• Changed the descriptions in the "ATX PLL Calibration Registers" table.</li> <li>• Added the "Power-up Calibration Sequence for Non-PCIe Hard IP (HIP) Channels" and "Power-up Calibration Sequence for PCIe HIP and non-PCIe Channels" figures.</li> <li>• Changed "Avalon memory-mapped interface" to "internal configuration bus" in the "User Recalibration" section.</li> <li>• Changed "Avalon memory-mapped interface" to "internal configuration bus" in the "ATX PLL Recalibration" section.</li> <li>• Changed the bit to calibrate the fPLL and changed "Avalon memory-mapped interface" to "internal configuration bus" in the "Fractional PLL Recalibration" section.</li> <li>• Changed "Avalon memory-mapped interface" to "internal configuration bus" in the "CMU or CDR PLL Recalibration" section.</li> <li>• Changed the addresses in the "User Recalibration" section.</li> <li>• Changed the addresses in the "ATX PLL Recalibration" section.</li> <li>• Changed the addresses in the "Fractional PLL Recalibration" section.</li> <li>• Changed the addresses in the "CDR/CMU PLL Recalibration" section.</li> <li>• Changed the addresses and added descriptions in the "PMA Recalibration" section.</li> <li>• Changed the addresses in the "Check Calibration Status" section.</li> <li>• Changed "Avalon memory-mapped interface" to "internal configuration bus" in the "PMA Recalibration" section.</li> <li>• Added the "Capability Registers" section.</li> </ul> |
| 2014.12.15       | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## 8. Analog Parameter Settings

---

Transceiver analog parameter settings are used to tune the analog functions in the physical medium attachment (PMA) and the PLL blocks while designing high-speed serial protocol solutions. You can use this feature to compensate for signal losses for high data rate communication.

Most transceiver parameters can be set using the **Parameter Editor** before generating the transceiver PHY IP. The parameters that depend on place and route decisions, device constraints, and tunable analog settings that cannot be set before IP generation are controlled in the following ways:

- Making analog parameter settings to I/O pins using the Assignment Editor.
- Updating the Quartus Prime Settings File (**.qsf**) with the known assignment.
- Using the Reconfiguration Interface to dynamically change the analog settings.

### 8.1. Making Analog Parameter Settings using the Assignment Editor

To make assignments using the **Assignment Editor**, complete the following steps:

1. On the **Assignments** menu, select **Assignment Editor**. The **Assignment Editor** appears.
2. Click inside the **Assignment Name** column and select the appropriate assignment. Refer to the *PMA Analog Settings* section for the list of available assignments for PMA analog settings.
3. Click inside the **Value** column and select the appropriate value for your assignment.  
The Quartus Prime software adds these instance assignments to the **.qsf** file for your project.

#### Related Information

[Analog Parameter Settings List](#) on page 598

### 8.2. Updating Quartus Settings File with the Known Assignment

The Quartus Prime Settings File (**.qsf**) contains all the entity-level assignments and settings for the current revision of the project. The Quartus Settings File is based on Tcl script syntax.

When you create assignments and settings using the **Parameter Editor** wizards and dialog boxes or Tcl commands, the Quartus Prime software automatically places the assignments at the end of the Quartus Prime Settings File. To control the analog parameters, you can directly add or modify the appropriate assignment in the Quartus Prime Settings File. The assignments you create are recognized, regardless of where you place them in the file.

### Related Information

#### Quartus Prime Settings File (.qsf)

Describes the commands and options available to modify the assignments in the qsf file.

## 8.3. Analog Parameter Settings List

The following table lists the analog parameter settings for the transmitter and receiver. The details of each of these settings are in the sections following this table.

**Table 307. Receiver Analog Parameter Settings**

| Analog Parameter Setting        | Pin Planner or Assignment Editor Name                            | Assignment Destination | Usage Guideline                            |
|---------------------------------|------------------------------------------------------------------|------------------------|--------------------------------------------|
| XCVR_A10_RX_LINK                | Receiver Link Type                                               | RX serial data         | Chip-to-chip or backplane                  |
| XCVR_A10_RX_TERM_SEL            | Receiver On-Chip-Termination                                     | RX serial data         | On chip termination                        |
| XCVR_VCCR_VCCT_VOLTAGE          | VCCR_GXB/VCCT_GXB Voltage                                        | RX serial data         | VCCR/VCCT voltage                          |
| XCVR_A10_RX_ONE_STAGE_ENABLE    | Receiver High Data Rate Mode Equalizer                           | RX serial data         | Continuous time-linear equalization (CTLE) |
| XCVR_A10_RX_EQ_DC_GAIN_TRIM     | Receiver High Gain Mode Equalizer DC Gain Control                | RX serial data         | CTLE                                       |
| XCVR_A10_RX_ADG_CTLE_ACGAIN_4S  | Receiver High Gain Mode Equalizer AC Gain Control                | RX serial data         | CTLE                                       |
| XCVR_A10_RX_ADG_CTLE_EQZ_1S_SEL | Receiver High Data Rate Mode Equalizer AC Gain Control           | RX serial data         | CTLE                                       |
| XCVR_A10_RX_ADG_VGA_SEL         | Receiver Variable Gain Amplifier Voltage Swing Select            | RX serial data         | VGA                                        |
| XCVR_A10_RX_ADG_DFE_FXTAP1      | Receiver Decision Feedback Equalizer Fixed Tap One Coefficient   | RX serial data         | Decision feedback equalization (DFE)       |
| XCVR_A10_RX_ADG_DFE_FXTAP2      | Receiver Decision Feedback Equalizer Fixed Tap Two Coefficient   | RX serial data         | DFE                                        |
| XCVR_A10_RX_ADG_DFE_FXTAP2_SGN  | Receiver Decision Feedback Equalizer Fixed Tap Two Sign          | RX serial data         | DFE                                        |
| XCVR_A10_RX_ADG_DFE_FXTAP3      | Receiver Decision Feedback Equalizer Fixed Tap Three Coefficient | RX serial data         | DFE                                        |
| XCVR_A10_RX_ADG_DFE_FXTAP3_SGN  | Receiver Decision Feedback Equalizer Fixed Tap Three Sign        | RX serial data         | DFE                                        |
| XCVR_A10_RX_ADG_DFE_FXTAP4      | Receiver Decision Feedback Equalizer Fixed Tap Four Coefficient  | RX serial data         | DFE                                        |
| XCVR_A10_RX_ADG_DFE_FXTAP4_SGN  | Receiver Decision Feedback Equalizer Fixed Tap Four Sign         | RX serial data         | DFE                                        |
| XCVR_A10_RX_ADG_DFE_FXTAP5      | Receiver Decision Feedback Equalizer Fixed Tap Five Coefficient  | RX serial data         | DFE                                        |
| XCVR_A10_RX_ADG_DFE_FXTAP5_SGN  | Receiver Decision Feedback Equalizer Fixed Tap Five Sign         | RX serial data         | DFE                                        |
| XCVR_A10_RX_ADG_DFE_FXTAP6      | Receiver Decision Feedback Equalizer Fixed Tap Six Coefficient   | RX serial data         | DFE                                        |

*continued...*

| Analog Parameter Setting        | Pin Planner or Assignment Editor Name                             | Assignment Destination | Usage Guideline |
|---------------------------------|-------------------------------------------------------------------|------------------------|-----------------|
| XCVR_A10_RX_AD_PDFE_FXTAP6_SGN  | Receiver Decision Feedback Equalizer Fixed Tap Six Sign           | RX serial data         | DFE             |
| XCVR_A10_RX_AD_PDFE_FXTAP7      | Receiver Decision Feedback Equalizer Fixed Tap Seven Coefficient  | RX serial data         | DFE             |
| XCVR_A10_RX_AD_PDFE_FXTAP7_SGN  | Receiver Decision Feedback Equalizer Fixed Tap Seven Sign         | RX serial data         | DFE             |
| XCVR_A10_RX_AD_PDFE_FXTAP8      | Receiver Decision Feedback Equalizer Fixed Tap Eight Coefficient  | RX serial data         | DFE             |
| XCVR_A10_RX_AD_PDFE_FXTAP8_SGN  | Receiver Decision Feedback Equalizer Fixed Tap Eight Sign         | RX serial data         | DFE             |
| XCVR_A10_RX_AD_PDFE_FXTAP9      | Receiver Decision Feedback Equalizer Fixed Tap Nine Coefficient   | RX serial data         | DFE             |
| XCVR_A10_RX_AD_PDFE_FXTAP9_SGN  | Receiver Decision Feedback Equalizer Fixed Tap Nine Sign          | RX serial data         | DFE             |
| XCVR_A10_RX_AD_PDFE_FXTAP10     | Receiver Decision Feedback Equalizer Fixed Tap Ten Coefficient    | RX serial data         | DFE             |
| XCVR_A10_RX_AD_PDFE_FXTAP10_SGN | Receiver Decision Feedback Equalizer Fixed Tap Ten Sign           | RX serial data         | DFE             |
| XCVR_A10_RX_AD_PDFE_FXTAP11     | Receiver Decision Feedback Equalizer Fixed Tap Eleven Coefficient | RX serial data         | DFE             |
| XCVR_A10_RX_AD_PDFE_FXTAP11_SGN | Receiver Decision Feedback Equalizer Fixed Tap Eleven Sign        | RX serial data         | DFE             |

**Table 308. Transmitter Analog Parameter Settings**

| Analog Parameter Setting                      | Pin Planner or Assignment Editor Name             | Assignment Destination | Usage Guideline           |
|-----------------------------------------------|---------------------------------------------------|------------------------|---------------------------|
| XCVR_A10_TX_LINK                              | Transmitter Link Type                             | TX serial data         | Chip-to-chip or backplane |
| XCVR_A10_TX_TERM_SEL                          | Transmitter On-Chip Termination                   | TX serial data         | On chip termination       |
| XCVR_A10_TX_COMPENSATION_EN                   | Transmitter High-Speed Compensation               | TX serial data         | PDN ISI compensation      |
| XCVR_VCCR_VCCT_VOLTAGE                        | VCCR_GXB/VCCT_GXB Voltage                         | TX serial data         | VCCR/VCCT voltage         |
| XCVR_A10_TX_SLEW_RATE_CTRL                    | Transmitter Slew Rate Control                     | TX serial data         | Slew Rate                 |
| XCVR_A10_TX_PRE_EMP_SIGN_PR_E_TAP_1T          | Transmitter Pre-Emphasis First Pre-Tap Polarity   | TX serial data         | Pre-emphasis              |
| XCVR_A10_TX_PRE_EMP_SIGN_PR_E_TAP_2T          | Transmitter Pre-Emphasis Second Pre-Tap Polarity  | TX serial data         | Pre-emphasis              |
| XCVR_A10_TX_PRE_EMP_SIGN_1S_T_POST_TAP        | Transmitter Pre-Emphasis First Post-Tap Polarity  | TX serial data         | Pre-emphasis              |
| XCVR_A10_TX_PRE_EMP_SIGN_2N_D_POST_TAP        | Transmitter Pre-Emphasis Second Post-Tap Polarity | TX serial data         | Pre-emphasis              |
| XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_PRE_TAP_1T | Transmitter Pre-Emphasis First Pre-Tap Magnitude  | TX serial data         | Pre-emphasis              |
| XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_PRE_TAP_2T | Transmitter Pre-Emphasis Second Pre-Tap Magnitude | TX serial data         | Pre-emphasis              |

*continued...*

| Analog Parameter Setting                        | Pin Planner or Assignment Editor Name              | Assignment Destination | Usage Guideline             |
|-------------------------------------------------|----------------------------------------------------|------------------------|-----------------------------|
| XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_1ST_POST_TAP | Transmitter Pre-Emphasis First Post-Tap Magnitude  | TX serial data         | Pre-emphasis                |
| XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_2ND_POST_TAP | Transmitter Pre-Emphasis Second Post-Tap Magnitude | TX serial data         | Pre-emphasis                |
| XCVR_A10_TX_VOD_OUTPUT_SWING_CTRL               | Transmitter Output Swing Level                     | TX serial data         | Differential output voltage |

**Table 309. Reference Clock Analog Parameter Settings**

| Analog Parameter Setting      | Pin Planner or Assignment Editor Name     | Assignment Destination | Usage Guideline     |
|-------------------------------|-------------------------------------------|------------------------|---------------------|
| XCVR_A10_REFCLK_TERM_TRISTATE | Dedicated Reference Clock Pin Termination | Reference clock pin    | On-chip termination |

**Note:** You must set all the required analog settings according to your protocol configuration. If you do not set the appropriate settings, then the Quartus Prime software selects the default values which may not be appropriate for your protocol implementation.

## 8.4. Receiver General Analog Settings

### 8.4.1. XCVR\_A10\_RX\_LINK

#### Pin planner or Assignment Editor Name

#### Receiver Link Type

#### Description

This parameter is configured depending on the link characteristic. Value SR is used for link insertion loss less than equal to 10dB and value LR is used for link insertion loss greater than 10dB. If this QSF assignment is not done, Quartus Prime assigns SR as the default value. Settings dependent on this parameter value are DC gain, VGA and sd\_threshold for SATA. This is also used for data rate legality check during compilation.

For SR: sd\_threshold for SATA = SDLV\_4

For LR: sd\_threshold for SATA = SDLV\_6

For the default values of DC gain and VGA corresponding to RX\_LINK setting, look for QSF assignments **XCVR\_A10\_RX\_EQ\_DC\_GAIN\_TRIM** and **XCVR\_A10\_RX\_ADJ\_VGA\_SEL**.

**Table 310. Available Options**

| Value                   | Description                                                        |
|-------------------------|--------------------------------------------------------------------|
| <b>SR (Short Reach)</b> | Less than or equal to 10dB IL, used for Chip-to-chip communication |
| <b>LR (Long Reach)</b>  | >10dB IL, used for Backplane communication                         |

### Assign To

RX serial data pin.

### Syntax

```
set_instance_assignment -name XCVR_A10_RX_LINK <value> -to
<rx_serial_data_pin_name>
```

### Related Information

[Arria 10 Device Datasheet](#)

## 8.4.2. XCVR\_A10\_RX\_TERM\_SEL

### Pin planner or Assignment Editor Name

### Receiver On-Chip Termination

#### Description

Controls the on-chip RX differential termination. For data rates higher than 25 Gbps, set the termination resistance to 85 Ohm.

**Note:** For protocols such as QPI, you need to set the termination setting to R\_R2. For all the other protocols, you can either set this setting to R\_R1 or R\_R2. The default value set for all the protocols other than QPI depends upon the data rate. When the data rate is less than or equal to 17.4 Gbps, the default value is R\_R1. When the data rate is greater than 17.4 Gbps, the default value is R\_R2.

**Table 311. Available Options**

| Value  | Description |
|--------|-------------|
| R_EXT0 | Tristate    |
| R_R1   | 100 Ohm     |
| R_R2   | 85 Ohm      |

### Assign To

RX serial data pin.

### Syntax

```
set_instance_assignment -name XCVR_A10_RX_TERM_SEL <value> -to
<rx_serial_data_pin_name>
```

## 8.4.3. XCVR\_VCCR\_VCCT\_VOLTAGE - RX

### Pin planner or Assignment Editor Name

### VCCR\_GXB and VCCT\_GXB voltages

### Description

Configures the VCCR\_GXB and VCCT\_GXB voltage for a GXB I/O pin by specifying the intended supply voltages for a GXB I/O pin. Intel recommends always including this QSF assignment.

| Value <sup>(66)</sup> | Description                  |
|-----------------------|------------------------------|
| 1_1V                  | VCCR_GXB or VCCT_GXB voltage |
| 1_0V                  | VCCR_GXB or VCCT_GXB voltage |
| 0_9V                  | VCCR_GXB or VCCT_GXB voltage |

### Assign To

RX serial data pin.

### Syntax

```
set_instance_assignment -name XCVR_VCCR_VCCT_VOLTAGE <value> -to  
<rx_serial_data pin name>.
```

### Related Information

[Arria 10 Device Datasheet](#)

## 8.5. Receiver Analog Equalization Settings

### 8.5.1. CTLE Settings

#### 8.5.1.1. XCVR\_A10\_RX\_ONE\_STAGE\_ENABLE

##### Pin planner or Assignment Editor Name

##### Receiver High Data Rate Mode Equalizer

##### Description

Selects between the CTLE high gain mode or CTLE high data rate mode for the equalizer. For data rate greater than 17.4 Gbps, only high data rate mode is allowed. For data rate less than or equal to 17.4 Gbps, you can select between high gain mode and high data rate mode. If no assignment is made, **S1\_MODE** is chosen by default for datarate less than or equal to 25.8 Gbps.

---

<sup>(66)</sup> These values are for the assignment editor. For the actual values, refer to the *Arria 10 Device Datasheet*.

**Table 312. Available Options**

| Value in QSF       | Value in Assignment Editor | Description                                                                                                                                                                                                 |
|--------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>NON_S1_MODE</b> | <b>Off</b>                 | Selects high gain mode for data rates up to 17.4 Gbps.                                                                                                                                                      |
| <b>S1_MODE</b>     | <b>On</b>                  | Selects high data rate mode up to 25.8 Gbps. Power consumption reduces in high data rate mode, as compared to high gain mode, when operating below 17.4 Gbps. This mode is the only option above 17.4 Gbps. |

**Assign To**

RX serial data pin.

**Syntax**

```
set_instance_assignment -name XCVR_A10_RX_ONE_STAGE_ENABLE
<value> -to <rx_serial_data pin name>
```

**8.5.1.2. XCVR\_A10\_RX\_EQ\_DC\_GAIN\_TRIM****Pin planner or Assignment Editor Name****Receiver High Gain Mode Equalizer DC Gain Control****Description**

Controls the DC gain of the continuous time linear equalizer (CTLE) in high gain mode. A higher gain setting results in a larger DC gain.

For RX\_LINK=SR, the default value is **STG2\_GAIN7**.

For RX\_LINK=LR, and if equalization mode = S1\_MODE, default value of DC gain is **STG1\_GAIN7**.

For RX\_LINK=LR, and if equalization mode = NON\_S1\_MODE, default value of DC gain is **NO\_DC\_GAIN**.

For PCIe, default value is **NO\_DC\_GAIN**.

For datarate > 17.4 Gbps, default value is **NO\_DC\_GAIN**.

**Table 313. Available Options**

| Value in TTK | Value in Assignment Editor / qsf <sup>(67)</sup> | Description                  |
|--------------|--------------------------------------------------|------------------------------|
| DC Gain 0    | <b>NO_DC_GAIN</b>                                | No DC gain                   |
| DC Gain 1    | <b>STG1_GAIN7</b>                                | Equalizer DC gain setting 7  |
| DC Gain 2    | <b>STG2_GAIN7</b>                                | Equalizer DC gain setting 14 |
| DC Gain 3    | <b>STG3_GAIN7</b>                                | Equalizer DC gain setting 21 |
| DC Gain 4    | <b>STG4_GAIN7</b>                                | Equalizer DC gain setting 28 |

---

<sup>(67)</sup> Refer to *Intel Arria 10 Device Datasheet*.

### Assign To

RX serial data pin.

### Syntax

```
set_instance_assignment -name XCVR_A10_RX_EQ_DC_GAIN_TRIM <value>
-to <rx_serial_data_pin_name>
```

### Related Information

[Intel Arria 10 Device Datasheet](#)

## 8.5.1.3. XCVR\_A10\_RX\_ADP\_CTLE\_ACGAIN\_4S

### Pin planner or Assignment Editor Name

### Receiver High Gain Mode Equalizer AC Gain Control

### Description

Controls the AC gain of the continuous time linear equalizer (CTLE) in high gain mode.

Arria 10 transceivers support two CTLE modes, high gain mode and high data rate mode. As a default, high data rate mode is enabled for data rates up to 25.8 Gbps. High gain mode can be enabled for datarate less than or equal to 17.4Gbps Higher gain setting results in larger AC gain.

The default value for PCIe Gen3 is **RADP\_CTLE\_ACGAIN\_4S\_7**.

For all the other cases, the default value is **RADP\_CTLE\_ACGAIN\_4S\_1**.

**Table 314. Available Options**

| Value                                      | Description                    |
|--------------------------------------------|--------------------------------|
| <b>RADP_CTLE_ACGAIN_4S_&lt;0 to 28&gt;</b> | CTLE AC gain setting <0 to 28> |

### Assign To

RX serial data pin.

### Syntax

```
set_instance_assignment -name XCVR_A10_RX_ADP_CTLE_ACGAIN_4S
<value> -to <rx_serial_data_pin_name>
```

## 8.5.1.4. XCVR\_A10\_RX\_ADP\_CTLE\_EQZ\_1S\_SEL

### Pin planner or Assignment Editor Name

### Receiver High Data Rate Mode Equalizer AC Gain Control

### Description

Controls the AC gain of the continuous time linear equalizer (CTLE) in high data rate mode and when adaptation is in manual mode (adaptation is disabled).

High data rate mode is enabled by default for data rates up to 25.8 Gbps. In high data rate mode, there is only one CTLE stage and 16 possible AC gain settings. Higher gain setting results in larger AC gain. The default value is set to

**RADP\_CTLE\_EQZ\_1S\_SEL\_3** i.e. CTLE AC Gain Setting 3. This QSF assignment only takes effect when one stage CTLE is enabled. If configured in four stage mode, it has no effect on CTLE gain value.

For datarate > 17.4 Gbps, default value is **RADP\_CTLE\_EQZ\_1S\_SEL\_13**.

For datarate ≤ 17.4 Gbps, default value is **RADP\_CTLE\_EQZ\_1S\_SEL\_3**.

**Table 315. Available Options**

| Value                                       | Description                     |
|---------------------------------------------|---------------------------------|
| <b>RADP_CTLE_EQZ_1S_SEL_&lt;0 to 15&gt;</b> | CTLE AC Gain Setting < 0 to 15> |

#### Assign To

RX serial data pin.

#### Syntax

```
set_instance_assignment -name XCVR_A10_RX_ADP_CTLE_EQZ_1S_SEL  
<value> -to <rx_serial_data pin name>
```

### 8.5.2. VGA Settings

#### 8.5.2.1. XCVR\_A10\_RX\_ADP\_VGA\_SEL

##### Pin planner or Assignment Editor Name

##### Receiver Variable Gain Amplifier Voltage Swing Select

##### Description

The variable gain amplifier (VGA) amplifies the signal amplitude and ensures a constant voltage swing before the data is fed to the CDR for sampling. This assignment controls the VGA output voltage swing when adaptation mode of VGA is set to manual. The default value is set to **RADP\_VGA\_SEL\_4** for VGA Output Voltage Swing Setting 4.

Default values for VGA if VGA are not set exclusively.

For PCIe Gen1 & Gen2: default value is **RADP\_VGA\_SEL\_4**.

For PCIe Gen3: default value is **RADP\_VGA\_SEL\_4**.

For datarate > 17.4 Gbps, default value is **RADP\_VGA\_SEL\_4**.

For RX\_LINK = LR and CTLE mode = NON\_S1\_MODE: default value is **RADP\_VGA\_SEL\_4**.

For RX\_LINK = LR and CTLE mode = S1\_MODE and datarate <= 4.5Gbps: default value is **RADP\_VGA\_SEL\_4**.

For RX\_LINK = LR and CTLE mode = S1\_MODE and datarate > 4.5Gbps: default value is **RADP\_VGA\_SEL\_4**.

For RX\_LINK = LR and CTLE mode = S1\_MODE and datarate > 4.5Gbps and data rate ≤ 17.4Gbps,: default value is **RADP\_VGA\_SEL\_4**.

For RX\_LINK = SR and CTLE mode = NON\_S1\_MODE and datarate <= 4.5Gbps: default value is **RADP\_VGA\_SEL\_4**.

For RX\_LINK = SR and CTLE mode = NON\_S1\_MODE and datarate > 4.5Gbps: default value is **RADP\_VGA\_SEL\_4**.

For RX\_LINK = SR and CTLE mode = S1\_MODE: default value is **RADP\_VGA\_SEL\_4**.

**Table 316. Available Options**

| Value                              | Description                               |
|------------------------------------|-------------------------------------------|
| <b>RADP_VGA_SEL_&lt;0 to 7&gt;</b> | VGA Output Voltage Swing Setting <0 to 7> |

#### Assign To

RX serial data pin.

#### Syntax

```
set_instance_assignment -name XCVR_A10_RX_ADP_VGA_SEL <value> -to  
<rx_serial_data_pin_name>
```

### 8.5.3. Decision Feedback Equalizer (DFE) Settings

The decision feedback equalizer (DFE) amplifies the high frequency component of a signal without amplifying the noise content. The DFE removes the post-cursor Inter Symbol Interference (ISI) of the bits received previously from the current bit and improves the Bit Error Rate (BER). The DFE architecture supports eleven fixed taps. The fixed taps in DFE remove the ISI of the previous 11 bits from the current bit.

The DFE circuit stores delayed versions of the data. The stored bit is multiplied by a coefficient and then summed with the incoming signal. The polarity of each coefficient is programmable.

*Note:* The DFE fixed tap assignments are described in the following section.

#### 8.5.3.1. XCVR\_A10\_RX\_ADP\_DFE\_FXTAP

##### Description

The following assignments specify the coefficient of DFE fixed taps 1 through 11. These assignments are applicable only when the DFE is enabled and adaptation is disabled for the DFE (DFE operates in manual mode). The default value for all assignments is set to **RADP\_DFE\_FXTAP<1 to 11>\_0** for DFE fixed tap<1 to 11> coefficient setting 0. DFE tap1 is the only tap which is always positive and hence there is no QSF assignment for DFE tap1 sign bit. Other taps can be positive or negative.

**Table 317. DFE Fixed Tap Assignments**

| Assignment                       | Pin Planner or Assignment Editor Name                            | Value                        | Description                                                            |
|----------------------------------|------------------------------------------------------------------|------------------------------|------------------------------------------------------------------------|
| XCVR_A10_RX_AD_P_DFE_FX_TAP1     | Receiver Decision Feedback Equalizer Fixed Tap One Coefficient   | RADP_DFE_FXTAP1_<0 to 127>   | DFE fixed tap 1 Coefficient Setting <0 to 127>                         |
| XCVR_A10_RX_AD_P_DFE_FX_TAP2     | Receiver Decision Feedback Equalizer Fixed Tap Two Coefficient   | RADP_DFE_FXTAP2_<0 to 127>   | DFE fixed tap 2 Coefficient Setting <0 to 127>                         |
| XCVR_A10_RX_AD_P_DFE_FX_TAP2_SGN | Receiver Decision Feedback Equalizer Fixed Tap Two Sign          | RADP_DFE_FXTAP2_SGN_<0 or 1> | DFE fixed tap 2 coefficient sign 0 or 1<br>0 = Positive and 1=Negative |
| XCVR_A10_RX_AD_P_DFE_FX_TAP3     | Receiver Decision Feedback Equalizer Fixed Tap Three Coefficient | RADP_DFE_FXTAP3_<0 to 127>   | DFE fixed tap 3 Coefficient Setting <0 to 127>                         |
| XCVR_A10_RX_AD_P_DFE_FX_TAP3_SGN | Receiver Decision Feedback Equalizer Fixed Tap Three Sign        | RADP_DFE_FXTAP3_SGN_<0 or 1> | DFE fixed tap 3 coefficient sign 0 or 1<br>0 = Positive and 1=Negative |
| XCVR_A10_RX_AD_P_DFE_FX_TAP4     | Receiver Decision Feedback Equalizer Fixed Tap Four Coefficient  | RADP_DFE_FXTAP4_<0 to 63>    | DFE fixed tap 4 Coefficient Setting <0 to 63>                          |
| XCVR_A10_RX_AD_P_DFE_FX_TAP4_SGN | Receiver Decision Feedback Equalizer Fixed Tap Four Sign         | RADP_DFE_FXTAP4_SGN_<0 or 1> | DFE fixed tap 4 coefficient sign 0 or 1<br>0 = Positive and 1=Negative |
| XCVR_A10_RX_AD_P_DFE_FX_TAP5     | Receiver Decision Feedback Equalizer Fixed Tap Five Coefficient  | RADP_DFE_FXTAP5_<0 to 63>    | DFE fixed tap 5 Coefficient Setting <0 to 63>                          |
| XCVR_A10_RX_AD_P_DFE_FX_TAP5_SGN | Receiver Decision Feedback Equalizer Fixed Tap Five Sign         | RADP_DFE_FXTAP5_SGN_<0 or 1> | DFE fixed tap 5 coefficient sign 0 or 1<br>0 = Positive and 1=Negative |
| XCVR_A10_RX_AD_P_DFE_FX_TAP6     | Receiver Decision Feedback Equalizer Fixed Tap Six Coefficient   | RADP_DFE_FXTAP6_<0 to 31>    | DFE fixed tap 6 Coefficient Setting <0 to 31>                          |
| XCVR_A10_RX_AD_P_DFE_FX_TAP6_SGN | Receiver Decision Feedback Equalizer Fixed Tap Six Sign          | RADP_DFE_FXTAP6_SGN_<0 or 1> | DFE fixed tap 6 coefficient sign 0 or 1<br>0 = Positive and 1=Negative |
| XCVR_A10_RX_AD_P_DFE_FX_TAP7     | Receiver Decision Feedback Equalizer Fixed Tap Seven Coefficient | RADP_DFE_FXTAP7_<0 to 31>    | DFE fixed tap 7 Coefficient Setting <0 to 31>                          |
| XCVR_A10_RX_AD_P_DFE_FX_TAP7_SGN | Receiver Decision Feedback Equalizer Fixed Tap Seven Sign        | RADP_DFE_FXTAP7_SGN_<0 or 1> | DFE fixed tap 7 coefficient sign 0 or 1<br>0 = Positive and 1=Negative |
| XCVR_A10_RX_AD_P_DFE_FX_TAP8     | Receiver Decision Feedback Equalizer Fixed Tap Eight Coefficient | RADP_DFE_FXTAP8_<0 to 63>    | DFE fixed tap 8 Coefficient Setting <0 to 63>                          |
| XCVR_A10_RX_AD_P_DFE_FX_TAP8_SGN | Receiver Decision Feedback Equalizer Fixed Tap Eight Sign        | RADP_DFE_FXTAP8_SGN_<0 or 1> | DFE fixed tap 8 coefficient sign 0 or 1<br>0 = Positive and 1=Negative |
| XCVR_A10_RX_AD_P_DFE_FX_TAP9     | Receiver Decision Feedback Equalizer Fixed Tap Nine Coefficient  | RADP_DFE_FXTAP9_<0 to 63>    | DFE fixed tap 9 Coefficient Setting <0 to 63>                          |

*continued...*

| <b>Assignment</b>                | <b>Pin Planner or Assignment Editor Name</b>                      | <b>Value</b>                  | <b>Description</b>                                                      |
|----------------------------------|-------------------------------------------------------------------|-------------------------------|-------------------------------------------------------------------------|
| XCVR_A10_RX_ADP_DFE_FX_TAP9_SGN  | Receiver Decision Feedback Equalizer Fixed Tap Nine Sign          | RADP_DFE_FXTAP9_SGN_<0 or 1>  | DFE fixed tap 9 coefficient sign 0 or 1<br>0 = Positive and 1=Negative  |
| XCVR_A10_RX_ADP_DFE_FX_TAP10     | Receiver Decision Feedback Equalizer Fixed Tap Ten Coefficient.   | RADP_DFE_FXTAP10_<0 to 63>    | DFE fixed tap 10 Coefficient Setting <0 to 63>                          |
| XCVR_A10_RX_ADP_DFE_FX_TAP10_SGN | Receiver Decision Feedback Equalizer Fixed Tap Ten Sign           | RADP_DFE_FXTAP10_SGN_<0 or 1> | DFE fixed tap 10 coefficient sign 0 or 1<br>0 = Positive and 1=Negative |
| XCVR_A10_RX_ADP_DFE_FX_TAP11     | Receiver Decision Feedback Equalizer Fixed Tap Eleven Coefficient | RADP_DFE_FXTAP11_<0 to 63>    | DFE fixed tap 11 Coefficient Setting <0 to 63>                          |
| XCVR_A10_RX_ADP_DFE_FX_TAP11_SGN | Receiver Decision Feedback Equalizer Fixed Tap Eleven Sign        | RADP_DFE_FXTAP11_SGN_<0 or 1> | DFE fixed tap 11 coefficient sign 0 or 1<br>0 = Positive and 1=Negative |

### Example DFE Fixed Tap Assignment

**Assignment:** XCVR\_A10\_RX\_ADP\_DFE\_FXTAP1

**Value:** RADP\_DFE\_FXTAP1\_2

**Description:** DFE fixed tap 1 Coefficient Setting 2

#### Assign To

RX serial data pin.

#### Syntax

```
set_instance_assignment -name XCVR_A10_RX_ADP_DFE_FXTAP1 <value>
-to <rx_serial_data pin name>
```

## 8.6. Transmitter General Analog Settings

### 8.6.1. XCVR\_A10\_TX\_LINK

#### Pin planner or Assignment Editor Name

#### Transmitter Link Type

#### Description

This parameter is configured depending on the link characteristics. Value SR is used for link insertion loss less than or equal to 10dB and value LR is used for link insertion loss greater than 10dB. If this QSF assignment is not done, Quartus Prime assigns SR as the default value. This is used for data rate legality check during compilation.

**Table 318. Available Options**

| Value     | Description                                                        |
|-----------|--------------------------------------------------------------------|
| <b>SR</b> | Less than or equal to 10dB IL, used for Chip-to-chip communication |
| <b>LR</b> | > 10dB IL, used for Backplane communication                        |

**Note:** The maximum data rate supported by transceiver channels depends on the device speed grade, power mode, and the type of transceiver channel. Refer to *Arria 10 Device Datasheet* for more details.

#### Assign To

TX serial data pin.

#### Syntax

```
set_instance_assignment -name XCVR_A10_TX_LINK <value> -to
<tx_serial_data pin name>
```

#### Related Information

[Arria 10 Device Datasheet](#)

### 8.6.2. XCVR\_A10\_TX\_TERM\_SEL

#### Pin planner or Assignment Editor Name

#### Transmitter On-Chip Termination

#### Description

Controls the on-chip TX differential termination for different protocols.

**Table 319. Available Options**

| Value       | Description |
|-------------|-------------|
| <b>R_R1</b> | 100 Ohm     |
| <b>R_R2</b> | 85 Ohm      |

**Note:** For protocols such as QPI, you need to set this setting to R\_R2. For all the other protocols, you can either set this setting to R\_R1 or R\_R2. The default value set for all the protocols other than QPI depends upon the data rate. When the data rate is less than or equal to 17.4 Gbps, the default value is R\_R1. When the data rate is greater than 17.4 Gbps, the default value is R\_R2.

### 8.6.3. XCVR\_A10\_TX\_COMPENSATION\_EN

#### Pin planner or Assignment Editor Name

#### Transmitter High-Speed Compensation

### Description

Specifies if the power distribution network (PDN) induced inter-symbol interference (ISI) compensation is enabled or disabled in the TX driver. When enabled, it reduces the PDN induced ISI jitter, but increases the power consumption. Use this feature for high speed applications. It defaults to **ENABLE** for non-PCIe modes.

**Table 320. Available Options**

| Value          | Description      |
|----------------|------------------|
| <b>ENABLE</b>  | Compensation ON  |
| <b>DISABLE</b> | Compensation OFF |

**Table 321. Rules**

| Data Rate       | Value of XCVR_A10_TX_COMPENSATION_EN |
|-----------------|--------------------------------------|
| PCIe Gen1, Gen2 | DISABLE                              |
| PCIe Gen3       | ENABLE                               |
| Others          | ENABLE/DISABLE                       |

### Assign To

TX serial data pin.

### Syntax

```
set_instance_assignment -name XCVR_A10_TX_COMPENSATION_EN <value>
-to <tx_serial_data_pin_name>
```

### Related Information

EPE (Early Power Estimator)

## 8.6.4. XCVR\_VCCR\_VCCT\_VOLTAGE - TX

### Pin planner or Assignment Editor Name

### VCCR\_GXB and VCCT\_GXB voltages

### Description

Configures the VCCR\_GXB and VCCT\_GXB voltage for a GXB I/O pin by specifying the intended supply voltages for a GXB I/O pin.

| Value <sup>(68)</sup> | Description                  |
|-----------------------|------------------------------|
| 1_1V                  | VCCR_GXB or VCCT_GXB voltage |
| 1_0V                  | VCCR_GXB or VCCT_GXB voltage |
| 0_9V                  | VCCR_GXB or VCCT_GXB voltage |

---

<sup>(68)</sup> These are assignment editor values. For the actual values, refer to the *Arria 10 Device Datasheet*.

### Assign To

TX serial data pin.

### Syntax

```
set_instance_assignment -name XCVR_VCCR_VCCT_VOLTAGE <value> -to  
<tx_serial_data pin name>
```

### Related Information

[Arria 10 Device Datasheet](#)

## 8.6.5. XCVR\_A10\_TX\_SLEW\_RATE\_CTRL

### Pin planner or Assignment Editor Name

### Transmitter Slew Rate Control

### Description

Specifies the slew rate of the output signal. The valid values span from the slowest rate to the fastest rate.

*Note:* Slew\_R6 and Slew\_R7 are not used.

**Table 322. Available Options**

| Value                     | Description                                     |
|---------------------------|-------------------------------------------------|
| <b>SLEW_R0 to SLEW_R5</b> | R0 is the slowest rate. R5 is the fastest rate. |

If QSF is not specified, the following table lists the default values.

**Table 323. Default Values**

| PCIe             |                   |  |  |  |
|------------------|-------------------|--|--|--|
| Value            | Default Slew Rate |  |  |  |
| <b>PCIe Gen1</b> | SLEW_R4           |  |  |  |
| <b>PCIe Gen2</b> | SLEW_R5           |  |  |  |
| <b>PCIe Gen3</b> | SLEW_R5           |  |  |  |

  

| Non-PCIe             |                   |                        |                        |                |
|----------------------|-------------------|------------------------|------------------------|----------------|
| Value<br>(VCCT/VCCR) | Default Slew Rate |                        |                        |                |
|                      | Data rate < 1G    | Data rate ≥ 1G to < 3G | Data rate ≥ 3G to < 6G | Data rate ≥ 6G |
| <b>0.95 V</b>        | SLEW_R0           | SLEW_R2                | SLEW_R3                | SLEW_R5        |
| <b>1.03 V</b>        | SLEW_R1           | SLEW_R3                | SLEW_R4                | SLEW_R5        |
| <b>1.12 V</b>        | SLEW_R2           | SLEW_R4                | SLEW_R5                | SLEW_R5        |

### Assign To

TX serial data pin.

### Syntax

```
set_instance_assignment -name XCVR_A10_TX_SLEW_RATE_CTRL <value>  
-to <tx_serial_data pin name>
```

*Note:* Currently, the Quartus Prime software doesn't choose the default values for Non-PCIe mode. You must specify the setting in the **.qsf** file.

## 8.7. Transmitter Pre-Emphasis Analog Settings

The programmable pre-emphasis block in the transmit buffer amplifies the high frequencies in the transmit data to compensate for attenuation in the transmission media.

*Note:* Ignore all the pre-emphasis QSF assignments for PCIe Gen1 and Gen2 if your transceiver link is within the PCI Express spec requirements. Quartus Prime assigns default values for these parameters.

### 8.7.1. XCVR\_A10\_TX\_PRE\_EMP\_SIGN\_PRE\_TAP\_1T

#### Pin planner or Assignment Editor Name

#### Transmitter Pre-Emphasis First Pre-Tap Polarity

#### Description

Controls the polarity of the first pre-tap for pre-emphasis. The default value is **FIR\_PRE\_1T\_NEG**.

**Table 324. Available Options**

| Value                 | Description        |
|-----------------------|--------------------|
| <b>FIR_PRE_1T_POS</b> | Positive pre-tap 1 |
| <b>FIR_PRE_1T_NEG</b> | Negative pre-tap 1 |

#### Assign To

TX serial data pin.

#### Syntax

```
set_instance_assignment -name XCVR_A10_TX_PRE_EMP_SIGN_PRE_TAP_1T  
<value> -to <tx_serial_data pin name>
```

### 8.7.2. XCVR\_A10\_TX\_PRE\_EMP\_SIGN\_PRE\_TAP\_2T

#### Pin Planner or Assignment Editor Name

#### Transmitter Pre-Emphasis Second Pre-Tap Polarity

#### Description

Controls the polarity of the second pre-tap for pre-emphasis. The default value is **FIR\_PRE\_2T\_NEG**.

**Table 325. Available Options**

| Value                 | Description        |
|-----------------------|--------------------|
| <b>FIR_PRE_2T_POS</b> | Positive pre-tap 2 |
| <b>FIR_PRE_2T_NEG</b> | Negative pre-tap 2 |

**Assign To**

TX serial data pin.

**Syntax**

```
set_instance_assignment -name XCVR_A10_TX_PRE_EMP_SIGN_PRE_TAP_2T
<value> -to <tx_serial_data pin name>
```

**8.7.3. XCVR\_A10\_TX\_PRE\_EMP\_SIGN\_1ST\_POST\_TAP****Pin planner or Assignment Editor Name****Transmitter Pre-Emphasis First Post-Tap Polarity****Description**

Controls the polarity of the first post-tap for pre-emphasis. The default value is **FIR\_POST\_1T\_NEG**.

**Table 326. Available Options**

| Value                  | Description         |
|------------------------|---------------------|
| <b>FIR_POST_1T_POS</b> | Positive post-tap 1 |
| <b>FIR_POST_1T_NEG</b> | Negative post-tap1  |

**Assign To**

TX serial data pin.

**Syntax**

```
set_instance_assignment -name
XCVR_A10_TX_PRE_EMP_SIGN_1ST_POST_TAP <value> -to <tx_serial_data
pin name>
```

**8.7.4. XCVR\_A10\_TX\_PRE\_EMP\_SIGN\_2ND\_POST\_TAP****Pin planner or Assignment Editor Name****Transmitter Pre-Emphasis Second Post-Tap Polarity****Description**

Controls the polarity of the second post-tap for pre-emphasis. The default value is **FIR\_POST\_2T\_NEG**.

**Table 327. Available Options**

| Value                  | Description         |
|------------------------|---------------------|
| <b>FIR_POST_2T_POS</b> | Positive post-tap 2 |
| <b>FIR_POST_2T_NEG</b> | Negative post-tap 2 |

**Assign To**

TX serial data pin.

**Syntax**

```
set_instance_assignment -name
XCVR_A10_TX_PRE_EMP_SIGN_2ND_POST_TAP <value> -to <tx_serial_data
pin name>
```

## 8.7.5. XCVR\_A10\_TX\_PRE\_EMP\_SWITCHING\_CTRL\_PRE\_TAP\_1T

**Pin planner or Assignment Editor Name**
**Transmitter Pre-Emphasis First Pre-Tap Magnitude**
**Description**

Controls the magnitude of the first pre-tap for pre-emphasis. The default value is **0**.

**Table 328. Available Options**

| Value         | Description      |
|---------------|------------------|
| <b>0 – 16</b> | Magnitude 0 – 16 |

**Note:** Refer to *Arria 10 Pre-Emphasis and Output Swing Settings* spreadsheet for selecting legal pre-emphasis and differential output voltage settings.

**Assign To**

TX serial data pin.

**Syntax**

```
set_instance_assignment -name
XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_PRE_TAP_1T <value> -to
<tx_serial_data pin name>
```

**Related Information**

[Arria 10 Pre-Emphasis and Output Swing Settings](#)

## 8.7.6. XCVR\_A10\_TX\_PRE\_EMP\_SWITCHING\_CTRL\_PRE\_TAP\_2T

**Pin planner or Assignment Editor Name**
**Transmitter Pre-Emphasis Second Pre-Tap Magnitude**

### Description

Controls the magnitude of the second pre-tap for pre-emphasis. The default value is **0**.

**Table 329. Available Options**

| Value        | Description     |
|--------------|-----------------|
| <b>0 – 7</b> | Magnitude 0 – 7 |

**Note:** Refer to *Arria 10 Pre-Emphasis and Output Swing Settings* spreadsheet for selecting legal pre-emphasis and differential output voltage settings.

### Assign To

TX serial data pin.

### Syntax

```
set_instance_assignment -name
XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_PRE_TAP_2T <value> -to
<tx_serial_data_pin_name>
```

### Related Information

[Arria 10 Pre-Emphasis and Output Swing Settings](#)

## 8.7.7. XCVR\_A10\_TX\_PRE\_EMP\_SWITCHING\_CTRL\_1ST\_POST\_TAP

### Pin planner or Assignment Editor Name

### Transmitter Pre-Emphasis First Post-Tap Magnitude

### Description

Controls the magnitude of the first post-tap for pre-emphasis. The default value is **0**.

**Table 330. Available Options**

| Value         | Description      |
|---------------|------------------|
| <b>0 – 25</b> | Magnitude 0 – 25 |

**Note:** Refer to *Arria 10 Pre-Emphasis and Output Swing Settings* spreadsheet for selecting legal pre-emphasis and differential output voltage settings.

### Assign To

TX serial data pin.

### Syntax

```
set_instance_assignment -name
XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_1ST_POST_TAP <value> -to
<tx_serial_data_pin_name>
```

**Related Information**

[Arria 10 Pre-Emphasis and Output Swing Settings](#)

### 8.7.8. XCVR\_A10\_TX\_PRE\_EMP\_SWITCHING\_CTRL\_2ND\_POST\_TAP

**Pin planner or Assignment Editor Name****Transmitter Pre-Emphasis Second Post-Tap Magnitude****Description**

Controls the magnitude of the second post-tap for pre-emphasis. The default value is **0**.

**Table 331. Available Options**

| Value         | Description      |
|---------------|------------------|
| <b>0 – 12</b> | Magnitude 0 – 12 |

**Note:** Refer to *Arria 10 Pre-Emphasis and Output Swing Settings* spreadsheet for selecting legal pre-emphasis and differential output voltage settings.

**Assign To**

TX serial data.

**Syntax**

```
set_instance_assignment -name  
XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_2ND_POST_TAP <value> -to  
<tx_serial_data pin name>
```

**Related Information**

[Arria 10 Pre-Emphasis and Output Swing Settings](#)

## 8.8. Transmitter VOD Settings

### 8.8.1. XCVR\_A10\_TX\_VOD\_OUTPUT\_SWING\_CTRL

**Pin planner or Assignment Editor Name****Transmitter Output Swing Level****Description**

Controls the transmitter programmable output differential voltage swing. The default value is **31**.

**Note:** Ignore this assignment for PCIe Gen1 and Gen2 if your transceiver link is within the PCI Express\* spec requirements. The Quartus Prime software assigns default value for this parameter.

**Table 332. Available Options**

| Value  | Description      |
|--------|------------------|
| 0 – 31 | Magnitude 0 – 31 |

**Note:** Refer to *Arria 10 Pre-Emphasis and Output Swing Settings* spreadsheet for selecting legal pre-emphasis and differential output voltage settings.

#### Assign To

TX serial data pin.

#### Syntax

```
set_instance_assignment -name XCVR_A10_TX_VOD_OUTPUT_SWING_CTRL
<value> -to <tx_serial_data pin name>
```

#### Related Information

[Arria 10 Pre-Emphasis and Output Swing Settings](#)

## 8.9. Dedicated Reference Clock Settings

### 8.9.1. XCVR\_A10\_REFCLK\_TERM\_TRISTATE

#### Pin planner or Assignment Editor Name

#### Dedicated Reference Clock Pin Termination

#### Description

Specifies if the termination for dedicated reference clock pin is tri-stated. It defaults to **TRISTATE\_OFF** for non-HCSL cases.

**Table 333. Available Options**

| Value        | Description                                                                                     |
|--------------|-------------------------------------------------------------------------------------------------|
| TRISTATE_OFF | Internal termination enabled and on-chip biasing circuitry enabled                              |
| TRISTATE_ON  | Internal termination tri-stated. Off-chip termination and biasing circuitry must be implemented |

**Table 334. Rules**

| I/O Standard | Value        |
|--------------|--------------|
| HCSL         | TRISTATE_ON  |
| CML          | TRISTATE_OFF |
| LVPECL       | TRISTATE_OFF |
| LVDS         | TRISTATE_OFF |

#### Assign To

Reference clock pin.

### Syntax

```
set_instance_assignment -name XCVR_A10_REFCLK_TERM_TRISTATE  
<value> -to <dedicated refclk pin name>
```

## 8.9.2. XCVR\_A10\_TX\_XTX\_PATH\_ANALOG\_MODE

### Pin planner or Assignment Editor Name

#### Transmitter Analog Presets

##### Description

Specifies the TX pin swing settings such as vod output swing control, pre-emphasis and slew rate settings for various protocols. The presets are set by selecting an analog\_mode setting. The selection is done as a **.QSF** setting on the TX pin. If individual **.QSF** is specified for the vod\_output\_swing\_ctrl, pre-emphasis settings, the individual **.QSF** overrides the preset settings. The parameter defaults to USER\_CUSTOM, which requires the individual **.QSF** to be set. Available TX preset values are shown in the Assignment Editor, Transmitter Analog Preset assignment section.

## 8.10. Unused Transceiver RX Channels Settings

Add the following Intel Arria 10 QSF assignments to prevent performance degradation of unused RX serial clock over time. You can either use a global assignment or per-pin assignments.

### Syntax

```
set_global_assignment -name PRESERVE_UNUSED_XCVR_CHANNEL ON  
set_instance_assignment -name PRESERVE_UNUSED_XCVR_CHANNEL ON -to  
<pin_name> (U34, for example)
```

An example of a **<pin\_name>** is U34, not PIN\_U34.

## 8.11. Analog Parameter Settings Revision History

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2018.10.16       | Made the following changes: <ul style="list-style-type: none"><li>For <b>PRESERVE_UNUSED_XCVR_CHANNEL</b>, clarified that an example of <b>&lt;pin_name&gt;</b> is U34, not PIN_U34.</li><li>In <b>XCVR_A10_RX_EQ_DC_GAIN_TRIM</b>, updated the <b>Receiver High Gain Mode Equalizer DC Gain Control</b> value descriptions from 6, 13, 20, 27 to 7, 14, 21 and 28 to match the <b>Assignment Editor</b> GUI.</li></ul> |
| 2017.11.06       | Made the following changes: <ul style="list-style-type: none"><li>Changed all default values of <b>RADP_VGA_SEL</b> to <b>4</b> in the "XCVR_A10_RX_ADJ_VGA_SEL" section.</li></ul>                                                                                                                                                                                                                                     |
| 2016.10.31       | Made the following changes:                                                                                                                                                                                                                                                                                                                                                                                             |

*continued...*

| Document Version | Changes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>Added the Value in Assignment Editor column to the table in the "XCVR_A10_RX_ONE_STAGE_ENABLE" section.</li> <li>Added a note to the "XCVR_A10_TX_SLEW_RATE_CTRL" section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2016.05.02       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Updated that "DFE continuous mode" is not supported any more. DFE is supported in three modes-Disabled, Manual, Adaptation Enabled.</li> <li>Changed the "Arria 10 Register Map" for available DFE modes, CTLE and VGA modes.</li> <li>Changed the maximum supported data rate for GT devices to 25.8 G.</li> <li>Removed the ODI section from 'Register Map' tab.</li> <li>Changed the DFE adaptation mode from "Continuous" to "Adaptation enabled".</li> <li>Changed the DFE adaptation mode from "Continuous" to "Adaptation enabled".</li> </ul>                                                                                                                                                                                                                                                                                                                  |
| 2016.02.11       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Updated the maximum data rate to 25.8 Gbps.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2015.12.18       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Updated the "Available Options" table for non-HCSL standards, in the "Dedicated Reference Clock Settings" section.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2015.11.02       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Changed the setting for "XCVR_A10_RX_EQ_DC_GAIN_TRIM" parameter in the CTLE Settings section.</li> <li>Updated the "Analog Parameter Settings List" table to reflect the number of DFE fixed taps.</li> <li>Updated "DFE Fixed Tap Assignments" table in the Decision Feedback Equalizer (DFE) Settings section.</li> <li>Updated descriptions for XCVR_A10_RX_LINK QSF assignment in "Receiver General Analog Settings" section.</li> <li>Updated description for XCVR_A10_RX_EQ_DC_GAIN_TRIM QSF, XCVR_A10_RX_ADAPCTLE_EQZ_1S_SEL QSF, XCVR_A10_RX_ADAPCTLE_ACGAIN_4S QSF, and XCVR_A10_RX_ADAP_VGA_SEL QSF assignments in "Receiver Analog Equalization Settings" section.</li> <li>Updated description for XCVR_A10_TX_LINK QSF, XCVR_A10_TX_SLEW_RATE_CTRL QSF, and XCVR_A10_TX_LINK QSF assignments in "Transmitter General Analog Settings" section.</li> </ul> |
| 2015.05.11       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Corrected typos in the Syntax description of each parameter setting.</li> <li>Added the XCVR_A10_TX_SLEW_RATE_CTRL parameter.</li> <li>Changed the available values for the following parameters: <ul style="list-style-type: none"> <li>XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_PRE_TAP_1T</li> <li>XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_1ST_POST_TAP</li> <li>XCVR_A10_TX_PRE_EMP_SWITCHING_CTRL_2ND_POST_TAP</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2014.12.15       | <p>Made the following changes:</p> <ul style="list-style-type: none"> <li>Modified the Rules section for XCVR_A10_TX_COMPENSATION_EN.</li> <li>Changed Available Options for XCVR_A10_RX_ONE_STAGE_ENABLE parameter settings table.</li> <li>Changed the "XCVR_A10_RX_ADAPCTLE_ACGAIN_4S" parameter setting.</li> <li>Added "XCVR_VCCR_VCCT_VOLTAGE" parameter setting.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2014.08.15       | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

## 9. Debugging Transceiver Toolkit

---

The transceiver toolkit helps you optimize high-speed serial links in your board design by providing real-time control, monitoring, and debugging of the transceiver links running on your board.

The transceiver toolkit allows you to:

- Control the transmitter or receiver channels to optimize transceiver settings and hardware features.
- Test bit-error rate (BER) while running multiple links at the target data rate.
- Control internal pattern generators and checkers, and enable loopback modes.
- Run auto sweep tests to identify the best physical media attachment (PMA) settings for each link.
- Test multiple devices across multiple boards simultaneously.

**Note:** The transceiver toolkit runs on the System Console framework.

To launch the toolkit, click **Tools > System Debugging Tools > System Debugging Toolkits**.

### 9.1. Transceiver Toolkit GUI

The transceiver toolkit GUI consists of a main window with multiple panes that allows you to interact with the design currently running on the host computer.

- **Main View**—Allows you to configure and control transceiver channels and links, and adjust programmable analog settings to improve the signal integrity of the link.
- **Toolkit Explorer**—Displays all available toolkits and launches tools that use the System Console framework.
- **System Explorer**—Displays a list of interactive instances in your design, including board connections, devices, designs, servers, and scripts.
- **Tcl Console**—Allows you to interact with your design using Tcl scripts, for example, sourcing scripts, writing procedures, and using System Console API.
- **Message Window**—Displays status, warning, error messages related to connections and debug actions.

Figure 289. Transceiver Toolkit GUI



### 9.1.1. Main View Functions

The **Main View** consists of three main panes:

- **Status Table**—You can view and configure channels from different instances in a single main view. You can select the channels you want to configure and display in the **Channels Parameters**. By choosing the desired channels, right-clicking, and exploring the **Actions** sub-menu, you can perform bulk actions across multiple channels.
- **Toolkit Parameters**—You can set the Auto refresh period under the **Toolkit Setting** and the BER test duration per case under the **Autosweep Settings**.
- **Channel Parameters**—You can control and monitor channels settings and status in one screen. You can start and stop tests by clicking the **Start** and **Stop** button. When you select more than one channel, you can view all channels in one screen by adjusting the number of columns. You can also control the width of the column and height of the row to fit all the channels in one screen.

**Figure 290. Main View**


## 9.2. Transceiver Debugging Flow Walkthrough

This section describes the high-level process of debugging transceivers using the transceiver toolkit.

### 9.2.1. Enabling Transceiver Toolkit Support

To enable Intel Arria 10 transceiver toolkit support, you must enable the following parameters in the Transceiver Native PHY and Transceiver PLL IP cores.

**Table 335. Parameters to Enable Transceiver Toolkit Support in Transceiver Native PHY IP Core**

| Parameter                                              | Description                                                                                                                                                                                        |
|--------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Enable Dynamic Reconfiguration</b>                  | Allows you to change the configuration of the transceiver channels and PLLs without powering down the device.                                                                                      |
| <b>Enable Native PHY Debug Master Endpoint (NPDME)</b> | Allows you to access the transceiver and PLL registers through System Console. When you recompile your design, the Intel Quartus Prime software inserts the NPDME debug fabric and embedded logic. |
| <i>continued...</i>                                    |                                                                                                                                                                                                    |

| Parameter                                  | Description                                                                                                              |
|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| <b>Enable control and status registers</b> | Enables soft registers to read status signals and write control signals on the PHY interface through the embedded debug. |
| <b>Enable PRBS Soft Accumulators</b>       | Enables soft logic for performing PRBS bit and error accumulation when you use the hard PRBS generator and checker.      |
| <b>Enable capability registers</b>         | Enables capability registers that provide high-level information about the configuration of the transceiver channel.     |

**Table 336. Parameters to Enable Transceiver Toolkit Support in Transceiver PLL IP Core**

| IP Core                           | Parameter to Enable                                                                                                                             |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Transceiver ATX PLL Intel FPGA IP | <ul style="list-style-type: none"> <li><b>Enable Dynamic Reconfiguration</b></li> <li><b>Enable Native PHY Debug Master Endpoint</b></li> </ul> |
| CMU PLL Intel FPGA IP             |                                                                                                                                                 |
| fPLL Intel FPGA IP                |                                                                                                                                                 |

The following figures illustrate the parameters that you must enable to debug transceivers in Intel Arria 10 GX transceiver designs.

**Figure 291. Dynamic Reconfiguration Parameters in Intel Arria 10 GX Transceiver Native PHY IP Core**

**Figure 292. Dynamic Reconfiguration Parameters in Intel Arria 10 GX Transceiver ATX PLL IP Core**



You can either activate these settings when you first instantiate these components or modify the instances after preliminary compilation. Follow these steps for each transceiver IP core:

1. In the **IP Components** tab of the Project Navigator, right click the IP instance, and click **Edit in Parameter Editor**.
2. Turn on debug settings.  
Refer to the *Dynamic Reconfiguration Parameters in Intel Arria 10 GX Transceiver Native PHY IP Core* and *Dynamic Reconfiguration Parameters in Intel Arria 10 GX Transceiver ATX PLL Core* diagrams.
3. Connect the reference signals that the debugging logic requires, if applicable.  
The NDPME requires connections for clock and reset signals. For details about frequency requirements, refer to the *Ports and Parameters* section.
4. Click **Generate HDL**.

After enabling parameters for all IPs in the design, recompile the project.

#### Related Information

- [Dynamic Reconfiguration Parameters](#) on page 67
- [Ports and Parameters](#) on page 547

### 9.2.2. Programming Design into an Intel FPGA

After you enabled transceiver toolkit parameters in the design, compile, and generate programming files, you can program the design into the Intel FPGA.

#### Related Information

[Intel Quartus Prime Pro Edition User Guide: Programmer](#)

### 9.2.3. Loading Design to the Transceiver Toolkit

If the FPGA is already programmed with the project when loading, the transceiver toolkit automatically links the design to the target hardware in the toolkit. The toolkit automatically discovers links between transmitter and receiver of the same channel.

Before loading the design, ensure that you connect the hardware. The device and JTAG connections appear in the devices and connections folders of the **System Explorer** pane.

**Figure 293. System Explorer Pane**



To load the design into the transceiver toolkit, follow these steps:

1. In the System Console, click **File > Load Design**.

**Figure 294. System Console**



2. Select the .sof programming file for the transceiver design.

After loading the project, the designs and design\_instances folders in the **System Explorer** pane display information about the design, such as the design name and the blocks in the design that can communicate to the **System Console**.

#### 9.2.4. Creating Transceiver Links

Transceiver links are identified automatically when a receiver and transmitter share the same channel. Each enabled transmitter and receiver channel on all loaded and linked devices is displayed in the **Toolkit Explorer** as shown in the following figure.

**Figure 295. Toolkit Explorer**

You can create a custom collection to view and configure TX and RX channels. If you want to create TX and RX paths between different physical channels, whether they are in the same device or in different devices, you must manually create new links. To have TX and RX paths between different physical channels, make sure you have made an external loopback either using a loopback cable or card on the board to have physical connections between the channels.

To manually create transceiver links that have different transmit and receive channels, follow these steps:

1. Choose the TX and RX pair you want to link.
2. Right-click to create a collection and specify a name in the **Add to Collection** box. Refer to the *Creating Collections from the Toolkit Explorer* section to create collection.
3. Click **OK**.

The link you create adds to **Collections** box. Click the link you want to control.

4. Click **Open Toolkit**.

You can also open all the channels in one view by double-clicking the instances in the **Details** box. The name of the channels collection is automatically added.

5. Click **Open Toolkit** to go to **Main View** where you can control and monitor the channels.

#### Related Information

- Creating Collections from the Toolkit Explorer section, Intel Quartus Prime Pro Edition User Guide: Debug Tools
- System Explorer Pane section, Intel Quartus Prime Pro Edition User Guide: Debug Tools

#### 9.2.4.1. Transceiver Toolkit Parameter Settings

**Table 337. Parameter Settings in Channel Parameter Pane**

| Parameter                         | Description                                                                                                                                                                                                                          | Control Pane                      |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| <b>Bit error rate (BER)</b>       | Reports the number of errors divided by bits tested since the last reset of the checker.                                                                                                                                             | Receiver pane                     |
| <b>Channel Address</b>            | Logical address number of the transceiver channel.                                                                                                                                                                                   | Transmitter pane<br>Receiver pane |
| <b>CTLE AC Gain</b>               | Specifies the receiver's continuous time linear equalization (CTLE) AC gain.                                                                                                                                                         | Receiver pane                     |
| <b>CTLE DC Gain</b>               | Provides an equal boost to the incoming signal across the frequency spectrum.                                                                                                                                                        | Receiver pane                     |
| <b>DFE Mode</b>                   | Decision feedback equalization (DFE) for improving signal quality. DFE modes are <b>Off</b> , <b>Manual</b> , and <b>Adaptation Enabled</b> . DFE in <b>Adaptation Enabled</b> mode automatically tries to find the best tap values. | Receiver pane                     |
| <b>Equalization Engine</b>        | Boosts the high-frequency gain of the incoming signal to compensate for the low-pass filter effects of the physical medium. When you use this option with DFE, use DFE in <b>Manual</b> or <b>Adaptation Enabled</b> mode.           | Receiver pane                     |
| <b>Number of bits tested</b>      | Specifies the number of bits tested since the last reset of the checker.                                                                                                                                                             | Receiver pane                     |
| <b>Number of error bits</b>       | Specifies the number of error bits encountered since the last reset of the checker.                                                                                                                                                  | Receiver pane                     |
| <b>Pre-emphasis</b>               | This programmable module boosts high frequency components in the transmit data for each transmit buffer signal. This action counteracts possible attenuation in the transmission media.                                              | Transmitter pane                  |
| <b>Receiver channel</b>           | Specifies the name of the selected receiver channel.                                                                                                                                                                                 | Receiver pane                     |
| <b>Refresh</b>                    | After loading the .sof file, loads fresh settings from the registers after running dynamic reconfiguration.                                                                                                                          | Transmitter pane<br>Receiver pane |
| <b>Reset</b>                      | Resets the current test.                                                                                                                                                                                                             | Receiver pane                     |
| <b>Run length</b>                 | Sets coverage parameters for test runs.                                                                                                                                                                                              | Transmitter pane<br>Receiver pane |
| <b>RX CDR locked to ref clock</b> | Shows the receiver in lock-to-reference (LTR) mode.                                                                                                                                                                                  | Receiver pane                     |
| <b>RX CDR locked to data</b>      | Shows the receiver in lock-to-data (LTD) mode.                                                                                                                                                                                       | Receiver pane                     |

*continued...*

| Parameter                      | Description                                                                                                                                                                   | Control Pane                      |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| <b>Serial loopback enabled</b> | Inserts a serial loopback before the buffers, allowing you to form a link on a transmitter and receiver pair on the same physical channel of the device.                      | Transmitter pane<br>Receiver pane |
| <b>Start</b>                   | Starts the pattern generator or checker on the channel to verify incoming data.                                                                                               | Transmitter pane<br>Receiver pane |
| <b>Stop</b>                    | Stops generating patterns and testing the channel.                                                                                                                            | Transmitter pane<br>Receiver pane |
| <b>Test pattern</b>            | Test pattern sent by the transmitter channel.<br>Test pattern available: PRBS7, PRBS9, PRBS15, PRBS23, and PRBS31.                                                            | Transmitter pane<br>Receiver pane |
| <b>Time limit</b>              | Specifies the time limit unit and value to have a maximum bounds time limit for each test iteration.                                                                          | Receiver                          |
| <b>Transmitter channel</b>     | Specifies the name of the selected transmitter channel.                                                                                                                       | Transmitter pane                  |
| <b>VGA DC Gain</b>             | The variable gain amplifier (VGA) amplifies the signal amplitude and ensures a constant voltage swing before the data enters the clock data recovery (CDR) block for sampling | Receiver pane                     |
| <b>VOD</b>                     | Programmable transmitter differential output voltage.                                                                                                                         | Transmitter pane                  |

#### Related Information

- [Arria 10 PMA Architecture](#) on page 459
- [Analog Parameter Settings List](#) on page 598
  - Provides more details about the available settings.

#### 9.2.4.2. Verifying Hardware Connections

After creating links, verify that the channels connect correctly and make sure that there are physical connections between the channels you want to test on the hardware. This precaution saves time in the workflow.

**Figure 296. RX CDR Locked to Data**



To use the toolkit to send data patterns and receive them correctly, follow these steps:

1. Start the generator on the TX channel.
2. Start the checker on the RX channel.
3. In the **Channel Parameters** tab, in a RX channel, verify that the **RX CDR locked to data** indicator is green and the bit error rate (BER) is very low or zero.

*Note:* The **RX CDR locked to ref clock** status goes green and red randomly.  
Ignore the **RX CDR locked to ref clock** status when the **RX CDR locked to data** status is green.

After you verify the communication between transmitter and receiver, you can run link test.

### 9.2.5. Running Link Test

After you create the transceiver links for debugging, you can run link tests. Use the **Status Table** and **Channel Parameters** tab to control link tests.

**Figure 297. Example: Channel Parameters Tab**

This figure shows the **Channel Parameters** tab where you can control and monitor the transceiver channels.



### 9.2.5.1. Running BER Tests

Bit error rate (BER) tests help you assess signal integrity. Different transceiver parameters result in different BER values. You run BER tests from the **Channel Parameters** tab.

**Figure 298. Status Table in Main View**

| Pin | Instance    | Channel      | Bit error r. | CTLE AC | CTLE DC | DFE Model | Equalizer... | Loopbac...    | Number ... | PRBS pa... | Pre-emp... | Pre-emp... | Pre-emp... | Pre-emp... | VGA DC... | Vod |
|-----|-------------|--------------|--------------|---------|---------|-----------|--------------|---------------|------------|------------|------------|------------|------------|------------|-----------|-----|
| ✓   | native_inst | RX Channel 0 | 0            | 3       | 2       | Off       | High Dat...  | Serial loo... | 0          | PRBS15     | N/A        | N/A        | N/A        | N/A        | 2         | N/A |
| ✓   | native_inst | RX Channel 1 | 0            | 3       | 2       | Off       | High Dat...  | Off           | 0          | PRBS7      | N/A        | N/A        | N/A        | N/A        | 2         | N/A |
| ✓   | native_inst | RX Channel 0 | N/A          | N/A     | N/A     | N/A       | N/A          | N/A           | N/A        | PRBS7      | 0          | 0          | 0          | 0          | N/A       | 31  |
| ✓   | native_inst | RX Channel 1 | N/A          | N/A     | N/A     | N/A       | N/A          | N/A           | N/A        | PRBS7      | 0          | 0          | 0          | 0          | N/A       | 31  |

**Table 338. Channel Color Highlights**

| Color | Transmitter Channel                                  | Receiver Channel                                   |
|-------|------------------------------------------------------|----------------------------------------------------|
| Red   | Channel is closed or generator clock is not running. | Channel is closed or checker clock is not running. |
| Green | Generator is sending a pattern.                      | Checker is checking and data pattern is locked.    |

To run a BER test for transceiver link, follow these steps:

1. In the Status Table, tick Pin for the TX and RX channels you want to test.
2. Right click the TX and RX channels row to perform action such as enabling the loopback mode and PRBS pattern. You can also specify the PRBS test pattern in the **Channel Parameters**.
3. Specify **PMA Settings** for the TX and RX channels in the **Channel Parameters** tab as shown in the *Example: Channel Parameters Tab* diagram.
4. Click **Start** in the TX Channel and RX Channel columns.  
Refer to the *Channel Color Highlights* table for details.  
The BER appears in Receiver Channel column, under **Hard PRBS Checker**.
5. To reset the error counter, click **Reset**.
6. To stop the test, click **Stop** in TX Channel and RX Channel columns.  
Refer to the *Channel Color Highlights* table for details.
7. Change the parameters and then click **Start** if you want to test the error rate with different PMA parameters.

### 9.2.5.2. Link Optimization Tests

The Transceiver Toolkit autosweep test automatically sweeps PMA ranges to determine the transceiver settings that provide the best signal integrity. The toolkit allows you to store a history of the test runs and keep a record of the best PMA settings.

To launch auto sweep, click **Tools > Auto Sweep**.

Figure 299. Example of Autosweep View



The Autosweep view, when launched, is not associated with any given instance(s) or instance or channel pair(s). You can create as many Autosweep views as you desire, to allow sweeping over different parameters on different channels of the same instance, or different instances entirely.

### Related Information

#### Intel Quartus Prime Pro Edition User Guide: Debug Tools

Provides more details about Autosweep view.

## 9.3. Linking Hardware Resource for Multiple FPGAs

When you load multiple design projects for multiple FPGAs, linking indicates which of the projects are in each FPGA. The toolkit automatically discovers hardware and designs that you connect. You can also manually link a design to connected hardware resources in the **System Explorer**.

If you are using more than one Intel FPGA board, you can set up a test with multiple devices linked to the same design. This setup is useful if you want to perform a link test between a transmitter and receiver on two separate devices. You can also load multiple Intel Quartus Prime projects and link between different systems. You can perform tests on separate and unrelated systems in a single Intel Quartus Prime instance.

**Figure 300. One Channel Loopback Mode for Intel Arria 10 GX Devices**



**Figure 301. Four Channels Loopback Mode for Intel Arria 10 GX Devices**



To link a device, right click on the device within the devices folder in **System Explorer**. Select **Link device to** and the name of the .qpf project file for that device.

#### Related Information

- [Transceiver Toolkit GUI](#) on page 620
- [Loading Design to the Transceiver Toolkit](#) on page 625

### 9.3.1. Linking One Design to One Device

To link one design to one device by one Intel FPGA Download Cable, follow these steps:

1. Load the design for your Intel Quartus Prime project.
2. If the design does not auto-link, link each device to an appropriate design.
3. Create the link between channels on the device to test.

### 9.3.2. Linking Two Designs to Two Devices

To link two designs to two separate devices connected by one Intel FPGA Download Cable on the same board, follow these steps:

1. Load the design for all the Intel Quartus Prime project files you need.
2. If the design does not auto-link, link each device to an appropriate design.
3. Open the project for the second device.
4. Link the second device on the JTAG chain to the second design (unless the design auto-links).
5. Create a link between the channels on the devices you want to test.

### 9.3.3. Linking One Design on Two Devices

To link the same design on two separate devices, follow these steps:

1. In the Transceiver Toolkit, load the .sof file that you are using on both devices.
2. Right-click the first device, link the device to the design instance or .sof file that you are using.
3. Right-click the second device, link the device to the same .sof file that you link to the first device.
4. Create a link between the channels on the devices you want to test.

### 9.3.4. Linking Designs and Devices on Separate Boards

To link two designs to two separate devices on separate boards that connect to separate Intel FPGA Download Cable:

1. Load the design for all the Intel Quartus Prime project files you need.
2. If the design does not auto link, link each device to an appropriate design.
3. Create the link between channels on the device to test.
4. Link the device connected to the second Intel FPGA Download Cable to the second design.
5. Create a link between the channels on the devices you want to test.

## 9.4. Troubleshooting Common Errors

### Missing High-Speed Link Pin Connections

Check the pin connections to identify high-speed links (`tx_p/n` and `rx_p/n`) that are missing. When porting an older design to the latest version of the Intel Quartus Prime software, ensure that these connections exist after porting.

### Reset Issues

Ensure that the reset input to the Transceiver Native PHY, Transceiver Reset Controller, and Transceiver PLL Intel FPGA IPs is not held active (`1'b1`). You also need to ensure the `reconfig_reset` port in Transceiver Native PHY and Transceiver PLL Intel FPGA IPs is not held active.

### Unconnected `reconfig_clk`

You must connect and drive the `reconfig_clk` input to the Transceiver Native PHY and Transceiver PLL Intel FPGA IPs. Otherwise, the toolkit does not display the transceiver link channel.

**Figure 302. Example Error Message**



## 9.5. Debugging Transceiver Toolkit Revision History

| Document Version | Changes          |
|------------------|------------------|
| 2021.06.10       | Initial release. |