

# PolarFire<sup>®</sup> FPGA and PolarFire SoC FPGA Transceiver

# Introduction

Microchip's PolarFire FPGAs are the fifth-generation family of non-volatile FPGA devices, built on state-of-the-art 28 nm non-volatile process technology. PolarFire FPGAs deliver the lowest power at mid-range densities. PolarFire FPGAs lower the cost of mid-range FPGAs by integrating the industry's lowest power FPGA fabric, lowest power 12.7 Gbps transceiver lane, built-in low power dual PCI Express Gen2 (EP/RP), and, on select data security (S) devices, an integrated low-power crypto co-processor.

Microchip's PolarFire SoC FPGAs are the fifth-generation family of non-volatile SoC FPGA devices, built on state-ofthe-art 28 nm non-volatile process technology. The PolarFire SoC family offers industry's first RISC-V based SoC FPGAs capable of running Linux. It combines a powerful 64-bit 5x core RISC-V Microprocessor Sub-System (MSS), based on SiFive's U54-MC family, with the PolarFire FPGA fabric in a single device.

The PolarFire FPGA and PolarFire SoC FPGA family includes multiple embedded low-power, performance-optimized transceivers. Each transceiver has both the physical medium attachment (PMA), protocol physical coding sub-layer (PCS) logic, and interfaces to the FPGA fabric. The transceiver has a multi-lane architecture with each lane natively supporting serial data transmission rates from 500 Mbps (250 Mbps with interpolation) to 12.7 Gbps.

The following table summarizes the transceiver components available in PolarFire FPGA and PolarFire SoC FPGA families.

#### **Table 1. Transceiver Components**

| Components | PolarFire FPGA (MPF) | PolarFire SoC FPGA (MPFS)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PMA/PCS    | ✓                    | <ul> <li>Image: A start of the start of</li></ul> |
| TXPLL      | ✓                    | <ul> <li>Image: A start of the start of</li></ul> |
| REF_CLK    | <i>✓</i>             | <ul> <li>Image: A start of the start of</li></ul> |

The transceiver includes all required analog functions for high-speed data transmission between devices over printed circuit boards (PCB) and high-quality cables. The transceiver is suitable for a variety of device-to-device communication protocols, as listed in the following table.

| Table 2. Supported Serial | Protocols |
|---------------------------|-----------|
|---------------------------|-----------|

| Protocol                | Standard/Version        | Protocol          | Standard/Version                                                                            |
|-------------------------|-------------------------|-------------------|---------------------------------------------------------------------------------------------|
| PCle                    | Gen1                    | CPRI <sup>1</sup> | CPRI-1, 2, 3, 4, 5, 6, 7, 7A, 8, 9                                                          |
| PCle                    | Gen2                    | SATA <sup>2</sup> | 1.0a                                                                                        |
| XAUI                    | IEEE <sup>®</sup> 802.3 | SATA <sup>2</sup> | 2.0                                                                                         |
| Interlaken <sup>3</sup> | 10.3125                 | SATA <sup>2</sup> | 3.0                                                                                         |
| Interlaken <sup>3</sup> | 6.375                   | SDI-SD            | SMPTE 259M                                                                                  |
| 10GBASE-R               | IEEE 802.3              | SDI-HD            | SMPTE 292M                                                                                  |
| 10GBASE-KR <sup>4</sup> | IEEE 802.3              | SDI-3G            | SMPTE 424M                                                                                  |
| Fibre Channel           | 1GFC                    | SGMII             | -                                                                                           |
| Fibre Channel           | 2GFC                    | 1000BASE-X        | IEEE 802.3                                                                                  |
| Fibre Channel           | 4GFC                    | LiteFast          | Proprietary Lightweight Serial Protocol<br>Interface (up to 12.7 Gbps, 8b10b<br>mode only.) |
| Fibre Channel           | 8GFC                    | RXAUI             | N/A                                                                                         |
| JESD204B                | LV-OIF-SxI5             | QSGMII            | -                                                                                           |
| JESD204B                | LV-OIF-6G-SR            | SLVS-EC           | —                                                                                           |
| JESD204B                | LV-OIF-11G-SR           | DisplayPort       | -                                                                                           |
| USXGMII                 | —                       | CoaXPress         | -                                                                                           |

(1) Common Public Radio Interface (CPRI) Specification V7.0 (2015-10-09).

 $^{(2)}$  SATA is supported using PMA only mode.

(3) Interlaken Protocol Specification, v1.2.

(4) PMA supports 10GBASE-KR operation.





**Note:** Transmit/receive fabric interfaces are specified in the associated PCS pin lists, that is, 8b10b, 64b6xb, PIPE, and PMA Only. For more information on PCIESS, see PolarFire FPGA and PolarFire SoC FPGA PCI Express User Guide.

# Features

Transceiver enables users to quickly build high-speed links that support many standard protocols with the features listed:

- Supports data rates from 500 Mbps (250 Mbps with interpolation) up to 12.7 Gbps.
- Serialization/deserialization width at FPGA fabric interface—8, 10, 16, 20, 32, 40, 64, and 80 bits.
- Differential output termination from 85  $\Omega,$  100  $\Omega,$  and 150  $\Omega.$
- Low-power modes.
- Receivers are compatible with CML and LVDS I/O Standards.
- Transmitters are compatible with CML, LVDS, and LVPECL I/O Standards.
- Configurable transmit pre- and post-tap de-emphasis controls.
- Configurable amplitude control from 250 mV to 1 V differential.
- Receivers detect circuitry for use with PCIe.
- Out-of-band (OOB), electrical idle signaling capability for
  - Serial-attached SCSI: small computer system interface (SAS).
  - Serial advanced technology attachment (SATA).
  - Peripheral component interconnect express (PCIe).
- Spread-spectrum generation built into the transmit phase-locked loop (PLL).
- 1 Gb and 10 Gb SyncE compatible Jitter attenuation available in the transmit PLL for loop timing applications.
- Continuous time linear equalizer (CTLE) with optional auto-calibration to improve received signal integrity.
- 5-tap decision feedback equalizer (DFE) with auto-calibration to compensate for high-frequency losses.
- · Receive data eye monitor for link analysis.
- Configurable peak detector/signal detect.
- Polarity inversion (receiver).
- Diagnostic loopback modes.
- Embedded pseudo-random binary sequence (PRBS) test pattern generators/checkers—available PRBS polynomials (2<sup>n</sup>), where n = 7, 9, 15, 23, and 31.
- AC JTAG (IEEE 1149.6) and DC JTAG (IEEE 1149.1) transmitter and receiver.
- IBIS-AMI support of transceiver inputs and outputs.
- Supports AC and DC coupling modes with configurable transmit common-mode voltage.
- Embedded PCS:
  - 8b10b—encoding/decoding is provided.
  - 64b6xb—64b/66b or 64/67b encoding/decoding with gearbox logic is provided.
  - PIPE—PHY interface for the PCI Express Rev 3.0 supporting PCIe Gen1/2.
  - PMA only-direct access to the PMA without any encoding.
  - PCIe—fully embedded PCIe Gen1/Gen2 root-port or endpoint subsystem (PCIESS) with AXI4 user interface with built-in DMA. The embedded PCIe controller subsystem is available only within Quad0. See PolarFire FPGA and PolarFire SoC FPGA PCI Express User Guide for more information on the embedded PCIE capabilities and its usage.

The Microchip Libero<sup>®</sup> SoC software supports configuration for the various modes of transceiver operations. Table 2 shows which of these configurations support industry-standard protocols and user-defined custom protocols. The Libero SoC software design tools allow designers to set the configuration needed for a specific operational mode for each transceiver lane. The software correctly provisions and generates all the required programming and configuration data used to initialize and bring the transceiver into operation. The transceiver configuration registers are set automatically by the Libero SoC transceiver configurator. These registers must be left at their default values set by the configurator, except for use cases that explicitly request different values.

## References

- For information about PCIESS, see PolarFire FPGA and PolarFire SoC FPGA PCI Express User Guide.
- For information about regional clock resources and connectivity of the transceivers to the global clock network, see PolarFire FPGA and PolarFire SoC FPGA Clocking Resources User Guide.
- For information about available I/O standards, see PolarFire FPGA and PolarFire SoC FPGA User I/O User Guide.
- For information about Optimized DFE feature, see UG0773: PolarFire FPGA SmartDebug User Guide.
- For information about implementing transceiver designs on printed circuit boards, see respective UG0726: PolarFire FPGA Board Design User Guide or PolarFire SoC FPGA Board Design Guidelines User Guide.

# **Table of Contents**

| Intro | oductio | n                                                        | 1 |
|-------|---------|----------------------------------------------------------|---|
|       | 1.      | Features                                                 | 4 |
|       | 2.      | References                                               | 5 |
| 1.    | Funct   | onal Description                                         | 8 |
|       | 1.1.    | PMA                                                      |   |
|       | 1.2.    | Enhanced Receiver Management                             |   |
|       | 1.3.    | Transceiver PCS Interface Modes                          |   |
|       | 1.4.    | PCS/FPGA Fabric Interface                                |   |
|       | 1.5.    | Transceiver Clocking                                     |   |
|       | 1.6.    | PMA and PCS Resets                                       |   |
|       | 1.7.    | PCS Rate Switch Between 8b10b and 64b66b Mode for CPRI75 |   |
| 2.    | Implei  | nentation8                                               | 1 |
| ۷.    | 2.1.    | Libero Configurators                                     |   |
|       | 2.1.    | Transceiver Modes                                        |   |
|       | 2.2.    | Libero Generated Files                                   |   |
|       | 2.3.    | Design Constraints                                       |   |
|       | 2.4.    | Adding Physical Constraints Using Libero                 |   |
|       | 2.5.    | Transceiver Initialization                               |   |
|       |         |                                                          |   |
| 3.    | Signa   | I Integrity Conditioning110                              | C |
|       | 3.1.    | Transmitter                                              | 1 |
|       | 3.2.    | Receiver                                                 |   |
|       | 3.3.    | IO Editor for Signal Integrity                           |   |
|       | 3.4.    | SmartDebug Signal Integrity110                           | 6 |
| 4.    | Simul   | ation                                                    | 2 |
|       | 4.1.    | RTL Simulation Mode122                                   | 2 |
| 5.    | Debu    | g and Testing                                            | 4 |
|       | 5.1.    | PRBS Generator/Checker                                   | 4 |
|       | 5.2.    | Loopback                                                 | 4 |
|       | 5.3.    | Dynamic Reconfiguration Interface                        | 6 |
| 6.    | Board   | Design Recommendations                                   | 7 |
| 0.    | 6.1.    | Transceiver Top-Level Pin Out                            |   |
|       | 6.2.    | Design for Protocols                                     |   |
|       | 6.3.    | 10G Interface                                            |   |
|       | 6.4.    | Transceivers Insertion Loss                              |   |
| _     |         |                                                          |   |
| 7.    | Revis   | ion History                                              | 2 |
| The   | Micro   | chip Website                                             | 3 |
| Pro   | duct C  | nange Notification Service13                             | 3 |
| Cus   | stomer  | Support13                                                | 3 |

| Microchip Devices Code Protection Feature | . 133 |
|-------------------------------------------|-------|
| Legal Notice                              | . 134 |
| Trademarks                                | . 134 |
| Quality Management System                 | . 135 |
| Worldwide Sales and Service               | 136   |

# 1. Functional Description

The transceiver (Figure 1) is divided into four distinct transmit (Tx) and receive (Rx) blocks:

- PMA
- · PCS interface block, including a dedicated PCIe PCS
- Transmit PLL (Tx PLL)
- Reference clock inputs

The high-speed PMA blocks connect to the FPGA fabric through the PCS block. The PMA generates the required clocks and converts the transmit data from parallel to serial, and receive data from serial to parallel. Each PMA block includes a connection to a PCS block and associated interface to the FPGA fabric making up a transceiver lane. The PCS interface block provides several industry-standard interfaces for use in protocol-specific designs.

A group of four transceiver lanes is called a quad. Each quad has a local transmit PLL used exclusively within the four transceiver lanes. Additional transmit PLLs are shared between quads.

In addition to the 8b10b, 64b6xb, PIPE, and PMA only blocks, two PCIe PCS logic blocks are included in each device. These blocks include hard embedded logic that provides full-featured PCIe endpoint/root port sub-system. These PCIe sub-systems (PCIESS) have hard connections to multiple transceiver lanes, providing flexibility for ×1, ×2, and ×4 width links. See PolarFire FPGA and PolarFire SoC FPGA PCI Express User Guide for additional information pertaining to PCIe.

### 1.1 PMA

The transceiver lanes include PMA receiver and transmitter sub-modules. These PMA sub-modules include the input and output buffers, signal conditioning circuits, CDRs, and transceiver. The PMA architecture allows the receive and transmit portions of each lane to operate independently. The PMA features are initialized at power-up and can also be altered during device operation using an APB dynamic reconfiguration interface (DRI).

The SmartDebug tool set provides access to dynamic changes of PMA features, including transmit and receive tuning, and receive eye monitoring capabilities.

#### 1.1.1 Receiver

The receiver deserializes high-speed serial data received through the input buffer by creating a parallel data stream for the FPGA fabric and recovering the clock information from the received data. The receiver portion of the PMA includes the receiver buffer, the clock and data recovery (CDR) unit, and the deserializer. The deserializer within the receive PMA passes deserialized data to the PCS block across a data bus up to 40-bits wide of the PMA-PCS interface, which provides the data path to the gearing logic before the data is passed to the FPGA fabric.

#### Figure 1-1. Transceiver Receiver



#### 1.1.1.1 Receive Input Buffer

The receiver provides an external input interface through differential pins, XCVR\_RXP/N, as shown in the following figure. The receiver includes a current mode logic (CML) input buffer with programmable DC restoration that is used in either AC- or DC-coupled applications.

The receive buffer provides an on-die differential termination scheme which can be programmed to 85  $\Omega$ , 100  $\Omega$ , or 150  $\Omega$ . The receiver buffer also includes a high-impedance (high-Z) mode for hot-swap capability when the device is powered OFF. Additionally, the receiver input supports logical swapping of the polarity of the P and N pins for added flexibility.

#### Figure 1-2. Receiver Input Buffer



**Note:** VICM is connected to VDDA when AC-coupled link is configured. DC-coupled configurations effectively disconnects VICM source. See 3.2.4 AC/DC Coupled Connection.

Each receiver lane includes optional signal threshold detection circuitry that users can select according to protocol or application requirements. This feature identifies whether the signal level present at the receiver input buffer is above the signal detect threshold voltage needed to trip or activate the receiver input, which prevents false activity on the receiver path. The signal detection has both a high and low signal detector. The Libero SoC software configurator provides the correct setting based on protocol or customization.

Note: The user can also use a JTAG-based interface from SmartDebug to experiment with receiver settings.

#### 1.1.1.2 Loss of Signal Detect (LOS)

Loss of signal (LOS) detection is included within the receiver path. The LOS circuitry detects the initial incoming signal determining a valid input (electrical RX\_IDLE=0) for clock-data recovery operations. The LOS peak detection captures the most positive and negative points of the input signal and compares the amplitude to a limit set by the user. See 3.2.5 Loss-of-Signal Detector. The performance of the physical peak detector is limited by the bandwidth of the input signal. The LOS detection works for rates 5 Gbps and less and may not be suitable for all protocols or data patterns. For conditions outside the range of the LOS operation, see 1.2 Enhanced Receiver Management.

#### 1.1.1.3 Continuous-Time Linear Equalizers (CTLE)

The CTLEs equalize a lane's low-pass response to compensate for high-frequency losses in that lane, thereby improving the quality of the received signal. This circuit can be adjusted to compensate for any physical lane mismatches.

There are two transparent stages of CTLE and a separate pair of stages for the decision feedback equalizer (DFE)/eye monitor receive path. The input signal path (Figure 1-3) is conditioned by tuning the incoming signal allowing the user to observe the effects of the tuning. The DC gain and peak bandwidth of each stage is selected with Libero. CTLE settings can be selected based on DC gain, peaking frequency, and AC gain or with an auto adaptive setting through the Libero transceiver interface configurator. The automatic or adaptive mode uses internally generated settings to the physical channels for lane optimization.

#### Figure 1-3. Input Signal Path



#### 1.1.1.4 Decision Feedback Equalizer

In the receiver front end, an optionally enabled 5-tap decision feedback equalizer (DFE) is available to equalize the lane response in conjunction with the CTLE. The DFE allows better compensation of transmission channel losses than a linear equalizer of CTLE, by providing a closer adjustment of filter parameters. The tap values of the DFE are the coefficients of this filter that are set by the adaptive algorithm.

The DFE mitigates lane noise or inter-symbol interference (ISI) caused by reflections or cross-talk without amplifying the high-frequency noise within the data. The DFE-based operation uses current bit information to cancel ISI for the following bit through a feedback mechanism, allowing the following bits to be correctly sampled. Using taps to delay and multiply the symbols, the DFE effectively cancels out interference on the analog signal. Similar to the CTLE operation, the DFE has an automatic mode. When the DFE is used in automatic mode, the CTLE can be in automatic mode as-well.

The operation is nonlinear, allowing it to overcome the notch response that the CTLE cannot perform. The DFE also includes an automatic calibration that finds the best possible tuning to match the transceiver lane to the system channel.

#### 1.1.1.5 Eye Monitor

The eye monitor is on-device circuitry to visualize the post-equalization signal quality in the receive path while the data path is still active in the system. The non-destructive eye monitor runs a separate sampler in parallel with the CDR and DFE data sampler. This permits the system to remain operational while the eye monitor is functioning.

The eye monitor systematically adjusts the offsets across the complete eye, calculates the bit-error rate (BER) for each offset setting, then correlates the BER and offset to statistically rebuild the eye diagram. Eye diagram statistics can be read and reconstructed using the Libero SmartDebug tools, which permits access through a JTAG interface for transceiver debugging and test access.

Swing and de-emphasis can be configured in hundreds of combinations. However, it is very cumbersome for the user to tune these when optimizing the transceiver input. The eye monitor feature eases the manual steps to find the adjustments. It is used as part of the CTLE/DFE auto-calibration. The eye monitor feedback mechanism optimizes the correct DFE settings by using a duplicate DFE circuit to monitor and adjust the incoming data stream.

#### 1.1.1.6 Receive Clock and Data Recovery

The receive CDR circuit follows the CTLE and works in tandem with the DFE. The receive CDR PLL can lock onto the input reference clock or the incoming data stream to be able to re-time the incoming data. The deserializer is closely coupled with the CDR, and translates the data from a serial to a parallel stream.

#### 1.1.1.6.1 CDR Options

The PMA of each lane includes a PLL used for the receiver CDR. The CDR PLL supports lock-to-reference and lock-to-data modes, which allows customization of the CDR options best suited for the application. It also includes a Burst-mode receiver option, which can switch between both options that are selectable through the Libero transceiver configurator.

**Lock-to-Reference**: 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 LOCK status signal is asserted high to indicate that the CDR has locked to the phase and frequency of the receiver input reference clock regardless of the data phase detector (PD). Lock-to-reference is used to lock the transceiver CDR to the reference clock rather than the incoming data when the receiver is used as a simple over-sampler, or when the CDR must be locked to a local oscillator.

**Lock-to-Data**: The CDR must use the lock-to-data mode to recover the clock and data from the incoming serial data. In this mode, the data phase detector of 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 adjusts the VCO. The LOCK status signal is asserted when the CDR finds valid data. The actual lock time depends on the incoming data stream's transition density.

**Burst Mode Receiver**: The transceiver CDR circuit has enhanced capabilities to support burst mode receivers (BMR). BMR is used in NGPON2 and 10GEPON passive optical network applications for fast and bounded lock times. The BMR option is used to implement the fast clock-data recovery when the conventional bang-bang phase detector PLLs cannot meet the stringent lock times required by the passive optical network (PON) applications.

Note: DFE auto-calibration is not available when the transceiver is configured for burst mode (BMR).

When BMR mode is selected, LANE\_X\_CDR\_LOCKMODE[1:0] are exposed for CDR mode control. The following table lists the value and the description of the CDR lock mode control bits.

| LANE_X_CDR_LOCKMODE[1:0]<br>Values | Mode                     |
|------------------------------------|--------------------------|
| 2'b00                              | Not used                 |
| 2'b01                              | High gain <sup>1</sup>   |
| 2'b10                              | Lock to reference        |
| 2'b11                              | Normal Mode <sup>2</sup> |

#### Table 1-1. CDR Lock Mode Values

<sup>(1)</sup> High Gain mode is used during Preamble/delimiter detection phase to fast phase lock to the incoming RX data. This mode may generate additional clock jitter on the recovered clock. Once the preamble/de-limiter is detected, it is recommended to switch to normal CDR mode to minimize jitter.

<sup>(2)</sup> This is used when payload is received form burst mode receiver.

For detailed CDR specifications, see respective PolarFire FPGA Datasheet and PolarFire SoC Advance Datasheet. For application example and implementation details, see DG0841: PolarFire Burst Mode Receiver Demo Guide.

Lock to Data with 2X Gain: This transceiver option is used to implement the fast clock-data recovery when incoming data streams such as stressful SDI patterns require high gain to quickly phase lock to the incoming pattern. This mode produces faster lock times than that of normal lock-to-data mode.

The following figure shows the CDR lock mode options.

#### Figure 1-4. CDR Lock Mode Options

| CDR lock mode                                             | Lock to data 💌                                                                        |
|-----------------------------------------------------------|---------------------------------------------------------------------------------------|
| CDR reference dock source<br>CDR reference dock frequency | Lock to data<br>Lock to reference<br>Burst Mode Receiver<br>Lock to data with 2x gain |

#### 1.1.1.7 Bit Slip

The deserializer has a bit-slip feature for word alignment. In this mode, the CDR slips to the next bit from the deserializer. This feature helps with building word-alignment logic in the fabric. It is not used with the built-in 8b10b PCS core but is available for PMA only applications using fabric-based alignment. This feature adjusts the alignment of the deserialized word by 1-bit in either direction when the bit-slip feature is active, reducing the uncertainty by ensuring deterministic latency. This feature is supported by the transceiver configurator. The configurator enables this RX\_SLIP input port. This port requests the transceiver CDR lane slip the parallel boundary by 1-bit.

In PMA mode applications, the RX\_BIT\_SLIP port is exposed on the block for the fabric to access. The RX\_BIT\_SLIP rising edge requests Rx data path slip relative to the RX\_CLK by 1-bit (UI) using handshaking between RX\_BIT\_SLIP and RX\_VAL. The handshake works as follows:

- 1. Fabric must wait for RX\_VAL = 1. Then RX\_BIT\_SLIP may be asserted to initiate slip.
- 2. XCVR responds by lowering RX VAL to 0.
- 3. Fabric then lowers RX\_BIT\_SLIP.
- 4. XCVR completes the slip and the RX\_VAL is assigned to 1 synchronously with respect to RX\_CLK rising edge.

#### 1.1.1.8 Receive PCS Divider

The PCS divider divides the bit-rate clock from the CDR PLL to a lower rate for use in the receive PCS. The PMA sends parallel data from the de-serializer up to 40-bits wide. This divider also sets the width of the parallel data provided to the PCS to 8, 10, 16, 20, 32, 40, 64, or 80 bits. The Libero transceiver configurator sets the divider based on the data rate and ultimate fabric interface width.

#### 1.1.1.9 Receiver Calibration

The XCVR receivers include both analog and digital blocks that require calibration to compensate for process, voltage, and temperature (PVT) variations in conjunction with signal integrity. The embedded calibration block of transceiver performs calibration operations that optimize the performance of the transceiver interconnection. It includes an adaptive deserializer calibration algorithm to correct for lossy channels.

Libero selects CTLE only and CTLE/DFE modes based on the system data rate and channel loss needs. The pre-determined settings provide the starting point for the design. These settings are configured to the appropriate calibration requirements based on the targeted requirements. Three types of calibrations are carried out within the Rx:

CTLE DC-offset

- CTLE Frequency Response
- DFE

#### 1.1.1.9.1 CTLE DC-Offset Calibration

Process, voltage, and temperature (PVT) variations result in a DC-offset of the receiver front-end amplifiers, that is, the output is different from zero when the input is zero. This limits the sensitivity of the receiver and therefore the signal-to-noise ratio (SNR). It also limits the performance of the other calibration mechanisms.

The CTLE DC-offset calibration circuitry calibrates the DC-offset by zeroing the input and adding an offset. This offset is dynamically determined by a binary search in response to the logic output of the amplifier.

#### 1.1.1.9.2 CTLE Frequency Response Calibration

The CTLE frequency response can be set to a few discrete values, therefore calibration depends on searching for the settings that result in the largest eye area.

CTLE DC\_offset and CTLE Frequency Response calibration together make up the CTLE solution. For the most lossy and disruptive channels, many or all CTLE settings combinations can result in a zero eye-opening area. In these scenarios, DFE can sometimes allow for a non-zero area, which would otherwise be impossible with CTLE alone.

#### 1.1.1.9.3 DFE Calibration

DFE calibration is carried out by an embedded sequence function, which is optimized to avoid local minima, achieve predictable results, allow for low area, and operate at high clock speeds. It adjusts the feedback coefficients in response to the eye-area. The sequence of the function is used to determine the width, height, and center of the eye opening. DFE Calibration is carried out by a algorithm that adjusts the feedback coefficients (from H1 to H5) by trial-and-error in response to the eye-area of the eye\_monitor. The algorithm operates on one dimension (a single coefficient) at a time. It takes a step of size 1 in the positive direction and then the negative direction that is H1+1 and H1-1. If the area improves on either step, it continues to take another step in the same direction. If both directions yield a lower area, it continues to the next coefficient with the same step size. After failing to improve the area on all coefficients, it increases the step size and continue. If the area is improved, the step size immediately reduces to 1. See the AC468: PolarFire FPGA Transceiver Decision Feedback Equalization Application Note for more information.

Dependent on the specific design targets chosen through Libero, the design can be configured in one of two modes that require calibration of the receiver.

In CTLE only mode, CTLE solution is executed to optimize gain/frequency settings using CTLE Frequency Response and DC Offset calibration.

In CTLE/DFE mode, CTLE calibration is first run to optimize gain/frequency settings using CTLE Frequency Response and DC Offset calibration. DFE calibration is then run for centering and coefficients.

DFE is optionally programmed to be used in several operations. Full DFE calibration autonomously calibrates to the best found DFE coefficients for optimized data eye centering. These are controlled by Libero specified options.

DFE can also be set in static mode where the user can specify the exact DFE coefficients required by the design. DFE Coefficients are set through PDC commands (see 2.4.2.1 DFE Coefficients) can be used from the register rather than from calibration. This mode does not expose the CALIB\_REQ pin or any of the pins to trigger auto-calibration or incremental calibration.

Incremental DFE is another option of calibration to incrementally improve the performance of the DFE path. A specific PF\_XCVR\_ERM core is generated by Libero which, exposes the required pins to trigger the incremental calibration.

Two algorithms are available for re-calibration:

- Data Eye clock centering Re-calibration
- DFE Coefficient Re-calibration.

Both algorithms do eye-centering, however, they are independent operations. Full calibration and Static calibration are mutually exclusive and Incremental calibration of any of the two algorithms can only be applied after at least one 'Full calibration'.

Users can enable one or both choices in PF\_XCVR\_ERM configurator depending on the mode of operation and the receiver calibration options selected.

The calibration blocks are used at power-up calibration and user demanded recalibration. These are Libero configured. The following table lists the summary of mode of operations.

#### Table 1-2. Mode of Operations

| CDR Mode<br>(Data Rate ≤ 10312.5 Mbps) | Incrementally Re-calibrate Data Eye | Incrementally Re-calibrate DFE Co-efficients |
|----------------------------------------|-------------------------------------|----------------------------------------------|
| None_CDR                               | Not supported                       | Not supported                                |
| On Demand                              | Supported                           | Not supported                                |
| On Demand and First Lock               | Supported                           | Not supported                                |
| None_DFE                               | Not supported                       | Not supported                                |

Examples of the specific types of calibration are:

#### ON\_DEMAND

The receiver does not calibrate automatically. The user must initiate an on-demand calibration using either the wires on the XCVR interface or over the DRI. If the specific design performs dynamic reconfiguration using DRI, then the user routine must perform a recalibration each time the XCVR locks to a new data rate and/or data pattern.

In CDR modes where data rate  $\leq$  10312.5 Mbps, the device performs DC offset calibration of the CDR and the CTLE calibration when the user toggles the CALIB\_REQ port. When calibration is completed, the best DC offset and RX CTLE settings are applied to the receiver.

In DFE modes where data rate > 10312.5 Mbps, the device performs the same optimization as in CDR mode with the addition on performing full DFE calibration of the DFE coefficients. When calibration is completed the best DC offset, RX CTLE, and DFE coefficient settings are applied to the receiver.

To successfully complete the RX (CTLE) calibration process, the reference clocks must be stable and free running at device power-up and valid data must be present at the transceiver Rx input buffers. The data should be approximately the actual data that is received but does not need to be any particular data pattern. However, for DFE, calibration can be dependent on the data pattern used at DFE calibration. For example, JESD204B startups with a continuous K28.5 stream, then later shifts to actual 8b10b data. This is a change in data pattern and may impact calibrated DFE coefficients.

The transceiver component is generated by the Libero software to include enhanced receiver management logic to control the proper calibration of the receiver, see 1.2 Enhanced Receiver Management. The ERM manages calibration providing the user design a streamlined procedure to initiate and monitor calibration from the fabric interface. These calibration modes have higher power than using the NONE selection as the EYE MONITOR circuitry is active during these modes.

#### Incrementally Recalibrate Data Eye

This is a method to improve the performance of the DFE path after an initial calibration is performed. This recalibration is intended to improve the data eye for most gradients that typically occur due to temperature or voltage changes within the system.

The recalibration is performed by using the DC offset values for the DFE path that were determined by the prior offset calibration as the initial values and then perform the clock phase centering function. The calibration is marked as complete, when the area compute function is completed in the silicon/FPGA. This is indicated by driving the output signal LANE#\_DATA\_EYE\_CALIBRATION\_DONE to high.

#### Incrementally Recalibrate DFE Co-efficients

In this recalibration, the DFE co-efficients are recomputed in an incremental manner when an initial calibration is performed (on-demand or on initial power up).

The recalibration is performed by using the DC-offset values for the DFE path that were determined during a prior offset calibration as the initial value. The prior computed DFE coefficient values (H1-H5) are used as the starting coefficients for the DFE calibration. This reduces the DFE computation time. The calibration is marked as complete when the DFE calibration is completed in the silicon/FPGA. The output signal LANE#\_DFE\_COEFF\_RECALIBRATION\_DONE is driven high when the calibration is completed.

#### ON\_DEMAND\_AND\_FIRST\_LOCK

It is same as On\_Demand with the addition of auto calibration. Auto calibration occurs automatically the first time the CDR locks to data. The user can also on-demand initiate a calibration event using wires on the XCVR interface or over the DRI.

#### 1.1.2 Transmitter

The transmitter takes parallel data from the FPGA fabric through the PCS-fabric interface block and gearing logic. The data passes through the PMA-PCS interface to the serializer to create a high-speed serial data stream using the serial clock provided from the transmit PLL. The transmitter portion of the PMA includes the transmitter serializer and the transmitter buffer as shown in the following figure.

#### Figure 1-5. Transceiver Transmitter



#### 1.1.2.1 Serializer

The serializer provides the link between the high-speed interface and the transmit PCS by performing a parallel-toserial conversion. Each lane has up to 40-bit data bus to the transmit PCS block and a separate post-divider for a divide by 1, 2, 4, 8, or 11. The post dividers are provided to divide the high-speed clock from the TxPLL to exactly what the serializer requires for the data rate. This allows sharing of a high-speed TxPLL by adjusting the local data rate within the transceiver lane. The glitch-free post-divider also allows for dynamic switching between dividers and data rates using the APB DRI.

#### 1.1.2.2 Transmit PCS Divider

The PCS divider divides the bit-rate clock from the transmit PLL to a lower rate TX\_CLK clock for use in the fabric. The PMA receives parallel data in the serializer up to 40 bits wide. This divider also sets the width of the parallel data received from the PCS to 8, 10, 16, 20, 32, 40, 64, and 80 bits. The specific ratio is a function of the parallel-to-serial or serial-to-parallel conversion in the PMA.

#### 1.1.2.3 Transmit Output Buffer

The following figure shows the transmit output buffer of the transceiver lane, which connects to the PCB via the XCVR\_TXP/N output pins. The low-power H-bridge differential output buffer includes a configurable driver for amplitude on the 100  $\Omega$  differential load up to a maximum swing of 1 V peak to peak. In addition, selectable levels of transmit common-mode voltage (Tx VCM) are available besides the swing amplitude control for the output driver segments to control the amount of emphasis. The transmit output buffer settings are accessible in real-time for adjustment through the JTAG interface using SmartDebug. It includes a receiver detection to recognize the presence of a physical link. The output buffer also has electrical idle capabilities used to orderly quiet the link transmitters.

#### Figure 1-6. Transmit Output Driver



Transmit common-mode voltage levels for the drivers are selected by the user during the configuration of the PMA when using the transceiver configurator in the Libero software. Reducing the transmit output amplitude lowers the overall transceiver power consumption.

**Note:** The user can also use a JTAG-based interface from SmartDebug to experiment with transmit settings.

## 1.2 Enhanced Receiver Management

Enhanced receiver management (ERM) is implemented in FPGA logic inside the XCVR component. The ERM adds DFE/CDR calibration management, and lock-to-data lock detection capabilities of the PF\_XCVR. The RTL is autonomously generated by Libero software. The generated blocks manage the start-up/on-demand CDR/DFE calibration and fine-grain lock detector with a PMA, 8b10b, and 64b6xb modes of the PF\_XCVR. The ERM allows the Rx Lock detection logic to handle advanced capabilities of Delayed Traffic and Cable Pull during operation without further interaction from other user logic.

The enhanced receiver management feature provides the following functions.

- Manages receiver lock-to-reference versus lock-to-data operation modes of PF\_XCVR.
- Manages receiver calibration, see 1.1.1.9 Receiver Calibration.
  - Provides optional automatic calibration upon determining first valid receiver bit-lock.
  - Provides optional support for on-demand requested calibration.
  - Provides optional support for Data Eye clock centering recalibration.
  - Provides optional support for DFE Coefficient recalibration.
- Provides indicator when receiver completes calibration.
- Provides LANEx\_LOS input, which may be asserted as a means of holding lock management in lock-toreference. This is useful when interfacing to an optical interface, which provides a loss-of-signal indicator such as SFP.

Enhanced receiver management is recommended to optionally improve the link management for data rates above 5 Gbps but can be used to improve link reliability with lower data rates while using the automatic calibration features of ERM. Enhanced receiver management is not included for PCI Express, PIPE, or Burst Mode Receiver solutions of PF\_XCVR when generated by Libero software. Generally, the advanced features from ERM are already managed by these protocol layers.

ERM is utilized to augment the Rx\_IDLE peak detector logic, which is only valid for a limited minimum density of transitions on the Rx data or high bit rates. Other lower density patterns such as SDI at 270 Mb/s or 10G-KR Auto-negotiation data are good examples of data patterns that cannot use the peak detector and thus other system-dependent methods to keep the Rx PLL in lock-to-reference mode in the absence of incoming data are required.

For example, some protocols such as 10GBASE-KR and PCI-Express, exchange specific training patterns to establish and tune the respective links. These protocols does not use the ERM as it can interfere with these kinds of negotiation operations. Other applications such as CPRI goes through a sophisticated process by stepping through multiple data rates during its startup. The ERM must not be used in this type of application. ERM must also not be used with Rx-only modes such as DisplayPort where the RxPLL is locked to a lower rate data stream.

ERM can be used with JESD204b, Interlaken, and fixed rate CPRI applications.

The ERM functionality extends capabilities for transceiver applications for both the family devices excluding the MPF300XT device. The ERM uses minimal logic resources, but does extend the lock time of the CDR by approximately three times versus when the ERM is not included.

The ERM ports are exposed by the transceiver configurator dependent on the selected calibration when enabled (default) in the GUI, see Figure 1-7. If the XCVR module is generated without selecting the ERM option in the Libero SoC configurator, the module will still contain ERM in the component name, however, the ERM functionality is reduced. The following table lists the ports required or used in conjunction with the ERM module.

| Name                           | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|--------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CTRL_CLK                       | Input     | 40 MHz clock for the enhanced receiver management logic. The CTRL_CLK input clock can be sourced from the divided output of the PF_OSC (RCOSC_160MHZ_CLK_DIV).                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| CTRL_ARST_N                    | Input     | Input signal needed to reset ERM. User must drive this input from the XCVR_INIT_DONE signal of the PF_INIT_MONITOR component.                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| LANE#_LOS                      | Input     | LANEx_LOS input which may be asserted from an external source such as optical SFP during no-signal condition as a means of preventing entry to lock-to-data. This input must be used to control application scenarios where the incoming data stream has enough activity to trigger the LANE#_RX_IDLE but lacks enough transitions to lock the RXPLL. LOS=0 (de-assertion) should happen when valid serial data is applied at the RxP/N inputs of the receiver. LOS=1 assertion must happen prior to the ERM's entry to lock-to-data, otherwise the assertion does nothing. |  |
| LANE#_CALIB_REQ                | Input     | Active-high input signal used to request an On-Demand calibration. LANE#_CALIB_REQ is edge triggered not level. User must clear and re-assert the CALIB_REQ for trigger on-demand calibration request.                                                                                                                                                                                                                                                                                                                                                                      |  |
| LANE#_CALIBRATING              | Output    | Output signal that will go HIGH to indicate that the DFE/CDR is calibrating.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| LANE#_RX_VAL                   | Output    | Indicates CDR fine lock and ERM managed operations complete. See 1.3 Transceiver PCS Interface Modes for more information.         1 – indicates Fine Lock is asserted, and recovered data is valid.         0 – indicates Fine Lock is de-asserted and recovered data is invalid.                                                                                                                                                                                                                                                                                          |  |
| LANE#_RX_IDLE                  | Output    | Indicates activity on the receiver inputs (RXD[P:N]). For ≤ 5 Gbps, active-low (RX_IDLE=0 indicates activity).<br>For >5G bit rates, this signal may not be accurate indicator of data activity. It may toggle or be HIGH although valid signal is applied at the receiver. This signal is exposed for debugging purposes only, for example, detection of signal when RxPLL is in lock2ref mode. See Figure 1-11, Figure 1-12, Figure 1-13, and Figure 1-14.                                                                                                                |  |
| LANE#_RX_READY                 | Output    | Indicates CDR fine lock completion. See 1.3 Transceiver PCS Interface Modes for more information.<br>1 – Fine lock is asserted (that is, RxPLL is locked to incoming data within<br>± 4000 ppm of the LANE#_TX_CLK_{G,R} frequency).<br>0 – Fine lock is de-asserted (that is. recovered clock is outside the ± 4000 ppm of the REFCLK frequency).                                                                                                                                                                                                                          |  |
| LANE#_RXD[P:N]                 | Input     | Differential pair of serial data inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| LANE#_DATA_EYE_<br>CALIBRATION | Input     | Active-high input signal (Asynchronous signal) to request Data Eye clock centering recalibration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |

