

## Introduction

The LatticeECP3™ FPGA family combines a high-performance FPGA fabric, high-performance I/Os and up to 16 channels of embedded SERDES with associated Physical Coding Sublayer (PCS) logic. The PCS logic can be configured to support numerous industry-standard, high-speed serial data transfer protocols.

Each channel of PCS logic contains dedicated transmit and receive SERDES for high-speed, full-duplex serial data transfer at data rates up to 3.2 Gbps. The PCS logic in each channel can be configured to support an array of popular data protocols including GbE, XAUI, SONET/SDH, PCI Express, SRIO, CPRI, OBSAI, SD-SDI, HD-SDI and 3G-SDI. In addition, the protocol-based logic can be fully or partially bypassed in a number of configurations to allow users flexibility in designing their own high-speed data interface.

The PCS also provides bypass modes that allow a direct 8-bit or 10-bit interface from the SERDES to the FPGA logic. Each SERDES pin can be independently DC-coupled and can allow for both high-speed and low-speed operation on the same SERDES pin for applications such as Serial Digital Video.

## Features

- **Up to 16 Channels of High-Speed SERDES**
  - 150 Mbps to 3.2 Gbps for Generic 8b10b, 10-bit SERDES and 8-bit SERDES modes. Refer to Table 8-1.
  - 230 Mbps to 3.2 Gbps per channel for all other protocols
  - 3.2 Gbps operation with low 110 mW power per channel
  - Receive equalization and transmit pre-emphasis for small form factor backplane operation
  - Supports PCI Express, Gigabit Ethernet (1GbE and SGMII) and XAUI, plus multiple other standards
  - Supports user-specified generic 8b10b mode
  - Out-of-band (OOB) signal interface for low-speed inputs (video application)
- **Multiple Clock Rate Support**
  - Separate reference clocks for each PCS quad allow easy handling of multiple protocol rates on a single device
- **Full-Function Embedded Physical Coding Sub-layer (PCS) Logic Supporting Industry Standard Protocols**
  - Up to 16 channels of full-duplex data supported per device
  - Multiple protocol support on one chip
  - Supports popular 8b10b-based packet protocols
  - SERDES Only mode allows direct 8-bit or 10-bit interface to FPGA logic
- **Multiple Protocol Compliant Clock Tolerance Compensation (CTC) Logic**
  - Compensates for frequency differential between reference clock and received data rate
  - Allows user-defined skip pattern of 1, 2, or 4 bytes in length
- **Integrated Loopback Modes for System Debugging**
  - Three loopback modes are provided for system debugging

## New Features Over LatticeECP2M™ SERDES/PCS

- Supports multiple protocols/standards within one quad of SERDES. The standards are required to have nominal frequencies either at the full rate or half rate of the supported standards listed in Table 8-1. Configuration flexibility should not be a barrier to supporting different mixes of protocols and standards. PCI Express, Gigabit Ethernet, SGMII and Serial RapidIO modes are supported in the multi-protocol grouping.
- Supports XAUI compliance features and extended SERDES maximum performance to 3.2 Gbps.

- Supports SONET/SDH OC-3/STM-1, OC-12/STM-4 and OC-48/STM-16 rates.
- Added support for per RX and TX DIV11 for SD-SDI, HD-SDI and 3G-SDI. Multi-rate SDI support.

## Using This Technical Note

The ispLEVER® design tools from Lattice support all modes of the PCS. Most modes are dedicated to applications for a specific industry standard data protocol. Other modes are more general purpose in nature and allow designers to define their own custom application settings. ispLEVER design tools allow the user to define the mode for each quad in their design. This technical note describes operation of the SERDES and PCS for all modes supported by ispLEVER. If you are using Lattice Diamond® design software, see Appendix D.