Table 1-3. ERM Ports

| continued                            |           |                                                                                                                                                       |  |
|--------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Name                                 | Direction | Description                                                                                                                                           |  |
| LANE#_DFE_COEFF_CALIBRAT             | Input     | Active -high input signal (Asynchronous signal) to request Incremental DFE Coefficient recalibration.                                                 |  |
| LANE#_DATA_EYE_<br>CALIBRATION_DONE  | Output    | Data Eye clock centering recalibration request handshake signal. This signal goes high when the Data Eye clock centering calibration is done.         |  |
| LANE#_DFE_COEFF_CALIBRAT<br>ION_DONE | Output    | Incremental DFE coefficient recalibration request handshake signal. This signal goes high when the Incremental DFE coefficient recalibration is done. |  |

#### Figure 1-7. Enhanced Receiver Management in XCVR Configurator

| General          |                         |                                |                          |
|------------------|-------------------------|--------------------------------|--------------------------|
| Iransceiver mode | Tx and Rx (Full Duplex) | ✓ Enhanced receiver management |                          |
| Number of lanes  | 1                       | Receiver calibration           | Dn-Demand and First Lock |

The operation ERM relies on the transceiver configurator settings to determine the selected calibration requirements, as shown in the following figure. The transceiver lane calibration options are selected with the transceiver configurator. See 1.1.1.9 Receiver Calibration for more information.

#### Figure 1-8. Calibration Options for Enhanced Receiver Management Operations

| Ξ | General          |                         |                                              |                          |
|---|------------------|-------------------------|----------------------------------------------|--------------------------|
|   | Transceiver mode | Tx and Rx (Full Duplex) | <ul> <li>Enhanced receiver manage</li> </ul> | ement                    |
|   | Number of lanes  | 1                       |                                              | None (CDR)               |
|   |                  |                         | Incrementally recalibrate                    | None (CDR)               |
|   |                  |                         | Incrementally recalibrate I                  | On-Demand                |
|   |                  |                         |                                              | On-Demand and First Lock |
| Ξ | PMA Settings     |                         |                                              | None (DFE)               |

The following receiver calibration options are provided for the ERM operation:

- None (CDR): Select if the XCVR is configured as CDR and no CTLE auto-calibration is performed. Static
  settings are configured by Libero based on data rate and backplane model. This receiver calibration mode uses
  Lock2Reference of the Rx PLL.
- **On-Demand and First Lock**: Select to perform calibration on first lock (after PoR) and on-demand. This option is available for both CDR and DFE configuration of the XCVR. You can trigger calibration on-demand using CALIB\_REQ port. The CALIBRATING signal is asserted upon CALIB\_REQ assertion and de-asserted when the calibration is completed.
- **On-Demand**: Select to perform calibration on-demand. This option is available for both CDR and DFE configuration of the XCVR. You can trigger calibration on-demand using CALIB\_REQ port. The CALIBRATING signal is asserted upon CALIB\_REQ assertion and de-asserted when the calibration is completed.
- None (Static DFE): DC Offset Calibration of the CDR is performed, however, the DFE Coefficients are set through PDC commands used from the register rather than from automatic DFE calibration operation. See 2.4.2 Physical Constraints. Static\_DFE does not use the DFE calibration routine and requires the user to carefully select DFE coefficient values. These values can be gathered by the SmartDebug tool or by simulation.

There are two potential ways to incrementally improve the performance of the DFE path when an initial calibration is completed.

- **Incrementally Recalibrate Data Eye**: This recalibration should improve the data eye for most gradients that typically occur from temperature or voltage changes within the system.
- **Incrementally Recalibrate DFE Coefficient**: This recalibration performs the DFE calibration in incremental method. The initially calculated DFE coefficient values are used as the starting values for this algorithm. This results in the reduction of the Calibration time by reducing the number of DFE coefficients that requires recalibration.

**Note:** Full calibration is always done for DFE. You must select one of the two options—On-Demand and First Lock or On-Demand—if the transceiver is configured in DFE mode.

Enable LANE#\_RX\_READY\_CDR and LANE#\_RX\_VAL\_CDR ports are optionally exposed by selecting the associated checkbox for the ERM solution. The XCVR component provides optional RX\_READY\_CDR and RX\_VAL\_CDR ports for the datapath and variation of the LANE#\_RX\_READY and LANE#\_RX\_VAL ports that are always exposed with the ERM. These additional ports are provided to monitor the CDR lock signal. These ports can be used for rate change from >5G to <5G and 10GBASE-KR auto-negotiation support.

XCVR designs implementing protocols with auto-negotiation logic typically negotiates link rates over DRI. In these use cases, the ERM will interfere with the auto-negotiation and can cause incorrect behavior.

| Clocks and Resets                  |           |   |                                          |                         |   |
|------------------------------------|-----------|---|------------------------------------------|-------------------------|---|
| Interface Clocks                   | nce dock  |   |                                          |                         |   |
| <u>T</u> X clock                   | Regional  | • | <u>R</u> X dock                          | Regional                | • |
| Interface Resets                   | TX and RX | Ŧ | PCS Reset                                | RX Only                 | • |
| Optional Ports<br>Enable TX_BYPAS: |           |   | ✓ Enable RX_READY_C ✓ Enable JA_CLK port | DR and RX_VAL_CDR ports |   |

#### Figure 1-9. Exposing RX\_READY\_CDR and RX\_VAL\_CDR Pins

The ERM manages the device behavior at first power-up or release from device reset (DEVRSTn). The ERM managed calibration begins after the device complete its initial startup configuration and the assertion of XCVR\_INIT\_DONE de-asserts the CTRL\_ARST\_N. This requires a valid serial data stream to be applied to the RXD input pins at the time of de-assertion of the CTRL\_ARST\_N signal. At that time, the ERM performs the desired user selected calibration operation as shown in the following figure. The LANE#\_RX\_IDLE activity shows the detection of incoming data moving the ERM to place the CDR into LOCK2DATA operation while it completes calibration and fine lock operation. The operation is indicated by the LANE#\_CALIBRATING and RX\_READY status signals. The LANE#\_RX\_VAL with output high upon completion of the calibration and locking routine.

The following table lists the ports exposed based on DFE options.

#### Table 1-4. DFE Options

| Options                                    | Input Port                  | Output Port                      |
|--------------------------------------------|-----------------------------|----------------------------------|
| Incrementally recalibrate data eye         | LANE#_DATA_EYE_CALIBRATION  | LANE#_DATA_EYE_CALIBRATION_DONE  |
| Incrementally recalibrate DFE coefficients | LANE#_DFE_COEFF_CALIBRATION | LANE#_DFE_COEFF_CALIBRATION_DONE |

#### Figure 1-10. DFE Options

| ٩                                   |                               |                         |          |                                                                                                                 |                                         |   | 4          |                |
|-------------------------------------|-------------------------------|-------------------------|----------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------|---|------------|----------------|
| PF_XCVR_default_configuration       | General                       |                         |          |                                                                                                                 |                                         |   |            |                |
| IOGBASE-R                           | Contraction and the           | E I I I I I I I I       |          | Enhanced receiver management                                                                                    |                                         |   |            |                |
| OGBASE-KR                           | Transceiver mode              | Tx and Rx (Full Duplex) | <u> </u> | <ul> <li>Enhanced receiver management</li> </ul>                                                                |                                         |   |            |                |
| GMII                                | Number of lanes               | 1                       |          | Receiver calibration                                                                                            | None (CDR)                              | * |            |                |
| SGMII                               |                               | 1.00                    |          | Incrementally recalibrate data                                                                                  | eve                                     |   |            |                |
| PRI Rate 1<br>PRI Rate 2            |                               |                         |          | Incrementally recalibrate DFE                                                                                   |                                         |   |            |                |
| PRI Rate 3                          |                               |                         |          | I Incrementally recalibrate DFE                                                                                 | coefficients                            |   |            |                |
| PRI Rate 3<br>PRI Rate 4            |                               |                         |          |                                                                                                                 |                                         |   |            |                |
| PRI Rate 4 PRI Rate 5               | PMA Settings                  |                         |          |                                                                                                                 |                                         |   |            |                |
| PRI Rate 6                          |                               | 68                      |          |                                                                                                                 | 100000000000000000000000000000000000000 |   |            |                |
| PRI Rate 7                          | TX data rate                  | 5000                    | Mbps     | RX data rate                                                                                                    | 5000 Mbps                               |   |            |                |
| PRI Rate 8                          | TX clock division factor      | 1                       |          | and and the second s | Lock to data                            |   | / / /      | PF XCVR 0      |
| DI 3G                               | TX Clock division factor      | 11                      | <u> </u> | RX CDR lock mode                                                                                                | Lock to data                            |   | -CTRL GX   |                |
| DI HD                               | TX PLL base data rate         | 5000.000                | Mbos     | RX CDR reference dock source                                                                                    | Dedicated 💌                             |   | -CTRL ARST | N HILLING      |
| DI SD                               |                               |                         |          |                                                                                                                 |                                         |   | BORS, FROM |                |
| nterlaken 6.25G                     | TX PLL bit dock frequency     | 2500.000                | MHz      | RX CDR reference dock frequency                                                                                 | 125.0 MHz                               |   | F PADA, IN |                |
| nterlaken 10G                       |                               |                         |          | RX JA dock frequency                                                                                            | 125 MHz                                 |   |            |                |
| AUI                                 |                               |                         |          |                                                                                                                 |                                         |   | PF_X       | CVR::PF_XCVR_0 |
|                                     | PCS Settings                  |                         |          |                                                                                                                 |                                         |   |            |                |
| man I among and I                   | E PCS Settings                |                         |          |                                                                                                                 |                                         |   |            |                |
| Apply New preset                    | TX PCS-Fabric interface width | 60                      | ▼ bits   | RX PCS-Fabric interface width                                                                                   | 40 💌 bits                               |   |            |                |
|                                     | TA PEST BUILTINE THE THE      | 140                     | 00       | KA PCS-Pabric Interface widen                                                                                   | 140 015                                 |   |            |                |
|                                     | TX FPGA interface frequency   | 125                     | MHz      | RX FPGA interface frequency                                                                                     | 125 MHz                                 |   |            |                |
|                                     |                               | 14.0                    |          | not if an internet in equality                                                                                  |                                         |   |            |                |
|                                     | PMA Mode                      |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     | Enable CDR Bit-sl             | o port                  |          |                                                                                                                 |                                         |   |            |                |
|                                     | It Endure Cort Dit si         | p por c                 |          |                                                                                                                 |                                         |   |            |                |
|                                     | 8b 10b Encoding/Decoding      |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     | 64b6xb Gear Box               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     | 6 64h66h                      |                         |          | C 646576                                                                                                        |                                         |   | • Symbol   |                |
|                                     | . 040000                      |                         |          | 0.0070                                                                                                          |                                         |   | Symbol     |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |
| Messages 🔞 Errors 🗼 Warnings 🕕 Info |                               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |
|                                     |                               |                         |          |                                                                                                                 |                                         |   |            |                |

The following waveforms show the behavior of the XCVR with ERM optionally included in the Libero generated component. XCVR configurations without ERM operates with reduced functionality and the LANE#\_RX\_READY behavior is identical to the LANE#\_RX\_READY\_CDR waveform since the ERM no longer manages the lane.

Figure 1-11. First Lock Calibration Waveform



During data transmission if the serial link is disrupted due to lack of activity detected by the Fine Lock LANE#\_RX\_READY = 0 and toggling of the LANE#\_RX\_IDLE output signal, the ERM handles a switch over of the CDR from LOCK2DATA to LOCK2REF as shown in the following figure. The ERM manages this mode until the data stream is re-established or the transceiver is placed into reset.





The ERM manages the re-establishment of a link after a break or disruption. A restart begins when a valid data stream is re-applied to the receiver inputs. This starts the operation of the ERM to systematically control the CDR to re-initialize the link. As shown in the following figure, the ERM properly re-establishes a CDR fine lock after assuring

the link is stable. When the link polling is complete, the ERM transitions the transceiver back to proper operation. This is completed without changing any of the CDR or DFE calibration settings and returns calibration setting to those used prior to the disruption or break in the serial data stream.





LTD= Lock to Data

Note: RX\_IDLE integrator detects threshold for signal-presence.

The user can also optionally invoke a calibration on-demand. This would be needed if the interconnection is changed such as swapping cables or other interface media. In this case, the user can request calibration only after a valid data stream is applied to the RXD inputs. As shown in the following figure, assertion of the LANE#\_CALIB\_REQ initiates the ERM to invoke a CDR/DFE calibration during which the CDR remains LOCK2DATA. The LANE#\_CALIB\_REQ is required to stay asserted by the user logic until LANE#\_CALIBRATING goes HIGH.





LTD = Lock to Data Note 1 - starting state of LANE#\_RX\_VAL might be 0 or 1

**Note:** At any time when the Rx PLL is not locked: Once a contiguous Rx data stream of > 25 us occurs, no transmit data gaps of non-standard-compliant data of > 5000 UI are allowed until LANE#\_RX\_VAL = 1. All non-compliant data gaps of any length must be followed by 5000 UI of compliant data until LANE#\_RX\_VAL = 1. If a violation to this requirement is seen, receiver calibration may not occur properly and the device may require the DRI bus to command a register access to cycle the PMA\_LANE\DES\_RSTPD\RXPD = 1'b1 -> 1'b0 in order to continue operating correctly. Assertion of PMA\_ARST should occur at approximately the same time as the RXPD = 1 is written via DRI. Then hold RXPD = 1 for 5 us before writing RXPD = 0 followed by deassertion of PMA\_ARST. For DRI specific information, see the respective PolarFire Device Register Map or PolarFire SoC Register Map. This scenario can also be controlled by using the LANE#\_LOS input to hold off ERM startup until the RX data stream is properly settled.

The ERM can be optionally not included at design creation using the Libero transceiver configurator. Transceiver designs that do not include the ERM have to manage the before mentioned considerations and should only be not used after carefully understanding the system requirements. Without the ERM, the transceiver LANEx\_RX\_READY pin may toggle when the Rx signal is open or disconnected, or while an out-of-range condition occurs. For example, incorrect Rx serial data rates, with serial input data >1.17% away, is considered out of range.

Initially, the Rx CDR lock may not lock with missing or bad data stream. The following conditions prevent the incorrect behavior.

- The Rx data rate is <±300 ppm of the Libero configured rate.
- Rx data is present when PMA\_ARST is de-asserted.
- Data stream must not stop once locked or the CDR Lock circuitry might not properly indicate the status of the CDR.
- PMA\_ARST can be used to restart with any data stream disruptions.

# 1.3 Transceiver PCS Interface Modes

The transceiver PMA connects with the fabric using four PCS interface modes. PMA-PCS gearing is used in conjunction with the interface clock. The TX\_CLK and RX\_CLK frequency is equal to the FPGA interface based on the data rate/(PMA-PCS width × PCS gearing). The PCS interface instantiates the embedded transceiver and RTL blocks when the user customizes and generates the block. These

pre-defined protocol interfaces provide data, control, and status signaling to the user logic in the FPGA fabric, including support for the following modes:

- 8b10b: encoding/decoding and word aligner.
- 64b6xb: 64b/66b or 64/67b encoding/decoding with gearbox logic.
- PIPE: a PHY interface for PCI Express (PIPE) supporting PCIe Gen2. Used with the embedded PCIe core or with the soft-IP hosted in the fabric. See PolarFire FPGA and PolarFire SoC FPGA PCI Express User Guide for details about the embedded PCIe core solution. This interface is transparent with the PCIE (PCIESS) core.
- PMA only: direct access to the PMA without any encoding or decoding.

#### 1.3.1 8b10b

The 8b10b mode supports the encoder and decoder only for interface widths of 16, 32, and 64 bits at the PMA.

The following features are supported in the 8b10b:

- Transmit encoding.
- Transmit disparity forcing.
- Transmit disparity adaptation, which operates in two sub-modes—1Gbps IEEE 802.3 mode and Fiber Channel mode.
- Receiver symbol alignment using CDR slip mechanism.
- Deterministic latency through the 8B10B transmitter and receiver data paths.
- · Receiver decoding.
- · Electable fabric width (on transceiver level) of two, four, or eight octets per clock beat.

The 8b10b trans-coder is protocol independent, in other words, it does not include a protocol-specific word aligner or word alignment state machine. Comma-detection is supported in this mode. The serial data must be aligned to comma-alignment boundaries before being used as parallel data. Without proper alignment, the incoming 8b10b data does not decode correctly. The comma character (K28.5) is usually used for alignment purposes as its 10-bit code is guaranteed not to occur elsewhere in the encoded bit stream.

#### 1.3.1.1 Word Alignment (Byte Boundary or Comma Detect)

The 8b10b PCS block performs the comma code-word detection and alignment operation. The comma character is used by the receive logic to align the incoming data stream into 10-bit words. The alignment comma descriptions (K28.1, K28.5, and K28.7) are defined in section 36.2.4.9 of the IEEE 802.3.2002.

A comma is identified when there is a match across any eight consecutive bits to {00111110} or {11000001} patterns. The only legal 10b characters, which contain series of bits are K28.1, K28.5, and K28.7. In 802.3 specification definition, there is no occurrence of two legal 10b characters sent in a sequence containing the comma pattern, which drastically reduces the chance that a symbol aligner can falsely lock. Alignment status per lane is indicated by the LANE#\_RX\_VAL output pin going to high only after the PMA CDR locks onto an incoming data stream.

Word Aligner can lock onto an incorrect alignment causing disparity errors and/or code violations from the 8b10b decoder. In this case, the word aligner needs to be reset to find a new alignment. This can be done by using the PCS\_ARST\_N reset. The fabric logic needs to monitor the LANE#\_RX\_CODE\_VIOLATION and LANE#\_RX\_DISPERROR to determine when to issue a PCS\_ARST\_N and find a new alignment.

**Note:** Every serial protocol has a specification on how to use disparity errors and code violations to reset the word aligner. In the XCVR 8b10b mode without a soft IP, the user must implement some type of monitoring scheme to identify false alignments.

#### 1.3.1.2 8b10b Data Path Interface

An 8b10b lane data path has the following interfaces:

- Fabric interface a data path interface with soft-logic
- · Internal clocks and resets interface
- PMA interface
  - Parallel transmit data to the serializer
  - Parallel receive data from the de-serializer
- Tx and Rx Fly-wheel FIFO (FWF)
- System registers interface controlling modes and options

The following figure shows an overview of the 8b10b data path within the 8b10b lane. The figure does not show specific 8b10b functional blocks (that is, encoder, aligner, decoder, and so on). The diagram is intended to show the relative data and clock paths from the serial to fabric interface and vice-versa.

The fabric TX\_DATA and RX\_DATA ports are allocated to pin functions as described in the Table 1-6. In addition to the fabric data pins, there are additional signals described in 8b10b port list (Table 1-6). on the fabric interface for 8B10B mode.



#### Figure 1-15. 8b10b Data Path

#### 1.3.1.3 8b10b Bit and Octet Sequencing

Fabric octet bit order is defined in similar way on the Tx and Rx interfaces. In 8b10b notation, each bit of decoded 8-bit octet is assigned a capital letter name of the set A to H. The fabric bus definition is tx\_data[7:0] == {H,G,F,E,D,C,B,A}. Thus for the common Dx.y (and Kx.y) character notation, x = tx data[4:0] and y = tx data[7:5].

The fabric octet sequence is little-endian. In other words, the first octet to be encoded per fabric clock is tx\_data[7:0]. The first octet at the receiver serial input stream per fabric clock is rx\_data[7:0].

The data sent out by the 8b10b lane to the PMA follows the standard convention for the XCVR module.

- Bit 0 is the first bit to be output by the serializer for the 40-bit word, pma\_txdata[39:0].
- Bit 0 is the first bit that is seen at the serial inputs by the deserializer in the SerDes for the 40-bit word, pma\_rxdata[39:0].

The 8b10b 10-bit code-group notation where lower-case letters a to j represent bits of the encoded character relate to the tx\_data[9:0] =  $\{j,h,g,f,i,e,d,c,b,a\}$ . The 'a' bit of each code-group is the first bit transmitted and/or received as per 8b10b protocol standards.

Depending on configuration, the 8b10b transmitter allows two, four, or eight octets to be transferred from the fabric per clock beat. This variable transfer rate implies the internal PCS clock domain is either: (a) two times the frequency of pcs\_tx\_clk; (b) the same frequency as pcs\_tx\_clk; or (c) half the frequency of pcs\_tx\_clk. The domains are always synchronous even when they are at different frequencies.

### 1.3.1.4 8b10b System Registers

There are specific registers used for configuring the 8b10b lane function options in the respective PolarFire Device Register Map or PolarFire SoC Register Map. Other fields are required to properly program the clocks, resets, XCVR, and lane overlay blocks and data path steering. Required system register field setting combinations required for enabling 8b10 lane usage.

| Register<br>Page xls | Register Name | Field Name                 | Description                                                                  | Required Value                                                                                                                                                       |  |  |
|----------------------|---------------|----------------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| pcslane              | L8_R0         | L8_TXENCSWAPSEL            | Selects between 1000BASE-<br>X/T and Fibre Channel octet-<br>swapping modes. | Optional: 0=1000BASE-X/T, 1=Fibre Channel                                                                                                                            |  |  |
|                      |               | L8_GEARMODE[1:0]           | Sets data path width of FWF interfaces.                                      | Must be consistent with clock selections for txfwf_rclk and rxfwf_wclk.                                                                                              |  |  |
|                      | LOVR_R0       | FAB_IFC_MODE[3:0]          | Selects path through fabric and FWF overlay blocks.                          | Must be set to the 8b10b value (3'd4).                                                                                                                               |  |  |
|                      |               | PCSPMA_IFC_MODE[3:0]       | Selects lane mode for driving data into the SerDes serializer.               |                                                                                                                                                                      |  |  |
|                      | LCLK_R0       | LCLK_EPCS_RX_CLK_SEL [1:0] | Chooses which clock is sent to fabric on epcs_rx_clk port.                   | Usually this should be set to 2'd1 so that the frequency of the fabric is the same as the internal                                                                   |  |  |
| pcslane              | LCLK_R0       | LCLK_EPCS_TX_CLK_SEL [1:0] | Chooses which clock is sent to fabric on epcs_tx_clk port.                   | side of the FWF. However variations are possible<br>if the use of the Rx FWF synchronous enable<br>will be employed. See FWF description for further<br>information. |  |  |
|                      |               | LCLK_PCS_RX_CLK_SEL [1:0]  | Defines clock module's source for pcs_rx_clk.                                | Must be set to 2'd3 for all applications using 8B10B function.                                                                                                       |  |  |
|                      |               | LCLK_PCS_TX_CLK_SEL [1:0]  | Defines clock module's source for pcs_rx_clk.                                |                                                                                                                                                                      |  |  |
|                      |               | LCLK_RXFWF_WCLK_SEL [1:0]  | Defines clock module's source for<br>rxfwf_wclk.                             | Must be consistent with L8_GEARMODE setting.                                                                                                                         |  |  |
|                      |               | LCLK_TXFWF_RCLK_SEL [1:0]  | Defines clock module's source for txfwf_rclk.                                |                                                                                                                                                                      |  |  |
|                      |               | LCLK_RXFWF_WCLK_PIPE       | Defines whether Rx FWF is<br>clocked by Tx side clocks or Rx<br>side clocks. | Must be set to 1'd0 for 8B10B functionality.                                                                                                                         |  |  |
|                      | LCLK_R1       | LCLK_ENA_8B10B_RX_CLK      | Instructs clock module to drive 8B10B pcs_rx_clk.                            | Must be set to 1'd1 for 8B10B operation.                                                                                                                             |  |  |
|                      |               | LCLK_ENA_8B10B_RXFWF_WCLK  | Instructs clock module to drive 8B10B rxfwf_wclk.                            |                                                                                                                                                                      |  |  |
|                      |               | LCLK_ENA_8B10B_TX_CLK      | Instructs clock module to drive 8B10B pcs_tx_clk.                            |                                                                                                                                                                      |  |  |
|                      |               | LCLK_ENA_8B10B_TXFWF_WCLK  | Instructs clock module to drive 8B10B txfwf_rclk.                            |                                                                                                                                                                      |  |  |
| pma_lane             | DES_CLK_CTRL  | DESMODE[2:0]               | Selects parallel bus width of deserializer interface.                        | Must select the 40-bit wide bus mode for 8b10b functionality (3'd7).                                                                                                 |  |  |
|                      | SER_CLK_CTRL  | SERMODE[2:0]               | Selects parallel bus width of serializer interface.                          |                                                                                                                                                                      |  |  |
|                      | DES_CDR_CTRL3 | SLIP_DES_CDR_SEL           | Selects source of CDR slip control.                                          | Must be 1'd0 so that the fabric can control the symbol alignment.                                                                                                    |  |  |
|                      |               | SLIP_DES_CDR_EN            | Optionally turns slip control off.                                           | Must be set to 1'd1.                                                                                                                                                 |  |  |

Table 1-5. System Registers Affecting 8b10b Data Path

The following table lists the port names and description for the 8b10b mode of PCS module.

#### Table 1-6. 8b10b Port List

| Port Name                                      | Direction | Clock        | Description                                                                                                                                                                                                                                                                                                        |
|------------------------------------------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LANE#_CDR_REF_CLK_#/<br>LANE#_CDR_REF_CLK_FAB  | Input     | _            | Reference clock to lane CDR. Can be sourced from either an FPGA clock or from a XCVR_#[A,B,C]REFCLK_P/N pin.                                                                                                                                                                                                       |
| LANE#_CLK_REF                                  | Input     | _            | This port is exposed to user with Half-Duplex option. LANE#_REF_CLK must be connected by the user to a stable clock with same clock frequency as Recovered clock such as the local clock.                                                                                                                          |
| LANE#_TX_PLL_REF_CLK_#                         | Input     | _            | Input clock from TX_PLL REF_CLK_TO_LANE output pin. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                             |
| LANE#_TX_BIT_CLK_0                             | Input     | _            | Clock from BIT_CLK of the XCVR TxPLL. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                                           |
| LANE#_TX_PLL_LOCK_#                            | Input     | _            | Input lock status from TX_PLL LOCK output pin. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                                  |
| LANE#_TX_DISPFNC[N:0] <sup>1</sup>             | Input     | TX_CLK_[R:G] | The TX_DISPFNC is a 2-bit encoded setting per octet where bit[1:0] is the lowest octet. The TX_DISPFNC port size is 4-bit, 8-bit, or 16-bit respective to 16-bit, 32-bit, or 64-bit PCS-Fabric interface widths.<br>The TX_DISPFNC encoding is as follows for each octet per IEEE specification Clause 36 (802.3). |
|                                                |           |              | The octet swap feature is designed such that the fabric marks the swap indicator on any octet of the interface. It is not necessary to align the K28.5 to octet 0 or octet 2.                                                                                                                                      |
|                                                |           |              | None - 2'b00 - Normally encode the octet with the encoder's current running disparity.                                                                                                                                                                                                                             |
|                                                |           |              | Swap - 2'b01 - Search for tx_dispfnc = 1, swap next octet when running disparity prior to ordered set is '+'.                                                                                                                                                                                                      |
|                                                |           |              | ForcePlus - 2'b11 - Replace running disparity from encoder with '+' when encoding associated octet. This tx_dispfnc occurs on any octet.                                                                                                                                                                           |
|                                                |           |              | ForceMinus - 2'b10 - Replace running disparity from encoder with '–' when encoding associated octet. This $tx_dispfnc$ occurs on any octet.                                                                                                                                                                        |
| LANE#_8B10B_TX_K[N:0] <sup>2</sup>             | Input     | TX_CLK_[R:G] | Active-high signal indicating that TX_DATA contains k-character information. This indicates that the input is a k-character byte, not a data byte.                                                                                                                                                                 |
| LANE#_TX_DATA[N:0]                             | Input     | TX_CLK_[R:G] | Encoded user data from the fabric. The send/receive order is low to high byte.                                                                                                                                                                                                                                     |
| LANE#_PCS_ARST_N                               | Input     |              | Asynchronous active-low reset for the PCS lane. This reset is responsible for the reset of the 8b10b logic and COMMA word aligner. The RX_SLIP is internally used to align the parallel word on the fabric interface, but does not reset the word aligner.                                                         |
| LANE#_PMA_ARST_N                               | Input     | —            | Asynchronous active-low reset for the PMA lane.                                                                                                                                                                                                                                                                    |
| LANE#_RXD_N                                    | Input     | _            | Transceiver receiver differential input.                                                                                                                                                                                                                                                                           |
| LANE#_RXD_P                                    | Input     | _            | Transceiver receiver differential input.                                                                                                                                                                                                                                                                           |
| LANE#_8B10B_RX_K[N:0] <sup>2</sup>             | Output    | RX_CLK_[R:G] | Active-high output from the decoder to the receiver indicating that the received data is a K character. The order of character bits within an octet, in 8b10b mode, is least to most-significant bit as defined by 8b10b code notation.<br>[0]: K decoded data on RX_DATA[7:0].                                    |
|                                                |           |              | [1]: K decoded data on RX_DATA[15:8].                                                                                                                                                                                                                                                                              |
| LANE#_RX_DISPARITY_<br>ERROR[N:0] <sup>2</sup> | Output    | RX_CLK_[R:G] | Active-high output indicates when the received code group exists in the 8b10b decoding table but is not found in the proper column according to the current running disparity.                                                                                                                                     |
| LANE#_RX_CODE_<br>VIOLATION[N:0] <sup>2</sup>  | Output    | RX_CLK_[R:G] | Active-high signal indicating that the decoder has detected an error in the received data.                                                                                                                                                                                                                         |
| LANE#_RX_DATA[N:0] <sup>3</sup>                | Output    | RX_CLK_[R:G] | Decoded user data to fabric. The send/receive data order is low to high byte meaning the octet<br>order is least to most-significant.<br>Data[7:0] = First octet<br>Data[15:8] = Second octet                                                                                                                      |

| continued                       |           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------------|-----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Name                       | Direction | Clock        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| LANE#_RX_VAL                    | Output    | Asynchronous | LANE#_RX_VAL indicates that the XCVR data path is initialized. The parallel bus<br>of LANE#_RX_DATA[N:0] contains actual data recovered from the serial stream when<br>LANE#_RX_VAL = 1.<br>In 8b10b mode, the Rx PCS logic self-resets when the CDR is not locked. In<br>this mode, LANE#_RX_VAL rises just after LANE#_RX_READY rises. Always pulse<br>LANE#_PCS_ARST_N=0 using a clock independent from the LANE#_RX_CLK_R transceiver<br>output. Asserting and holding LANE#_PCS_ARST_N=0 can prevent LANE#_PCS_RX_READY<br>from rising and hold LANE#_RX_CLK_R at a static level.                                                                                             |
|                                 |           |              | In 8b10b mode, the LANE#_RX_VAL is qualified when XCVR receiver calibration completes,<br>included with the enhanced receiver management completion, and the CDR locks and the initial<br>comma/word alignment occurs.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| LANE#_RX_READY                  | Output    | Asynchronous | Rises when the enhanced receiver management and CDR completes a fine lock detection to the incoming data transitions and the de-serializer is powered-up. If there is no incoming data to the CDR then the RX_READY is low. The primary purpose of this pin is to let the fabric know the CDR is locked to serial input data and is producing valid clocking.<br>Note: In a loopback case where looping the local transmitter output to the receiver input, it is necessary to take the Tx out of reset to ensure valid serial transitions, allowing the Rx CDR to lock. If the user waits till Rx CDR locks before releasing Tx from reset, in such a case, the system deadlocks. |
| LANE#_RX_IDLE                   | Output    | Asynchronous | Receive Electrical Idle (EI) detection flag. Flag is 1 when EI is valid. LANE#_Rx_IDLE peak detector logic is only valid for a limited minimum density of transitions on the Rx data and not to be used in applications above 5Gbps.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| LANE#_TX_CLK_STABLE             | Output    | _            | Transmit transceiver/PCS lane ready flag. This flag is 1 when the transmit PLL is locked to the reference clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| LANE#_RX_CLK_[R:G]              | Output    | _            | Global or regional receive clock to the fabric. <sup>4</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| LANE#_TX_CLK_[R:G] <sup>5</sup> | Output    | —            | Global or regional transmit clock to the fabric. <sup>4</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| LANE#_TXD_N                     | Output    | _            | Transceiver transmitter differential output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| LANE#_TXD_P                     | Output    | _            | Transceiver transmitter differential output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

 $(1)_{\mbox{ N}}$  can be 1, 3, 7, and 15.

(2) N can be 1, 3, and 7.

(3) N can be 15, 31, and 63.

 $^{(4)}$  [R:G] naming is generated based on the use of regional or global resources that are selected with Libero.

Note: LANE# can be 0, 1, 2, and 3.

(5) In PolarFire FPGA MPF500 devices and PolarFire SoC FPGA devices, the TX\_CLK\_R and RX\_CLK\_R pins of XCVR lanes placed in the PCIESS (Q0) and GPSS1 (Q1) quads cannot drive I/Os.

#### 1.3.2 64b66b/64b67b

The 64b66b/64b67b (64b6xb) interface modes are used mainly for 10 Gbps-based protocols, 10G base interface over Ethernet (10GBASE-R/KR), common public radio interface (CPRI) rates of 9.830 Gbps, and 40GBASE-R standards. 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 following features are supported in the 64b6xb:

- Fabric width is selectable. Four and eight byte widths are available.
- Gearbox functions are set for 67-bit or 66-bit block size. The gearbox functions can be bypassed.
- Optional scrambler and descrambler 64b66b data.
- Optional test pattern generate/compare mode.
- Optional PRBS generate/compare mode.
- Optional disparity generate/check (applies to 64b67b data).
- Receiver block lock state-machine controlling the hunt for synchronization header boundaries is available in two forms.

- The IEEE 802.3 Clause 49 state-machine loses lock when 16 invalid headers are observed within a contiguous set of 64 headers.
- The IEEE 802.3 Clause 82 state-machine loses lock when 65 invalid headers are observed within a contiguous set of 1024 headers.
   Both block lock state-machines require an initial set of 64 contiguous valid headers to gain block lock. The Clause 82 state-machine is specified for use with 40 G and 100 G links. One of these state-machines must be enabled in order for the receiver to locate and lock onto the block boundaries.
- Optional receiver IEEE 802.3 bit error rate monitor function.
- Optional data path delay status monitors for transmit and receive.

Note: Forward Error Correction (FEC) option of IEEE 802.3 10GBASE-KR is not supported by the 64b6xb PCS.

The encoder uses per-lane block interfaces with a fabric interface to receive and transmit encoded data and a PMA interface to send parallel data to the transceiver. This mode also supports the Interlaken protocol by providing 64b67b with optional embedded gearing logic.

#### 1.3.2.1 64b6xb Data Path Interface

An 64b6xb lane data path has the following interfaces:

- Fabric interface a data path interface with soft-logic
- Internal clocks and resets interface
- PMA interface
  - Parallel transmit data to the serializer
  - Parallel receive data from the de-serializer
- Tx and Rx Fly-wheel FIFO(FWF)
- 64b6xb Transmit Data Path Blocks, Fabric to PMA Order
- 64b6xb Receive Data Path Blocks, PMA to Fabric Order
- System registers interface controlling modes and options

The following figure shows an overview of the 64b6xb data path within the 64b6xb lane. The diagram is intended to show the relative data and clock paths from the serial to fabric interface and vice-versa.

The fabric TX\_DATA and RX\_DATA ports are allocated to pin functions as described in 64B6xB Port List Table 1-10. In addition to the fabric data pins, there are additional signals described in 64B6xB portlist (Table 1-10) on the fabric interface for 64B6xB mode.

#### Table 1-7. 64b6xb Transmit Data Path Blocks, Fabric to PMA Order

| Tx Block     | Purpose                                                                                                                                                                                                                        |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8B_to_4B     | Optionally compresses transmit bus width from 64-bits to 32-bits.                                                                                                                                                              |
| Tx Scrambler | Implements IEEE 802.3 Clause 49 data scrambling. Same scrambling also specified for use in Interlaken.                                                                                                                         |
| Tx Disparity | Implements inversion of 67-bit symbol. Only for use in Interlaken.                                                                                                                                                             |
| Tx Gearbox   | Outputs continuous stream of 32-bits per clock beat to the PMA given an input consisting of 64-bit block symbols, which has cyclic gaps in its active clock beats. This block inserts the 2 or 3 bits of header on each block. |
| Tx Test Gen  | Optionally replaces the output stream with PRBS or square-wave pattern (1111_0000).                                                                                                                                            |

#### Table 1-8. 64b6xb Receive Data Path Blocks, PMA to Fabric Order

| Rx Block     | Purpose                                                                                                                                                                                                                                                          |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rx Gearbox   | Locates block boundaries (configurable to 66-bit or 67-bit) in continuous stream of 32-bits data per clock beat from PMA. Removes the 2 or 3 bit headers and plays out the 64-bit data blocks in cyclic pattern of 32-bit clock beats with some inactive cycles. |
| Rx Disparity | Inverts block based on header bit used in Interlaken.                                                                                                                                                                                                            |

| continued       |                                                                                                              |
|-----------------|--------------------------------------------------------------------------------------------------------------|
| Rx Block        | Purpose                                                                                                      |
| Rx De-scrambler | Implements IEEE 802.3 Clause 49 data de-scrambling. Same de-scrambling also specified for use in Interlaken. |
| Rx 4B_to_8B     | Optionally widens the data path to 64-bits per clock beat.                                                   |

#### Figure 1-16. 64b6xb Data Path



#### 1.3.2.2 64b6xb System Registers

There are specific registers used for configuring the 64b6xb lane function options in the respective PolarFire Device Register Map or PolarFire SoC Register Map. Other fields are required to properly program the clocks, resets, XCVR, and lane overlay blocks and data path steering. System register field setting combinations is required for enabling 64b6xb lane usage.

| Register Page<br>xls | Register<br>Name | Field Name                | Description                                                                                                                                                                                                                                                                              |
|----------------------|------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pcslane              | L64_R0           | L64_CFG_BYPASS_GEARBOX    | When = 1, both transmit and receive gearbox functions are bypassed.                                                                                                                                                                                                                      |
|                      |                  | L64_CFG_BYPASS_SCRAMBLER  | When = 1, both the scrambler and the descrambler are bypassed.                                                                                                                                                                                                                           |
|                      |                  | L64_CFG_BYPASS_DISPARITY  | Enable the Interlaken block disparity generation and checking blocks by setting cfg_bypass_disparity=0.                                                                                                                                                                                  |
|                      |                  | L64_CFG_BYPASS_8B_MOD     | When = 0 to obtain 64-bit fabric interfaces. Set cfg_bypass_8B_mode=1 for 32-bit fabric interfaces.                                                                                                                                                                                      |
|                      |                  | L64_CFG_GRBX_64B67B       | When = 1 for 67-bit blocks (Interlaken).                                                                                                                                                                                                                                                 |
|                      |                  | L64_CFG_GRBX_SM_C49       | When = 1 to enable IEEE 802.3 Clause 49 receiver lock state machine. Value of L64_CFG_GRBX_SM_C82 must be set as inverse of this bit.                                                                                                                                                    |
|                      |                  | L64_CFG_GRBX_SM_C82       | When = 1 to enable IEEE 802.2 Clause 82 receiver lock state machine behavior (40G link version). Value of L64_CFG_GRBX_SM_C49 must be set as inverse of this bit.                                                                                                                        |
|                      |                  | L64_CFG_BER_MON_EN.       | When = 1 to enable the BER Monitor in the receiver. The BER Monitor is useful in CPRI applications.                                                                                                                                                                                      |
|                      |                  | L64_CFG_BER_1US_TIMER_VAL | This register should be set to the number of clock beats which most closely represents one microsecond. This field is used by the BER Monitor to time the 125 microsecond interval. Examples: CPRI rate 7A setting is 0x18B; CPRI rate 8 setting is 0x140; CPRI rate 9 setting is 0x107. |

#### Table 1-9. System Registers Affecting 64b6xb Data Path

#### 1.3.2.3 64b66b Receiver

The receiver takes 32-bits or 64-bits of data from the PMA's CDR on each clock beat into the gearbox. The gearbox frames the data into 66-bit symbols by searching for valid values on the sync header bits as per IEEE 802.3 Clause 49.



#### Figure 1-17. 64b66b Receive Sequence For 32-Bit Interface

| Figure 1-18. 64b66b Receive Sequence For 64-Bit Interface |       |    |   |   |   |   |    |   |   |   |           |    |            |   |
|-----------------------------------------------------------|-------|----|---|---|---|---|----|---|---|---|-----------|----|------------|---|
| clk                                                       |       |    |   |   |   |   |    |   |   |   |           |    |            |   |
| pcs_sos                                                   | •     |    |   |   |   |   |    |   |   |   | 32 cycles |    | ► 33rd     |   |
| pcs_hdr<br>[3:0]                                          | 01    | 10 |   |   |   | ( | 01 |   |   |   |           | 10 | 01         |   |
| pcs_data<br>[63:0]                                        | а     | b  | с | d | e | f | g  | h | i | j | ]         | p  | dead cycle |   |
| pcs_h                                                     | dr_en |    |   |   |   |   |    |   |   |   |           |    |            |   |
| pcs_da                                                    | ta_en |    |   |   |   |   |    |   |   | - |           |    |            | _ |

#### 1.3.2.4 64b66b Transmit

In the transmit direction, the encoded 64-bit blocks are applied to PCS data from the fabric along with the sync headers. When the 64-bit symbol is a control block, like Idle, Start or Terminate, then pcs\_hdr[1:0]=0b10. Otherwise, pcs\_hdr[1:0]=0b01. The timing signal pcs\_sos, indicates the sequence boundaries. The sequence boundaries differ for 32-bit and 64-bit interfacing as shown in the following figures. The configuration includes the scrambling of the data within the 64-bit blocks. Scrambling is done in accordance with IEEE 802.3.

The transmit gearbox produces 32-bits to the PMA on each clock beat where the data is converted to serial form and sent out to the link partner.



#### Figure 1-19. 64b66b Transmit Sequence For 64-Bit Interface

#### 1.3.2.5 64b67b Transmit

In the recommended configuration for 64b67b, encoded and scrambled data is presented from the fabric into TX\_DATA along with sync headers on TX\_HDR[3:0]. The data from the fabric must conform to the expected sequence of clock beats according to the fabric interface width.



Figure 1-21. 64b67b Transmit Sequence For 32-Bit Interface

The 64-bit interface option has dead cycles on clock beats 44, 45, 88, 89, 132, and 133.

The transmit data first enters the PCS Timing control block, which generates the appropriate markers for 64b67b blocks. The data then goes to the disparity calculation block. The total number of ones and zeros are balanced by inverting blocks as necessary. When a block is inverted, sync header bit 2 is set to mark the inversion. Bits [1:0] of the sync header have the same meaning as they do in 64b66b blocks.

Data from the disparity block then goes to the transmit gearbox where it is output in 32-bit chunks per clock beat and sent to the PMA serializer.

#### 1.3.2.6 64b67b Receive

Data comes into the 64b67b receiver from the PMA 32-bits per clock beat from the de-serializer. The data is qualified by RX\_READY=1, which is set by the greater PMA logic when CDR achieves bit lock and is producing a stable clock.

The receive gearbox frames the 67-bit blocks by examining sync header bits [1:0] in the same method as described for 64b66b. The difference is in the span of bits between sync headers. The receive disparity block invert blocks as indicated by sync header bit [2]. The receive data is then sent to the fabric in 64-bit or 32-bit clock beat sequences. The 32-bit sequence is shown in the following figure where two clock beats transfer one symbol. In the 32-bit width, the sequence is 134 clock beats long and contains blank symbol transfers for clock beats 44-45, 88-89 and 132-133.





Sequence timing for the 64-bit interface consists of 67 clock beats with dead cycles at beats 22, 44, and 66.

The following table lists the port names and description for the 64b66b/64b67b mode of the PCS module. See section 49.2.4 of the IEEE 802.3ae specification for more information.

| Table 1-10. 64b66b/64b67b Port | List |
|--------------------------------|------|
|--------------------------------|------|

| Port Name                                     | Direction | Clock        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------------------------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LANE#_CDR_REF_CLK_#/<br>LANE#_CDR_REF_CLK_FAB | Input     | -            | Reference clock to lane CDR. Can be sourced from either the FPGA clock or from a XCVR_#[A,B,C]REFCLK_P/N pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| LANE#_CLK_REF                                 | Input     | -            | This port is exposed to user with Half-Duplex option. LANE#_REF_CLK must be connected by the user to a stable clock with same clock frequency as Recovered clock such as the local clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| LANE#_TX_PLL_REF_CLK_#                        | Input     | -            | Input clock from the TX_PLL REF_CLK_TO_LANE output pin. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| LANE#_TX_BIT_CLK_0                            | Input     | -            | Clock from BIT_CLK of the XCVR TxPLL. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| LANE#_TX_PLL_LOCK_#                           | Input     | -            | Input lock status from the TX_PLL LOCK output pin. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| LANE#_TX_SOS                                  | Input     | TX_CLK_[R:G] | Start-of-sequence pulse for a super frame, the length of which varies with the mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| LANE#_TX_HDR[3:0]                             | Input     | TX_CLK_[R:G] | Sync header corresponding to different encoding types.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| LANE#_TX_DATA[63:0]                           | Input     | TX_CLK_[R:G] | Input encoded data from fabric. PF_XCVR sends/receives bytes in high to low byte order only in the 64B6xB mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| LANE#_PCS_ARST_N                              | Input     | TX_CLK_[R:G] | Asynchronous active-low reset for PCS lane.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| LANE#_PMA_ARST_N                              | Input     | TX_CLK_[R:G] | Asynchronous active-low reset for the PMA lane.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| LANE#_TX_ELEC_IDLE                            | Input     | Asynchronous | Transceiver configurator allows pin to be exposed on component. This input forces XCVR_P/N transmit output pad pair to a common-mode voltage. It is used for low-frequency out-of-band signaling, or to signal entry into a low-power state to the link partner.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| LANE#_TX_BYPASS_DATA                          | Input     | Asynchronous | Transceiver configurator allows pin to be exposed on component. When LANE#_TX_BYPASS_DATA=1, the data can be driven into the transmit pads instead of the normal serializer data. The bypass is asynchronous and this signal does not transit through the FWF. This pin should be tied low if exposed to fabric and not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| LANE#_RXD_N                                   | Input     | _            | Transceiver receiver differential input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| LANE#_RXD_P                                   | Input     | _            | Transceiver receiver differential input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| LANE#_RX_HDR_VAL                              | Output    | RX_CLK_[R:G] | Enable for header data in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| LANE#_RX_SOS                                  | Output    | RX_CLK_[R:G] | Start-of-sequence pulse for a super frame, the length of which varies based on the mode. High output indicates start of sequence.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| LANE#_RX_DATA_VAL                             | Output    | RX_CLK_[R:G] | Valid when there is data on RX_DATA.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| LANE#_RX_HDR[3:0]                             | Output    | RX_CLK_[R:G] | Sync header corresponding to different encoding types.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| LANE#_RX_DATA[63:0]                           | Output    | RX_CLK_[R:G] | Receive encoded data from 64b6b to the fabric. PF_XCVR sends/receives bytes in high to low byte order only in the 64B6xB mode.<br>Bit 31 or bit 63 arrives first in the serial data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| LANE#_RX_VAL                                  | Output    | RX_CLK_[R:G] | LANE#_RX_VAL indicates that the XCVR data path is initialized. The parallel bus<br>of LANE#_RX_DATA[N:0] contains actual data recovered from the serial stream when<br>LANE#_RX_VAL = 1.<br>In 64b66b/64b67b mode, the Rx PCS logic self-resets when the CDR is not locked. In this<br>mode, LANE#_RX_VAL rises just after LANE#_RX_READY rises. If you want to control Rx<br>PCS reset, hold LANE#_PCS_ARST_N in reset when LANE#_RX_READY is low and release,<br>when LANE#_RX_READY goes high. Once LANE#_PCS_ARST_N is released from reset,<br>LANE#_RX_VAL rises to indicate the Rx parallel data is valid. In 64b6xb mode, the RX_VAL<br>is qualified when the XCVR receiver calibration completes, included with the enhanced receiver<br>management completion, and the CDR locks. |

| continued                       |           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|---------------------------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Port Name                       | Direction | Clock        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| LANE#_RX_READY                  | Output    | _            | Rises when the enhanced receiver management and CDR completes a fine lock detection to the incoming data transitions and the de-serializer is powered-up. If there is no incoming data to the CDR then the RX_READY is low. The primary purpose of this pin is communicating to fabric that the CDR is locked to serial input data and is producing valid clocking.<br>Note: In a loopback case while looping the local transmitter output to the receiver input, it is necessary to take the Tx out of reset to ensure valid serial transitions, allowing the Rx CDR to lock. The system deadlocks, if the user waits till Rx CDR locks before the Tx is released from reset. |  |  |
| LANE#_RX_IDLE                   | Output    | _            | Receive electrical-idle detection flag. LANE#_Rx_IDLE peak detector logic is only valid for a limited minimum density of transitions on the Rx data and not to be used in applications above 5Gbps.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| LANE#_TX_CLK_STABLE             | Output    | _            | Transmit transceiver/PCS lane ready flag.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| LANE#_RX_CLK_[R:G]              | Output    | _            | Global or regional receive clock to the fabric for the receiver.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| LANE#_TX_CLK_[R:G] <sup>1</sup> | Output    | _            | Global or regional transmit clock to the fabric for the transmitter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| LANE#_STATUS_HI_BER             | Output    | RX_CLK_[R:G] | From the bit error rate monitor, which counts bad sync header values (0b00 or 0b11). Occurs over 125 $\mu s$ interval.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| LANE#_STATUS_LOCK               | Output    | RX_CLK_[R:G] | From the selected receive sync lock state-machine (Clause 49 or Clause 82). This is 0 when the sync header boundary is not locked, and it is 1 when sync lock is achieved. See IEEE 802.3 Clause 49 and Clause 82 for block lock state machine.                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| LANE#_TXD_N                     | Output    | _            | Transceiver transmitter differential output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| LANE#_TXD_P                     | Output    | _            | Transceiver transmitter differential output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |

#### Notes:

- 1. In PolarFire FPGA MPF500 devices and PolarFire SoC FPGA Devices, the TX\_CLK\_R and RX\_CLK\_R pins of XCVR lanes placed in the PCIESS(Q0) and GPSS1(Q1) quads cannot drive I/Os.
- 2. LANE# can be 0, 1, 2, and 3. [R:G] naming is generated based on the use of regional or global resources that are selected with Libero.

#### 1.3.3 PIPE

The transceiver PMA interface to PCIe is based on a standard PIPE interface logic. It provides a standard interface between the PMA lane and the higher link-level of the PHY. The logic handles the following functions:

- 8b10b encoding/decoding logic.
- Lane polarity requirements.
- Elastic FIFO and SKP character logic.
- Hot-plug insertion logic.
- PMA controls required by PCIe standard.
- PCIe detection of remote receiver, power state change, and so on. Provides translation of MACs LTSSM states into PMA power states.

The PIPE interface is used by the embedded PCIESS or can be used with a soft PCIe IP in the FPGA fabric. The embedded PCIESS is accessed through a dedicated interface to the PIPE interface mode, which ties the PCIESS to the PIPE without additional fabric logic. All PHY interface signals are synchronous to the PIPE CLOCK. The PIPE PCS is used as the interconnection between either the embedded PCIe block or used with a fabric-based soft-IP connected to the transceiver PMA. The port list differs slightly based on whether the PIPE interface is configured in PCIe mode. See the PHY Interface for the PCI Express.

#### Table 1-11. PIPE Port List

| Port Name                                     | Direction | Clock | Description                                                                                               |
|-----------------------------------------------|-----------|-------|-----------------------------------------------------------------------------------------------------------|
| LANE#_CDR_REF_CLK_#/<br>LANE#_CDR_REF_CLK_FAB | Input     | —     | Reference clock to lane CDR. Can be sourced from either FPGA clock or from a XCVR_#[A,B,C]REFCLK_P/N pin. |

| continued                 |           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|---------------------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Port Name                 | Direction | Clock        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| LANE#_CLK_REF             | Input     | -            | This port is exposed to user with Half-Duplex option. LANE#_REF_CLK must be connected by the user to a stable clock with same clock frequency as Recovered clock such as the local clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| LANE#_TX_PLL_REF_CLK_#    | Input     | -            | Input clock from TX_PLL REF_CLK_TO_LANE output pin. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| LANE#_TX_PLL_LOCK_#       | Input     | -            | Input lock status from TX_PLL LOCK output pin. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| LANE#_TX_BIT_CLK_#        | Input     | _            | Clock from BIT_CLK of the XCVR TXPLL. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| LANE#_TX_DATA[39:0]       | Input     | -            | Parallel data bus to the PCS from the fabric. The PF_XCVR send/receive order is low to high byte.<br>When the hard PCIESS is used, received data is always 32 bits wide. The upper bits [39:32] are ignored.<br>When the soft PCIe IP design is used, then TXDATA is 40 bits wide; otherwise, it is 32 bits wide (the upper byte is ignored).                                                                                                                                                                                                                                                                                                                                                             |  |  |
| LANE#_TXDATAK[3:0]        | Input     | TX_CLK_[R:G] | Indicates the type of characters on the TXDATA bus. A 0 indicates a data character, while 1 indicates a control character. If the soft PCIe IP is used, this signal is ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| LANE#_TXDETECTRX_LOOPBACK | Input     | TX_CLK_[R:G] | High instructs the PHY to begin the receive detect process or external loopback as described<br>in the PCI Express specification. As with many PIPE signals, the meaning of this signal<br>depends on which power state the PHY is in. When in P1 state, this signal informs the PHY<br>to perform a receive detect, but when in P0 state, this signal informs the device to go into<br>loopback mode.                                                                                                                                                                                                                                                                                                    |  |  |
| TXCOMPLIANCE              | Input     | TX_CLK_[R:G] | When asserted, this ordinarily forces the currently running disparity to negative. As the name implies, this is useful in conjunction with the transmission of the compliance pattern to generate test data. It is also used in a multi-lane implementation to turn off any unused lanes, for example, when a ×4 link must operate as a ×1. When both TXCOMPLIANCE and TXELECIDLE are asserted, the affected lane turns off to conserve as much power as possible.                                                                                                                                                                                                                                        |  |  |
| POWERDOWN[1:0]            | Input     | TX_CLK_[R:G] | <ul> <li>These inputs place the transceiver into one of four power states:</li> <li>P0: normal operational mode.</li> <li>P0s: PCLK remains on, but the receiver conserves power; entered when the receiver detects electrical idle. Corresponds to link state L0s.</li> <li>P1: PCLK remains on; both the receiver and transmitter are in electrical idle. Corresponds to link state L1.</li> <li>P2: PCLK is off. The PHY must minimize power consumption as it must operate within the VAUX limits. Corresponds to link state L2.</li> <li>See the PHY Interface for the PCI Express for more details on PHY power management.</li> </ul>                                                              |  |  |
| PCIE_RATE[1:0]            | Input     | TX_CLK_[R:G] | Controls the link signaling rate.<br>In PCIe mode:<br>00: Gen1 (2.5 Gbps)<br>01: Gen2 (5.0 Gbps)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| TXMARGIN[2:0]             | Input     | TX_CLK_[R:G] | Selects transmitter voltage levels:<br>000: TxMargin value 0. Normal operating range<br>001: TxMargin value 1. 800 mV–1200 mV for full swing or 400 mV –700 mV for half swing<br>010: TxMargin value 2 (required). Vendor defined<br>011: TxMargin value 3 (required). Vendor defined<br>100: TxMargin value 3 (required). 200 mV–400 mV for full-swing or 100 mV–200 mV for<br>half-swing<br>101: TxMargin value 5 (optional). 200 mV–400 mV for full-swing or 100 mV–200 mV for<br>half-swing<br>110: TxMargin value 6 (optional). 200 mV–400 mV for full swing or 100 mV–200 mV for<br>half-swing<br>111: TxMargin value 7 (optional). 200 mV–400 mV for full swing or 100 mV–200 mV for<br>half-swing |  |  |

| continued             |           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Name             | Direction | Clock        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| TXDEEMPH              | Input     | TX_CLK_[R:G] | Selects transmitter de-emphasis:<br>0: 6 dB de-emphasis at 5 Gbps<br>1: 3.5 dB de-emphasis at 5 Gbps<br>PIPE implementations that only support 2.5 Gbps signaling rate do not implement this signal.                                                                                                                                                                                                                                                                                                                                                                                    |
| TXSWING               | Input     | TX_CLK_[R:G] | Controls transmitter voltage swing:<br>0: Full swing<br>1: Half swing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| LANE#_RXPOLARITY      | Input     | TX_CLK_[R:G] | This active-high signal indicates the PHY to do a polarity inversion on the received data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| LANE#_RXSTANDBY       | Input     | TX_CLK_[R:G] | Used to set the RxStandby state:<br>0: Active<br>1: Standby                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| LANE#_TXELECIDLE      | Input     | TX_CLK_[R:G] | When this signal is asserted high, it forces the transmitter to the electrical idle state regardless of power states. When this signal is de-asserted, valid data from TXDATA and TXDATAK are transmitted in the P0 state. If the PHY is in the P2 state, a beacon must be transmitted when TXELECIDLE is de-asserted. In the P0s and P1 states, TXELECIDLE must be asserted. The use of this signal is also affected by the PHY power state since there are some states in which the transmitter must be electrically idle. See the PHY Interface for the PCI Express for more detail. |
| LANE#_PCS_ARST_N      | Input     | _            | Asynchronous active-low reset for PCS lane.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| LANE#_PMA_ARST_N      | Input     | _            | Asynchronous active-low reset for PMA lane.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| LANE#_RXD_N           | Input     | _            | Transceiver receiver differential input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| LANE#_RXD_P           | Input     | _            | Transceiver receiver differential input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| LANE#_RXELECIDLE      | Output    | RX_CLK_[R:G] | The PCIe receiver pins detect an electrical idle state on the link. High indicates receiver detection of electrical idle, and low indicates beacon signaling when in P2.                                                                                                                                                                                                                                                                                                                                                                                                                |
| LANE#_RXSTANDBYSTATUS | Output    | RX_CLK_[R:G] | The PHY uses this signal to indicate its Rx Standby state.<br>0: Active<br>1: Standby                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| LANE#_RX_DATA[39:0]   | Output    | RX_CLK_[R:G] | Parallel data bus from the PCS to the fabric. The PF_XCVR send/receive order is low to high byte.<br>When the soft PCIe IP design is used, then RXDATA is 40 bits wide; otherwise, it is 32 bits wide (the upper byte is ignored).                                                                                                                                                                                                                                                                                                                                                      |
| LANE#_RXDATAK[3:0]    | Output    | RX_CLK_[R:G] | The data#/control indicator(s) for the received symbols on the RXDATA bus:<br>0: RXDATA contains data<br>1: RXDATA contains ordered sets<br>If the soft PCIe IP is used, then RXDATAK is ignored.                                                                                                                                                                                                                                                                                                                                                                                       |
| LANE#_RXVALID         | Output    | RX_CLK_[R:G] | Qualifies the data on RXDATA and RXDATAK. When this signal is asserted, the data on the receive data bus is valid, and the PHY has achieved symbol lock.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| LANE#_RXSTATUS[2:0]   | Output    | RX_CLK_[R:G] | Delivers receiver status and error codes for the received data and receiver detect status from<br>the PHY to the MAC; for example, SKP symbol added or removed, disparity error, elastic<br>buffer overflow or underflow, 8b10b decode error, and so on.<br>0 0 0: Received data OK<br>0 0 1 1: SKP added<br>0 1 0 1: SKP removed<br>0 1 1: Receiver detected<br>1 0 0: Code error<br>1 0 1: Elastic buffer overflow<br>1 1 0: Elastic buffer underflow<br>1 1 1: Receive disparity error                                                                                               |
| LANE#_RX_BYPASS_DATA  | Output    | Async        | RX_BYPASS_DATA output is a low-speed bypass of the differential receiver that is used for the receive pads. This is a a low-frequency out-of-band debug signal.                                                                                                                                                                                                                                                                                                                                                                                                                         |

| continued                       |           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|---------------------------------|-----------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Port Name                       | Direction | Clock        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| LANE#_PHYSTATUS                 | Output    | RX_CLK_[R:G] | Signals that the PHY has completed its setup and is ready for data traffic. It is also used to indicate successful transition from power management state, rate change, and receive detection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| LANE#_RX_VAL                    | Output    | RX_CLK_[R:G] | LANE#_RX_VAL indicates that the XCVR data path is initialized. The parallel bus<br>of LANE#_RX_DATA[N:0] contains actual data recovered from the serial stream when<br>LANE#_RX_VAL = 1.<br>In PIPIE mode, the Rx PCS logic self-resets when the CDR is not locked. In this mode,<br>LANE#_RX_VAL rises just after LANE#_RX_READY rises. If you want to control Rx<br>PCS reset, hold Rx PCS in reset when LANE#_RX_READY is low and release, when<br>LANE#_RX_READY goes high. Once Rx PCS is released from reset, LANE#_RX_VAL rises<br>to indicate the Rx parallel data is valid.<br>In PIPE mode, the LANE#_RX_VAL is qualified when the CDR locks and the initial comma/<br>word alignment occurs. |  |  |  |
| LANE#_RX_READY                  | Output    | _            | Rises when the CDR is phase-locked to the incoming data transitions and the de-seriali<br>is powered-up. If there is no incoming data to the CDR then the RX_READY is low. The<br>primary purpose of this pin is communicating to fabric that the CDR is locked to serial in<br>data and is producing valid clocking.<br>Note: In a loopback case while looping the local transmitter output to the receiver input,<br>necessary to take the Tx out of reset to ensure valid serial transitions, allowing the Rx C<br>to lock. The system deadlocks, if the user waits till Rx CDR locks before the Tx is releas<br>from reset.                                                                         |  |  |  |
| LANE#_RX_IDLE                   | Output    |              | Receive electrical-idle detection flag. Asserts asynchronously, but de-asserts synchronously to the RX_CLK_OUT rising edge.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| LANE#_TX_CLK_STABLE             | Output    | _            | Transmit transceiver/PCS lane ready flag. This flag is 1 when the transmit PLL is locked to the reference clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| LANE#_TX_CLK_[R:G] <sup>1</sup> | Output    | _            | Global or regional transmit clock to fabric.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| PIPE_CLOCK                      | Output    | _            | In PCIe Gen1/Gen2 modes of Soft PIPE PCS setting, there is only one TX_CLK_[R:G] for all the 4 lanes that could be configured in single XCVR configurator instance, that is, LANE0_TX_CLK_[R:G] (renamed as PIPE_CLOCK). This PIPE_CLOCK is commonly used for all the lanes. Internally, both RX_FWF_CLK and TX_FWF_CLK (internal ports on the XCVR macro) of each lane are connected to the PIPE_CLOCK (LANE0_TX_CLK_R/G) through RCLKINT/CLKINT.                                                                                                                                                                                                                                                      |  |  |  |
| LANE#_TXD_N                     | Output    | —            | Transceiver transmitter differential output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| LANE#_TXD_P                     | Output    | _            | Transceiver transmitter differential output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |

(1) In PolarFire FPGA MPF500 devices and PolarFire SoC FPGA, the TX\_CLK\_R and RX\_CLK\_R pins of XCVR lanes placed in the PCIESS(Q0) and GPSS1(Q1) quads cannot drive I/Os.

**Note:** LANE# can be 0, 1, 2, and 3. [R:G] naming is generated based on the use of regional or global resources that are selected with Libero.

# 1.3.4 PIPE Interface Compliance Exceptions

The PIPE Interface complies with Intel's Specification version 4.0 with the following exceptions.

- P1 to P0 power-state, PhyStatus pulse response is approximately 30 microseconds delayed from the request to enter P0. The long delay is caused by waiting for the Rx PLL to spin-up and stabilize. The P0-entry is observed externally as a long delay before sending training patterns. The training pattern delay is a fatal protocol error.
- PCI-Express receiver detection has the following issues when used with soft PIPE interface.
  - A receiver detection returning a Receiver-Not-Present status does so with an oscillating PhyStatus pulse train. MAC-side LTSSM logic must ignore all but the first PhyStatus pulse of the oscillation.
  - A subsequent receiver detection operation N, begins a receiver detect, but immediately returns the status
    of detection N-1 via PhyStatus and RxStatus when N > 0. The very first receiver detection (N = 0) waits
    until the conclusion of the receiver detect activity and returns its status via PhyStatus and RxStatus.

The following figure shows how PIPE interface signals behave when the first detection finds no connected receiver. The response time in simulation is fixed for a given reference clock frequency due to the means of modeling the

XCVR. The XCVR model has a fixed reflection time of the common-mode voltage step. In real silicon, the reflection time depends upon the termination network, and this also determines when PIPE PhyStatus pulse occurs.



Figure 1-23. Initial Receiver Detection Response For Receiver-Not-Present

The following figure shows how the soft PIPE interface signals behave when the first detection finds a connected receiver. The difference between receiver presence and absence is the value of RxStatus in simulation, but in real silicon, the delay to the PhyStatus pulse can be different. In real silicon, the Receiver-Not-Present response occurs earlier than a Receiver-Present response.





The following figure shows how PIPE interface responds to a successive receiver detection when the prior detection result is Receiver-Not-Present.





# 1.3.5 PMA Only

This interface uses the transceiver PMA as a conduit to receive and transmit data to or from the fabric boundary. Serial data is deserialized and sent to the receive FWF before the data is sent to the parallel FPGA fabric bus. Similarly, parallel data from the fabric goes through a transmit FWF prior to entering the parallel interface of the serializer.

The following features are supported in the PMA only mode:

- Flexible PMA interface width options of [8, 10, 16, 20, 32, 40] bits.
- Flexible fabric interface width options of [8, 10, 16, 20, 32, 40, 64, 80] bits per clock beat.
- Fabric control of CDR bit-slip for optional symbol alignment purposes.
- Fabric control of transmitter electrical-idle.
- · Fabric control override of CDR lock behavior enabling Burst Mode Receiver support.
- Fabric side interface for transmitter operates at half the frequency of the transmit PMA interface.
- Fabric side interface for receiver operates at half the frequency of the receiver PMA interface.

The PMA interface bypasses any PCS encoding and decoding logic and is used with customized PCS functionality implemented in the FPGA fabric. The fabric-hosted soft-IP can be customer supplied or soft-IP provided through 3rd-party of Microsemi direct cores. The transceiver PMA mode is useful in supporting protocols such as SDI-HD. The PMA Only mode is also used for 1GbE interfaces. The CoreTSE suite of 1GbE IPs contain a soft 8b10b encoder/decoder, which allows the use of either the transceiver or the I/O CDR to implement this standard.

#### Figure 1-26. PMA-Bus Waveform

| LANE#_TX_CLK  |   |         |   | <b></b> |                  |        |
|---------------|---|---------|---|---------|------------------|--------|
| LANE#_TX_DATA | X | TX Data | X |         |                  |        |
| LANE#_TXD_PIN |   |         |   |         | b0 \_b1 \_b2 \ ( | b38b39 |



Figure 1-27. PMA Only Data Path – 80-bits



Figure 1-28. PMA Only Data Path – Less Than or Equal to 40-bits

The following table lists the port names and description for the PMA mode module.

| Table | 1-12. | PMA | Port | List |
|-------|-------|-----|------|------|
|       |       |     |      |      |

| Port Name                                     | Direction | Clock        | Description                                                                                                                                                                                                                                                                                                                          |
|-----------------------------------------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LANE#_CDR_REF_CLK_#/<br>LANE#_CDR_REF_CLK_FAB | Input     | _            | Reference clock to lane CDR. Can be sourced from either FPGA clock or from a XCVR_#[A,B,C]REFCLK_P/N pin.                                                                                                                                                                                                                            |
| LANE#_CLK_REF                                 | Input     | —            | This port is exposed to user with Half-Duplex option. LANE#_REF_CLK must be connected by the user to a stable clock with same clock frequency as Recovered clock such as the local clock.                                                                                                                                            |
| LANE#_TX_BIT_CLK_[1:0] <sup>2</sup>           | Input     | _            | $eq:clock-from-BIT_CLK-of-the-XCVR-TxPLL. Included in CLKS\_FROM\_TXPLL\_\# BIF (bus interface).$                                                                                                                                                                                                                                    |
| LANE#_TX_PLL_REF_CLK_#                        | Input     | -            | Input clock from TX_PLL REF_CLK_TO_LANE output pin. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                                               |
| LANE#_TX_PLL_LOCK_#                           | Input     | —            | Input lock status from TX_PLL LOCK output pin. Included in CLKS_FROM_TXPLL_# BIF (bus interface).                                                                                                                                                                                                                                    |
| LANE#_TX_DATA[N:0] <sup>1</sup>               | Input     | TX_CLK_[R:G] | Transmits data. The PF_XCVR send/receive order is low to high byte. The first serial bit appears in bus bit0. Switching transmission order in PMA mode is accomplished by reversing the bus connections in the fabric.                                                                                                               |
| LANE#_TX_ELEC_IDLE                            | Input     | Asynchronous | Transceiver configurator allows pin to be exposed on component. This input forces XCVR_P/N transmit output pad pair to a common-mode voltage. This can be used for low-frequency out-of-band signaling, or to signal entry into a low-power state to the link partner.                                                               |
| LANE#_TX_BYPASS_DATA                          | Input     | Asynchronous | Transceiver configurator allows pin to be exposed on component.<br>When LANE#_TX_BYPASS_DATA=1, the data can be driven into the transmit pads instead of the<br>normal serializer data. The bypass is asynchronous and this signal does not transit through the<br>FWF. This pin must be tied low if exposed to fabric and not used. |

| continued                          |           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------------|-----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port Name                          | Direction | Clock        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| LANE#_RX_SLIP                      | Input     | RX_CLK_[R:G] | LANE#_RX_SLIP assertion resets the Rx_FWF causing LANE#_RX_VAL to momentarily deassert(=0). Rising-edge requests that the transceiver lane CDR slip the parallel boundary by one bit. The direction of slip is different for 8b parallel word modes than it is for 10b parallel word modes. See 1.1.1.7 Bit Slip.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| LANE#_PCS_ARST_N <sup>2</sup>      | Input     | _            | Asynchronous active-low reset for the PCS lane.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| LANE#_PMA_ARST_N <sup>2</sup>      | Input     | _            | Asynchronous active-low reset for the PMA lane.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| LANE#_RXD_N <sup>2</sup>           | Input     | _            | Transceiver receiver differential input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| LANE#_RXD_P <sup>2</sup>           | Input     | _            | Transceiver receiver differential input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| LANE#_RX_DATA[N:0] <sup>1</sup>    | Output    | RX_CLK_[R:G] | Receives data. The PF_XCVR send/receive order is low to high byte. The first serial bit appears in bus bit0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| LANE#_TX_CLK_STABLE <sup>2</sup>   | Output    | _            | Transmits transceiver/PCS lane ready flag. This flag is 1 when the transmit PLL is locked to the reference clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| LANE#_RX_VAL <sup>2</sup>          | Output    | _            | LANE#_RX_VAL indicates that the XCVR data path is initialized. The parallel bus<br>of LANE#_RX_DATA[N:0] contains actual data recovered from the serial stream when<br>LANE#_RX_VAL = 1.<br>LANE#_RX_VAL is qualified when the XCVR receiver calibration completes, included with the<br>enhanced receiver management completion, and the CDR locks.<br>LANE#_RX_VAL pulsing low while RX_READY = 1 does not indicate that the clocking is unstable.<br>It means that the LANE#_RX_DATA output is all-zeros temporarily because the Rx datapath is<br>in reset. If that condition does not need to be detected for a specific application, then LANE#_<br>RX_VAL can be ignored.<br>Lane#_RX_VAL = 1, indicates the PCS is out of reset, which implies LANE#_RX_READY = 1<br>because PCS Rx is normally being held in reset while LANE#_RX_READY = 0 |
| LANE#_RX_READY <sup>2</sup>        | Output    | _            | Lane#_RX_READY = 1 means the Rx PLL is locked. LANE#_RX_READY rises when the enhanced receiver management and CDR completes a fine lock detection to the incoming data transitions and the de-serializer is powered-up. If there is no incoming data to the CDR then the RX_READY is low. The primary purpose of this pin is communicating to fabric that the CDR is locked to serial input data and is producing valid clocking.<br>Note: In a loopback case while looping the local transmitter output to the receiver input, it is necessary to take the Tx out of reset to ensure valid serial transitions, allowing the Rx CDR to lock. The system deadlocks, if the user waits till Rx CDR locks before the Tx is released from reset.                                                                                                         |
| LANE#_RX_IDLE <sup>2</sup>         | Output    | —            | Receives electrical-idle detection flag. LANE#_Rx_IDLE peak detector logic is only valid for a limited minimum density of transitions on the Rx data and not to be used in applications above 5Gbps. Enhanced Receiver Management can provide a reliable mechanism for higher data rates.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| LANE#_RX_CLK_[R:G] <sup>2</sup>    | Output    | _            | Global or regional receive clock to fabric.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| LANE#_TX_CLK_[R:G] <sup>2, 3</sup> | Output    | —            | Global or regional transmit clock to fabric.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| LANE#_TXD_N <sup>2</sup>           | Output    | _            | Transceiver transmitter differential output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| LANE#_TXD_P <sup>2</sup>           | Output    | —            | Transceiver transmitter differential output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

<sup>(1)</sup> N can be 7, 9, 15,19, 31, 39, 63, and 79.

(2) LANE# can be 0, 1, 2, and 3.

**Note:** [R:G] naming is generated based on the use of regional or global resources that are selected with Libero.

(3) In PolarFire FPGA MPF500 devices and PolarFire SoC FPGA devices, the TX\_CLK\_R and RX\_CLK\_R pins of XCVR lanes placed in the PCIESS(Q0) and GPSS1(Q1) quads cannot drive I/Os.

# 1.4 PCS/FPGA Fabric Interface

The FPGA fabric-transceiver interface includes both clock and data signals. This interface provides clock interconnects using the global or regional clock networks in the FPGA fabric. Based on the transceiver lane configuration, the receive parallel output clock is recovered from either the receive serial data or the rate matched clock generated by the embedded clock domain crossing logic. Transmit output is always from the TxPLL. The PCS/FPGA fabric can gear the fabric interface by an additional 1:2 ratio provided by the PCS dividers (see

1.1.2.2 Transmit PCS Divider). The modes where this can occur are 8b10b using 8-octet interfacing, 64b6xb using 8-byte interfacing, PMA mode 64-bit, and 80-bit interfacing.

Local clock outputs of the PF\_XCVR are programmed to track with the additional gearing done in the PCS. If the fabric interface width is geared by the PCS and global clocks are the source of the interface timing, then the global clock output must be divide-by-two.

There are four clocking resources from PCS to the fabric-Global, Regional, Regional (Deterministic), and Global-Shared.

- **Global**: These clocks have a dedicated interconnection specifically designed to reach throughout the device from the transceiver fabric interface onto dedicated FPGA fabric global clock network. Global clocks are designed to have low skew and low duty cycle distortion, low power, and improved jitter tolerance and support for very high-frequency signals.
- **Global-Shared**: These clocks are similar to Globals but have resources to allow sharing between the TxPLLs. The sharing of lane clocking resources results in equal latency in the transmitter phase compensation FIFO of all shared lanes.

**Note:** Global-Shared mode allows the global clock output from one lane to be used for other lanes. This clocking mode is used when several lanes are part of the same protocol using the same clock.

When Global-Shared mode is enabled, all the lanes include a global clock output port, but only one lane can be used as the master port. All the lanes include a TX\_WCLK input port. This port must be connected to the global clock output of the master lane. The fly-wheel FIFO absorbs the phase difference between the lanes and the master lane's global clock. See the following SmartDesign figure for an example.





- **Regional**: These clocks use local resources to interconnect with the FPGA fabric with a FIFO in the data path at the fabric boundary.
- **Regional (Deterministic)**: These clocks use local resources to interconnect with the FPGA fabric with zerocycle data path at the fabric boundary providing low-latency. Microchip IP and solutions use these resources to optimize the FPGA architecture to provide robust use cases. See Table 1-16.

# 1.4.1 Non-Deterministic Interface

The transceiver PMA to FPGA fabric/PCS data path includes a fly-wheel FIFO (FWF) interface, which is used to transfer data between clock domains. This interface is included within the protocol-specific PCS HDL modules or user FPGA fabric logic.

FWF is a simple form of FIFO where its write and read clocks are known to be at the same nominal frequency, with some allowed phase difference and jitter that is compensated within the block.

The interface between the PMA and fabric cannot be throttled. However, the addition of the FWF block in the data path handles the phase crossing of every PMA lane, ensuring that timing is met across this interface. The received data, along with the recovered parallel clock, is passed to the FWF, which synchronizes the data and clock for either regional or global clock routing.

In the transmit direction, data from the fabric or PCS is passed through the FWF with a clock from the FWF ensuring synchronous clock and data relationships passing to the PMA interface. The FWF is optionally selected in the Libero Transceiver Configurator by choosing the correct global or regional interface clock option, see Table 2-8.

#### Figure 1-30. Non-Deterministic Interface With FWF



----- This connection only visible within the Libero generated component.

The FWF provides clock domain crossing functionality to manage clock and data setup and hold. The following figures show the timing relationships of transmit and receive data paths at the fabric interface.

#### Figure 1-31. Non-Deterministic Interface Transmit Timing Waveform







# 1.4.2 Deterministic Interface

Low-latency regional clocks with a specific mode of the FWF are used when a zero-cycle path is required. For example, by protocols such as CPRI and JESD204B that require both receive and transmit paths have a fixed deterministic latency as expressed in number of clock cycles. In this case, data is interfaced directly to capture registers while the clock is routed on regional clock resources. The regional clock does not have the large clock insertion delay as the global clock network. A regional clock can easily achieve timing closure to the fabric with this small amount of clock delay. Deterministic timing is optionally selected in the Libero Transceiver configurator by choosing the deterministic regional options, see Table 2-8.





Figure 1-34. Deterministic Transceiver Transmit Timing Waveform



Note: TXCLK\_FABRIC at PCS I/F after Regional clock route.

#### Figure 1-35. Deterministic Transceiver Receive Timing Waveform



Note: RXCLK\_FABRIC at PCS I/F after Regional clock route.

#### 1.4.3 Transceiver Clock Regions

Two regional clock buffers per transceiver lane (eight per transceiver quad) come from the transceiver. These interconnections are the basis for specific regions that the particular quads can drive. These regions vary from device to device within the family. These regions have a predetermined connectivity to fabric resources, CCC, and I/Os.



Figure 1-36. PolarFire FPGA Transceiver Clock Regions

MPF500T







Users need to understand the regional clock implications when targeting designs that may migrate to different device sizes. The user must also use this in pin planning of boards when desiring to drive I/O from the transceiver clocks.

Table 1-13. PolarFire FPGA Clock Region Connectivity

| Device  | Region   | FPGA | FPGA Fabric Resource Count |       |      |      |      |                                |  |
|---------|----------|------|----------------------------|-------|------|------|------|--------------------------------|--|
|         |          | ю    | 4LUT                       | DFF   | MATH | SRAM | URAM | CCC (PLL/DLL) (CCC_NE, CCC_SE) |  |
| MPF100T | One Only | 120  | 49260                      | 49260 | 152  | 160  | 456  | 4(PLL/DLL) (CCC_NE, CCC_SE)    |  |
| MPF200T | Тор      | 60   | 49980                      | 49980 | 152  | 160  | 456  | 2- CCC (PLL/DLL) (CCC_SE)      |  |
|         | Bottom   | 60   | 37296                      | 37296 | 114  | 120  | 342  | 2- CCC (PLL/DLL) (CCC_SE)      |  |
| MPF300T | Тор      | 96   | 80652                      | 80652 | 248  | 256  | 744  | 2- CCC (PLL/DLL) (CCC_NE)      |  |
|         | Bottom   | 96   | 60192                      | 60192 | 186  | 192  | 558  | 2- CCC (PLL/DLL) (CCC_SE)      |  |

| continued |        |        |                           |        |     |     |     |                           |  |
|-----------|--------|--------|---------------------------|--------|-----|-----|-----|---------------------------|--|
| Device    | Region | FPGA I | PGA Fabric Resource Count |        |     |     |     |                           |  |
| MPF500T   | Тор    | 120    | 75468                     | 75468  | 234 | 240 | 702 | 2- CCC (PLL/DLL) (CCC_NE) |  |
|           | Middle | 0      | 102516                    | 102516 | 312 | 320 | 936 | 0                         |  |
|           | Bottom | 120    | 75468                     | 75468  | 234 | 240 | 702 | 2- CCC (PLL/DLL) (CCC_SE) |  |

Table 1-14. PolarFire SoC FPGA Clock Region Connectivity

| Device   | Region | FPO | FPGA Fabric Resource Count |       |      |      |      |                                |  |
|----------|--------|-----|----------------------------|-------|------|------|------|--------------------------------|--|
|          |        | 10  | 4LUT                       | DFF   | MATH | SRAM | URAM | CCC (PLL/DLL) (CCC_NE, CCC_SE) |  |
| MPFS250T | Тор    | 96  | 80652                      | 80652 | 248  | 256  | 744  | 2- CCC (PLL/DLL) (CCC_NE)      |  |
|          | Bottom | 96  | 60192                      | 60192 | 186  | 192  | 558  | 2- CCC (PLL/DLL) (CCC_SE)      |  |

See PolarFire FPGA and PolarFire SoC FPGA Clocking Resources User Guide for more information about regional clock resource regions.

# 1.4.4 Transceiver Data Path Latency

Transceiver data path latency is defined, when the earliest serial bit appears in bus bit 0 for both transmit and receive interfaces of PMA mode. The PMA mode data path can be setup for different transmit and receive widths as needed. Clock phase latency is not considered.

| PCS Mode | PCS Fabric Width | PMA PCS Width | Transmit Latency (UI) | Receive Latency (UI) | Total Latency (UI) |
|----------|------------------|---------------|-----------------------|----------------------|--------------------|
| PMA      | 8                | 8             | 82                    | 58.5                 | 140.5              |
| PMA      | 10               | 10            | 100                   | 73.4                 | 173.4              |
| РМА      | 16               | 16            | 148                   | 122.4                | 270.4              |
| РМА      | 20               | 20            | 184                   | 153.6                | 337.6              |
| PMA      | 32               | 32            | 292                   | 250.5                | 542.5              |
| РМА      | 40               | 40            | 364                   | 313.5                | 677.5              |
| PMA      | 64               | 32            | 452                   | 410.5                | 862.5              |
| РМА      | 80               | 40            | 564                   | 513.5                | 1077.5             |
| 8b10b    | 40               | 40            | 404                   | 314                  | 718                |
| 8b10b    | 80               | 40            | 564                   | 513.5                | 1077.5             |

Table 1-15. Transceiver Data Path Latency

Note: 8b10b mode uses 20, 40, and 80 PmaPcsWidth. PIPE modes uses 40 PmaPcsWidth.

# 1.4.5 Transceiver Clocking Use Cases

Each transceiver quad can source a global clock directly. Transceiver designs should use regional clocks for the interface logic when possible. This reduces over use of global clocks. In many cases, transceiver designs can share global clocks when multiple interfaces are used, depending on protocol requirements. Only one global clock is supported per transceiver quad. See respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet for AC performance information. For information about connectivity of the transceivers to the global clock network, see PolarFire FPGA and PolarFire SoC FPGA Clocking Resources User Guide.

The following table lists the transceiver interface clocking use cases in the Libero SoC software, which uses presets per protocol. See 1.4 PCS/FPGA Fabric Interface for explanation of system clock source modes.

| Preset                | Width              | Rx                             | Tx_                       | System Clock Source <sup>1</sup>                       |
|-----------------------|--------------------|--------------------------------|---------------------------|--------------------------------------------------------|
| 10GBASE-R             | x1                 | Regional                       | Global                    | Global from XCVR Tx                                    |
| 10GBASE-R             | Multiple           | Regional                       | Global shared             | Global from XCVR Tx shared                             |
| 10GBASE-KR            | x1 and<br>Multiple | Regional                       | Regional                  |                                                        |
| SGMII/1000BASE        | x1                 | Regional                       | Regional                  | Global from XCVR Tx                                    |
| SGMII/1000BASE        | Multiple           | Regional                       | Global shared             | Global from XCVR Tx shared                             |
| JESD204B              | x1                 | Regional                       | Global                    | Global from XCVR Tx shared                             |
| JESD204B              | xN                 | Regional                       | Global shared             | Global from XCVR Tx shared                             |
| CPRI                  | x1                 | Regional                       | Regional                  | Global                                                 |
| CPRI                  | xN                 | Regional                       | Regional                  | Global shared                                          |
| Interlaken            | хN                 | Regional ≥ Global <sup>2</sup> | Global shared             | Global from XCVR Tx shared                             |
| XAUI                  | x4                 | Regional                       | Global shared             | Global from XCVR Tx shared                             |
| RXAUI                 | x2                 | Regional                       | Global shared             | Global from XCVR Tx shared                             |
| SDI <sup>3</sup>      | x1                 | Global                         | Global                    | Global                                                 |
| SDI <sup>3</sup>      | Multiple           | Global                         | Global shared             | Global                                                 |
| LiteFast <sup>3</sup> | x1                 | Global                         | Global                    | Global from XCVR Tx and Rx                             |
| LiteFast <sup>3</sup> | хN                 | Regional ≥ Global <sup>2</sup> | Global shared             | Global from XCVR Tx (shared) and Rx                    |
| LiteFast <sup>3</sup> | x1 and<br>Multiple | Global                         | Global shared             | Global from XCVR Tx (shared)<br>and Rx (per interface) |
| QSGMII                | x1                 | Regional                       | Regional                  | Global 125 MHz                                         |
| QSGMII                | Multiple           | Regional                       | Global shared             | Global 125 MHz Shared                                  |
| SATA <sup>3</sup>     | x1                 | Global Tx                      | Global Tx                 | Global Tx                                              |
| SATA <sup>3</sup>     | Multiple           | Global Tx                      | Global Tx                 | Global Tx (not shared)                                 |
| SRIO                  | x1                 | Regional                       | Global                    | Global                                                 |
| SRIO                  | xN                 | Regional                       | Global shared             | Global                                                 |
| SRIO                  | Multiple           | Regional                       | Global (per<br>interface) | Global                                                 |
| Fiber Channel         | x1                 | Regional                       | Global Tx                 | Global Tx                                              |
| Fiber Channel         | Multiple           | Regional                       | Global Tx shared          | Global Tx Shared                                       |

Table 1-16. Transceiver Interface Clocking Use Cases

<sup>(1)</sup> Shared implies that multiple lanes use common clock resources.

<sup>(2)</sup> Uses regional clock and moves to global clock resources in the FPGA fabric.

<sup>(3)</sup> Typically, these interfaces are implemented uni-directional. For full duplex, the RX interface and TX interface clock can not be global or global (Shared) at the same time as only one global clock is supported per transceiver quad. If using the RX and TX both as global is required by design, the design must use two separate XCVR configurations (instances), one in RX half duplex mode and other in TX half duplex mode.

# 1.5 Transceiver Clocking

Clocking of transceivers use several dedicated resources that are embedded in each device. All XCVR designs require a XCVR\_REF\_CLK to provide and clock input to a XCVR\_TXPLL, which provides the necessary clocks for the XCVR\_LANE or XCVR\_LANES. The XCVR\_TXPLL synthesizes the input reference clock to generate the high-speed serial clock used in the transmitter PMA. XCVR\_REF\_CLKs and XCVR\_TXPLLs are shared and used for several high-speed serial protocols.

# 1.5.1 Transmit PLL

Two variations of the transmit PLLs embedded within the transceiver lanes are available based on protocol requirements. Both TxPLLs use ring VCO-based PLLs. Using a combination of TxPLL ranges and post-dividers produce frequencies across the entire supported range of the device. The transmit PLLs include one type with spread-spectrum (SSCG) generation modulation capabilities (TXPLL\_SSC) and another type without SSCG capabilities (TxPLL). Both types of transmit PLLs use the same half-rate, fractional-N type (Frac-N) architecture design, thereby relaxing the speed requirements of the phase detector and frequency dividers. This consequently expands the VCO tuning range and enhances the phase noise performance while having a significant impact on the total power. The transmit PLL phase detector provides a valid output while driving a full-rate random data stream on both edges using the half-rate clock. All transmit PLLs support a jitter-attenuator option. The jitter attenuator is used to track the data rate of any noisy reference clock with a clean input reference clock to provide a 0 ppm offset from the noisy reference clock while providing a jitter-cleaned output.

Each transceiver lane can select a transmit clock from the transmit PLLs that are close enough to drive their half rate clock (Figure 1-38). The PLL uses the input reference clock to generate a serial bit clock (at half the rate). The transmit PLL detects and signals a loss of lock in the event that the reference clock stops toggling or when the reference clock transitions to an incorrect frequency.

There are also instances that include additional transmit PLLs, which can be used by the local transceiver quad and in a subset of lanes of adjacent quads.

The output frequency of each transmit PLL is derived automatically from the reference clock frequency and the settings for the PLL multipliers. Each transmit lane can then divide this base transmit PLL rate per lane using the post-divider by 1, 2, 4, 8, or 11. The resulting frequency is half the bit rate based on the transmit half-rate architecture. For example, a 2.5 GHz clock is used for a 5 Gbps transmit transceiver line rate. The programmable multipliers are defined and programmed by the Libero transceiver interface configurator as per the desired protocol.

In addition, the transmit PLL can also provide the system clock for the FPGA logic.

#### Figure 1-38. Transmit PLL



Two different types of transmit PLLs can be used with the transceiver based on half-rate architecture. Both PLL types have identical analog portions with only digital logic differences, therefore each PLL type has identical performance.

**Q#\_TXPLL\_SSC**: This PLL operates in the 1.6 GHz – 6.4 GHz frequency range and can provide a transmit bit clock to a transceiver quad. The TxPLL\_SSC supports jitter attenuation for loop-time applications. Unique to this PLL is the spread-spectrum clocking (SSC) generation support, which can generate a saw-tooth clock with various options.

For each quad, there is one TxPLL\_SSC that can only be used by lanes within that quad.

**Q#\_TXPLLn**: There are two of these PLLs within the transceiver quad location, TxPLL0 and TxPLL1. This type of PLL also supports the full 1.6 GHz – 6.4 GHz frequency range and can drive the transmit bit clock pair of adjacent transmit lanes both above and below the PLL. This PLL also supports jitter attenuation, but does not provide SSC

support. There are also transmit PLLs, which can be used by the local transceiver quad and in a subset of lanes of adjacent quads. See Figure 1-52 and Figure 1-54 for more information about PolarFire FPGA TxPLL sharing. See Figure 1-55 for more information about PolarFire SoC FPGA TxPLL sharing.

**Note:** Both types of TxPLLs accept spread-spectrum input.

The jitter attenuation feature uses digital filtering within the transmit PLL to remove the unwanted noise of a reference clock across a wide frequency band. The low-jitter output is sent to an oscillator that is numerically controlled to adjust the phase and frequency relationships to achieve a 0 ppm offset from the original noisy reference clock.

#### Table 1-17. Transmit PLL

| PLL Type                                         | Rate                 | Details                                                                                                                                                                                                             |
|--------------------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Q#_TXPLL_SSC <sup>1</sup>                        | 1.6 GHz – 6.4<br>GHz | PLL is used within the quad only. This PLL supports jitter attenuation and SSC.                                                                                                                                     |
| Q#_TXPLL0 <sup>1</sup><br>Q#_TXPLL1 <sup>1</sup> | 1.6 GHz – 6.4<br>GHz | PLL can be used by a pair of adjacent transmit lanes within each of the immediately adjacent transceiver quads (a total of four lanes). This PLL does not have SSC capability, but does support jitter attenuation. |

<sup>(1)</sup> Q# = Transceiver quad identifier (Q0, Q1, and so on.)

# 1.5.2 Spread Spectrum Clocking

TxPLL produces spread spectrum clock generation (SSCG). SSCG uses a modulated output clock signal to reduce peak EMI. The lowering of peak EMI enables significant reduction in expensive shielding cost or reduce interference with other sensitive circuits. By modulating the PLL, the resulting spectrum at each clock harmonic is made broadband or flattened, and reduced in amplitude from 10 db to 20 dB, depending on frequency and modulation amplitude.

TxPLL is configured in Fractional-N mode to preserve the accuracy of modulation to the targeted modulation frequency. The SSCG works by modulating the feedback divider value (Divval) of the TxPLL, thus modulating the PLLs output frequency and introducing a noise source or wave table.

Setting the modulation mode (Center versus Down) and modulation amplitude depend on the amount of EMI reduction desired and the timing margin for circuits running on the spread clock domain.

SSCG is optionally implemented using the Libero TxPLL configurator by setting the modulation frequency, modulator spread mode (Center and Down spread), Spread/Divval, and Wave table. See 2.1 Libero Configurators.

The following figure shows the frequency versus time and the resulting amplitude in the frequency domain.

#### Figure 1-39. Spread Spectrum Clocking Modulation Mode



# 1.5.3 Transmit Lane Alignment

Applications like Serial RapidIO, XAUI, DisplayPort, Interlaken, and JESD204B need transmit alignment across multiple lanes. Transmit lane alignment depends on the number of lanes, total skew, fabric clock frequency relative

to the line rate, and number of TX PLLs. The method of alignment involves launching a reset from the shared PLL to each TX lane after the PLLs are locked.

The transceiver PMA block supports transmit lane alignment for upto four lanes using the following quad-based reset methods:

- Q#\_TxPLL\_SSC PLLs and its four lanes (quad) as shown in Figure 1-40.
- Q#\_TxPLL[1:0] and two lanes each from the adjacent quads as shown Figure 1-41.

The transmit clock for each transceiver lane can be driven by an external or a quad PLL. The reset for the TX lanes is based on the PLL selected. This reset is connected within the transceiver block to travel with the transmit clock. All of the TX lanes for a given TX clock are reset by asserting the internally connected signal TX PLL CLKRESET. To ensure a proper reset, stop the TX clocks for four clock cycles. With this quad-based reset method, very low skew is achieved. In this scenario, all lanes are within the same QUAD using the same TXPLL. The TXPLL initially align the lanes internally with PLL lock. This occurs prior to the assertion of the PLL\_LOCK output pin of the TXPLL. Any subsequent LANE#\_PMA\_ARSTN assertions will reset the post-dividers for the lane, which can cause a misalignment after the initial alignment that was completed by the CLK\_RESET from the TXPLL.

The reinitialization of this lock and alignment mechanism can also be initiated via DRI register control, depending on TXPLL type. Register toggling (1=>0=>1) after initial power-up of PMA\_CMN/TXPLL\_CTRL/TXPLL\_CLKRESETEN or EXTPLL/EXTPLL\_CTRL/EXTPLL\_CLKRESETEN is required. This action disrupts the TxPLL and re-align the Tx lanes.



Figure 1-40. Using TXPLL\_SSC For Upto Four Lanes





In the following scenarios, the quad based reset of TX lanes cannot be used:

- When one transmit clock is used for multiple lanes that do not belong to the same quad. In this scenario, per lane reset of TX lanes must be used because the reset operation on one lane does not affect the other lanes.
- When an arbitrary number of lanes more than four (5 to 8) need the transmit alignment.

In these scenarios, the transceiver uses two PLLs with the same reference clock and a separate fabric logic for reset of the TX lanes as shown in the following figure.



# Figure 1-42. FPGA Logic For TX Alignment (5 to 8 Lanes)

The fabric reset logic per lane is provided by asserting the LANE#\_PMA\_ARST\_N signal (where # represents the lane to be reset). The RESETSEREN# register must be set to reset each lane. To achieve proper skew alignment, the rising and falling edges of the RESETSER# signal must arrive at the transceiver PMA lane pins within two high-speed bit clocks. This can be implemented by a known low-skew internal clock signal using the global or local FPGA routing clocks to Flip-Flop inside the PCS. Any arbitrary low-skew clock can be used as a reference clock to the transceiver Tx PLLs. The Tx\_Align pulse needs to be asserted for 16 clock cycles after the PLLs are locked and transmit lanes are programmed with the same post-PLL divide factors. If this requirement is met, all of the TX lanes used for the given transceiver port are aligned within 2-bit clock user interfaces.

# 1.5.4 Transceiver Clocks

The transceiver transmitters have high-performance bit clocks running at half the line rate of the fastest transmit lane driven by the clock. The transmit PLLs generate these clocks based on a transmit reference clock, with the configuration set in the Libero design software.

Within each lane, the transmit bit-rate clock (Figure 1-5) is divided by 1 (full rate), 2, 4, 8, or 11 to set the transmit rate of a given lane. The resulting clock is further divided by 8, 10, 16, 20, 32, 40, 64, and 80 to generate a parallel transmit word clock to the fabric.

The transceiver receivers have their own per-lane receive PLL built into the CDR to generate a per-lane receive clock supporting asynchronous data in that lane. Generally, the CDR is used in lock-to-data mode. The receive CDR PLL initially spins up to approximate the correct frequency to lock to the incoming data by first locking to an input receive reference clock that is near the incoming data rate. Once that is achieved, it then switches to clock recovery mode where it locks to the incoming data and then extracts the clock from the incoming data (which is also a half-rate bit clock running at half the speed of the received data rate). Lock-to-reference is also available

for customized protocols. The CDR PLL locks to the local input reference clock and spins to the desired frequency without performing phase compensation or clock recovery functions. These applications pass the data directly to fabric where it can be used for custom over-sampling and synchronizing processing.

The per-lane CDR extracts a clock from the incoming data stream and then generates a receive parallel word clock that is divided by 8, 10, 16, 20, 32, 40, 64, or 80 from the bit rate of the given lane.

# 1.5.4.1 Transceiver Reference Clock Interface

The reference clock interface block to the transceiver provides multiple options for supplying the reference clock input to the transceiver transmit and receive PLLs (Figure 1-43). Various sources can provide the reference clock interface via REFCLK0 and REFCLK1 ports.

- **Differential dedicated input pad**: allows a direct clock input of a low-jitter reference clock via a LVDS/HCSL input pins REFCLK\_P/N.
- **Single-ended dedicated input pad(s)**: allows the selection from two different single-ended clock inputs, enabling the transmit PLL to select from two different clock sources. Separate single-ended clock inputs allow unrelated transmit and receive clock sources to be sourced to the transceiver.

**Note:** Two separate single-ended inputs allow one for the transmit reference clock and a second for the receive reference clock.

- **Cascade of a reference clock**: the clock received on the external pins of a quad can be driven to the quad below. The reference clock interface provides cascading of an input reference clock path from the REFCLK pins of one transceiver quad to the TxPLLs and receiver CDRs of other transceivers. In designs that have lanes spanning different transceiver quads, the cascading clocks eliminate the need to connect the on-board reference clock sources to the REFCLK pin of each transceiver quad. The reference clock interface also drives a clock signal on the REFCLK pins to the clock logic in the FPGA fabric.
- **Recovered clock**: allows for the reference clock to be sourced by the recovered clock from local quad (via JA\_REF\_CLK). Within a Quad, the recovered clock used as JA\_REF\_CLK has dedicated connections between the lanes without any additional jitter.

For inter-quad or using the recovered clock from one Quad to the JA\_REF\_CLK of another Quad, this has added jitter from using routing of the FPGA fabric. Since this clock is from the noisy digital VDD/VSS domain on the device, the reference clock jitter is higher than the dedicated inputs. Generally used with the jitter attenuation feature.

**Note:** The reference clock driving the transmit PLL REF\_CLK also serves each lane for the receive CDR. Since each receive lane has an independent PLL, it is possible to use an independent reference clock per receive lane. PLL for the CDR is per transceiver PMA lane.

The PF\_XCVR\_REF\_CLK does allow the FAB\_REF\_CLK output pin to drive a fabric global resource. This connection is limited to one per quad and if used, it prevents using the global of a XCVR lane in the same quad. However, you can connect XCVR\_FAB\_REF\_CLK output pin to PLL and one lane to global at the same time. For information about implementation of this connection, see 2.1.1 Transceiver Reference Clock Configurator.



#### Figure 1-43. Reference Clock (REFCLK) Interface to Transmit PLL

The following table lists the transmit PLL pins.

| Table 1-18. Transmit PLL Pin Lis | st <sup>1</sup> |
|----------------------------------|-----------------|
|----------------------------------|-----------------|

| Name                         | Direction                                                                                                                                               | Description                                                                                                                                                                                                                            |  |  |  |  |  |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| REF_CLK                      | Input                                                                                                                                                   | Transmit PLL input clock from reference clock interface (Figure 1-43).                                                                                                                                                                 |  |  |  |  |  |
| PLL_LOCK                     | Output                                                                                                                                                  | PLL_LOCK is the PLL lock indicator signal that can be used to drive logic in the fabric. It is a fabric routed signal. (High = LOCK).                                                                                                  |  |  |  |  |  |
| CLKS_TO_XCVR                 | Output                                                                                                                                                  | CLKS_TO_XCVR is a bus interface port (BIF) with three outputs that are required to be interconnected between the TXPLL and the XCVR components. The BIF includes BIT_CLK, LOCK, and REF_CLK_TO_LANE outputs.                           |  |  |  |  |  |
| BIT_CLK <sup>2</sup>         | Output                                                                                                                                                  | High-speed clock to lane.                                                                                                                                                                                                              |  |  |  |  |  |
| LOCK <sup>2</sup>            | Output                                                                                                                                                  | Connected to the TX_PLL_LOCK_0/1 input port, which is a part of the CLKS_FROM_TXPLL_0/1 BIF on the XCVR block. It is a hardwired connection.                                                                                           |  |  |  |  |  |
| REF_CLK_TO_LANE <sup>2</sup> | Output                                                                                                                                                  | Connected to the TX_PLL_REF_CLK_0/1 input port, which is a part of the CLKS_FROM_TXPLL_0/1 BIF on the XCVR block. It is a hardwired connection. TXPLL reference clock that is passed to the XCVR lane clock (used for simulation only) |  |  |  |  |  |
| CLK_125                      | Output                                                                                                                                                  | Exposed directly on the TXPLL block. Its frequency is fixed at 125 MHz. It is exposed only when the TXPLL BIT_CLK is 2500 Mbps, and must be used for a PCIe use case.                                                                  |  |  |  |  |  |
|                              | <ul> <li>(1) Pin list for both Q#_TxPLL[1:0] and Q#_TxPLL_SSC PLLs.</li> <li>(2) Port is a part of the hus interface port (BIE) CLKS_TO_XCVR</li> </ul> |                                                                                                                                                                                                                                        |  |  |  |  |  |

<sup>(2)</sup> Port is a part of the bus interface port (BIF) CLKS\_TO\_XCVR.

There are some use-cases which can allow a XCVR quad's global output to be used to broadcast the SerDes REFCLK, if that XCVR is configured to use regional clocks for the TX/RX clocks allowing these specific use-cases to broadcast the SerDes REFCLK into the FPGA fabric with a more predictable amount of clock jitter.

# 1.5.4.2 Jitter Attenuator

All transmit PLLs support a jitter-attenuator option. The jitter attenuator is used to track the data rate of any noisy reference clock with a clean input reference clock to provide a 0 ppm offset from the noisy reference clock while providing a jitter-cleaned output. It is used in designs requiring loop-timing where the recovered clock is used as the transmit clock requiring low jitter performance. This is used in applications such as Synchronous Ethernet (SyncE) providing low jitter synchronization to an Ethernet network. The following figure illustrates the application using jitter attenuation.

#### Figure 1-44. Typical Jitter Attenuator Application Scheme



The TXPLL in the transceiver can provide jitter attenuation. Its design attenuates input jitter by using Libero configured settings to adjust the loop bandwidth and damping factors. The TXPLL input from the recovered source of the RX\_CLK is cleaned from jitter components in the JA\_CLK input path of the TXPLL. The TXPLL configurator allows pre-determined configurations of the attenuation feature based on protocol including the following protocols.

- 10G SyncE (32-bit, 64-bit)
- 1G SyncE 10-bit
- CPRI Rate [1-8]
- SDI (3G, HD, SD)

JA\_PLL demonstrates compliance with the 10G SyncE the ITU-T G.8261 and G.8262 standards. A 10G SyncE Characterization Report and Libero Reference Design solution is available.

Select **Jitter Cleaning Mode** under the **Clock Options** and choose the targeted protocol templates from the dropdown as shown in the following figure.

| Figure 1- | -45. Jitter Attenuation                  | TXPLL                                                                                                                                                                                |      |          |     |                   |     |
|-----------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|-----|-------------------|-----|
| Trans     | mit PLL                                  |                                                                                                                                                                                      |      |          |     |                   |     |
|           | ·                                        |                                                                                                                                                                                      |      |          |     |                   |     |
|           | Clock Inputs/Output                      | ts                                                                                                                                                                                   |      |          |     |                   |     |
|           | Reference Clock Source                   | Dedicated 💌                                                                                                                                                                          |      | 200      | MHz |                   |     |
|           | Desired Output Bit Clock                 | 10000.000                                                                                                                                                                            | Mbps | 5000.000 | MHz | Fractional-N used | ,   |
|           | Bandwidth                                | Low                                                                                                                                                                                  |      |          |     |                   |     |
|           |                                          |                                                                                                                                                                                      |      |          |     |                   |     |
|           |                                          | _                                                                                                                                                                                    | _    |          | _   | _                 |     |
|           | Clock Options                            |                                                                                                                                                                                      |      |          |     |                   |     |
|           | C Normal Mode                            |                                                                                                                                                                                      |      |          |     |                   |     |
|           | C SSCG Modulation                        |                                                                                                                                                                                      |      |          |     |                   |     |
|           | <ul> <li>Jitter Cleaning Mode</li> </ul> | 10G SyncE 32Bit                                                                                                                                                                      |      | •        |     |                   |     |
|           | Features                                 | 10G SyncE 32Bit<br>10G SyncE 64Bit<br>1G SyncE 10Bit<br>CPRI Rate 1<br>CPRI Rate 2<br>CPRI Rate 3<br>CPRI Rate 4<br>CPRI Rate 5<br>CPRI Rate 5<br>CPRI Rate 6<br>CPRI Rate 8 - 64Bit |      |          |     |                   | MHz |

Enable Dynamic Reconfiguration Interface (DRI)

Jitter attenuation PLL presets can be selected with TX PLL configurator (and the enable JA\_CLK port in XCVR configurator). Jitter attenuation presets must follow the predefined requirements for the application design.

For example, if **SDI 3G** is selected in the TX PLL configurator, then set the PCS-FABRIC width in XCVR configurator to 20-bit and use the defined reference clock frequency.

| Table 1-19. Jitter | Attenuation | PLL | Presets |
|--------------------|-------------|-----|---------|
|--------------------|-------------|-----|---------|

| Jitter Cleaning Mode Selection | Data Rate (Mbps) | Reference Clock<br>Frequency (MHz) | PCS - Fabric bit Width | Mode   |
|--------------------------------|------------------|------------------------------------|------------------------|--------|
| 10G SyncE 32Bit                | 10312.5          | 156.25                             | 32                     | 64b66b |
| 10G SyncE 64Bit                | 10312.5          | 156.25                             | 64                     | 64b66b |
| 1G SyncE 10Bit                 | 1250             | 125                                | 10                     | РМА    |
| CPRI Rate 1                    | 614.4            | 122.88                             | 32                     | 8b10b  |
| CPRI Rate 2                    | 1228.8           | 122.88                             | 32                     | 8b10b  |
| CPRI Rate 3                    | 2457.6           | 122.88                             | 32                     | 8b10b  |
| CPRI Rate 4                    | 3072             | 122.88                             | 32                     | 8b10b  |
| CPRI Rate 5                    | 4915.2           | 122.88                             | 32                     | 8b10b  |
| CPRI Rate 6                    | 6144             | 122.88                             | 32                     | 8b10b  |
| CPRI Rate 8 64-Bit             | 10137.6          | 122.88                             | 64                     | 64b66b |
| SDI 3G                         | 2970             | 148.5                              | 20                     | РМА    |
| SDI HD                         | 1485             | 148.5                              | 10                     | РМА    |

| continued                      |                            |                                    |                        |      |  |
|--------------------------------|----------------------------|------------------------------------|------------------------|------|--|
| Jitter Cleaning Mode Selection | Data Rate (Mbps)           | Reference Clock<br>Frequency (MHz) | PCS - Fabric bit Width | Mode |  |
| SDI SD                         | 270                        | 148.5                              | 10                     | РМА  |  |
| Custom Protocol Settings       | See the following details. |                                    |                        |      |  |

#### 1.5.4.2.1 Custom Protocol Settings

Full duplex jitter attenuation solution is available for custom protocols in Libero SoC v12.3 or later. This support is for one refclk and one data rate allowing user the flexibility to create designs requiring customized settings not already supported by the presets.

The user must enter the reference clock frequency and clock source information for the correct generation of the jitter cleaning configuration. The reference clock source selection determines the input clock ports exposed on the component (See Figure 1-47). Users are required to connect the ports in the top-level to the correct XCVR lane. The use of the JAPLL with custom settings require the user to use the JA clock frequency for the associated lane as it appears in the RX JA clock frequency dialogue box of the XCVR configurator (See Figure 1-48).

#### Figure 1-46. JAPLL Custom Protocol Settings

| <ul> <li>Normal Mode</li> <li>SSCG Modulation</li> </ul>                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Itter Cleaning Mode</li> <li>10G SyncE 32Bit</li> <li>CPRI Rate 2</li> <li>CPRI Rate 3</li> <li>CPRI Rate 4</li> <li>CPRI Rate 5</li> <li>CPRI Rate 6</li> <li>CPRI Rate 8 - 64Bit</li> <li>SDI 3G</li> <li>SDI HD</li> </ul> |
| Features     Custom Protocol Settings      Enable Dynamic Reconfiguration Interface (DRI)                                                                                                                                              |

#### Figure 1-47. Reference Clock Source Options





### Figure 1-48. RX JA Clock Frequency (XCVR Configurator)

| PMA Settings               |           |      |                                  |              |
|----------------------------|-----------|------|----------------------------------|--------------|
| <u>T</u> X data rate       | 10000     | Mbps | <u>R</u> X data rate             | 10000        |
| TX clock division factor   | 1 💌       |      | RX CDR lock mode                 | Lock to data |
| TX PLL base data rate      | 10000.000 | Mbps | RX CDR reference clock source    | Dedicated 💌  |
| TX PLL bit clock frequency | 5000.000  | MHz  | RX CDR reference clock frequency | 80.00 💌      |
|                            |           |      | RX JA clock frequency            | 312.5        |

#### 1.5.4.3 Dedicated Reference Clock Input Pins

For every transmit PLL within the transceiver PMA, there is a reference input pin pair for an external input of reference clocks to the device, as shown in the following figure. The reference clock inputs provide flexibility to interface with both single-ended and differential clocks and can drive up to two independent clocks per transceiver quad. The reference clock inputs has a single power supply (VDD\_XCVR\_CLK) that is shared across all reference clock buffers. These reference clocks can also be sourced for the global and regional clock networks in the FPGA fabric of the devices.

The following figure provides a detailed view of the dedicated reference clock.

# Figure 1-49. Dedicated Transceiver Reference Clock Inputs



**Note:** For more information on reference clock interface block, see Figure 1-43.

#### 1.5.4.3.1 Differential Input

This mode supports differential inputs such as LVDS/HCSL. The differential reference clock is available on REFCLK0 (REFCLK1 is not available with differential input clock mode). The inputs include an optional on-die 100  $\Omega$  differential termination resistor. By default, the differential input termination resistance is set in high-Z mode until programmed with Libero software. XCVR\_VREF is not used for differential reference clock input signaling. XCVR\_VREF is used for single-ended signals requiring a voltage reference, such as SSTL.

#### 1.5.4.3.2 Reference Voltage Input

In this mode, the input interface supports two single-ended modes:

- Local reference input: A reference voltage is connected to the XCVR\_REFCLK\_N input, which is used for the clock connected to the XCVR\_REFCLK\_P input. The resulting reference clock is available on the REFCLK0 output (REFCLK1 output is unavailable with local reference input mode).
- Global reference input: This mode allows for two separate reference clock sources, where the XCVR\_REFCLK\_P input is compared with a global transceiver reference called XCVR\_VREF and is output on REFCLK0. The XCVR\_REFCLK\_N input is simultaneously compared to the same XCVR\_VREF reference signal, and the result is output on REFCLK1. In this scenario, each XCVR\_REFCLK\_P and XCVR\_REFCLK\_N pins can accept a single-ended clock source. The resulting clock signals are available on REFCLK0 and REFCLK1 outputs, respectively. Internal voltage reference circuitry is included when a reference voltage input is used. No external voltage is required to the reference voltage input (XCVR\_VREF) pin, which is internally connected.

**Note:** There is one XCVR\_VREF signal per device that can be sourced from an external pin or an internal reference voltage circuit. An internally generated voltage reference (VREF) is default. A user can optionally use an externally supplied VREF if desired.

#### 1.5.4.3.3 Single-Ended CMOS Input

In addition, the XCVR\_REFCLK\_P/N pins can connect a single-ended CMOS clock signal to the REFCLK0 and REFCLK1 inputs. This allows two independent reference clocks to be applied to a XCVR REFCLK inputs. XCVR\_VREF is not used for single-ended CMOS reference clock input signaling.

#### 1.5.4.3.4 XCVR REFCLK Usage

Transceiver Reference clock input standards will default to the following configurations dependent on the selection of LVCMOS, Voltage Reference, or Differential selection in the REFCLK configurator.

#### Table 1-20. XCVR REFCLK Defaults

| Reference Clock Mode | I/O Std  | Resistor Pull | Schmitt Trigger | ODT | VDDI |
|----------------------|----------|---------------|-----------------|-----|------|
| LVCMOS               | LVCMOS25 | None          | OFF             | 0   | 2.5  |
| Voltage Reference    | SSTL25I  | None          | OFF             | 0   | 2.5  |
| Differential         | LVDS25   | None          | OFF             | 100 | 2.5  |

The default can be changed using I/O PDC constraints (not available in IOEditor).

```
-io_std <iostd>
-ODT_VALUE <odt>
-RES_PULL <res_pull>
-SCHMITT_TRIGGER <schmitt>
-USE_EXTERNAL_VREF <true, false>
-POWER_SUPPLY <power Supply for all Ports>
-EXTERNAL_VREF <true/false>
```

#### Notes:

- By default, the VDD\_XCVR\_CLK power supply is set to 2.5 V. If 3.3 V is used, add it to all ports in the PDC. If a
  port is not specified in the PDC, it takes the default setting. All REFCLK ports need to be specified in the PDC to
  specify their location else the flow stops.
- The new options are case sensitive, the values are not.
- To turn OFF the odt, set the ODT\_VALUE to 0.
- SSTL18I, SSTL18II, SSTL25I, and SSTL25II inputs optionally have a VREF pin to set.
- PDC option is called USE\_EXTERNAL\_VREF <true/false> where the default is false to use the internal VREF pin.

| Single-ended          | Differential <sup>2</sup> | Reference Voltage (Not supported for ES/XT devices). |
|-----------------------|---------------------------|------------------------------------------------------|
| LVCMOS18 (VDDI = 2.5) | HCSL25 <sup>3</sup>       | HSUL18I (VDDI = 2.5)                                 |
| LVCMOS25 (VDDI = 2.5) | LVDS25                    | HSUL18II (VDDI = 2.5)                                |
| LVCMOS33 (VDDI = 3.3) | LVPECL33 (VDDI = 3.3)     | SSTL18I (VDDI = 2.5)                                 |
| LVTTL (VDDI = 3.3)    | MINILVDS25                | SSTL18II (VDDI = 2.5)                                |
| -                     | MIPI25                    | SSTL25I (VDDI = 2.5)                                 |
| -                     | MLVDS25                   | SSTL25II (VDDI = 2.5)                                |
| -                     | PPDS25                    | -                                                    |
| -                     | RSDS25                    | -                                                    |
| -                     | SLVS25                    | -                                                    |
| -                     | SUBLVDS25                 | -                                                    |
| -                     | LVDS33 <sup>4</sup>       |                                                      |

#### Table 1-21. Reference Clock Input Buffer Standards<sup>1</sup>

(1) VDDI = VDD\_XCVR\_CLK

(2) Differential inputs do not include internal voltage-bias circuitry.

 $^{(3)}$  LP-HCSL is supported with HCSL25 reference clock setting without 100  $\Omega$  differential ODT.

(4) LVDS33 is supported in device with VDDI= 3.3 V and supported in Libero by selecting LVDS25 IO Standard configuration.

Users need to be aware of power supply requirements and voltage reference requirements. See PolarFire FPGA and PolarFire SoC FPGA User I/O User Guide for more information.

#### 1.5.4.3.5 Reference Clock Input Pins

The input pins XCVR\_REFCLK\_P/N are assigned through the Libero transceiver configurator based on the targeted transceiver quad. The pins are identified based on quad. For example, where there are three transmit PLLs:

- XCVR\_#A\_REFCLK\_P/N—This REFCLK input is associated with the connection dedicated to the TXPLL\_SSC. Also, this input has connectivity to the Global clock resource.
- XCVR\_#B\_REFCLK\_P/N
- XCVR\_#C\_REFCLK\_P/N (For PolarFire FPGA, this input is only available in a subset of transceiver quads per device as shown in Figure 1-52 and Figure 1-54) (For PolarFire SoC FPGA, this input is only available in a subset of transceiver quads per device as shown in Figure 1-53 and Figure 1-55)

The following figure shows REFCLK input pins. These pins drive into the reference clock interface block to the TxPLLs and CDRs per quad or cascaded among several quads as required by the user design.

# Figure 1-50. REFCLK Input Pin Diagram



To Cascade Clock

**Note:** The XCVR\_#[ABC]\_REFCLK pins are available per quad. The REFCLK input to the reference clock interface (see Figure 1-43) connects the REFCLK source to the associated TxPLL.

For more information on reference clock interface, see 1.5.4.1 Transceiver Reference Clock Interface.

## 1.5.4.4 Reference Clock Disruptions

Reference clocks are required to be applied and stable to the PLLs for proper transceiver operations for Lock to Data or Lock to Reference applications. TXPLL and RXCDR PLL require a guaranteed reference clock to ensure proper operation. Reference clock inputs does not include any "signal detection". It is the responsibility of the user design to monitor and handle losses or switching of the system level reference clocks. Reference clock disruptions can cause the lock control circuitry to misbehave and possibly be stuck into whatever state it is in when the reference clock is lost.

#### 1.5.4.5 Transceiver Resource Layout

For both the family devices, there are between one to six transceiver quads with four transceivers each, for a total of 4 to 24 full-duplex transceiver lanes. There are up to three external reference clock inputs per quad, which can be used with every transmit PLL and transceiver lane CDRs. See 1.5.4 Transceiver Clocks for more information.

The transmit PLL output clocks can be used by one or more lanes within a quad, or shared with adjacent quads.

Each receive lane CDR has its own PLL; therefore, all receive rates can run at independent frequencies. For the transmit lanes, one base rate can be created by a transmit PLL and driven to each of the transmit lanes it can connect to. Each lane can select between the base rate of two different transmit PLLs or a divided version (Div2, Div4, Div8, or Div11), which can be selected per transmit lane.

The reference clock to the CDR can be sourced from the FPGA fabric thereby allowing more reference clock sources within a design. The inherent noise from the fabric is tolerated by the CDR.

The following tables list the number of transceiver resources available for each family device.

| Table 1-22 | . PolarFire | FPGA | Transceiver | Resources |
|------------|-------------|------|-------------|-----------|
|------------|-------------|------|-------------|-----------|

| Device              | XCVR Lanes | TxPLLs | Reference Clock Input Pins      |
|---------------------|------------|--------|---------------------------------|
| MPF100              | 8          | 6      | 12 single-ended/6 differential  |
| MPF200 <sup>1</sup> | 16         | 11     | 22 single-ended/11 differential |
| MPF300              | 16         | 11     | 22 single-ended/11 differential |
| MPF500              | 24         | 15     | 30 single-ended/15 differential |

<sup>(1)</sup> MPF200-FCG484 and FCVG484 packages only support up to eight XCVR lanes and six TXPLLs.

| Table 1-23. PolarFire SoC FPGA | Transceiver Resources |
|--------------------------------|-----------------------|
|--------------------------------|-----------------------|

| Device                | XCVR Lanes | TxPLLs | Reference Clock Input Pins      |
|-----------------------|------------|--------|---------------------------------|
| MPFS250T <sup>1</sup> | 16         | 11     | 22 single-ended/11 differential |
|                       |            |        |                                 |

<sup>(1)</sup> MPFS250-FCVG484 supports four XCVR lanes (Quad0 only) and three TXPLLS.

Figure 1-51, Figure 1-52, and Figure 1-54 show the arrangement of the transceiver quads, the connectivity of lanes, transmit PLLs, and embedded PCIe blocks for the MPF100, MPF200, MPF300, and MPF500 device. This arrangement ensures package compatibility for all of the devices in the PolarFire FPGA family. For example, if a package supports all of the devices of the PolarFire family and a PCIe block is used on the smallest device, then the same PCIe block is available on the same package pins for all other devices in the family.

Figure 1-53 shows the arrangement of the transceiver quads, the connectivity of lanes, transmit PLLs, and embedded PCIe blocks for the MPFS250T device. This arrangement ensures package compatibility for all of the devices in the PolarFire SoC FPGA family. For example, if a package supports all of the devices of the PolarFire SoC family and a PCIe block is used on the smallest device, then the same PCIe block is available on the same package pins for all other devices in the family.



Figure 1-51. MPF100 Transceiver and Transmit PLL Layout





# Figure 1-52. MPF200 and MPF300 Transceiver and Transmit PLL Layout





Figure 1-53. MPFS250T Transceiver and Transmit PLL Layout

#### Note:

MPFS250-FCVG484 supports four XCVR lanes (Quad0 only) and three TXPLLS. See Figure 1-55.





# Figure 1-55. MPFS250T-FCVG484 Quad0



# 1.6 PMA and PCS Resets

The transceiver uses partitioned resets, one single wire for PMA\_ARST\_N and one for PCS\_ARST\_N to the PF\_XCVR. Specifically, these two inputs can come from the FPGA fabric to reset the PMA and PCS portions of the transceiver. Both inputs assert the reset asynchronously and de-assertion is internally synchronized.

PMA\_ARST\_N reset always impacts both the Rx and Tx. This active LOW input resets all internal portions of the transceiver PMA including the serializer/deserializer, DFE, eye monitor, loopback FIFO, and internal analog circuits. The following figure shows the block diagram of PMA\_ARST\_N.

### Figure 1-56. PMA\_ARST\_N Block Diagram



#### \* Signals in red are reset signals per PMA lane.

Control registers are available to selectively reset all components within the PMA and TXPLLs. These registers can be accessed through DRI (see 5.3 Dynamic Reconfiguration Interface). For information about the register map, see respective PolarFire Device Register Map or PolarFire SoC Register Map.

PCS\_ARST\_N reset impacts either or both the receiver and the transmitter portion of PCS depending on transceiver mode (see 2.2 Transceiver Modes). Resetting the Tx causes the serial link to be void of data toggling while internally restarting and the PCS transmit data path flushes out. Resetting the Rx causes the PCS active mode circuitry to be restarted. In 8b10b PCS mode, PCS\_ARSTN is used to force the symbol alignment to restart when too many data errors are seen in the fabric logic. PCS\_ARSTN causes the RX clocks to stop. Users should not assert/de-assert the PCS\_ARSTN reset via logic that is driven from the RX clocks as this would then create a lock-up situation where the PCS Reset is never de-asserted because the RX clock stops to toggle.

The functionality of the resets are register configured by the Libero software. See the respective PolarFire Device Register Map or PolarFire SoC Register Map for information about register maps. After Libero programming, these register controlled bits are written at power up prior to releasing the Tx PLL from reset. By doing this configuration during reset guarantees that the PCS Tx is reset without manual intervention.

In PMA Only XCVR configurations, the PCS\_ARST\_N can be tied to 1. This configuration assumes that the PCSLANE/LRST\_R0/LRST\_ULCKD\_CDR\_RESETS\_PCS\_RX register is set to 0x1 (default). This configuration resets the fly-wheel FIFOs within the PCS for PMA Only modes when the CDR automatically resets PCS Rx domain logic.

Libero PCS\_ARST\_N settings: only reset the Rx PCS when PCS\_ARST\_N falls; and self-reset the Tx PCS when the Tx PLL transitions from unlocked to locked. The Tx PLL lock is typically the last event which impacts the health of the clock going into the PCS from the PMA. However, if there is an application which requires a change to serializer post-divider or change to which PLL a particular Tx lane uses; these events cause a change in PCS clocking. These types of configuration changes should be carried out by first asserting the soft PCS Tx Reset system register, then changing the serializer configuration, and then de-asserting the soft PCS Tx Reset system register. This method assures the PCS plus its FWF sees a consistent clocking at the time when they are out of reset. Rate modifications must be done through DRI using a reset/modify/unreset sequence and must be implemented by the user design. For such rate changes, the \*ARST\_N pins do not have to be used since soft resets are available through the DRI.

In 8b10b mode, the word aligner can only find a new pattern following a reset. Therefore, the Libero default is for PCS\_ARST\_N for Rx Only.

See 2.2 Transceiver Modes for information about the impact of PMA and PCS resets.

# 1.7 PCS Rate Switch Between 8b10b and 64b66b Mode for CPRI

All CPRI protocol data rates are statically supported with the Libero Transceiver Configurator using either 8b10b or 64b66b modes. 8b10b supports CPRI rates 2, 3, 4, 5, 6, and 7 while 64b66b mode supports rates 7a, 8, and 9. In cases requiring dynamic switching, the user must take steps to accommodate the correct design intentions for switching the PCS mode between the data rates. This case requires a rate switch between the 8b10b and 64b66b modes.

8b10b ports are a superset of 64b66b ports. This implies that the user should plan the FPGA fabric design to interface with 8b10b ports of the XCVR and use the fabric to control the mode switching to the CPRI user IP as shown in the following figure.





The following table lists the port crossover between the 8b10b and 64b66b modes provided by the XCVR PCS to the FPGA fabric.

Table 1-24. Port Crossover between the 8b10b and 64b66b Modes

| Direction | 8B10B Mode        | 64B6xB Mode        |
|-----------|-------------------|--------------------|
| Input     | TX_DISPFNC[15]    | TX_ELEC_IDLE       |
| Input     | TX_DISPFNC[14]    | TX_BYPASS_DATA     |
| Input     | TX_DISPFNC[13:12] | RESERVED_IN[1:0]   |
| Input     | TX_DISPFNC[11:8]  | RESERVED_IN[5:2]   |
| Input     | TX_DISPFNC[7:6]   | RESERVED_IN[7:6]   |
| Input     | TX_DISPFNC[5:2]   | RESERVED_IN[11:8]  |
| Input     | TX_DISPFNC[1]     | RESERVED_IN[12]    |
| Input     | TX_DISPFNC[0]     | RESERVED_IN[13]    |
| Input     | TX_K[7:6]         | RESERVED_IN[15:14] |
| Input     | TX_K[5]           | RESERVED_IN[16]    |
| Input     | TX_K[4]           | TX_SOS             |
| Input     | TX_K[3:0]         | TX_HDR[3:0]        |
| Input     | TX_DATA[63:33]    | TX_DATA[63:33]     |
| Input     | TX_DATA[32:19]    | TX_DATA[32:19]     |
| Input     | TX_DATA[18:17]    | TX_DATA[18:17]     |
| Input     | TX_DATA[16]       | TX_DATA[16]        |
| Input     | TX_DATA[15]       | TX_DATA[15]        |

# **Functional Description**

| continued |                             |                    |  |
|-----------|-----------------------------|--------------------|--|
| Direction | 8B10B Mode                  | 64B6xB Mode        |  |
| Input     | TX_DATA[14]                 | TX_DATA[14]        |  |
| Input     | TX_DATA[13:12]              | TX_DATA[13:12]     |  |
| Input     | TX_DATA[11:10]              | TX_DATA[11:10]     |  |
| Input     | TX_DATA[9:8]                | TX_DATA[9:8]       |  |
| Input     | TX_DATA[7:5]                | TX_DATA[7:5]       |  |
| Input     | TX_DATA[4]                  | TX_DATA[4]         |  |
| Input     | TX_DATA[3]                  | TX_DATA[3]         |  |
| Input     | TX_DATA[2]                  | TX_DATA[2]         |  |
| Input     | TX_DATA[1]                  | TX_DATA[1]         |  |
| Input     | TX_DATA[0]                  | TX_DATA[0]         |  |
| Output    | RX_K[7]                     | RX_BYPASS_DATA     |  |
| Output    | RX_K[6:0]                   | RESERVED_OUT[6:0]  |  |
| Output    | RX_CODE_VIOLATION_7         | RESERVED_OUT[13:7] |  |
|           | RX_DISPARITY_ERROR_7        |                    |  |
|           | RX_CODE_VIOLATION_6         |                    |  |
|           | RX_DISPARITY_ERROR_6        |                    |  |
|           | RX_CODE_VIOLATION_5         |                    |  |
|           | RX_DISPARITY_ERROR_5        |                    |  |
|           | RX_CODE_VIOLATION_4         |                    |  |
| Output    | RX_DISPARITY_ERROR_4        | RX_HDR_VAL         |  |
| Output    | RX_CODE_VIOLATION_3         | STATUS_HI_BER      |  |
| Output    | RX_DISPARITY_ERROR_3        | STATUS_LOCK        |  |
| Output    | RX_CODE_VIOLATION_2         | RX_SOS             |  |
| Output    | RX_DISPARITY_ERROR_2        | RX_DATA_VAL        |  |
| Output    | RX_CODE_VIOLATION_1         | RX_HDR[3:0]        |  |
|           | RX_DISPARITY_ERROR_1        |                    |  |
|           | RX_CODE_VIOLATION_0         |                    |  |
|           | RX_DISPARITY_ERROR_0        |                    |  |
| Output    | RX_DATA[63:51]              | RX_DATA[63:51]     |  |
| Output    | RX_DATA[50:49]              | RX_DATA[50:49]     |  |
| Output    | RX_DATA[48:9]               | RX_DATA[48:9]      |  |
| Output    | RX_DATA[8:5]                | RX_DATA[8:5]       |  |
| Output    | RX_DATA[4]                  | RX_DATA[4]         |  |
| Output    | RX_DATA[3:1]                | RX_DATA[3:1]       |  |
| Output    | RX_DATA[0]                  | RX_DATA[0]         |  |
| Input     | TX_BIT_CLK <sup>4</sup>     |                    |  |
| Input     | TX_PLL_LOCK <sup>4</sup>    |                    |  |
| Input     | TX_PLL_REF_CLK <sup>4</sup> |                    |  |
| Input     | CTRL_CLK <sup>5</sup>       |                    |  |
|           | CTRL_CLK <sup>3</sup>       |                    |  |

| continued | continued              |             |  |
|-----------|------------------------|-------------|--|
| Direction | 8B10B Mode             | 64B6xB Mode |  |
| Input     | CALIB_REQ <sup>5</sup> |             |  |
| Input     | LOS <sup>5</sup>       |             |  |
| Input     | CDR_REF_CLK            |             |  |
| Output    | CALIBRATING            |             |  |
| Input     | TX_WCLK <sup>6</sup>   |             |  |
| Input     | PCS_ARST_N             |             |  |
| Input     | PMA_ARST_N             |             |  |
| Output    | RX_VAL                 |             |  |
| Output    | RX_READY               |             |  |
| Output    | RX_IDLE                |             |  |
| Output    | TX_CLK_STABLE          |             |  |
| Output    | RX_CLK_[R:G]           |             |  |
| Output    | TX_CLK_[R:G]           |             |  |
| Input     | RXD_P                  |             |  |
| Input     | RXD_N                  |             |  |
| Output    | TXD_P                  |             |  |
| Output    | TXD_N                  |             |  |

### Notes:

- 1. Port names in Libero has prefix lane#\_ appended to name.
- 2. Refer to specific PCS port list tables for port description.
- 3. Ports prefixed by RESERVED for a specific mode is not used for the MODE.
- 4. Port is included in CLKS\_FROM\_TXPLL BIF.
- 5. Port is included with Enhanced Receiver Management (ERM).
- 6. TX\_WCLK is included when Global (Shared) TX Clock is used.

The user control logic must accommodate switching transceiver control registers listed in the following table. This is typically by modifying the registers using the DRI to the transceiver from an APB within the design.

The following table outlines the affected registers that must be modified during rate switching.

| Register<br>Page xls | Register Name | Field Name                                                                                                                           | Description                                                                     | Required Value for 8B10B                                                                                                                                                | Required Value for<br>64B6xB                                            |  |
|----------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|--|
| pcslane              | L8_R0         | L8_R0 L8_TXENCSWAPSEL Selects between 1000BASE-X/T and Fibre Channel octet-swapping modes. Optional: 0=1000BASE-X/T, 1=Fibre Channel |                                                                                 | Don't-care                                                                                                                                                              |                                                                         |  |
|                      |               | L8_GEARMODE[1:0]                                                                                                                     | Sets data path<br>width of FWF<br>interfaces.                                   | Must be consistent with clock selections for txfwf_rclk and rxfwf_wclk.                                                                                                 | Don't-care                                                              |  |
|                      | LOVR_R0       | FAB_IFC_MODE[3:0]                                                                                                                    | Selects path<br>through fabric<br>and FWF overlay<br>blocks.                    | Register changes the meanings of the<br>epcs_tx_data and epcs_rx_data pins<br>based on the setting of the pcslane<br>LOVR_R0:PCSPMA_IFC_MODE[3:0]                       | PCSPMA_IFC_MODE<br>is one-hot encoded as<br>follows<br>0b0010 == 64B6xB |  |
|                      |               | PCSPMA_IFC_MODE[3:0]                                                                                                                 | Selects lane mode<br>for driving data<br>into the SerDes<br>serializer.         | control register field. The<br>PCSPMA_IFC_MODE is one-hot<br>encoded as follows:<br>0b0100 == 8B10B mode                                                                | mode                                                                    |  |
|                      | LCLK_R0       | LCLK_EPCS_RX_CLK_SEL [1:0]                                                                                                           | Chooses which<br>clock is sent<br>to fabric on<br>epcs_rx_clk port.             | Usually this should be set to 2'd1 so<br>that the frequency of the fabric is the<br>same as the internal side of the FWF.<br>However variations are possible if the use | 2'd1                                                                    |  |
|                      |               | LCLK_EPCS_TX_CLK_SEL [1:0]                                                                                                           | Chooses which<br>clock is sent<br>to fabric on<br>epcs_tx_clk port.             | of the Rx FWF synchronous enable will<br>be employed. See FWF description for<br>further information.                                                                   | 2'd1                                                                    |  |
| pcslane              | LCLK_R0       | LCLK_PCS_RX_CLK_SEL [1:0]                                                                                                            | Defines clock<br>module's source<br>for pcs_rx_clk.                             | Must be set to 2'd3 for all applications using 8B10B function.                                                                                                          | 2'd3                                                                    |  |
|                      |               | LCLK_PCS_TX_CLK_SEL [1:0]                                                                                                            | Defines clock<br>module's source<br>for pcs_rx_clk.                             |                                                                                                                                                                         |                                                                         |  |
|                      |               | LCLK_RXFWF_WCLK_SEL [1:0]                                                                                                            | Defines clock<br>module's source<br>for rxfwf_wclk.                             | Must be consistent with L8_GEARMODE setting.                                                                                                                            | 2'd2                                                                    |  |
|                      |               | LCLK_TXFWF_RCLK_SEL [1:0]                                                                                                            | Defines clock<br>module's source<br>for txfwf_rclk.                             |                                                                                                                                                                         | 2'd2                                                                    |  |
|                      |               | LCLK_RXFWF_WCLK_PIPE                                                                                                                 | Defines whether<br>Rx FWF is clocked<br>by Tx side clocks<br>or Rx side clocks. | Must be set to 1'd0 for 8B10B functionality.                                                                                                                            | 1'd0                                                                    |  |

Table 1-25. System Registers Affecting 8B10B and 64B6xB Data Paths

# **Functional Description**

| contin                 | continued     |                             |                                                                     |                                                                                            |                                                                                 |  |
|------------------------|---------------|-----------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--|
| Register<br>Page xls   | Register Name | Field Name                  | Description                                                         | Required Value for 8B10B                                                                   | Required Value for<br>64B6xB                                                    |  |
| pcslane<br>(continued) | LCLK_R1       | LCLK_ENA_8B10B_RX_CLK       | Instructs clock<br>module to drive<br>8B10B pcs_rx_clk.             | Must be set to 1'd1 for 8B10B operation.                                                   | 1'd0                                                                            |  |
|                        |               | LCLK_ENA_8B10B_RXFWF_WCLK   | Instructs clock<br>module to drive<br>8B10B rxfwf_wclk.             |                                                                                            |                                                                                 |  |
|                        |               | LCLK_ENA_8B10B_TX_CLK       | Instructs clock<br>module to drive<br>8B10B pcs_tx_clk.             |                                                                                            |                                                                                 |  |
|                        |               | LCLK_ENA_8B10B_TXFWF_WCLK   | Instructs clock<br>module to drive<br>8B10B txfwf_rclk.             |                                                                                            |                                                                                 |  |
|                        |               | LCLK_ENA_64B6XB_RX_CLK      | IA_64B6XB_RX_CLK Instructs clock module to drive 64B6xB pcs_rx_clk. |                                                                                            | 1'd1                                                                            |  |
|                        |               | LCLK_ENA_64B6XB_RX_CLK_DIV2 | Instructs clock<br>module to<br>drive 64B6xB<br>pcs_rx_clk_div2.    | 1'd0                                                                                       | 1'd1 for 64-bit fabric<br>1'd0 for 32-bit fabric                                |  |
|                        |               | LCLK_ENA_64B6XB_TX_CLK      | Instructs clock<br>module to<br>drive 64B6xB<br>pcs_tx_clk.         | 1'd0                                                                                       | 1'd1                                                                            |  |
|                        |               | LCLK_ENA_64B6XB_TX_CLK_DIV2 | Instructs clock<br>module to<br>drive 64B6xB<br>pcs_tx_clk_div2.    | 1'b0                                                                                       | 1'b1 for 64-bit fabric<br>1'b0 for 32-bit fabric                                |  |
| pma_lane               | DES_CLK_CTRL  | DESMODE[2:0]                | Selects parallel<br>bus width<br>of deserializer<br>interface.      | Must select the 40-bit wide bus mode for 8b10b functionality (3'd7).                       | Must select the 32-<br>bit wide bus mode<br>for 64B6xB functionality<br>(3'd6). |  |
|                        | SER_CLK_CTRL  | SERMODE[2:0]                | Selects parallel<br>bus width of<br>serializer interface.           |                                                                                            |                                                                                 |  |
|                        | DES_CDR_CTRL3 | SLIP_DES_CDR_SEL            | Selects source of<br>CDR slip control.                              | Below setting is dependent on RX_SLIP_B<br>XCVR Configurator GUI. This has dependent<br>IP |                                                                                 |  |
|                        |               |                             |                                                                     | Must be 1'd0 so that the fabric can control the symbol alignment.                          | Should be 1'd1 so that fabric cannot control the symbol alignment.              |  |
|                        |               | SLIP_DES_CDR_EN             | Optionally turns slip control OFF.                                  | Must be set to 1'd1.                                                                       | Must be set to 1'd0                                                             |  |

**Note:** See respective PolarFire Device Register Map or PolarFire SoC Register Map for more information.

# 2. Implementation

Transceiver blocks support many high-speed serial protocols. These protocols are supported using multiple transceiver building blocks that the user constructs using the transceiver configurators in the Libero design software. The Libero configurator allows the user to set the reference clock and data rates for particular protocols. This information is then used to properly generate the configuration settings for the PMA, and the associated interface logic. The configurators build components that are used to instantiate/configure the transceiver-specific hardware macros including the PMA and PCS blocks using the Libero SmartDesign software.

# 2.1 Libero Configurators

Three explicit PolarFire configurators are the preferred tool for wrapper generation needed to instantiate transceiver primitive macros called PF\_XCVR\_REF\_CLK, PF\_TX\_PLL, and PF\_XCVR. The configurator is part of the Libero SoC design tools and is available when the PolarFire macros are downloaded from the Libero catalog.

The following table provides details on three Libero transceiver configurators in the Libero Software: transmit PLL, transceiver reference clock, and transceiver interface modules. The transmit PLL (PF\_TX\_PLL) and transceiver interface (PF\_XCVR) modules are used when the transceivers are implemented in the Libero FPGA design. The transceiver reference clock (PF\_XCVR\_REF\_CLK) is used when the dedicated input clock from the top-level pins are used. Optionally, this is not used if the transceiver reference clock comes from the PLL or from the FPGA fabric. The user must instantiate and configure these three blocks in their transceiver design.

| Configurator                   | Масго           | Details                                                                                                                                                                                                     |
|--------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transmit PLL                   | PF_TX_PLL       | Generates the TxPLL/TxPLL_SSC based on the provided input to the GUI. The PF_TX_PLL generates the BIT_CLK for the transceiver.                                                                              |
| Transceiver Reference<br>Clock | PF_XCVR_REF_CLK | Generates the reference clock based on the provided input to the GUI—selection of differential or single-end input buffer and selection of single or dual clock inputs to the transmit PLL clock interface. |
| Transceiver Interface          | PF_XCVR_ERM     | Configures the requested number of lanes (4 lane maximum) with the same PMA and PCS settings—the lanes required by the design and CDRPLL settings.                                                          |

As the FPGA designer makes selections in the each transceiver module configurators, it automatically guides and narrows down the subsequent choices and defaults. Each configurator maintains a module diagram while the designer selects the module properties. Once all the choices are made, the configurator generates an RTL netlist that instantiates the required macros specific to the requirements of the design. Only the relevant ports appear in the generated macro. This section describes how to enter these configuration parameters in the transceiver configurator GUIs.

# 2.1.1 Transceiver Reference Clock Configurator

The Transceiver Reference Clock Configurator is used to build the correct reference clock input to the transceiver and to the Tx PLL. The user can pick the input type and various input options.

To initiate the Reference Clock Configurator, perform the following steps:

1. Access the **Transceiver Reference Clock** cores under **Features** from the **Catalog** window, as shown in the following figure.

| 8×      |
|---------|
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
| LK_C1_0 |
|         |
|         |
| REF_CLK |
|         |
|         |
| CLK C1  |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |

2. Double-click each PF\_XCVR\_REF\_CLK block from the catalog to launch the configurator. A GUI allows the selection of the related reference clock properties.



Figure 2-2. Transceiver Reference Clock Configurator GUI

The following table lists transceiver reference clock configurator GUI options.

| Table 2-2. Transceiver Reference | e Clock Configurator GUI Options |
|----------------------------------|----------------------------------|
|----------------------------------|----------------------------------|

|                                 | Options                                                                          | Default      | Details                                                                     |
|---------------------------------|----------------------------------------------------------------------------------|--------------|-----------------------------------------------------------------------------|
| Reference Clock 0 Configuration |                                                                                  |              |                                                                             |
| Enable reference clock 0        | Enable and disable                                                               | Enabled      | Checked = enabled                                                           |
| Reference Clock 0 Mode          | LVCMOS, voltage reference, and differential                                      | Differential |                                                                             |
| Enable fabric clock output      | Enable and disable Disabled Checked = enabled When enabled, a port is e routing. |              | When enabled, a port is exposed for fabric                                  |
| Reference Clock 1 Configuration |                                                                                  | ·            | ·                                                                           |
| Enable reference clock 1        | Enable and disable                                                               | Disabled     | Checked = enabled                                                           |
| Reference Clock 1 Mode          | LVCMOS and voltage reference                                                     | LVCMOS       |                                                                             |
| Enable fabric clock output      | Enable and disable                                                               | Disabled     | Checked = enabled<br>When enabled, a port is exposed for fabric<br>routing. |

3. Select the reference clock mode type based on the input buffer type in the application. Single-ended **Differential** is the default mode.

| Figure 2-3. | Transceiver | Reference | Clock | Mode | Туре |
|-------------|-------------|-----------|-------|------|------|
|-------------|-------------|-----------|-------|------|------|

| Configuration                                          |
|--------------------------------------------------------|
| Reference Clock 0                                      |
| Enable reference clock 0 🔽                             |
| Reference Clock 0 Mode Differential                    |
| LVCMOS<br>Enable fabric clock output Voltage Reference |
| Differential                                           |
| Reference Clock 1                                      |
| Enable reference clock 1                               |
| Reference Clock 1 Mode LVCMOS                          |
| Enable fabric clock output                             |

In the case of **LVCMOS** or **Voltage Reference** inputs, the design can have up to two individual reference clock inputs in one instance of the PF\_XCVR\_REF\_CLK. This configuration can access either or both Reference Clock 0 or/and 1.





However, only one reference clock input is available when the designer selects **Differential** (Figure 2-3). In this case, only **Reference Clock 0** can be accessed and use a differential clock source signal.

| Configuration                                                     |                                            |
|-------------------------------------------------------------------|--------------------------------------------|
| Reference Clock 0                                                 |                                            |
| Enable reference clock 0 🔽<br>Reference Clock 0 Mode Differential |                                            |
| Reference Clock 1                                                 |                                            |
| Enable reference clock 1                                          | PF_XCVR_REF_CLK_0                          |
| Enable fabric clock output                                        | - REF_CLK_PAD_P<br>- REF_CLK_PAD_N REF_CLK |
|                                                                   | PF_XCVR_REF_CLK                            |

Figure 2-6. PF\_XCVR\_REF\_CLK With Differential Input and Single Output Clock

4. Optionally enable a connection to the FPGA fabric for either/both reference clock 0 or reference clock 1. When enabled, a related port of the associated reference clock is exposed for fabric routing.

| Figure 2-7. PF | _XCVR | _REF_ | _CLK With | Fabric | Output | Clock |
|----------------|-------|-------|-----------|--------|--------|-------|
|----------------|-------|-------|-----------|--------|--------|-------|

| Configuration                 | 1                            |
|-------------------------------|------------------------------|
| Reference Clock 0             |                              |
| Enable reference clock 0 🔽    |                              |
| Reference Clock 0 Mode LVCMOS |                              |
| Enable fabric clock output 🔽  |                              |
| Reference Clock 1             | PF_XCVR_REF_CLK_0            |
| Enable reference clock 1 🔽    |                              |
| Reference Clock 1 Mode LVCMOS | REF_CLK_0-                   |
| Enable fabric clock output    | -REF_CLK_PAD_0 REF_CLK_1-    |
|                               | REF_CLK_PAD_1 FAB_REF_CLK_0- |
|                               | FAB_REF_CLK_1                |
|                               | PF_XCVR_REF_CLK              |
|                               |                              |

5. Click **OK** after making desired selections.

When the Reference Clock configurator generates the reference clock block, specify the desired IP Standard. This is completed by adding the desired IO to the PDC file. For more information about adding the IO to the PDC file, see 2.4.2 Physical Constraints.

For more information about XCVR REFCLK input configuration, see 1.5.4.3.4 XCVR REFCLK Usage.

The PF\_XCVR\_REF\_CLK allows a global routing connection to the FAB\_REF\_CLK output via a CLKINT global buffer. The FAB\_REF\_CLK output uses regular fabric routing resources and the connection traverse half the device before connecting onto a CLKINT fabric Global Buffer at the center of the chip. FAB\_REF\_CLK clock is potentially

more susceptible to fabric switching noise, depending on the design, which could lead to an unpredictable amount of clock jitter on that clock being broadcasted to the fabric.

### 2.1.2 Transmit PLL Configurator

The Transceiver Transmit PLL Configurator is used to build the correct transmit PLL to the transceiver. The user can pick from many of the PLL options used for the transceiver based on the application.

To initiate the Transceiver Transmit PLL Configurator, perform the following steps:

1. Access the **Transmit PLL** module under **Features** from the **Catalog** window, as shown in the following figure. **Figure 2-8. Transceiver Transmit PLL Selection from Catalog** 

| Catalog                                                                |                       | Β×       | Rep         | ports | 8 | ×∣ | Start  | Page i | Β×   | SD top*  |
|------------------------------------------------------------------------|-----------------------|----------|-------------|-------|---|----|--------|--------|------|----------|
|                                                                        | 🔍 👻 🔲 Simulation Mode | <u> </u> |             | 1     | 0 |    |        |        |      |          |
| Name                                                                   | 🛆 Version             |          | <b>Co</b> ) | •     | U |    | × +-   |        | H C  | • 🕀 🗘    |
| ···· PolarFire IOD Generic Receive Interfaces                          | 2.1.101               |          |             |       |   |    |        |        |      |          |
| PolarFire IOD Generic Receive Interfaces                               | 2.1.101               |          |             |       |   |    |        |        |      |          |
| PolarFire IOD Generic Receive Interfaces                               | 2.1.100 (*)           |          |             |       |   |    |        |        |      |          |
| PolarFire IOD Generic Transmit Interfaces                              | 2.0.108               |          |             |       |   |    |        |        |      |          |
| <ul> <li>PolarFire IOD Generic Transmit Interfaces Clocking</li> </ul> | 1.0.121               |          |             |       |   |    |        |        |      |          |
| PolarFire Initialization Monitor                                       | 2.0.105               |          |             |       |   |    |        |        |      |          |
| PolarFire LPDDR3                                                       | 2.3.111               |          |             |       |   |    |        |        |      |          |
| PolarFire Octal DDR PHY (Beta)                                         | 1.2.109 (*)           |          |             |       |   |    |        |        |      |          |
| <ul> <li>PolarFire Octal DDR PHY (Beta)</li> </ul>                     | 1.2.107 (*)           |          |             |       |   |    |        |        |      |          |
| PolarFire Octal DDR PHY (Pre-Production)                               | 1.4.101               |          |             |       |   |    |        |        |      |          |
| PolarFire Octal DDR PHY (Pre-Production)                               | 1.4.101               |          |             |       |   |    |        |        |      | <u> </u> |
| PolarFire Octal DDR PHY (Pre-Production)                               | 1.4.100 (*)           |          |             |       |   | ۲  | F_     | ۱X_    | PLL  | _C0_     |
| - PolarFire QDR                                                        | 1.7.100               |          |             |       |   | 1  |        |        | -    |          |
| PolarFire RC Oscillators                                               | 1.0.102               |          |             |       |   |    |        |        |      | PLL_LOC  |
| ···· PolarFire RGMII to GMII                                           | 1.3.101               |          |             |       |   | -R | EF_CLI | K      | СК   | 5 то хси |
| ···· PolarFire RGMII to GMII                                           | 1.3.101               |          |             |       |   | l  |        |        | CER  |          |
| PolarFire RGMII to GMII                                                | 1.3.100 (*)           |          |             |       |   |    | DE     | TV     | / DI | L CO     |
| PolarFire SRAM (AHBLite and AXI)                                       | 1.2.108               |          |             |       |   |    | FI.    | _ 1 ^  |      | L_C0     |
| PolarFire SRAM (AHBLite and AXI)                                       | 1.2.108               |          |             |       |   |    |        |        |      |          |
| Tamper                                                                 | 1.0.200               |          |             |       |   |    |        |        |      |          |
| <ul> <li>Temperature and Voltage Sensor Interface</li> </ul>           | 1.0.110               |          |             |       |   |    |        |        |      |          |
| Transceiver Interface                                                  | 3. 1. 100             |          |             |       |   |    |        |        |      |          |
| Transceiver Interface                                                  | 3.1.100               |          |             |       |   |    |        |        |      |          |
| Transceiver Interface                                                  | 3.0.101 (*)           |          |             |       |   |    |        |        |      |          |
| Transceiver Reference Clock                                            | 1.0.103               |          |             |       |   |    |        |        |      |          |
| Transmit PLL                                                           | 2.0.202               |          |             |       |   |    |        |        |      |          |
| Transmit PLL                                                           | 2.0.201               |          |             |       |   |    |        |        |      |          |
| + Processors                                                           |                       |          |             |       |   |    |        |        |      |          |
| Solutions                                                              |                       | <b>•</b> |             |       |   |    |        |        |      |          |

Description: Transmit PLL

2. Double-click each PF\_TX\_PLL block from the catalog to launch the configurator. A GUI allows the option of selecting the related transmit PLL properties.

| Figure 2-9. | Transmit PLL | Configurator | GUI |
|-------------|--------------|--------------|-----|
|-------------|--------------|--------------|-----|

| Configurator                         |                                                                                         | œ – ⊡ ×                |
|--------------------------------------|-----------------------------------------------------------------------------------------|------------------------|
| Transmit PLL                         |                                                                                         |                        |
| Microsemi:5gCore:PF_TX_PLL:2.0.202   |                                                                                         |                        |
|                                      | (annual)                                                                                |                        |
| PF_TX_PLL_default_configuration      | Transmit PLL                                                                            |                        |
| - 10GBASE-R<br>10GBASE-KR            | Clock Inputs/Outputs                                                                    |                        |
| SGMI                                 |                                                                                         |                        |
| - QSGMII                             | Configure Tx PLL in Integer Mode                                                        |                        |
| - CPRI Rate 1                        |                                                                                         |                        |
| - CPRI Rate 2                        | Desired Output Bit Clock 10000.000 Mbps Desired Output Bit Clock Frequency 5000.000 MHz |                        |
| - CPRI Rate 3                        |                                                                                         |                        |
| - CPRI Rate 4                        | Reference Clock Frequency 200 MHz                                                       |                        |
| - CPRI Rate 5                        | Reference Clock Source Dedicated 💌                                                      |                        |
| - CPRI Rate 6                        | Refere duct source Decrated                                                             |                        |
| - CPRI Rate 7                        | Bandwidth Low 💌                                                                         |                        |
| - CPRI Rate 8                        |                                                                                         |                        |
| - SDI 3G                             |                                                                                         |                        |
| - SDI HD                             | Clock Options                                                                           |                        |
| - SDI SD                             |                                                                                         |                        |
| <ul> <li>Interlaken 6.25G</li> </ul> | Normal Mode                                                                             |                        |
| - Interlaken 10G                     |                                                                                         |                        |
| - XAUI                               | C SSCG Modulation                                                                       |                        |
|                                      |                                                                                         |                        |
|                                      | C Jitter Cleaning Mode 10G SyncE 328It                                                  | PF_TX_PLL_0            |
|                                      | Enable Jitter Attenuation PLL at power-up                                               | PL 100-                |
|                                      |                                                                                         | HEF_CAK CAS_TO_XCAN    |
|                                      | Jitter Attenuation PLL Reference Clock Frequency 125 MHz                                |                        |
|                                      | Itter Attenuation PLL Reference Clock Source Dedicated                                  | PF_TX_PLL::PF_TX_PLL_0 |
|                                      | Jitter Attenuation PLL Reference Clock Source Dedicated 💌                               |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      | Features                                                                                |                        |
|                                      |                                                                                         |                        |
| 1 1                                  | Enable Dynamic Reconfiguration Interface (DRI)                                          |                        |
| Apply New preset                     |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      | ۲ <u>۲</u>                                                                              | Symbol                 |
| Log                                  |                                                                                         |                        |
| -                                    |                                                                                         |                        |
| 🔳 Messages 🔞 Errors 🗼 Warnings 🕕 Ir  | fo                                                                                      |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
|                                      |                                                                                         |                        |
| Help •                               |                                                                                         | OK Cancel              |
|                                      |                                                                                         |                        |

The following table lists the transmit PLL configurator GUI options.

Table 2-3. Transmit PLL Configurator GUI Options

| Clock Inputs                        | Options                          | Default                 | Details                                                                                                                                                                                                                                                                                                 |
|-------------------------------------|----------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Configure Tx PLL in Integer<br>Mode | Enable and disable               | Disabled                | When disabled, it is in TXPLL Fractional N Mode. When enabled, it allows fixed value of available reference clock frequencies.                                                                                                                                                                          |
| Reference Clock Source              | Dedicated and fabric             | Dedicated               | Dialogue box requires input clock rate (200 MHz default)                                                                                                                                                                                                                                                |
| Desired Output Bit Clock            | VCO rate, and output clock (MHz) | 10000 Mbps, 5000<br>MHz | Only valid combinations can be entered based on reference clock and PLL capability. This value represents the BIT_CLK output speed.                                                                                                                                                                     |
| Bandwidth                           | Low/High                         | Low                     | By default, the Tx PLL selects the low bandwidth option in order to filter more of the reference clock jitter. If the system has a low-jitter reference clock, the user can then set it to high bandwidth mode to decrease the overall jitter. Low bandwidth has longer lock times than high bandwidth. |
| Clock options (Only one opti        | on can be selected)              | ·                       |                                                                                                                                                                                                                                                                                                         |
| Normal Mode                         | Enable and disable               | Enabled                 | Radio-button on = enabled                                                                                                                                                                                                                                                                               |
| SSCG Modulation                     | Enable and disable               | Enabled                 | Radio-button on = disabled                                                                                                                                                                                                                                                                              |

# Implementation

| continued                                            |                    |          |                                                                                                                                                                                      |
|------------------------------------------------------|--------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock Inputs                                         | Options            | Default  | Details                                                                                                                                                                              |
| Jitter Cleaning Mode                                 | Enable and disable | Disabled | Radio-button on = disabled<br>The following options are available when enabled:<br>10G SyncE 32Bit                                                                                   |
|                                                      |                    |          | 10G SyncE 64Bit                                                                                                                                                                      |
|                                                      |                    |          | 1G SyncE 10Bit                                                                                                                                                                       |
|                                                      |                    |          | CPRI Rate 1                                                                                                                                                                          |
|                                                      |                    |          | CPRI Rate 2                                                                                                                                                                          |
|                                                      |                    |          | CPRI Rate 3                                                                                                                                                                          |
|                                                      |                    |          | CPRI Rate 4                                                                                                                                                                          |
|                                                      |                    |          | CPRI Rate 5                                                                                                                                                                          |
|                                                      |                    |          | CPRI Rate 6                                                                                                                                                                          |
|                                                      |                    |          | CPRI Rate 8 – 64-bit                                                                                                                                                                 |
|                                                      |                    |          | SDI 3G                                                                                                                                                                               |
|                                                      |                    |          | SDI HD                                                                                                                                                                               |
|                                                      |                    |          | SDI SD                                                                                                                                                                               |
|                                                      |                    |          | Custom Protocol Settings                                                                                                                                                             |
| Features                                             |                    |          |                                                                                                                                                                                      |
| Enable Dynamic<br>Reconfiguration Interface<br>(DRI) | Enable and disable | Disabled | Adds Pins to TXPLL component for using Dynamic Reconfiguration Interface. See<br>PolarFire FPGA and PolarFire SoC FPGA Device Power-Up and Resets User Guide<br>for DRI information. |

**Note:** For information about pin functions, see Table 1-18.

3. Select one of the **Reference Clock** sources (dedicated source is the default) to define **Clock Inputs** and enter the reference clock value.

| Figure | 2-10. | Clock | Inputs |  |
|--------|-------|-------|--------|--|
|        |       |       |        |  |

| Ξ | Clock Inputs/Outputs             |           |      |                                    |              |
|---|----------------------------------|-----------|------|------------------------------------|--------------|
|   | Configure Tx PLL in Integer Mode |           |      |                                    |              |
|   | Desired Output Bit Clock         | 10000.000 | Mbps | Desired Output Bit Clock Frequency | 5000.000 MHz |
|   | Reference Clock Frequency        | 20.000000 | MHz  |                                    |              |
|   | Reference Clock Source           | Dedicated | •    |                                    |              |
|   | Bandwidth                        | Low       | •    |                                    |              |

4. Enter the values in **Desired Output Bit Clock**. Frequency cannot be entered—it is calculated automatically based on the speed (data rate in Mbps) and the reference clock.

#### Figure 2-11. Fabric Clock Input

| -      |                                   | -                      |                           |           |                                |                   |              |              |
|--------|-----------------------------------|------------------------|---------------------------|-----------|--------------------------------|-------------------|--------------|--------------|
| Transr | nit PLL                           |                        |                           |           |                                |                   |              |              |
|        |                                   |                        |                           |           |                                |                   |              |              |
| -      | Clock Inputs/Outputs              |                        |                           |           |                                |                   |              |              |
|        | Configure Tx PLL in Integer Mode  |                        |                           |           |                                |                   |              |              |
|        | Desired Output Bit Clock          | 10000.000              | Mbps                      |           | Desired Output Bit Clock Frequ | ency 5000.000 MHz |              |              |
|        | Reference Clock Frequency         | 20.0000000             | MHz                       |           |                                |                   |              |              |
|        | Reference Clock Source            | Fabric                 |                           |           |                                |                   |              |              |
|        | Bandwidth                         | Low                    | -                         |           |                                |                   |              |              |
|        |                                   |                        | _                         |           |                                |                   |              |              |
| ⊡      | Clock Options                     |                        |                           |           |                                |                   |              |              |
|        | Normal Mode                       |                        |                           |           |                                |                   |              |              |
|        | C SSCG Modulation                 |                        |                           |           |                                |                   |              |              |
|        | C Jitter Cleaning Mode            | 10G SyncE 32Bit        | Ŧ                         |           |                                |                   |              |              |
|        |                                   | F Enable Jitter Atten  | uation PLL at power-up    |           |                                |                   |              |              |
|        |                                   | Jitter Attenuation PLL | Reference Clock Frequency | 125       |                                | MHz               | PF_TX        | _PLL_0       |
|        |                                   | Jitter Attenuation PLL | Reference Clock Source    | Dedicated |                                | v                 | -FAB_REF_CLK | PLL_LOCK -   |
|        |                                   |                        |                           |           |                                |                   |              | CLKS_TO_XCVR |
| ⊡      | Features                          |                        |                           |           |                                |                   | PF_T         | X_PLL        |
|        | Enable Dynamic Reconfiguration In | terface (DRI)          |                           |           |                                |                   |              |              |

Normal Mode configures the TX PLL to default operation based on the clock Inputs/Outputs setting. Whereas, Jitter Cleaning mode customizes the attenuation coefficients for the pre-defined standards to be used where the recovered clock can be used as a TX reference clock to meet protocol jitter specifications.

### Figure 2-12. Clock Options

| Ξ | Clock Options          |                                                  |           |                     |
|---|------------------------|--------------------------------------------------|-----------|---------------------|
|   | _                      |                                                  |           |                     |
|   | Normal Mode            |                                                  |           |                     |
|   | O SSCG Modulation      |                                                  |           |                     |
|   | C Jitter Cleaning Mode | 10G SyncE 32Bit                                  |           |                     |
|   |                        | F Enable Jitter Attenuation PLL at power-up      |           |                     |
|   |                        | Jitter Attenuation PLL Reference Clock Frequency | 125       | MHz                 |
|   |                        | Jitter Attenuation PLL Reference Clock Source    | Dedicated | $\overline{\nabla}$ |
|   |                        |                                                  |           |                     |

5. Click **Spread Spectrum** clock generation mode (Not available prior to Libero SoC v12.3). This feature allows spread-spectrum generation to be enable from the transmit phase-locked loop. See respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet for more information on spread spectrum specifications.

### Figure 2-13. Spread Spectrum Clock Generation Enable

| Transmit PLI | L SSCG Modulation                |                          |                           |           |                                 |                  |
|--------------|----------------------------------|--------------------------|---------------------------|-----------|---------------------------------|------------------|
|              |                                  |                          |                           |           |                                 |                  |
| 🗆 Clo        | ock Inputs/Outputs               |                          |                           |           |                                 |                  |
|              | Configure Tx PLL in Integer Mode |                          |                           |           | Tx PLL configured in Fractiona  |                  |
| Desi         | ired Output Bit Clock            | 10000.000                | Mbps                      |           | Desired Output Bit Clock Freque | ncy 5000.000 MHz |
| Refe         | erence Clock Frequency           | 20.000000                | MHz                       |           |                                 |                  |
| Refe         | erence Clock Source              | Fabric                   | •                         |           |                                 |                  |
| Band         | dwidth                           | Low                      | •                         |           |                                 |                  |
|              |                                  | ,                        | _                         |           |                                 |                  |
| 🗆 Clo        | ock Options                      |                          |                           |           |                                 |                  |
| 01           | Normal Mode                      |                          |                           |           |                                 |                  |
| • •          | SSCG Modulation                  |                          |                           |           |                                 |                  |
| 01           | Jitter Cleaning Mode             | 10G SyncE 32Bit          | <b>v</b>                  |           |                                 |                  |
|              |                                  | Enable Jitter Atten      | uation PLL at power-up    |           |                                 |                  |
|              |                                  | Jitter Attenuation PLL F | Reference Clock Frequency | 125       |                                 | MHz              |
|              |                                  | Jitter Attenuation PLL F | Reference Clock Source    | Dedicated |                                 | <b>v</b>         |

6. Select SSCG mode to enable the SSCG Modulation Feature tab. Figure 2-14. Spread Spectrum Modulation Options

| Transn | nit PLL SSCG Modulation                           |                      |
|--------|---------------------------------------------------|----------------------|
| Ξ      | Modulation Frequency                              |                      |
|        | Target: 64<br>Calculated: 52,0833                 | KHz<br>KHz           |
|        |                                                   |                      |
| Ξ      | Spread Mode                                       |                      |
|        | O Down Spread                                     |                      |
|        | <ul> <li>Center Spread</li> </ul>                 |                      |
| Ξ      | Spread / Divval                                   |                      |
|        | Spread                                            |                      |
| Ξ      | Wave Table                                        |                      |
|        | Internal (128)     Pseudo-random Noise Modulation | n Source Pattern 0 💌 |
|        | Enable Random Noise Filter                        |                      |

Click **OK** after making desired selections.
 For more information about Spread Spectrum, see 1.5.2 Spread Spectrum Clocking.

## Table 2-4. Spread Spectrum

|                                          | Options                     | Default     | Details                                                                                                                 |  |  |  |
|------------------------------------------|-----------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Modulation Frequency                     |                             |             |                                                                                                                         |  |  |  |
| Target                                   | User entry                  | 64 KHz      | Target Spread Spectrum modulation.                                                                                      |  |  |  |
| Calculated                               |                             | 60.0962 KHz | Calculation is based on TXPLL reference clock settings.                                                                 |  |  |  |
| Spread Mode                              | Down spread/Center Spread   | Down        | Configures the modulation style                                                                                         |  |  |  |
| Spread/Divval                            |                             |             |                                                                                                                         |  |  |  |
| Spread                                   | Pull down                   | 0           | Sets up to 32 divider settings (0, 01.,3.1). This value sets the percent of modulation amplitude down or center spread. |  |  |  |
| Wave Table                               |                             | 1           | ·                                                                                                                       |  |  |  |
| Internal (128)                           |                             | Enabled     | Selects internal 128 point triangle wave                                                                                |  |  |  |
| Pseudo-random Noise Modulation<br>Source |                             | Disabled    | Selection between 3 predefined modulation patterns.                                                                     |  |  |  |
| Enable Random Noise Filter               | Enable/Disable <sup>1</sup> | Disabled    | Enable to turn on filtering to reduce jitter if needed.                                                                 |  |  |  |
|                                          |                             |             |                                                                                                                         |  |  |  |

(1) When pseudo-random noise modulation source is enabled after the user selects one of the predefined modulation patterns. The optional high pass filtered PRBS is modulated to the PLL reducing the harmonic frequency amplitude peaks.

For more information about jitter cleaning operation, see 1.5.4.2 Jitter Attenuator.

 Click Enable Dynamic Reconfiguration Interface (DRI) checkbox to add the ports needed to connect the Transmit PLL to the DRI. See PolarFire FPGA and PolarFire SoC FPGA Device Power-Up and Resets User Guide for more information about DRI usage and specifications.

| .g                              |   | <br>                                 |
|---------------------------------|---|--------------------------------------|
| Transmit PLL SSCG Modulation    |   |                                      |
|                                 |   |                                      |
| Clock Inputs/Outputs            |   |                                      |
| Configure Tx PLL in Integer Mod | e | Tx PLL configured in Fractional Mode |

| Configure Tx PLL in Integer Mode |                        |                           |          | Tx PLL configured in Fraction  | al Node           |              |              |
|----------------------------------|------------------------|---------------------------|----------|--------------------------------|-------------------|--------------|--------------|
| Desired Output Bit Clock         | 10000.000              | Mbps                      |          | Desired Output Bit Clock Frequ | ency 5000.000 MHz |              |              |
| Reference Clock Frequency        | 20.0000000             | MHz                       |          |                                |                   |              |              |
| Reference Clock Source           | Fabric                 | -                         |          |                                |                   |              |              |
| Bandwidth                        | Low                    | •                         |          |                                |                   |              |              |
|                                  |                        |                           |          |                                |                   |              |              |
| Clock Options                    |                        |                           |          |                                |                   |              |              |
| Normal Mode                      |                        |                           |          |                                |                   |              |              |
| SSCG Modulation                  |                        |                           |          |                                |                   |              |              |
| C Jitter Cleaning Mode           | 10G SyncE 32Bit        | Ψ                         |          |                                |                   |              |              |
|                                  | 🗹 Enable Jitter Atten  | uation PLL at power-up    |          |                                |                   | DE .         |              |
|                                  | Jitter Attenuation PLL | Reference Clock Frequency | 25       |                                | MHz               | PF_          | TX_PLL_0     |
|                                  | Jitter Attenuation PLL | Reference Clock Source    | edicated |                                | Ψ.                | -FAB REF CLK |              |
|                                  |                        |                           |          |                                |                   | TXPLL_DRI    | CLKS_TO_XCVR |
| Features                         |                        |                           |          |                                |                   | PF           | _TX_PLL      |
| able Dynamic Reconfiguration Ir  | nterface (DRI)         |                           |          |                                |                   |              |              |
|                                  |                        |                           |          |                                |                   |              |              |

9. Click **OK** after making desired selections.

The TxPLL supports an additional clock output. This CLK\_125 output port is automatically exposed when TxPLL BIT\_CLK is 5 Gbps. This clock is used with the PCIE macro as input to the transaction layer or AXI clock. For more information about CLK\_125, see PolarFire FPGA and PolarFire SoC FPGA PCI Express User Guide.

| Figure | 2-16. | CLK | 125 | GUI |
|--------|-------|-----|-----|-----|
|        |       |     |     |     |

Ξ

| Tran | ismit PLL                      |                    |                        |                 |                                |                    | 1           |
|------|--------------------------------|--------------------|------------------------|-----------------|--------------------------------|--------------------|-------------|
| E    | Clock Inputs/Outputs           |                    |                        |                 |                                |                    |             |
|      | Configure Tx PLL in Integer M  | ode                |                        |                 |                                |                    |             |
|      | Desired Output Bit Clock       | 5000               | Mbps                   |                 | Desired Output Bit Clock Frequ | uency 2500.000 MHz |             |
|      | Reference Clock Frequency      | 200                | MHz                    |                 |                                |                    |             |
|      | Reference Clock Source         | Dedicated          | •                      |                 |                                |                    |             |
|      | Bandwidth                      | Low                | •                      |                 |                                |                    |             |
|      |                                |                    |                        |                 |                                |                    |             |
| E    | Clock Options                  |                    |                        |                 |                                |                    |             |
|      | Normal Mode                    |                    |                        |                 |                                |                    |             |
|      | C SSCG Modulation              |                    |                        |                 |                                |                    |             |
|      | C Jitter Cleaning Mode         | 10G SyncE 32Bit    |                        | Ψ.              |                                |                    |             |
|      |                                | F Enable Jitter A  | ttenuation PLL at powe | r-up            |                                |                    | PF_TX_PLL_0 |
|      |                                | Jitter Attenuation | PLL Reference Clock Fr | equency 125     |                                | MHz                | PLL_LOCK-   |
|      |                                | Jitter Attenuation | PLL Reference Clock Se | ource Dedicated |                                | Ψ.                 |             |
|      |                                |                    |                        |                 |                                |                    |             |
| E    | Features                       |                    |                        |                 |                                |                    | PF TX PLL   |
|      | 🗌 Enable Dynamic Reconfigurati | on Interface (DRI) |                        |                 |                                |                    |             |

**Note:** PLL\_LOCK port is automatically exposed as an output port on the TXPLL block. It is the PLL lock indicator signal that can be used to drive logic in the fabric. It is a fabric routed signal.

# 2.1.3 Transceiver Interface Configurator

The Transceiver Interface Configurator is used to build the transceiver based on protocol requirements. The user selects the number of lanes, data rate, and protocol-specific settings.

To initiate the Transceiver Interface Configurator, perform the following steps:

1. Access the **Transceiver Interface** module under **Features** from the **Catalog** window, as shown in the following figure.

|                                                         |                           | θ × Reports θ × StartPage θ × So test* θ ×                                             |
|---------------------------------------------------------|---------------------------|----------------------------------------------------------------------------------------|
| italog                                                  |                           | 🐻 🗸 🔀 🗗 📴 🕅 😋 📅 🖓 🔊 🖉 🖉 🖉 💥 🍳 🔍 🐼 👯 🔍 🔍 🐼 🖤 🖬 🗛 🛃 Fitter Nets: 👘 🗆 🗤 Show Only BF Nets |
| XEVF                                                    | 🔍 🔹 🦷 Simulation Mode 🛛 🔹 |                                                                                        |
| ne                                                      | 🛆 Version                 |                                                                                        |
| 1/0                                                     |                           |                                                                                        |
| Transceiver Reference Clock                             | 1.0.103                   |                                                                                        |
| Peripherals                                             |                           |                                                                                        |
| Core10GBaseR_PHY                                        | 2.0.105                   | PF_XCVR_ERM_C0_0                                                                       |
| - CoreLSM                                               | 2.2.101                   |                                                                                        |
| - CoreSmartBERT                                         | 2.8.101                   |                                                                                        |
| — 🖛 CoreXAUI                                            | 2.1.101                   | -CTRL_CLK                                                                              |
| CoreXAUI                                                | 2.0.133 (*)               | - CHRE_CER                                                                             |
| Transceiver Interface                                   | 3.1.107                   | CTDL ADCT N                                                                            |
| PolarFire Features                                      |                           | -CTRL_ARST_N                                                                           |
| - CoreSmartBERT                                         | 2.8.101                   | PADs_OUT                                                                               |
| Transceiver Interface                                   | 3.1.107                   | PADs_IN                                                                                |
| Transceiver Reference Clock                             | 1.0.103                   | LANEO_TXD_N                                                                            |
| User Defined                                            |                           | LANEO RXD N LANEO RXD N                                                                |
| PF_XCVR_APBLINK_V                                       | 1.0.101                   | LANEO_TXD P                                                                            |
|                                                         |                           |                                                                                        |
|                                                         |                           | LANEO OUT                                                                              |
|                                                         |                           | CLKS_FROM_TXPLL_0                                                                      |
|                                                         |                           |                                                                                        |
|                                                         |                           |                                                                                        |
| umentation:                                             |                           | - LANEO_IN                                                                             |
| 677: PolarFire FPGA Transceiver User Guide              |                           |                                                                                        |
| 687: PolarFire FPGA 1G Ethernet Solutions User Guide    |                           |                                                                                        |
| 727: PolarFire FPGA 10G Ethernet Solutions User Guide   |                           | PF XCVR ERM C0                                                                         |
| cription: Transceiver Interface - Enhanced Receiver Mar | nagement                  |                                                                                        |
|                                                         |                           |                                                                                        |
|                                                         |                           |                                                                                        |
| New cores are available                                 | Download them now!        |                                                                                        |

Figure 2-17. Transceiver Interface Selection From Catalog

2. Double-click each PF\_XCVR block in the catalog to launch the configurator. A GUI allows the option to select the related XCVR properties.

| Figure 2-18 | . Transceiver | Interface | <b>Configuration GUI</b> |
|-------------|---------------|-----------|--------------------------|
|-------------|---------------|-----------|--------------------------|

|                 |                             |                         |                                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|-----------------------------|-------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GBASE-R         | General                     |                         |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| GBASE-KR        | Transceiver mode            | Tx and Rx (Full Duplex) | Enhanced receiver management               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| SMIL            | Number of lanes             |                         | Receiver calibration None (CDR)            | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SGMII           | Humber of Rifes             | 1.                      | Incrementally recalibrate data eve         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RI Rate 1       |                             |                         | Incrementally recalibrate DFE coefficients |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PRI Rate 2      |                             |                         |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RI Rate 3       | PMA Settings                |                         |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PRI Rate 4      |                             |                         | RX data rate 5000 Mbos                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PRI Rate 5      | TX data rate                | 5000 Mbps               |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PRI Rate 6      | TX clock division factor    | 1                       | RX CDR lock mode                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PRI Rate 7      | TX PLL base data rate       | 5000.000 Mbps           | RX CDR reference clock source Dedicated    | PF XCVR 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| PRI Rate 8      | TX PLL bit clock frequency  | 2500.000 MHz            | RX CDR reference clock frequency 125.0 MHz |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| DI 3G           |                             |                         | RX JA clock frequency 125 MHz              | -CTR_CAX<br>-CTR_ARST_N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| DIHD            |                             |                         |                                            | TAXS FROM TYPE 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| DI SD           | PCS Settings                |                         |                                            | EPADe_IN LANED_OU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| terlaken 6.25G  | TX PCS-Fabric interface wid | th 40 • bits            | RX PCS-Fabric interface width 40 v bits    | the first of the second s |
| terlaken 10G    |                             |                         |                                            | PF_XCVR::PF_XCVR_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| AUI             | TX FPGA interface frequency | 125 MHz                 | RX FPGA interface frequency 125 MHz        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| oply New preset | PMA Mode                    |                         |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 | Enable CDR Bit-sl           | p port                  |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 | 2 8b10b Encoding/Decodin    | 9                       |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 | G4b6xb Gear Box             |                         |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 | G 64b66b                    |                         | C 64b67b                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 | Enable Disparity            |                         | Enable BER monitor state machine           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 | Enable Scrambler            | /Descrambler            | Enable 32 bits data width                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                 | Soft PIPE Interface         |                         |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

The following tables list Transceiver Interface options.

Table 2-5. Transceiver Interface General Settings

| General                         | Options                                                                                                                                                      | Default                 | Details                                                                                                             |  |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------|--|
| Number of lanes                 | er of lanes 1 to 4                                                                                                                                           |                         |                                                                                                                     |  |
| Transceiver mode                | Tx and Rx (Full Duplex)                                                                                                                                      | Tx and Rx (Full Duplex) | See 2.2 Transceiver Modes for more information.                                                                     |  |
|                                 | Tx Only                                                                                                                                                      |                         |                                                                                                                     |  |
|                                 | Rx Only                                                                                                                                                      |                         |                                                                                                                     |  |
|                                 | Tx and Rx (Independent)                                                                                                                                      |                         |                                                                                                                     |  |
| Enhanced Receiver<br>Management | Enable/Disabled                                                                                                                                              | Enabled                 | Includes the enhanced receiver management solution when checkbox is checked (See 1.2 Enhanced Receiver Management). |  |
| Receiver Calibration            | None (CDR),<br>On-Demand,<br>On-Demand & First Lock, and None (DFE),<br>Incrementally Recalibrate Data Eye and<br>Incrementally Recalibrate DFE Coefficients | On-Demand & First Lock  | See 1.1.1 Receiver.                                                                                                 |  |

#### Table 2-6. Transceiver Interface PMA Settings

| PMA Settings                                  | Options                                                                                                     | Default      | Details                    |
|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------|--------------|----------------------------|
| Tx data rate                                  | 250 Mbps – 12700 Mbps                                                                                       | 5000 Mbps    | 10312.5 Mbps (STD maximum) |
| TX clock division factor                      | 1, 2, 4, 8, and 11                                                                                          | 1            | _                          |
| TXPLL base data rate                          | Computed <sup>1</sup>                                                                                       | _            | —                          |
| TX PLL bit clock frequency                    | Computed                                                                                                    | _            | —                          |
| RX Data rate                                  | 250 Mbps – 12700 Mbps                                                                                       | 5000 Mbps    | 10312.5 Mbps (STD maximum) |
| RX CDR lock mode                              | Lock to reference, Lock to data, Burst Mode $\mbox{Receiver}^2,\mbox{ lock to data with } 2x\mbox{ gain}^3$ | Lock to data | —                          |
| RX CDR reference clock source                 | Dedicated and fabric                                                                                        | Dedicated    | _                          |
| RX CDR reference clock frequency <sup>4</sup> | Based on transceiver data rate                                                                              | _            | -                          |
| RX JA Clock Frequency                         | Calculated based on configuration                                                                           | _            | _                          |

(1) Enter the transceiver data rate (lane rate), and the TX clock division factor in the XCVR UI. Based on these settings, the TX\_PLL base data rate is calculated. The TX\_BIT\_CLK frequency is half of the TX\_PLL base data rate. The TX\_PLL base data rate must be entered under the desired output clock option of the PF\_TX\_PLL block. The PF\_TX\_PLL generates the BIT\_CLK output (connected to the TX\_BIT\_CLK\_0/1 input of PF\_XCVR).

(2) When Burst Mode Receiver (BMR) is selected, LANE\_X\_CDR\_LOCKMODE[1:0] port is exposed.

(3) Default Gain, slower CDR lock time, lower jitter tolerance 2x Gain, faster CDR lock time, higher jitter.

<sup>(4)</sup> This input frequency is given by the user to support the integer feedback divider of the receiver PLL. From the drop-down, enter a CDR reference clock frequency (MHz) value equal to the reference clock used to the Receiver PLL. The computation derives the feedback divider used to clock the receiver data path.

#### Table 2-7. Transceiver Interface PCS Settings

| PCS Settings                          | Options                                        | Default              | Details                                                                              |
|---------------------------------------|------------------------------------------------|----------------------|--------------------------------------------------------------------------------------|
| PCS-fabric interface width            | 8, 10, 16, 20, 32, 40, 64, and 80 <sup>1</sup> | 40                   | _                                                                                    |
| FPGA interface frequency <sup>2</sup> | Computed                                       | -                    | -                                                                                    |
| PMA Mode                              | Enable CDR Bit-slip port                       | Enable               | -                                                                                    |
| 8b10b encoding/decoding               | None                                           | -                    | -                                                                                    |
| 64b6xb gear box                       | 64b66b<br>64b67b                               | 64b66b               | If 64b6xb mode is enabled, then PCS-Fabric interface width must be 32-<br>or 64-bit. |
| 64b66b gear box                       | Enable disparity                               | Disabled             | Enabled for 64b67b - Optional for 64b66b gear box.                                   |
|                                       | Enable scrambler/de-scrambler                  | Disabled             | _                                                                                    |
|                                       | Enable BER monitor state machine               | Disabled             | -                                                                                    |
|                                       | Enable 32 bits data width                      | Disabled             | _                                                                                    |
| 64b67b gear box                       | Enable BER monitor state machine               | Disabled             | Enable 32 bits data width                                                            |
|                                       | Enable Disparity                               | Enabled              | Cannot be enabled for 64b66b                                                         |
|                                       | Enable Scrambler/de-scrambler                  | Disabled             | -                                                                                    |
|                                       | Enable 32 bits data width                      | Disabled             | -                                                                                    |
| Soft PIPE interface                   | PCle Gen1 (2.5Gbps)<br>PCle Gen2 (5.0Gbps)     | PCIe Gen1 (2.5 Gbps) | —                                                                                    |

(1) Dependent on PCS settings.

(2) TX\_CLK\_G/R frequency = RX\_CLK\_G/R frequency = FPGA Interface frequency = data rate/(PMA-PCS width × PCS Gearing).

#### Table 2-8. Clocks and Resets

| Interface Options                               | Options                                                                 | Default                        | Details                                                                                                                                                                                                      |
|-------------------------------------------------|-------------------------------------------------------------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interface clock Use as PLL reference clock Disa |                                                                         | Disabled                       | When Use as PLL reference clock is selected, this exposes additional ports that permit connection to the PLL REFCLKs.<br>LANEn_TX_CLK_TO_PLL_REFCLK                                                          |
|                                                 |                                                                         |                                | LANEn_RX_CLK_TO_PLL_REFCLK                                                                                                                                                                                   |
|                                                 |                                                                         |                                | This allow designs that require gearing other than 2:1 with wider fabric interfaces and use dedicated routing to the PLL. This is used in place of CLKDIV, which does not have the dedicated routing to PLL. |
| TX clock                                        | Global, Regional,<br>Regional (Deterministic),<br>Global Shared         | Regional                       | See Table 1-16                                                                                                                                                                                               |
| RX clock                                        | Global, Regional,<br>Regional (Deterministic),<br>Global Shared, and NA | Regional                       | NA option must be selected when the PCS is configured in Soft PIPE mode (PCIe). See Table 1-16                                                                                                               |
| Interface Resets                                | PMA Reset <sup>1</sup>                                                  | TX and RX                      | -                                                                                                                                                                                                            |
|                                                 | PCS Reset                                                               | Tx Only, Rx<br>Only, Tx and Rx | RX Only – only RX side can be reset from the fabric.<br>TX Only – only TX side can be reset from the fabric.                                                                                                 |
|                                                 |                                                                         |                                | TX and RX – both RX and TX sides can be reset from the fabric.                                                                                                                                               |
| Optional Ports                                  | Enable/Disable                                                          | -                              | TX_BYPASS port/TX_ELEC_IDLE port.<br>See Table 1-10 or Table 1-12.                                                                                                                                           |
|                                                 |                                                                         |                                | RX_READY_CDR and RX_VAL_CDR ports.<br>See 1.2 Enhanced Receiver Management.                                                                                                                                  |
|                                                 |                                                                         |                                | JA_CLK port. See 1.5.4.2 Jitter Attenuator.                                                                                                                                                                  |
| Dynamic<br>Reconfiguration                      | Enable Dynamic<br>Reconfiguration Interface<br>(DRI)                    | Disabled                       | _                                                                                                                                                                                                            |

<sup>(1)</sup> The minimum pulse width required is 16 clock cycles.

Preset configurations are available within the **Transceiver Interface** Configurator to speed up the transceiver configuration. Factory provided presets are available with the Libero release. Additionally, customized presets can be saved. See 2.2 Transceiver Modes for more information.

- 3. Select **Number of lanes** from 1 to 4 in the general settings configuration.
- 4. Enter the **Transceiver data rate** and select one of the **TX clock division factors**. The **TX PLL base data rate** is calculated in the GUI. The calculated TX PLL base data rate must be entered under the desired output clock option inside the PF\_TX\_PLL configurator. LANE#\_TX\_PLL\_REF\_CLK\_#, LANE#\_TX\_BIT\_CLK\_0, and LANE#\_TX\_PLL\_LOCK\_# are included in CLKS\_FROM\_TXPLL\_# BIF (bus interface). This connection is required between the TXPLL and Transceiver Interface.
- 5. Select the desired **CDR reference clock mode** and **CDR reference clock frequency** from the drop-down list based on the application.

**Note:** CDR reference clock frequency drop-down list is populated with valid frequencies based on the data rate.

- Select the CDR reference clock source based on the design requirements. The dedicated clock adds a dedicated CDR\_REF\_CLK port whereas the fabric port only includes a port that can be connected to the fabric resources. The dedicated CDR\_REF\_CLK\_0/1 port must be connected to the REF\_CLK or REF\_CLK\_0/1 output of the PF\_XCVR\_REF\_CLK block.
- Select PCS-Fabric interface width from the GUI. This selection computes the FPGA interface frequency. The FPGA interface frequency is calculated based on the transceiver data rate, PCS-Fabric width, and the PCS settings/mode.
- 8. Click the GUI radio button to select the desired PCS mode. See 1.3 Transceiver PCS Interface Modes for more information on PCS mode.
- 9. Select the desired interface clock options in the Interface Options GUI. See 1.4 PCS/FPGA Fabric Interface.
- 10. For PMA Only modes CDR Bit-slip, select the **Enable CDR Bit-slip port** to add the LANE#\_RX\_SLIP pin.

### Figure 2-19. PMA Mode—Enable CDR Bit-Slip Port

PMA Mode

 Image: Enable CDR Bit-slip port

### Figure 2-20. XCVR Component With CDR Bit-Slip Port Enabled

| PF_X                                    | CVR_0               |
|-----------------------------------------|---------------------|
| CLKS_FROM_TXPLL_0                       | PADs_OUT            |
| ⊟PADs_IN                                | LANE0_TXD_N         |
| → LANE0_RXD_N                           | LANE0_TXD_P         |
| - PLANEO_RXD_P                          | LANE0_OUT           |
| ⊟LANE0_IN LA                            | NE0_RX_BYPASS_DATA  |
| <ul> <li>LANE0_CDR_REF_CLK_</li> </ul>  | 0 LANEO_RX_CLK_R    |
| – ►LANE0_PCS_ARST_N                     | LANE0_RX_DATA[39:0] |
| LANEO_PMA_ARST_N                        | LANE0_RX_IDLE       |
| LANEO_RX_SLIP                           | LANE0_RX_READY      |
| LANEO_TX_BYPASS_DA                      | TA LANEO_RX_VAL     |
| <ul> <li>LANE0_TX_DATA[39:0]</li> </ul> | LANEO_TX_CLK_R      |
| LANEO_TX_ELEC_IDLEI                     | LANEO_TX_CLK_STABLE |
| PF_XCVR::                               | PF_XCVR_0           |

**Note:** For information about RX\_SLIP, see 1.1.1.7 Bit Slip.

### Figure 2-21. XCVR Component With BMR Port Enabled



**Note:** For information about CDR\_LOCKMODE pins, see burst mode receiver in 1.1.1.6.1 CDR Options.

11. Select the **Enable Dynamic Reconfiguration** to add the LANE#\_DRI\_SLAVE pins. See 5.3 Dynamic Reconfiguration Interface for usage details.

Figure 2-22. XCVR Component With DRI Port Enabled



12. After making all of the selections in the Transceiver Interface Configurator, click **OK**.

When the transceiver interface configuration is complete, a PF\_XCVR macro is generated by the Libero Software. The macro includes the ports based on the configuration. Figure 2-23 to Figure 2-27 shows sample PCS macros. The PF\_XCVR macro is instantiated into the user design to customize the connectivity of the application.





















After building the PF\_XCVR, PF\_TX\_PLL, and PF\_XCVR\_REF\_CLK cores, the transceiver subsystem must be connected together in the SmartDesign canvas. Typically, the REF\_CLK and/or FAB\_REF\_CLK outputs of the PF\_XCVR\_REF\_CLK are connected to the respective inputs of the PF\_XCVR and the input REF\_CLK of the PF\_TX\_PLL. LANE#\_TX\_PLL\_REF\_CLK\_#, LANE#\_TX\_BIT\_CLK\_0, and LANE#\_TX\_PLL\_LOCK\_# are included in CLKS\_FROM\_TXPLL\_# BIF (bus interface). This connection is required between the TXPLL and transceiver interface. The SmartDesign component must then be generated.









See the port list tables in 1.3 Transceiver PCS Interface Modes for complete pin descriptions generated with the Transceiver Configurator.

# 2.2 Transceiver Modes

The transceiver architecture permits several ways to use the transmit and receive portions of the PMA and PCS. A TXPLL is not instantiated by the Transceiver configurator. The user must instantiate the TXPLL. The Transceiver configurator gives the user options to use the Tx and Rx together or independently or alone. The transceiver modes

require the user to input the specific design requirements to generate the transceiver block. The modes also define the operation of the PMA\_ARSTN and PCS\_ARSTN pins and how these pins reset the transceiver functionality.

| Figure 2-30 | . Transceiver | Modes | shown i | in Trar | nsceiver GUI |
|-------------|---------------|-------|---------|---------|--------------|
|-------------|---------------|-------|---------|---------|--------------|

| _ |                                          |                                                                 |      |                                                        |            |      |
|---|------------------------------------------|-----------------------------------------------------------------|------|--------------------------------------------------------|------------|------|
|   | General                                  |                                                                 |      |                                                        |            |      |
|   | Transceiver mode<br>Number of lanes      | Tx and Rx (Full Duplex) Tx and Rx (Full Duplex) Tx only Rx only |      | ☑ Enhanced receiver management<br>Receiver calibration | None (CDR) | ]    |
| Ξ | PMA Settings                             | Tx and Rx (Independent)                                         | 1    |                                                        |            |      |
|   | TX data rate<br>TX clock division factor | 5000                                                            | Mbps | RX data rate<br>RX CDR lock mode                       | 5000       | Mbps |
|   | TX PLL base data rate                    | 5000.000                                                        | Mbps | RX CDR reference dock source                           | Dedicated  | 3    |
|   | TX PLL bit clock frequency               | 2500.000                                                        | MHz  | RX CDR reference clock frequency                       | 125.00     | MHz  |
|   |                                          |                                                                 |      | RX JA dock frequency                                   | 125        | MHz  |