This document provides a thorough description of the complete functionality of the embedded SERDES and associated PCS logic. Electrical and timing characteristics of the embedded SERDES are provided in the [LatticeECP3 Family Data Sheet](#). Operation of the PCS logic is provided in the PCS section of this document. A table of all status and control registers associated with the SERDES and PCS logic which can be accessed via the SCI Bus is provided in the appendices. Package pinout information is provided in the Pinout Information section of the [LatticeECP3 Family Data Sheet](#).

## Standards Supported

The supported standards are listed in Table 8-1.

**Table 8-1. Standards Supported by the SERDES**

| Standard                                                               | Data Rate (Mbps)              | System Reference Clock (MHz)    | FPGA Clock (MHz)             | Number of General/Link Width | Encoding Style |
|------------------------------------------------------------------------|-------------------------------|---------------------------------|------------------------------|------------------------------|----------------|
| PCI Express 1.1                                                        | 2500                          | 100                             | 250                          | x1, x2, x4                   | 8b10b          |
| Gigabit Ethernet, SGMII                                                | 1250                          | 125                             | 125                          | x1                           | 8b10b          |
|                                                                        | 2500                          | 125                             | 250                          | x1                           | 8b10b          |
|                                                                        | 3125                          | 156.25                          | 156.25                       | x1                           | 8b10b          |
|                                                                        | 3125                          | 156.25                          | 156.25                       | x4                           | 8b10b          |
| XAUI                                                                   | 3125                          | 156.25                          | 156.25                       | x4                           | 8b10b          |
| Serial RapidIO Type I, Serial RapidIO Type II, Serial RapidIO Type III | 1250, 2500, 3125              | 125, 125, 156.25                | 125, 250, 156.25             | x1, x4                       | 8b10b          |
| OBSAI-1, OBSAI-2, OBSAI-3, OBSAI-4                                     | 768, 1536, 2304, 3072         | 76.8, 76.8, 153.6, 115.2, 153.6 | 76.8, 153.6, 230.4, 153.6    | x1                           | 8b10b          |
| CPRI-1, CPRI-2, CPRI-3, CPRI-4                                         | 614.4, 1228.8, 2457.6, 3072.0 | 61.44, 61.44, 122.88, 122.88    | 61.44, 122.88, 122.88, 153.6 | x1                           | 8b10b          |
| SD-SDI (259M, 344M)                                                    | 143¹, 177¹, 270, 360, 540     | 14.3¹, 17.7¹, 27, 36, 54        | 143, 177, 27, 36, 54         | x1                           | NRZI/Scrambled |
| HD-SDI (292M)                                                          | 1483.5, 1485                  | 74.175, 148.35, 74.25, 148.50   | 74.175, 148.35, 74.25, 148.5 | x1                           | NRZI/Scrambled |
| 3G-SDI (424M)                                                          | 2967, 2970                    | 148.35, 148.5                   | 148.35, 148.5                | x1                           | NRZI/Scrambled |
| SONET STS-3²                                                           | 155.52                        | 15.552                          | 15.552                       |                              |                |
| SONET STS-12²                                                          | 622.08                        | 62.208                          | 62.208                       |                              |                |
| SONET STS-48²                                                          | 2488                          | 248.8                           | 248.8                        |                              |                |
| 10-Bit SERDES                                                          | 150 - 3125                    | 15 - 312.5                      | 15 - 312.5                   | x1, x2, x3, x4               | N/A            |

**Table 8-1. Standards Supported by the SERDES (Continued)**

| Standard      | Data Rate (Mbps) | System Reference Clock (MHz) | FPGA Clock (MHz) | Number of General/Link Width | Encoding Style |
|---------------|------------------|------------------------------|------------------|------------------------------|----------------|
| 8-Bit SERDES  | 150 - 3125       | 15 - 312.5                   | 15 - 312.5       | x1, x2, x3, x4               | N/A            |
| Generic 8b10b | 150 - 3125       | 15 - 312.5                   | 15 - 312.5       | x1, x2, x3, x4               | 8b10b          |

1. For slower rates, the SERDES are bypassed and signals are directly fed to the FPGA core.

2. The SONET protocol is supported in 8-Bit SERDES mode. Refer to the SONET section of this document for detailed information.

## Architecture Overview

The SERDES/PCS block is arranged in quads containing logic for four independent full-duplex data channels.

Figure 8-1 shows the arrangement of SERDES/PCS quads on the LatticeECP3-150 FPGA (other devices have fewer quads).

**Figure 8-1. LatticeECP3-150 Block Diagram**


Table 8-2 shows the number of available SERDES/PCS quads for each device in the LatticeECP3 family.

**Table 8-2. Number of SERDES/PCS Quads per LatticeECP3 Device**

| Package         | ECP3-17                 | ECP3-35 | ECP3-70 | ECP3-95 | ECP3-150 |
|-----------------|-------------------------|---------|---------|---------|----------|
| 256-ball ftBGA  | 1                       | 1       | —       | —       | —        |
| 328-ball csBGA  | 2 channels <sup>1</sup> | —       | —       | —       | —        |
| 484-ball ftBGA  | 1                       | 1       | 1       | 1       | —        |
| 672-ball ftBGA  | —                       | 1       | 2       | 2       | 2        |
| 1156-ball ftBGA | —                       | —       | 3       | 3       | 4        |

1. Channels 0 and 3 are available.

Every quad can be programmed into one of several protocol-based modes. Each quad requires its own reference clock which can be sourced externally from package pins or internally from the FPGA logic.

Each quad can be programmed with select protocols that have nominal frequencies which can utilize the full and half-rate options per channel. For example, a PCI Express x1 at 2.5Gbps and a Gigabit Ethernet channel can be utilized in the same quad using the half-rate option on the Gigabit Ethernet channel. If a quad shares a PCI Express x1 channel with a non-PCI Express channel, ensure that the reference clock for the quad is compatible with all protocols within the quad. For example, a PCI Express spread spectrum reference clock is not compatible with most Gigabit Ethernet applications.

Since each quad has its own reference clock, different quads can support different standards on the same chip. This feature makes the LatticeECP3 family of devices ideal for bridging between different standards.

PCS quads are not dedicated solely to industry standard protocols. Each quad (and each channel within a quad) can be programmed for many user-defined data manipulation modes. For example, word alignment and clock tolerance compensation can be programmed for user-defined operation.

## PCS Quads and Channels

Each quad on a device supports up to four channels of full-duplex data. One to four channels in a quad can be utilized, depending on the application. Users can set many options for each channel independently within a given quad.

Figure 8-1 shows an example of a device with four PCS quads which contain a total of 16 PCS channels.

## Per Channel SERDES/PCS and FPGA Interface Ports

All PCS quads regardless of the mode used have the same external high-speed serial interface at the package pins. However, every PCS mode has its own unique list of input/output ports from/to the FPGA logic appropriate to the protocol chosen for the quad. A detailed description of the quad input/output signals for each mode is provided in this document. Figure 8-2 describes a simplified SERDES/PCS quad.

**Figure 8-2. SERDES/PCS Quad Block Diagram**



### Detailed Channel Block Diagram

Figure 8-3 is a detailed block diagram representation of the major functionality in a single channel of the LatticeECP3 SERDES/PCS. This diagram shows all the major blocks and the majority of the control and status signals that are visible to the user logic in the FPGA. This diagram also shows the major sub-blocks in the channel – SERDES, SERDES Bridge, PCS Core and the FPGA Bridge.

**Figure 8-3. LatticeECP3 SERDES/PCS Detailed Channel Block Diagram**



## Clocks and Resets

A PCS quad supplies per-channel locked reference clocks and per-channel recovered receive clocks to the FPGA logic interface. Each PCS quad provides clocks on both primary and secondary FPGA clock routing. The PCS/FPGA interface also has ports for the transmit and receive clocks supplied from the FPGA fabric for all four channels in each quad.

Each quad has reset inputs to force reset of both the SERDES and PCS logic in a quad or just the SERDES. In addition, separate resets dedicated for the PCS logic are provided for each channel for both the transmit and receive directions.

## Transmit Data Bus

The signals for the transmit data path are from the FPGA to the FPGA Bridge in the PCS Block. The datapath can be geared 2:1 to the internal PCS data path, which is 8 bits wide (plus control/status signals). The highest speed of the interface for PCI Express x1 is 250 MHz in 1:1 geared mode. With 2:1 gearing (i.e. a 16-bit wide data path), a possible speed is 156.25 MHz (for XAUI 4x channel mode). The SERDES and PCS will support data rates up to 3.2 Gbps data that correspond to an interface speed of 160 MHz (with 2:1 gearing).

## Receive Data Bus

The signals for the receive path are from the FPGA Bridge in the PCS Block to the FPGA. The data path may be geared 2:1 to the internal PCS data path which is 8 bits wide. The data bus width at the FPGA interface is 16 bits wide. It is possible to disable the 2:1 gearing via a software register bit, in which case, the bus widths are halved (8 bits wide). When the data is geared 2:1, the lower bits (rxdata[9:0]) correspond to the word that has been received first and the higher bits (rxdata[19:10]) correspond to the word that has been received second. If the data is not geared 2:1, the lower bits ((rxdata[9:0])) are the active bits and the higher bits should not be used. Table 8-3 describes the use of the data bus for each protocol mode.

**Table 8-3. Data Bus Usage by Mode**

| Data Bus PCS<br>Cell Name <sup>4</sup> | G8B10B | CPRI | OBSAI | PCI Express | SRIO                              | Gigabit Ethernet | XAUI                          | 8-Bit<br>SERDES        | 10-Bit<br>SERDES | SDI            |
|----------------------------------------|--------|------|-------|-------------|-----------------------------------|------------------|-------------------------------|------------------------|------------------|----------------|
| FF_RX_D_0_0                            |        |      |       |             |                                   | rxdata_ch0[0]    |                               |                        |                  |                |
| FF_RX_D_0_1                            |        |      |       |             |                                   | rxdata_ch0[1]    |                               |                        |                  |                |
| FF_RX_D_0_2                            |        |      |       |             |                                   | rxdata_ch0[2]    |                               |                        |                  |                |
| FF_RX_D_0_3                            |        |      |       |             |                                   | rxdata_ch0[3]    |                               |                        |                  |                |
| FF_RX_D_0_4                            |        |      |       |             |                                   | rxdata_ch0[4]    |                               |                        |                  |                |
| FF_RX_D_0_5                            |        |      |       |             |                                   | rxdata_ch0[5]    |                               |                        |                  |                |
| FF_RX_D_0_6                            |        |      |       |             |                                   | rxdata_ch0[6]    |                               |                        |                  |                |
| FF_RX_D_0_7                            |        |      |       |             |                                   | rxdata_ch0[7]    |                               |                        |                  |                |
| FF_RX_D_0_8                            |        |      |       |             | tx_k_ch0[0]                       |                  | txc_ch0[0]                    | GND                    | txdata_ch0[8]    |                |
| FF_RX_D_0_9                            |        |      |       |             | tx_force_disp_ch0[0] <sup>1</sup> |                  | GND                           |                        | txdata_ch0[9]    |                |
| FF_RX_D_0_10                           |        |      |       |             | tx_disp_sel_ch0[0] <sup>1</sup>   | GND              | xmit_ch0[0] <sup>2</sup>      |                        | GND              |                |
| FF_RX_D_0_11                           |        |      |       |             | GND                               | pci_ei_en_ch0[0] | GND                           | tx_disp_correct_ch0[0] |                  | GND            |
| FF_RX_D_0_12                           |        |      |       |             |                                   | txdata_ch0[8]    |                               |                        |                  | txdata_ch0[10] |
| FF_RX_D_0_13                           |        |      |       |             |                                   | txdata_ch0[9]    |                               |                        |                  | txdata_ch0[11] |
| FF_RX_D_0_14                           |        |      |       |             |                                   | txdata_ch0[10]   |                               |                        |                  | txdata_ch0[12] |
| FF_RX_D_0_15                           |        |      |       |             |                                   | txdata_ch0[11]   |                               |                        |                  | txdata_ch0[13] |
| FF_RX_D_0_16                           |        |      |       |             |                                   | txdata_ch0[12]   |                               |                        |                  | txdata_ch0[14] |
| FF_RX_D_0_17                           |        |      |       |             |                                   | txdata_ch0[13]   |                               |                        |                  | txdata_ch0[15] |
| FF_RX_D_0_18                           |        |      |       |             |                                   | txdata_ch0[14]   |                               |                        |                  | txdata_ch0[16] |
| FF_RX_D_0_19                           |        |      |       |             |                                   | txdata_ch0[15]   |                               |                        |                  | txdata_ch0[17] |
| FF_RX_D_0_20                           |        |      |       |             | tx_k_ch0[1]                       |                  | txc_ch0[1]                    | GND                    | txdata_ch0[18]   |                |
| FF_RX_D_0_21                           |        |      |       |             | tx_force_disp_ch0[1] <sup>1</sup> |                  | GND                           |                        | txdata_ch0[19]   |                |
| FF_RX_D_0_22                           |        |      |       |             | tx_disp_sel_ch0[1] <sup>1</sup>   | GND              | xmit_ch0[1] <sup>2</sup>      |                        | GND              |                |
| FF_RX_D_0_23                           |        |      |       |             | GND                               | pci_ei_en_ch0[1] | GND                           | tx_disp_correct_ch0[1] |                  | GND            |
| FF_RX_D_0_0                            |        |      |       |             |                                   | rxdata_ch0[0]    |                               |                        |                  |                |
| FF_RX_D_0_1                            |        |      |       |             |                                   | rxdata_ch0[1]    |                               |                        |                  |                |
| FF_RX_D_0_2                            |        |      |       |             |                                   | rxdata_ch0[2]    |                               |                        |                  |                |
| FF_RX_D_0_3                            |        |      |       |             |                                   | rxdata_ch0[3]    |                               |                        |                  |                |
| FF_RX_D_0_4                            |        |      |       |             |                                   | rxdata_ch0[4]    |                               |                        |                  |                |
| FF_RX_D_0_5                            |        |      |       |             |                                   | rxdata_ch0[5]    |                               |                        |                  |                |
| FF_RX_D_0_6                            |        |      |       |             |                                   | rxdata_ch0[6]    |                               |                        |                  |                |
| FF_RX_D_0_7                            |        |      |       |             |                                   | rxdata_ch0[7]    |                               |                        |                  |                |
| FF_RX_D_0_8                            |        |      |       |             | rx_k_ch0[0]                       |                  | txc_ch0[0]                    | NC                     | rxdata_ch0[8]    |                |
| FF_RX_D_0_9                            |        |      |       |             | rx_disp_err_ch0[0]                | rxstatus0_ch0[0] | rx_disp_err_ch0[0]            | NC                     | rxdata_ch0[9]    |                |
| FF_RX_D_0_10                           |        |      |       |             | rx_cv_err_ch0[0] <sup>3</sup>     | rxstatus0_ch0[1] | rx_cv_err_ch0[0] <sup>3</sup> |                        | NC               |                |
| FF_RX_D_0_11                           |        |      |       |             | NC                                | rxstatus0_ch0[2] |                               | NC                     |                  |                |
| FF_RX_D_0_12                           |        |      |       |             |                                   | rxdata_ch0[8]    |                               |                        | rxdata_ch0[10]   |                |
| FF_RX_D_0_13                           |        |      |       |             |                                   | rxdata_ch0[9]    |                               |                        | rxdata_ch0[11]   |                |
| FF_RX_D_0_14                           |        |      |       |             |                                   | rxdata_ch0[10]   |                               |                        | rxdata_ch0[12]   |                |
| FF_RX_D_0_15                           |        |      |       |             |                                   | rxdata_ch0[11]   |                               |                        | rxdata_ch0[13]   |                |
| FF_RX_D_0_16                           |        |      |       |             |                                   | rxdata_ch0[12]   |                               |                        | rxdata_ch0[14]   |                |
| FF_RX_D_0_17                           |        |      |       |             |                                   | rxdata_ch0[13]   |                               |                        | rxdata_ch0[15]   |                |

**Table 8-3. Data Bus Usage by Mode (Continued)**

| Data Bus PCS Cell Name <sup>4</sup> | G8B10B                        | CPRI             | OBSAI | PCI Express                   | SRIO | Gigabit Ethernet | XAUI | 8-Bit SERDES   | 10-Bit SERDES  | SDI |  |  |  |  |  |
|-------------------------------------|-------------------------------|------------------|-------|-------------------------------|------|------------------|------|----------------|----------------|-----|--|--|--|--|--|
| FF_RX_D_0_18                        | rxdata_ch0[14]                |                  |       |                               |      |                  |      |                | rxdata_ch0[16] |     |  |  |  |  |  |
| FF_RX_D_0_19                        | rxdata_ch0[15]                |                  |       |                               |      |                  |      |                | rxdata_ch0[17] |     |  |  |  |  |  |
| FF_RX_D_0_20                        | rx_k_ch0[1]                   |                  |       | rxc_ch0[1]                    |      |                  | NC   | rxdata_ch0[18] |                |     |  |  |  |  |  |
| FF_RX_D_0_21                        | rx_disp_err_ch0[1]            | rxstatus1_ch0[0] |       | rx_disp_err_ch0[1]            |      |                  | NC   | rxdata_ch0[19] |                |     |  |  |  |  |  |
| FF_RX_D_0_22                        | rx_cv_err_ch0[1] <sup>3</sup> | rxstatus1_ch0[1] |       | rx_cv_err_ch0[1] <sup>3</sup> |      |                  | NC   |                |                |     |  |  |  |  |  |
| FF_RX_D_0_23                        | NC                            | rxstatus1_ch0[2] |       | NC                            |      |                  |      |                |                |     |  |  |  |  |  |

1. The force\_disp signal will force the disparity for the associated data word on bits [7:0] to the column selected by the tx\_disp\_sel signal. If disp\_sel is a one, the 10-bit code is taken from the 'current RD+' column (positive disparity). If the tx\_disp\_sel is a zero, the 10-bit code is taken from the 'current RD-' (negative disparity) column.
2. The Lattice Gigabit Ethernet PCS IP core provides an auto-negotiation state machine that generates the signal xmit. It is used to interact with the Gigabit Ethernet Idle State Machine in the hard logic.
3. When there is a code violation, the packet PCS 8b10b decoder will replace the output from the decoder with hex EE and K asserted (K=1 and d=EE is not part of the 8b10b coding space).
4. FF\_TX\_D\_0\_0: FPGA Fabric Transmit Data Bus Channel 0 Bit 0.

## Mode-Specific Control/Status Signal Descriptions

Table 8-4 describes the mode-specific control/status signals.

**Table 8-4. Control Signals and their Functions**

| Signal Name                     | Description                                                                                                                       |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| <b>Transmit Control Signals</b> |                                                                                                                                   |
| tx_k_ch[3:0]                    | Per channel, active-high control character indicator.                                                                             |
| tx_force_disp_ch[3:0]           | Per channel, active-high signal which instructs the PCS to accept disparity value from the disp_sel_ch(0-3) FPGA interface input. |
| tx_disp_sel_ch[3:0]             | Per channel, disparity value supplied from FPGA logic. Valid when force_disp_ch(0-3) is high.                                     |
| tx_correct_disp_ch[3:0]         | Corrects disparity identifier when asserted by adjusting the 8b10b encoder to begin in the negative disparity state.              |
| <b>Receive Status Signals</b>   |                                                                                                                                   |
| rx_k_ch[3:0]                    | Per channel, active-high control character indicator.                                                                             |
| rx_disp_err_ch[3:0]             | Per channel, active-high signal driven by the PCS to indicate a disparity error was detected with the associated data.            |
| rx_cv_err_ch[3:0]               | Per channel, code violation signal to indicate an error was detected with the associated data.                                    |

### Control

Each mode has its own set of control signals which allows direct control of various PCS features from the FPGA logic. In general, each of these control inputs duplicates the effect of writing to a corresponding control register bit or bits.

{signal}\_c is the control signal from the FPGA core to the FPGA bridge. All of the control signals are used asynchronously inside the SERDES/PCS.

### Status

Each mode has its own set of status or alarm signals that can be monitored by the FPGA logic. In general, each of these status outputs corresponds to a specific status register bit or bits. The Diamond design tools give the user the option to bring these ports out to the PCS FPGA interface.

{signal}\_s is the status the signal to the FPGA core from the FPGA bridge. All of the status signals are asynchronous from the SERDES/PCS. These should be synchronized to a clock domain before they are used in the FPGA design.

Please refer to the Mode-Specific Control/Status Signals section of this document for detailed information about control and status signals.

## SERDES/PCS

The quad contains four channels with both RX and TX circuits, and an auxiliary channel that contains the TX PLL. The reference clock to the TX PLL can be provided either by the primary differential reference clock pins or by the FPGA core. The quad SERDES/PCS macro performs the serialization and de-serialization function for four lanes of data. In addition, the TxPLL within the SERDES/PCS block provides the system clock for the FPGA logic. The quad also supports both full-data-rate and half-data-rate modes of operation on each TX and RX circuit independently. The block-level diagram is shown in Figure 8-4.

**Figure 8-4. SERDES/PCS Block Signal Interface**



## I/O Descriptions

Table 8-5 lists all default and optional inputs and outputs to/from a PCS quad. Users can choose optional ports for a PCS quad using the IPexpress™ GUI.

**Table 8-5. SERDES\_PCS I/O Descriptions**

| Signal Name                                                                             | I/O | Type    | Description                                                                                                                                                                                   |
|-----------------------------------------------------------------------------------------|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Primary I/O, SERDES Quad</b>                                                         |     |         |                                                                                                                                                                                               |
| hdinp_ch0                                                                               | I   | Channel | High-speed CML input, positive, channel 0                                                                                                                                                     |
| hdinn_ch0                                                                               | I   | Channel | High-speed CML input, negative, channel 0                                                                                                                                                     |
| hdinp_ch1                                                                               | I   | Channel | High-speed CML input, positive, channel 1                                                                                                                                                     |
| hdinn_ch1                                                                               | I   | Channel | High-speed CML input, negative, channel 1                                                                                                                                                     |
| hdinp_ch2                                                                               | I   | Channel | High-speed CML input, positive, channel 2                                                                                                                                                     |
| hdinn_ch2                                                                               | I   | Channel | High-speed CML input, negative, channel 2                                                                                                                                                     |
| hdinp_ch3                                                                               | I   | Channel | High-speed CML input, positive, channel 3                                                                                                                                                     |
| hdinn_ch3                                                                               | I   | Channel | High-speed CML input, negative, channel 3                                                                                                                                                     |
| hdoutp_ch0                                                                              | O   | Channel | High-speed CML output, positive, channel 0                                                                                                                                                    |
| hdoutn_ch0                                                                              | O   | Channel | High-speed CML output, negative, channel 0                                                                                                                                                    |
| hdoutp_ch1                                                                              | O   | Channel | High-speed CML output, positive, channel 1                                                                                                                                                    |
| hdoutn_ch1                                                                              | O   | Channel | High-speed CML output, negative, channel 1                                                                                                                                                    |
| hdoutp_ch2                                                                              | O   | Channel | High-speed CML output, positive, channel 2                                                                                                                                                    |
| hdoutn_ch2                                                                              | O   | Channel | High-speed CML output, negative, channel 2                                                                                                                                                    |
| hdoutp_ch3                                                                              | O   | Channel | High-speed CML output, positive, channel 3                                                                                                                                                    |
| hdoutn_ch3                                                                              | O   | Channel | High-speed CML output, negative, channel 3                                                                                                                                                    |
| refclkp                                                                                 | I   | Quad    | Reference Clock input, positive, dedicated CML input                                                                                                                                          |
| refclkn                                                                                 | I   | Quad    | Reference Clock input, negative, dedicated CML input                                                                                                                                          |
| <b>Receive / Transmit Data Bus (See Tables 8-3 and 8-4 for Detailed Data Bus Usage)</b> |     |         |                                                                                                                                                                                               |
| rxdata_ch0[23:0]                                                                        | O   | Channel | Data signals for the channel 0 receive path                                                                                                                                                   |
| rxdata_ch1[23:0]                                                                        | O   | Channel | Data signals for the channel 1 receive path                                                                                                                                                   |
| rxdata_ch2[23:0]                                                                        | O   | Channel | Data signals for the channel 2 receive path                                                                                                                                                   |
| rxdata_ch3[23:0]                                                                        | O   | Channel | Data signals for the channel 3 receive path                                                                                                                                                   |
| txdata_ch0[23:0]                                                                        | I   | Channel | Data signals for the channel 0 transmit path                                                                                                                                                  |
| txdata_ch1[23:0]                                                                        | I   | Channel | Data signals for the channel 1 transmit path                                                                                                                                                  |
| txdata_ch2[23:0]                                                                        | I   | Channel | Data signals for the channel 2 transmit path                                                                                                                                                  |
| txdata_ch3[23:0]                                                                        | I   | Channel | Data signals for the channel 3 transmit path                                                                                                                                                  |
| <b>Control Signals</b>                                                                  |     |         |                                                                                                                                                                                               |
| tx_idle_ch[3:0]_c                                                                       | I   | Channel | Controls transmission of electrical idle by SERDES transmitter.<br>1 = Force SERDES transmitter to output electrical idle<br>0 = Normal operation                                             |
| pcie_det_en_ch[3:0]_c                                                                   | I   | Channel | FPGA logic (user logic) informs the SERDES block that it will be requesting for a PCI Express Receiver Detection operation.<br>1 = Enable PCI Express receiver detect, 0 = Normal operation   |
| pcie_ct_ch[3:0]_c                                                                       | I   | Channel | 1 = Request transmitter to do far-end receiver detection<br>0 = Normal data operation                                                                                                         |
| rx_invert_ch[3:0]_c                                                                     | I   | Channel | Control the inversion of received data.<br>1 = Invert the data, 0 = Don't invert the data                                                                                                     |
| word_align_en_ch[3:0]_c                                                                 | I   | Channel | Control comma aligner.<br>1 = Re-acquire COMMA alignment, 0 = Clears internal aligned status<br>Once alignment is found, it is locked at current position until the signal is pulsed to HIGH. |

**Table 8-5. SERDES\_PCS I/O Descriptions (Continued)**

| Signal Name             | I/O | Type    | Description                                                                                                              |
|-------------------------|-----|---------|--------------------------------------------------------------------------------------------------------------------------|
| sb_felb_ch[3:0]_c       | I   | Channel | SERDES Bridge Parallel Loopback<br>1 = Enable loopback from RX to TX, 0 = Normal data operation                          |
| sb_felb_RST_ch[3:0]_c   | I   | Channel | SERDES Bridge Parallel Loopback FIFO Clear<br>1 = Reset Loopback FIFO, 0 = Normal Loopback operation                     |
| tx_sync_qd_c            | I   | Quad    | Serializer Reset<br>Transition = Reset, Level = Normal Operation                                                         |
| rx_div2_mode_ch[3:0]_c  | I   | Channel | Receiver Rate Mode Select (Full/Half Rate)<br>1 = Half Rate, 0 = Full Rate                                               |
| tx_div2_mode_ch[3:0]_c  | I   | Channel | Transmitter Rate Mode Select (Full/Half Rate)<br>1 = Half Rate, 0 = Full Rate                                            |
| rx_div11_mode_ch[3:0]_c | I   | Channel | Receiver Rate Mode Select (Div11/Full Rate)<br>1 = Div11 Rate, 0 = Full Rate                                             |
| tx_div11_mode_ch[3:0]_c | I   | Channel | Transmitter Rate Mode Select (Div11/Full Rate)<br>1 = Div11 Rate, 0 = Full Rate                                          |
| txd_ldr_en_ch{3:0}_c    | I   | Channel | Low Data Rate TX Serial Path Enable<br>1 = Enable, 0 = Disable                                                           |
| <b>Reset Signals</b>    |     |         |                                                                                                                          |
| rx_pcs_rst_ch[3:0]_c    | I   | Channel | Active-high, asynchronous input. Resets individual receive channel logic only in PCS.                                    |
| tx_pcs_rst_ch[3:0]_c    | I   | Channel | Active-high, asynchronous input. Resets individual transmit channel logic only in PCS.                                   |
| rx_serdes_rst_ch[3:0]_c | I   | Channel | Active-high. Resets selected digital logic in the SERDES receive channel.                                                |
| tx_serdes_rst_c         | I   | Quad    | Active-high. Resets selected digital logic in all SERDES transmit channels.                                              |
| rst_qd_c                | I   | Quad    | Active-high, asynchronous input. Resets all SERDES channels including the auxiliary channel and PCS.                     |
| serdes_rst_qd_c         | I   | Quad    | Active-high, asynchronous input to SERDES quad. Resets all SERDES channels including the Quad channel but not PCS logic. |
| tx_pwrup_ch[3:0]_c      | I   | Channel | Active-high transmit channel power up. 0 = Transmit channel power-down.                                                  |
| rx_pwrup_ch[3:0]_c      | I   | Channel | Active-high receive channel power up. 0 = Receive channel power-down.                                                    |
| <b>Status Signals</b>   |     |         |                                                                                                                          |
| pcie_done_ch[0:3]_s     | O   | Channel | 1 = Far-end receiver detection complete<br>0 = Far-end receiver detection incomplete                                     |
| pcie_con_ch[3:0]_s      | O   | Channel | Result of far-end receiver detection.<br>1 = Far-end receiver detected<br>0 = Far end receiver not detected.             |
| rx_los_low_ch[3:0]_s    | O   | Channel | Loss of signal (LO THRESHOLD RANGE) detection for each channel.                                                          |
| lsm_status_ch[3:0]_s    | O   | Channel | 1 = Lane is synchronous to commas<br>0 = Lane has not found comma                                                        |
| ctc_urrun_ch[3:0]_s     | O   | Channel | 1 = Receive clock compensator FIFO underrun error<br>0 = No FFIFO errors                                                 |
| ctc_orun_ch[3:0]_s      | O   | Channel | 1 = Receive clock compensator FIFO overrun error<br>0 = No FIFO errors                                                   |
| rx_cdr_lol_ch[3:0]_s    | O   | Channel | 1 = Receive CDR loss of lock<br>0 = Lock maintained                                                                      |
| tx_pll_lol_qd_s         | O   | Quad    | 1 = Transmit PLL loss of lock<br>0 = Lock maintained                                                                     |
| ctc_ins_ch[3:0]_s       | O   | Channel | 1 = SKIP Character Added by CTC                                                                                          |

**Table 8-5. SERDES\_PCS I/O Descriptions (Continued)**

| Signal Name                                                                | I/O | Type    | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------------------------------------------------------------------|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctc_del_ch[3:0]_s                                                          | O   | Channel | 1 = SKIP Character Deleted by CTC                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>FPGA Interface Clocks</b>                                               |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                              |
| rx_full_clk_ch[3:0]                                                        | O   | Channel | Receive channel recovered clock. In user mode, the source is always the channel's recovered clock. For standards such as 10 GbE that support clock compensation, the source is the respective transmit channel's system clock. For PCS bypass modes, it is also the transmit system clock, thus requiring raw mode to actually be done using either 8b10b mode with the 8b10b decoder disabled (10-bit or 20-bit data path). |
| rx_half_clk_ch[3:0]                                                        | O   | Channel | Receive channel recovered half clock. In 2:1 gearing mode, it is a divide-by-2 output.                                                                                                                                                                                                                                                                                                                                       |
| tx_full_clk_ch[3:0]                                                        | O   | Channel | TX PLL full rate clock. Only tx_full_clk_ch0 can drive the primary clock routing directly. All of the tx_full_clk_ch[3:0] signals can drive the secondary clock routing by applying a USE SECONDARY clocking preference. <sup>3</sup>                                                                                                                                                                                        |
| tx_half_clk_ch[3:0]                                                        | O   | Channel | TX PLL half clock. Only tx_half_clk_ch0 can drive the primary clock routing directly. All of the tx_half_clk_ch[3:0] signals can drive the secondary clock routing by applying a USE SECONDARY clocking preference. <sup>3</sup>                                                                                                                                                                                             |
| refclk2fpga                                                                | O   | Quad    | Reference clock to FPGA core. If selected, this clock is always active as long as reference clock is active even when the quad is in power down mode.                                                                                                                                                                                                                                                                        |
| fpga_rxrefclk_ch[3:0]                                                      | I   | Quad    | RX reference clock from FPGA logic, for CDR PLL                                                                                                                                                                                                                                                                                                                                                                              |
| fpga_txrefclk                                                              | I   | Quad    | TX reference clock from FPGA logic, for TX SERDES PLL                                                                                                                                                                                                                                                                                                                                                                        |
| ebrd_clk_ch[3:0] <sup>2</sup>                                              | I   | Channel | Receive channel clock input from FPGA for CTC FIFO read.                                                                                                                                                                                                                                                                                                                                                                     |
| rxclk_ch[3:0]                                                              | I   | Channel | Receive channel clock input from FPGA. Used to clock the RX FPGA Interface FIFO with a clock synchronous to the reference and/or receive reference clock.                                                                                                                                                                                                                                                                    |
| txclk_ch[3:0]                                                              | I   | Channel | Transmit channel clock input from FPGA. Per channel transmit clock inputs from FPGA. Used to clock the TX FPGA Interface FIFO with a clock synchronous to the reference clock. Also used to clock the RX FPGA Interface FIFO with a clock synchronous to the reference clock when CTC is used.                                                                                                                               |
| <b>Low-Speed Receive/Transmit Data and SERDES Client Interface Signals</b> |     |         |                                                                                                                                                                                                                                                                                                                                                                                                                              |
| rx_drd_ldr_ch[3:0]                                                         | O   | Channel | Single-ended serial low data rate outputs (RX) to FPGA core                                                                                                                                                                                                                                                                                                                                                                  |
| tx_drd_ldr_ch[3:0]                                                         | I   | Channel | Single-ended serial low data rate inputs (TX) from FPGA core                                                                                                                                                                                                                                                                                                                                                                 |
| sci_wrdtdata[7:0]                                                          | I   | —       | Write data input                                                                                                                                                                                                                                                                                                                                                                                                             |
| sci_wrn                                                                    | I   | —       | Write input strobe                                                                                                                                                                                                                                                                                                                                                                                                           |
| sci_sel_quad                                                               | I   | —       | Selects quad registers                                                                                                                                                                                                                                                                                                                                                                                                       |
| sci_sel_ch[3:0]                                                            | I   | —       | Selects channel registers                                                                                                                                                                                                                                                                                                                                                                                                    |
| sci_addr[5:0]                                                              | I   | —       | Address bus input                                                                                                                                                                                                                                                                                                                                                                                                            |
| sci_rd                                                                     | I   | —       | Read data select                                                                                                                                                                                                                                                                                                                                                                                                             |
| sci_rddata[7:0]                                                            | O   | —       | Read data output                                                                                                                                                                                                                                                                                                                                                                                                             |
| sci_int                                                                    | O   | —       | Interrupt output                                                                                                                                                                                                                                                                                                                                                                                                             |

1. During configuration, both hdoutp and hdoutn are pulled high to VCCOB.
2. This clock is not provided in the wrapper module port list. Software automatically assigns the clock depending on the CTC mode. See the FPGA Interface Clocks section of this document for detailed information.
3. General routing is used to access the Secondary Clock Net. The user may get a PAR warning but the delay will be small enough to ignore in most applications. Use the Timing Preferences and review the Trace Report to make sure the timing is not violated.

## SERDES/PCS Functional Description

LatticeECP3 devices have from one to four quads of embedded SERDES/PCS logic. Each quad, in turn, supports four independent full-duplex data channels. A single channel can support a data link and each quad can support up to four such channels.

The embedded SERDES CDR PLLs and TX PLLs support data rates that cover a wide range of industry standard protocols.

Refer to Figure 8-3 for each of the items below.

- **SERDES**
  - Equalizer
  - CDR (Clock and Data Recovery)
  - Deserializer
  - PreEmphasis
  - Serializer
  - Two Serial Loopback modes, TX-to-RX or RX-to-TX
- **SERDES Bridge (SB)**
  - Inverter – Inverts receive data, required by PCI Express
  - SERDES Bridge Parallel Loopback
- **PCS Core**
  - Word Alignment
  - 8b10b Decoder
  - 8b10b Encoder
  - Link State Machine
  - Clock Tolerance Compensation
- **FPGA Bridge (FB)**
  - Downsample FIFO
  - Upsample FIFO

## SERDES

### Equalizer

As the data rate of digital transmission advances over Gbps, frequency-dependent attenuation results in severe intersymbol interference in the received signal and makes it mandatory to use an equalizer in the data transceiver to recover data correctly. Six pole positions are provided: Mid\_Low, Mid\_Med, Mid\_High, Long\_Low, Long\_Med, Long\_High frequency ranges.

A default selection of the pole position is included when a protocol standard is selected. This selection is based on most commonly used condition on user's system board. However, user may wish to optimize the signal by adjusting this setting. User has to perform bit-error-rate tests on all different pole settings to determine the optimal one.

### Pre-Emphasis

Pre-emphasis refers to a system process designed to increase the magnitude of some frequencies with respect to the magnitude of other frequencies. The goal is to improve the overall signal-to-noise ratio by minimizing the adverse effects of such phenomena as attenuation differences. Users can select up to 80% of pre-emphasis.

By default, pre-emphasis is not enabled. User can determine if the Tx drive signal has to route a long distance to the Rx side. If the routing trace length is long, he can try out different pre-emphasis settings to determine the best signal eye at the Rx-end of the trace.

## Reference Clocks

The SERDES quad contains four channels with both RX and TX circuits, and an auxiliary channel that contains the TX PLL. The reference clock to the TX PLL can be provided either by the primary differential reference clock pins, by the neighbor quad's reference clock or by the FPGA core. In addition, the PLL within the SERDES block provides an output clock that can be used as the system clock driving the FPGA fabric.

The reference clock to the RX can be provided either by the reference clock to the TX PLL or by the FPGA core. The reference clocks from the FPGA core to the TX PLL and to the RX may come from different sources.

## SERDES Clock Architecture

Figure 8-5 shows the overall SERDES clock architecture. The diagram is split into two halves, Quad and Channel. Only one per-channel section is shown for the sake of brevity. Also, the various control bits for the different blocks are shown. These could be quad-based control register bits or channel-based control register bits. In some cases, it can be channel control port based. Some are a combination of both register and control ports. Using both modes enables dynamic control of certain functional properties.

**Figure 8-5. SERDES Clock Architecture**



1. All control bits are quad based.
2. All control bits are channel based, except as indicated (\*).
3. These clocks are user-transparent.

The main components of the clock architecture include:

- Per RX and per TX Divider (DIV) modes – DIV2, DIV11
- Multi-quad REFCLK connections
- Multiple channel transmit synchronization using the tx\_sync\_qd\_c signal from the FPGA
- OOB low data rate application support

## Rate Modes

The TX in each channel can be independently programmed to run at one of the following rates:

- FULL\_RATE
- HALF\_RATE (DIV2)
- DIV11

The RX can also use a separate reference clock per channel, allowing the transmitter and receiver to run at completely different rates.

It is important to note that the PLL VCO is left untouched, supporting the highest rate for that protocol. All divided rates required by that protocol are supported by programming the divider mux selects. This enables very quick data rate changeover since the PLL does not need to be reprogrammed. This is valuable in many applications.

*Note: The LatticeECP3 PCS cannot handle a change in rates at runtime. Simply changing the refclk rate will not allow the SERDES to work at a new range. The SERDES settings must be re-configured, either with a new bit-stream, or changed via the SERDES' SCI interface. The SERDES link must be reset after the settings are changed.*

The TX PLL and the four CDR PLLs generally run at the same frequency, which is a multiple of the reference clock frequency. Table 8-6 illustrates the various clock rate modes possible. The bit clock indicated is a multiple of the reference clock frequency.

**Table 8-6. TXPLL and RX CDRPLL Supported Modes**

| Reference Clock Mode | refclkPmode (Quad) | Bus_width | Bit Clock (Full Rate) | Bit Clock (div2, div11)     |
|----------------------|--------------------|-----------|-----------------------|-----------------------------|
| 20x                  | 0                  | 10        | Refclk x 20           | Refclk x 10                 |
| 16x                  | 0                  | 8         | Refclk x 16           | Refclk x 8                  |
| 10x                  | 1                  | 10        | Refclk x 10           | Refclk x 5                  |
| 8x                   | 1                  | 8         | Refclk x 8            | Refclk x 4                  |
| 25x                  | —                  | 8         | Refclk x 25           | Refclk x 12.5               |
| 25x                  | —                  | 10        | Refclk x 25           | Refclk x 12.5               |
| 20x                  | 0                  | 10        | Refclk x 20           | Refclk x 20/11 <sup>1</sup> |

1. DIV11 mode.

## Reference Clock from an FPGA Core

As described in Figure 8-5, the TX reference clock can be brought from the FPGA core. In this case, the extra jitter caused by the FPGA resources to route the clock to the SERDES will be passed onto the transmit data and may violate TX jitter specifications on a case-by-case basis. Caution should be used when using an FPGA-originated SERDES TX reference clock.

**Figure 8-6. Reference Clock Block Diagram**



## Full Data, Div 2 and Div 11 Data Rates

Each TX Serializer and RX Deserializer can be split into full data rate and div2 rate or div11 rate depending on the protocol, allowing for different data rates in each direction and in each channel. Refer to Figure 8-6 for further information.

As shown in Figure 8-7, all four channels can be configured differently.

**Figure 8-7. Example of Full Data Rate and Half Data Rate in the IPexpress GUI**



The actual data rate and FPGA interface clock rate for this example are described in Table 8-7. The IPexpress GUI will be discussed in detail later in this document.

**Table 8-7. Clock Rate Example**

| Channel   | Data Rate | Reference Clock Multiplier | Data Rate Mode    | Calculated Reference Clock Rate | FPGA Interface Data Bus Width | FPGA Interface Clock Rate | tx_full_clk | tx_half_clk |
|-----------|-----------|----------------------------|-------------------|---------------------------------|-------------------------------|---------------------------|-------------|-------------|
| Channel 0 | 1 Gbps    | 10 x                       | FULL              | 100 MHz                         | 8 (10) <sup>3</sup>           | 100 MHz                   | 100 MHz     | 50 MHz      |
| Channel 1 | 500 Mbps  | 10 x                       | DIV2              | 100 MHz                         | 8 (10)                        | 50 MHz                    | 50 MHz      | 25 MHz      |
| Channel 2 | 1 Gbps    | 10 x                       | FULL              | 100 MHz                         | 16 (20)                       | 50 MHz                    | 100 MHz     | 50 MHz      |
| Channel 3 | 500 Mbps  | 10 x                       | DIV2 <sup>2</sup> | 100 MHz                         | 16 (20)                       | 25 MHz                    | 50 MHz      | 25 MHz      |

1. The clocks in the shaded cells are used as the FPGA interface clocks in each mode.
2. In DIV2 mode, the tx\_full\_clk is adjusted to half rate. tx\_half\_clk is used for the 16-bit bus interface only.
3. 10-bit SERDES only mode or SDI mode.

## Dynamic Switching Between Full Rate and Half Rate (DIV2)

This section describes how to switch between Full Rate and Half Rate (DIV) dynamically.

The two rate mode control signals are or'ed as shown in Figure 8-8.

**Figure 8-8. Rate Mode Control Signals**



`tx_div2_mode_chx_c` is an input control signal to the TX path from the FPGA fabric.

`rx_div2_mode_chx_c` is an input control signal to the RX path from the FPGA fabric.

Rate\_Mode\_Tx(CH\_14[1]) is the Control Register bit for the TX path.

**Rate\_Mode\_Rx(CH\_15[1])** is the Control Register bit for the RX path.

In the rx lane, the pcs\_rst should be applied after switching.

In the tx lane, no reset is required for the new rate to take place.

## Reference Clock Sources

**refclkp, refclkn**

Dedicated CML input. This is the first choice unless different clock sources for RX and TX are used. The clock signal may be CML, LVDS or LVPECL. Refer to TN1114, [Electrical Recommendations for Lattice SERDES](#), for example interface circuits.

**fpga\_txrefclk, fpga\_rxrefclk**

Reference clock from FPGA logic. The Primary Clock pad (PCLK) should be used as the clock input pin to the FPGA. The clock signal may be CML, LVDS, LVPECL or single-ended.

FPGA PLL

When an FPGA PLL is used as the reference clock, the reference clock to the PLL should be assigned to a dedicated PLL input pad. The FPGA PLL output jitter may not meet system specifications at higher data rates. Use of an FPGA PLL is not recommended in jitter-sensitive applications.

## **Spread Spectrum Clocking (SSC) Support**

The ports on the two ends of Link must transmit data at a rate that is within 600pm of each other at all times. This is specified to allow bit-rate clock source with a +/- 300ppm tolerance. The minimum clock period cannot be violated. The preferred method is to adjust the spread technique to not allow for modulation above the nominal frequency. The data rate can be modulated from +0% to -0.5% of the nominal data rate frequency, at a modulation rate in the range not exceeding 30KHz to 33Khz. Along with the +/- 300ppm tolerance limit, both ports require the same bit rate clock when the data is modulated with an SSC.

In PCI Express applications, the root complex is responsible for spreading the reference clock. The endpoint will use the same clock to pass back the spectrum through the TX. Thus, there is no need for a separate RXREFCLK. The predominant application is an add-in card. Add-in cards are not required to use the REFCLK from the connector but must receive and transmit with the same SSC as the PCI Express connector REFCLK.

While the LatticeECP3 architecture will allow the mixing of a PCI Express channel and a Gigabit Ethernet, Serial RapidIO or SGMII channel within the same quad, using a PCI Express SSC as the transmit reference clock will cause a violation of the Gigabit Ethernet, Serial RapidIO and SGMII transmit jitter specifications.

## **Loss of Signal**

Each channel contains a programmable loss-of-signal detector as shown in Figure 8-9.

The loss-of-signal threshold depends on the value of the programmable current source. The current source value is chosen using the rlos\_lset[2:0] control bit. The result of threshold detection is indicated to the FPGA through the rx\_los\_low status signal.

**Figure 8-9. Loss of Signal Detector**



Note: rx\_los\_low shows that a signal has been detected for data rates above 1 Gbps with a maximum CID (Consecutive Identical Digits) of 7 bits (i.e., a minimum input signal transition density as is sent by 8b10b).

rx\_los\_low is supported with a default setting of rlos\_lset[2:0] = 2, except in PCI Express mode and SDI mode. In PCI Express mode, 2 and 3 are supported.

In SDI mode, it is recommended to use the carrier detect output signal (/CD) from the external SDI cable equalizer.

**Table 8-8. Response Time for Loss of Signal Detector**

| Description                                               | Min. | Typ. | Max. | Units |
|-----------------------------------------------------------|------|------|------|-------|
| Time to detect that signal is lost (rx_los_low 0 to 1)    | —    | 8    | 10   | ns    |
| Time to detect that signal is present (rx_los_low 1 to 0) | —    | 8    | 10   | ns    |

## **Loss Of Lock**

Both the transmit PLL and the individual channel CDRs have digital counter-based, loss-of-lock detectors. If the transmit PLL loses lock, the loss-of-lock for the PLL is asserted and remains asserted until the PLL reacquires lock. If a CDR loses lock, the loss-of-lock for that channel is asserted and locking to the reference clock retrains the VCO in the CDR. When this is achieved, loss-of-lock for that channel is de-asserted and the CDR is switched back over to lock to the incoming data. The CDR will either remain locked to the data, or will go back out of lock again in which case the re-training cycle will repeat. For detailed information on CDR loss-of-lock, refer to the SERDES/PCS RESET section of this document.

**Table 8-9. Response Time for Loss-of-Lock Detector**

| Description                                                           | Min. | Typ. | Max. | Units |
|-----------------------------------------------------------------------|------|------|------|-------|
| Time to detect that loop is unlocked (tx_pll_lol, rx_cdr_lol, 0 to 1) | —    | 200  | 500  | us    |
| Time to detect that loop is locked (tx_pll_lol, rx_cdr_lol, 1 to 0)   | —    | 200  | 500  | us    |

## **TX Lane-to-Lane Skew**

A control signal, tx\_sync\_qd\_c, resets all of the active TX channels to start serialization with bit 0. Most multi-channel protocol standards have requirements to ensure that the TX lane-to-lane skew is within a certain specification.

The reset to the TX serializers is generated either by toggling the tx\_sync\_qd\_c signal or by a transition in PLL loss of lock.

## SERDES PCS Configuration Setup

The LatticeECP3 PCS can be configured for use in various applications. Setup is chosen with the IPexpress module generation tool which allows the user to select the mode and feature options for the PCS. Option selections are saved in an auto-configuration file which is subsequently used by the Bitstream Generator to write the user selections into the bitstream. To change PCS option selections it is recommended that the user rerun IPexpress to regenerate a PCS module and create a new auto-configuration file. Some options can be changed by manually editing the auto-configuration file before running the Bitstream Generator. After configuration, PCS options can be changed dynamically by writing to PCS registers via the optional SERDES Client Interface bus. The SERDES Client Interface allows the SERDES/PCS quad to be controlled by registers as opposed to configuration memory cells. A table of control and status registers accessible through the SCI is provided in Appendix A.

## Auto-Configuration File

Initial register setup for each PCS mode can be performed by using the auto-configuration feature in IPexpress. The module generator provides an auto-configuration file which contains the quad and channel register settings for the chosen mode. This file can be referred to for front-end simulation and also can be integrated into the bitstream. When an auto-configuration file is integrated into the bitstream all the quad and channel registers will be set to values defined in the auto-configuration file during configuration. The SCI must be included in a design if the user needs to change control registers or monitor status registers during operation.

## Transmit Data

The PCS quad transmit data path consists of an 8b10b encoder and serializer per channel.

### 8b10b Encoder

This module implements an 8b10b encoder as described within the IEEE 802.3ae-2002 1000BASE-X specification. The encoder performs the 8-bit to 10-bit code conversion as described in the specification, along with maintaining the running disparity rules as specified. The 8b10b encoder can be bypassed on a per-channel basis by setting the attribute CHx\_8B10B to "BYPASS" where x is the channel number.

### Serializer

The 8b10b encoded data undergoes parallel-to-serial conversion and is transmitted off-chip via the embedded SERDES.

## Receive Data

The PCS quad receive data path consists of the following sub-blocks per channel: Deserializer, Word Aligner, 8b10b Decoder, Optional Link State Machine, and Optional Receive Clock Tolerance Compensation (CTC) FIFO.

### Deserializer

Data is brought on-chip to the embedded SERDES where it goes from serial to parallel.

### Word Alignment (Byte Boundary Detect)

This module performs the comma codeword detection and alignment operation. The comma character is used by the receive logic to perform 10-bit word alignment upon the incoming data stream. The comma description can be found in section 36.2.4.9 of the 802.3.2002 1000BASE-X specification as well as section 48.2.6.3, Figure 48-7 of the 10GBASE-X specification.

A number of programmable options are supported within the word alignment module:

- Word alignment control from either embedded Link State Machine (LSM) or from FPGA control. Supported in 8-bit SERDES Only, 10-bit SERDES Only and SDI modes, in addition to 8b10b packet mode.

- Ability to set two programmable word alignment characters (typically one for positive and one for negative disparity) and a programmable per bit mask register for alignment comparison. Alignment characters and the mask register is set on a per quad basis. For many protocols, the word alignment characters can be set to “XX00000011” (jhgfiedcba bits for positive running disparity comma character matching code groups K28.1, K28.5, and K28.7) and “XX01111100” (jhgfiedcba bits for negative running disparity comma character matching code groups K28.1, K28.5, and K28.7). However, the user can define any 10-bit pattern.
- The first alignment character is defined by the 10-bit value assigned to attribute COMMA\_A. This value applies to all channels in a PCS quad.
- The second alignment character is defined by the 10-bit value assigned to attribute COMMA\_B. This value applies to all channels in a PCS quad.
- The mask register defines which word alignment bits to compare (a ‘1’ in a bit of the mask register means check the corresponding bit in the word alignment character register). The mask registers defined by the 10-bit value assigned to attribute COMMA\_M. This value applies to all channels in a PCS quad. When the attribute CHx\_RXWA (word alignment) is set to “ENABLED” and CHx\_ILSM (Internal Link State Machine) is set to “ENABLED”, one of the protocol-based Link State Machines will control word alignment. For more information on the operation of the protocol-based Link State Machines, see the Protocol-Specific Link State Machine section below.

## 8b10b Decoder

The 8b10b decoder implements an 8b10b decoder operation as described with the IEEE 802.3-2002 specification. The decoder performs the 10-bit to 8-bit code conversion along with verifying the running disparity. When a code violation is detected, the receive data, rxdata, is set to 0xEE with rx\_k\_chn set to ‘1’.

## External Link State Machine Option

When the attribute CHx\_ILSM (Internal Link State Machine) is set to DISABLED, and CHx\_RXWA (word alignment) is set to ENABLED, the control signal word\_align\_en\_ch(0-3)\_c is used to enable the word aligner. This signal should be sourced from a FPGA external Link State Machine implemented in the FPGA fabric.

When the CHx\_RXWA is set to ENABLED, the word\_align\_enable CH\_01[7] shown in Figure 8-10 is set to HIGH, enabling the word\_align\_en\_ch(0-3)\_c signal to be controlled by FPGA fabric. When the signal word\_align\_en\_ch(0-3)\_c is HIGH, the Word Aligner looks for incoming data for either COMMA\_A or COMMA\_B for alignment. Once it is aligned, it stays locked and aligned, and stops comparing incoming data.

If re-alignment is required, the word\_align\_en\_ch(0-3)\_c should be pulsed from HIGH to LOW, then to HIGH. Driving the signal to LOW clears up the Word Aligner internal status to unlock. Alignment does not start until the word\_align\_en\_ch(0-3)\_c signal is driven back to HIGH. When it is driven to HIGH, it constantly compares the incoming data to either COMMA\_A or COMMA\_B for alignment. When alignment is found, it stays locked and aligned, and stops comparing data.

After each alignment or re-alignment, the Word Aligner keeps aligning to that state, until the signal word\_align\_en\_ch(0-3)\_c is pulsing to HIGH and either COMMA\_A or COMMA\_B character is found. Before that, when the signal is LOW, or pulsed to HIGH but before the comma character is detected, the Word Aligner would still keep aligning to the current state.

External Link State Machine allows the user to perform re-alignment with a change in word alignment under specific conditions, and also allows the user to perform re-alignment if the External Link State Machine finds some issue with the link.

Figure 8-10 illustrates the Link State Machine options.

**Figure 8-10. PCS Word Aligner and Link State Machine Options**



When a Link State Machine is selected and enabled for a particular channel, that channel's `lsm_status_ch(0-3)_s` status signal will go high upon successful link synchronization.

Note that the `lsm_status_ch(0:3)_s` status signal may have glitches. User should add deglitch logic on this output to ensure stable signal transition.

### Idle Insert for Gigabit Ethernet Mode

The PCS set to Gigabit Ethernet Mode provides for insertion of `/I2/` symbols into the receive data stream for auto-negotiation. Gigabit Ethernet auto-negotiation is performed in soft logic. This function inserts a sequence of 8 `/I2/` ordered sets every 2048 clock cycles. `/I2/` insertion is controlled by the `xmit_ch(0-3)` input to the PCS which is driven from the autonegotiation soft logic. Figure 8-11 shows one channel (channel 0 in this example) of receive logic when the PCS is set to Gigabit Ethernet Mode showing these control/status signals.

**Figure 8-11. PCS Receive Path for Gigabit Ethernet Mode (Channel 0 Example)**



### Clock Tolerance Compensation

The Clock Tolerance Compensation (CTC) module performs clock rate adjustment between the recovered receive clocks and the locked reference clock. Clock compensation is performed by inserting or deleting bytes at pre-defined positions, without causing loss of packet data. A 16-byte CTC FIFO is used to transfer data between the two clock domains and will accommodate clock differences of up to the specified ppm tolerance for the LatticeECP3 SERDES (see DC and Switching Characteristics section of the [LatticeECP3 Family Data Sheet](#)).

A channel has the Clock Tolerance Compensation block enable when that channel's attribute CHx\_CTC is set to "ENABLED". The CTC is bypassed when that channel's attribute CHx\_CTC is set to "DISABLED".

A diagram illustrating 1-byte deletion is shown in Figure 8-12.

**Figure 8-12. Clock Tolerance Compensation 1-Byte Deletion Example**



A diagram illustrating 1-byte insertion is shown in Figure 8-13.

**Figure 8-13. Clock Tolerance Compensation 1-Byte Insertion Example**



A diagram illustrating 2-byte deletion is shown in Figure 8-14.

**Figure 8-14. Clock Tolerance Compensation 2-Byte Deletion Example**



A diagram illustrating 2-byte insertion is shown in Figure 8-15.

**Figure 8-15. Clock Tolerance Compensation 2-Byte Insertion Example**



A diagram illustrating 4-byte deletion is shown in Figure 8-16.

**Figure 8-16. Clock Tolerance Compensation 4-Byte Deletion Example**



A diagram illustrating 4-byte insertion is shown in Figure 8-17.

**Figure 8-17. Clock Tolerance Compensation 4-Byte Insertion Example**



When the CTC is used, the following settings for clock compensation must be set, as appropriate, for the intended application:

- **Set the insertion/deletion pattern length using the CC\_MATCH\_MODE attribute.** This sets the number of skip bytes the CTC compares to before performing an insertion or deletion. Values for CC\_MATCH\_MODE are “1” (1-byte insertion/deletion), “2” (2-byte insertion/deletion), and “4” (4-byte insertion/deletion). The minimum interpacket gap must also be set as appropriate for the targeted application. The interpacket gap is set by assigning values to attribute CC\_MIN\_IPG. Allowed values for CC\_MIN\_IPG are “0”, “1”, “2”, and “3”. The minimum allowed interpacket gap after skip character deletion is performed based on these attribute settings is described in Table 8-10.
- **The skip byte or ordered set must be set corresponding to the CC\_MATCH\_MODE chosen.** For 4-byte insertion/deletion (CC\_MATCH\_MODE = “4”), the first byte must be assigned to attribute CC\_MATCH1, the second byte must be assigned to attribute CC\_MATCH2, the third byte must be assigned to attribute CC\_MATCH3, and the fourth byte must be assigned to attribute CC\_MATCH4. Values assigned are 10-bit binary values.

For example:

If a 4-byte skip ordered set is /K28.5/D21.4/D21.5/D21.5, then “CC\_MATCH1” should be “0110111100”, “CC\_MATCH2” = “0010010101”, “CC\_MATCH3” = “0010110101” and “CC\_MATCH4” = “0010110101”.

For a 2-byte insertion/deletion (CC\_MATCH\_MODE = “2”), the first byte must be assigned to attribute CC\_MATCH3, and the second byte must be assigned to attribute CC\_MATCH4.

For a 1-byte insertion/deletion (CC\_MATCH\_MODE = “1”), the skip byte must be assigned to attribute CC\_MATCH4.

- **The clock compensation FIFO high water and low water marks must be set to appropriate values for the targeted protocol.** Values can range from 0 to 15 and the high water mark must be set to a higher value than the low water mark (they should not be set to equal values). The high water mark is set by assigning a value to attribute CCHMARK. Allowed values for CCHMARK are hex values ranging from “0” to “F”. The low water mark is set by assigning a value to attribute CCLMARK. Allowed values for CCLMARK are hex values ranging from “0” to “F”.
- Clock compensation FIFO overrun can be monitored on a per-channel basis on the PCS/FPGA interface port labeled cc\_overrun\_ch(0-3) if “Error Status Ports” is selected when generating the PCS block with the module generator.
- Clock compensation FIFO underrun can be monitored on a per-channel basis on the PCS/FPGA interface port labeled cc\_underrun\_ch(0-3) if “Error Status Ports” is selected when generating the PCS block with the module generator.

## Calculating Minimum Interpacket Gap

Table 8-10 shows the relationship between the user-defined values for interpacket gap (defined by the CC\_MIN\_IPG attribute), and the guaranteed minimum number of bytes between packets after a skip character deletion from the PCS. The table shows the interpacket gap as a multiplier number. The minimum number of bytes between packets is equal to the number of bytes per insertion/deletion times the multiplier number shown in the table. For example, if the number of bytes per insertion/deletion is 4 (CC\_MATCH\_MODE is set to “4”), and the minimum interpacket gap attribute CC\_MIN\_IPG is set to “2”, then the minimum interpacket gap is equal to 4 (CC\_MATCH\_MODE = “4”) times 3 (Table 8-10 with CC\_MIN\_IPG = “2”) or 12 bytes. The PCS will not perform a skip character deletion until the minimum number of interpacket bytes have passed through the CTC.

**Table 8-10. Minimum Interpacket Gap Multiplier**

| CC_MIN_IPG | Insert/Deletion Multiplier Factor |
|------------|-----------------------------------|
| 0          | 1x                                |
| 1          | 2x                                |
| 2          | 3x                                |
| 3          | 4x                                |

**Note on CTC support in the LatticeECP3-150EA device family with TW suffix:** For the initial release of LatticeECP3-150EA device with TW suffix, the CTC in the PCS is not supported. The CTC feature can be bypassed and implemented in soft IP. Many IP cores from Lattice implement the CTC logic in soft form.

## Using IPexpress with Diamond

IPexpress is used to create and configure SERDES and PCS blocks. Designers use the GUI to select the SERDES Protocol Standard for a particular quad or channel. IPexpress takes the input from this GUI and generates a configuration file (.txt file) and HDL netlist. The HDL model is used in the simulation and synthesis flow. The configuration file contains attribute-level map information. This file is input for simulation and the bitgen program. It is strongly recommended that designers make changes and updates in IPexpress and then regenerate the configuration file. In some exceptional situations, users can modify the configuration file.

Figure 8-18 shows the tools flow when using IPexpress to generate the SERDES/PCS block for the SERDES Protocol Standard.

**Figure 8-18. SERDES\_PCS Diamond User Flow**



## PCS Module Generation in IPexpress

Figure 8-19 shows the main window when PCS is selected in the IPexpress GUI.

**Figure 8-19. IPexpress PCS Main Window**



### Quad Setup Tab

Figure 8-20 shows the Quad Setup Tab window when the file name is entered and the **Customize** button is checked in the main window. The first entry required in this window is to select a Protocol Mode for each channel. Each channel can be configured as ‘RX and TX’, ‘RX Only’, ‘TX Only’, ‘Disabled’ or ‘Low Speed Data Port’.

**Figure 8-20. Configuration GUI - Quad Setup Tab**



**Table 8-11. SERDES\_PCS GUI Attributes - Quad Tab Setup**

| GUI Text                     | Attribute Name | Range                                                                  | Default Value |
|------------------------------|----------------|------------------------------------------------------------------------|---------------|
| Channel Protocol             | CHx_MODE       | RX and TX, RX Only, TX Only                                            | DISABLED      |
| Disable Channel <sup>1</sup> | CHx_MODE       | ENABLE, DISABLE                                                        | DISABLED      |
| Protocol                     | CHx_PROTOCOL   | GIGE, SGMII, XAUI, SRIO, PCIE, SDI, G8B10B, 10BSER, 8BSER, CPRI, OBSAI | G8B10B        |
| Low Speed Data Port          | CHx_LDR        | RX and TX, RX Only, TX Only                                            | DISABLED      |

1. For the LatticeECP3-17EA device in the 328-ball csBGA package, only channels 0 and 3 are available.

### Reference Clock Setup Tab

In this tab, the attributes of the TX and RX reference clock sources are selected. Users can select either a EXTERNAL or INTERNAL reference clock. Further, there is a tool to provide the required clock rate and multiplier settings for a particular data rate. In addition, for a given data bus width the tool provides the required clock rate to interface the channel to the core.

**Figure 8-21. Configuration GUI - Reference Clocks Setup Tab**



**Table 8-12. SERDES\_PCS GUI Attributes - Reference Clocks Setup Tab**

| GUI Text                    | Attribute Name                        | Range                  | Default Value (GUI) | Default Value (Attribute) |
|-----------------------------|---------------------------------------|------------------------|---------------------|---------------------------|
| <b>Transmit</b>             |                                       |                        |                     |                           |
| Max. Data Rate <sup>1</sup> | N/A                                   | 0.23 to 3.2 Gbps       | 2.5 Gbps            | N/A                       |
| TX Refclk Source            | PLL_SRC                               | INTERNAL, EXTERNAL     | INTERNAL            | REFCLK_INT                |
| TX/RX Multiplier            | REFCK_MULT                            | 8X, 10X, 16X, 20X, 25X | Protocol Dependent  |                           |
| TX Reference clock Rate     | #REFCLK_RATE <sup>2</sup>             |                        | Protocol Dependent  |                           |
| Protocol                    | No user access. For information only. |                        |                     |                           |
| TX Rate                     | CHx_TX_DATA_RATE                      | FULL, DIV2, DIV11      | FULL                | FULL                      |
| FPGA Bus Width              | CHs_TX_DATA_WIDTH                     | 8, 10, 16, 20          | Protocol Dependent  |                           |
| FPGA Interface Clock        | #CH0_TX_FICLK_RATE                    |                        |                     |                           |
| <b>Receive</b>              |                                       |                        |                     |                           |
| Max. Data Rate <sup>1</sup> | N/A                                   | 0.23 to 3.2 Gbps       | 2.5 Gbps            | N/A                       |
| Protocol                    | No user access. For information only. |                        |                     |                           |
| Refclk Source               | CHx_CDR_SRC                           | INTERNAL, EXTERNAL     | INTERNAL            | REFCLK_INT                |
| Multiplier                  | No user access. For information only  |                        |                     |                           |
| RX Rate                     | CHx_RX_DATA_RATE                      | FULL, DIV2, DIV11      | FULL                | FULL                      |
| RX Reference Clock Rate     | #CH0_RXREFCLK_RATE                    |                        |                     |                           |
| FPGA Bus Width              | CHx_RX_DATA_WIDTH                     | 8, 10, 16, 20          | Protocol Dependent  |                           |
| FPGA Interface Clock        | #CH0_RX_FICLK_RATE                    |                        |                     |                           |

1. Rate is not reflected in the autoconfig file. Instead, DATARATE RANGE is specified for a given data rate as: 150 Mbps  $\leq$  LOWLOW  $\leq$  230 Mbps, 230 Mbps  $<$  LOW  $\leq$  450 Mbps, 450 Mbps  $<$  MEDLOW  $\leq$  0.9 Gbps, 0.9 Gbps  $<$  MED  $\leq$  1.8 Gbps, 1.8 Gbps  $<$  MEDHIGH  $\leq$  2.55 Gbps, 2.55 Gbps  $<$  HIGH  $\leq$  3.2Gbps.
2. Attributes preceded by '#' represent attributes that are for user information only. These attributes are also included in the auto-config file for reference.

## SERDES Advance Setup

This tab is used to access the advanced attributes of the transmit and receive SERDES for all four channels. Transmit attributes such as PreEmphasis, Termination, Differential Output Voltage selection are selected. Receive attributes such as Equalization, Termination, I/O Coupling are selected. Attributes for Transmit SERDES Clock and PLL are also selected.

**Figure 8-22. Configuration GUI - SERDES Advanced Setup Tab**



**Table 8-13. SERDES\_PCS GUI Attributes – SERDES Advanced Setup Tab**

| GUI Text                                                   | Attribute Name        | Value                                                                                                                                                                                   | Default Value    |
|------------------------------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| Differential Output Voltage                                | CHx_TDRV <sup>8</sup> | -4 (640mV) <sup>5</sup> , -3 (780mV), -2 (870mV), -1 (920mV), 0 (1040mV:default), 1 (1130mV) <sup>6</sup> , 2 (1260mV) <sup>7</sup> , 3 (1350mV) <sup>7</sup> , 4 (1440mV) <sup>7</sup> | 0                |
| PreEmphasis                                                | CHx_TX_PRE            | Disabled, 0 (0%), 1 (5%), 2 (12%), 3 (18%), 4 (25%), 5 (33%), 6 (40%), 7 (48%)                                                                                                          | DISABLED         |
| TX I/O Termination (Ohms) <sup>3</sup>                     | CHx_RTERM_TX          | 50, 75, 5K                                                                                                                                                                              | 50               |
| Equalization <sup>1</sup>                                  | CHx_RX_EQ             | Disabled, Mid_Low, Mid_Med, Mid_High, Long_Low, Long_Med, Long_High                                                                                                                     | DISABLED         |
| RX I/O Termination (Ohms) <sup>3</sup>                     | CHx_RTERM_RX          | 50, 60, 75, High                                                                                                                                                                        | 50               |
| RX I/O Coupling                                            | CHx_RX_DCC            | AC, DC                                                                                                                                                                                  | AC <sup>2</sup>  |
| Loss of Signal Threshold                                   | CHx_LOS_THRESHOLD_LO  | 2 (+15%), 3 (+25%)                                                                                                                                                                      | 2 <sup>4</sup>   |
| TX PLL Reference Clock I/O Termination (Ohms) <sup>3</sup> | PLL_TERM              | 50, 2K                                                                                                                                                                                  | 50               |
| TX PLL Reference Clock I/O Coupling                        | PLL_DCC               | AC, DC                                                                                                                                                                                  | AC <sup>10</sup> |
| PLL Loss of Lock                                           | PLL_LOL_SET           | 0: +/- 1350ppm x2 <sup>9</sup><br>1: +/- 2400ppm x2<br>2: +/- 6800ppm<br>3: +/- 400ppm                                                                                                  | 0                |

1. Refer to Table 8-106 for details.
2. The typical capacitor value of the internal on-chip AC coupling is 5 pF.
3. Termination resistors and their usage:
  - RX I/O Termination:
    - 50: So far all of the protocols except SMTPE use a 50-Ohm termination resistor.
    - 60: Provided for flexibility.
    - 75: SMPTE uses a 75-Ohm termination resistor.
    - HIGH: Default value when Rx is not used.
  - TX I/O Termination:
    - 50: So far all of the protocols except SMTPE use a 50-Ohm termination resistor.
    - 75: SMPTE uses a 75-Ohm termination resistor.
    - 5K: Such as PCI Express electric idle and PCI Express RX detection. User does not set this termination value for RX detection.  
Refer to the PCI Express Receiver Detection section.
  - TX PLL Termination:
    - 50: If there is no 50-Ohm termination resistor on the PCB.
    - 2K: If there is a 50-Ohm termination resistor on the PCB.
4. PCS configuration, GUI supports only the value 2 for all protocols except PCI Express. For PCI Express, both values 2 and 3 are supported.
5. TDRV\_AMP\_BOOST(CH\_13[3]) is set to 1 to achieve this amplitude.
6. This setting is the PCI Express default setting. It is recommended to use this default setting with the PCI Express protocol. The IPexpress GUI TDRV drop-down window is grayed out for this reason. Other settings can still be used by editing the attribute CHn\_TDRV in the auto-config file(.txt file).
7. VCCOB must be 1.5V for these settings.
8. The values are typical numbers. There is about +/-20% of margin for the whole frequency range. Refer to Table 8-105, CHn\_TDRV row for details.
9. 'x2' indicates successful double count of ppm in the internal LOL counter.
10. AC-coupling is recommended for most applications. DC-coupling should be used only in conjunction with an external AC-coupling capacitor.

### Assignment of PCS Location

Users can specify their desired location of the PCS quad by writing in the constraint file (.lpf). The preference "locate" is used. An example of the syntax is shown below.

```
LOCATE COMP "pcs_inst_name" SITE "PCSB" ;
```

| Quad Name | Site Name |
|-----------|-----------|
| Quad A    | PCSA      |
| Quad B    | PCSB      |
| Quad C    | PCSC      |
| Quad D    | PCSD      |

High-speed I/O termination topology is shown in Figure 8-23.

**Figure 8-23. High-Speed I/O Terminations**



### PCS Advanced1 Setup

This tab is used to access the advanced attributes of the transmit and receive PCS for all four channels. The polarity and operating mode (e.g. 8b10b) of each individual TX and RX channel can be individually selected. In addition, word alignment values such as comma values, comma mask and comma align can be selected.

**Figure 8-24. Configuration GUI - PCS Advanced1 Setup Tab**



**Table 8-14. SERDES/PCS GUI – PCS Advanced1 Setup Tab**

| GUI Text       |                            | Attribute Name           | Default                         |
|----------------|----------------------------|--------------------------|---------------------------------|
| Transmitter    | Invert the Transmit Signal | CHx_TX_SB                | DISABLED                        |
|                | Enable 8b10b Encoder       | CHx_TX_8B10B             | Protocol Dependent              |
|                | FPGA FIFO Bridge           | CHx_TX_FIFO              | Protocol Dependent              |
| Receiver       | Invert the Receive Signal  | CHx_RX_SB                | DISABLED                        |
|                | Dynamically Invert Port    | N/A                      | DISABLED                        |
|                | Enable 8b10b Decoder       | CHx_RX_8B10B             | Protocol Dependent              |
|                | FPGA FIFO Bridge           | CHx_RX_FIFO              | Protocol Dependent              |
| Word Alignment | Word Alignment Block       | CHx_RXWA                 | Protocol Dependent              |
|                | Internal Link              | CHx_ILSM                 | Protocol Dependent              |
|                | Specific Comma             | #CHx_SCOMMA              | Protocol Dependent              |
|                | Plus Comma Value           | CHx_COMMA_A <sup>1</sup> | 1100000101                      |
|                | Minus Comma Value          | CHx_COMMA_B              | 0011111010                      |
|                | Comma Mask                 | CHx_COMMA_M              | Protocol Dependent <sup>2</sup> |

1. By definition, COMMA\_A and COMM\_B are one set of 8b10b-encoded control characters with positive and negative running disparities. Users must provide the proper IDLE sequence per the protocol in order to get the link state machine synchronization. For example, 1 GbE protocol needs K28.5+D5.6 or D16.2 as IDLE (word alignment and sync state machine). The default values are in little endian format.
2. In most applications, K28.5 is used as the comma character. The default value of the mask is 1111111111. In G8B10B mode, any comma can be used so the mask will be 1111111100 to detect any of the three comma characters, K28.1, 28.5, 28.7.

## PCS Advanced2 Setup

This tab is used for setting values for the Clock Tolerance Compensation block.

**Figure 8-25. Configuration GUI – PCS Advanced2 Setup Tab**



**Table 8-15. SERDES/PCS GUI – PCS Advanced2 Setup Tab**

| GUI Text            | Attribute Name    | Default                         |
|---------------------|-------------------|---------------------------------|
| CTC block           | CHx_CTC           | Protocol Dependent <sup>1</sup> |
| Size of ordered set | CHx_CC_MATCH_MODE | Protocol Dependent              |
| Byte N              | CHx_CC_MATCH1     | Protocol Dependent              |
| Byte N+1            | CHx_CC_MATCH2     | Protocol Dependent              |
| Byte N+2            | CHx_CC_MATCH3     | Protocol Dependent              |
| Byte N+3            | CHx_CC_MATCH4     | Protocol Dependent              |
| Interpacket gap     | CHx_CC_MIN_IPG    | Protocol Dependent              |
| Deletion threshold  | CCHMARK           | 9                               |
| Insertion threshold | CCLMARK           | 7                               |

1. Always disabled: XAUI, SDI, CPRI, OBSAI, Serial Rapid IO, 10-bit SERDES, 8-bit SERDES  
All other modes: Disabled by default. Most of the CTC features are provided in IP.

## Control Setup

This tab is used to select the SCI interface and other debug and control options. In addition, users can enable the SCI, error reporting, PLL quarter clock, and loopback capability.

**Figure 8-26. Configuration GUI – Control Setup Tab**



**Table 8-16. Tab 5, SERDES\_PCS GUI Attributes – Control Setup Tab**

| GUI Text                                           | Attribute Name                                                                                                                               | Default               |
|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| Loopback Mode (Ch0, Ch1, Ch2, Ch3)                 | DISABLED<br>Loopback serial data after equalizer<br>Loopback serial data after transmit driver<br>Loopback parallel data after de_serializer | DISABLED <sup>1</sup> |
| Transmitter Electrical Idle                        | signal tx_idle_ch0_c is provided                                                                                                             | DISABLED              |
| Include Reset Sequence Generation <sup>2</sup>     | Include the TX and RX Reset Sequence                                                                                                         | ENABLED               |
| Provide SERDES Client Interface                    | N/A                                                                                                                                          |                       |
| Provide the SERDES Client Interface Interrupt Port | INT_ALL                                                                                                                                      | DISABLED              |
| Reference Clock to FPGA core                       | QD_REFCK2CORE                                                                                                                                | DISABLED              |

- When loopback mode is in default mode (DISABLED), the two SERDES Bridge Parallel loopback control signals (sb\_felb\_ch[3:0]\_c and sb\_felb\_RST\_ch[3:0]\_c) are available in the HDL module for users to turn on and off the loopback mode dynamically. These signals should be tied to ground if loopback mode is not used.
- Reset Sequence Generation is described in the SERDES/PCS RESET section of this document.

## Reference Clock to FPGA Core and Reset Sequence

The reset sequence uses a reference clock in the Reset State Machine.

If “Internal” is selected as the Tx Refclk source, the Reset State Machine uses the internal reference clock.

If “External” is selected as the Tx Refclk source, the Reset State Machine uses the Reference Clock to FPGA Core signal transparent to the user (Control Register bit, QD\_0A[1] is set). The REFCLK2FPGA signal will be included in the wrapper module only when “Reference Clock to FPGA Core” is selected.

## Generation Options

This tab provides options for users to select the PCS module generation output files of their choice.

**Figure 8-27. Configuration GUI – Generation Options Tab**



When migrating an older project created in a previous version of Diamond to the latest version for the first time, it is highly recommended to regenerate the PCS module in the latest version even if no configuration changes are required. This will ensure the most current set of primitive library elements is used. If this is not done, it is possible that the design may either fail in the flow or go through the flow but show unexpected behavior on the board.

When regenerating the PCS module in an existing project, often the HDL file remains the same and only the configuration file must be regenerated. In this case, users can run the “Generate Bitstream Data” and “Force One Level” option to save compile time.

- **Automatic** – When selected, IPexpress will generate only the necessary files. This can include both the HDL and TXT files or just the TXT file. This is the default setting.
- **Force Module and Settings Generation** – When selected, both the HDL and TXT files will be generated. This forces the Project Navigator processes to be reset back to synthesis.
- **Force Settings Generation Only** – When selected, only the TXT file will be generated. If HDL generation is necessary, an error message will be provided.
- **Flow Definitions** – The generation option works differently between the two module flows.
  - **HDL Source Flow: HDL File in Project Navigator**  
The existing LPC file can be opened from IPexpress for regeneration. In this case, the reset point set by the GUI will be the new starting point. So, when the user double-clicks a process or runs the “Force One Level” option, it will start at that reset point.
  - **LPC Source Flow: LPC File in Project Navigator**  
Opening the LPC file and regenerating the PCS module will reset the whole process whether or not the HDL module is regenerated.

In either case, the checkmarks in the Processes window will remain unchanged but will be updated as soon as the user starts the process.

## Configuration File Description

IPexpress generates this file which contains attribute-level map information. This file is used by the simulation model as well as the bitstream generation process to automatically initialize the PCSD quad to the mode selected in IPexpress.

The configuration file uses “txt” as the file type extension.

Below is an example of the configuration file.

```
# This file is used by the simulation model as well as the bitstream
# generation process to automatically initialize the PCSD quad to the mode
# selected in the IPexpress. This file is expected to be modified by the
# end user to adjust the PCSD quad to the final design requirements.

DEVICE_NAME "LFE3-95E"
CH0_MODE "RXTX"
CH1_MODE "DISABLED"
CH2_MODE "DISABLED"
CH3_MODE "DISABLED"
TX_DATARATE_RANGE "HIGH"
PLL_SRC "REFCLK_EXT"
REFCK_MULT "10X"
#REFCLK_RATE 250.0

CH0_PROTOCOL "G8B10B"
CH0_LDR "RXTX"
CH0_RX_DATARATE_RANGE "HIGH"
CH0_TX_DATA_RATE "FULL"
CH0_TX_DATA_WIDTH "8"
CH0_TX_FIFO "DISABLED"
CH0_CDR_SRC "REFCLK_EXT"
#CH0_TX_FICLK_RATE 250.0
CH0_RX_DATA_RATE "FULL"
CH0_RX_DATA_WIDTH "8"
CH0_RX_FIFO "DISABLED"
#CH0_RX_FICLK_RATE 250.0
CH0_TDRV "0"
CH0_TX_PRE "DISABLED"
CH0_RTERM_TX "50"
CH0_RX_EQ "DISABLED"
CH0_RTERM_RX "50"
CH0_RX_DCC "AC"
CH0_LOS_THRESHOLD_LO "2"
CH0_TX_SB "DISABLED"
CH0_TX_8B10B "ENABLED"
CH0_RX_SB "DISABLED"
CH0_RX_8B10B "ENABLED"
CH0_RXWA "ENABLED"
CH0_ILSM "ENABLED"
#CH0_SCOMMA "1111111111"
CH0_COMMA_A "1100000101"
CH0_COMMA_B "0011111010"
CH0_COMMA_M "1111111100"
CH0_CTC "ENABLED"
```

|                   |              |
|-------------------|--------------|
| CH0_CC_MATCH_MODE | "2"          |
| CH0_CC_MATCH1     | "0000000000" |
| CH0_CC_MATCH2     | "0000000000" |
| CH0_CC_MIN_IPG    | "3"          |
|                   |              |
| CH0_SSLB          | "DISABLED"   |
| CH0_SPLBPORTS     | "DISABLED"   |
| CH0_PCSLBPORTS    | "DISABLED"   |
| PLL_TERM          | "50"         |
| PLL_DCC           | "AC"         |
| PLL_LOL_SET       | "0"          |
| CCHMARK           | "9"          |
| CCLMARK           | "7"          |
| INT_ALL           | "DISABLED"   |
| QD_REFCK2CORE     | "ENABLED"    |

## 8-Bit and 10-Bit SERDES-Only Modes

This section describes the operation of the two modes of the SERDES/PCS block, 8-bit SERDES-Only and 10-bit SERDES-Only. These modes are intended for applications requiring access to a high-speed I/O interface without the protocol-based manipulation provided in the LatticeECP3 PCS logic.

### Transmit Path

- Serializer: Conversion of 8-bit or 10-bit parallel data to serial data.

### Receive Path

- Deserializer: Conversion of serial data to 8-bit or 10-bit parallel data.
- Optional word alignment to user-defined alignment pattern.

## Generic 8b10b Mode

The Generic 8b10b mode of the SERDES/PCS block is intended for applications requiring 8b10b encoding/decoding without the need for additional protocol-specific data manipulation. The LatticeECP3 SERDES/PCS block can support Generic 8b10b applications up to 3.2 Gbps per channel. In Generic 8b10b mode, the word aligner can be controlled from the embedded PCS Link State Machine (LSM).

When the embedded Link State Machine is selected and enabled, the lsm\_status\_ch[3:0]\_s status signal will go high upon successful link synchronization.

To achieve link synchronization in this mode, the following conditions need to be satisfied on the 8b10b patterns received at the SERDES channel's receiver input (hdinp\_ch[0-3]/hdinn\_ch[0-3]):

- Periodic 8b10b encoded comma characters need to be present in the serial data. Periodicity is required to allow the LSM to re-synchronize to commas upon loss of sync. The comma characters should correspond to the "Specific Comma" value shown in Figure 8-24. For example, when the Specific Comma is set to K28P157, the comma value on the serial link can be the 8b10b encoded version of any of K28.1 (k=1, Data=0x3C), K28.5 (k=1, Data=0xBC), or K28.7 (k=1, Data=0xFC). Note though that K28.5 is most commonly used.
- A comma character has to be followed by a data character
- Two comma characters have to be an even number of word clock cycles apart

Additional information:

- It takes roughly four good comma/data pairs for the LSM to reach link synchronization
- It takes four consecutive errors (illegal 8b10b encoded characters, code violations, disparity errors, uneven number of clock cycles between commas) to cause the LSM to unlock
- A CDR loss of lock condition will cause the LSM to unlock by virtue of the many code violation and disparity errors that will result
- When the internal reset sequence state machine is used, a CDR loss of lock (rx\_cdr\_lol\_ch[3:0]\_s) or a loss of signal (rx\_los\_low\_ch[3:0]\_s ) condition will cause the RX reset sequence state machine to reset the SERDES and cause the LSM to unlock

The two examples below illustrate the difference between a valid and an invalid even clock cycle boundary between COMMA occurrences (*Note: C = comma, D = data*).

Valid (even) comma boundary:

| <b>Word Clock Cycle</b> | <b>0</b> | <b>1</b> | <b>2</b> | <b>3</b> | <b>4</b> | <b>5</b> | <b>6</b> | <b>7</b> | <b>8</b> | <b>9</b> | <b>10</b> | <b>11</b> |
|-------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|-----------|-----------|
| <b>CHARACTER</b>        | C        | D        | C        | D        | C        | D        | D        | D        | D        | D        | C         | D         |

Invalid (odd) comma boundary:

| <b>Word Clock Cycle</b> | <b>0</b> | <b>1</b> | <b>2</b> | <b>3</b> | <b>4</b> | <b>5</b> | <b>6</b> | <b>7</b> | <b>8</b> | <b>9</b> | <b>10</b> | <b>11</b> | <b>12</b> |
|-------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|-----------|-----------|-----------|
| <b>CHARACTER</b>        | C        | D        | C        | D        | C        | D        | D        | D        | D        | C        | D         | C         | D         |

In the invalid (odd) comma boundary case above, the comma occurrences on cycles 9 and 11 are invalid since they do not fall on an even boundary apart from the previous comma.

Alternatively, the LSM can be disabled, and the word aligner is controlled from the fabric word\_align\_en\_ch[3:0]\_c input pin. See “[External Link State Machine Option](#)” on page 21 and “[PCS Advanced1 Setup](#)” on page 36 for more information.

### Transmit Path

- Serializer
- 8b10b encoder

### Receive Path

- Deserializer
- Word alignment to a user-defined word alignment character or characters from embedded GbE Link State Machine
- 8b10b decoding
- Clock Tolerance Compensation (optional)

## **LatticeECP3 PCS in Gigabit Ethernet and SGMII Modes**

The Gigabit Ethernet mode of the LatticeECP3 SERDES/PCS block supports full compatibility, from the Serial I/O to the GMII/SGMII interface of the IEEE 802.3-2002 1000 BASE-X Gigabit Ethernet standard.

### **Transmit Path**

- Serializer
- 8b10b encoding

### **Receive Path**

- Deserializer
- Word alignment based on IEEE 802.3-2002 1000 BASE-X defined alignment characters.
- 8b10b decoding
- The Gigabit Ethernet Link State Machine is compliant to Figure 36-9 (Synchronization State Machine, 1000BASE-X) of IEEE 802.3-2002 with one exception. Figure 36-9 requires that four consecutive good code groups are received in order for the LSM to transition from one SYNC\_ACQUIRED\_{N} (N=2,3,4) to SYNC\_ACQUIRED\_{N-1}. Instead, the actual LSM implementation requires five consecutive good code groups to make the transition.
- Gigabit Ethernet Carrier Detection: Section 36.2.5.1.4 of IEEE 802.3-2002 (1000BASE-X) defines the carrier\_detect function. In Gigabit Ethernet mode, this feature is not included in the PCS and a carrier\_detect signal is not provided to the FPGA fabric.
- Clock Tolerance Compensation logic capable of accommodating clock domain differences.

### **Gigabit Ethernet (1000BASE-X) Idle Insert**

This is required for Clock Compensation and Auto-negotiation. Auto-negotiation is done in FPGA logic. The Lattice Gigabit Ethernet PCS IP core provides the auto-negotiation discussed below.

Idle pattern insertion is required for clock compensation and auto-negotiation. Auto-negotiation is done in FPGA logic. This module automatically inserts /I2/ symbols into the receive data stream during auto-negotiation. While auto-negotiating, the link partner will continuously transmit /C1/ and /C2/ ordered sets. The clock-compensator will not delete these ordered sets as it is configured to only insert/delete /I2/ ordered sets. In order to prevent overruns and underruns in the clock-compensator, /I2/ ordered sets must be periodically inserted to provide insertion/deletion opportunities for the clock compensator.

While performing auto-negotiation, this module will insert a sequence of eight /I2/ ordered sets (two bytes each) every 2048 clock cycles. As this module is after the 8b10b decoder, this operation will not introduce any running disparity errors. These /I2/ ordered sets will not be passed on to the FPGA receive interface as the GMII interface is driven to IDLE by the RX state machine during auto-negotiation. Once auto-negotiation is complete, /I2/ insertion is disabled to prevent any corruption of the received data.

Note that this state machine is active only during auto-negotiation. The auto-negotiation state machine and the GbE receive state machines are implemented in the soft logic. This state machine depends on the signal xmit\_ch[3:0] from the auto-negotiation state machine. This signal is provided on the TX data bus. Though this signal is relatively static (especially after auto-negotiation) it is included in the TX data bus.

**Table 8-17. GbE IDLE State Machine Control and Status Signals**

| Module Signal | Direction | Description                                    |
|---------------|-----------|------------------------------------------------|
| xmit_ch[3:0]  | In        | From FPGA logic Auto-Negotiation State Machine |

### **Gigabit Ethernet Idle Insert and correct\_disp\_ch[3:0] Signals**

The correct\_disp\_ch[3:0] signal is used on the transmit side of the PCS to ensure that an interpacket gap begins in the negative disparity state. Note that at the end of an Ethernet frame, the current disparity state of the transmitter can be either positive or negative, depending on the size and data content of the Ethernet frame.

However, from the FPGA soft-logic side of the PCS, the current disparity state of the PCS transmitter is unknown. This is where the correct\_disp\_ch[3:0] signal comes into play. If the correct\_disp\_ch[3:0] signal is asserted for one clock cycle upon entering an interpacket gap, it will force the PCS transmitter to insert an IDLE1 ordered-set into the transmit data stream if the current disparity is positive. However, if the current disparity is negative, then no change is made to the transmit data stream.

From the FPGA soft-logic side of the PCS, the interpacket gap is typically characterized by the continuous transmission of the IDLE2 ordered set which is as follows: tx\_k\_ch=1, txdata= 0xBC tx\_k\_ch=0, txdata=0x50.

Note that in the PCS channel, IDLE2s mean that current disparity is to be preserved. IDLE1s mean that the current disparity state should be flipped. Therefore, it is possible to ensure that the interpacket gap begins in a negative disparity state. If the disparity state before the interpacket gap is negative, then a continuous stream of IDLE2s are transmitted during the interpacket gap. If the disparity state before the interpacket gap is positive, then a single IDLE1 is transmitted followed by a continuous stream of IDLE2s.

In the FPGA soft-logic side of the PCS, the interpacket gap is always driven with IDLE2s into the PCS. The correct\_disp\_ch[3:0] signal is asserted for one clock cycle, k\_cntrl=0, data=0x50 when the interpacket gap first begins. If necessary, the PCS will convert this IDLE2 into an IDLE1. For the remainder of the interpacket gap, IDLE2s should be driven into the PCS and the correct\_disparity\_chx signal should remain deasserted.

For example, if a continuous stream of 512 bytes of Ethernet frames and 512 bytes of /I/ are sent, it can be observed that:

- During the first interpacket gap, all negative disparity /I2/s are seen (K28.5(-) D16.2(+))
- During the next interpacket gap, the period begins with positive disparity /I1/ (K28.5 (+), D5.6 (+/- are the same)), then all remaining ordered sets are negative disparity /I2/s
- During the next interpacket gap, all negative disparity /I2/s are seen
- During the next interpacket gap, the period begins with positive disparity /I1/ (K28.5 (+), D5.6 (+/- are the same)), then all remaining ordered sets are negative disparity /I2/s

A number of programmable options are supported within the encoder module. These are:

- Ability to force negative or positive disparity on a per-word basis
- Ability to input data directly from the FIFO Bridge - external multiplexer
- Ability to replace code words dependant upon running disparity (100BASE-X and FC)
- Software register controlled bypass mode

## XAUI Mode

With the Lattice XAUI IP Core, the XAUI mode of the SERDES/PCS block supports full compatibility from Serial I/O to the XGMII interface of the IEEE 802.3-2002 XAUI standard. XAUI Mode supports 10 Gigabit Ethernet.

### Transmit Path

- Serializer
- Transmit State Machine which performs translation of XGMII idles to proper ||A||, ||K||, ||R|| characters according to the IEEE 802.3ae-2002 specification
- 8b10b Encoding

**Receive Path**

- Deserializer
- Word alignment based on IEEE 802.3-2002 defined alignment characters.
- 8b10b Decoding
- The XAUI Link State Machine is compliant to Figure 48-7 - PCS synchronization state diagram of IEEE 802.3ae-2002 with one exception. Figure 48-7 requires that four consecutive good code groups be received in order for the LSM to transition from one SYNC\_ACQUIRED\_{N} (N=2,3,4) to SYNC\_ACQUIRED\_{N-1}. Instead, the actual LSM implementation requires five consecutive good code groups to make the transition.
- Clock Tolerance Compensation logic in PCS is disabled in XAUI mode. MCA (Multi-Channel Alignment) and CTC are done in the XAUI IP core.
- x4 multi-channel alignment should be done in FPGA core logic.

**LatticeECP3 PCS in PCI Express Revision 1.1 (2.5Gpbs) Mode**

The PCI Express mode of the SERDES/PCS block supports x1, x2, and x4 PCI Express applications.

**Transmit Path**

- Serializer
- 8b10b Encoding
- Receiver Detection
- Electrical Idle

**Receive Path**

- Deserializer
- Word alignment based on the Sync Code
- 8b10b Decoding
- Link Synchronization State Machine functions incorporating operations defined in the PCS Synchronization State Machine (Figure 48-7) of the IEEE 802.3ae-2002 10GBASE-X Specification.
- x2 or x4 PCI Express operation with one PCS quad set to PCI Express mode.
- Clock Tolerance Compensation logic capable of accommodating clock domain differences.
- x2 or x4 multi-channel alignment should be done in FPGA core logic.

Table 8-18 describes the PCI Express mode specific ports.

**Table 8-18. PCI Express Mode Specific Ports**

| Signal                | Direction | Class   | Description                                                                                                                                                                         |
|-----------------------|-----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pcie_done_ch[3:0]_s   | Out       | Channel | 1 = Far-end receiver detection complete<br>0 = Far-end receiver detection incomplete                                                                                                |
| pcie_con_ch[3:0]_s    | Out       | Channel | Result of far-end receiver detection<br>1 = Far-end receiver detected<br>0 = Far-end receiver not detected                                                                          |
| pcie_det_en_ch[3:0]_c | In        | Channel | FPGA logic (user logic) informs the SERDES block that it will request a PCI Express Receiver Detection operation.<br>1 = Enable PCI Express Receiver Detect<br>0 = Normal Operation |
| pcie_ct_ch[3:0]_c     | In        | Channel | 1 = Request transmitter to do far-end receiver detection<br>0 = Normal data operation                                                                                               |
| rxstatus[2:0]         | Out       | Channel | Per-channel PCI Express receive status port. RxStatus# is an encoded status of the receive data path. 2 bits wide if in 16-bit data bus mode.                                       |

The status signal, rxstatus, is an encoded status of the receive data path. The encoding is as follows.

**Table 8-19. rxstatus Encoding**

| rxstatus[2:0] |   |   | Description                                     | Priority |
|---------------|---|---|-------------------------------------------------|----------|
| 0             | 0 | 0 | Received data OK                                | 8        |
| 0             | 0 | 1 | 1 byte inserted by CTC                          | 7        |
| 0             | 1 | 0 | 1 byte deleted by CTC                           | 6        |
| 0             | 1 | 1 | Receiver detected (pcie_done, pcie_con)         | 1        |
| 1             | 0 | 0 | 8b10b decode error (code violation - rx_cv_err) | 2        |
| 1             | 0 | 1 | CTC FIFO overflow (ctc_orun)                    | 3        |
| 1             | 1 | 0 | CTC FIFO underflow (ctc_urun)                   | 4        |
| 1             | 1 | 1 | Receive disparity error (rx_disp_err)           | 5        |

### PCI Express Termination

At the electrical level, PCI Express utilizes two uni-directional low voltage differential signaling pairs at 2.5Gbps for each lane. Transmit and receive are separate differential pairs, for a total of four data wires per lane. An input receiver with programmable equalization and output transmitters with programmable pre-emphasis permits optimization of the link. The PCI Express specification requires that the differential line must be common mode terminated at the receiving end. Each link requires a termination resistor at the far (receiver) end. The nominal resistor values used are 100 ohms. This is accomplished by using the embedded termination features of the CML inputs as shown in Figure 8-28. The specification requires AC coupling capacitors (CTX) on the transmit side of the link. This eliminates potential common-mode bias mismatches between transmit and receive devices. The capacitors must be added external to the Lattice CML outputs.

### PCI Express L2 State

For the PCI Express L2 state, the rx\_pwrup\_c signal should not be de-asserted to power-down the rx channel. This will force the RX termination to high impedance and will not allow the far-end to detect the receiver. Rather, the rx\_pcs\_RST\_c signal should be used to hold the channel in reset to save power.

**Figure 8-28. PCI Express Interface Diagram**



**Table 8-20. Differential PCI Express Specifications**

| Symbol      | Parameter                       | Min. | Nom. | Max. | Units | Comments                                                                                                                                                                                                                                                                               | Location |
|-------------|---------------------------------|------|------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| ZTX-DIFF-DC | DC Differential TX Impedance    | 80   | 100  | 120  | Ohm   | TX DC Differential mode low impedance. ZTX-DIFF-DC is the small signal resistance of the transmitter measured at a DC operating point that is equivalent to that established by connecting a 100 Ohm resistor from D+ and D- while the TX is driving a static logic one or logic zero. | Internal |
| ZRX-DIFF-DC | DC Differential Input Impedance | 80   | 100  | 120  | Ohm   | RX DC Differential mode impedance during all LTSSM states. When transmitting from a Fundamental Reset to Detect, (the initial state of the LTSSM), there is a 5 ms transition time before receiver termination values must be met on all un-configured lanes of a port.                | Internal |
| CTX         | AC Coupling Capacitor           | 75   |      | 200  | nF    | All transmitters shall be AC coupled. The AC coupling is required either within the media or within the transmitting component itself.                                                                                                                                                 | External |

#### PCI Express Electrical Idle Transmission

Electrical Idle is a steady state condition where the transmitter P and N voltages are held constant at the same value (i.e., the Electrical Idle Differential Peak Output Voltage, VTX-IDLE-DIFFp, is between 0 and 20mV). Electrical Idle is primarily used in power saving and inactive states.

Per the PCI Express base specification, before a transmitter enters Electrical Idle, it must always send the Electrical Idle Ordered Set (EIOS), a K28.5 (COM) followed by three K28.3 (IDL). After sending the last symbol of the Electrical Idle Ordered Set, the transmitter must be in a valid Electrical Idle state as specified by TTX-IDLE-SET-TO-IDLE is less than 20UI.

To achieve this, the Electrical Idle Enable (tx\_idle\_chx\_c) from the FPGA core logic to the PCS is sent in along with each transmit data. This signal is pipelined similarly all the way to the PCS-SERDES boundary. For all valid data this signal is LOW. To initiate Electrical Idle, the FPGA logic pulls this signal HIGH on the clock after it transmits the last K28.3 (IDL) symbol. As the signal is pipelined to the PCS-SERDES boundary, the relationship between the transmit data and this signal is exactly the same as on the FPGA-PCS boundary.

14UI after the rising edge of the Electrical Idle enable signal at the PCS-SERDES boundary the last bit (bit7) of the last K28.3 (IDL) symbol is transmitted. 16UI (<20UI) later the transmit differential buffer achieves Electrical Idle state.

**Figure 8-29. Transmit Electrical Idle**



As long as the FPGA core logic deems that the transmitter needs to stay in Electrical Idle state it needs to clock in data (preferably all zeros) along with the Electrical Idle Enable (**tx\_idle\_chx\_c**) signal active (HIGH). The transmitter is required to stay in the Electrical Idle state for a minimum of 50UI (20ns) (TTX-IDLE-MIN).

#### PCI Express Electrical Idle Detection

Each channel in the quad has a loss-of-signal detector. The Electrical Idle is detected once two out of the three K28.3 (IDL) symbols in the Electrical Idle Ordered Set (EOS) have been received. After the Electrical Idle Ordered Set is received, the receiver should wait for a minimum of 50ns (TTX-IDLE-MIN) before enabling its Electrical Idle Exit detector.

These signals (one per channel, four per quad) should be routed through the PCS, and should be made available to the FPGA core. The required state machine(s) to support electrical idle can then be constructed in the FPGA core.

#### PCI Express Receiver Detection

Figure 8-30 shows a Receiver Detection sequence. A Receiver Detection test can be performed on each channel of a quad independently. Before starting a Receiver Detection test, the transmitter must be put into electrical idle by setting the **tx\_idle\_ch#\_c** input high. The Receiver Detection test can begin 120 ns after **tx\_elec\_idle** is set high by driving the appropriate **pci\_det\_en\_ch#\_c** high. This puts the corresponding SERDES Transmit buffer into receiver detect mode by setting the driver termination to high impedance and pulling both differential outputs to VCCOB through the high impedance driver termination.

Setting the SERDES Transmit buffer into receiver detect state takes up to 120 ns. After 120 ns, the receiver detect test can be initiated by driving the channel's **pcie\_ct\_ch#\_c** input high for four byte (word) clock cycles. The corresponding channel's **pcie\_done\_ch#\_s** is then cleared asynchronously. After enough time for the receiver detect test to finish has elapsed (determined by the time constant on the transmit side), the **pcie\_done\_ch#\_s** receiver detect status port will go high and the Receiver Detect status can be monitored at the **pcie\_con\_ch#\_s** port. If at that time the **pcie\_con\_ch#\_s** port is high, then a receiver has been detected on that channel. If, however, the **pcie\_con\_ch#\_s** port is low, then no receiver has been detected for that channel. Once the Receiver Detect test is complete, **tx\_idle\_ch#\_c** can be deasserted.

Receiver detection proceeds as follows:

1. The user drives pcie\_det\_en high, putting the corresponding TX driver into receiver detect mode. This sets the driver termination to high-impedance (5K ohm) and pulls both outputs of the differential driver toward common mode through the high-impedance driver termination. The TX driver takes some time to enter this state so the pcie\_det\_en must be driven high for at least 120ns before pcie\_ct is asserted.
2. The user drives pcie\_ct high for four byte clocks.
3. SERDES drives the corresponding pcie\_done low.
4. SERDES drives the internal signal (corresponding to pcie\_ct) for as long as it is required (based on the time constant) to detect the receiver.
5. SERDES drives the corresponding pcie\_con connection status.
6. SERDES drives the corresponding pcie\_done high.
7. The user can use this asserted state of pcie\_done to sample the pcie\_con status to determine if the receiver detection was successful.

**Figure 8-30. PCI Express Mode Receiver Detection Sequence**



### PCI Express Power Down Mode

rx\_serdes\_RST\_ch[3:0] reset signal should be used instead of rx\_pwrup\_ch[3:0] signal. This allows the RX termination to remain enabled at 50 Ohms so that the far-end transmitter can detect that a receiver is connected.

### PCI Express Beacon Support

This section highlights how the LatticeECP3 PCS can support Beacon detection and transmission. The PCI Express requirements for Beacon detection are presented with the PCS support for Beacon transmission and detection.

#### Beacon Detection Requirements

- Beacon is required for exit from L2 (P2) state.
- Beacon is a DC-balanced signal of periodic arbitrary data, which is required to contain some pulse widths  $\geq 2\text{ns}$  (500 MHz) and  $< 16\text{us}$  (30 KHz).
- Maximum time between pulses should be  $< 16\text{ us}$ .
- DC balance must be restored within  $< 32\text{ us}$ .
- For pulse widths  $> 500\text{ ns}$ , the output beacon voltage level must be 6 db down from VTX-DIFFp-p (800 mV to 1200 mV).
- For pulse widths  $< 500\text{ ns}$ , the output beacon voltage level must be  $\leq$  VTX-DIFFp-p and  $\geq 3.5$  db down from VTX-DIFFp-p.

### PCS Beacon Detection Support

- The signal loss threshold detection circuit senses if the specified voltage level exists at the receiver buffer.
- This is indicated by the rlos\_lo\_ch(0-3) signal.
- This setting can be used both for PCI Express Electrical Idle Detection and PCI Express beacon detection (when in power state P2).
- The remote transmitting device can have a beacon output voltage of 6 db down from VTX-DIFFpp (i.e., 201 mV). If this signal can be detected, then the beacon is detected.

### PCS Beacon Transmission Support

Sending the K28.5 character (IDLE) (5 ones followed by 5 zeroes) provides a periodic pulse with of 2 ns occurring every 2 ns ( $1.0 \text{ UI} = 400 \text{ ps}$ , multiplied by 5 = 2 ns). This meets the lower requirement. The output beacon voltage level can then be VTX-DIFFp-p. This is a valid beacon transmission.

### SDI (SMPTE) Mode

The SDI mode of the LatticeECP3 SERDES/PCS block supports all three SDI modes, SD-SDI, HD-SDI and 3G-SDI.

#### Transmit Path

- Serializer

#### Receive Path

- Deserializer
- Optional word alignment to user-defined alignment pattern.

The following data rates are the most popular in the broadcast video industry.

- SD-SDI (SMPTE259M): 270Mbps
- HD-SDI (SMPTE292M): 1.485Gbps,  $1.485\text{Gbps}/1.001 = 1.4835\text{Gbps}$
- 3G-SDI (SMPTE424M): 2.97Gbps,  $2.97\text{Gbps}/1.001 = 2.967\text{Gbps}$

Most designers have indicated that they would like to see support for all these rates. The reason is that in a broadcast studio, or a satellite head-end or cable head-end, they do not necessarily have prior knowledge of what the RX data rate will be.

The switchover time between different rates should be as low as possible. The time to re-lock the CDR is unavoidable. In the LatticeECP3 SERDES, the PLL does not have to be re-locked. This is possible because the LatticeECP3 has per RX and TX dividers. Video links generally have a uni-directional nature (i.e., different channels can run at different rates, and more importantly, the RX and TX in the same channel can run at different rates).

Also, depending on the geography where the equipment is deployed, either the full HD/3G-SDI rates (Europe/Asia) are used while transmitting video or the fractional rates (North America - NTSC). This allows us to develop two potential solution example cases for multi-rate SMPTE support with high quad utilization.

Please note that simultaneous support of 3G/HD Full TX Rate(s) and Fractional TX Rate(s) is not possible in the same SERDES quad. In general, based on the above, geographically partitioned usage is an acceptable limitation.

**Figure 8-31. Example A: 3G/HD/SD Full RX/TX Rate Support and 3G/HD Fractional TX Rate Support**



To support the major application requirements, a selectable DIV per RX and TX is supported. In LatticeECP3, DIV11 has been added. One potential multi-rate configuration is to provide a 148.5MHz REFCLK from the primary pins to the TX PLL. The TX PLL would be in the x20 mode. The resulting output clock would be 2.97GHz. Then, by using the DIV2 for 1.485Gbps and DIV11 for 270Mbps, a very quick switchover can be achieved without having to re-train and lock the PLL.

### Serial RapidIO (SRIo) Mode

This section describes the operation of the Serial RapidIO mode of the SERDES/PCS block. The LatticeECP3 supports 1x and 4x Serial RapidIO applications with one PCS quad. SRIo1.0 highlights multiple frequency support, 3.125Gbps, 2.5Gbps and 1.25Gbps. The ratio of these rates is 2.5:2:1. Supporting all of these rates with integer dividers in the same quad is not possible, but the ratio of 2.5 Gbps to 1.25 Gbps is 2:1 (full rate : half rate).

#### Transmit Path

- Serializer
- 8b10b encoding

#### Receive Path

- Deserializer
- Word alignment based on the Sync Code Group as defined in the RapidIO Physical Layer 1x/4x LP-Serial specification.
- 8b10b decoding
- Clock Tolerance Compensation logic capable of accommodating clock domain differences

## Serial Digital Video and Out-Of-Band Low Speed SERDES Operation

The LatticeECP3 SERDES/PCS supports any data rates that are slower than what the SERDES TX PLL and RX CDR natively support (<250Mbps: Out-Of-Band signal, OOB), by bypassing the receiver CDR and associated SERDES/PCS logic (e.g., 100Mbps Fast Ethernet, SD-SDI at 143Mbps or 177Mbps). Though these out-of-band paths primarily use low data rates, higher rates can be used for other functional reasons. See the Multi-Rate SMPTE Support section of this document for more information.

In addition, for SD-SDI, these rates sometimes must co-exist on the same differential RX pair with HD-SDI rates (i.e., SD-SDI rates may be active and then the data rate may switch over to HD-SDI rates). Since there is no way to predict which of these two rates will be in effect, it is possible to send the input data stream to two SERDES in parallel, a high-speed SERDES (already in the quad) and a lower-speed SERDES (implemented outside the quad). One possible implementation is shown in Figure 8-32.

There is an input per channel RXD\_LDR, low data rate single-ended input from the RX buffer to the FPGA core. In the core a low-speed Clock Data Recovery (CDR) block or a Data Recovery Unit (DRU) can be built using soft logic. A channel register bit, RXD\_LDR\_EN, can enable this data path. If enabled by another register bit, a signal from the FPGA can also enable this in LatticeECP3.

In the transmit direction, it is also possible to use a serializer built in soft logic in the FPGA core and use the TXD\_LDR pin to send data into the SERDES. It will be muxed in at a point just before the pre-emphasis logic near where the regular high-speed SERDES path is muxed with the boundary scan path. This is shown conceptually in Figure 8-32. The low data rate path can be selected by setting a channel register bit, TX\_LDR\_EN.

Alternatively, on the output side, the high-speed SERDES is used to transmit either high-speed data, or lower speed data using decimation (the SERDES continues to run at high-speed, but the output data can only change every nth clock where n is the decimation factor).

**Figure 8-32. Possible Implementation of Serial Digital Video Support**



## Open Base Station Architecture Initiative (OBSAI)

OBSAI is an open forum that is aimed at an open market for cellular base stations.

The LatticeECP3 SERDES/PCS supports most of the OBSAI features except the 3.84Gbps rate.

### Transmit Path

- Serializer
- Transmit State Machine is set to Gigabit Ethernet Mode
- 8b10b Encoding

### Receive Path

- Deserializer
- Word alignment based on IEEE 802.3-2002 1000 BASE-X defined alignment characters
- 8b10b Decoding

A Basesation Transceiver System (BTS) has four main components/modules and there are three major interfaces, or Reference Points (RPs), between them.

- **RP3** – RF Module receives signals from portable devices (terminals) and down converts it to digital data.
- **RP2** – The baseband module takes the encoded signal and processes it and sends it to the transport module, which will send it over the terrestrial network.
- **RP1** – A control module maintains coordination between these three functions.

Currently, most of the focus in the industry revolves around providing lower RF modules and power amplifiers and hence OBSAI's primary effort has been to define Reference Point 3 (RP3). In fact, the specification of interest is RP3-01, which is focused on Remote Radio Heads (RRHs).

The OBSAI RP3 electrical specification is based on the XAUI electrical specification and customized to the needs of a Base Transceiver System. The XAUI electrical interface is specified in Clause 47 of IEEE 802.3ae-2002. RP3 version 3.1 specifies the following electrical rates 3.84Gbps, 3.072Gbps, 2.304Gbps, 1.536Gbps and 0.736Gbps out of which the last four are supported.

The RP3 electrical specification defines a receiver compliance mask and provides a sample transmitter output mask. The BER should be better than  $1 \times 10^{-15}$ , which is more stringent than XAUI requirement of  $1 \times 10^{-12}$ . The RP3 electrical specification also differs from the XAUI specification in the definition of the UI. XAUI allows for a difference of +/- 100ppm. This difference does not apply to OBSAI systems since the BTSes are fully synchronous systems.

Since a BTS is a synchronous system, it is imperative to measure and calibrate the delay across any bus. OBSAI has carefully considered this and, as a result, come up with a method for synchronizing the master frame across the RP3 link. Delay calibration takes into account all factors, including processing, and buffer delay, in transmit and receive modules, as well as the latency across the link.

Another major item in the data-link layer is the synchronization between the transmitter and receiver. Synchronization ensures the actual data can be decoded successfully over the link. The frequency of errors as well as the synchronization status is constantly monitored.

RP3-01 has gone further and specified line rates that are integer multiples of 768Mbps, up to 3.84Gbps, and are considered OBSAI compatible line rates. Due to the number of line rates available, auto-negotiation between the remote RF units and the local units is defined. This extension of the specification includes Ethernet transmission between two RP3-01 nodes, mapping RP1 information into the RP3 link because the RRH does not have a

---

physical RP1 link, delay measurement, synchronization between RP3-01 units, and data multiplexing across the RP3-01 link.

The delay of each functional block in the LatticeECP3 SERDES/PCS is described in the CPRI section.

## **Common Public Radio Interface (CPRI)**

The goal of CPRI is to allow base station manufacturers and component vendors to share a common protocol and more easily adapt platforms from one user to another.

### **Transmit Path**

- Serializer
- Transmit State Machine is set to Gigabit Ethernet Mode
- 8b10b Encoding

### **Receive Path**

- Deserializer
- Word alignment based on IEEE 802.3-2002 1000 BASE-X defined alignment characters
- 8b10b Decoding

Unlike OBSAI, CPRI does not specify mechanical or electrical interface requirements. In terms of scope, CPRI has a much narrower focus than OBSAI. CPRI looks solely at the link between the RRH and the baseband module(s). In CPRI nomenclature, those modules are known as Radio Equipment (RE) and Radio Equipment Control (REC), respectively. In other words, CPRI is specifying the same interface as the OBSAI RP3 specification. CPRI primarily covers the physical and data link layer of the interface. It also specifies how to transfer the user plane data, control and management (C&M) plane data and the synchronization plane data.

CPRI has had better “traction” for two reasons - the muscle of the companies backing it and the focus on just one interface link (between the RF modules and the Baseband modules) and even at that focusing primarily on the physical and data link layers.

CPRI allows four line bit rate options; 614.4Mbps, 1.2288Gbps, 2.4576Gbps and 3.072Gbps; at least one of these rates needs to be supported. The higher line rate is always compared to the one that is immediately lower.

CPRI does not have a mandatory physical layer protocol, but the protocol used must meet the BER requirement of  $1 \times 10^{-12}$ , which is less stringent than OBSAI. It also specifies the clock stability and the phase noise requirements.

CPRI also recommends two electrical variants: high voltage (HV) and low voltage (LV). HV is guided by 1000Base-CX specifications in IEEE 802.3-2002 clause 39 with 100-ohm impedance. LV is guided by XAUI. LV is recommended for all rates and will be the focus for this device.

It is important to understand two link layer requirements when dealing with the CPRI and OBSAI specifications:

- Link delay accuracy and cable delay calibration
- Startup synchronization

### **Link Delay Accuracy and Cable Delay Calibration**

Though the following discussion largely leverages from the CPRI requirements, the same requirements also apply to OBSAI implementations.

The REs or RRHs are frequency locked to the REC or BTS. Thus, in this synchronous system it is necessary to calibrate all delays between RRHs and the BTS to meet air-interface timing requirements. The interface requires the support of the basic mechanisms to enable calibrating the cable delay on links and the round trip delay on sin-

---

gle- and multi-hop connections. Specifically, the reference points for delay calibration and the timing relationship between input and output signals at RE (Radio Equipment) are defined. All definitions and requirements are described for a link between REC Master Port and RE Slave Port in the single-hop scenario as shown in Figure 8-33.

**Figure 8-33. Link Between REC Master Port and RE Slave Port (Single Hop Scenario)**



Reference points R1-4 correspond to the output point (R1) and the input point (R4) of REC, and the input point (R2) and the output point (R3) of an RE terminating a particular logical connection. The antenna is shown as Ra for reference.

- T12 is the delay of the downlink signal from the output point of REC (R1) to the input point of RE (R2), essentially the downlink cable delay.
- T34 is the delay of the uplink signal from the output point of RE (R3) to the input point of the REC (R4), essentially the uplink cable delay.
- Toffset is the frame offset between the input signal at R2 and the output signal at R3.
- T14 is the frame timing difference between the output signal at R1 and the input signal at R4 (i.e., the round trip delay - RTT).

Delay measurement is accomplished using frame timing. CPRI has a 10ms frame based on the UMTS radio frame number or Node B Frame Number, also known as BFN. Each UMTS Radio Frame has 150 hyperframes (i.e., each HyperFrame is 66.67us) with the corresponding hyperframe number (HFN = 0<=Z<=149). Each hyperframe has 256 (0<=W<=255) basic frames (i.e. each basic frame is 260.42ns = Tchip or Tc).

An RE determines the frame timing of its output signal (uplink) to be the fixed offset (Toffset) relative to the frame timing of its input signal (downlink). Toffset is an arbitrary value, which is greater than or equal to 0 and less than 256 Tc (it cannot slip beyond a hyperframe). Different REs may use different values for Toffset. REC knows the value of Toffset of each RE in advance (pre-defined value or RE informs REC by higher layer message).

To determine T14, the downlink BFN and HFN from REC to RE is given back in uplink from the RE to the REC. In the case of an uplink-signaled error condition, the REC treats the uplinks BFN and HFN as invalid. So,  $T14 = T12 + Toffset + T34$ .

As stated earlier the system is synchronous. Further, assuming that hyperframes are of fixed length and the RRH-BTS interconnect (cable length) is equal in both directions (i.e.,  $T12 = T34$ , both optical fibers are in one bundle), the interconnect delay devolves down to  $(T14 - Toffset)/2$ . The method for determining T14 has been discussed earlier. So the major component that affects delay calibration is Toffset. Thus, the interconnect delay is the difference in hyperframe arrival and departure times measured at each side of the link.

Delay calibration requirements are driven by 3GPP and UTRAN requirements specifically requirements R-21 in the CPRI specification (CPRI v3.0 page 20), which states that the accuracy of the round trip delay measurement of the cable delay of one link is +/- Tc/16. Additionally, requirement R-20 states that the round trip time absolute accuracy of the interface, excluding the round trip group delay on the transmission medium (excluding the cable length), shall

---

meet a similar requirement (+/-  $T_c/16$  for T14). Taking into account the previous discussion, the absolute link delay accuracy in the downlink between REC master port and RE slave port excluding the cable length is half of the above requirement (+/-  $T_c/32$  or approximately 8ns (8.138ns)). Thus, both T14 and Toffset need absolute accuracy less than +/- 8ns.

Next it is important to determine how many bits of uncertainty can be acceptable for the different rates. Essentially, the various CPRI and OBSAI bit rates can be multiplied by 8.138ns to determine the number of bits worth of indeterminism/variance is acceptable. The impact of this will become clear subsequently when the SERDES serial/parallel data path is discussed.

Most SERDES have a certain level of uncertainty that is introduced in the serializing and de-serializing process. Thus, a SERDES with 16-bit bus architecture may have twice the delay uncertainty as a SERDES with a 8-bit architecture because the number of bits per word is doubled.

TX and RX latency respectively in Table 8-23 is listed. The table also lists the variability between the latency. This variability directly contributes to the absolute delay accuracy required from earlier discussion. The variability comes from three sources: TX FPGA Bridge FIFO, RX FPGA Bridge FIFO and RX Clock Tolerance Compensation FIFO. Since the CPRI system is a synchronous system, the RX CTC FIFO is bypassed and the RX recovered clock is used.

The remaining contributors to the latency variability are the FPGA Bridge FIFO. This FIFO can be bypassed if the interface to the FPGA is 8-bit bus mode. In 16-bit interface mode, the FPGA Bridge FIFO cannot be bypassed because the 2:1 gearing is done via the FIFO.

## **SONET/SDH**

Synchronous Optical Networking (SONET) and Synchronous Digital Hierarchy (SDH) are standardized multiplexing protocols that transfer data over optical fiber or via an electrical interface. SONET generic criteria are detailed in the Telcordia Technologies Generic Requirements document GR-253-CORE. Generic criteria applicable to SONET and other transmission systems (e.g., asynchronous fiber optic systems or digital radio systems) are found in Telcordia GR-499-CORE. SONET and SDH were originally designed to transport circuit mode communications (e.g., T1, T3) from a variety of different sources. The primary difficulty in doing this prior to SONET was that the synchronization sources of these different circuits were different. This meant each circuit was operating at a slightly different rate and with different phase. SONET allowed for the simultaneous transport of many different circuits of differing origin within a single framing protocol.

The LatticeECP3 SERDES/PCS offers transceivers capable of supporting three SONET/SDH data rates, STS-3/STM-1 (155.52 Mbps), STS-12/STM-4 (622.08 Mbps) and STS-48/STM-16 (2.488 Gbps). 8-bit SERDES mode is used for SONET/SDH applications.

In order to be SONET/SDH line-compliant, external components are required with the LatticeECP3. An external line driver is required on the output of the SERDES. To filter out high frequency jitter from the incoming data stream, a jitter cleaner can be applied to the recovered clock before using it as the transmit reference clock.

For chip-to-chip or backplane applications, the external line driver and the clock jitter cleaner are not required.

Figure 8-34 shows the line-side solution using external components.

**Figure 8-34. SONET/SDH Line Interface**


## FPGA Interface Clocks

Figure 8-35 shows a conceptual diagram of the later stage of the PCS core and the FPGA Bridge and the major clocks that cross the boundary between PCS and the FPGA.

**Figure 8-35. Conceptual PCS/FPGA Clock Interface Diagram**


In the above diagram and in the subsequent clock diagrams in this section, please note that suffix “i” indicates the index [3:0] i.e., one for each channel.

It is a requirement that if any of the selectors to the clock muxes are changed by writes to register bits, the software agent will reset the logic clocked by that muxed clock.

The PCS outputs 16 clocks. There are two transmit clocks (per channel) and two receive clocks (per channel). The two transmit clocks provide full rate and half rate clocks and are all derived from the TX PLL. There are also two clocks (full and half) per receive channel. All 16 clocks can be used as local (secondary) or global (primary) clocks for the FPGA logic as required. tx\_half\_clks are used when the gearing is in 2:1 mode. As described in Table 8-5, only tx\_full\_clk\_ch0 and tx\_half\_clk\_ch0 can drive the primary clock routing directly. Other channel clocks can also drive the primary clock net but general routing is used. All of the tx\_full\_clk\_ch[3:0] and tx\_half\_clk\_ch[3:0] signals can drive the secondary clock net by applying a USE SECONDARY clocking preference. General routing is also used to drive Secondary clock net.

The transmit clock is used on the write port of the TX FIFO (or Phase Shift FIFO, depending on the case). One of the two receive clocks is connected to the read clock of the RX FIFO. The other clock is used on the read port of the CTC FIFO and potentially on the write port of the RX FIFO (depending on the case). Based on the whether the CTC and the TX FIFO are bypassed and whether the PCS is in 8bit/10bit interface mode or 16bit/20bit interface mode, four use cases are possible. The active paths are highlighted with weighted lines. It is also indicated how many and what kind of clock trees are required. There are some modes that would more commonly be preferred by the user.

This section describes the operation of the six supported cases. The cases are outlined in Table 8-21.

**Table 8-21. Six Interface Cases Between the SERDES/PCS Quad and the FPGA Core**

| Interface                | Data Width | RX CTC FIFO | RX Phase-Shift/<br>Down-Sample FIFO | TX Phase-Shift/<br>Up-Sample FIFO |
|--------------------------|------------|-------------|-------------------------------------|-----------------------------------|
| Case I-a <sup>2</sup>    | 8/10 bit   | Yes         | Yes                                 | Yes                               |
| Case I-b <sup>2</sup>    | 8/10 bit   | Bypass      | Yes                                 | Yes                               |
| Case I-c <sup>2</sup>    | 8/10 bit   | Yes         | Bypass                              | Bypass                            |
| Case I-d <sup>2</sup>    | 8/10 bit   | Bypass      | Bypass                              | Bypass                            |
| Case II-a <sup>1,2</sup> | 16/20 bit  | Yes         | Yes                                 | Yes                               |
| Case II-b <sup>1,2</sup> | 16/20 bit  | Bypass      | Yes                                 | Yes                               |

1. When using a 16/20-bit datapath width, the TX phase-shift (upsample) FIFO and the RX phase-shift FIFO (downsample) are always used. They cannot be bypassed. It is not required that both RX and TX have the same FPGA interface datapath width simultaneously. There is independent control available. For the sake of brevity, they have been represented together in the same use case.
2. The TX phase-shift (upsample) FIFO and the RX phase-shift FIFO (downsample) don't need to be bypassed together. They are independently controllable. Again, for the sake of brevity, they have been represented here in the same case.

## 2:1 Gearing

For guaranteed performance of the FPGA global clock tree, it is recommended to use a 16/20-bit wide interface for SERDES line rates greater than 2.5Gbps. In this interface, the FPGA interface clocks are running at half the byte clock frequency.

Even though the 16/20-bit wide interface running at half the byte clock frequency can be used with all SERDES line rates, the 8/10-bit wide interface is preferred when the SERDES line rate is low enough to allow it (2.5Gbps and below) because this results in the most efficient implementation of IP in the FPGA core.

The decision matrix for the six interface cases is explained in Table 8-22.

**Table 8-22. Decision Matrix for Six Interface Cases**

| SERDES Line Rate   | Datapath Width             | Multi-Channel Alignment Required? | CTC Required?              | RX FIFO Required? | Interface Case         |
|--------------------|----------------------------|-----------------------------------|----------------------------|-------------------|------------------------|
| 2.5 Gbps and below | 8/10 bit<br>(1:1 gearing)  | No, single-channel link           | Yes                        | Yes               | Case I_a <sup>1</sup>  |
|                    |                            |                                   |                            | No                | Case I_c <sup>1</sup>  |
|                    |                            | Yes, multi-channel link           | No                         | Yes               | Case I_b <sup>2</sup>  |
|                    |                            |                                   |                            | No                | Case I_d <sup>2</sup>  |
|                    | 16/20 bit<br>(2:1 gearing) | No, single-channel link           | Must bypass, not available | Yes               | Case I_b <sup>3</sup>  |
|                    |                            |                                   |                            | No                | Case I_d <sup>3</sup>  |
|                    |                            | Yes, multi-channel link           | Yes                        | Yes               | Case II_a <sup>4</sup> |
|                    |                            |                                   | No                         | Yes               | Case II_b <sup>5</sup> |
|                    |                            |                                   | Must bypass, not available | Yes               | Case II_b <sup>6</sup> |

1. This case is intended for single-channel links at line rates of 2.5 Gbps and lower (8/10-bit wide interface) that require clock tolerance compensation in the quad. CTC is required when both ends of the link have separate reference clock sources that are within +/- 300ppm of each other. Case I\_a is used if the IP in the core requires the RX phase-shift FIFO. Case I\_b is used if the IP does not require this FIFO.
2. This case is intended for single-channel links at line rates of 2.5Gbps and lower (8/10-bit wide interface) that do NOT require clock tolerance compensation in the quad. CTC is not required when both ends of the link are connected to the same reference clock source. This is often the case for chip-to-chip links on the same circuit board. There is exactly 0ppm difference between the reference clocks and so CTC is not required and can be bypassed. CTC is also not required in the quad when this function is performed by the IP in the core.
3. This case is intended for multi-channel links at line rates of 2.5Gbps and lower (8/10-bit wide interface). Multi-channel alignment MUST be done in the FPGA design. Since multi-channel alignment must be done prior to CTC, the CTC FIFO in the quad MUST be bypassed when multi-channel alignment is required and so both multi-channel alignment and CTC (if required) are done by the FPGA design.
4. This case is intended for single-channel links at line rates of 3.2Gbps and lower that require a 2:1 gearbox between the quad and the FPGA core (16/20 bit wide interface). Clock tolerance compensation is included in the quad. CTC is required when both ends of the link have separate reference clock sources that are within +/- 300ppm of each other.
5. This case is intended for single-channel links at line rates of 3.2Gbps and lower that require a 2:1 gearbox between the quad and the FPGA core (16/20-bit wide interface). Clock tolerance compensation is NOT included in the quad. CTC is not required when both ends of the link are connected to the same reference clock source. This is often the case for chip-to-chip links on the same circuit board. There is exactly 0ppm difference between the reference clocks and so CTC is not required and can be bypassed. CTC is also not required in the quad when this function is performed by the FPGA design.
6. This case is intended for multi-channel links at line rates of 3.2Gbps and lower that require a 2:1 gearbox between the quad and the FPGA core (16/20-bit wide interface). Multi-channel alignment MUST be done by the FPGA design. Since multi-channel alignment must be done prior to CTC, the CTC FIFO in the quad MUST be bypassed when multi-channel alignment is required and so both multi-channel alignment and CTC (if required) are done by the FPGA design.

**Case I\_a: 8/10-Bit, CTC FIFO and RX/TX FIFOs Not Bypassed**

Figure 8-36. 8/10-Bit, CTC FIFO and RX/TX FIFOs NOT Bypassed



1. The TX FIFO acts as a Phase Shift FIFO only in this case.
2. The RX FIFO acts as a Phase Shift FIFO only in this case.
3. The quad-level full rate clock from the TX PLL (tx\_full\_clk) has direct access to the FPGA center clock mux. This is a relatively higher performance path. A Global Clock Tree out of the Center Clock Mux is used to clock the user's interface logic in the FPGA. Some leaf nodes of the clock tree are connected to the FPGA Transmit Input clock (txi\_clk), the CTC FIFO Read Clock per Channel (ebrd\_clk) through the FPGA Receive Input clock (rxi\_clk). This case is possibly the most common single-channel use case.

**Example of Clock and Data Signals Interface in FPGA Logic (Case I\_a)**

Below is a portion of the SERDES/PCS module instantiation in the top module which describes how clock and data ports are mapped in Verilog.

```
.txi_clk_ch0(txclk),
.rxi_clk_ch0(txclk),
.rx_full_clk_ch0(),
.tx_full_clk_ch0(txclk),
.tx_half_clk_ch0(),
.txdata_ch0(txdata_2_pcs),
.rxdata_ch0(rxdata_from_pcs),
.tx_k_ch0(txkcntl_2_pcs),
.rx_k_ch0(rxkcntl_from_pcs),
```

ebrd\_clk\_ch0 is routed automatically by the software, depending on the case.

Note that tx\_full\_clk\_ch0 uses wire name 'txclk' and feeds both txi\_clk\_ch0 and rxi\_clk\_ch0, as shown in Figure 8-36.

**Case I\_b: 8/10-Bit, CTC FIFO Bypassed**

Figure 8-37. 8b/10-Bit, CTC FIFO Bypassed



1. The TX FIFO acts as a Phase Shift FIFO only in this case.
2. The RX FIFO acts as a Phase Shift FIFO only in this case.
3. The TX FPGA Channel input clock is clocked similarly as in the previous case using a clock tree driven by a direct connection of the full rate transmit FPGA output clock to the FPGA center clock mux. Once the CTC FIFO is bypassed, the recovered clock needs to control the write port of the RX FIFO. The recovered clock of each channel may need to drive a separate local or global clock tree (i.e., up to four local or global clock trees per quad). The clock tree will then drive the FPGA receive clock input to control the read port of the RX FIFO. The reason for bypassing the CTC FIFO in this case is most likely for doing multi-channel alignment in the FPGA core. It implies that CTC using an elastic buffer will be done in the FPGA core. The CTC FIFOs can be written by either the recovered clocks or by a master recovered clock. The read of the CTC FIFO will be done using the TX clock via the TX clock tree.

**Case I\_c: 8/10-Bit, RX/TX FIFO Bypassed**

Figure 8-38. 8/10-Bit, RX/TX FIFO Bypassed



1. The TX channel clocking is similar to the previous two cases. On the RX channel, the FPGA input clock is now ebrd\_clk. The FPGA TX clock tree drives this clock. In this case, ebrd\_clk is automatically routed by the software.

**Case I\_d: 8/10-Bit, CTC FIFO and RX/TX FIFOs Bypassed**

Figure 8-39. 8b/10-Bit, CTC FIFO and RX/TX FIFOs Bypassed



1. FPGA clock trees can be interchangeably thought of as clock domains in this case. The TX channel clocking is similar to the previous three cases. On the RX channel, the recovered channel RX clock is sent out to the FPGA. This case is useful for supporting video applications.

**Case II\_a: 16/20-bit, CTC FIFO and RX/TX FIFOs NOT Bypassed**

Figure 8-40. 16/20-bit, CTC FIFO and RX/TX FIFOs NOT Bypassed



1. The TX FIFO acts both as a Phase Shift FIFO and Upsample FIFO in this case.
2. The RX FIFO acts both as a Phase Shift FIFO and Downsample FIFO in this case.
3. This is a very common single channel use case when the FPGA is unable to keep up with full byte frequency. Two clock trees are required. These clock trees are driven by direct access of transmit full-rate clock and transmit half-rate clock to the FPGA clock center mux. The full-rate clock tree drives the CTC FIFO read port and the RX FIFO write port. The half-rate clock tree drives the RX FIFO and the FPGA logic.

**Case II\_b: 16/20-bit, CTC FIFO Bypassed**

Figure 8-41. 16/20-bit, CTC FIFO Bypassed



1. The TX FIFO acts both as a Phase Shift FIFO and Upsample FIFO in this case.
2. The RX FIFO is acting both as a Phase Shift FIFO and Downsample FIFO in this case.
3. This is a very common multi-channel alignment use case when the FPGA is unable to keep up with full byte frequency. The receive clock trees (up to four) can be local or global. They are running a half-rate clock. The transmit clock tree is driven by direct access of the transmit half-rate clock to the FPGA clock center mux.

## SERDES/PCS Block Latency

Table 8-23 describes the latency of each functional block in the transmitter and receiver. Latency is given in parallel clock cycles. Figure 8-42 shows the location of each block.

**Table 8-23. SERDES/PCS Latency Breakdown**

| Item                                     | Description                                     | Min. | Avg. | Max. | Fixed   | Bypass | Units    |
|------------------------------------------|-------------------------------------------------|------|------|------|---------|--------|----------|
| <b>Transmit Data Latency<sup>1</sup></b> |                                                 |      |      |      |         |        |          |
| T1                                       | FPGA Bridge – 1:1 gearing with different clocks | 1    | 3    | 5    | —       | 1      | byte clk |
|                                          | FPGA Bridge – 1:1 gearing with the same clocks  | —    | —    | —    | 3       | 1      | byte clk |
|                                          | FPGA Bridge – 2:1 gearing                       | 1    | 3    | 5    | —       | —      | word clk |
| T2                                       | 8b10b Encoder                                   | —    | —    | —    | 2       | 1      | byte clk |
| T3                                       | SERDES Bridge transmit                          | —    | —    | —    | 2       | 1      | byte clk |
| T4                                       | Serializer: 8-bit mode                          | —    | —    | —    | 15 + Δ1 | —      | UI + ps  |
|                                          | Serializer: 10-bit mode                         | —    | —    | —    | 18 + Δ1 | —      | UI + ps  |
| T5                                       | Pre-emphasis ON                                 | —    | —    | —    | 1 + Δ2  | —      | UI + ps  |
|                                          | Pre-emphasis OFF                                | —    | —    | —    | 0 + Δ3  | —      | UI + ps  |
| <b>Receive Data Latency<sup>2</sup></b>  |                                                 |      |      |      |         |        |          |
| R1                                       | Equalization ON                                 | —    | —    | —    | Δ1      | —      | UI + ps  |
|                                          | Equalization OFF                                | —    | —    | —    | Δ2      | —      | UI + ps  |
| R2                                       | Deserializer: 8-bit mode                        | —    | —    | —    | 10 + Δ3 | —      | UI + ps  |
|                                          | Deserializer: 10-bit mode                       | —    | —    | —    | 12 + Δ3 | —      | UI + ps  |
| R3                                       | SERDES Bridge receive                           | —    | —    | —    | 2       | 1      | byte clk |
| R4                                       | Word alignment <sup>3</sup>                     | 3.1  | —    | 4    | —       | —      | byte clk |
| R5                                       | 8b10b decoder                                   | —    | —    | —    | 1       | 1      | byte clk |
| R6                                       | Clock Tolerance Compensation                    | 7    | 15   | 23   | 1       | 1      | byte clk |
| R7                                       | FPGA Bridge – 1:1 gearing with different clocks | 1    | 3    | 5    | —       | 1      | byte clk |
|                                          | FPGA Bridge – 1:1 gearing with same clocks      | —    | —    | —    | 3       | 1      | byte clk |
|                                          | FPGA Bridge – 2:1 gearing                       | 1    | 3    | 5    | —       | —      | word clk |

1.  $\Delta 1 = -245\text{ps}$ ,  $\Delta 2 = +88\text{ps}$ ,  $\Delta 3 = +112\text{ps}$ .

2.  $\Delta 1 = +118\text{ps}$ ,  $\Delta 2 = +132\text{ps}$ ,  $\Delta 3 = +700\text{ps}$ .

3. Table 8-24 shows word aligner latency depending on word alignment offset. The exact offset can be found in channel status register, CH\_22, bit [3:0].

**Table 8-24. Word Aligner Latency vs. Offset**

| wa_offset[3:0] (CH_22[3:0]) | Latency (Word Clock) |
|-----------------------------|----------------------|
| 0                           | 4.0                  |
| 1                           | 3.9                  |
| 2                           | 3.8                  |
| 3                           | 3.7                  |
| 4                           | 3.6                  |
| 5                           | 3.5                  |
| 6                           | 3.4                  |
| 7                           | 3.3                  |
| 8                           | 3.2                  |
| 9                           | 3.1                  |

**Figure 8-42. Transmitter and Receiver Latency Block Diagram**



## SERDES Client Interface

The SCI allows the SERDES/PCS quad to be controlled by registers as opposed to the configuration memory cells. It is a simple register configuration interface. The block diagram of the SCI that resides in the FPGA core is shown in Figure 8-43.

**Figure 8-43. SCI Interface Block Diagram**



The interface logic that resides in the FPGA core should be developed by users per their interface scheme. Contact Lattice Technical Support for example code.

The SCI\_ADDR bus is six bits wide within the block. The bus width at the block boundary is 11 bits. The upper five bits are used for quad block selection and channel selection. Table 8-25 shows the SCI address map for the SERDES quad.

Refer to Appendix A and Appendix B for SERDES/PCS register address and bit descriptions.

**Table 8-25. SCI Address Map for Up to Four SERDES/PCS Quads**

| Address Bits   | Description                                                                                                                                                                                       |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCI_ADDR[5:0]  | Register address bits<br>000000 = select register 0<br>000001 = select register 1<br>...<br>111110 = select register 62<br>111111 = select register 63                                            |
| SCI_ADDR[8:6]  | Channel address bits<br>000 = select channel 0<br>001 = select channel 1<br>010 = select channel 2<br>011 = select channel 3<br>100 = select Quad<br>101 = Unused<br>110 = Unused<br>111 = Unused |
| SCI_ADDR[10:9] | Quad address bits<br>00 = select Quad A<br>01 = select Quad B<br>10 = select Quad C<br>11 = select Quad D                                                                                         |

Read and write operations through this interface are asynchronous. In the WRITE cycle the write data and write address must be set up and held in relation to the falling edge of the SCI\_WR. In the READ cycle the timing has to be in relation with the SCI\_RD pulse. Figures 8-44 and 8-45 show the WRITE and READ cycles, respectively.

**Figure 8-44. SCI WRITE Cycle, Critical Timing**



1.  $tsu^1$  is the setup time for address and write data prior to the falling edge of the write strobe.
2.  $th^2$  is the hold time for address and write data after the falling edge of the write strobe.

Note: To avoid accidental writing to control registers, registers should be used at the SCI input ports to drive them low at power-up reset.

**Figure 8-45. SCI READ Cycle, Critical Timing**

**Table 8-26. Timing Parameters**

| Parameter         | Typical Value | Units |
|-------------------|---------------|-------|
| tsu, trddv, taddv | 1.127         | ns    |
| th, trdde         | 0.805         | ns    |

The SCI interface is as simple as memory read/write. Here is an example of the pseudo code:

Write:

- Cycle 1: Set sci\_addr[5:0], sciw\_data[7:0], sci\_sel = 1'b1
- Cycle 2: Set sci\_wrn from 0  $\geq$  1
- Cycle 3: Set sci\_wrn from 1  $\geq$  0, sci\_sel = 1'b0

Read:

- Cycle 1: Set sci\_addr[5:0], sci\_sel = 1'b1
- Cycle 2: Set sci\_rd from 0  $\geq$  1
- Cycle 3: Obtain reading data from sci\_rddata[7:0]
- Cycle 4: Set sci\_rd from 1  $\geq$  0

## Interrupts and Status

The status bit may be read via the SCI, which is a byte wide and thus reads the status of eight interrupt status signals at a time. The SCI\_INT signal goes high to indicate that an interrupt event has occurred. The user is then required to read the QIF status register that indicates whether the interrupt came from the quad or one of the channels. This register is not cleared on read. It is cleared when all interrupt sources from the quad or channel are cleared. Once the aggregated source of the interrupt is determined, the user can read the registers in the associated quad or channel to determine the source of the interrupt. Tables 8-27 and 8-28 list all the sources of interrupt.

**Table 8-27. Quad Interrupt Sources**

| Quad SCI_INT Source                                   | Description                                                                                                                                                                                                                    | Register Name                            |
|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| int_qd_out                                            | Quad Interrupt. If there is an interrupt event anywhere in the quad this register bit will be active. This register bit is cleared when all interrupt events have been cleared.                                                | PCS Quad Status Register QD_20           |
| int_ch_out[0:3]                                       | Channel Interrupt. If there is an interrupt event anywhere in the respective channel this register bit will be active. These register bits are cleared when all interrupt sources in the respective channel have been cleared. | PCS Quad Status Register QD_20           |
| ls_sync_statusn_[0:3]_int<br>ls_sync_status_[0:3]_int | Link Status Low (out of sync) channel interrupt Link Status High (in sync) channel interrupt                                                                                                                                   | PCS Quad Interrupt Status Register QD_22 |
| ~PLOL, PLOL                                           | Interrupt generated on ~PLOL and PLOL - PLL Loss of Lock                                                                                                                                                                       | SERDES Quad Status Register QD_25        |

**Table 8-28. Channel Interrupt Sources**

| Channel SCI_INT Source                                                            | Description                                                                                                                                                                | Register Name                                       |
|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| fb_tx_fifo_error_int<br>fb_rx_fifo_error_int<br>cc_overrun_int<br>cc_underrun_int | FPGA Bridge TX FIFO Error Interrupt<br>FPGA Bridge RX FIFO Error Interrupt<br>CTC FIFO Overrun and Underrun Interrupts                                                     | PCS Channel General Interrupt Status Register CH_23 |
| pci_det_done_int<br>rls_lo_int<br>~rls_lo_int<br>rlol_int<br>~rlol_int            | Interrupt generated for pci_det_done<br>Interrupt generated for rls_lo<br>Interrupt generated for ~rls_lo<br>Interrupt generated for rlol<br>Interrupt generated for ~rlol | SERDES Channel Interrupt Status Register CH_2A      |

### SERDES Client Interface Application Example

Lattice ORCAstra FPGA configuration software is a PC-based GUI that allows users to configure the operational mode of a Lattice FPGA by programming control bits in the FPGA registers.

SERDES/PCS status information is displayed on-screen in real time, and any configuration can be saved to control registers for additional testing. Use of the GUI does not interfere with the programming of the FPGA core portion. More information and downloadable files for ORCAstra can be found on the Lattice Semiconductor website at [www.latticesemi.com/products/designsoftware/orcastra.cfm](http://www.latticesemi.com/products/designsoftware/orcastra.cfm).

Users can get a complete LatticeECP3 ORCAstra interface design from IPexpress. In addition to the HDL file that contains the ORCAstra interface, a file called “chip.v” (for Verilog) that wraps the ORCAstra interface is also provided.

### Dynamic Configuration of the SERDES/PCS Quad

The SERDES/PCS quad can be controlled by registers that are accessed through the optional SERDES Client Interface.

When controlled by the configuration memory cells, it is a requirement that the SERDES/PCS quads must reach a functional state after configuration is complete, without further intervention from the user. This means that any special reset sequences that are required to initialize the SERDES/PCS quad must be handled automatically by the hardware. In other words, use of the SCI is optional. The SERDES/PCS quad does NOT assume that the soft IP is present in the FPGA core.

## SERDES Debug Capabilities

### PCS Loopback Modes

The LatticeECP3 family provides three loopback modes controlled by control signals at the PCS/FPGA interface for convenient testing of the external SERDES/board interface and the internal PCS/FPGA logic interface. Two loopback modes are provided to loop received data back onto the transmit data path. The loopback modes are useful

for checking the high-speed serial SERDES package pin connections as well as the embedded SERDES and/or PCS logic.

### **RX-to-TX Serial Loopback Mode**

Loops serial receive data back onto the transmit buffer without passing through the CDR or de-serializer. Selecting the RX-to-TX Serial Loopback option in the IPexpress GUI will set both the LB\_CTL[1:0] to '10' and TDRV\_DAT\_SEL[1:0] register bits to '11' (see Tables 8-81 and 8-84).

### **TX-to-RX Serial Loopback Mode**

This mode loops back serial transmit data back onto the receiver CDR block. Selecting the TX-to-RX Serial Loopback option in the IPexpress GUI will set LB\_CTL[1:0] to '01' (see Table 8-81).

### **SERDES Parallel Loopback Mode**

Loops parallel receive data back onto the transmit data path without passing through the PCS logic. When disabled in the IPexpress GUI, the parallel loopback mode can be dynamically controlled from the FPGA core control signals sb\_felb\_ch[3:0]\_c and sb\_felb\_rst\_ch[3:0]\_c.

If the dynamic feature of this loopback mode is not used, the two control signals should be tied to ground.

When enabled in the loopback mode in the IPexpress GUI, the control register bit sb\_pfifo\_lp(CH\_03[5]) is set and the loopback mode is set. The control signals from the FPGA core, sb\_felb\_ch[3:0]\_c and sb\_felb\_rst\_ch[3:0]\_c, are not available in the PCS module.

Refer to the Figure 8-46 for the discussion above.

**Figure 8-46. Three Loopback Modes**



**Figure 8-47. Loopback Enable Signals**

$sb\_felb\_ch[3:0]_c \wedge sb\_pfifo\_lp(CH\_03[5])$  — SERDES Bridge Far End Parallel Loopback Enable

$LB\_CTL[1:0](CH\_11[5:4] = '10') \wedge TDRV\_DAT\_SEL[1:0](CH\_14[6:5] = '11')$  — RX-to-TX Serial Loopback Enable

$LB\_CTL[1:0](CH\_11[5:4] = '01')$  — TX-to-RX Serial Loopback Enable

## ORCAstra

Lattice ORCAstra software helps you quickly explore configuration options without going through a lengthy re-compile process or making changes to your board. Configurations created in the GUI can be saved to memory and re-loaded for later use. To use ORCAstra, the ORCASTRA module from IPexpress must be created and used in the FPGA design.

A macro capability is also available to support script-based configuration and testing. The GUI can also be used to display system status information in real time. Use of the ORCAstra software does not interfere with the programming of the FPGA.

Figure 8-48 shows the ORCAstra GUI top-level window. Users can read and write in this window without going through the subwindows for each PCS channel by read and write data at the address cell. When invoked, ORCAstra will automatically recognize the device type. Or, device types can be selected under the device pull-down menu.

**Figure 8-48. ORCAstra Top-Level Screen Shot**



By default, the data box shown in Figure 8-48 follows Big Endian byte order (i.e., the most significant bit is placed on the left). Users can change to Little Endian order by selecting **Display Data Reversed in Data Box** under the **Options** tab.

Click on the tab **Interface=None** and select **1 ispVM JTAG Hub USB Interface** from the drop-down list.

Then select the **C2 0A 80 80** from the **Select Target JTAG Device** window.

**Figure 8-49. JTAG Device Selection**



Then click **OK** in the ORCAstra Hub I/O window.

**Figure 8-50. Hub ID Selection**



The figure shows there are activities on channel 0 and channel 1. In this example, we assume that the PCS SCI address is mapped to Quad 0 in the design.

Double-clicking on the **PCS0** (Quad 0) button will open the main window as shown in Figure 8-51.

These standard Windows menus control the selection of the device and interface. They also support various configuration options, including setting up and saving configurations with stored files.

**Figure 8-51. ORCAstra Main Window**


### Control Boxes and Buttons, Status Boxes and the Text Window

Moving the cursor over a control box and clicking the left mouse button sets the control bits. Both the bit location and function for the selected box are displayed in the text window and will match those of the register map tables in the [LatticeECP3 Family Data Sheet](#). Only the function is displayed when the cursor is over the bit name. Status boxes are similar to control boxes but have an LED appearance and a colored background.

Figure 8-52 shows the SERDES Buffer Options window. Configuration options can be selected from the pull-down menu.

**Figure 8-52. SERDES Buffer Options Window**


More information and downloadable files for ORCAstra can be found on the Lattice Semiconductor website at the following address: [www.latticesemi.com/products/designsoftware/orcastra.cfm](http://www.latticesemi.com/products/designsoftware/orcastra.cfm).

## Other Design Considerations

### Simulation of the SERDES/PCS

**Table 8-29. Simulation Model Locations**

| Simulator  | Model Location                                                 |
|------------|----------------------------------------------------------------|
| Active-HDL | ispTOOLS\cae_library\simulation\blackbox\pcsc-aldec.zip        |
| ModelSim   | ispTOOLS\cae_library\simulation\blackbox\pcsd-mti_6.0-V1-1.zip |
| NC-Verilog | ispTOOLS\cae_library\simulation\blackbox\pcsd-ncv.zip          |
| VCS        | ispTOOLS\cae_library\simulation\blackbox\PCSD_sim.vp.zip       |

### 16/20-Bit Word Alignment

The PCS receiver cannot recognize the 16-bit word boundary. When Word Aligner is enabled, the PCS can only do BYTE alignment. The 16-bit word alignment should be done in the FPGA fabric and is fairly straight forward. The simulation model works in the same way. It can be enhanced if users implement an alignment scheme as described below.

For example, if transmit data at the FPGA interface are:

YZABCDEFHIJKLM... (each letter is a byte, 8-bit or 10-bit)

Then the incoming data in PCS after 8b10b decoder and before rx\_gearbox are:

YZABCDEFHIJKLM...

After rx\_gearbox, they can become:

1. {ZY} {BA} {DC} {FE} {HG} {JI} {LK} ....

or

2. {AZ} {CB} {ED} {GF} {IH} {KJ} {ML} ...

Clearly, sequence 2 is not aligned. It has one byte offset, but 16/20-bit alignment is needed. Let's say the special character 'A' should be always placed in the lower byte.

Flopping one 20-bit data combines with the current 16/20-bit data to form 32/40-bit data as shown below:

```
1. {DCBA} {HGFE} {LKJI} ...
^
| **Found the A in lower 10-bit, set the offset to '0', send out aligned
data 'BA'
```

Next clock cycle:

```
{FEDC} {JIHG} {NMLK} ...
^
| **send out aligned data 'DC'
```

etc.

After the 16/20-bit alignment, the output data are:

{ZY} {BA} {DC} {FE} {HG} {JI} {LK}...

2. {CBAZ} {GFED} {KJIH} ....

^

| \*\*Found the A in upper 10-bit, set the offset to '10', send out aligned  
data 'BA'

Next clock cycle:

{EDCB} {IHGF} {MLKJ} ...

^

| \*\*send out aligned data 'DC'

etc.

After the 20-bit alignment, the output data are:

{ZY} {BA} {DC} {FE} {HG} {JI} {LK} ...

*Note: The LSB of a 8/10-bit byte or a 16/20-bit word is always transmitted first and received first.*

For sample 16/20-bit word alignment code, send your request to [techsupport@latticesemi.com](mailto:techsupport@latticesemi.com).

#### Unused Quad/Channel and Power Supply

On unused quads and channels, VCCA should be powered up. VCCIB, VCCOB, HDINP/N, HDOUTP/N and REF-CLKP/N should be left floating. Unused channel outputs are tristated, with approximately 10 KOhm internal resistor connecting between the differential output pair. During configuration, HDOUTP/N are pulled high to VCCOB.

Even when a channel is used as Rx Only mode or Tx Only mode, both the VCCOB and VCCIB of the channel must be powered up. Unused SERDES is configured in power down mode by default.

#### Reset and Power-Down Control

The SERDES quad has reset and power-down controls for the entire macro and also for each transmitter and receiver as shown in Figure 8-53. The reset signals are active high and the power-down is achieved by driving the pwrup signals low. The operation of the various reset and power-down controls are described in the following sections.

*Note: When the device is powering up and the chip level power-on-reset is active, the SERDES control bits (in the PCS) will be cleared (or will take on their default value). This will put the SERDES quad into the power-down state.*

**Figure 8-53. SERDES/PCS Quad Reset and Power-Down Controls**


Typically, all resets are via power-on reset and various FPGA fabric resets. The reset logic is shown in Figure 8-54 and Table 8-30.

**Figure 8-54. SERDES/PCS Reset Diagram**


**Table 8-30. SERDES/PCS Reset Table**

| Reset Signals           |                        | PCS <sup>1</sup><br>TX | PCS <sup>1</sup><br>RX | SERDES<br>TX | SERDES<br>RX | PCS<br>CTRL<br>Registers | TX<br>PLL      | CDR<br>PLL |
|-------------------------|------------------------|------------------------|------------------------|--------------|--------------|--------------------------|----------------|------------|
| FPGA                    | Control Register       |                        |                        |              |              |                          |                |            |
| tx_pcs_RST_ch[3:0]_c    | lane_tx_RST[3:0]       | X                      |                        |              |              |                          |                |            |
| rx_pcs_RST_ch[3:0]_c    | lane_rx_RST[3:0]       |                        | X                      |              |              |                          |                |            |
| rst_qd_c                | quad_RST               | X                      | X                      | X            | X            |                          | X              | X          |
| serdes_RST_qd_c         | serdes_RST             |                        |                        | X            | X            |                          | X              | X          |
| rx_serdes_RST_ch[3:0]_c | rrst[3:0] <sup>2</sup> |                        |                        |              | X            |                          |                | X          |
| tx_serdes_RST_c         | trst                   |                        |                        |              |              |                          | X <sup>3</sup> |            |
| TRIION (configuration)  |                        | X                      | X                      | X            | X            | X                        |                |            |

1. Includes SB (SERDES Bridge), PCS core and FB (FPGA Bridge) sub-blocks.

2. For internal use only. This reset should always be tied to '0' unless there is a need to reset the CDR PLL.

3. tx\_serdes\_RST\_c reset does not reset the TX PLL. It only forces tx\_pll\_lol\_qd\_s to go high.

**Table 8-31. Reset Controls Description<sup>1, 2, 3</sup>**

| Reset Signal            |                     | Description                                                                                                                                                                    |
|-------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FPGA                    | Control Register    |                                                                                                                                                                                |
| rst_qd_c                | quad_RST            | Active-high, asynchronous input. Resets all SERDES channels including the auxiliary channel and PCS. This reset includes serdes_RST, txpll, cdr, lane_tx_RST, and lane_rx_RST. |
| serdes_RST_qd_c         | serdes_RST          | Active-high, asynchronous input to the SERDES quad. Gated with software register bit. This reset is for the SERDES block only and TXPLL and CDRPLL are included.               |
| tx/rx_pcs_RST_ch[3:0]_c | lane_tx/rx_RST[0:3] | Active-high, asynchronous input. Resets individual TX/RX channel in SB, PCS core and FB blocks.                                                                                |
| rx_serdes_RST_ch[3:0]_c | rrst[0:3]           | Resets loss-of-lock (rlol), loss-of-signal and calibration circuits.                                                                                                           |
| tx_serdes_RST_c         | trst                | Resets the loss-of-lock of AUX PLL (plol).                                                                                                                                     |

1. For all channels in the quad running in full-data-rate mode, parallel side clocks are guaranteed to be in-phase.

2. For all channels in the quad running in half-data-rate mode, each channel has a separate divide-by-two circuit. Since there is no mechanism in the quad to guarantee that these divide-by-two circuits are in phase after de-assertion of "serdes\_RST", the PCS design should assume that the dividers (and therefore the parallel side clocks) are NOT in phase.

3. In half-data-rate mode, since there is no guarantee that the parallel side clocks are in phase, this may add channel-to-channel skew to both transmit and receive sides of a multi-channel link.

**Table 8-32. Reset Pulse Specification**

| Parameter                  | Description                       | Min. | Typ. | Max. | Units |
|----------------------------|-----------------------------------|------|------|------|-------|
| t <sub>SERDES_RST_QD</sub> | Quad SERDES Reset high time       | 1    |      |      | us    |
| t <sub>RX_PCS_RST</sub>    | Channel RX PCS Reset high time    | 3    |      |      | ns    |
| t <sub>TX_PCS_RST</sub>    | Channel TX PCS Reset high time    | 3    |      |      | ns    |
| t <sub>RX_SERDES_RST</sub> | Channel RX SERDES reset high time | 3    |      |      | ns    |
| t <sub>TX_SERDES_RST</sub> | Quad TX SERDES reset high time    | 3    |      |      | ns    |

#### Power-Down Control Description

Each RX and TX channel can be individually powered-down by a software register bit or a control signal from the FPGA. The individual channel power-down control bits will only power-down selected blocks within the SERDES macro and the high-speed I/O buffers.

**Table 8-33. Power-Down Control Description**

| Signal             |             | Description                                                                                                                                                                                                                                                                                                                    |
|--------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FPGA               | Register    |                                                                                                                                                                                                                                                                                                                                |
|                    | serdes_pd   | Active-low asynchronous input to the SERDES quad, acts on all channels including the auxiliary channel. When driven low, it powers down the whole macro including the transmit PLL. All clocks are stopped and the macro power dissipation is minimized. After release, both the TX and RX reset sequences should be followed. |
| tx_pwrup_ch[0:3]_c | tpwrup[0:3] | Active-high transmit channel power-up – Powers up the serializer and output driver. After release, the TX reset sequence should be followed.                                                                                                                                                                                   |
| rx_pwrup_ch[0:3]_c | rpwrup[0:3] | Active-high receive channel power-up – Powers up CDR, input buffer (equalizer and amplifier) and loss-of-signal detector. After release, the RX reset sequence should be followed.                                                                                                                                             |

**Table 8-34. Power-Down/Power-Up Timing Specification**

| Parameter          | Description                     | Min. | Typ. | Max. | Units |
|--------------------|---------------------------------|------|------|------|-------|
| t <sub>PWRDN</sub> | Power-down time after serdes_pd | 20   |      |      | ns    |
| t <sub>PWRUP</sub> | Power-up time after serdes_pd   | 20   |      |      | ns    |

## SERDES/PCS RESET

### Reset Sequence and Reset State Diagram

After power-up and configuration, all SERDES resets and FPGA resets are applied.

### Reset Sequence Generation

Reset Sequence is included in the IPExpress GUI (available in Diamond 1.1 and later versions).

We recommend to select the reset sequence generation option in IPExpress as described in the Control Setup tab section. The HDL file generated for the SERDES/PCS will include the Tx Reset State Machine and Rx Reset State Machine.

### Lock Status Signals Definitions

|                      |                                                                                                                                        |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| tx_pll_lol_qd_s:     | : 1 = TX PLL loss of lock<br>: 0 = TX PLL lock<br>It takes 1,400,000 UI to declare the lock of TX PLL                                  |
| rx_cdr_lol_ch[3:0]_s | : 1 = CDR loss of lock<br>: 0 = Lock maintained<br>It takes 400,000 reference clock cycles (worst case) to declare the lock of CDR PLL |
| rx_los_low_ch[3:0]_s | : 1 = Loss of signal detection for each channel<br>: 0 = Signal detected                                                               |

The rx\_cdr\_lol\_ch[3:0]\_s status signal is an indicator of the CDR lock status as defined above. However, during the CDR locking process the CDR PLL will lock to a reference clock when there is no input data present. This avoids ignoring the input data when it is restored.

In order to ensure the presence of input data during CDR lock status checking, it is recommended to use the rx\_los\_low\_ch[3:0]\_s signal in conjunction with the rx\_cdr\_lol\_ch[3:0]\_s signal.

### TX Reset Sequence

1. QUAD\_RESET: At power up, assert rst\_qd\_c and tx\_pcs\_RST\_CH[3:0]\_C.
2. WAIT\_FOR\_TIMER1: Start TIMER1. Wait for a minimum 20 ns.
3. CHECK\_PLOL: Release rst\_qd\_c.
4. WAIT\_FOR\_TIMER2: Start TIMER2. If TIMER2 expires and the TX PLL is not locked, go to step 1.
5. NORMAL: Release tx\_pcs\_RST\_CH#\_C. If tx\_pll\_lol\_qd\_s goes high during normal operation, go to step 1.

### RX Reset Sequence

1. WAIT\_FOR\_PLOL: Wait until the TX PLL locks and receive data is present. rx\_serdes\_RST\_CH[3:0]\_C is set to 0 because rx\_los\_low[3:0]\_s goes high when it is asserted.
2. RX\_SERDES\_RESET: Assert rx\_serdes\_RST\_CH[3:0]\_C and rx\_pcs\_RST\_CH[3:0]\_C.
3. WAIT\_FOR\_TIMER1: Wait for a minimum of 3 ns.
4. CHECK\_LOL\_LOS: Release rx\_serdes\_RST\_CH\_C. Reset TIMER2.

5. WAIT\_FOR\_TIMER2: Wait for both `cdr_lol_ch[3:0]_s` and `rx_los_low_ch[3:0]` to go low. If there is a transition in `rx_lol_los` (`rx_cdr_lol_ch_s || rx_los_low_ch_s`), go to step 4. If TIMER2 expires with `rx_lol_los = 1`, go to step 1.

6. NORMAL: Release `rx_pcs_rst_ch_c`. If `rx_lol_los` goes high, go to step 1.

*Note: The RX reset sequence provides the CDR re-locking feature when the input data source is interrupted during normal operation. The RX reset can be applied by channel base.*

The reset sequence state diagrams are described in Figures 8-55 and 8-56.

A set of [sample reset sequence code](#) is available on the Lattice web site.

**Figure 8-55. TX Reset State Diagram**



## Notes:

TIMER 1: rst\_qd\_c asserted for a minimum of 20 ns.

TIMER 2: Time to declare TX PLL lock: 1,400,000 UI.

**Figure 8-56. RX Reset State Diagram**

**Notes:**

TIMER 1: rx\_serdes\_rst\_ch[3:0]\_c asserted for minimum 3 ns.

TIMER 2: Time for rx\_lol\_los signal to stay low (400,000 reference clock cycles). Any FPGA clock can be used to satisfy the timer requirement.

In the diagram above, rx\_lol\_los is defined as rx\_cdr\_lol\_ch[3:0]\_s || rx\_los\_low\_ch[3:0]\_s.

The tx\_pll\_lol\_qd\_s input to the state diagram RTL code should be tied low in Rx Only mode or when the recovered clock is used as the Tx PLL reference clock, as in SDI applications.

When multiple receiver channels rx\_serdes\_rst\_ch[3:0]\_c are to be asserted, it is recommended to activate the reset signals one channel at a time. Simultaneous resetting of multiple receiver SERDES channels may cause a current surge in the SERDES/PCS quad.

The rx\_los\_low output from SERDES may be triggered for some input streams with continuous zeros, like the SDI pathological pattern. For such applications, the rx\_los\_low input to the reset state machine must be connected to the carrier detect output (must be inverted) of the cable equalizer if available. In general, CD=1 means carrier is present. So this signal must be inverted to replace rx\_los\_low. If a cable equalizer is not available, users may tie it to zero but in this case, the CDR can lock to a local reference clock when there is no input data present.

### **Power Supply Sequencing Requirements**

When using the SERDES with 1.5V VCCIB or VCCOB, the SERDES should not be left in a steady state condition with the 1.5V power applied and the 1.2V power not applied. Both the 1.2V and the 1.5V power should be applied to the SERDES at nominally the same time. The normal variation in ramp\_up times of power supplies and voltage regulators is not a concern.

### **References**

- TN1033, [High-Speed PCB Design Considerations](#)
- TN1114, [Electrical Recommendations for Lattice SERDES](#)
- HB1009, [LatticeECP3 Family Handbook](#)
- DS1021, [LatticeECP3 Family Data Sheet](#)

### **Technical Support Assistance**

e-mail: [techsupport@latticesemi.com](mailto:techsupport@latticesemi.com)

Internet: [www.latticesemi.com](http://www.latticesemi.com)

### **Revision History**

| Date          | Version | Change Summary                                                                                                                     |
|---------------|---------|------------------------------------------------------------------------------------------------------------------------------------|
| February 2009 | 01.0    | Initial release.                                                                                                                   |
| March 2009    | 01.1    | Updated Data Bus Usage for Each Mode table.                                                                                        |
|               |         | Updated Reference Clock Usage Block Diagram.                                                                                       |
| June 2009     | 01.2    | tdrv_amp attribute setting changed to tdrv attribute.                                                                              |
|               |         | Added External Link State Machine Option section.                                                                                  |
|               |         | Added Idle Insert for Gigabit Ethernet Mode section.                                                                               |
|               |         | GUI screen shots updated.                                                                                                          |
|               |         | Word alignment latency updated.                                                                                                    |
| November 2009 | 01.3    | Updated Reset Sequence State Diagrams are provided, tx and rx side separately.                                                     |
|               |         | los settings are updated.                                                                                                          |
|               |         | Added SONET support.                                                                                                               |
|               |         | Removed Far End Parallel Loopback feature.                                                                                         |
|               |         | Data rate ranges are re-defined.                                                                                                   |
|               |         | Reduced minimum data rate to 150 Mbps.                                                                                             |
| February 2010 | 01.4    | Reset sequence state diagram updated.                                                                                              |
| March 2010    | 01.5    | Added Generation Options tab in IPexpress GUI.                                                                                     |
| June 2010     | 01.6    | Updated for Lattice Diamond design software support.                                                                               |
|               |         | refclk_to/from_nq signals removed from clock diagram.                                                                              |
| December 2010 | 01.7    | Added Reset Sequence Generation option in the IPexpress GUI.                                                                       |
|               |         | Added detailed information about comma mask.                                                                                       |
| July 2011     | 01.8    | Standards Supported by SERDES table – updated information for Gigabit Ethernet, SGMII, 10-Bit SERDES, 8-Bit SERDES, Generic 8b10b. |
|               |         | Transmit Data Bus section updated.                                                                                                 |
|               |         | Receive Data Bus section updated.                                                                                                  |
|               |         | Updated footnotes for Loss of Signal Detector figure.                                                                              |

## Revision History (Continued)

| Date             | Version      | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| July 2011(cont.) | 01.8 (cont.) | <p>SERDES_PCS GUI Attributes - Quad Tab Setup table – Added SGMII to Protocol Range.</p> <p>SERDES/PCS Latency Breakdown table – updated gearing information.</p> <p>Simulation Model Locations table – Added VCS row.</p> <p>Updated SERDES/PCS Reset Diagram.</p> <p>Updated footnotes of the Rx Reset State Diagram.</p> <p>Updated information for bit 5 in the SERDES Control Register QD_0A table.</p> <p>Updated information for bits 3 and 2:0 in the SERDES Control Register CH_13 table.</p> <p>Added footnote to PCS Status Register CH_21 table.</p> <p>Attribute Cross Reference Table – Updated attribute values for TX_DATARATE_RANGE and CHn_RX_DATARATE_RANGE. Updated first footnote.</p>                |
| September 2011   | 01.9         | <p>SERDES Control Register CH_14, corrected default value of tpwrup register bit.</p> <p>Attribute Cross-Reference Table, removed all int_all reserved bits and los_hi bits.</p> <p>PCS Control Register QD_02, updated default values.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| November 2011    | 02.0         | <p>SERDES_PCS I/O Descriptions table – Updated descriptions for tx_full_clk_ch[3:0] and tx_half_clk_ch[3:0].</p> <p>Updated Tx Lane-to-Lane Skew text section.</p> <p>Updated word alignment control bullet in the Word Alignment (Byte Boundary Detect) section.</p> <p>Updated External Link State Machine Option text section.</p> <p>Power-Down Control Description table – Updated description for tx_pwrup_ch[0:3]_c signal.</p> <p>Appendix A, SERDES Control Register QD_0B table – Updated description for Bit 7.</p> <p>Appendix A, PCS Control Register CH_01 table – Updated description for Bit 7.</p> <p>Appendix C, Attribute Cross-Reference table – Updated attribute value for {CHn_RXWA, CHn_ILSM}.</p> |
| February 2012    | 02.1         | Updated document with new corporate logo.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| April 2012       | 02.2         | <p>Updated Number of SERDES/PCS Quads per LatticeECP3 Device table for 328-ball csBGA.</p> <p>SERDES_PCS I/O Descriptions table – Updated description for refclk2fpga.</p> <p>SERDES_PCS GUI Attributes – SERDES Advanced Setup Tab table – Updated footnote 3.</p> <p>Added new Reference Clock to FPGA Core and Reset Sequence text section.</p> <p>Updated Generic 8b10b Mode text section.</p> <p>Updated FPGA Interface Clocks text section.</p> <p>Appendix A, Channel Interface Registers Map table – Updated information for CH_16, CH_17 and CH_23.</p> <p>Appendix A, SERDES Control Register CH_11 table – Changed Bit 3:2 to “Reserved”.</p>                                                                   |

## Revision History (Continued)

| Date        | Version | Change Summary                                                                                                               |
|-------------|---------|------------------------------------------------------------------------------------------------------------------------------|
| May 2012    | 02.3    | Clarified data pattern requirements for LSM synchronization in generic 8b10b mode.                                           |
| August 2012 | 02.4    | Added LatticeECP3-17EA 328 csBGA limited channels availability.                                                              |
|             |         | SERDES_PCS I/O Descriptions table – Added footnote 3.                                                                        |
|             |         | RX Reset State Diagram footnote updated.                                                                                     |
| June 2013   | 02.5    | Added note on possible lsm_status_ch(0:3)_s glitches.                                                                        |
|             |         | Updated note on the SERDES/PCS GUI – PCS Advanced2 Setup Tab table.                                                          |
|             |         | Updated the Protocol-Specific SERDES Setup Options table.                                                                    |
|             |         | Updated the SERDES Control Register CH_10 table.                                                                             |
|             |         | Added information on the SERDES Equalizer and Pre-Emphasis settings.                                                         |
|             |         | Updated Technical Support Assistance information.                                                                            |
| March 2014  | 02.6    | Updated Table 8-23, SERDES/PCS Latency Breakdown. Revised units.                                                             |
|             |         | Updated Table 8-49, PCS Control Register QD_0D. Revised PLL_LOL_SET[1:0] description.                                        |
| April 2014  | 02.7    | Updated Table 8-5, SERDES_PCS I/O Descriptions. Revised control comma aligner description.                                   |
|             |         | Updated External Link State Machine Option section. Revised word aligner and Link State Machine options information.         |
| August 2014 | 2.8     | Updated <a href="#">Rate Modes</a> , section. Revised information on SERDES settings in Note.                                |
|             |         | Updated <a href="#">Generic 8b10b Mode</a> section. Changed K28.1 (k=1, Data=0xFC) to K28.7 (k=1, Data=0xFC) in the example. |
|             |         | Updated <a href="#">PCI Express Electrical Idle Transmission</a> section. Changed K28.5 (IDL) to K28.3 (IDL).                |

## Appendix A. Configuration Registers

### Quad Registers Overview

**Table 8-35. Quad Interface Registers Map**

| BA                                       | Register Name | D7                        | D6                        | D5                        | D4                        | D3                        | D2                        | D1                        | D0                        |
|------------------------------------------|---------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|
| <b>Per Quad PCS Control Registers</b>    |               |                           |                           |                           |                           |                           |                           |                           |                           |
| 00                                       | QD_00         | reg_sync_toggle           | force_int                 | char_mode                 | xge_mode                  |                           |                           |                           |                           |
| 01                                       | QD_01         |                           |                           |                           |                           | internal use only         |                           |                           |                           |
| 02                                       | QD_02         | high_mark[3]              | high_mark[2]              | high_mark[1]              | high_mark[0]              | low_mark[3]               | low_mark[2]               | low_mark[1]               | low_mark[0]               |
| 03                                       | QD_03         |                           |                           |                           |                           |                           | pfifo_clr_sel             | internal use only         | internal use only         |
| 04                                       | QD_04         | internal use only         |                           |                           |                           |                           |                           |                           |                           |
| 05                                       | QD_05         | internal use only         |                           |                           |                           |                           |                           |                           |                           |
| 06                                       | QD_06         | internal use only         |                           |                           |                           |                           |                           |                           |                           |
| 07                                       | QD_07         | internal use only         |                           |                           |                           |                           |                           |                           |                           |
| 08                                       | QD_08         | internal use only         |                           |                           |                           |                           |                           |                           |                           |
| 09                                       | QD_09         | ls_sync_statusn_3_int_ctl | ls_sync_statusn_2_int_ctl | ls_sync_statusn_1_int_ctl | ls_sync_statusn_0_int_ctl | ls_sync_statusn_3_int_ctl | ls_sync_statusn_2_int_ctl | ls_sync_statusn_1_int_ctl | ls_sync_statusn_0_int_ctl |
| <b>Per Quad SERDES Control Registers</b> |               |                           |                           |                           |                           |                           |                           |                           |                           |
| 0A                                       | QD_0A         | internal use only         | reserved                  | tx_refck_sel              | refck_dcc_en              | refck_rterm               |                           | refck_out_sel[1]          | refck_out_sel[0]          |
| 0B                                       | QD_0B         | refck25x                  | bus8bit_sel               | reserved                  | reserved                  | reserved                  | reserved                  | refck_mode[1]             | refck_mode[0]             |
| 0C                                       | QD_0C         | reserved                  | reserved                  | reserved                  | reserved                  | reserved                  | reserved                  | cdr_lol_sel[1]            | cdr_lol_sel[0]            |
| 0D                                       | QD_0D         | internal use only         | internal use only         | internal use only         | pll_lol_sel[1]            | pll_lol_sel[0]            | tx_vco_ck_div[2]          | tx_vco_ck_div[1]          | tx_vco_ck_div[0]          |
| 0E                                       | QD_0E         | internal use only         |
| 0F                                       | QD_0F         | -polt_int_ctl             | -polt_int_ctl             | reserved                  | reserved                  | reserved                  | reserved                  | reserved                  | reserved                  |
| <b>Per Quad Clock Reset Registers</b>    |               |                           |                           |                           |                           |                           |                           |                           |                           |
| 10                                       | QD_10         | reserved                  | reserved                  | reserved                  | reserved                  | serdes_pd                 | serdes_rst                | quad_rst                  | trst                      |
| 11                                       | QD_11         | reserved                  |
| <b>Per Quad PCS Status Registers</b>     |               |                           |                           |                           |                           |                           |                           |                           |                           |
| 20                                       | QD_20         |                           |                           | int_qd_out                | int_ch[3]                 | int_ch[2]                 | int_ch[1]                 | int_ch[0]                 |                           |
| 21                                       | QD_21         | ls_sync_status_3          | ls_sync_status_2          | ls_sync_status_1          | ls_sync_status_0          | ls_sync_statusn_3         | ls_sync_statusn_2         | ls_sync_statusn_1         | ls_sync_statusn_0         |
| 22                                       | QD_22         | ls_sync_status_3_int      | ls_sync_status_2_int      | ls_sync_status_1_int      | ls_sync_status_0_int      | ls_sync_statusn_3_int     | ls_sync_statusn_2_int     | ls_sync_statusn_1_int     | ls_sync_statusn_0_int     |
| 23                                       | QD_23         | internal use only         |
| 24                                       | QD_24         | internal use only         |
| <b>Per Quad SERDES Status Registers</b>  |               |                           |                           |                           |                           |                           |                           |                           |                           |
| 25                                       | QD_25         | polt                      | -polt                     | reserved                  | reserved                  | reserved                  | reserved                  | reserved                  | reserved                  |
| 26                                       | QD_26         | polt_int                  | -polt_int                 | reserved                  | reserved                  | reserved                  | reserved                  | reserved                  | reserved                  |
| 27                                       | QD_27         | reserved                  |
| 28                                       | QD_28         | reserved                  |

### Per Quad PCS Control Registers Details

**Table 8-36. PCS Control Register QD\_00**

| Bit | Name            | Description                                                                                                               | Type | Default |
|-----|-----------------|---------------------------------------------------------------------------------------------------------------------------|------|---------|
| 7   | reg_sync_toggle | Transition = Reset the four TX serializers to minimize TX lane-to-lane skew<br>Level = Normal operation of TX serializers | RW   | 0       |
| 6   | force_int       | 1 = Force to generate interrupt signal<br>0 = Normal operation                                                            | RW   | 0       |
| 5   | char_mode       | 1 = Enable SERDES characterization mode<br>0 = Disable SERDES characterization mode                                       | RW   | 0       |
| 4   | xge_mode        | 1 = Selects 10Gb Ethernet<br>0 = Depends on Channel Mode Selection                                                        | RW   | 0       |
| 3:0 | Reserved        |                                                                                                                           |      |         |

**Table 8-37. PCS Control Register QD\_01**

| Bit | Name              | Description | Type | Default |
|-----|-------------------|-------------|------|---------|
| 7:0 | Internal use only |             |      |         |

**Table 8-38. PCS Control Register QD\_02**

| Bit | Name           | Description                                               | Type | Default |
|-----|----------------|-----------------------------------------------------------|------|---------|
| 7:4 | high_mark[3:0] | Clock compensation FIFO high water mark. Mean is 4'b1000. | RW   | 4'b1001 |
| 3:0 | low_mark[3:0]  | Clock compensation FIFO low water mark. Mean is 4'b1000.  | RW   | 4'b0111 |

**Table 8-39. PCS Control Register QD\_03**

| Bit | Name              | Description                                                                                                          | Type | Default |
|-----|-------------------|----------------------------------------------------------------------------------------------------------------------|------|---------|
| 7:3 | Reserved          |                                                                                                                      |      |         |
| 2   | pfifo_clr_sel     | 1 = pfifo_clr signal or channel register bit clears the FIFO<br>0 = pfifo_error internal signal self clears the FIFO | RW   | 0       |
| 1   | Internal use only |                                                                                                                      |      |         |
| 0   | Internal use only |                                                                                                                      |      |         |

**Table 8-40. PCS Control Register QD\_04**

| Bit | Name              | Description | Type | Default |
|-----|-------------------|-------------|------|---------|
| 7:0 | Internal use only |             |      |         |

**Table 8-41. PCS Control Register QD\_05**

| Bit | Name              | Description | Type | Default |
|-----|-------------------|-------------|------|---------|
| 7:0 | Internal use only |             |      |         |

**Table 8-42. PCS Control Register QD\_06**

| Bit | Name              | Description | Type | Default |
|-----|-------------------|-------------|------|---------|
| 7:0 | Internal use only |             |      |         |

**Table 8-43. PCS Control Register QD\_07**

| Bit | Name              | Description | Type | Default |
|-----|-------------------|-------------|------|---------|
| 7:0 | Internal use only |             |      |         |

**Table 8-44. PCS Control Register QD\_08**

| Bit | Name              | Description | Type | Default |
|-----|-------------------|-------------|------|---------|
| 7:0 | Internal use only |             |      |         |

**Table 8-45. PCS Control Register QD\_09**

| Bit | Name                      | Description                                                                                                                                           | Type | Default |
|-----|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 7   | ls_sync_status_3_int_ctl  | 1 = Enable interrupt for ls_sync_status_3 (in sync)<br>0 = Disable interrupt for ls_sync_status_3 (in sync)                                           | RW   | 0       |
| 6   | ls_sync_status_2_int_ctl  | 1 = Enable interrupt for ls_sync_status_2 (in sync)<br>0 = Disable interrupt for ls_sync_status_2 (in sync)                                           | RW   | 0       |
| 5   | ls_sync_status_1_int_ctl  | 1 = Enable interrupt for ls_sync_status_1 (in sync)<br>0 = Disable interrupt for ls_sync_status_1 (in sync)                                           | RW   | 0       |
| 4   | ls_sync_status_0_int_ctl  | 1 = Enable interrupt for ls_sync_status_0 (in sync)<br>0 = Disable interrupt for ls_sync_status_0 (in sync)                                           | RW   | 0       |
| 3   | ls_sync_statusn_3_int_ctl | 1 = Enable interrupt for ls_sync_status_3 when it goes low (out of sync)<br>0 = Disable interrupt for ls_sync_status_3 when it goes low (out of sync) | RW   | 0       |
| 2   | ls_sync_statusn_2_int_ctl | 1 = Enable interrupt for ls_sync_status_2 when it goes low (out of sync)<br>0 = Disable interrupt for ls_sync_status_2 when it goes low (out of sync) | RW   | 0       |
| 1   | ls_sync_statusn_1_int_ctl | 1 = Enable interrupt for ls_sync_status_1 when it goes low (out of sync)<br>0 = Disable interrupt for ls_sync_status_1 when it goes low (out of sync) | RW   | 0       |
| 0   | ls_sync_statusn_0_int_ctl | 1 = Enable interrupt for ls_sync_status_0 when it goes low (out of sync)<br>0 = Disable interrupt for ls_sync_status_0 when it goes low (out of sync) | RW   | 0       |

## Per Quad PCS Control Registers Details

**Table 8-46. SERDES Control Register QD\_0A**

| Bit | Name              | Description                                                                     | Type | Default |
|-----|-------------------|---------------------------------------------------------------------------------|------|---------|
| 7   | Internal use only |                                                                                 |      |         |
| 6   | Reserved          |                                                                                 | RW   | 0       |
| 5   | TX_REFCK_SEL      | TxPLL reference clock select<br>0 = REFCLKP/N<br>1 = FPGA core                  | RW   | 0       |
| 4   | Reserved          |                                                                                 |      |         |
| 3   | REFCK_RTERM       | Termination at reference clock input buffer<br>0 = High impedance<br>1 = 50 OHm | RW   | 1       |
| 2   | Reserved          |                                                                                 | RW   | 0       |
| 1   | REFCLK_OUT_SEL[1] | 0 = refclk2fpga output disable<br>1 = refclk2fpga output enable                 | RW   | 0       |
| 0   | REFCLK_OUT_SEL[0] | 0 = tx_refck_local output enable<br>1 = tx_refck_local_output disable           | RW   | 0       |

Note: Refer to Figure 8-9 for Reference Clock Select Control signals.

**Table 8-47. SERDES Control Register QD\_0B**

| Bit | Name            | Description                                                                                                                                                                                                                                                                           | Type | Default |
|-----|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 7   | REFCK25X        | 1 = Internal high-speed bit clock is 25x<br>0 = See REFCK_MODE                                                                                                                                                                                                                        | RW   | 0       |
| 6   | BUS8BIT_SEL     | 1 = Select 8-bit bus width<br>0 = Select 10-bit bus width                                                                                                                                                                                                                             | RW   | 0       |
| 5   | Reserved        |                                                                                                                                                                                                                                                                                       | RW   | 0       |
| 4   | Reserved        |                                                                                                                                                                                                                                                                                       | RW   | 0       |
| 3   | Reserved        |                                                                                                                                                                                                                                                                                       | RW   | 0       |
| 2   | Reserved        |                                                                                                                                                                                                                                                                                       | RW   | 0       |
| 1:0 | REFCK_MODE[1:0] | If REFCK25X = 0, then:<br>00 = Internal high-speed bit clock is 20x<br>01 = Internal high-speed bit clock is 10x<br>10 = Internal high-speed bit clock is 16x<br>11 = Internal high-speed bit clock is 8x<br><br>If REFCLK25X = 1, then:<br>xx = Internal high-speed bit clock is 25x | RW   | 00      |

**Table 8-48. PCS Control Register QD 0C**

**Table 8-49. PCS Control Register QD\_0D**

| Bit | Name               | Description                                                                                    |                                                                      | Type | Default |
|-----|--------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|------|---------|
| 7:6 | Internal use only  |                                                                                                |                                                                      |      |         |
| 5   | Internal use only  |                                                                                                |                                                                      |      |         |
| 4:3 | PLL_LOL_SET[1:0]   | Lock<br>00 = +/- 300ppm x2<br>01 = +/- 300ppm<br>10 = +/- 1500ppm<br>11 = +/- 4000ppm          | Unlock<br>+/- 600ppm x2<br>+/- 2000ppm<br>+/- 2200ppm<br>+/- 6000ppm | RW   | 0       |
| 2:0 | TX_VCO_CK_DIV[2:0] | VCO output frequency select<br>00x = Divided by 1<br>100 = Divided by 4<br>110 = Divided by 16 | 01x = Divided by 2<br>101 = Divided by 8<br>111 = Divided by 32      | RW   | 0       |

**Table 8-50. PCS Control Register QD 0E**

| Bit | Name              | Description | Type | Default |
|-----|-------------------|-------------|------|---------|
| 7:0 | Internal use only |             |      |         |

**Table 8-51. PCS Control Register QD\_0F**

| Bit | Name          | Description                                                                                           | Type  | Default |
|-----|---------------|-------------------------------------------------------------------------------------------------------|-------|---------|
| 7   | PLOL_INT_CTL  | 1 = Interrupt enabled for loss of lock on PLOL<br>0 = Interrupt disabled for loss of lock on PLOL     | RO CR | 0       |
| 6   | -PLOL_INT_CTL | 1 = Interrupt enabled for obtaining lock on PLOL<br>0 = Interrupt disabled for obtaining lock on PLOL | RO CR | 0       |
| 5:0 | Reserved      |                                                                                                       |       |         |

### Per Quad Reset and Clock Control Registers Details

**Table 8-52. PCS Control Register QD\_10**

| Bit | Name       | Description             | Type | Default |
|-----|------------|-------------------------|------|---------|
| 7:4 | Reserved   |                         |      |         |
| 3   | serdes_pd  | 0 = Assert power down   | RW   | 1       |
| 2   | serdes_rst | 1 = Assert serdes reset | RW   | 0       |
| 1   | quad_rst   | 1 = Assert quad reset   | RW   | 0       |
| 0   | trst       | 1 = TX reset            | RW   | 0       |

**Table 8-53. PCS Control Register QD\_11**

| Bit | Name     | Description | Type | Default |
|-----|----------|-------------|------|---------|
| 7:0 | Reserved |             |      |         |

### Per Quad PCS Status Registers Details

**Table 8-54. PCS Status Register QD\_20**

| Bit | Name            | Description                            | Type | Int? |
|-----|-----------------|----------------------------------------|------|------|
| 7:6 | Reserved        |                                        |      |      |
| 5   | ion_delay       | 0 = Delayed global resetn from tri_ion | RO   | No   |
| 4   | int_qd_out      | 1 = Per quad interrupt status          | RO   | No   |
| 3:0 | int_ch_out[3:0] | 1 = Per channel interrupt status       | RO   | No   |

**Table 8-55. PCS Status Register QD\_21**

| Bit | Name              | Description                                                                                                                                    | Type | Int? |
|-----|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------|------|------|
| 7   | ls_sync_status_3  | 1 = Alarm generated on sync_status_3<br>0 = Alarm not generated on sync_status_3                                                               | RO   | Yes  |
| 6   | ls_sync_status_2  | 1 = Alarm generated on sync_status_2<br>0 = Alarm not generated on sync_status_2                                                               | RO   | Yes  |
| 5   | ls_sync_status_1  | 1 = Alarm generated on sync_status_1<br>0 = Alarm not generated on sync_status_1                                                               | RO   | Yes  |
| 4   | ls_sync_status_0  | 1 = Alarm generated on sync_status_0<br>0 = Alarm not generated on sync_status_0                                                               | RO   | Yes  |
| 3   | ls_sync_statusn_3 | 1 = Alarm generated on sync_status_3 when it goes low (out of sync)<br>0 = Alarm not generated on sync_status_3 when it goes low (out of sync) | RO   | Yes  |
| 2   | ls_sync_statusn_2 | 1 = Alarm generated on sync_status_2 when it goes low (out of sync)<br>0 = Alarm not generated on sync_status_2 when it goes low (out of sync) | RO   | Yes  |
| 1   | ls_sync_statusn_1 | 1 = Alarm generated on sync_status_1 when it goes low (out of sync)<br>0 = Alarm not generated on sync_status_1 when it goes low (out of sync) | RO   | Yes  |
| 0   | ls_sync_statusn_0 | 1 = Alarm generated on sync_status_0 when it goes low (out of sync)<br>0 = Alarm not generated on sync_status_0 when it goes low (out of sync) | RO   | Yes  |

**Table 8-56. PCS Interrupt Status Register QD\_22**

| Bit | Name                  | Description                                                                                                                                            | Type     | Int? |
|-----|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------|
| 7   | ls_sync_status_3_int  | 1 = Interrupt generated on sync_status_3<br>0 = Interrupt not generated on sync_status_3                                                               | RO<br>CR | Yes  |
| 6   | ls_sync_status_2_int  | 1 = Interrupt generated on sync_status_2<br>0 = Interrupt not generated on sync_status_2                                                               | RO<br>CR | Yes  |
| 5   | ls_sync_status_1_int  | 1 = Interrupt generated on sync_status_1<br>0 = Interrupt not generated on sync_status_1                                                               | RO<br>CR | Yes  |
| 4   | ls_sync_status_0_int  | 1 = Interrupt generated on sync_status_0<br>0 = Interrupt not generated on sync_status_0                                                               | RO<br>CR | Yes  |
| 3   | ls_sync_statusn_3_int | 1 = Interrupt generated on sync_status_3 when it goes low (out of sync)<br>0 = Interrupt not generated on sync_status_3 when it goes low (out of sync) | RO<br>CR | Yes  |
| 2   | ls_sync_statusn_2_int | 1 = Interrupt generated on sync_status_2 when it goes low (out of sync)<br>0 = Interrupt not generated on sync_status_2 when it goes low (out of sync) | RO<br>CR | Yes  |
| 1   | ls_sync_statusn_1_int | 1 = Interrupt generated on sync_status_1 when it goes low (out of sync)<br>0 = Interrupt not generated on sync_status_1 when it goes low (out of sync) | RO<br>CR | Yes  |
| 0   | ls_sync_statusn_0_int | 1 = Interrupt generated on sync_status_0 when it goes low (out of sync)<br>0 = Interrupt not generated on sync_status_0 when it goes low (out of sync) | RO<br>CR | Yes  |

**Table 8-57. PCS Status Register QD\_23**

| Bit | Name              | Description | Type | Default |
|-----|-------------------|-------------|------|---------|
| 7:0 | Internal use only |             |      |         |

**Table 8-58. PCS Status Register QD\_24**

| Bit | Name              | Description | Type | Default |
|-----|-------------------|-------------|------|---------|
| 7:0 | Internal use only |             |      |         |

## Per Quad SERDES Status Registers Details

**Table 8-59. SERDES Status Register QD\_25**

| Bit | Name     | Description           | Type | Int? |
|-----|----------|-----------------------|------|------|
| 7   | PLOL     | 1 = PLL loss-of-lock  | RO   | Yes  |
| 6   | -PLOL    | 1 = PLL lock obtained | RO   | Yes  |
| 5:0 | Reserved |                       |      |      |

**Table 8-60. SERDES Interrupt Status Register QD\_26**

| Bit | Name      | Description                                                              | Type     | Int? |
|-----|-----------|--------------------------------------------------------------------------|----------|------|
| 7   | PLOL_INT  | 1 = Interrupt generated on PLOL<br>0 = Interrupt not generated on PLOL   | RO<br>CR | Y    |
| 6   | -PLOL_INT | 1 = Interrupt generated on -PLOL<br>0 = Interrupt not generated on -PLOL | RO<br>CR | Y    |
| 5:0 | Reserved  |                                                                          |          |      |

**Table 8-61. SERDES Status Register QD\_27**

| Bit | Name     | Description | Type | Default |
|-----|----------|-------------|------|---------|
| 7:0 | Reserved |             |      |         |

**Table 8-62. SERDES Status Register QD\_28**

| Bit | Name     | Description | Type | Default |
|-----|----------|-------------|------|---------|
| 7:0 | Reserved |             |      |         |

## Channel Registers Overview

**Table 8-63. Channel Interface Registers Map**

| BA                                           | Register Name | D7                | D6                   | D5                  | D4                  | D3                  | D2                 | D1                       | D0                       |
|----------------------------------------------|---------------|-------------------|----------------------|---------------------|---------------------|---------------------|--------------------|--------------------------|--------------------------|
| <b>Per Channel General Control Registers</b> |               |                   |                      |                     |                     |                     |                    |                          |                          |
| 00                                           | CH_00         |                   |                      |                     |                     | rio_mode            | pcie_mode          | fc_mode                  | uc_mode                  |
| 01                                           | CH_01         | word_align_enable | internal use only    | internal use only   | ge_an_enable        |                     | internal use only  | invert_tx                | invert_rx                |
| 02                                           | CH_02         | pfifo_clr         | pcie_ei_en           | pcs_det_time_sel[1] | pcs_det_time_sel[0] | rx_gear_mode        | tx_gear_mode       | rx_ch                    | tx_ch                    |
| 03                                           | CH_03         |                   | sb_bypass            | sb_pfifo_lp         | internal use only   | enc_bypass          | internal use only  | tx_gear_bypass           | fb_loopback              |
| 04                                           | CH_04         | lsm_sel           | ilsm_en              | rx_gear_bypass      | ctc_bypass          | dec_bypass          | wa_bypass          | rx_sb_bypass             | sb_loopback              |
| 05                                           | CH_05         | min_ipg_cnt[1]    | min_ipg_cnt[0]       | match_4_enable      | match_2_enable      |                     |                    |                          |                          |
| 06                                           | CH_06         | cc_match_1[7]     | cc_match_1[6]        | cc_match_1[5]       | cc_match_1[4]       | cc_match_1[3]       | cc_match_1[2]      | cc_match_1[1]            | cc_match_1[0]            |
| 07                                           | CH_07         | cc_match_2[7]     | cc_match_2[6]        | cc_match_2[5]       | cc_match_2[4]       | cc_match_2[3]       | cc_match_2[2]      | cc_match_2[1]            | cc_match_2[0]            |
| 08                                           | CH_08         | cc_match_3[7]     | cc_match_3[6]        | cc_match_3[5]       | cc_match_3[4]       | cc_match_3[3]       | cc_match_3[2]      | cc_match_3[1]            | cc_match_3[0]            |
| 09                                           | CH_09         | cc_match_4[7]     | cc_match_4[6]        | cc_match_4[5]       | cc_match_4[4]       | cc_match_4[3]       | cc_match_4[2]      | cc_match_4[1]            | cc_match_4[0]            |
| 0A                                           | CH_0A         | cc_match_4[9]     | cc_match_4[8]        | cc_match_3[9]       | cc_match_3[8]       | cc_match_2[9]       | cc_match_2[8]      | cc_match_1[9]            | cc_match_1[8]            |
| 0B                                           | CH_0B         | udf_comma_mask[7] | udf_comma_mask[6]    | udf_comma_mask[5]   | udf_comma_mask[4]   | udf_comma_mask[3]   | udf_comma_mask[2]  | udf_comma_mask[1]        | udf_comma_mask[0]        |
| 0C                                           | CH_0C         | udf_comma_a[7]    | udf_comma_a[6]       | udf_comma_a[5]      | udf_comma_a[4]      | udf_comma_a[3]      | udf_comma_a[2]     | udf_comma_a[1]           | udf_comma_a[0]           |
| 0D                                           | CH_0D         | udf_comma_b[7]    | udf_comma_b[6]       | udf_comma_b[5]      | udf_comma_b[4]      | udf_comma_b[3]      | udf_comma_b[2]     | udf_comma_b[1]           | udf_comma_b[0]           |
| 0E                                           | CH_0E         | udf_comma_a[9]    | udf_comma_a[8]       | udf_comma_b[9]      | udf_comma_b[8]      | udf_comma_mask[9]   | udf_comma_mask[8]  |                          |                          |
| 0F                                           | CH_0F         |                   |                      |                     |                     | cc_underrun_int_ctl | cc_overrun_int_ctl | fb_rx_fifo_error_int_ctl | fb_tx_fifo_error_int_ctl |
| <b>Per Channel SERDES Control Registers</b>  |               |                   |                      |                     |                     |                     |                    |                          |                          |
| 10                                           | CH_10         | req_en            | req_lv_set           | rcv_dcc_en          | rate_sel[1]         | rate_sel[0]         | rx_dco_ck_div[2]   | rx_dco_ck_div[1]         | rx_dco_ck_div[0]         |
| 11                                           | CH_11         | internal use only | internal use only    | lb_ctl[1]           | lb_ctl[0]           | internal use only   | internal use only  | rterm_rx[1]              | rterm_rx[0]              |
| 12                                           | CH_12         | tdrv_amp[2]       | tdrv_amp[1]          | tdrv_amp[0]         | tdrv_pre_set[4]     | tdrv_pre_set[3]     | tdrv_pre_set[2]    | tdrv_pre_set[1]          | tdrv_pre_set[0]          |
| 13                                           | CH_13         | ldr_core2tx_sel   |                      |                     |                     | internal use only   | internal use only  | internal use only        | internal use only        |
| 14                                           | CH_14         | tx_div11_sel      | tdrv_dat_sel[1]      | tdrv_dat_sel[0]     | tdrv_ppre_en        | rterm_tx[1]         | rterm_tx[0]        | rate_mode_tx             | tpwrup                   |
| 15                                           | CH_15         | internal use only | internal use only    | internal use only   | internal use only   | ldr_rx2core_en      | rx_refck_sel       | rate_mode_rx             | rpwrup                   |
| 16                                           | CH_16         | rx_div11_sel      | rlos_sel             |                     |                     |                     | rlos_lset[2]       | rlos_lset[1]             | rlos_lset[0]             |
| 17                                           | CH_17         |                   | pci_det_done_int_ctl | rlos_lo_int_ctl     | -rlos_lo_int_ctl    |                     |                    | rlos_int_ctl             | -rlos_int_ctl            |
| <b>Per Channel Clock Reset Registers</b>     |               |                   |                      |                     |                     |                     |                    |                          |                          |
| 18                                           | CH_18         | internal use only | internal use only    |                     |                     |                     | rrst               | lane_rx_rst              | lane_tx_rst              |
| 19                                           | CH_19         |                   |                      |                     | tx_f_clk_dis        | tx_h_clk_en         | rx_f_clk_dis       | rx_h_clk_en              | sel_sd_rx_clk            |
| <b>Per Channel General Status Registers</b>  |               |                   |                      |                     |                     |                     |                    |                          |                          |
| 20                                           | CH_20         |                   |                      |                     |                     | cc_underrun         | cc_overrun         | fb_rx_fifo_error         | fb_tx_fifo_error         |
| 21                                           | CH_21         | prbs_error_cnt[7] | prbs_error_cnt[6]    | prbs_error_cnt[5]   | prbs_error_cnt[4]   | prbs_error_cnt[3]   | prbs_error_cnt[2]  | prbs_error_cnt[1]        | prbs_error_cnt[0]        |
| 22                                           | CH_22         |                   |                      |                     |                     | wa_offset[3]        | wa_offset[2]       | wa_offset[1]             | wa_offset[0]             |
| 23                                           | CH_23         |                   |                      |                     |                     | cc_underrun_int     | cc_overrun_int     | fb_rx_fifo_error_int     | fb_tx_fifo_error_int     |
| 24                                           | CH_24         |                   | ffs_ls_sync_status   | fb_rxrst_o          | fb_txrst_o          |                     |                    | cc_re_o                  | cc_we_o                  |
| 25                                           | CH_25         |                   |                      |                     |                     |                     |                    |                          |                          |
| <b>Per Channel SERDES Status Registers</b>   |               |                   |                      |                     |                     |                     |                    |                          |                          |
| 26                                           | CH_26         |                   | pcie_det_done        | rlos_lo             | -rlos_lo            | rlos_hi             | -rlos_hi           | rlos                     | -rlos                    |
| 27                                           | CH_27         | internal use only | internal use only    | internal use only   | internal use only   |                     |                    | cdr_traine_done          | pci_connect              |
| 28                                           | CH_28         | internal use only | internal use only    | internal use only   | internal use only   | internal use only   | internal use only  | internal use only        | internal use only        |
| 29                                           | CH_29         | internal use only | internal use only    | internal use only   | internal use only   | internal use only   | internal use only  | internal use only        | internal use only        |
| 2A                                           | CH_2A         | pci_det_done_int  | rlos_lo_int          | -rlos_lo_int        | rlos_hi_int         | -rlos_hi_int        | rlos_int           | -rlos_int                |                          |
| 2B                                           | CH_2B         |                   |                      |                     |                     |                     |                    |                          |                          |
| 2C                                           | CH_2C         |                   |                      |                     |                     |                     |                    |                          |                          |

## Per Channel PCS Control Registers Details

**Table 8-64. PCS Control Register CH\_00**

| Bit | Name      | Description                                                                                                                                     | Type | Default |
|-----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 7:4 | Reserved  |                                                                                                                                                 |      |         |
| 3   | rio_mode  | 1 = Selects RapidIO mode<br>0 = Selects other mode (10GbE, 1GbE)                                                                                | RW   | 0       |
| 2   | pcie_mode | 1 = Selects PCI Express mode<br>0 = Selects other mode (RapidIO, 10GbE, 1GbE)                                                                   | RW   | 0       |
| 1   | fc_mode   | 1 = Selects Fibre Channel mode<br>0 = Selects other mode (PCI Express, RapidIO, 10GbE, 1GbE)                                                    | RW   | 0       |
| 0   | uc_mode   | 1 = Selects User Configured (G8B10B, 8BSER only, 10BSER only) mode<br>0 = Selects other mode (Fibre Channel, PCI Express, RapidIO, 10GbE, 1GbE) | RW   | 0       |

**Table 8-65. PCS Control Register CH\_01**

| Bit | Name              | Description                                                                     | Type | Default |
|-----|-------------------|---------------------------------------------------------------------------------|------|---------|
| 7   | word_align_enable | 1 = Enable continuous comma alignment<br>0 = Disable continuous comma alignment | RW   | 0       |
| 6   | Internal use only |                                                                                 |      |         |
| 5   | Internal use only |                                                                                 |      |         |
| 4   | ge_an_enable      | 1 = Enable GbE Auto-negotiation<br>0 = Disable GbE Auto-negotiation             | RW   | 0       |
| 3   | Reserved          |                                                                                 |      |         |
| 2   | Internal use only |                                                                                 |      |         |
| 1   | invert_tx         | 1 = Invert transmit data<br>0 = Don't invert transmit data                      | RW   | 0       |
| 0   | invert_rx         | 1 = Invert received data<br>0 = Don't invert received data                      | RW   | 0       |

**Table 8-66. PCS Control Register CH\_02**

| Bit | Name                  | Description                                                                                                                                                           | Type | Default |
|-----|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 7   | pfifo_clr             | 1 = Clears PFIFO if quad register bit pfifo_clr_sel is set to 1. This signal is or'ed with interface signal pfifo_clr.<br>0 = Normal operation                        | RW   | 0       |
| 6   | pcie_ei_en            | 1 = PCI Express Electrical Idle enabled<br>0 = Normal operation                                                                                                       | RW   | 0       |
| 5:4 | pcs_det_time_sel[1:0] | PCS connection detection time<br>11 = 16us<br>10 = 4us<br>01 = 2us<br>00 = 8us                                                                                        | RW   | 0       |
| 3   | rx_gear_mode          | 1 = Enable 2:1 gearing for receive path on selected channels<br>0 = Disable 2:1 gearing for receive path on selected channels                                         |      |         |
| 2   | tx_gear_mode          | 1 = Enable 2:1 gearing for transmit path on selected channels<br>0 = Disable 2:1 gearing for transmit path on selected channels                                       | RW   | 0       |
| 1   | rx_ch                 | 1 = Received output can be monitored on the test characterization pins. The test characterization mode (bit 6 in PCS controller register QD_03) should be set to '1'. | RW   | 0       |
| 0   | tx_ch                 | 1 = Transmit PCS inputs are sourced from test characterization ports. The test characterization mode should be enabled.                                               | RW   | 0       |

**Table 8-67. PCS Control Register CH\_03**

| Bit | Name              | Description                                                                          | Type | Default |
|-----|-------------------|--------------------------------------------------------------------------------------|------|---------|
| 7   | Reserved          |                                                                                      |      |         |
| 6   | sb_bypass         | 1 = Bypass TX SERDES Bridge<br>0 = Normal operation                                  | RW   | 0       |
| 5   | sb_pfifo_lp       | 1 = Enable parallel loopback from RX to TX via parallel FIFO<br>0 = Normal operation | RW   | 0       |
| 4   | internal use only |                                                                                      |      |         |
| 3   | enc_bypass        | 1 = Bypass 8b10b encoder<br>0 = Normal operation                                     |      |         |
| 2   | internal use only |                                                                                      |      |         |
| 1   | tx_gear_bypass    | 1 = Bypass PCS TX gear<br>0 = Normal operation                                       | RW   | 0       |
| 0   | internal use only |                                                                                      |      |         |

**Table 8-68. PCS Control Register CH\_04**

| Bit | Name           | Description                                                                                    | Type | Default |
|-----|----------------|------------------------------------------------------------------------------------------------|------|---------|
| 7   | lsm_sel        | 1 = Select external RX link state machine<br>0 = Select internal link state machine            | RW   | 0       |
| 6   | ilsm_en        | 1 = Force enabling the RX link state machine<br>0 = Force disabling the RX link state machine. | RW   | 0       |
| 5   | rx_gear_bypass | 1 = Bypass PCS RX gear<br>0 = Normal operation                                                 | RW   | 0       |
| 4   | ctc_bypass     | 1 = Bypass clock tolerance compensation<br>0 = Select Normal data                              | RW   | 0       |
| 3   | dec_bypass     | 1 = Bypass 8b10b decoder<br>0 = Normal operation                                               |      |         |
| 2   | wa_bypass      | 1 = Bypass word alignment<br>0 = Normal operation                                              | RW   | 0       |
| 1   | rx_sb_bypass   | 1 = Bypass RX SERDES bridge<br>0 = Normal operation                                            | RW   | 0       |
| 0   | sb_loopback    | 1 = Enable loopback in the PCS from TX to RX in SERDES bridge<br>0 = Normal operation          | RW   | 0       |

**Table 8-69. PCS Control Register CH\_05**

| Bit | Name             | Description                                                      | Type | Default |
|-----|------------------|------------------------------------------------------------------|------|---------|
| 7:6 | min_ipg_cnt[1:0] | Minimum IPG to enforce                                           | RW   | 11      |
| 5   | match_4_enable   | 1 = Enable four character skip matching (using match 4, 3, 2, 1) | RW   | 0       |
| 4   | match_2_enable   | 1 = Enable two character skip matching (using match 4, 3)        | RW   | 1       |
| 3:0 | Reserved         |                                                                  |      |         |

**Table 8-70. PCS Control Register CH\_06**

| Bit | Name            | Description                                                 | Type | Default |
|-----|-----------------|-------------------------------------------------------------|------|---------|
| 7:0 | cc_match_1[7:0] | Lower bits of user-defined clock compensator skip pattern 1 | RW   | 8'h00   |

**Table 8-71. PCS Control Register CH\_07**

| Bit | Name            | Description                                                 | Type | Default |
|-----|-----------------|-------------------------------------------------------------|------|---------|
| 7:0 | cc_match_2[7:0] | Lower bits of user-defined clock compensator skip pattern 2 | RW   | 8'h00   |

**Table 8-72. PCS Control Register CH\_08**

| Bit | Name            | Description                                                 | Type | Default |
|-----|-----------------|-------------------------------------------------------------|------|---------|
| 7:0 | cc_match_3[7:0] | Lower bits of user-defined clock compensator skip pattern 3 | RW   | 8'hBC   |

**Table 8-73. PCS Control Register CH\_09**

| Bit | Name            | Description                                                 | Type | Default |
|-----|-----------------|-------------------------------------------------------------|------|---------|
| 7:0 | cc_match_4[7:0] | Lower bits of user-defined clock compensator skip pattern 4 | RW   | 8'h50   |

**Table 8-74. PCS Control Register CH\_0A**

| Bit | Name            | Description                                                                                             | Type | Default |
|-----|-----------------|---------------------------------------------------------------------------------------------------------|------|---------|
| 7:6 | cc_match_4[9:8] | Upper bits of user-defined clock compensator skip pattern 4<br>[9] = Disparity error<br>[8] = K control | RW   | 2'b01   |
| 5:4 | cc_match_3[9:8] | Upper bits of user-defined clock compensator skip pattern 3<br>[9] = Disparity error<br>[8] = K control | RW   | 2'b01   |
| 3:2 | cc_match_2[9:8] | Upper bits of user-defined clock compensator skip pattern 2<br>[9] = Disparity error<br>[8] = K control | RW   | 2'b00   |
| 1:0 | cc_match_1[9:8] | Upper bits of user-defined clock compensator skip pattern 1<br>[9] = Disparity error<br>[8] = K control | RW   | 2'b00   |

**Table 8-75. PCS Control Register CH\_0B**

| Bit | Name                | Description                           | Type | Default |
|-----|---------------------|---------------------------------------|------|---------|
| 7:0 | udf_comma_mask[7:0] | Lower bits of user-defined comma mask | RW   | 8'hFF   |

**Table 8-76. PCS Control Register CH\_0C**

| Bit | Name             | Description                                    | Type | Default |
|-----|------------------|------------------------------------------------|------|---------|
| 7:0 | udf_comma_a[7:0] | Lower bits of user-defined comma character 'a' | RW   | 8'h83   |

**Table 8-77. PCS Control Register CH\_0D**

| Bit | Name             | Description                                    | Type | Default |
|-----|------------------|------------------------------------------------|------|---------|
| 7:0 | udf_comma_b[7:0] | Lower bits of user-defined comma character 'b' | RW   | 8'h7C   |

**Table 8-78. PCS Control Register CH\_0E**

| Bit | Name                | Description                                    | Type | Default            |
|-----|---------------------|------------------------------------------------|------|--------------------|
| 7:6 | udf_comma_a[9:8]    | Upper bits of user-defined comma character 'a' | RW   | 2'b10              |
| 5:4 | udf_comma_b[9:8]    | Upper bits of user-defined comma character 'b' | RW   | 2'b01              |
| 3:2 | udf_comma_mask[9:8] | Upper bits of user-defined comma mask          | RW   | 2'b11 <sup>1</sup> |
| 1:0 | Reserved            |                                                |      |                    |

1. In most applications, K28.5 is used as the comma character. The default value of the mask is 1111111111. In G8B10B mode, any comma can be used so the mask will be 1111111100 to detect any of the three comma characters, K28.1, 28.5, 28.7.

**Table 8-79. PCS Interrupt Control Register CH\_0F**

| Bit | Name                     | Description                                                                   | Type | Default |
|-----|--------------------------|-------------------------------------------------------------------------------|------|---------|
| 7:4 | Reserved                 |                                                                               |      |         |
| 3   | cc_underrun_int_ctl      | 1 = Enable interrupt for cc_underrun<br>0 = Disable interrupt for cc_underrun | RW   | 0       |
| 2   | cc_overrun_int_ctl       | 1 = Enable interrupt for cc_overrun<br>0 = Disable interrupt for cc_overrun   | RW   | 0       |
| 1   | fb_rx_fifo_error_int_ctl | 1 = Enable interrupt on empty/full condition in the receive FPGA bridge FIFO  | RW   | 0       |
| 0   | fb_tx_fifo_error_int_ctl | 1 = Enable interrupt on empty/full condition in the transmit FPGA bridge FIFO | RW   | 0       |

### Per Channel SERDES Control Registers Details

Unless indicated, all channels must be reset after writing any SERDES Control Register.

**Table 8-80. SERDES Control Register CH\_10**

| Bit | Name               | Description                                                                                                                                            | Type | Default |
|-----|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 7   | REQ_EN             | 1= Enable receiver equalization<br>0 = Disable receiver equalization                                                                                   | RW   | 0       |
| 6   | REQ_LVL_SET        | Level setting for equalization<br>1 = Long-reach equalization<br>0 = Mid-length route equalization                                                     | RW   | 0       |
| 5   | RCV_DCC_EN         | 1 = Enable receiver DC coupling<br>0 = Enable receiver AC coupling                                                                                     | RW   | 0       |
| 4:3 | RATE_SEL[1:0]      | Equalizer pole position select:<br>00 = HIGH Equalization<br>01 = MED Equalization<br>10 = LOW Equalization<br>11 = Reserved                           | RW   | 00      |
| 2:0 | RX_DCO_CK_DIV[2:0] | VCO output frequency select:<br>00x = Divide by 1<br>01x = Divide by 2 100 = divide by 4<br>101 = Divide by 8 110 = divide by 16<br>111 = Divide by 32 | RW   | 000     |

**Table 8-81. SERDES Control Register CH\_11**

| Bit | Name          | Description                                                                                                                                                                             | Type | Default |
|-----|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 7:4 | LB_CTL[3:0]   | Loop back control:<br>[3] = internal use only<br>[2] = internal use only<br>[1] = slb_eq2t_en, serial LB from equalizer to driver enable<br>[0] = slb_t2r_en, serial tx to rx LB enable | R/W  | 4'h0    |
| 3:2 | Reserved      |                                                                                                                                                                                         |      |         |
| 1:0 | RTERM_RX[1:0] | 00 = HiZ, 01 = 50 Ohm, 10 = 60 Ohm, 11 = 75 Ohm                                                                                                                                         | R/W  | 2'b01   |

**Table 8-82. SERDES Control Register CH\_12**

| Bit | Name              | Description                                                                                                                                                                                                                                                            | Type | Default  |
|-----|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 7:5 | TDRV_AMP[2:0]     | CML driver amplitude setting:<br>000 = 0%<br>001 = +8%<br>010 = +11%<br>011 = +20%<br>100 = -17%<br>101 = -12%<br>110 = -10%<br>111 = -6%                                                                                                                              | RW   | 000      |
| 4:0 | TDRV_PRE_SET[4:0] | TX drive pre-emphasis level setting [2:0]<br>000 = 0%<br>001 = 5%<br>010 = 12%<br>011 = 18%<br>100 = 25%<br>101 = 33%<br>110 = 40%<br>111 = 48%<br>[4:3] Fine tune (added to any value chosen by bits[2:0] settings above)<br>00 = 0%<br>01 = 2%<br>10 = 3%<br>11 = 5% | RW   | 5'b00000 |

**Table 8-83. SERDES Control Register CH\_13**

| Bit | Name                 | Description                                                                                        | Type | Default |
|-----|----------------------|----------------------------------------------------------------------------------------------------|------|---------|
| 7   | ldr_core2tx_sel      | 1 = Select low speed serial data from FPGA core                                                    | RW   | 0       |
| 6   | pden_sel             | Reserved                                                                                           | RW   | 0       |
| 5:4 | Reserved             |                                                                                                    |      |         |
| 3   | TDRV_AMP_BOOST       | TX Drive amplitude boost<br>0 = 0%<br>1 = -25%                                                     | RW   | 0       |
| 2:0 | TDRV_DRVCUR_SET[2:0] | 000 = 48%<br>001 = 30%<br>010 = 60%<br>011 = 50%<br>100 = 0%<br>101 = -7%<br>110 = 19%<br>111 = 8% | RW   | 100     |

**Table 8-84. SERDES Control Register CH\_14**

| Bit | Name               | Description                                                                                                                                         | Type | Default |
|-----|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 7   | TX_DIV11_SEL       | 0 = Full-rate selection for transmit (high definition SMPTE)<br>1 = Divide-by-11 selection for transmit (standard definition SMPTE)                 | RW   | 0       |
| 6:5 | TDRV_DAT_SEL [1:0] | Driver output select:<br>00 = Data from Serializer muxed to driver (normal operation)<br>11 = Serial LB from equalizer to driver if slb_eq2t_en='1' | RW   | 00      |
| 4   | TDRV_PRE_EN        | 1 = TX driver pre-emphasis enable<br>0 = TX driver pre-emphasis disable                                                                             | RW   | 0       |
| 3:2 | RTERM_TX[1:0]      | TX resistor termination select. Disable when PCI Express mode is selected.<br>0x = 5K OHm<br>10 = 50 Ohm<br>11 = 75 OHm                             | RW   | 10      |
| 1   | RATE_MODE_TX       | 0 = Full-rate selection for transmit<br>1 = Half-rate selection for transmit                                                                        | RW   | 0       |
| 0   | tpwrup             | 0 = Power-down transmit channel<br>1 = Power-up transmit channel                                                                                    | RW   | 0       |

**Table 8-85. SERDES Control Register CH\_15**

| Bit | Name              | Description                                                                                                                                       | Type | Default |
|-----|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 7   | Internal use only |                                                                                                                                                   |      |         |
| 6   | Internal use only |                                                                                                                                                   |      |         |
| 5   | Internal use only |                                                                                                                                                   |      |         |
| 4   | Internal use only |                                                                                                                                                   |      |         |
| 3   | ldr_rx2core_en    | 1 = Enables boundary scan input path for routing the high-speed receive inputs to a lower-speed SERDES in the FPGA (for out-of-band applications) | RW   | 0       |
| 2   | rx_refck_sel      | RX CDR reference clock select<br>0 = REFCLKP/N<br>1 = FPGA core                                                                                   | RW   | 0       |
| 1   | RATE_MODE_RX      | 0 = Full-rate selection for receive<br>1 = Half-rate selection for receive                                                                        | RW   | 0       |
| 0   | rpwrup            | 0 = Power-down receive channel<br>1 = Power-up receive channel                                                                                    | RW   | 0       |

**Table 8-86. SERDES Control Register CH\_16**

| Bit | Name           | Description                                                                                                                       | Type | Default |
|-----|----------------|-----------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 7   | RX_DIV11_SEL   | 0 = Full-rate selection for receive (high-definition SMPTE)<br>1 = Divide by 11 selection for receive (standard-definition SMPTE) | RW   | 0       |
| 6   | rlos_sel       | 1 = Select rlos_hi<br>0 = Select rlos_lo                                                                                          | RW   | 0       |
| 5:3 | Reserved       |                                                                                                                                   | RW   | 000     |
| 2:0 | RLOS_LSET[2:0] | LOS detector reference current adjustment for smaller swing<br>000 = default<br>010 = +15%<br>011 = +25%                          | RW   | 010     |

**Table 8-87. SERDES Interrupt Control Register CH\_17**

| Bit | Name                 | Description                                                                                                           | Type | Default |
|-----|----------------------|-----------------------------------------------------------------------------------------------------------------------|------|---------|
| 7   | Reserved             |                                                                                                                       |      |         |
| 6   | pci_det_done_int_ctl | 1 = Enable interrupt for detection of far-end receiver for PCI Express                                                | RW   | 0       |
| 5   | rlos_lo_int_ctl      | 1 = Enable interrupt for RX loss of signal when input levels fall below the programmed LOW threshold (using rlos_set) | RW   | 0       |
| 4   | -rlos_lo_int_ctl     | 1 = Enable interrupt for RX loss of signal when input level meets or is greater than programmed LOW threshold         | RW   | 0       |
| 3   | Reserved             |                                                                                                                       |      |         |
| 2   | Reserved             |                                                                                                                       |      |         |
| 1   | rlol_int_ctl         | 1 = Enable interrupt for receiver loss of lock                                                                        | RW   | 0       |
| 0   | -rlol_int_ctl        | 1 = Enable interrupt when receiver recovers from loss of lock                                                         | RW   | 0       |

## Per Channel Reset and Clock Control Registers Details

**Table 8-88. Reset and Clock Control Register CH\_18**

| Bit | Name              | Description                               | Type | Default |
|-----|-------------------|-------------------------------------------|------|---------|
| 7   | Internal use only |                                           |      |         |
| 6   | Internal use only |                                           |      |         |
| 5:3 | Reserved          |                                           |      |         |
| 2   | rrst              | 1 = RX reset                              | RW   | 0       |
| 1   | lane_rx_rst       | 1 = Assert reset signal to receive logic  | RW   | 0       |
| 0   | lane_tx_rst       | 1 = Assert reset signal to transmit logic | RW   | 0       |

**Table 8-89. Reset and Clock Control Register CH\_19**

| Bit | Name          | Description          | Type | Default |
|-----|---------------|----------------------|------|---------|
| 7:5 | Reserved      |                      |      |         |
| 4   | tx_f_clk_dis  | 1 = Disable tx_f_clk | RW   | 0       |
| 3   | tx_h_clk_en   | 1 = Enable tx_h_clk  | RW   | 0       |
| 2   | rx_f_clk_dis  | 1 = Disable rx_f_clk | RW   | 0       |
| 1   | rx_h_clk_en   | 1 = Enable rx_h_clk  | RW   | 0       |
| 0   | sel_sd_rx_clk | 1 = Select sd_rx_clk | RW   | 0       |

## Per Channel PCS Status Registers Details

**Table 8-90. PCS Status Register CH\_20**

| Bit | Name             | Description                                                        | Type | Int? |
|-----|------------------|--------------------------------------------------------------------|------|------|
| 7:5 | Reserved         |                                                                    |      |      |
| 4   | pfifo_error      | 1 = Parallel FIFO error<br>0 = No parallel FIFO error              | RO   | Yes  |
| 3   | cc_underrun      | 1 = CTC FIFO underrun<br>0 = CTC FIFO not underrun                 | RO   | Yes  |
| 2   | cc_overrun       | 1 = CTC FIFO overrun<br>0 = CTC FIFO not overrun                   | RO   | Yes  |
| 1   | fb_rx_fifo_error | 1 = FPGA bridge (FB) RX FIFO overrun<br>0 = FB RX FIFO not overrun | RO   | Yes  |
| 0   | fb_tx_fifo_error | 1 = FPGA bridge (FB) TX FIFO overrun<br>0 = FB TX FIFO not overrun | RO   | Yes  |

**Table 8-91. PCS Status Register CH\_21**

| Bit | Name                     | Description                                                                      | Type     | Int? |
|-----|--------------------------|----------------------------------------------------------------------------------|----------|------|
| 7:0 | prbs_errors <sup>1</sup> | Count of the number of PRBS errors. Clears to zero on read. Sticks at flip-flop. | RO<br>CR | No   |

1. Built-in PRBS generator and checker are for internal use only.

**Table 8-92. PCS Status Register CH\_22**

| Bit | Name           | Description         | Type | Int? |
|-----|----------------|---------------------|------|------|
| 7:4 | Reserved       |                     |      |      |
| 3:0 | wa_offset[3:0] | Word aligner offset | RO   | No   |

**Table 8-93. PCS Interrupt Status Register CH\_23**

| Bit | Name                 | Description                                                                                    | Type     | Int? |
|-----|----------------------|------------------------------------------------------------------------------------------------|----------|------|
| 7:4 | Reserved             |                                                                                                |          |      |
| 3   | cc_underrun_int      | 1 = Interrupt generated on cc_underrun<br>0 = Interrupt not generated on cc_underrun           | RO<br>CR | Yes  |
| 2   | cc_overrun_int       | 1 = Interrupt generated on cc_overrun<br>0 = Interrupt not generated on cc_overrun             | RO<br>CR | Yes  |
| 1   | fb_rx_fifo_error_int | 1 = Interrupt generated on fb_rx_fifo_error<br>0 = Interrupt not generated on fb_rx_fifo_error | RO<br>CR | Yes  |
| 0   | fb_tx_fifo_error_int | 1 = Interrupt generated on fb_tx_fifo_error<br>0 = Interrupt not generated on fb_tx_fifo_error | RO<br>CR | Yes  |

**Table 8-94. PCS Status Register CH\_24**

| Bit | Name               | Description                                                     | Type | Int? |
|-----|--------------------|-----------------------------------------------------------------|------|------|
| 7   | Reserved           |                                                                 |      |      |
| 6   | ffs_ls_sync_status | 1 = Sync in the link state machine<br>0 = Not sync in the LSM   | RO   | No   |
| 5   | fb_rxrst_o         | 1 = FPGA bridge RX normal operation<br>0 = FPGA bridge RX reset | RO   | No   |
| 4   | fb_txrst_o         | 1 = FPGA bridge TX normal operation<br>0 = FPGA bridge TX reset | RO   | No   |
| 3   | Reserved           |                                                                 |      |      |
| 2   | Reserved           |                                                                 |      |      |
| 1   | cc_re_o            | 1 = CTC FIFO read enable<br>0 = CTC FIFO read disable           | RO   | No   |
| 0   | cc_we_o            | 1 = CTC FIFO write enable<br>0 = CTC FIFO write disable         | RO   | No   |

**Table 8-95. PCS Status Register CH\_25**

| Bit | Name     | Description | Type | Int? |
|-----|----------|-------------|------|------|
| 7   | Reserved |             |      |      |

## Per Channel SERDES Status Registers Details

**Table 8-96. SERDES Status Register CH\_26**

| Bit | Name         | Description                                                                                                                          | Type     | Int? |
|-----|--------------|--------------------------------------------------------------------------------------------------------------------------------------|----------|------|
| 7   | Reserved     |                                                                                                                                      |          |      |
| 6   | pci_det_done | 1 = Receiver detection process not completed by SERDES transmitter<br>0 = Receiver detection process completed by SERDES transmitter | RO<br>CR | Yes  |
| 5   | rlos_lo      | 1 = Indicates that the input signal detected by receiver is below the programmed LOW threshold                                       | RO<br>CR | Yes  |
| 4   | -rlos_lo     | 1 = Indicates that the input signal detected by receiver is greater or equal to the programmed LOW threshold                         | RO<br>CR | Yes  |
| 3   | Reserved     |                                                                                                                                      | RO<br>CR | Yes  |
| 2   | Reserved     |                                                                                                                                      | RO<br>CR | Yes  |
| 1   | rlol         | 1 = Indicates CDR loss of lock to data. CDR is locked to reference clock                                                             | RO       | Yes  |
| 0   | -rlol        | 1 = Indicates that CDR has locked to data                                                                                            | RO       | Yes  |

**Table 8-97. SERDES Status Register CH\_27**

| Bit | Name              | Description                                                                                                                                            | Type | Int? |
|-----|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|
| 7   | Internal use only |                                                                                                                                                        |      |      |
| 6   | Internal use only |                                                                                                                                                        |      |      |
| 5   | Internal use only |                                                                                                                                                        |      |      |
| 4   | Internal use only |                                                                                                                                                        |      |      |
| 3:2 | Reserved          |                                                                                                                                                        |      |      |
| 1   | cdr_trained       | 1 = Indicates CDR training is done                                                                                                                     | RO   | No   |
| 0   | pci_connect       | 1 = Receiver detected by SERDES transmitter (at the transmitter device)<br>0 = Receiver not detected by SERDES transmitter (at the transmitter device) | RO   | No   |

**Table 8-98. SERDES Status Register CH\_28**

| Bit | Name              | Description | Type | Int? |
|-----|-------------------|-------------|------|------|
| 7:0 | Internal use only |             |      |      |

**Table 8-99. SERDES Status Register CH\_29**

| Bit | Name              | Description | Type | Int? |
|-----|-------------------|-------------|------|------|
| 7:0 | Internal use only |             |      |      |

**Table 8-100. SERDES Interrupt Status Register CH\_2A**

| Bit | Name             | Description                              | Type  | Int? |
|-----|------------------|------------------------------------------|-------|------|
| 7   | Reserved         |                                          |       |      |
| 6   | pci_det_done_int | 1 = Interrupt generated for pci_det_done | RO CR | Yes  |
| 5   | rlos_lo_int      | 1 = Interrupt generated for rlos_lo      | RO CR | Yes  |
| 4   | -rlos_lo_int     | 1 = Interrupt generated for -rlos_lo     | RO CR | Yes  |
| 3   | Reserved         |                                          | RO CR | Yes  |
| 2   | Reserved         |                                          | RO CR | Yes  |
| 1   | rlol_int         | 1 = Interrupt generated for rlol         | RO CR | Yes  |
| 0   | -rlol_int        | 1 = Interrupt generated for -rlol        | RO CR | Yes  |

**Table 8-101. PCS Status Register CH\_2B**

| Bit | Name     | Description | Type | Int? |
|-----|----------|-------------|------|------|
| 7   | Reserved |             |      |      |

**Table 8-102. PCS Status Register CH\_2C**

| Bit | Name     | Description | Type | Int? |
|-----|----------|-------------|------|------|
| 7   | Reserved |             |      |      |

## Appendix B. Register Settings for Various Standards

### Per Channel Register Settings for Various Standards

*Table 8-103. Per Channel Register Settings for Various Standards*

| Character  | 1GbE                     | 10GbE   | 1GFC                          | PCI-Ex                        | RapidIO   |
|------------|--------------------------|---------|-------------------------------|-------------------------------|-----------|
| K23.7 (F7) | Carrier extend           |         |                               | PAD                           |           |
| K27.7 (FB) | SOP                      | ST      |                               | Start TLP                     | A (align) |
| K28.0 (1C) |                          | SKIP R  |                               | SKIP                          | SC        |
| K28.1 (3C) |                          |         |                               | FTS                           |           |
| K28.2 (5C) |                          | SoS     |                               | Start DLP                     |           |
| K28.3 (7C) |                          | ALIGN A |                               | IDLE                          | PD        |
| K28.4 (9C) |                          | SEQ     |                               |                               |           |
| K28.5 (BC) | +D5.6 or D16.2<br>= IDLE | SYNC K  | +D21.4+D21.5<br>+D21.5 = IDLE | COMMA<br>(used for alignment) | K         |
| K28.6 (DC) |                          |         |                               |                               |           |
| K28.7 (FC) |                          |         |                               |                               | R (skip)  |
| K29.7 (FD) | EOP                      | T       |                               | END                           |           |
| K30.7 (FE) | ERR                      | ERR     |                               | END BAD                       |           |

### Per Quad Register Settings for Various Standards

*Table 8-104. Per Quad Register Settings for Various Standards*

| Register      | 1GbE   | 10GbE  | 1G, 2G FC | PCI-Ex 1x | PCI-Ex 4x | RapidIO 1x | RapidIO 4x |
|---------------|--------|--------|-----------|-----------|-----------|------------|------------|
| comma_a_lo    | hex 03 | hex 03 | hex 03    | hex 03    | hex 03    | hex 03     | hex 03     |
| comma_b_lo    | hex FC | hex FC | hex FC    | hex FC    | hex FC    | hex FC     | hex FC     |
| comma_mask_lo | hex 7F | hex 7F | hex 7F    | hex 7F    | hex 7F    | hex 7F     | hex 7F     |

## Appendix C. Attribute Cross Reference Table

Table 8-105. Attribute Cross-Reference Table

| Independent Attribute Name | Dependent Attribute Name                                     | Attribute Value                                                                                                                                                                                                                                                             | Register Map                                          |
|----------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| QUAD_MODE                  | {Qn_REFCK_NQ_EN} <sup>8</sup>                                | SINGLE : {0}<br>MASTER : {1}<br>SLAVE : {1}<br>SLAVE_END : {0}                                                                                                                                                                                                              | {QD_0b[2]}                                            |
| CHn_PROTOCOL               | {10G_MODE,<br>CHn_PROT_MODE,<br>CHn_RX_DET,<br>CHn_GE_AN_EN} | GIGE : {0,<br>0000,00,1}<br>FC : {0,0010,00,0}<br>XAUI : {1,0000,00,0}<br>SRIO : {0,1000,00,0}<br>PCIE : {0,0100,00,0}<br>SDI : {0,0001,00,0}<br>G8B10B : {0,0001,00,0}<br>10BSER : {0,0001,00,0}<br>8BSER : {0,0001,00,0}<br>CPRI : {0,0001,00,0}<br>OBSAI : {0,0001,00,0} | {QD_00[4],<br>CH_00[3:0],<br>CH_02[5:4],<br>CH_01[4]} |
| CHn_MODE                   | {CHn_TXPWDNB,<br>CHn_RXPWDNB}                                | RXTX : {11}<br>RXONLY : {01}<br>TXONLY : {10}<br>DISABLED : {00}                                                                                                                                                                                                            | {CH_14[0],<br>CH_15[0]}                               |
| TX_DATARATE_RANGE          | {PLL_DIV}                                                    | LOWLOW : {110}<br>LOW : {101}<br>MEDLOW : {100}<br>MED : {010}<br>MEDHIGH : {010}<br>HIGH : {000}                                                                                                                                                                           | {QD_0D[2:0]}                                          |
| CHn_RX_DATARATE_RANGE      | {CHn_CDR_DIV}                                                | LOWLOW : {110}<br>LOW : {101}<br>MEDLOW : {100}<br>MED : {010}<br>MEDHIGH : {000}<br>HIGH : {000}                                                                                                                                                                           | {CH_10[2:0]}                                          |
| REFCK_MULT                 | {REFCK25X,<br>REFCK_MODE}                                    | 8X : {0,11}<br>10X : {0,01}<br>16X : {0,10}<br>20X : {0,00}<br>25X : {1,00}                                                                                                                                                                                                 | {QD_0b[7],<br>QD_0b[1:0]}                             |
| CHn_RX_DATA_RATE           | {CHn_RX_RATE_MODE,<br>CHn_RX_DIV11}                          | FULL : {00}<br>DIV2 : {10}<br>DIV11 : {01}                                                                                                                                                                                                                                  | {CH_15[1],<br>CH_16[7]}                               |
| CHn_TX_DATA_RATE           | {CHn_TX_RATE_MODE,<br>CHn_TX_DIV11}                          | FULL : {00}<br>DIV2 : {10}<br>DIV11 : {01}                                                                                                                                                                                                                                  | {CH_14[1],<br>CH_14[7]}                               |
| CHn_TX_DATA_WIDTH          | {CHn_TXCLKF,<br>CHn_TXCLKH,<br>CHn_TX_GEAR}                  | 8 : {0,1,0}<br>10 : {0,1,0}<br>16 : {0,1,1}<br>20 : {0,1,1}                                                                                                                                                                                                                 | {CH_19[4],<br>CH_19[3],<br>CH_02[2]}                  |
| CHn_RX_DATA_WIDTH          | {CHn_RXCLKF,<br>CHn_RXCLKH,<br>CHn_RX_GEAR}                  | 8 : {0,0,0}<br>10 : {0,0,0}<br>16 : {1,1,1}<br>20 : {1,1,1}                                                                                                                                                                                                                 | {CH_19[2],<br>CH_19[1],<br>CH_02[3]}                  |
| CHn_TX_FIFO                |                                                              | DISABLED : {1}<br>ENABLED : {0}                                                                                                                                                                                                                                             | {CH_03[1]}                                            |
| CHn_RX_FIFO                |                                                              | DISABLED : {1}<br>ENABLED : {0}                                                                                                                                                                                                                                             | {CH_04[5]}                                            |

**Table 8-105. Attribute Cross-Reference Table (Continued)**

| Independent Attribute Name                     | Dependent Attribute Name                                                                               | Attribute Value                                                                                                                                                    | Register Map                                                         |
|------------------------------------------------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| PLL_SRC                                        | {TXREFCK_NQ_SEL,<br>TXREFCK_SEL}                                                                       | REFCLK_EXT :{0,0}<br>REFCLK_CORE:{0,1}<br>REFCLK_NQ :{1,0} <sup>8</sup>                                                                                            | {QD_0B[3],<br>QD_0A[5]}                                              |
| CHn_CDR_SRC                                    | {RXREFCK_NQ_SEL,<br>CHn_RXREFCK_SEL,<br>CHn_TRAIN_EN,<br>CHn_TRAIN_DIV }                               | REFCLK_EXT :{0,0,0,0}<br>REFCLK_CORE:{0,1,0,0}<br>REFCLK_NQ :{1,0,0,0} <sup>8</sup><br>TRAIN_DIV4 :{0,0,1,0} <sup>8</sup><br>TRAIN_DIV8 :{0,0,1,1} <sup>8</sup>    | {QD_0B[4],<br>CH_15[2],<br>CH_15[7],<br>CH_15[6]}                    |
| CHn_TDRV <sup>7</sup>                          | {CHn_TDRV_AMP,<br>CHn_TDRV_DRVCUR_SET,<br>CHn_TDRV_AMP_BOOST}                                          | -4: {110,100,1}<br>-3: {100,101,0}<br>-2: {100,100,0}<br>-1: {101,100,0}<br>0: {000,100,0}<br>1: {001,100,0}<br>2: {011,100,0}<br>3: {100,000,0}<br>4: {000,000,0} | {CH_12[7:5],<br>CH_13[2:0],<br>CH_13[3]}                             |
| CHn_TDRV<br>(for PCI Express Protocol<br>only) | {CHn_TDRV_AMP,<br>CHn_TDRV_DRVCUR_SET,<br>CHn_TDRV_AMP_BOOST,<br>CHn_TDRV_PRE_EN,<br>CHn_TDRV_PRE_SET} | 2: {100,000,0,1,00101}                                                                                                                                             | {CH_12[7:5],<br>CH_13[2:0],<br>CH_13[3],<br>CH_14[4],<br>CH_12[4:0]} |
| CHn_TX_PRE                                     | {CHn_TDRV_PRE_EN,<br>CHn_TDRV_PRE_SET}                                                                 | DISABLED:{0,00000}<br>0:{1,00000}<br>1:{1,00001}<br>2:{1,00010}<br>3:{1,00011}<br>4:{1,00100}<br>5:{1,00101}<br>6:{1,00110}<br>7:{1,00111}                         | {CH_14[4],<br>CH_12[4:0]}                                            |
| CHn_RTERM_TX                                   |                                                                                                        | 50:{10}<br>75:{11}<br>5K:{0X}                                                                                                                                      | {CH_14[3:2]}                                                         |
| CHn_RX_EQ                                      | {CHn_REQ_EN,<br>CHn_REQ_LVL_SET,<br>CHn_RATE_SEL}                                                      | DISABLED :{0,0,00}<br>MID_LOW :{1,0,10}<br>MID_MED :{1,0,01}<br>MID_HIGH :{1,0,00}<br>LONG_LOW :{1,1,10}<br>LONG_MED :{1,1,01}<br>LONG_HIGH:{1,1,00}               | {CH_10[7],<br>CH_10[6],<br>CH_10[4:3]}                               |
| CHn_RTERM_RX                                   | {CHn_RX_RTERM}                                                                                         | 50 :{01}<br>60 :{10}<br>75 :{11}<br>HIGH:{00}                                                                                                                      | {CH_11[1:0]}                                                         |
| CHn_RX_DCC                                     |                                                                                                        | AC:{0}<br>DC:{1}                                                                                                                                                   | {CH_10[5]}                                                           |
| CHn_LOS_THRESHOLD_LO <sup>1</sup>              | {CHn_RLOS_E}                                                                                           | 0:{0000}<br>1:{0001}<br>2:{0010}<br>3:{0011}<br>4:{0100}<br>5:{0101}<br>6:{0110}<br>7:{0111}                                                                       | {mc1_ser_ctl_chN[75],<br>CH_16[2:0]}                                 |
| PLL_TERM                                       |                                                                                                        | 50:{1}<br>2K:{0}                                                                                                                                                   | {QD_0A[3]}                                                           |

**Table 8-105. Attribute Cross-Reference Table (Continued)**

| Independent Attribute Name | Dependent Attribute Name            | Attribute Value                      | Register Map                 |
|----------------------------|-------------------------------------|--------------------------------------|------------------------------|
| PLL_DCC                    |                                     | AC:{0}<br>DC:{1}                     | {QD_0A[4]}                   |
| PLL_LOL_SET                |                                     | 0:{00}<br>1:{01}<br>2:{10}<br>3:{11} | {QD_0D[4:3]}                 |
| CHn_TX_SB                  | {CHn_TXPOL,<br>CHn_TXSBBYP}         | DISABLED:{0,0}<br>ENABLED :{1,0}     | {CH_01[1],<br>CH_03[6]}      |
| CHn_RX_SB                  | {CHn_RXPOL,<br>CHn_RXSBBYP}         | DISABLED:{0,0}<br>ENABLED :{1,0}     | {CH_01[0],<br>CH_04[1]}      |
| CHn_TX_8B10B               |                                     | ENABLED :{0}<br>DISABLED:{1}         | {CH_03[3]}                   |
| CHn_RX_8B10B               |                                     | ENABLED :{0}<br>DISABLED:{1}         | {CH_04[3]}                   |
| CHn_COMMA_A                |                                     | Note 2                               | {QD_0C[0:7],<br>QD_0E[6:7]}  |
| CHn_COMMA_B                |                                     | Note 2                               | {QD_0D[0:7],<br>QD_0E[4:5]}  |
| CHn_COMMA_M                |                                     | Note 2                               | {QD_0B[0:7],<br>QD_0E[2:3]}  |
| CHn_RXWA                   |                                     | DISABLED:{1}<br>ENABLED :{0}         | {CH_04[2]}                   |
| CHn_ILSM                   |                                     | DISABLED:{1}<br>ENABLED :{0}         | {CH_04[7]}                   |
| CHn_CTC                    | {CHn_RXRECCLK}                      | ENABLED :{0,0}<br>DISABLED{1,1}      | {CH_19[0] ,<br>CH_04[4]}     |
| CHn_CC_MATCH1              |                                     | Note 2                               | {QD_0A[1:0],<br>CH_06[7:0]}  |
| CHn_CC_MATCH2              |                                     | Note 2                               | {QD_0A[3:2] ,<br>CH_07[7:0]} |
| CHn_CC_MATCH3              |                                     | Note 2                               | {QD_0A[5:4] ,<br>CH_08[7:0]} |
| CHn_CC_MATCH4              |                                     | Note 2                               | {QD_0A[7:6] ,<br>QD_09[7:0]} |
| CHn_CC_MATCH_MODE          | {CHn_MATCH_2_EN,<br>CHn_MATCH_4_EN} | 1:{0,0}<br>2:{1,0}<br>4:{0,1}        | {CH_05[4] ,<br>CH_05[5]}     |
| CHn_CC_MIN_IPG             |                                     | 0:{00}<br>1:{01}<br>2:{10}<br>3:{11} | {CH_05[7:6]}                 |

Table 8-105. Attribute Cross-Reference Table (Continued)

| Independent Attribute Name | Dependent Attribute Name                                                                                                                                                                                                  | Attribute Value                                                                                                                                                                                              | Register Map                                                                                                                                                               |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CCHMARK                    |                                                                                                                                                                                                                           | 0 :{0000}<br>1 :{0001}<br>2 :{0010}<br>3 :{0011}<br>4 :{0100}<br>5 :{0101}<br>6 :{0110}<br>7 :{0111}<br>8 :{1000}<br>9 :{1001}<br>10:{1010}<br>11:{1011}<br>12:{1100}<br>13:{1101}<br>14:{1110}<br>15:{1111} | {QD_02[7:4]}                                                                                                                                                               |
| CCLMARK                    |                                                                                                                                                                                                                           | 0 :{0000}<br>1 :{0001}<br>2 :{0010}<br>3 :{0011}<br>4 :{0100}<br>5 :{0101}<br>6 :{0110}<br>7 :{0111}<br>8 :{1000}<br>9 :{1001}<br>10:{1010}<br>11:{1011}<br>12:{1100}<br>13:{1101}<br>14:{1110}<br>15:{1111} | {QD_02[3:0]}                                                                                                                                                               |
| CHn_SSLB                   |                                                                                                                                                                                                                           | DISABLED :{0000, 00}<br>ENABLED_EQ2T:{0010, 11}<br>ENABLED_T2R :{0001, 00}                                                                                                                                   | {CH_11[7:4],<br>CH_14[6:5]}                                                                                                                                                |
| CHn_SPLBPORTS <sup>4</sup> | {PFIFO_CLR_SEL,<br>CHn_SB_PFIFO_LP}                                                                                                                                                                                       | DISABLED:{0,0}<br>ENABLED :{1,1}                                                                                                                                                                             | {QD_03[2],<br>CH_03[5]}                                                                                                                                                    |
| QD_REFCK2CORE              |                                                                                                                                                                                                                           | DISABLED:{0}<br>ENABLED :{1}                                                                                                                                                                                 | {QD_0a[1]}                                                                                                                                                                 |
| INT_ALL                    | {PLOLINT,<br>PLOLNINT,<br>CHn_PCIDETINT,<br>CHn_RLOSSINT,<br>CHn_RLOSSNINT,<br>CHn_RLOLINT,<br>CHn_RLOLNINT,<br>CHn_LSSYNCINT,<br>CHn_LSSYNCNINT,<br>CHn_TXFIFOINT,<br>CHn_RXFIFOINT,<br>CHn_CCORUNINT,<br>CHn_CCURUNINT} | DISABLED:{<br>0,0,0,0,0,0,0,0,0000,0000,<br>0,0,0,0}<br>ENABLED:{<br>1,1,1,1,1,1,1,1,1111,1111,<br>1,1,1,1}                                                                                                  | {QD_0F[7],<br>QD_0F[6],<br>CH_17[6],<br>CH_17[5],<br>CH_17[4],<br>CH_17[1],<br>CH_17[0],<br>QD_09[7:4],<br>QD_09[3:0],<br>CH_0F[0],<br>CH_0F[1],<br>CH_0F[2],<br>CH_0F[3]} |
| CHn_LDR                    | {CHn_LDR_RX_EN,<br>CHn_LDR_TX_SEL}                                                                                                                                                                                        | DISABLED:{0,0}<br>RXTX :{1,1}<br>RXONLY :{1,0}<br>TXONLY :{0,1}                                                                                                                                              | {CH_15[3],<br>CH_13[7]}                                                                                                                                                    |
| {PLL_SRC, CHn_CDR_SRC}     | {REFCKLOCAL}                                                                                                                                                                                                              | Note 5                                                                                                                                                                                                       | {QD_0A[0]}                                                                                                                                                                 |

**Table 8-105. Attribute Cross-Reference Table (Continued)**

| Independent Attribute Name      | Dependent Attribute Name | Attribute Value                                                                       | Register Map |
|---------------------------------|--------------------------|---------------------------------------------------------------------------------------|--------------|
| {CHn_TX_8B10B,<br>CHn_RX_8B10B} | {BUS8BIT_SEL}            | Note 6                                                                                | {QD_0B[6]}   |
| {CHn_RXWA, CHn_ILSM}            | {CHn_SIG_DET}            | {DISABLED, X} <sup>3</sup> {0}<br>{ENABLED, DISABLED} {0}<br>{ENABLED, ENABLED} {1}   | {CH_04[6]}   |
| {CHn_RXWA, CHn_ILSM}            | {CHn_C_ALIGN}            | {DISABLED, X} 2 <sup>3</sup> {0}<br>{ENABLED, DISABLED} {0}<br>{ENABLED, ENABLED} {0} | {CH_01[7]}   |

- rx\_los\_low will only show that a signal has been detected for data rates above 1 Gbps with a maximum CID (Consecutive Identical Digits) of 7 bits (i.e., a minimum input signal transition density as is sent by 8b10b). rx\_los\_low is only supported with a default setting of rlos\_lset[2:0] = 2 for all protocols except PCI Express and SDI. For PCI Express, 2 and 3 are supported. In SDI mode, it is recommended to use the carrier detect output signal (/CD) from the external SDI cable equalizer. rlos\_hset is not supported.
- 10-bit symbol code default / populated by the user in the “PCS Advanced Setup” configuration GUI. Since the 10-bit symbol code representation in the GUI is LSB to MSB, the bit representation is swapped appropriately in the table for software use.
- X = don't care.
- If any of the channels is enabled, the quad bit will be set to 1.
- If PLL\_SRC and all of the enabled CHn\_CDR\_SRC is set to REFCLK\_CORE then this bit should be 1, else this bit should be 0.
- If any of the enabled channels CHn\_TX\_8B10B or CHn\_RX\_8B10B are DISABLED then this bit should be 1 or else this bit should be set to 0.
- The TDRV\_AMP attribute has been replaced by TDRV. When the .lpc file is opened, the software will automatically replace the TDRV\_AMP attribute with TDRV. If the user attempts to re-compile without re-generating the PCS module, the software will generate an error in the automake.log file. Users should either edit the .txt file or re-generate the PCS module using IPexpress.
- refclk\_to/from\_nq signals are for internal use only.

**Table 8-106. Protocol-Specific SERDES Setup Options**

| Protocol      | DATARATE                                  | DATARATE Range                                         | REFCK Multiplier       | Data Width | RX Equalization <sup>1</sup>                                                         |
|---------------|-------------------------------------------|--------------------------------------------------------|------------------------|------------|--------------------------------------------------------------------------------------|
| GbE           | 1.25G                                     | MED                                                    | 10x, 20x, 25x          | 8, 16      | DISABLE,<br>MID_MED,<br>LONG_MED                                                     |
| SGMII         | 1.25G                                     | MED                                                    | 10x, 20x, 25x          | 8          |                                                                                      |
| PCI Express   | 2.5G                                      | HIGH                                                   | 25x, 20x               | 8, 16      | MID_LOW,<br>DISABLE,                                                                 |
| XAUI          | 3.125                                     | HIGH                                                   | 20x, 10X               | 16         | MID_HIGH,<br>LONG_HIGH                                                               |
| CPRI          | 614.4M,<br>1.2288G,<br>2.4576G,<br>3.072G | MEDLOW,<br>MED,<br>MEDHIGH,<br>HIGH                    | 10x, 20x, 25x          | 8, 16      | DISABLE,<br>MID_LOW,<br>MID_MED,<br>MID_HIGH,<br>LONG_LOW,<br>LONG_MED,<br>LONG_HIGH |
| SDI           | 270M,<br>1.485G,<br>2.97G                 | LOW,<br>MED,<br>HIGH                                   | 20x                    | 10, 20     | DISABLE,<br>MID_LOW,<br>MID_MED,<br>MID_HIGH,<br>LONG_LOW,<br>LONG_MED,<br>LONG_HIGH |
| G8B10B        | ANY_VALUE                                 | LOWLOW,<br>LOW,<br>MEDLOW,<br>MED,<br>MEDHIGH,<br>HIGH | 10x, 20x, 25x          | 8, 16      | DISABLE,<br>MID_LOW,<br>MID_MED,<br>MID_HIGH,<br>LONG_LOW,<br>LONG_MED,<br>LONG_HIGH |
| 8-Bit SERDES  |                                           |                                                        | 8x, 16x                | 8, 16      |                                                                                      |
| 10-Bit SERDES |                                           |                                                        | 10x, 20x, 25x          | 8, 16      |                                                                                      |
| USER_DEF      |                                           |                                                        | 8x, 10x, 16x, 20x, 25x | 8, 16      |                                                                                      |

1. Rx Equalization is based on user signal traces. MID ~20", LONG ~40". LOW/MED/HIGH is amount of equalization user needs to test out.

## Appendix D. Lattice Diamond Overview

This appendix discusses the use of Lattice Diamond design software for projects that include the LatticeECP2M SERDES/PCS module.

For general information about the use of Lattice Diamond, refer to the [Lattice Diamond User Guide](#).

If you have been using ispLEVER software for your FPGA design projects, Lattice Diamond may look like a big change. But if you look closer, you will find many similarities because Lattice Diamond is based on the same toolset and work flow as ispLEVER. The changes are intended to provide a simpler, more integrated, and more enhanced user interface.

### Converting an ispLEVER Project to Lattice Diamond

Design projects created in ispLEVER can easily be imported into Lattice Diamond. The process is automatic except for the ispLEVER process properties, which are similar to the Diamond strategy settings, and PCS modules. After importing a project, you need to set up a strategy for it and regenerate any PCS modules.

### Importing an ispLEVER Design Project

Make a backup copy of the ispLEVER project or make a new copy that will become the Diamond project.

1. In Diamond, choose **File > Open > Import ispLEVER Project**.
2. In the ispLEVER Project dialog box, browse to the project's .syn file and open it.
3. If desired, change the base file name or location for the Diamond project. If you change the location, the new Diamond files will go into the new location, but the original source files will not move or be copied. The Diamond project will reference the source files in the original location.

The project files are converted to Diamond format with the default strategy settings.

### Adjusting PCS Modules

PCS modules created with IPExpress have an unusual file structure and need additional adjustment when importing a project from ispLEVER. There are two ways to do this adjustment. The preferred method is to regenerate the module in Diamond. However this may upgrade the module to a more recent version. An upgrade is usually desirable but if, for some reason, you do not want to upgrade the PCS module, you can manually adjust the module by copying its .txt file into the implementation folder. If you use this method, you must remember to copy the .txt file into any future implementation folders.

### Regenerate PCS Modules

1. Find the PCS module in the Input Files folder of File List view. The module may be represented by an .lpc, .v, or .vhdl file.
2. If the File List view shows the Verilog or VHDL file for the module, and you want to regenerate the module, import the module's .lpc file:
  - a. In the File List view, right-click the implementation folder () and choose **Add > Existing File**.
  - b. Browse for the module's .lpc file, **<module\_name>.lpc**, and select it.
  - c. Click **Add**. The .lpc file is added to the File List view.
  - d. Right-click the module's Verilog or VHDL file and choose **Remove**.
3. In File List, double-click the module's .lpc file. The module's IPExpress dialog box opens.
4. In the bottom of the dialog box, click **Generate**. The Generate Log tab is displayed. Check for errors and close.

In File List, the .lpc file is replaced with an .ipx file. The IPexpress manifest (.ipx) file is new with Diamond. The .ipx file keeps track of the files needed for complex modules.

## Using IPexpress with Lattice Diamond

Using IPexpress with Lattice Diamond is essentially the same as with ispLEVER.

The configuration GUI tabs are all the same except for the Generation Options tab. Figure 8-57 shows the Generation Options tab window.

**Figure 8-57. Generation Options Tab**



**Table 8-107. SERDES\_PCS GUI Attributes – Generation Options Tab**

| GUI Text                                | Description                                                                                                                   |
|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Automatic                               | Automatically generates the HDL and configuration(.txt) files as needed. Some changes do not require regenerating both files. |
| Force Module and Settings Generation    | Generates both the HDL and configuration files.                                                                               |
| Force Settings Generation Only          | Generates only the attributes file. You get an error message if the HDL file also needs to be generated.                      |
| Force Place & Route Process Reset       | Resets the Place & Route Design process, forcing it to be run again with the newly-generated PCS module.                      |
| Force Place & Route Trace Process Reset | Resets the Place & Route Trace process, forcing it to be run again with the newly-generated PCS module.                       |

Note:

Automatic is set as the default option. If either Automatic or Force Settings Generation Only and no sub-options (Process Reset Options) are checked and the HDL module is not generated, the reset pointer is set to Bitstream generation automatically.

After the Generation is finished, the reset marks in the process window will be reset accordingly.

## Creating a New Simulation Project Using Simulation Wizard

This section describes how to use the Simulation Wizard to create a simulation project (.spf) file so you can import it into a standalone simulator.

1. In Project Navigator, click **Tools > Simulation Wizard**. The Simulation Wizard opens.
2. In the Preparing the Simulator Interface page click **Next**.
3. In the Simulator Project Name page, enter the name of your project in the Project Name text box and browse to the file path location where you want to put your simulation project using the Project Location text box and Browse button.  
  
When you designate a project name in this wizard page, a corresponding folder will be created in the file path you choose. Click **Yes** in the pop-up dialog that asks you if you wish to create a new folder.
4. Click either the Active-HDL® or ModelSim® simulator check box and click **Next**.
5. In the Process Stage page choose which type of Process Stage of simulation project you wish to create. Valid types are RTL, Post-Synthesis Gate-Level, Post-Map Gate-Level, and Post-Route Gate-level+Timing. Only those process stages that are available are activated.

Note that you can make a new selection for the current strategy if you have more than one defined in your project.

The software supports multiple strategies per project implementation which allow you to experiment with alternative optimization options across a common set of source files. Since each strategy may have been processed to different stages, this dialog allows you to specify which stage you wish to load.

6. In the Add Source page, select from the source files listed in the Source Files list box or use the browse button on the right to choose another desired source file. Note that if you wish to keep the source files in the local simulation project directory you just created, check the **Copy Source to Simulation Directory** option.
7. Click **Next** and a Summary page appears and provides information on the project selections including the simulation libraries. By default, the Run Simulator check box is enabled and will launch the simulation tool you chose earlier in the wizard in the Simulator Project Name page.
8. Click **Finish**.

The Simulation Wizard Project (.spf) file and a simulation script DO file are generated after running the wizard. You can import the DO file into your current project if desired. If you are using Active-HDL, the wizard will generate an .ado file and if you are using ModelSim, it creates and .mdo file.

*Note: PCS configuration file, (.txt) must be added in step 6.*