## 2.2.1 Full-Duplex Mode

Tx and Rx Duplex support is the most common use of the transceiver and often referred to as full-duplex. It is defined as the mode where the Rx and Tx portions of the PMA share resources such as clocking and reset functions. Full duplex uses a common clock for both the Tx and Rx, that is, the base rates and PCS widths are the same. Both PMA\_ARSTN and PCS\_ARSTN resets both the Tx and Rx of the PMA and PCS, respectively.

Full-duplex configures the XCVR with common Tx and Rx data rates. Although, users can see independent control for data rate and PCS-Fabric widths, a Libero SoC DRC prevent users from selecting different rates/widths when TX and RX is in full-duplex mode. In full-duplex mode, the user must match the Rx and Tx requirements.

### 2.2.2 Half-Duplex Mode

Another mode of the transceiver is half-duplex mode. It is defined by allowing parts of the Rx and Tx to operate independently. Half duplex modes optimize the use of lanes within XCVR quads by allowing the separation of Rx and Tx within a lane. To address the half-duplex modes, the following options are available to transceiver.

- Tx only
- Rx only
- Tx and Rx (Independent)

When users select Tx only or Rx only option, then one physical XCVR lane is completely used, and the un-used Rx or Tx cannot be used. When user select Rx only in the GUI, the Tx GUI options is marked as N/A for display purposes. In the same way, when user select Tx only in GUI, the Rx GUI options is marked as N/A for display purposes. However, in both cases, the un-used Tx or Rx parameters are still set to some valid values in the generated core (based on the default parameter values from core). PMA\_ARSTN resets both the Tx and Rx of the PMA, however, the PCS\_ARSTN will reset the TX only or Rx only accordingly.

If users intend to implement two independent half-duplex channels in the same physical XCVR lane then select the 'Tx and Rx (Independent)' option in Transceiver mode. By using 'Tx and Rx (Independent)' option, users can specify a different data rate for RX channel and TX channel. When configured Tx and Rx (Independent), an additional input pin (LANE#\_CLK\_REF) is exposed on the component. See the related port list for pin definition. Additionally, the PCS-FABRIC width can also be different between RX and TX. However, if half-duplex applications are to be merged into one XCVR lane, then both applications must use the same basic mode of the PCS. The reason for this is, system register control for steering the data path among the four basic modes (PIPE, 64B6xB, 8B10B, NATIVE/PMA) is shared for TX and RX.

Libero SoC programs the appropriate registers within the transceiver to power-down the serializer or de-serializer in Tx only /Rx only Transceiver modes.

### Table 2-9. PCS Modes Supported

| Transceiver Mode        | PCS Mode supported       |
|-------------------------|--------------------------|
| Tx and Rx (Full Duplex) | PMA, 8b10b, 64b6xb, PIPE |
| Tx only                 | PMA and 8b10b            |

| continued               |                    |  |  |  |
|-------------------------|--------------------|--|--|--|
| Transceiver Mode        | PCS Mode supported |  |  |  |
| Rx only                 | PMA and 8b10b      |  |  |  |
| Tx and Rx (Independent) | PMA mode           |  |  |  |

Tx only, Rx only, and Tx and Rx (Independent) modes are supported only in PMA mode. In 8b10b mode, both Tx and Rx must use the same fabric interface width. Tx/Rx Independent option PCS mode applies for both Tx and Rx and cannot be different within the lane. For example, the Tx cannot be 8b10b when the Rx is 64b66b.

The TXPLL supports Fractional-N frequency synthesizer, and the CDR PLL only supports integer-based synthesis. Typically, the same REFCLK is used for both the TXPLL and CDR PLL for full-duplex lane. The user has the option to use integer-based for the TXPLL if the frequency is achieved without issue.

If the TXPLL uses Frac-N rather than integer-based to synthesize the bit clock, the CDR PLL will not have the Frac-N capability. Consequently, the user needs to determine if the PPM tolerance of the CDR is enough to compensate for the TXPLL rate.

# 2.3 Libero Generated Files

Libero SoC software automatically generates the required files after stepping through the design entry steps of the transceiver. The following files are created:

- Netlist file—the RTL netlist instantiates the transceiver macros and related RTL wrappers based on protocol specific functions.
- <design name>.sdc file—Timing constraints file in the case of TXPLL and XCVR configurators.
- <module name>.v, \_syn\_comps.v, \_pre\_comps.v
  - HDL source files for all Synthesis and Simulation tools.
  - HDL source files for Synopsys SynplifyPro Synthesis tool.
  - HDL source files for Mentor Precision Synthesis tool.

**Note:** The entire file list and their file paths are maintained in mainfest.txt at <Project Directory>/component/work/ <Component name>/\*\_manifest.txt files.

**Note:** XCVR and PCIESS initialization data is available in the generated netlists of the TXPLL, XCVR, and PCIE blocks. This is used to configure the blocks specifically for users design customization. See 2.6 Transceiver Initialization.

# 2.4 Design Constraints

Design constraints are either requirements or properties in the design. Constraining ensures transceiver designs meets their performance goals, embedded block locations, and pin assignment requirements.

The software supports timing, physical, and netlist optimization constraints for the transceivers. Design constraints can be set by either using Microsemi's interactive tools or by importing constraint files directly into the design session.

### 2.4.1 Timing Constraints

Timing constraints for the designs are required to meet the performance goals of the transceiver interface. Specify timing constraints directly in the SDC or by using the timing constraints editor. The following timing constraints must be methodically introduced into the design. Libero assists by automatically generating timing constraints related to transceiver clock usage.

A component-level SDC file is created for every XCVR instance, which is pulled into the SDC file created for the entire Libero design project as shown in the following example.

#### CDR reference clock source

#### Dedicated

```
create_clock -period <T> [get_pins {LANE<n>/REF_CLK_P}]
```

#### Fabric

create\_clock -period <T> [get\_pins {LANE0<n>RX\_REF\_CLK}]

#### Interface clock

#### Global

create\_clock -period <T> [get\_pins {LANE<n>/TX\_CLK\_G}]
create\_clock -period <T> [get\_pins {LANE<n>/RX\_CLK\_G}]

#### **Regional or Regional (Deterministic)**

create\_clock -period <T> [get\_pins {LANE<n>/TX\_CLK\_R}]
create\_clock -period <T> [get\_pins {LANE<n>/RX\_CLK\_R}]

#### Global-shared Mode

```
create_clock -period <T> [get_pins {LANE<n>/TX_CLK_G}]
create_clock -period <T> [get_pins {LANE<n>/RX_CLK_G}]
create_clock -period <T> [get_pins {LANE<n>/TX_CLK_R}]
create_clock -period <T> [get_pins {LANE<n>/RX_CLK_R}]
```

Users need to use the **Derived SDC** file generated by clicking the **Derive Constraints** in the **Timing** tab of the **Constraint Manager** window of Libero SoC software.

The following example shows a Libero project with transceiver.

```
create_clock -name {REF_CLK_PAD_P} -period 6.4 [ get_ports { REF_CLK_PAD_P } ]
create_clock -name {My_Project_0/my_xcvr_0/PF_XCVR_0/LANE0/TX_CLK_R} -period 16 [ get_pins
{ My_Project_0/my_xcvr_0/PF_XCVR_0/LANE0/TX_CLK_R } ]
create_clock -name {My_Project_0/my_xcvr_0/PF_XCVR_0/LANE0/RX_CLK_R } -period 16 [ get_pins
{ My_Project_0/my_xcvr_0/PF_XCVR_0/LANE0/RX_CLK_R } ]
create_clock -name {My_Project_0/my_pll_0_0/pll_xvier_0_0/txpll_isnt_0/DIV_CLK} -period 8
[ get_pins { My_Project_0/my_pll_0_0/txpll
```

#### Figure 2-31. Derive Constraints using Constraints Editor

| ſ | I/O Attributes | Timing / Floo | or Planner V Ne | tlist Attributes   |             |          |      |              |         |                     |     |      |  |
|---|----------------|---------------|-----------------|--------------------|-------------|----------|------|--------------|---------|---------------------|-----|------|--|
|   | New            | Import        | Link            | Edit with Constrai | nt Editor 🔻 | Check    | F    | Derive Const | raints  | Constraint Coverage | · _ | Help |  |
|   |                |               |                 | Synt               | thesis      | Place an | d Ro | ute Timin    | g Verit | fication            |     |      |  |

The transceiver can source three different clocks into the fabric—TX\_CLK, RX\_CLK, and the REFCLK (FAB\_REF\_CLK). These clocks contain high frequency jitter that is not reported by Libero SoC in the timing report and SmartTime. It is recommended that users add clock uncertainty constraints to these clocks in their design.

The following is a list of recommended values for clock uncertainty per clock, resource, and speed-grade.

- FAB REF CLK on Global: 275 ps for STD, 200 ps for -1
- FAB\_REF\_CLK on Regional: Not supported
- TX CLK G on Global: 300 ps for STD, 225 ps for -1
- TX CLK R on Regional: 225 ps for STD, 150 ps for -1
- RX\_CLK\_G on Global: 325 ps for STD, 250 ps for -1
- RX CLK R on Regional: 250 ps for STD, 175 ps for -1

Following is an example clock uncertainty constraint. This constraint would be added to the user's timing SDC file.

#### # TX\_CLK and RX\_CLK on Regionals

```
set_clock_uncertainty -setup 0.150 [ get_pins { PF_XCVR_ERM_LANE2/I_XCVR/LANE0/TX_CLK_R } ]
set_clock_uncertainty -setup 0.175 [ get_pins { PF_XCVR_ERM_LANE2/I_XCVR/LANE0/RX_CLK_R } ]
```

#### # TX\_CLK and RX\_CLK on Globals

```
set_clock_uncertainty -setup 0.300 [ get_pins { PF_XCVR_ERM_LANE2/I_XCVR/LANE0/TX_CLK_G } ]
set_clock_uncertainty -setup 0.325 [ get_pins { PF_XCVR_ERM_LANE2/I_XCVR/LANE0/RX_CLK_G } ]
```

### # FAB\_REF\_CLK on Global

```
set_clock_uncertainty -setup 0.275 [ get_clocks REF_CLK_PAD_P ]
```

#### 2.4.2 Physical Constraints

Transceiver designs require physical constraints. These constraints provide placement guidance for the embedded transceiver blocks such as XCVR\_REF\_CLK, XCVR\_TXPLL, and XCVR. Select the placement of the RXD and TXD transceiver pins and reference clock input pins by adding location constraints to the design PDC file. Placement fails if the XCVR lane TX and RX I/Os, XCVR\_REF\_CLK I/Os and TX\_PLL locations are not explicitly placed. The Libero I/O Editor assists with the creation of physical constraints using a GUI, see 2.5 Adding Physical Constraints Using Libero.

For physical constraining by the user, the instance name is mapped to top-level physical pins based on the device and package pin-outs found in the physical pin assignment tables (PPAT). The user provides the constraint to the PDC file as listed in the following table.

#### For XCVR Lanes:

set\_io -port\_name <port name> \-pin\_Name <package pin name> \-DIRECTION INPUT

#### For XCVR REFCLK:

set\_io -port\_name <refclk port name> \

-pin\_name <package pin>\

-DIRECTION INPUT \

-io\_std: See PolarFire FPGA and PolarFire SoC FPGA User I/O User Guide for information about available IO Standards.

-ODT VALUE: See PolarFire FPGA and PolarFire SoC FPGA User I/O User Guide for information about available ODT values.

#### Table 2-10. Physical Constraint Instances For XCVR

| XCVR Instance <sup>1</sup> | Corresponding Top-level Pins <sup>2</sup>                                                                                                     |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Q#_LANE0                   | XCVR_Q#_RX0_P/N<br>XCVR_Q#_TX0_P/N                                                                                                            |
| Q#_LANE1                   | XCVR_Q#_RX1_P/N<br>XCVR_Q#_TX1_P/N                                                                                                            |
| Q#_LANE2                   | XCVR_Q#_RX2_P/N<br>XCVR_Q#_TX2_P/N                                                                                                            |
| Q#_LANE3                   | XCVR_Q#_RX3_P/N<br>XCVR_Q#_TX3_P/N                                                                                                            |
| Q#_TXPLL_SSC               | Dependent on design clocking requirements<br>(See Figure 1-52 and Figure 1-54 for PolarFire FPGA. See Figure 1-53 for<br>PolarFire SoC FPGA.) |
| Q#_TXPLL0                  | Dependent on design clocking requirements<br>(See Figure 1-52 and Figure 1-54 for PolarFire FPGA. See Figure 1-53 for<br>PolarFire SoC FPGA.) |
| Q#_TXPLL1 <sup>3</sup>     | Dependent on design clocking requirements<br>(See Figure 1-52 and Figure 1-54 for PolarFire FPGA. See Figure 1-53 for<br>PolarFire SoC FPGA.) |

| continued                  |                                           |  |  |
|----------------------------|-------------------------------------------|--|--|
| XCVR Instance <sup>1</sup> | Corresponding Top-level Pins <sup>2</sup> |  |  |
| Q#_REFCLK_A                | XCVR_Q#A_REFCLK_P/N                       |  |  |
| Q#_REFCLK_B                | XCVR_Q#B_REFCLK_P/N                       |  |  |
| Q#_REFCLK_C                | XCVR_Q#C_REFCLK_P/N                       |  |  |

<sup>(1)</sup> Q# = Transceiver Quad identifier (Q0, Q1, and so on.)

<sup>(2)</sup> Pin-mapping to top-level pins can be found in the pin-assignment tables (PPAT) for each device and package type. For more information about PPATs, see or PolarFire SoC.

<sup>(3)</sup> For PolarFire FPGA, only TXPLL\_SSC and TXPLL0 is available for Quad4 and Quad5. Refer Figure 1-52. The default differential REFCLK value is set to 100 (-ODT\_VALUE 100). To disable the ODT value, set the value of the differential REFCLK to 0 (-ODT\_VALUE 0 in the PDC file.

### 2.4.2.1 DFE Coefficients

DFE Calibration of the DFE Coefficients is not be performed in Static DFE. See 1.1.1.9.3 DFE Calibration.

To set the required registers with static values, users must enhance the "set\_io" PDC command to add new attributes. The new attributes that need to be added are highlighted in the below PDC command.

#### PDC command example:

```
set_io -port_name LANE0_RXD_N \
-RX_DFE_COEFFICIENT_H1_20 \
-RX_DFE_COEFFICIENT_H2_20 \
-RX_DFE_COEFFICIENT_H3_20 \
-RX_DFE_COEFFICIENT_H4_20 \
-RX_DFE_COEFFICIENT_H4_20 \
-DIRECTION_INPUT
```

The RX\_DFE\_COEFFICIENT attributes are optional (applied only when Static calibration is selected). These attributes take integer values between 0 and 15. The corresponding register fields are 5 bits wide in all cases with the MSB bit reserved for sign bit.

# 2.5 Adding Physical Constraints Using Libero

The transceiver I/O pin assignments can be made with PDC commands and passed as physical design constraints to the physical layout tool. The I/O PDC constraints (for XCVR LANE RX pins, TX pins, and XCVR\_REF\_CLK pins) must be specified in an I/O PDC file. The chip plan location constraints for TXPLL must be specified in a floor plan PDC file. The I/O Editor provides a GUI tool designed to make I/O pin assignments graphically and user-friendly, as an easy alternative to writing PDC commands. When the pin assignment is committed and saved in the Pin Planner, a PDC file is created. This PDC file can then be passed to the Place and Route tool as a physical design constraint.

## 2.5.1 Invoking the Pin Planner

To invoke the Pin Planner, the design must be in the post-synthesis state.

- Invoke the Constraint Manager from the Design Flow window (Design Flow > Manage Constraints > Open Manage Constraints View).
- In the Constraints Manager, select the I/O Attributes tab and then select Edit > Edit with I/O Editor (I/O Attributes > Edit > Edit with I/O Editor). The I/O Editor opens.
   Placement View tab—Presents a physical view of the transceiver connectivity, including transceiver lanes (XCVR), Reference Clock (REFCLK), and Transmit PLLs (TxPLL).

# Figure 2-32. IO Editor GUI



The transceiver view allows you to make assignments—XCVR, REFCLK, and TxPLLs. It has two views:

- A schematic view of the REFCLK, the TXPLL, and the XCVRs they drive.
- A graphical physical view of the REFCLK, its connection from the PADS to the TXPLL and the XCVR lanes.

The schematic and physical views provide design rule guidance for selecting legal connectivity combinations between the XCVR I/O, TxPLLs, and REFCLK inputs. It provides logical mapping to the device physical resources using connection rules of the device.

# Implementation



#### Figure 2-33. XCVR Placement Tab

The following figure shows the XCVR **Signal Integrity View** tab. When user selects lane in Left Panel, the user can view and change the signal integrity parameters for the Rx and Tx transceiver ports.

| Signal I                                          | ntegrity View                                                                                                            |
|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| LANE0_TXD_P/N                                     | LANE0_RXD_P/N                                                                                                            |
| TX Emphasis Amplitude                             | RX Insertion Loss                                                                                                        |
| 400mV_with3.5dB                                   | 6.5dB                                                                                                                    |
| TX Impedance (ohms)                               | The transceiver data rate is set to 5000 Mbps for this port<br>The current settings will configure this port in CDR mode |
| TX Transmit Common Mode Adjustment (% of VDDA) 50 | Calibration None_CDR                                                                                                     |
|                                                   | RX CTLE<br>No_Peak_+2.8dB                                                                                                |
|                                                   | CDR GAIN                                                                                                                 |
|                                                   | RX Termination (ohms)                                                                                                    |
|                                                   | RX P/N Board Connection                                                                                                  |
|                                                   | AC_COUPLED_WITH_EXT_CAP                                                                                                  |
|                                                   | 1                                                                                                                        |
|                                                   | RX Loss of Signal Detector - High 3                                                                                      |
|                                                   | Polarity (P/N reversal)                                                                                                  |
|                                                   |                                                                                                                          |
|                                                   |                                                                                                                          |
|                                                   |                                                                                                                          |
| Placement View / Signal Integrity View /          |                                                                                                                          |

#### Figure 2-34. XCVR Signal Integrity Tab

For more information about tuning the transceiver signal integrity, see 3. Signal Integrity Conditioning.

# 2.6 Transceiver Initialization

The transceiver is initialized after the user customizes the transceiver or PCIe features with the associated configurators. The transceiver initialization data refers to the memory files and the initialization clients required for the three stages of initialization that is executed by the device at start-up. For proper functioning, the user design must generate initialization data before programming (running Generate Bitstream or the Export Programming File, Export Programming Job, Export Programming Job Data, Export SmartDebug Job Data, Generate SPI Flash Image, Generate SPI Flash Image, and Export SPI Flash Image).

- 1. The operations of Configuration and Generation are separated into two individual design flow steps called **Configure Design Initialization Data and Memories** and **Generate Design Initialization Data**.
- 2. Invoking the Configure Design Initialization Data and Memories opens up the initialization UI.
- 3. Clicking **Apply** in the **Design Initialization** tab only saves the configuration for initialization data, it does not generate the initialization data.

For design with transceivers, the Libero software automatically incorporates the required initialization data into the design project without any manual steps by the user. With transceiver designs, there are instances where a custom configuration file is used for cases not directly supported by Libero SoC. In these rare instances, the custom configuration file is used to compile the design to initialize the transceiver components. XCVR configuration data present in the design is initialized during power-up using initialization clients placed in the non-volatile sNVM memory. Initialization data is generated and stored in binary (\*.mem) file of the second stage client, which initializes the TXPLL, PCIe and XCVR blocks present in the design.

The programming steps (Generate Bitstream and the Export steps Export Programming File, Export Programming Job, Export Programming Job Data, Export SmartDebug Job Data and Export SPI Flash Image) depend on the Generate Design Initialization Data. Libero automatically runs the Generate Design Initialization Data, if it is not

already in pass state, when any of these programming steps are run. This ensures that initialization data is always present and up-to-date before programming.

### 2.6.1 Transceiver Initialization Data

After completion of the Libero SoC customization, the XCVR, PCIe, TxPLL, and CCCs are autonomously configured and initialized during the design generation. The register customization can be reviewed in a report generated during the **Generate Design Initialization Data** step within Libero SoC. A "configuration Report for SERDES XCVR, PCIe, CC, Transmit PLL" is generated that records the value in the related registers. The report is located in the *project\designer\impl\Design\_Initialization\_Data\_report.xml*.

# 3. Signal Integrity Conditioning

The transceivers have many tuning adjustments for the analog portions of the PMA allowing for signal integrity optimizations to the system. These features include Rx Continuous Time Line Equalization (CTLE), Rx termination, polarity inversion, Pre- and Post-cursor output emphasis, output impedance settings, and Tx amplitude adjustment. Transceivers are programmed at startup from default configuration information known to the Libero SoC software based on protocol and data rate specifics supplied by the user during design customization and generation. The Libero configurators generate the Rx and Tx default settings that initialize the transceivers at power on or device reset by toggling the DEVRSTN pin.

Other embedded transceiver features include Decision Feedback Equalization (DFE) within the receiver PMA that further corrects signal imperfections caused by PCB losses and quality of the signal being driven to the Rx. The Rx path also includes an input signal eye monitoring feature.

The user can also control the transceiver settings after device programming using the FlashPro programming cable and the SmartDebug Transceiver software utility. Transceivers have a memory mapped Dynamic Reconfiguration Interface (DRI) allowing SmartDebug to communicate with the transceiver blocks to change and monitor the transceivers in real-time. This feature provides debugging capabilities and altering of the transceivers for optimized performance in the system. After the final SmartDebug signal integrity optimization, the user can export the tuned information back into the Libero SoC software for future design regeneration.

### Figure 3-1. Signal Integrity Conditioning Flow



Building a transceiver based design using Libero SoC software flow allows flexibility to improve the transceiver performance within the system. The Libero SoC software sets initial good defaults for the user's custom design based on input information to the transceiver configurators. The user can change the associated transceiver input and output settings using the IO Editor after initial design generation. The user can further enhance the signal integrity qualities of the transceiver after design place, route, and bitstream generation by using the SmartDebug capabilities. This allows user to continue the signal integrity tuning after programming the device in the system and provides a feedback path to include the customized signal integrity settings in subsequent design regeneration.

Both the Signal Integrity views of the IO Editor and SmartDebug Transceiver present the same signal integrity settings for both the transmitter and receiver. The available settings are predefined by the factory providing a flexible means to adjust the XCVR.

### 3.1 Transmitter

The transmitter takes parallel data from the FPGA fabric through the PCS-fabric interface block and gearing logic. The data passes through the PMA-PCS interface to the serializer to create a high-speed serial data stream using the serial clock provided from the transmit PLL. For more information about transmitter, see 1.1.2 Transmitter.

### 3.1.1 Transmit Emphasis and DC Amplitude

Transmit emphasis and DC amplitude settings adjust the transmitter output drivers. The settings are provided from a drop-down menu of pre-defined combinations of Tx emphasis and DC amplitude.

The DC amplitude is adjusted by changing the driver segments to deliver a differential swing to the receiving device. The trade-off between large output-swing is power consumption and output return loss. The transmit emphasis adjusts the magnitude of the output based on the prior bit values reducing the successive bits. This transition emphasis compensates for the channel losses and opens the signal eye at the far-end receiver. This is accomplished by deemphasizing or weighting driver taps with negative dB adjustment.

Adjustment of the Tx amplitude and Tx emphasis are used to match the PCB interconnect losses. For information about Predefined Transmit Emphasis and DC Amplitude settings, see AC483: PolarFire FPGA Transceiver Signal Integrity Application Note.

### 3.1.2 Impedance (Differential)

This feature is used to add—85  $\Omega$  or 100  $\Omega$  or 150  $\Omega$ —calibrated internal impedances onto the differential outputs. This setting adjusts the impedance selected to match the system to optimize performance.

### 3.1.3 Tx Insertion Loss

Table 3-1 lists the recommended transmit amplitude and emphasis values for short, medium, and long applications. User should manually adjust the amplitude/emphasis to match the Tx channel of the PCB. For Rx, these values can be set in Libero.

### Table 3-1. Amplitude and Emphasis

| Channel Type | Amplitude (mV) | Emphasis (dB) |
|--------------|----------------|---------------|
| Short        | 400            | -3.5          |
| Medium       | 800            | -6            |
| Long         | 1000           | -6            |

### 3.1.4 Transmit Common Mode Level

Transmit common mode level is used as a percentage—50% or 60% or 70% or 80%—of full common mode level or VDDA. It is only adjusted when DC coupled (for example with SDI or high CID protocols). This is to match the common-mode restoration to the DC coupled receiver. For AC coupled systems, the level should remain as default.

### 3.2 Receiver

The receiver deserializes high-speed serial data received through the input buffer by creating a parallel data stream for the FPGA fabric and recovering the clock information from the received data. For more information about receiver, see 1.1.1 Receiver.

### 3.2.1 Rx Insertion Loss

Receiver insertion loss is used to match the PCB qualities of the system. The predefined settings are used to statically adjust the receiver CDR and DFE. The CDR and DFE parameters are assigned based on a targeted data rate and backplane model. CDR uses only the CTLE capabilities of the PMA receiver. The DFE uses combination

of CTLE with DFE optimizations. To start the transceiver design, select the Rx Insertion loss values in Libero. Libero adjusts to the best known setting based on the data rate. If the pre-defined settings do not achieve the best performance, users can fine-tune the Rx CTLE settings to precisely match their system requirements after initial system bring-up.

Backplane or PCB Length, that is, Reach definitions are based upon number of connectors and overall insertion loss as per the CEI-11G SR, MR and LR specifications defined by Tyco Electronics Z-Pack Tinman testing platform. See 6.4 Transceivers Insertion Loss.

See AC483: PolarFire FPGA Transceiver Signal Integrity Application Note for information about the data rate range and models of backplane length.

### 3.2.2 Rx CTLE

CTLE at the receiver end is a typical equalization technique for equalizing the incoming signal to a flat response. CTLE is used to reduce the low-frequency component of the signal while boosting the high-frequency component. The receiver equalization settings are a function of the cut-off frequency and the amplitude gain across data rates. The equalizer circuitry can be tuned to compensate for the signal distortion due to the high frequency reduction of the physical channel of the PCB and interconnect.

For example, an under-equalized channel cannot adequately open the eye, whereas over-equalization can produce a channel with high jitter.

Correct equalization has optimal eye opening with low noise and low jitter. Rx insertion loss default settings sets the CTLE. AC483: PolarFire FPGA Transceiver Signal Integrity Application Note lists the combination of settings that help the user to find the best response to the incoming signal based on data rate "buckets". Within each bucket, there are optimized settings based on gain and peaking. When using DFE designs, users should not alter the predefined values of CTLE. These values are optimized to work in conjunction with the DFE configuration based on Rx insertion defaults as listed in following table.

### 3.2.3 Rx Termination

Within the Rx buffer, a calibrated input termination can be set having three—85  $\Omega$  or 100  $\Omega$  or 150  $\Omega$ —available differential impedances. The input impedance can be configured to match the system requirements.

### 3.2.4 AC/DC Coupled Connection

DC coupled connection option is set for using AC or DC coupled channels to the receiver. The device does include an internal coupling capacitor option, however, it also includes internal biasing circuitry required for AC coupled applications.

- AC coupled with external cap. Vcim is internally generated.
- DC coupled Link partner is in control of the Vcim through the incoming signal.

**Note:** For AC coupled with external cap, user must still place ac-coupling capacitor on PCB for AC coupled connection.

AC-coupling or DC-coupling is configured through the XCVR Signal Integrity options, which is available in Libero SoC v12.2 and later. Coupling options can be set in the Signal Integrity View tab (open the I/O Editor > XCVR View).

### 3.2.5 Loss-of-Signal Detector

Loss-of-signal (LOS) detector (LOW and HIGH value) sets the requirement of the voltage detector. The following table lists the upper and lower set points for a LOS to ensure that a good signal is applied into the receiver. Referring to data sheet Loss-of-Signal detect, Peak Detect Range (VDETLOW), below the Peak Detect Range minimum value setting is interpreted as "no signal" and above the maximum number will interpreted as "signal". In between the minimum and maximum values are considered indeterminate.

| Setting | Range                                                                                                                                                   |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCIE    | Preset PCIe low threshold setting = 1<br>For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet. |
|         | Preset PCIe high threshold setting = 2 For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.   |
| SATA    | Preset SATA low threshold setting = 2 For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.    |
|         | Preset SATA high threshold setting = 3 For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.   |
| 0       | For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.                                          |
| 1       | For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.                                          |
| 2       | For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.                                          |
| 3       | For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.                                          |
| 4       | For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.                                          |
| 5       | For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.                                          |
| 6       | For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.                                          |
| 7       | For Min and MAX values of VDETLOW, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.                                          |

#### Table 3-2. LOS Range

Software defaults to LOS-Low = 1 and LOS-High = 3.

### 3.2.6 Polarity Invert

Polarity invert is used to swap the P and N receiver pins, which provide flexible PCB routing by interchanging the devices physical pin to the logical signal. If the polarity of differential traces is swapped on the PCB, the differential data can be swapped to correct it. In PIPE mode, there is an input port for rxpolarity inversion, but that is not the case for the other modes. Polarity inversion is controlled by a system register (INV\_RX\_POLARITY\_LN#), not an input port for PMA/8b10b/64b6xb modes.

### 3.3 IO Editor for Signal Integrity

Using the Libero SoC IO Editor, the default signal Integrity parameter settings can be adjusted. These settings are exported from the IO Editor in the PDC format along with port name, pin, direction and so on. The io.pdc file created contains physical placement and signal integrity options of all XCVR lane instances used in the SmartDesign.

### 3.3.1 IO Editor—Signal Integrity

To access the Signal Integrity tab from IO Editor:

1. Open Constraint Manager > Edit > Edit with I/O Editor.

#### Figure 3-2. IO Editor—XCVR View

| Reports         | x Sta       | rtPage 🗗 🕽 | K 50    | NativePMA_      | Prbs 🗗     | ×     | Test_PRBS. | v đ× |
|-----------------|-------------|------------|---------|-----------------|------------|-------|------------|------|
| / I/O Attribute | s / Timing  | Floor Pla  | anner V | Netlist Attribu | utes       |       |            |      |
| New             | ▼ Imp       | ort        | Link    | Edit            | ]          | Check | н          | lelp |
|                 |             |            |         | Edit w          | /ith I/O E | ditor | te         |      |
| constraint      | \io\user.pd | c [Target] | ]       |                 |            |       |            |      |

2. In the **XCVR View [active]** tab, select **Signal Integrity View** tab and the XCVR lane to edit signal integrity settings as shown in the following figure.

Signal Integrity panel displays the default values from the initial PDC when XCVR is created by the Libero SoC software. If user modifies the default values in the **Signal Integrity** tab of the IO Editor, it writes in the PDC.



#### Figure 3-3. IO Editor—Signal Integrity View

### 3.3.2 PDC Constraint File Commands for XCVR Signal Integrity

PDC constraint support uses the set\_io pdc commands to set the related parameters. The settings are applied only to the dedicated XCVR ports—TX\_P, TX\_N (outputs), RX\_P, and RX\_N (inputs)

Example: set\_io -port\_name TX\_P -TX\_EMPHASIS\_AMPLITUDE 100mV\_with\_0dB

Note: User can set the parameter on the P or N side and it applies to both.

#### 3.3.2.1 PDC Supported Attributes and Values

The following table lists the PDC supported attributes and values. For more information about he description of the attributes, see 3.1 Transmitter.

| Name                               | Direction | Values           | Default         |
|------------------------------------|-----------|------------------|-----------------|
| TX_EMPHASIS_AMPLITUDE              | Output    | 400mV_with3.5dB  | 400mV_with1.0dB |
|                                    |           | 100mV_with_0dB   |                 |
|                                    |           | 200mV_with_0dB   |                 |
|                                    |           | 200mV_with1.0dB  |                 |
|                                    |           | 200mV_with2.5dB  |                 |
|                                    |           | 200mV_with3.5dB  |                 |
|                                    |           | 200mV_with4.4dB  |                 |
|                                    |           | 200mV_with6.0dB  |                 |
|                                    |           | 300mV_with_0dB   |                 |
|                                    |           | 400mV_with_0dB   |                 |
|                                    |           | 400mV_with1.0dB  |                 |
|                                    |           | 400mV_with2.5dB  |                 |
|                                    |           | 400mV_with4.4dB  |                 |
|                                    |           | 400mV_with6.0dB  |                 |
|                                    |           | 500mV_with_0dB   |                 |
|                                    |           | 600mV_with3.5dB  |                 |
|                                    |           | 600mV_with6.0dB  |                 |
|                                    |           | 800mV_with_0dB   |                 |
|                                    |           | 800mV_with1.0dB  |                 |
|                                    |           | 800mV_with2.5dB  |                 |
|                                    |           | 800mV_with3.5dB  |                 |
|                                    |           | 800mV_with4.4dB  |                 |
|                                    |           | 800mV_with6.0dB  |                 |
|                                    |           | 1000mV_with_0dB  |                 |
|                                    |           | 1000mV_with1.0dB |                 |
|                                    |           | 1000mV_with2.5dB |                 |
|                                    |           | 1000mV_with3.5dB |                 |
|                                    |           | 1000mV_with4.4dB |                 |
|                                    |           | 1000mV_with6.0dB |                 |
| TX_IMPEDANCE                       | Output    | 150              | 100             |
|                                    |           | 100              |                 |
|                                    |           | 85               |                 |
| TX_TRANSMIT_COMMON_MODE_ADJUSTMENT | Output    | 50               | 50              |
|                                    |           | 60               |                 |
|                                    |           | 70               |                 |
|                                    |           | 80               |                 |

### Table 3-3. TX Attributes and Values

The following table lists the PDC supported attributes and values. For more information about the description of the attributes, see 3.2 Receiver.

### Table 3-4. RX Attributes and Values

| Name                            | Direction | Values                                                                                                | Default                                             |
|---------------------------------|-----------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| RX_INSERTION_LOSS               | Input     | 6.5 dB                                                                                                | 6.5 dB                                              |
|                                 |           | 17.0 dB                                                                                               |                                                     |
|                                 |           | 25.0 dB                                                                                               | -                                                   |
| RX_CTLE                         | Input     | See Rx CTLE Settings table in AC483: PolarFire<br>FPGA Transceiver Signal Integrity Application Note. | Set based on data rate and Rx insertion loss model. |
| RX_TERMINATION                  | Input     | 100                                                                                                   | 100                                                 |
|                                 |           | 150                                                                                                   | -                                                   |
|                                 |           | 85                                                                                                    | -                                                   |
| RX_PN_BOARD_CONNECTION          | Input     | AC_COUPLED_WITH_EXT_CAP                                                                               | AC_COUPLED_WITH_EXT_CAP                             |
|                                 |           | DC_COUPLED                                                                                            |                                                     |
| RX_LOSS_OF_SIGNAL_              | Input     | OFF                                                                                                   | OFF                                                 |
| DETECTOR_LOW                    |           | PCIE                                                                                                  |                                                     |
|                                 |           | SATA                                                                                                  |                                                     |
|                                 |           | 1                                                                                                     |                                                     |
|                                 |           | 2                                                                                                     |                                                     |
|                                 |           | 3                                                                                                     |                                                     |
|                                 |           | 4                                                                                                     |                                                     |
|                                 |           | 5                                                                                                     |                                                     |
|                                 |           | 6                                                                                                     |                                                     |
|                                 |           | 7                                                                                                     |                                                     |
| RX_LOSS_OF_SIGNAL_DETECTOR_HIGH | Input     | OFF                                                                                                   | OFF                                                 |
|                                 |           | PCIE                                                                                                  |                                                     |
|                                 |           | SATA                                                                                                  |                                                     |
|                                 |           | 1                                                                                                     |                                                     |
|                                 |           | 2                                                                                                     |                                                     |
|                                 |           | 3                                                                                                     |                                                     |
|                                 |           | 4                                                                                                     |                                                     |
|                                 |           | 5                                                                                                     |                                                     |
|                                 |           | 6                                                                                                     |                                                     |
|                                 |           | 7                                                                                                     |                                                     |
| POLARITY                        | Input     | Normal                                                                                                | Normal                                              |
|                                 |           | Inverted                                                                                              |                                                     |

## 3.4 SmartDebug Signal Integrity

SmartDebug signal integrity is invoked from debug transceiver. SmartDebug Signal Integrity helps to evaluate the reliability of a high-speed serial link using transceivers. The signal integrity GUI follows the same format as the IO Editor. For more information about software operation, see UG0773: PolarFire FPGA SmartDebug User Guide. For more information about transceiver signal tuning, see AC483: PolarFire FPGA Transceiver Signal Integrity Application Note.

|                                                   | integrity view                                                                                                              |
|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| LANE0_TXD_P/N                                     | LANE0_RXD_P/N                                                                                                               |
| TX Emphasis Amplitude                             | RX Insertion Loss                                                                                                           |
| 400mV_with3.5dB                                   | 6.5dB                                                                                                                       |
| TX Impedance (ohms)                               | The transceiver data rate is set to 10312.5 Mbps for this port<br>The current settings will configure this port in CDR mode |
| TX Transmit Common Mode Adjustment (% of VDDA) 50 | Calibration<br>OnDemand_FirstLock                                                                                           |
|                                                   | RX CTLE<br>5GHz_+7.3dB                                                                                                      |
|                                                   | CDR GAIN<br>High                                                                                                            |
|                                                   | RX Termination (ohms)                                                                                                       |
|                                                   | RX P/N Board Connection AC_COUPLED_WITH_EXT_CAP                                                                             |
|                                                   | RX Loss of Signal Detector - Low                                                                                            |
|                                                   | RX Loss of Signal Detector - High                                                                                           |
|                                                   | Polarity (P/N reversal)                                                                                                     |

**Cianal Integrity View** 

Figure 3-4. SmartDebug Signal Integrity GUI Panel

The Signal Integrity UI panel can be viewed in SmartBERT, Loopback Modes, Static Pattern Transmit, and Eye Monitor debug tabs. This allows the user to move between test operations and signal integrity tuning, hence, allowing the user to interactively test while making adjustments to the signal integrity settings.

Consistent with debugging techniques of high-speed serial channels, users utilize the SmartDebug GUI to select integrated test data streams and enable device embedded loop backs. This allows the active channel to be adjusted to match the users PCB losses and discontinuities. For more information about test pattern capabilities, see 5.1 PRBS Generator/Checker.

### 3.4.1 Loopback Modes

Loopback operations are embedded within the XCVR and are commonly used in debug practice. These loop backs can be tested solely within the device by sending and receiving on-chip or can test real-data to and from the system side. For information, see 5.2 Loopback.

For example, by placing the transceiver into EQ Far-End loopback, a system can drive data into the Rx and send it back directly onto the Tx. In this case, the system is passing the serial data stream within the input and output buffers. Change the Signal Integrity panel settings to find the optimal setting to match the system.

In the Loopback Modes tab, select the targeted lane to test under Transceiver Hierarchy, select EQ-FAR END and then click Apply to monitor the system performance from the far-end. Adjust the signal integrity setting to optimize the Rx and Tx performance of the transceiver. The following figure shows the loopback modes of the Debug TRANSCEIVER.

Note: The Apply button is enabled when you make a selection for any parameter.

#### Figure 3-5. Loopback Modes—Far-end Example

| ansceiver Hierarchy | Physical Locatic | PF_XCVR_0/LANE0 C EQ-NEAR END C EQ-FAR END CDR FAR END No Loopback |
|---------------------|------------------|--------------------------------------------------------------------|
| PF_XCVR_0           |                  |                                                                    |
| LANE0               | Q2_LANE0         |                                                                    |
|                     |                  |                                                                    |
|                     |                  |                                                                    |

Similarly, the user can also continue to test a deeper path into the XCVR path using CDR Far-end loopback. In this manner, the same system data stream would pass from the input buffer through the Rx PMA and the parallel data stream would be routed back through a pathway to the Tx PMA to the output buffer.

### 3.4.2 SmartBERT

The CoreSmartBERT IP core provides a broad-based evaluation and demonstration platform for transceivers (PF\_XCVR). See HB0788: CoreSmartBERT Handbook (download the handbook from Libero Catalog). For any transceiver design, PRBS tests from XCVR PMA are available by default. SmartBERT enables you to run diagnostic tests on the transceiver lanes. The self-testing capability can be used for isolating faults either during development debug or for in-field diagnostics using the transceiver built-in PRBS generator and checker.

SmartBERT uses the PRBS generator and checker functionality available in each transceiver lane to determine the bit error rate (BER) of a lane. The various PRBS patterns supported are PRBS7, PRBS9, PRBS15, PRBS23, and PRBS31. Near-end loopback can be performed using one of these PRBS patterns. Bit Error Rate (BER) displays the BER for the PRBS test in progress.

To run a PRBS pattern:

- 1. Select one of the **Patterns** from the drop-down list.
- Select the EQ-NearEnd check box. When checked, the selected lane gets added to the right hand side where PRBS test can be performed. When unchecked, the selected lane gets removed from the added list (see Figure 3-7).
- Click Start in the bottom-left corner of the window. The loopback cycle is initiated and the result is displayed. It enables both transmitter and the receiver for a particular lane and for a particular PRBS pattern. The GUI shows the status of the TXPLL, RXPLL, Lock to Data, Data rate, and the BER (see Figure 3-7).
- 4. Click **Stop** in the bottom-right corner of the window to stop the loopback.

Monitor the Lock indicators and error counters to check the quality of the link. This test ensures proper power supplies, clocks and resets to the XCVR and traffic is not going off-chip to the system. The following figures show the Smart BERT options of the debug transceiver.

| Transceiver Hierarchy | Physical Locatic 4 |                 | Pattern | EQ- NearEnd | TX PLL | RX PLL 1 | D | Signal Integrity: PF_XCVR_3/U               | UNE0                                  |         |
|-----------------------|--------------------|-----------------|---------|-------------|--------|----------|---|---------------------------------------------|---------------------------------------|---------|
| PF_XCVR_0             |                    | PF_XCVR_3/LANE0 | PR857 • | trable      | 8      | 80 8     |   | Transmitter<br>Transmit Emphasis and Amplit | Receiver<br>Termination ( Differentia | 4)      |
| PF_XCVR_2             |                    |                 |         | _           |        |          |   | 400m//_with4.4d8 _                          | ] [100                                |         |
| E LANEO               | Q2_LANE2           |                 |         |             |        |          |   | Impedence ( Differential )                  | P / N Board Connection                |         |
| L LANET               | QZ_LAINED          |                 |         |             |        |          |   | 150 .                                       | AC_COUPLED_WITH_E                     | (T_€ •  |
| LANE2                 | Q2_LANE3           |                 |         |             |        |          |   | Polarity ( P/ N reversal )                  | Loss of Signal Detector               | - Low   |
| LANE3                 | Q2_LANE1           |                 |         |             |        |          |   | Inverted .                                  | 3                                     |         |
|                       |                    |                 |         |             |        |          |   | Transmit Common Mode Adjus                  | t Loss of Signal Detector             | - High  |
|                       |                    |                 |         |             |        |          |   | 70 .                                        | ] [2                                  |         |
|                       |                    |                 |         |             |        |          |   |                                             | Polarity (P/N reversal)               |         |
|                       |                    |                 |         |             |        |          |   |                                             | Inverted                              |         |
|                       |                    |                 |         |             |        |          |   |                                             | Continuous Time Linear                | Equal   |
|                       |                    |                 |         |             |        |          |   |                                             | 6GHz_Peak13.8d8                       |         |
|                       |                    |                 |         |             |        |          |   |                                             | Decision Feedback Equa                | lizatio |
|                       |                    |                 |         |             |        |          |   |                                             | Disabled                              |         |
|                       |                    |                 |         |             |        |          |   |                                             | Calibration                           |         |
|                       |                    |                 |         |             |        |          |   |                                             | Undefined                             |         |
|                       |                    |                 |         |             |        |          |   |                                             |                                       |         |
| 1                     | 1 1                | •               |         |             |        | 1        |   |                                             |                                       |         |
| Phy Reset             |                    | Start           |         |             |        | Stop     |   | Export Import                               | 1.122                                 | ply     |

Figure 3-6. PRBS Self Test Near-End Loopback Example

Figure 3-7. Test Status Indicators

|                 | Pattern | EQ-NearEnd | TX PLL | RX PLL | Lock to Data | Cumulative Error Count | Data Rate (Gbps) | BER      | Error Counter | Error Injection |
|-----------------|---------|------------|--------|--------|--------------|------------------------|------------------|----------|---------------|-----------------|
| PF_XCVR_0/LANE0 | PRBS7 - | Enable     | •      | •      | •            | 0                      | 5.1              | 3.77e-12 | Reset         |                 |

### 3.4.3 Eye Monitoring

Eye monitor enables visualizing the eye diagram present within the receiver. This feature plots the receive eye after the CTLE and DFE functions. The diagram representation provides vertical and horizontal measurements of the eye and BER performance measurements (see Figure 3-8). Eye Monitor is supported for data rates above 3.125 Gbps.

It is unfeasible to physically measure the eye opening at the XCVR receiver with an oscilloscope. Typically, the closest probe point is at the receiver device package pin at the PCB interconnection. This probe point does not provide the accuracy required to measure the real eye-width at the data sampling point since this point is before any input equalization can properly condition the signal.

On-chip eye monitoring circuitry provides a mechanism to measure and visualize the receiver eye margin after the equalizer, that enables access to eye quality measurements. The eye monitor is included in every transceiver design not requiring any other user added RTL blocks. The eye monitor functionality is based on capturing data sample in the nominal center and offset of the receiver eye. The eye monitor assists to estimate the horizontal eye-opening and select the best data sampling point at the receiver. The eye monitor feature provides 32 phase steps spanning one complete UI. The eye monitor algorithm steps through 32 phase steps while monitoring the BER at each phase step capturing the horizontal eye opening after receiver equalization.

### 3.4.3.1 SmartDebug Eye Monitor Utility

The eye information of an individual transceiver lane is available in the SmartDebug Eye Monitor utility and is used to view the eye opening after the signal conditioning of the receiver equalization. After the receive buffer, graphically plots the eye opening to visualize the signal quality, Eye Monitor utility within SmartDebug uses the on-chip Eye Monitor circuitry, to analyze the incoming data that includes the receivers gain, noise level, and jitter. The eye monitor is invoked from the eye monitor tab. It requires live data traffic to be driven into the receiver and cannot be used with the on-chip loopback paths.

The generated eye plot depicts one unit interval (UI) or one bit-period centered on the x and y axis. The y-axis shows the vertical opening with respect to voltage. Its upper and lower bounds are limited by the capture. In the y-axis, the

plot shows the signal clipped on the top and bottom. This is an operation of the algorithm and not actually the quality of the input signal. The x-axis depicts the phase steps across one UI.

The plot produces an eye diagram by overlaying many bits whereas a color gradient shows the density hits of the signal. Thus, the opening is represented as the area with least hits.

Click the **Eye Monitor** tab in the **Debug TRANSCEIVER** window to see the eye monitor representation within the receiver.



### Figure 3-8. Eye Monitor Plot

### 3.4.3.2 SmartDebug Decision Feedback Equalization Support

SmartDebug is used to adapt the DFE coefficients to optimize the settings for the overall signal integrity at the receiver for the system under test environment. On-demand, the SmartDebug utility runs the adaptive algorithm to of the DFE filter to resolve the TAP values of the DFE coefficients. This can be applied on any XCVR design greater than 5G. The routine is invoked from the Optimize DFE in the GUI. The TXPLL needs to be locked to begin DFE procedure. This runs the algorithm to set the optimal settings. The optimized settings remains intact until the next DEVRSTn or power cycle. The following figure shows the Optimize DFE window.

| ansceiver Hierarchy | Physical Locatic |                 | Pattern      | Ð       | Signal Integrity: PF_XCVR_0/LANE0      |           |                                                          |
|---------------------|------------------|-----------------|--------------|---------|----------------------------------------|-----------|----------------------------------------------------------|
| PF_XCVR_0           | Q2_LANE0         | PF_XCVR_0/LANE0 | PRBS7 *      |         | LANE0_TXD_P/N<br>TX Emphasis Amplitude |           | LANE0_RXD_P/N<br>RX Insertion Loss                       |
|                     |                  |                 |              |         | 400mV_with3,5dB                        | *         | 6.5dB                                                    |
|                     |                  |                 |              |         | TX Impedance ( ohms )                  |           | The transceiver data rate is set to 5100Mbps for this p  |
|                     |                  |                 |              |         | 150                                    | ÷         | The current settings will configure this port in CDR mod |
|                     |                  |                 |              |         | TX Transmit Common Mode Adjustment (%  | of VDDA ) | RX CTLE                                                  |
|                     |                  |                 | Optimize     | DFE     | ? X                                    | ÷         | 3GHz_+5.5dB_2.1dB                                        |
|                     |                  |                 |              |         | 44 8 97 P                              |           | RX Termination (ohms)                                    |
|                     |                  |                 | Select lanes | to Opti | mize DFE                               | ÷         | 150                                                      |
|                     |                  |                 | Quad 2       | 🔽 Lar   | 1e 0                                   |           | RX P/N Board Connection                                  |
|                     |                  |                 |              |         |                                        |           | AC_COUPLED_WITH_EXT_CAP                                  |
|                     |                  |                 |              |         |                                        |           | RX Loss of Signal Detector - Low                         |
|                     |                  |                 | 5            | otimiza | DFE on Selected Lanes                  |           | PCIE                                                     |
|                     |                  |                 |              | puinze  | ore on selected calles                 |           | RX Loss of Signal Detector - High                        |
|                     |                  |                 |              |         |                                        |           | PCIE                                                     |
|                     |                  |                 | Help         |         | Close                                  |           |                                                          |
|                     |                  |                 |              |         |                                        |           |                                                          |
|                     |                  |                 |              |         |                                        |           |                                                          |
|                     |                  |                 |              |         |                                        |           |                                                          |
|                     |                  |                 |              |         |                                        |           |                                                          |
|                     |                  |                 |              |         |                                        |           |                                                          |
|                     |                  |                 |              |         |                                        |           |                                                          |
|                     |                  | 2.1             |              |         | 1                                      |           |                                                          |
|                     | <u>}</u>         | •               | •            |         | Export Import                          |           | Optimize DFE Design Defaults Apply                       |
| hy Reset            |                  | Start           | Stop         |         | Export All Lanes Import All Lanes      |           |                                                          |

### Figure 3-9. Example of Optimize DFE

For more information about Optimized DFE feature, see UG0773: PolarFire FPGA SmartDebug User Guide.

# 4. Simulation

RTL simulation mode is available for all of the transceiver modes. This simulation mode enables the simulation of all the protocol communication layers (including the PMA, PCS, and fabric interfaces) and provides accurate cycle simulation for the design. However, using RTL simulation incurs some run-time penalties. Microchip provides a specific PCIe BFM model for enhanced simulation of PCIe designs using the embedded PCIe controllers, see PolarFire FPGA and PolarFire SoC FPGA PCI Express User Guide.





## 4.1 RTL Simulation Mode

RTL simulation mode simulates the XCVR block from the fabric interface to the serial I/O interface. RTL simulation mode is available for all of the XCVR modes. This mode supports all of the protocol communication layers, including the physical layer, and provides accurate cycle simulation for the design. Using RTL simulation, however, experiences some run-time penalties. As the IP user block is off-chip, it must be connected to the user design in the top-level test bench. It is the user's responsibility to provide the model for the off-chip IP that can communicate with the XCVR block in the same protocol used by the XCVR block when using this mode. Post-synthesis simulation is available with PF XCVR ERM designs when configured with both ERM OFF and ON.

To minimize simulation time, certain peripherals in the transceiver do not have full behavioral models. These models are replaced with memory models that output a message indicating when the memory locations inside the peripheral are accessed. The memory models are created by using register information that is generated by Libero. The XCVR register data is found at <Libero Project>\component\work\<top\_level>\<xcvr\_component\_name>. The peripheral signals do not toggle based on any writes to registers, or react to any signal inputs on the protocol pins.

Using RTL simulation mode, the FPGA designer can have an off-chip verification IP model that communicates with the transceiver. For example, if the design uses a 8b10b XCVR block, the FPGA designer must have a 8b10b verification IP off-chip block to communicate with the XCVR block using the required protocol. When the IP user block is off-chip, it must be connected to the design in the top-level testbench.

# 5. Debug and Testing

Both the device families include debug and testing features for multi-gigabit transceivers. It provides capabilities for diagnostic test setups and inserting test patterns during FPGA testing and debugging. This chapter describes the embedded transceiver capabilities that allow high-speed link diagnostics.

### 5.1 PRBS Generator/Checker

Each transceiver has embedded blocks with a built-in PRBS generator and checker that can be used to perform link testing and diagnostics. These test capabilities are available to the user through the SmartDebug toolset. For more information on PRBS generator and checker, see 3.4.2 SmartBERT.

The implementation of the PRBS generator uses a linear feedback shift register (LFSR). The generator produces a pre-defined sequence of 1s and 0s, occurring with the same probability. A sequence of consecutive  $n \times (2^{n-1})$  bits comprise one data pattern, and this pattern repeats itself over time. This sequence is compared within the checker to ensure no errors in the sequence are detected.

The PRBS generator/checker supports the following test patterns for 32- and 40-bit wide PMA parallel buses.

- PRBS31: x<sup>31</sup> + x<sup>28</sup> + 1
- PRBS23: x<sup>23</sup> + x<sup>18</sup> + 1
- PRBS15: x<sup>15</sup> + x<sup>14</sup> + 1
- PRBS9: x<sup>9</sup> + x<sup>5</sup> +1
- PRBS7: x<sup>7</sup> + x<sup>6</sup> + 1

PRBS7 is also supported in widths of 8, 10, 16, and 20 bits.

**Note:** Some PRBS pattern polynomials are used as part of several standards such as ITU-T recommendations. The PRBS7 polynomial is not necessarily a telecommunications standard but is typically used by test equipment because its similarity with 8b10b-encoded patterns.

The PRBS checker is on the parallel side of the de-serializer. If LANE#\_RX\_SLIP is toggled during PRBS testing, then the next word will not be in the same PRBS pattern as the one before it which causes a failure to match.

### 5.2 Loopback

There are three loopbacks supported within the transceiver blocks to assist designers in debugging the system by segmenting the link (Figure 5-1). The loopbacks are accessed through the SmartDebug tools. For information about data rate performance of loopback paths, see respective PolarFire FPGA Datasheet or PolarFire SoC Advance Datasheet.

### 5.2.1 EQ Far-End Loopback

Far-end serial loopback (receiver to transmitter) or EQ FELB bypasses all input equalization (CTLE and DFE) as detailed in 1.1.1 Receiver and therefore, only supports lower speed operation since these features cannot be utilized.

Because it does not use the CDR (the receive and transmit lanes are essentially shorted together), there is no PPM relationship between the receive and transmit data.

### 5.2.2 EQ Near-End Loopback

Near-end serial loopback (transmitter to receiver) or EQ NELB uses the digital serialized transmit data that bypasses the transmit output buffer and loops the data back to the third-stage CTLE input, bypassing the receiver input and connecting to the CDR only.

The EQ NELB mode does not test the transmit buffer, high-speed receive buffer, low-speed receive buffer, CTLE stages 1 and 2 for the CDR, CTLE stages 1, 2, and 3 for the DFE and eye monitor circuits.

### 5.2.3 CDR Far-End Loopback

CDR FELB (CDR far-end loop back), occurs after the parallel word creation in the PCS through a loop-back FIFO. The transmit word is then serialized and sent out of the transmitter.

This loopback is after the CDR which requires the receive and transmit paths to have exactly matched clock rates or 0 ppm differences. In the Far-end loopback case, the LANE#\_RX\_READY must be used instead of LANE#\_RX\_VAL to indicate valid data path.

#### Figure 5-1. Transceiver Loopbacks



## 5.3 Dynamic Reconfiguration Interface

The dynamic reconfiguration interface (DRI) is used with transceiver to access the memory map of the transceiver blocks. DRI is an APB slave that allows global access to all transceiver lanes, PCIe blocks, transmit PLLs, and FPGA PLLs. The DRI allows changing key features of the transceiver before and during operation. The DRI connectivity is dedicated within the device requiring no FPGA fabric routing. For more information about DRI, see PolarFire FPGA and PolarFire SoC FPGA Device Power-Up and Resets User Guide and PolarFire FPGA and PolarFire SoC FPGA Dynamic Reconfiguration Interface User Guide. For information about design targeted configuration, see 2.6.1 Transceiver Initialization Data.

Care must be exercised when using the DRI to alter transceiver settings as changes from the factory settings can cause undesired results.

### Figure 5-2. PF\_DRI Example



Components

**Note:** For implementation example, see AC475: PolarFire FPGA Dynamic Reconfiguration Interface Application Note.

### Note:

\*\* The PCIESS blocks do not connect directly to a DRI port, however, the associated XCVR LANE for Quad0 must be connected to the DRI for dynamic control of the XCVR features used with PCIESS. The PCIE[0:1] blocks have dedicated APB port for access to the register control within the PCIE subsystem.

# 6. Board Design Recommendations

User must have knowledge of the following PCB design topics before designing a PCB that uses transceivers.

- Device interfacing
- Transmission line impedance and routing
- · Power supply design filtering and distribution
- Component selection
- PCB layout and stack-up design

See respective UG0726: PolarFire FPGA Board Design User Guide or PolarFire SoC FPGA Board Design Guidelines User Guide for implementing transceiver designs on printed circuit boards.

### 6.1 Transceiver Top-Level Pin Out

The transceiver quad includes four differential receive and transmit pairs. The reference clock to the transmit PLLs can be provided either by the provided primary differential reference clock pins or by the FPGA clock resources.

The transceiver pins, power pins, and associated clock are listed in the following table.

| Table 6-1 | . Transceiver | <b>Device Level F</b> | Pin List | (continued) | 1 |
|-----------|---------------|-----------------------|----------|-------------|---|
|-----------|---------------|-----------------------|----------|-------------|---|

| Pin Name <sup>2</sup>                     | Direction | Description                                                                                                                                                                          |
|-------------------------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XCVR_#_TX3_P                              | Output    | Transmit data. Transceiver differential positive output. Each transceiver quad consists of four transmit+ signals.                                                                   |
| XCVR_#_TX2_P                              | Output    | Transmit data. Transceiver differential positive output. Each transceiver quad consists of four transmit+ signals.                                                                   |
| XCVR_#_TX1_P                              | Output    | Transmit data. Transceiver differential positive output. Each transceiver quad consists of four transmit+ signals.                                                                   |
| XCVR_#_TX0_P                              | Output    | Transmit data. Transceiver differential positive output. Each transceiver quad consists of four transmit+ signals.                                                                   |
| XCVR_#_TX3_N                              | Output    | Transmit data. Transceiver differential negative output. Each transceiver quad consists of four transmit- signals.                                                                   |
| XCVR_#_TX2_N                              | Output    | Transmit data. Transceiver differential negative output. Each transceiver quad consists of four transmit- signals.                                                                   |
| XCVR_#_TX1_N                              | Output    | Transmit data. Transceiver differential negative output. Each transceiver quad consists of four transmit- signals.                                                                   |
| XCVR_#_TX0_N                              | Output    | Transmit data. Transceiver differential negative output. Each transceiver quad consists of four transmit- signals.                                                                   |
| XCVR_#_RX3_P                              | Input     | Receive data. Transceiver differential positive input. Each transceiver quad consists of four receive+ signals.                                                                      |
| XCVR_#_RX2_P                              | Input     | Receive data. Transceiver differential positive input. Each transceiver quad consists of four receive+ signals.                                                                      |
| XCVR_#_RX1_P                              | Input     | Receive data. Transceiver differential positive input. Each transceiver quad consists of four receive+ signals.                                                                      |
| XCVR_#_RX0_P                              | Input     | Receive data. Transceiver differential positive input. Each transceiver quad consists of four receive+ signals.                                                                      |
| XCVR_#_RX3_N                              | Input     | Receive data. Transceiver differential negative input. Each transceiver quad consists of four receive- signals.                                                                      |
| XCVR_#_RX2_N                              | Input     | Receive data. Transceiver differential negative input. Each transceiver quad consists of four receive- signals.                                                                      |
| XCVR_#_RX1_N                              | Input     | Receive data. Transceiver differential negative input. Each transceiver quad consists of four receive- signals.                                                                      |
| XCVR_#_RX0_N                              | Input     | Receive data. Transceiver differential negative input. Each transceiver quad consists of four receive- signals.                                                                      |
| XCVR_#[A,B,C]_REFCLK_P <sup>3</sup>       | Input     | This pin is used as the positive terminal when used with a differential clock source.                                                                                                |
| $XCVR_{\texttt{#}[A,B,C]}_{REFCLK_{N^3}}$ | Input     | This pin is used as the negative terminal when used with a differential clock.                                                                                                       |
| XCVR_VREF                                 | Power     | This pin is used as a reference voltage for the REFCLK input buffers. It is used for single-ended clock signals. This signal is common for all transceiver on device.                |
| VDDA25                                    | Power     | 2.5 V analog supply. All transmit PLLs and associated high-speed clock routes in each transceiver PMA are connected on-chip but isolated from the other transmit PLLs on the device. |
| VDDA                                      | Power     | Supply for receive, transmit, and common circuits. Common for all lanes within the PMA block.                                                                                        |
| VDD_XCVR_CLK                              | Power     | Provides common power to all transceiver reference clock buffers. VDD_XCVR_CLK power supply operates using a voltage of 2.5 V to 3.3 V.                                              |

(1) See the related PolarFire Package Pin Assignment Table or PolarFire SoC Package Pin Assignment Table for recommended USED or UNUSED conditions.
 (2) # Indicates the associated transceiver quad (that is, Q0=0, Q1=1, ...Q5=5).

(3) There is one pin per transmit PLL per transceiver quad. There is a minimum of two differential reference clock input pairs per quad with an additional pair for specific quads. It is limited to driving only one clock source for the transceiver block when used differentially or two when used in the single-ended mode.

### 6.2 Design for Protocols

Transceiver designs are used in many high-speed protocols. Each protocol specifies the system requirements to meet the specific standards of the protocol. The electrical performance requirements for these protocols must be addressed by proper design of the PCB. The following sections describes the PCB requirements of transceivers for specific protocols. For more information, see respective UG0901: PolarFire SoC FPGA Board Design Guidelines User Guide or UG0726: PolarFire FPGA Board Design User Guide.

### 6.2.1 PCI Express

PCIe is a point-to-point serial differential low-voltage interconnect supporting up to four channels. Each lane consists of two pairs of differential signals: a transmit pair, XCVR\_x\_TXy\_P/N, and a receive pair, XCVR\_x\_RXy\_P/N. Each signal has a 2.5 GHz embedded clock.

The following figure shows the connectivity between the transceiver interface and the PCIe edge connector.



### Figure 6-1. Connectivity Between XCVR Interface and PCIe Edge Connector

**Note:** The ceramic 0201 and 0402 AC coupled capacitors are preferred for transceivers. The transmitter must have AC coupling capacitors.

### 6.2.2 JESD204B

JESD204B version increases the supported lane data rates to 12.5 Gbps and divides devices into three different speed grades. The source and load impedance is the same for all three speed grades being defined as 100  $\Omega$ . The first speed grade aligns with the lane data rates from the JESD204 and JESD204A versions of the standard, and defines the electrical interface for lane data rates up to

3.125 Gbps. The second speed grade in JESD204B defines the electrical interface for lane data rates up to 6.375 Gbps. This speed grade lowers the minimum differential voltage level to 400 mV peak-to-peak, down from 500 mV peak-to-peak for the first speed grade. The third speed grade in JESD204B defines the electrical interface for lane data rates up to 12.5 Gbps.

The following figure shows the connectivity between the device and the JESD204B interface.



Figure 6-2. Connectivity Between Device and JESD204B Interface

### 6.3 10G Interface

The following figure shows the connection between device and SFP+ interface.

Figure 6-3. Connectivity Between Device and SFP+ Interface



### 6.3.1 Unused Transceiver Pins

If the transceiver interface is not used in the design, the transceiver pins must be connected as defined in the related PolarFire Package Pin Assignment Table (PPAT) or PolarFire SoC Package Pin Assignment Table (PPAT).

### 6.4 Transceivers Insertion Loss

The following table lists the type of insertion loss.

### Table 6-2. Transceivers Insertion Loss

| Туре   | Trace Distance                                                     | Insertion Loss   | PCB length           | Di-Electric<br>material | Trace width and Spacing                                                 |
|--------|--------------------------------------------------------------------|------------------|----------------------|-------------------------|-------------------------------------------------------------------------|
| Short  | Connections within a board or via one connector to a daughter card | 6.5 dB at 5 GHz  | 8 inches strip-line  | Nelco FR-4              | trace width = 7mil, space between the P to N signal = 10mil material    |
| Medium | Backplane application with 2 connectors                            | 17.0 dB at 5 GHz | 24 inches strip-line | Nelco FR-4              | trace width = 7mil, space between the P to N signal = 10mil material    |
| Long   | Backplane application with 2 connectors                            | 25.0 dB at 5 GHz | 40 inches strip-line | Nelco FR-4              | trace width = 7mil, space between the P to N signal<br>= 10mil material |

### Notes:

- 1. For FR-4 and good quality connectors, the insertion Loss is ~0.5 dB per inch at 5 GHz and each connector is ~2.5 dB per connector at 5 GHz.
- 2. Medium reach backplane is meant for an 18" backplane with two 3" length line-card traces.
- 3. Long reach backplane is meant for a 34" backplane with two 3" line card traces.
- 4. DFE Equalization mode is not supported at < 3 Gb/s (rates from 3 Gb/s to 5 Gb/s, including PCI-Express, could be supported with DFE but are not set up to do so in this RX\_PRESETS table).

# 7. Revision History

The revision history table describes the changes that were implemented in the document. The changes are listed by revision, starting with the most current publication.

### Table 7-1. Revision History

| Revision | Date    | Description                                                                                                                                                                                                                                           |
|----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A        | 08/2021 | <ul> <li>The first publication of the document.</li> <li>This user guide was created by merging the following documents:</li> <li>UG0677: PolarFire FPGA Transceiver User Guide</li> <li>UG0915: PolarFire SoC FPGA Transceiver User Guide</li> </ul> |

# The Microchip Website

Microchip provides online support via our website at www.microchip.com/. This website is used to make files and information easily available to customers. Some of the content available includes:

- **Product Support** Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- **General Technical Support** Frequently Asked Questions (FAQs), technical support requests, online discussion groups, Microchip design partner program member listing
- **Business of Microchip** Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

# **Product Change Notification Service**

Microchip's product change notification service helps keep customers current on Microchip products. Subscribers will receive email notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, go to www.microchip.com/pcn and follow the registration instructions.

# Customer Support

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- Local Sales Office
- Embedded Solutions Engineer (ESE)
- Technical Support

Customers should contact their distributor, representative or ESE for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in this document.

Technical support is available through the website at: www.microchip.com/support

# **Microchip Devices Code Protection Feature**

Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specifications contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is secure when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods being used in attempts to breach the code protection features of the Microchip devices. We believe that these methods require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Attempts to breach these code protection features, most likely, cannot be accomplished without violating Microchip's intellectual property rights.
- · Microchip is willing to work with any customer who is concerned about the integrity of its code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of its code. Code protection does not mean that we are guaranteeing the product is "unbreakable." Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

# Legal Notice

Information contained in this publication is provided for the sole purpose of designing with and using Microchip products. Information regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications.

THIS INFORMATION IS PROVIDED BY MICROCHIP "AS IS". MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION INCLUDING BUT NOT LIMITED TO ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE OR WARRANTIES RELATED TO ITS CONDITION, QUALITY, OR PERFORMANCE.

IN NO EVENT WILL MICROCHIP BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL OR CONSEQUENTIAL LOSS, DAMAGE, COST OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE INFORMATION OR ITS USE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY RELATED TO THE INFORMATION OR ITS USE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY, THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THE INFORMATION. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

# Trademarks

The Microchip name and logo, the Microchip logo, Adaptec, AnyRate, AVR, AVR logo, AVR Freaks, BesTime, BitCloud, chipKIT, chipKIT logo, CryptoMemory, CryptoRF, dsPIC, FlashFlex, flexPWR, HELDO, IGLOO, JukeBlox, KeeLoq, Kleer, LANCheck, LinkMD, maXStylus, maXTouch, MediaLB, megaAVR, Microsemi, Microsemi logo, MOST, MOST logo, MPLAB, OptoLyzer, PackeTime, PIC, picoPower, PICSTART, PIC32 logo, PolarFire, Prochip Designer, QTouch, SAM-BA, SenGenuity, SpyNIC, SST, SST Logo, SuperFlash, Symmetricom, SyncServer, Tachyon, TimeSource, tinyAVR, UNI/O, Vectron, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

AgileSwitch, APT, ClockWorks, The Embedded Control Solutions Company, EtherSynch, FlashTec, Hyper Speed Control, HyperLight Load, IntelliMOS, Libero, motorBench, mTouch, Powermite 3, Precision Edge, ProASIC, ProASIC Plus, ProASIC Plus logo, Quiet-Wire, SmartFusion, SyncWorld, Temux, TimeCesium, TimeHub, TimePictra, TimeProvider, WinPath, and ZL are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Adjacent Key Suppression, AKS, Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, Augmented Switching, BlueSky, BodyCom, CodeGuard, CryptoAuthentication, CryptoAutomotive, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, Espresso T1S, EtherGREEN, IdealBridge, In-Circuit Serial Programming, ICSP, INICnet, Intelligent Paralleling, Inter-Chip Connectivity, JitterBlocker, maxCrypto, maxView, memBrain, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PowerSmart, PureSilicon, QMatrix, REAL ICE, Ripple Blocker, RTAX, RTG4, SAM-ICE, Serial Quad I/O, simpleMAP, SimpliPHY, SmartBuffer, SMART-I.S., storClad, SQI, SuperSwitcher, SuperSwitcher II, Switchtec, SynchroPHY, Total Endurance, TSHARC, USBCheck, VariSense, VectorBlox, VeriPHY, ViewSpan, WiperLock, XpressConnect, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

The Adaptec logo, Frequency on Demand, Silicon Storage Technology, and Symmcom are registered trademarks of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

<sup>©</sup> 2021, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

ISBN: 978-1-5224-8797-5

# **Quality Management System**

For information regarding Microchip's Quality Management Systems, please visit www.microchip.com/quality.



# **Worldwide Sales and Service**

| MERICAS                  | ASIA/PACIFIC                              | ASIA/PACIFIC                              | EUROPE                                    |
|--------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|
|                          |                                           |                                           |                                           |
| Corporate Office         | Australia - Sydney<br>Tel: 61-2-9868-6733 | India - Bangalore<br>Tel: 91-80-3090-4444 | Austria - Wels<br>Tel: 43-7242-2244-39    |
|                          |                                           | India - New Delhi                         |                                           |
| Chandler, AZ 85224-6199  | China - Beijing                           |                                           | Fax: 43-7242-2244-393                     |
| el: 480-792-7200         | Tel: 86-10-8569-7000                      | Tel: 91-11-4160-8631                      | Denmark - Copenhager                      |
| ax: 480-792-7277         | China - Chengdu                           | India - Pune                              | Tel: 45-4485-5910                         |
| echnical Support:        | Tel: 86-28-8665-5511                      | Tel: 91-20-4121-0141                      | Fax: 45-4485-2829                         |
| ww.microchip.com/support | China - Chongqing                         | Japan - Osaka<br>Tel: 81-6-6152-7160      | Finland - Espoo                           |
| Veb Address:             | Tel: 86-23-8980-9588                      |                                           | Tel: 358-9-4520-820                       |
| /ww.microchip.com        | China - Dongguan                          | Japan - Tokyo                             | France - Paris                            |
| tlanta                   | Tel: 86-769-8702-9880                     | Tel: 81-3-6880- 3770                      | Tel: 33-1-69-53-63-20                     |
| uluth, GA                | China - Guangzhou                         | Korea - Daegu                             | Fax: 33-1-69-30-90-79                     |
| el: 678-957-9614         | Tel: 86-20-8755-8029                      | Tel: 82-53-744-4301                       | Germany - Garching                        |
| ax: 678-957-1455         | China - Hangzhou                          | Korea - Seoul                             | Tel: 49-8931-9700                         |
| ustin, TX                | Tel: 86-571-8792-8115                     | Tel: 82-2-554-7200                        | Germany - Haan                            |
| el: 512-257-3370         | China - Hong Kong SAR                     | Malaysia - Kuala Lumpur                   | Tel: 49-2129-3766400                      |
| oston                    | Tel: 852-2943-5100                        | Tel: 60-3-7651-7906                       | Germany - Heilbronn<br>Tel: 49-7131-72400 |
| /estborough, MA          | China - Nanjing                           | Malaysia - Penang                         |                                           |
| el: 774-760-0087         | Tel: 86-25-8473-2460                      | Tel: 60-4-227-8870                        | Germany - Karlsruhe                       |
| ax: 774-760-0088         | China - Qingdao                           | Philippines - Manila                      | Tel: 49-721-625370                        |
| chicago                  | Tel: 86-532-8502-7355                     | Tel: 63-2-634-9065                        | Germany - Munich                          |
| asca, IL                 | China - Shanghai                          | Singapore                                 | Tel: 49-89-627-144-0                      |
| el: 630-285-0071         | Tel: 86-21-3326-8000                      | Tel: 65-6334-8870                         | Fax: 49-89-627-144-44                     |
| ax: 630-285-0075         | China - Shenyang                          | Taiwan - Hsin Chu                         | Germany - Rosenheim                       |
| allas                    | Tel: 86-24-2334-2829                      | Tel: 886-3-577-8366                       | Tel: 49-8031-354-560                      |
| ddison, TX               | China - Shenzhen                          | Taiwan - Kaohsiung                        | Israel - Ra'anana                         |
| el: 972-818-7423         | Tel: 86-755-8864-2200                     | Tel: 886-7-213-7830                       | Tel: 972-9-744-7705                       |
| ax: 972-818-2924         | China - Suzhou                            | Taiwan - Taipei                           | Italy - Milan                             |
| etroit                   | Tel: 86-186-6233-1526                     | Tel: 886-2-2508-8600                      | Tel: 39-0331-742611                       |
| ovi, MI                  | China - Wuhan                             | Thailand - Bangkok                        | Fax: 39-0331-466781                       |
| el: 248-848-4000         | Tel: 86-27-5980-5300                      | Tel: 66-2-694-1351                        | Italy - Padova                            |
| ouston, TX               | China - Xian                              | Vietnam - Ho Chi Minh                     | Tel: 39-049-7625286                       |
| el: 281-894-5983         | Tel: 86-29-8833-7252                      | Tel: 84-28-5448-2100                      | Netherlands - Drunen                      |
| Idianapolis              | China - Xiamen                            |                                           | Tel: 31-416-690399                        |
| oblesville, IN           | Tel: 86-592-2388138                       |                                           | Fax: 31-416-690340                        |
| el: 317-773-8323         | China - Zhuhai                            |                                           | Norway - Trondheim                        |
| ax: 317-773-5453         | Tel: 86-756-3210040                       |                                           | Tel: 47-72884388                          |
| el: 317-536-2380         |                                           |                                           | Poland - Warsaw                           |
| os Angeles               |                                           |                                           | Tel: 48-22-3325737                        |
| ission Viejo, CA         |                                           |                                           | Romania - Bucharest                       |
| el: 949-462-9523         |                                           |                                           | Tel: 40-21-407-87-50                      |
| ax: 949-462-9608         |                                           |                                           | Spain - Madrid                            |
| el: 951-273-7800         |                                           |                                           | Tel: 34-91-708-08-90                      |
| aleigh, NC               |                                           |                                           | Fax: 34-91-708-08-91                      |
| el: 919-844-7510         |                                           |                                           | Sweden - Gothenberg                       |
| ew York, NY              |                                           |                                           | Tel: 46-31-704-60-40                      |
| el: 631-435-6000         |                                           |                                           | Sweden - Stockholm                        |
| an Jose, CA              |                                           |                                           | Tel: 46-8-5090-4654                       |
| el: 408-735-9110         |                                           |                                           | UK - Wokingham                            |
| el: 408-436-4270         |                                           |                                           | Tel: 44-118-921-5800                      |
| anada - Toronto          |                                           |                                           | Fax: 44-118-921-5820                      |
| el: 905-695-1980         |                                           |                                           |                                           |
| ax: 905-695-2078         |                                           |                                           |                                           |