# LatticeECP2M SERDES/PCS ユーザガイド

# PCSの概要

LatticeECP2M™ FPGAファミリは業界をリードするアーキテクチャを持ち、高性能FPGAファブリックと、高性能I/O、および大規模組み込みメモリを単一チップに集積しています。また、すべてのLatticeECP2Mデバイスが特徴としているのは、組み込みSERDES(最大16チャネル)とこれに付随するPhysical Coding Sublayer(PCS)ロジックです。多数の業界標準高速データ転送プロトコルをサポートするためにPCSロジックを構成することができます。

各チャネルに専用のPCSロジックは送受信SERDESを含み、データレート3.125Gbpsの高速全二重シリアルデータ転送に対応します。PCSロジックはイーサネット(1GbEとSGMII)、PCI Express、CPRI、およびOBSAIを含む一連のポピュラーなデータプロトコルをサポートするために各チャネルを構成することができます。さらに、ユーザの高速データインターフェイス設計に柔軟に対応できるように、多くの構成でプロトコルベースのロジックを完全か部分的にバイパスすることができます。

またPCSはバイパスモードを提供し、SERDESからFPGAロジックとは8ビット、または10ビットの直接インターフェイスがあります。また、それぞれのSERDESピンは個別にDC結合に設定することでき、高速動作と、シリアル・デジタルビデオ(SDI)アプリケーションのような低速動作を、同じSERDESピンで対応することが可能です。

# 機能

- ・最大16チャネルの高速SERDES
  - チャネルあたり250Mbpsから3.125Gbps
  - 3.125Gbps動作時にチャネルあたり100mWの低消費電力
  - フォームファクタの小さいバックプレーン動作の為の受信等化と送信プリエンファシス
  - PCI Express、イーサネット(1GbEとSGMII)、および他の複数の規格をサポート
  - ユーザ指定の汎用(Generic) 8b10bモードをサポート
  - PCI Expressのビーコンをサポート
  - 低速入力用のOOB (out-of-band)信号インターフェイス(ビデオ用途)
- ・複数のクロックレートをサポート
  - 各PCSクワッド用に個別の基準クロックが使用でき、単一デバイスで複数のプロトコルレートを容易に扱うことが可能
- ・フル機能の組み込み物理コーディング・サブレイヤ(PCS)ロジックで業界標準プロトコルをサポート
  - デバイス当たり最大16チャネルの全二重データ通信をサポート
  - 単一チップで複数プロトコルをサポート
  - 8b10bベースの広く採用されているパケットプロトコルをサポート
  - SERDES OnlyモードはFPGAロジックと8ビット、または10ビットで直接インターフェイスが可能
- ・ギガビット・イーサネットのサポート
  - IEEE 1000BASE-Xに準拠
  - 8b10bエンコーディング/デコーディング
  - 自動ネゴシエーションをサポートするための受信データストリーム中への /l2/ シンボル挿入
  - コンマキャラクタのワードアライメント
  - クロックトレランス補償 (CTC) 回路

LatticeECP2M 8-1 SERDES/PCS-UGJ

- ・PCI Expressサポート
  - 単一PCSクワッドでx1またはx4をサポート
  - ワードアライナを集積
  - 8b10bエンコーディング/デコーディング
  - クロックトレランス補償(CTC)回路
  - 電気的アイドルとレシーバ検出のサポート
  - ビーコン送信とビーコン検出のサポート
- ・複数プロトコルに準拠するクロックトレランス補償(CTC)ロジック
  - 基準クロックと受信データレートとの周波数差を補償
  - 長さ1/2/4バイトのユーザ定義スキップパターンの使用が可能
- ・システムデバッグのためのループバック・モードを集積
  - システムデバッグのために3つのループバック・モードを提供

# サポート規格

サポートする規格を表8-1にリストアップします。

表8-1 サポートするSERDES規格 (フルサポート)

| 規格                                 | レート [Mbps]            | REFCLK [MHz]              | FPGA CLK<br>[MHz]     | 符号化             | 信号タイプ |
|------------------------------------|-----------------------|---------------------------|-----------------------|-----------------|-------|
| PCI Express                        | 2500                  | 100                       | 250                   | 8b10b           | CML   |
| GbE/SGMII                          | 1250                  | 125                       | 125                   | 8b10b           | CML   |
| Generic 8b10b                      | 250 ~ 3125            | 25.0 ~ 312.5              | 25.0 ~ 312.5          | 8b10b/なし        | CML   |
| 10-bit SERDES<br>Only <sup>1</sup> | 250 ~ 3125            | 25.0 ~ 312.5              | 25.0 ~ 312.5          | なし              | CML   |
| 8-bit SERDES<br>Only <sup>1</sup>  | 250 ~ 3125            | 25.0 ~ 312.5              | 25.0 ~ 312.5          | なし              | CML   |
| SD-SDI <sup>2</sup>                | 143, 177, 270,<br>360 | 14.3, 17.7, 27.0,<br>36.0 | 143, 177, 135,<br>180 | SMPTEスクランブ<br>ル | CML   |
| HD-SDI                             | 1483.5, 1485          | 148.35, 148.5             | 148.35, 148.5         | SMPTEスクランブ<br>ル | CML   |
| CPRI                               | 614.4<br>1228.8       | 61.44<br>122.88           | 61.44<br>122.88       | 8b10b           | CML   |

<sup>1.</sup>SERDES Onlyモードは8ビットと10ビット共に、リンクアライン/コンマアラインと、8b10bエンコーダ/デコーダ、およびCTCをバイパスします。CDRはバイパスしません。

上記SERDESモードでXAUI、SRIO、OBSAI、CPRI、1XFC、2XFC、PICMG3.1、PICMG3.4、PICMG3.5、および3G-SDIの各規格をサポートすることができます。より詳細な情報が必要な場合はラティスセミコンダクターのテクニカルサポート・グループにご連絡ください。

LatticeECP2M 8-2 SERDES/PCS-UGJ

<sup>2.</sup>標準精細度(SD)用のシリアルデジタル・インターフェイス(SDI): 143Mbps、177MbpsはSERDES/PCSブロックをバイパスします。クロックとデータはRXピンからBSCANパスを通してFPGAコアに入ります。CDRはFPGAコアで行われます。送信方向では、これらの低いビットレートにはデシメーションが用いられます。FPGA内でCDRを実行するためには、14.3MHzと17.7MHzの基準クロックが必要です。270Mbpsは最も一般的な周波数です。これは10ビットのデータパスを通ります。

# アーキテクチャ概要

PCSロジックは独立する4系統の全二重データチャンネル用のロジックを含み、クワッドごとにアレンジされています。表8-2はLatticeECP2Mファミリで各デバイスにあるSERDES/PCSクワッドを示します。

表8-2 LatticeECP2MファミリのデバイスごとのSERDES/PCSクワッド

| デバイス          | ECP2M20 | ECP2M35 | ECP2M50 | ECP2M70 | ECP2M100 |
|---------------|---------|---------|---------|---------|----------|
| Quad URC (右上) | Yes     | Yes     | Yes     | Yes     | Yes      |
| Quad LRC (右下) | -       | -       | Yes     | Yes     | Yes      |
| Quad ULC (左上) | -       | -       | -       | Yes     | Yes      |
| Quad LLC (左下) | -       | -       | -       | Yes     | Yes      |

#### PCSクワッド

図8-1はデバイス内でPCSクワッドの配置を示すLatticeECP2Mのレイアウトです。(4つのクワッドを含む最も大きいアレイが示されています。他のデバイスではクワッド数は少なくなります。)

図8-1 LatticeECP2M70/100プロック図



全てのクワッドは複数のプロトコルベースのモードの1つにプログラムすることができます。各クワッドはそれ自身の基準クロックを必要とし、外部からパッケージピンを介して、或いは内部FPGAロジックから供給することができます。

各クワッドにはそれぞれ基準クロックがあるので、クワッドが異なれば同一チップでも違う規格をサポートすることができます。この機能はLatticeECP2Mファミリを、異なる規格間のブリッジ機能の実装に理想的な

LatticeECP2M 8-3 SERDES/PCS-UGJ

#### デバイスにします。

PCSクワッドは単に業界標準プロトコル専用なだけではありません。多くのユーザ定義のデータ操作モードのために、各クワッド(そしてクワッド内の各チャネル)をプログラムすることができます。例えば、ユーザ定義のワードアライメントとクロックトレランス補償を司るモードは、非プロトコル動作としてプログラムすることができます。

#### PCSクワッドとチャネル

デバイスの各クワッドは最大4チャネルの全二重データをサポートします。アプリケーションによって、ユーザは単一クワッドで1~4チャネルのいづれも利用することができます。どのクワッドであれ、ユーザが各チャネルごとに独立して設定できる多くのオプションがあります。

また図8-1には4つのPCSクワッド、合計16のPCSチャネルを含むデバイスの例を示します。それぞれのクワッドはLatticeECP2Mアレイ内を4分割した位置に従って命名されています。すなわちURPCS(右上のPCS)、ULPCS(左上のPCS)、LRPCS(右下のPCS)、LLPCS(左下のPCS)です。

# チャネル単位のPCS/FPGAインターフェイス・ポート

選ばれたモードにかかわらず、すべてのPCSクワッドはパッケージピンに共通の外部高速シリアル・インターフェースを持っています。しかしながら、各クワッドとFPGAロジック間のI/Oポートには、それぞれのPCSモードで選択されたプロトコルに適切となる独自のリストがあります。本ドキュメントでは各モード用のクワッド入出力信号の詳細を記述します。単一クワッド内のチャネルを示す概略図を図8-2に示します。

#### 図8-2 PCSクワッドのブロック図



### PCSクワッドの配置

LatticeECP2M-50以上の規模のデバイスは2~4つのPCSクワッドを含んでいます。

ユーザは、プリファレンス(設計制約)ファイルの中でLOCATEプリファレンスを用いることで、各PCSクワッド配置を所望の位置に指定することができます。LOCATE制約については、以下に例を示します。

LOCATE COMP "PCS\_instantiation\_1" SITE "URPCS"; (訳注; PCS\_instantiation\_1はコンポーネント名)

LatticeECP2M 8-4 SERDES/PCS-UGJ

### 詳細なチャネルプロック図

図8-3は、LatticeECP2M SERDES/PCS単一チャネルの主要な機能の詳細なブロック図を表します。この図にはFPGAでユーザロジックから見えるすべての主要なブロック、および制御とステータス信号の大部分が示されています。また、この図はチャネルSERDES、SERDESブリッジ、PCSコア、およびFPGAブリッジの主要なサブブロックも示しています。

図8-3 LatticeECP2M SERDES/PCSチャネルの詳細プロック図



以下にFPGAインターフェイス信号の概要説明が続きます。

### クロックとリセット

PCSクワッドはFPGAロジック・インターフェイスに対して、(Tx PLLに)ロックした基準クロックおよびチャネルごとの受信再生クロックを供給します。各PCSクワッドはこれらのクロックをプライマリ、及びセカンダリのFPGAクロック配線に提供します。また、各クワッドのPCS/FPGAインターフェイスには、FPGAファブリックから全4チャネルに供給する送受信クロックポートがあります。

各クワッドには、クワッド内のSERDESとPCSロジックの両方か、或いはSERDESのみを強制リセットする 信号入力があります。さらに送受信方向共に、PCSロジック専用のリセットが各チャネルごとにあります。

#### 送信データバス

送信データパスの信号はFPGAからPCSブロック内のFPGAブリッジまでです。高速伝送規格のために、(制御/ステータス信号と共に)8ビット幅の内部PCSデータパス用に2:1変換すること(ギアリング)ができます。

LatticeECP2M 8-5 SERDES/PCS-UGJ

PCI Express x1用インターフェイスの最高速度は2:1変換しないモードで250MHzです。ギアリング2:1あり (すなわち、16ビット幅データパス)で、最大速度は156.25MHz(XAUI 4xチャネルモード用)です。SERDES とPCSは、156.25MHz(2:1ギアリングあり)のインターフェイス速度に対応する3.125Gbpsデータレートまで サポートします。

| 表8-3 異なるモードごとの送信データバスのと | シッ | 卜配分 |
|-------------------------|----|-----|
|-------------------------|----|-----|

| データビット<br>(ff_tx_d[23:0]) | GE           | XAUI      | PCI Express<br>(8b10b) | 8-bit I/F (8b10b)     | 10-bit I/F <sup>2, 3</sup> |
|---------------------------|--------------|-----------|------------------------|-----------------------|----------------------------|
| [11], [23]                | Correct_disp | 0でドライブ    | pcie_ei_en             | correct_disp          | 0でドライブ                     |
| [10], [22]                | xmit 4       | 0でドライブ    | disp_sel               | disp_sel <sup>1</sup> | 0でドライブ                     |
| [9], [21]                 | 0でドライブ       | 0でドライブ    | force_disp             | force_disp 1          | txd [9]                    |
| [8], [20]                 | k_cntrl      | txc       | k_cntrl                | k_cntrl               | txd [8]                    |
| [7:0], [19:12]            | txd [7:0]    | txd [7:0] | txd [7:0]              | txd [7:0]             | txd [7:0]                  |

- 1. G8B10Bモードで動作しているとき、force\_disp信号はデータワード[7:0]に対してdisp\_sel信号で選択された コラムのビットにディスパリティを強制します。disp\_selが1の場合、10ビットコードは現在のRD+(正のディスパリティ)コラムから選択されます。disp\_selが0の場合,10ビットコードは現在のRD-(負のディスパリティ) コラムから選択されます
- 2. データにギアリングがある(2:1)とき、低位ビット(ff\_tx\_[9:0])が最初に送信されるオクテットであり、高位ビット(ff\_tx\_d[19:10])が2番目に送信されるオクテットです。データがギアリングなしの場合、低位ビット(ff\_tx\_d[9:0])が有効なビットであり、高位ビットは全てゼロにされるべきです。
- 3.8ビットモード、或いは10ビットモードで用いられるインターフェイスと8b10bエンコーダ/デコーダはバイパスされます。例えば、SDIなど。
- 4. 自動ネゴシエーション・ステートマシンは信号xmitを生成します。これはハードロジック内でGigE Idle SMと相互にインターフェイスする為に用いられます。

### 受信データバス

受信パスの信号は、PCSブロック内のFPGAブリッジからFPGAまでです。データパスは8ビット幅の内部 PCSデータパス用に2:1ギアリングされるかもしれません。ソフトウェア・レジスタビットでギアリングを禁止することが可能で、その場合バス幅は半分にされます。データがギアリングされるとき、低位ビット (ff\_rx\_d[9:0])が最初に受信されたオクテットであり、高位ビット(ff\_rx\_d[9:0])が2番目に受信されたオクテットです。データがギアリングなしの場合、低位ビット(ff\_rx\_d[9:0])が有効なビットであり、高位ビットは使用されるべきではありません。

表8-4 異なるモードごとの受信データのバスビット配分

| データピット<br>(ff_rx_d[23:0]) | GE <sup>1</sup> | XAUI      | PCI Express<br>(8b10b) <sup>2</sup> | 8-bit I/F (8b10b) <sup>1</sup> | 10-bit I/F |
|---------------------------|-----------------|-----------|-------------------------------------|--------------------------------|------------|
| [11], [23]                | rx_even 2       | NC        | rxstatus[2]3                        | NC                             | NC         |
| [10], [22]                | cv              | cv        | rxstatus[1]3                        | cv                             | NC         |
| [9], [21]                 | disp_err        | disp_err  | rxstatus[0]3                        | disp_err                       | rxd [9]    |
| [8], [20]                 | k_cntrl         | txc       | k_cntrl                             | k_cntrl                        | rxd [8]    |
| [7:0], [19:12]            | rxd [7:0]       | rxd [7:0] | rxd [7:0]                           | rxd [7:0]                      | rxd [7:0]  |

- 1. コードバイオレーションがあるとき、PCS 8b10bパケットデコーダはその出力を0xEEとKアサートに置き替えます(K=1かつd=EEは8b10b符号スペースに定義がありません)。
- 2. rx\_evenはGigE自動ネゴシエーションと受信ステートマシン(FPGAロジックで実装される)での使用のためにGigEリンク・ステートマシンによって生成される信号です。

0

LatticeECP2M 8-6 SERDES/PCS-UGJ

#### 制御

各モードにはそれ特有の制御信号の組があり、FPGAロジックから様々なPCS機能の直接制御を可能にします。通常これらの制御入力は、それぞれの制御レジスタビットへのライト操作と同等の作用を与えます。 ispLEVERデザインツールは、これらのポートをFPGAインターフェイスに取り出すためのオプションをユーザに与えます。

#### ステータス

各モードにはそれ特有のステータスやアラーム信号の組があり、FPGAロジックからモニタできます。通常これらのステータス出力は、特定のステータス・レジスタビットにそれぞれ対応しています。ispLEVERデザインツールは、これらのポートをPCS FPGAインターフェイスに取り出すためのオプションをユーザに与えます。制御とステータスに関する詳細な情報については "モード特有の制御/ステータス信号" セクションを参照してください。

# SCI (SERDESクライアント・インターフェイス)バス

SCIはソフトIPで、SERDES/PCSクワッドブロックがコンフィグレーション・メモリセルではなく、レジスタによって制御されることを可能にします。それは簡単なレジスタ・コンフィグレーション・インターフェイスです。

### このテクニカルノートの利用

ラティスからのispLEVERデザインツールはPCSの全モードをサポートします。殆んどのモードが特定の業界標準データ通信プロトコルのアプリケーション専用です。他のモードは、ユーザが自身のカスタムアプリケーション設定を定義する、より汎用のモードです。 ispLEVERデザインツールで、ユーザのデザインで使用するモードに各クワッドを定義します。

このドキュメントはispLEVERによってサポートされるSERDESとPCSのすべてのモードの動作について説明します。このドキュメントは組み込みSERDESと、連携するPCSロジックの完全な機能を詳細に記述します。組み込みSERDESの電気的特性とタイミング特性はLatticeECP2/Mファミリデータシートにあります。PCSロジックの動作はPCSセクションにあり、SCIバスを介してアクセスすることができるSERDES/PCSロジックに関連する全ステータス・制御レジスタは、その一覧表がメモリマップ・セクションに提供されています。パッケージピン配置情報はLatticeECP2/Mファミリデータシートのアーキテクチャ・セクションに含まれています。

LatticeECP2M 8-7 SERDES/PCS-UGJ

# SERDES/PCS

クワッドは4チャネルのRxとTx回路、及びTx PLLを含む補助チャネルを含んでいます。Tx PLLへの基準クロックは、基準クロック差動入力ピンかFPGAコアから供給することができます。クワッドSERDES/PCSマクロは4レーンのデータのためにシリパラ変換とパラシリ変換機能を実行し、マクロ内のPLLはFPGAロジックにシステムクロックを提供します。またクワッドはTxとRx各回路で、フルデータレートとハーフデータレート動作モードの両方を独立してサポートします。ブロックレベルの図が図8-4で示されています。

#### 図8-4 SERDES\_PCSブロックの信号インターフェイス



### I/O定義

表8-5にPCSクワッドに対するすべてのデフォルトおよびオプションのI/Oをリストアップします。ユーザは、IPexpress GUIを用いることでPCSクワッドのオプションポートを選ぶことができます。

LatticeECP2M 8-8 SERDES/PCS-UGJ

# 表8-5 SERDES\_PCS I/O記述

| 信号名                                     | I/O  | タイプ    | 記述                                                       | Default /<br>Optional |
|-----------------------------------------|------|--------|----------------------------------------------------------|-----------------------|
| プライマリI/O, SERDESク                       | フワッド |        |                                                          |                       |
| hdinp0                                  | I    | チャネル   | 高速CML非反転入力、チャネル0                                         | D                     |
| hdinn0                                  | I    | チャネル   | 高速CML反転入力、チャネル0                                          | D                     |
| hdinp1                                  | I    | チャネル   | 高速CML非反転入力、チャネル1                                         | D                     |
| hdinn1                                  | I    | チャネル   | 高速CML反転入力、チャネル1                                          | D                     |
| hdinp2                                  | - 1  | チャネル   | 高速CML非反転入力、チャネル2                                         | D                     |
| hdinn2                                  | I    | チャネル   | 高速CML反転入力、チャネル2                                          | D                     |
| hdinp3                                  | I    | チャネル   | 高速CML非反転入力、チャネル3                                         | D                     |
| hdinn3                                  | ı    | チャネル   | 高速CML反転入力、チャネル3                                          | D                     |
| hdoutp0                                 | 0    | チャネル   | 高速CML非反転出力、チャネル0                                         | D                     |
| hdoutn0                                 | 0    | チャネル   | 高速CML反転出力、チャネル0                                          | D                     |
| hdoutp1                                 | 0    | チャネル   | 高速CML非反転出力、チャネル1                                         | D                     |
| hdoutn1                                 | 0    | チャネル   | 高速CML反転出力、チャネル1                                          | D                     |
| hdoutp2                                 | 0    | チャネル   | 高速CML非反転出力、チャネル2                                         | D                     |
| hdoutn2                                 | 0    | チャネル   | 高速CML反転出力、チャネル2                                          | D                     |
| hdoutp3                                 | 0    | チャネル   | 高速CML非反転出力、チャネル3                                         | D                     |
| hdoutn3                                 | 0    | チャネル   | 高速CML反転出力、チャネル3                                          | D                     |
| refclkp                                 | ı    | クワッド   | 基準クロック非反転入力、専用CML入力                                      | D                     |
| refclkn                                 | ı    | クワッド   | 基準クロック反転入力、専用CML入力                                       | D                     |
| 送受信データバス(詳細な                            | バス使ん | 用法について | よ表8-3を参照)                                                | -                     |
| ff_rxdata_ch0[23:0]                     | I    | チャネル   | チャネル0受信パスのデータ信号                                          | D                     |
| ff_rxdata_ch1[23:0]                     | 1    | チャネル   | チャネル1受信パスのデータ信号                                          | D                     |
| ff_rxdata_ch2[23:0]                     | ı    | チャネル   | チャネル2受信パスのデータ信号                                          | D                     |
| ff_rxdata_ch3[23:0]                     | I    | チャネル   | チャネル3受信パスのデータ信号                                          | D                     |
| ff_txdata_ch0[23:0]                     | 0    | チャネル   | チャネル0送信パスのデータ信号                                          | D                     |
| ff_txdata_ch1[23:0]                     | 0    | チャネル   | チャネル1送信パスのデータ信号                                          | D                     |
| ff_txdata_ch2[23:0]                     | 0    | チャネル   | チャネル2送信パスのデータ信号                                          | D                     |
| ff_txdata_ch3[23:0]                     | 0    | チャネル   | チャネル3送信パスのデータ信号                                          | D                     |
| 制御信号                                    |      |        | 1                                                        | -                     |
| ffc_sb_inv_rx_ch[3:0]                   | I    | チャネル   | 受信データの反転制御<br>1 = データを反転<br>0 = データを反転しない                | 0                     |
| ffc_enable_cgalign_ch[3:0] <sup>4</sup> | I    | チャネル   | コンマアライナを制御<br>1 = コンマアライナをイネーブル<br>0 = コンマアライナを現在の位置にロック | 0                     |
| ffc_signal_detect_ch[3:0] <sup>4</sup>  | I    | チャネル   | リンクステートマシン (LSM) を制御<br>1 = LSMをイネーブル<br>0 = LSMをディセーブル  | 0                     |
| ffc_fb_loopback_ch[3:0]                 | 1    | チャネル   | FPGAブリッジ・ループバック<br>1 = RxからTxへのループバックをイネーブル<br>0 = 通常動作  | 0                     |

LatticeECP2M 8-9 SERDES/PCS-UGJ

|                                     |   |      | SERDESブリッジ・パラレルループバック                                                                                                             |   |
|-------------------------------------|---|------|-----------------------------------------------------------------------------------------------------------------------------------|---|
| ffc_sb_pfifo_lp_ch[3:0]             | I | チャネル | 1 = RxからTxへのループバックをイネーブル<br>0 = 通常動作                                                                                              | 0 |
| ffc_pfifo_clr_ch[3:0]               | I | チャネル | SERDESブリッジ・パラレルループバックFIFO<br>のクリア<br>1 = ループバックFIFOをリセット<br>0 = 通常のループバック動作                                                       | D |
| rx_sdi_en                           | I | チャネル | BSCANモードのみで使用                                                                                                                     | 0 |
| tx_sdi_en                           | I | クワッド | BSCANモートのみで使用                                                                                                                     | U |
| リセット信号                              |   |      |                                                                                                                                   |   |
| ffc_lane_rx_rst_ch[3:0]             | I | チャネル | Highアクティブ、非同期入力。PCS内の個々の<br>Rxチャネルロジックのみをリセット。                                                                                    | D |
| ffc_lane_rx_tst_ch[3:0]             | I | チャネル | Highアクティブ、非同期入力。PCS内の個々のTxチャネルロジックのみをリセット.                                                                                        | D |
| ffc_rrst_ch[3:0]                    | I | チャネル | Highアクティブ、非同期入力。SERDES Rxチャネル内の一部ロジックのみをリセット。                                                                                     | D |
| ffc_trst                            | I | クワッド | Highアクティブ、非同期入力。SERDES全Txチャネル内の一部ロジックをリセット。                                                                                       | D |
| ffc_quad_rst                        | I | クワッド | Highアクティブ、非同期入力。補助チャネルを<br>含むSERDES全チャネルをリセット。                                                                                    | D |
| ffc_macro_rst                       | I | クワッド | Highアクティブ、SERDESクワッドへの非同期入力。PCSロジック以外の補助チャネルを含むSERDES全チャネルをリセット。ソフトウェア・レジスタビットfpga_reset_enableとゲートされる。fpga_reset_enableのデフォルトは1。 | D |
| ffc_txpwdnb_ch[3:0]                 | I | チャネル | Lowアクティブ送信チャネルパワーダウン。<br>0 = 送信チャネルパワーダウン                                                                                         | D |
| ffc_rxpwdnb_ch[3:0]                 | Ι | チャネル | Lowアクティブ受信チャネルパワーダウン。<br>0 = 受信チャネルパワーダウン                                                                                         | D |
| ステータス信号                             |   |      |                                                                                                                                   |   |
| ffs_rlos_lo_ch[3:0]                 | 0 | チャネル | 各チャネル用LOS検出。閾値設定にはレジスタ<br>ビットrlos_hset[2:0]が用いられる。Low側の閾<br>値はユーザからアクセスできない。<br>1 = LOS<br>0 = 信号検出                               | D |
| ffs_ls_sync_status_ch[3:0]          | 0 | チャネル | 1 = レーンはコンマに同期<br>0 = レーンはコンマを不検出.                                                                                                | D |
| ffs_cc_underrun_ch[3:0] 6           | 0 | チャネル | 1 = Rxクロック補償FIFOのアンダーランエラー<br>0 = FIFOエラーなし                                                                                       | 0 |
| ffs_cc_overrun_ch[3:0] <sup>6</sup> | 0 | チャネル | 1 = Rxクロック補償FIFOのオーバーランエラー<br>0 = FIFOエラーなし                                                                                       | 0 |
| ffs_rxfbfifo_error_ch[3:0]          | 0 | チャネル | 1 = Rx FPGAブリッジFIFOエラー<br>0 = FIFOエラーなし                                                                                           | D |
| ffs_txfbfifo_error_ch[3:0]          | 0 | チャネル | 1 = Tx FPGAブリッジFIFOエラー<br>0 = FIFOエラーなし.                                                                                          | D |
| ffs_rlol_ch[3:0]                    | 0 | チャネル | 1 = Rx CDR LOL<br>0 = ロックを維持                                                                                                      | D |
| ffs_plol                            | 0 | クワッド | 1 = Tx PLL LOL<br>0 = ロックを維持                                                                                                      | D |

LatticeECP2M 8-10 SERDES/PCS-UGJ

| oob_out_ch[3:0] <sup>3</sup> | 0             | チャネル     | FPGA内ビデオSERDES用へのチャネルのシングルエンド出力                                                                                                                                                          | D |
|------------------------------|---------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| refck2core                   | 0             | クワッド     | FPGAへの基準クロック                                                                                                                                                                             | 0 |
| FPGAへのクロック信号                 |               |          |                                                                                                                                                                                          |   |
| ff_rxfullclk_ch[3:0]         | 0             | チャネル     | Rxチャネル再生クロック。ユーザモードではソースは常にチャネルの再生クロック。GbEや10GbEなどCTCサポートの規格では、ソースは当該送信チャネルのシステムクロック。PCSバイパスモードでもTxシステムクロックであり、8b10bモードか8b10bデコーダをディセーブルして(10-bit or 20-bit data path)実行する"raw"モードが必要です。 | D |
| ff_rxhalfclk_ch[3:0]         | 0             | チャネル     | Rxチャネル再生ハーフクロック。2:1ギアリング<br>では2分周された出力。                                                                                                                                                  | D |
| ff_rxqtrclk_ch[3:0]          | 0             | チャネル     | Rxチャネル再生クオータ(1/4)クロック。もう一段の2:1ギアリング用。                                                                                                                                                    | 0 |
| ff_txfullclk                 | 0             | チャネル     | Tx PLLフルレートクロック                                                                                                                                                                          | D |
| ff_txhalfclk                 | 0             | チャネル     | Tx PLLハーフレートクロック                                                                                                                                                                         | D |
| ff_txqtrclk                  | 0             | チャネル     | Tx PLLクオータ (1/4) レートクロック                                                                                                                                                                 | 0 |
| FPGAからのクロック信号                | <del></del> 号 |          |                                                                                                                                                                                          |   |
| core_rxrefclk                | - 1           | クワッド     | FPGAからのRx基準クロック。CDR PLL用。                                                                                                                                                                | D |
| core_txrefclk                | ı             | クワッド     | FPGAロジックからのTx基準クロック。Tx<br>SERDES PLL用。                                                                                                                                                   | D |
| ff_ebrd_clk_[3:0]            | ı             | チャネル     | FPGAからのRxチャネルクロック入力。CTC<br>FIFO (エラスティックバッファ) リード用。                                                                                                                                      | D |
| ff_rxiclk_ch[3:0]            | ı             | チャネル     | FPGAからの各Rxチャネル用クロック入力。基準クロックや受信基準クロックに同期する FIFOとRx FPGA部のインターフェイス用クロック。                                                                                                                  | D |
| ff_txiclk_ch[3:0]            | ı             | チャネル     | FPGAからの各Txチャネル用クロック入力。基準クロックに同期したFIFOとインターフェイスするため。CTCが用いられる場合は、Rx FPGA部が基準クロックに同期したFIFOにインターフェイスするために用いられる。                                                                             | D |
| SERDESクライアント・                | インター          | フェイス(SCI | ·                                                                                                                                                                                        |   |
| scienaux                     | I             | R        | 1: sciwdataがクワッド制御レジスタにライト<br>0: メモリデータがクワッド制御レジスタにラ<br>イト                                                                                                                               | 0 |
| scien_ch[3:0]                | ı             | R        | 1: sciwdataがチャネル制御レジスタにライト<br>0: メモリデータがチャネル制御レジスタにラ<br>イト                                                                                                                               | 0 |
| sciselaux                    | I             | R        | 1: クワッドレジスタを選択                                                                                                                                                                           | 0 |
| scisel_ch[3:0]               | I             | R        | 1: チャネルレジスタを選択                                                                                                                                                                           | 0 |
| sciaddress[5:0]              | I             | R        | アドレスバス入力                                                                                                                                                                                 | 0 |
| scireaddata[7:0]             | 0             | R        | リードデータ出力                                                                                                                                                                                 | 0 |
| sciwritedata[7:0]            | i             | R        | ライトデータ入力                                                                                                                                                                                 |   |

LatticeECP2M 8-11 SERDES/PCS-UGJ

| scird                       | I | R | 1: リードデータを選択<br>0: リードデータは非選択                        | 0 |
|-----------------------------|---|---|------------------------------------------------------|---|
| sciwstn                     | I | R | ライトストローブ                                             | 0 |
| sciinterrupt                | 0 | R | 割り込み出力                                               | 0 |
| cyawstn                     | I | R | 1: "sciwstn = 0" の場合、全メモリセルをレジス<br>タにコピー<br>0: デフォルト | 0 |
| SERDESキャラクタライゼーション / テスト用バス |   |   |                                                      |   |
| cin[11:0]                   | I | R | キャラクタライズ用テストバスロジックのデータ入力                             | D |
| cout[19:0]                  | 0 | R | キャラクタライズ用テストバスロジックのデー<br>タ出力                         | D |

- 1. コンフィグレーションの間、HDOUTPとHDOUTNは共にVCCOBにプルアップされます。
- 2. Generic 8b10b PCSモジュールはオプションとして4本のPCI制御/ステータス信号を含んでいます。用いられない場合、制御信号はGNDに接続し、またステータス信号はフローティングのままでも構いません。
- 3. CDRを用いないで信号を得る唯一の方法はOOB OUT信号を用いることです。この信号はSDIモード用のみ。
- 4. 外部リンクステートマシンが選択されると、PCSポートリストにこれらの信号が表れます。図8-28を参照してください。
- 5. ラティスセミコンダクター社内での用途のみ。
- 6. これら信号はパルスです。正しくモニタするためにはラッチする必要があります。

# SERDES/PCSの機能記述

LatticeECP2Mファミリのデバイスには、組み込みSERDES/PCSロジックのクワッドが1~4あります。各クワッドは、独立する全二重データチャンネルを4系統サポートします。単一チャネルはデータリンクを1系統サポートすることができ、各クワッドはそのような4つのチャネルまでサポートすることができます。モード選択はクワッド単位でされることに注意してください。例えば或るクワッドをギガビット・イーサネットモードに選択すると、そのクワッドにおける全4チャネルがギガビット・イーサネットモード専用になります。

組み込みSERDES CDR PLLとTx PLLは広範囲の業界標準プロトコルをカバーするデータレートをサポートします。

図8-3はSERDES/PCSチャネル内の主なブロックとサブブロックを説明します。

- SERDES
  - イコライザ
  - CDR(クロックデータ・リカバリ)
  - デシリアライザ
  - プリエンファシス
  - シリアライザ
  - シリアル・ループバック
- ・SERDESブリッジ(SB)
  - インバータ;受信データを反転します。PCI Expressで必要です。
  - SERDESブリッジ・パラレル・ループバック
- PCSコア
  - ワードアライメント

LatticeECP2M 8-12 SERDES/PCS-UGJ

- 8b10bデコーダ
- 8b10bエンコーダ
- リンクステートマシン
- エラスティック・バッファ(CTC)
- ・FPGAブリッジ(FB)
  - ダウンサンプルFIFO
  - アップサンプルFIFO
  - PCSパラレル・ループバック

#### **SERDES**

### イコライザ

デジタル伝送のデータレートがGbps以上に進化するにつれて、周波数依存の減衰によって受信信号に厳しいシンボル間干渉をもたらす結果となり得ます。従ってイコライザを用いることは、正しくデータを復元するために必須になります。LatticeECP2Mでは3つの極配置オプションを用意しており、これらは低/中/高周波領域です。

### プリエンファシス

プリエンファシスはシステムプロセスに関するものです。ユーザは最大80%のプリエンファシスを選択することができます。

# レシーバのCID(同一ディジットの連続)

Rx-CID; BER 10<sup>-12</sup> でのレシーバのCID(0/1同一ディジットの連続)

- ・3.125Gbpsで7ビット
- ・1.25Gbpsで20ビット

これはDC結合を用いるとき、入力データストリームが0/1の遷移なしで許容されるビット数です。

#### 基準クロックの使用

1本の基準クロック(REFCLK)がLatticeECP2Mファミリではサポートされます。Tx PLLと4個のRx PLLはすべて同じ周波数で、基準クロック周波数の倍数で動作します。各チャネルのTxシリアライザは、そのままのレート(フルデータレート・モード)か半分のレート(ハーフデータレート・モード)で動作するかを、独立してプログラムすることができます。同様に、各チャネルのRxデシリアライザもフルデータレート・モード、ハーフデータレート・モードのいづれで動作するかを独立してプログラムすることができます。すべてのTxとRxが同じモードでプログラムされると(通常はフルレート)、クワッドの全4チャネルが同一Tx/Rx周波数で動作することになります。

SERDES内の送信PLLは、ピンからの外部基準クロックか、FPGAコア(core\_txrefclk)から提供される基準クロックかのどちらかに、ロックすることができます。SERDES内の受信PLLも、ピンからの外部基準クロックかFPGAコア(core\_rxrefclk)から供給される基準クロックのどちらかにロックすることができます。

LatticeECP2M 8-13 SERDES/PCS-UGJ

### 図8-5 ブロック図、基準クロックの使用



#### 基準クロックのソース

#### refclkp, refclkn

CMLのSERDESクロック専用入力。送受信用に特に別のソースが用意されていない限り、最初のオプションです。ソースはCML、LVDS、LVPECLのいづれかです。インターフェイス例についてはTN1114 (Electrical Recommendations for Lattice SERDES )を参照してください。

#### core\_rxrefclk, core\_txrefclk

FPGAロジックからの基準入力。プライマリクロック(PCLK)を使用するべきです。

#### **FPGA PLL**

FPGA PLLが基準クロックとして用いられるとき、そのPLLに対する基準クロックは専用クロック入力ポートを用いるべきです。高速データレート用のクロックではFPGA PLL出力のジッタはシステム規格を満たさないかもしれません。ジッタが重要な用途では用いないことを推奨します。

### フルデータレートとハーフデータレート

各TxシリアライザとRxデシリアライザは、フルデータレートとハーフデータレートに分けることができ、各方向と各チャネルにおいて2つの異なるデータレートを許容します。

このデュアルレート機能を用いるには、チャネルベースのプロトコルモードを選択しなければなりません。 例:

1. IPexpress(図8-22)のQuad Tabウィンドウでは、G8B10B Mode、Channel Based Protocol Mode、Channel0(Full Rate)が選択されています。

LatticeECP2M 8-14 SERDES/PCS-UGJ

- 2. Reference Clock(CM)ウィンドウ(図8-24)で、Full Rate Channelコラムの下に、以下を入力します。
  - ・シリアル・ビットクロックレート: 2.5 GHz
  - ・基準クロックの乗数: 10X
  - ・残り3つのエントリーはそのまま
- 3. Half Rate Channelコラムはハーフレートのために計算された値を表示します:

フルレートチャネル ハーフレートチャネル

シリアル・ビットクロックレート2.5GHz1.25GHz基準クロック乗数10X5X計算された基準クロックレート250MHz250MHzFPGAインターフェイス・データバス幅88計算後のFPGA I/Fクロックレート250MHz250MHz

#### フルクロック、ハーフクロック、およびクオータクロックの使用

多くの場合、図8-32で図示されるff\_txfullclkはff\_rxiclk\_chx、ff\_txiclk\_chx、ff\_ebrd\_clk\_xに用いられます。

Reference Clock MultiplierとFPGA Interface Data Bus Widthが選択されているとき、IPexpress GUIは自動的にFPGAインターフェイスのクロック周波数を計算します。

表8-6はrefclk\_multiplierモードと、8ビットまたは16ビットのインターフェイス・データバス幅の取り得るすべての組み合わせに対するクロック使用例について示します。

表8-6 クロック使用例、G8B10Bモード、REFCLK=120MHz

| 基準クロック乗数        | 10xH               | 10x      | 20xH     | 20x      |
|-----------------|--------------------|----------|----------|----------|
| ピットレート          | 600 Mbps           | 1.2 Gbps | 1.2 Gbps | 2.4 Gbps |
| 8ビット・インターフェイス例  |                    |          |          |          |
| rxfullclk 1     | 60                 | 120      | 120      | 240      |
| rxhalfclk       | 30                 | 60       | 60       | 120      |
| txfullclk       | 120                | 120      | 240      | 240      |
| txhalfclk       | 60                 | 60       | 120      | 120      |
| txqtrclk        | 30                 | 30       | 60       | 60       |
| 16ビット・インターフェイス例 |                    |          |          |          |
| rxfullclk       | 60                 | 120      | 120      | 240      |
| rxhalfclk 1     | 30                 | 60       | 60       | 120      |
| txfullclk       | 120                | 120      | 240      | 240      |
| txhalfclk       | 60                 | 60       | 120      | 120      |
| txqtrclk        | 30 <sup>2, 3</sup> | 30       | 60       | 60       |

- 1. CTC BYPASSモードでは、これら再生クロックはrxiclkのソースとして用いられます。図8-34/-36参照。
- 2. 陰影をつけられたセル中のクロックは、FPGAインターフェイス・クロックとして各モードで使用されます。
- 3. このモードが選択されるとき、コンフィグレーションGUIのOptional PortタブウィンドウでPLL Quarter Clockをチェックしなければなりません(図8-28を参照してください)。

フルデータレート・チャネルのVCOはビットクロックと同じです。ハーフデータレート・チャネルではビットクロックはVCOの半分です。

LatticeECP2M 8-15 SERDES/PCS-UGJ

### LOS(信号の喪失)

各チャネルは図8-6で示されるようにプログラマブルなLOS(信号の喪失)検出器を含んでいます。LOS閾値は プログラマブル電流源の値に依存し、rlos\_hset[2:0]制御ビットを用いて選ばれます。

# LOL(ロックはずれ)

送信PLLと個別チャネルのCDRには、いづれもカウンタベースのデジタルLOL検出器があります。送信PLLのロックがはずれるとLOLがアサートされ、PLLが再ロックするまでそのままです。

CDRのロックがはずれると、そのチャネルのLOLがアサートされ、CDRのVCOを基準クロックにロックしようと試みます。これが達成されるとそのチャネルのLOLはネゲートされ、CDRは入力データにロックするために元に戻ります。CDRはデータにロックし続けるか、または再びロックはずれに戻り再トレーニングへと、その繰り返しとなります。

#### **図8-6 LOS検出器**



注:rlos\_lsel[2:0]制御ビットと関連するステータスビットはラティス社内のみでの用途です。

### Txレーン間スキュー

制御ビットsync\_toggleは、アクティブな全Txチャネルがbit0からパラシリ変換を始めるためのリセット用に加えられました。ほとんどのマルチチャンネル・プロトコル規格では、ある規定値の中にTxレーン間スキューが収まることを保証する要件があります。マルチチャンネル・アライメント(MCA)はLatticeECP2MのハードPCSではサポートされません。

Txシリアライザへのリセットはsync\_toggle制御ビットをトグルするか、PLL LOLの遷移によって生成されます。リセットはすべてのアクティブなTxシリアライザに適用されます。これらのソース信号が共にレベルである場合、Txシリアライザは通常動作しています。

LatticeECP2M 8-16 SERDES/PCS-UGJ

### PCS機能のセットアップ

LatticeECP2M PCSは様々なアプリケーションでの用途に構成することができます。セットアップは ispLEVER IPexpressモジュール生成ツールで選ばれ、ユーザはPCSのモードと機能オプションを選択できます。選択オプションは自動構成(auto-configuration)ファイルの中に保存され、これはispLEVERビットストリーム・ジェネレータによって用いられてビットストリーム内に書き出されます。PCS選択オプションを変えるためには、ユーザはIPexpressを再実行してPCSモジュールを作り直し、新しい自動構成ファイルを作成することを推奨します。ビットストリーム・ジェネレータを実行する前に、マニュアルで自動構成ファイルを編集することによって幾つかのオプションを変えることもできます。

コンフィグレーション後に、オプションのSERDESクライアント・インターフェイス(SCI)バスを通してPCSレジスタに書くことによって、動的にPCSオプションを変えることができます。SCIはソフトIPで、SERDES/PCSクワッドがコンフィグレーション・メモリセルの設定と異なるレジスタ値によって制御されることを可能にします。SCIを介してアクセスできる制御/ステータス・レジスタの一覧表を、このドキュメントのメモリマップ章に示してあります。

### 自動構成(auto-configuration)ファイル

ispLEVERの自動構成機能を用いることで、それぞれのPCSモードのための初期レジスタ設定を行うことが可能です。モジュール・ジェネレータは、選ばれたモード用にクワッド/チャネルレジスタ設定の自動構成ファイル (<module名>.txt) を生成します。このファイルはフロントエンド・シミュレーションで参照することができ、またビットストリームに統合されます。すべてのクワッド/チャネルレジスタが、コンフィグレーションの際に自動構成ファイルで定義された値に設定されます。したがって全レジスタが自動構成ファイルで設定されるのみで良ければ、SCIは不要です。他方、ユーザがデバイス動作中に制御レジスタの値を変えるか、またはステータス・レジスタをモニタする必要がある場合は、デザイン内にSCIを含まなければなりません。

#### 送信データ

PCSクワッド送信データパスはチャネル単位での8b10bエンコーダとシリアライザから成ります。

#### 8b10bエンコーダ

このモジュールはIEEE 802.3ae-2002 1000BASE-X仕様の中で記述されている8b10bエンコーダを実装しています。エンコーダは仕様で説明されるように8ビットから10ビットコードへの変換を実行し、同時に規定されているディスパリティ規則を維持します。CHx\_8B10B(xはチャネル番号)の属性をBYPASSに設定することによって、8b10bエンコーダをバイパスすることができます。

#### シリアライザ

8b10b符号化されたデータはパラシリ変換され、組み込みSERDESを介してチップ外部に送信されます。

#### 受信データ

PCSクワッド受信データパスはチャネルごとに次のサブブロックからなります;デシリアライザ、ワードアライナ、8b10bデコーダ、オプションのリンクステートマシン(LSM)、およびオプションの受信クロックトレランス補償(CTC)FIFO。

#### デシリアライザ

データは組み込みSERDESを介してオンチップに取り込まれ、シリアルからパラレルになります。

#### ワードアライメント(バイト境界の検出)

このモジュールはコンマ符号語の検出とアライメント動作を実行します。受信ロジックで入力されるデータストリームに10ビットのワードアライメントを実行するために、コンマキャラクタが用いられています。

LatticeECP2M 8-17 SERDES/PCS-UGJ

CHx\_COMMA\_ALIGN(xはチャネル番号)のアトリビュートをBYPASSに設定することによって、ワードアライナをバイパスすることができます。コンマ記述は802.3.2002 1000BASE-X仕様のセクション36.2.4.9と、セクション48.2.6.3(10GBASE-X仕様の図48-7)にあります。

ワードアライメント・モジュール内で多くのプログラマブル・オプションがサポートされます:

・ソフトウェア・イネーブル制御(User Configured; UCモード)

注: UC Modeは8-bit SERDES Only、10-bit SERDES Only、SD-SDI、HD-SDIを意図します。

・2つのプログラマブル・ワードアライメント・キャラクタ(通常正と負のディスパリティのためにそれぞれ1つ)を設定できる機能と、アライメント・コンペア(比較)のためのビット単位でプログラマブルなマスクレジスタ。アライメント・キャラクタとマスクレジスタはクワッド毎に設定されます。

多くのプロトコルにおいて、"XXX0000011" (正のランニング・ディスパリティ・コンマキャラクタでコードグループK28.1、K28.5、およびK28.7に適合するjhgfiedcbaビット)と "XXX1111100" (負のランニング・ディスパリティ・コンマキャラクタでコードグループK28.1、K28.5、およびK28.7に適合するjhgfiedcbaビット) にワードアライメント・キャラクタを設定することができます。しかしながら、ユーザは最大10ビット長のどのようなビットパターンも定義することができます。

- ・最初のアライメント・キャラクタは属性COMMA\_Aに割り当てられた10ビットの値によって定義されます。 この値はPCSクワッドの全チャンネルに適用されます。
- ・第二のアライメント・キャラクタは属性COMMA\_Bに割り当てられた10ビットの値によって定義されます。 この値はPCSクワッドの全チャンネルに適用されます。
- ・マスクレジスタは、どのワードアライメント・ビットを比較したらよいかを定義します(マスクレジスタで1のビットは、ワードアライメント・キャラクタレジスタで対応するビットをチェックすることを意味します)。属性COMMA\_Mに割り当てられた10ビットの値によって定義されたマスクレジスタ。この値はPCSクワッドの全チャンネルに適用されます。

属性CHx\_COMMA\_ALIGNがAUTOに設定されると、プロトコルベースのリンクステートマシンの1つがワードアライメントを制御します。詳しい動作に関する情報は、後述のプロトコル特有のリンクステートマシン記述を参照してください。

### 8b10bデコーダ

8b10bデコーダは、IEEE802.3-2002規格で記述されるようにデコーダ動作を実装しています。デコーダはランニング・ディスパリティの検証と共に10ビットから8ビットコードへの変換を実行します。CHx\_8B10B(x はチャネル番号)の属性をBYPASSに設定することによって、8b10bデコーダをバイパスすることができます。

コードバイオレーションが検出されると、ff\_rxdata受信データは0xEEに、ff\_rx\_k\_cntrl\_chは1に設定されます。

# プロトコル特有のリンクステートマシン(LSM)

PCSは様々なクワッドモードで用いられる種々プロトコルのためにLSMを実装しています。

プロトコル特有のLSMが選択されるとき、CH(0-3)\_COMMA\_ALIGNをAUTOに設定することによって、そのチャネルのLSMをイネーブルしなければなりません。各モードでイネーブルされる特有LSMの選択は、以下に記述され、また図8-7にまとめられています。

PROTOCOL属性がGIGEであるとき、ギガビット・イーサネット用のLSMが選択されます。リンク同期は、アラインされたコードワード(符号語)が必要数連続して検出された後に達成されます。ギガビット・イーサ

LatticeECP2M 8-18 SERDES/PCS-UGJ

ネットリンク同期ステートマシンは802.3-2002 1000BASE-X仕様の図36-9で示される同期ステート図を実装します。

G8B10Bと10-bit SERDES Onlyプロトコルでは、COMMA\_ALIGNがAUTOに設定されるとき、ギガビット・イーサネット・リンクステートマシンが使用されます。

#### 外部リンクステートマシンのオプション

属性CHx\_COMMA\_ALIGNがDYNAMICに設定されるとき、プロトコル特有のLSMはバイパスされます。その場合、ffc\_enable\_cgalign\_ch(0-3)が少なくとも1クロック周期Lowにされた後、ワードアライナは比較が成功した最初か第二のユーザ定義ワードアライメント・キャラクタのどちらかで、アライメントはロックします。(入って来るデータをユーザ定義のワードアライメント・キャラクタに比較するのをやめて、現在のアライメントを維持します。)その後にFPGAインターフェイスのffc\_enable\_cgalign\_ch(0-3)ポートに与えられるLowパルスは、ワードアライナをアンロックします。そして、ワードアライナはユーザ定義のワードアライメント・キャラクタの1つに次に一致した時に再ロックされます。望まれるなら、一定の条件下でのワードアライメントの変化を許容するために、PCSクワッドの外部に実装されたLSMによりffc\_enable\_cgalign\_ch(0-3)を制御することができます。

図8-7はLSMオプションについて図示します。

### 図8-7 PCSワードアライナとLSMオプション



表8-7 リンクステートマシン (LSM) とワードアライナ(WA)の選択

| COMMA<br>ALIGNモード | 記述                                                                                   |
|-------------------|--------------------------------------------------------------------------------------|
| AUTO              | WAがイネーブル、LSMがイネーブル(GbE LSM: デフォルト)                                                   |
| DYNAMIC           | WAがイネーブル、LSMはディセーブル。cg_alignとsig_detect信号は0に設定される。<br>潜在的に外部LSMが両信号を制御できる            |
| BYPASS            | WAはバイパス、LSMはディセーブル。ユーザは、FPGAコアにワードアライナを設計し、ロジック内に自らのcg_alignとsig_detect信号を与えることもできる。 |

LSMが選択/イネーブルされたとき、リンク同期に成功すると、その特定チャネルに関するステータス信号ffs\_ls\_sync\_status(0-3)はHighになります。

LatticeECP2M 8-19 SERDES/PCS-UGJ

# ギガビット・イーサネットモードのアイドル挿入

Generic 8b10bモードには、さらにワードアライメントのためにLSMを選択するオプションがあります。ギガビット・イーサネットモードに設定されたPCSは、自動ネゴシエーションのために、受信データストリームの中に /l2/ シンボル挿入を行います。ギガビット・イーサネットの自動ネゴシエーションはソフトロジックで実行されます。この機能は2048クロックサイクル毎に8つの /l2/ オーダーセット・シーケンスを挿入します。/l2/ 挿入は自動ネゴシエーション・ソフトロジックからドライブされるPCSへのff\_xmit\_ch(0-3)入力で制御されます。また、PCSから自動ネゴシエーション・ソフトロジックまでの信号ff\_rx\_even\_ch(0-3)[0]を提供します。図8-8はPCSがギガビット・イーサネットモードに設定されたときの、1チャネルの受信ロジックを示し(この例ではチャネルの)、これらの制御/ステータス信号を示しています。

図8-8 ギガビット・イーサネットモードのPCS受信パス(チャネル0の例)



# クロックトレランス補償(CTC)

CTCは、受信再生クロックとロックする基準クロックの間のクロックレートの調整を実行します。クロック 補償は、パケットデータの損失を引き起こすことなく、事前に定められた位置でバイトを挿入するか、また は削除することによって実行されます。16バイトのエラスティックFIFOは、2つのクロックドメイン間のデ ータ転送に用いられ、LatticeECP2M SERDESのためにクロック偏差の規定ppm上限まで対応します。 (LatticeECP2/Mファミリデータシートの "DCおよびスイッチング特性" セクションを参照して下さい。)

属性CHx\_CTC\_BYPがNORMALに設定されると、そのチャネルのCTCブロックはイネーブルされ、BYPASSに設定されるとバイパスされます。

1バイト削除について図8-9で示します。

LatticeECP2M 8-20 SERDES/PCS-UGJ

図8-9 クロックトレランス補償、1パイト削除の例



1バイト挿入について図8-10で示します。

図8-10 クロックトレランス補償、1バイト挿入の例



2バイト削除について図8-11で示します。

図8-11 クロックトレランス補償、2パイト削除の例



LatticeECP2M 8-21 SERDES/PCS-UGJ

2バイト挿入について図8-12で示します。

### 図8-12 クロックトレランス補償、2バイト挿入の例



4バイト削除について図8-13で示します。

図8-13 クロックトレランス補償、4バイト削除の例



4バイト挿入について図8-14で示します。

図8-14 クロックトレランス補償、4バイト挿入の例



クロック補償値はクワッドベースで設定されます。CHx\_CTC\_BYP(xはチャネル番号)の属性をBYPASSに設定することによって、CTCをバイパスすることができます。CHx\_CTC\_BYPをNORMALに設定することは、CTCがアクティブであることを意味します。ispLEVERモジュール・ジェネレータでは、チャネルをSingleと定義するとCTCをイネーブルする自動構成ファイルが作成されます。チャネルをMCA Group1かMCA Group 2と定義すると、CTCをバイパスする自動構成ファイルが作成されます。CTCが使用されるとき、意

LatticeECP2M 8-22 SERDES/PCS-UGJ

図されたアプリケーションのクロック補償のために、以下の設定を適切に設定しなければなりません。

- ・CC\_MATCHMODE属性を用いて、挿入/削除パターン長を設定します。これは挿入や削除を実行する前に CTCが比較しスキップするバイト数を設定します。CC\_MATCHMODEの値は、MATCH\_4 (1バイトの挿入/削除)と、MATCH\_3\_4 (2バイトの挿入/削除)、及びMATCH\_1\_2\_3\_4 (4バイトの挿入/削除)です。また、ターゲット・アプリケーションに適切な最小パケット間ギャップを設定しなければなりません。パケット間ギャップは属性CC\_MIN\_IPGに値を割り当てることによって設定されます。CC\_MIN\_IPGの許容値は0、1、2、および3です。これらの属性設定に基づいてスキップキャラクタ削除が実行された後の、許容される最小パケット間ギャップは以下の表8-8で説明されています。
- ・選ばれたCC\_MATCHMODEに対応するように、スキップバイトかオーダーセットが設定されなければなりません。4バイトの挿入/削除(CC\_MATCHMODE = MATCH\_1\_2\_3\_4)に関しては、属性MATCH\_1を最初のバイトに割り当て、属性MATCH\_2に第二バイト、属性MATCH\_3を第三バイト、そして属性MATCH\_4に第四バイトをそれぞれ割り当てなければなりません。割り当てられる値は2進の10ビット値です。例えば、4バイトのスキップ・オーダーセットが /K28.5/D21.4/D21.5/D21.5 である場合、MATCH\_1は "0110111100"、 MATCH\_2 = "0010010101"、そしてMATCH\_3 = MATCH\_4 = "0010110101" であるべきです。2バイトの挿入/削除 (CC\_MATCHMODE = MATCH\_3\_4) に関しては、属性MATCH\_3が最初のバイトに割り当て、属性MATCH\_4に第二バイトをそれぞれ割り当てなければなりません。1バイトの挿入/削除 (CC\_MATCHMODE = MATCH\_4が最初のバイトに割り当てられなければなりません。
- ・クロック補償FIFOにおいて、ターゲット・プロトコル用のHigh/Lowウォーターマーク(水位標)を設定しなければなりません。値は0~15の範囲を取り得、HighウォーターマークをLowウォーターマークより高い値に設定しなければなりません(等しい値に設定するべきではありません)。属性CCHMARKに値を割り当てることによって、Highウォーターマークが設定されます。CCHMARKの許容値は16進値の0からFです。属性CCLMARKに値を割り当てることによって、Lowウォーターマークが設定されますCCLMARKの許容値も16進値の0からFです。
- ・ispLEVERモジュール・ジェネレータでPCSブロックを生成するとき、Error Status Portsが選択されている場合、チャネルごとのクロック補償FIFOオーバーランは、PCS/FPGAインターフェイスでffs\_cc\_overrun\_ch(0-3)という名称のポートでモニタすることができます。
- ・ispLEVERモジュール・ジェネレータでPCSブロックを生成するときError Status Portsが選択されている場合、チャネルごとのクロック補償FIFOアンダーランは、PCS/FPGAインターフェイスでffs\_cc\_underrun\_ch(0-3)という名称のポートでモニタすることができます。

### 最小パケット間ギャップの計算

表8-8はパケット間ギャップ(CC\_MIN\_IPG属性で定義される)のユーザ定義の値と、PCSからのスキップ・キャラクタ削除後の保証されるパケット間最小バイト数との関係を示します。表は乗数としてパケット間ギャップを示します。パケット間の最小バイト数と、挿入/削除を表中で示された乗数倍されたバイト数は等しいです。例えば挿入/削除あたりのバイト数が4(CC\_MATCHMODEはMATCH\_1\_2\_3\_4に設定される)で、かつ最小パケット間ギャップの属性C\_MIN\_IPGが2の時、最小のパケット間ギャップは4(CC\_MATCHMODE = MATCH\_1\_2\_3\_4)掛ける3(表8-8のCC\_MIN\_IPG = 2)、即ち12バイトに等しくなります。最小のパケット間バイト数がCTCを通り抜けるまで、PCSはスキップキャラクタの削除を実行しません。

LatticeECP2M 8-23 SERDES/PCS-UGJ

表8-8 最小パケット間ギャップの乗数

| CC_MIN_IPG | 挿入/削除の乗数 |
|------------|----------|
| 0          | 1 X      |
| 1          | 2 X      |
| 2          | 3 X      |
| 3          | 4 X      |

#### クロックドメイン

図8-15は、PCS内でCTCブロックを利用するモードでの、単一チャネルの送受信両方向のクロックドメインを示します。

送信側では、FPGAインターフェイスにおけるff\_txiclk\_ch入力からロックした基準クロックまでのクロックドメイン転送は、FPGA送信インターフェイスFIFOで起こります。FPGA送信インターフェイスFIFOは、同じ周波数である2クロック間の位相差を吸収する意図があります。これらのFIFO(1チャネルあたり1つ)は周波数偏差を補うことはできません。

受信側のクロックドメイン転送は、チャネル再生クロックから基準クロック間のCTCブロックで起こります。CTCは、LatticeECP2Mの最大許容値まで、再生受信クロックと基準クロックの周波数差を調節することができます。CTCの後、FPGA受信インターフェイスFIFOで、ロックされた基準クロックとff\_rxiclk\_chの間でクロック・インターフェイスがあります。FPGA受信インターフェイスFIFOは、同一周波数の2クロック間の位相差の調整をすることが目的です。FPGA受信インターフェイスFIFO(1チャネルあたり1つ)は、周波数偏差を補うことはできません。

図8-15 CTCモードのPCSクロックドメイン転送



LatticeECP2M 8-24 SERDES/PCS-UGJ

### 図8-16 CTCを用いるPCSクワッドへの同期入力クロック



同期インターフェイスを保証するためには、送信クロック入力と受信クロック入力の両方が、Generic 8b10bモードに設定されたPCSクワッドの基準クロック出力の1つからドライブされるべきです。図8-16は同期インターフェイスとなるような、取り得る接続について図示します。

図8-17は、PCS内でCTCブロックを利用しないモードでの、単一チャネルの送受信両方向のクロックドメインを示します。送信側では、FPGAインターフェイスにおけるff\_txiclk\_ch入力からロックした基準クロックまでのクロックドメイン転送は、FPGA送信インターフェイスFIFOで起こります。FPGA送信インターフェイスFIFOは、同一周波数の2クロック間の位相差を調整することが目的です。これらのFIFO(1チャネルあたり1つ)は周波数偏差を補うことはできません。受信側のクロックドメイン転送は、FPGA受信インターフェイスFIFOで受信再生クロックとff\_rxiclk\_chの間で起こります。FPGA受信インターフェイスFIFOは、同一周波数の2クロック間の位相差を調整することが目的です。FPGA受信インターフェイスFIFO(1チャネルあたり1つ)は周波数偏差を補うことはできません。

LatticeECP2M 8-25 SERDES/PCS-UGJ

### 図8-17 非CTCモードでのPCSクロックドメイン転送



同期インターフェイスを保証するためには、送信クロック入力と受信クロック入力の両方が、Generic 8b10bモードに設定されたPCSクワッドの基準クロック出力の1つからドライブされるべきです。図8-18は同期インターフェイスとなる、取り得る接続について図示します。

LatticeECP2M 8-26 SERDES/PCS-UGJ



#### 図8-18 CTCを用いないPCSクワッドへの同期入力クロック

# スペクトル拡散クロック(SSC)のサポート

LatticeECP2M SERDES/PCSにはスペクトル拡散ジェネレータがありませんが、スペクトル拡散データを受信することができます。

LatticeECP2MでのSSCサポートは同様の機能を必要とするすべてのプロトコルに適用されますが、リンク両端のポートは互いに600ppm以内に収まるレートでデータを伝送しなければなりません。これはビットレート用クロックソースに+/-300ppmの偏差を許容する仕様です。変調レート30KHzからの33KHzの範囲で、データレートは定格の+0%から-0.5%まで変調ことができます。+/-300ppmの許容限界に加えて、データがSSCで変調されるとき、両ポートは同じビットレート・クロックを必要とします。

(PCI Expressでは)ルート・コンプレックスは基準クロックを拡散する責任があります。そしてエンドポイントは、TXを通してスペクトルを戻すために、それと同じクロックを用います。したがって別のRXREFCLKは必要ありません。

この支配的なアプリケーションはアドインカードです。これは、PCI ExpressコネクタのようにコネクタからのREFCLKを用いる必要はありませんが、同じSSCで受信し、送信しなければなりません。

# シリアル・デジタルビデオとOOB (帯域外) 低速SERDES動作

レシーバCDRと付随するSERDES/PCSロジックをバイパスすることによって、低速度(250Mbps未満、Out-Of-Band=OOB信号)の入力にSERDES受信バッファを用いることができます。この機能はシリアル・デジタルビデオ用途など、高速データと低速データの両方からDCまでの伝送に、同一の端子で対応する必要があるアプリケーションに有用です。

LatticeECP2M SERDES/PCS は標準精細度シリアル・デジタルインターフェイスSD-SDI(143Mbps、177Mbps、270Mbps、360Mbps)、および高精細度シリアル・デジタルインターフェイスHD-SDI(1.485Gbps

LatticeECP2M 8-27 SERDES/PCS-UGJ

と1.4835Gbps)をサポートします。これらは送受信ピンを共用することが必要です。考えられる実装方法の1つが図8-19で示されます。PCS/FPGAインターフェイスにおけるOOB信号ポートは、250Mbpsより低速の信号を入力するのに用いられます。

SD-SDIモードが選択されると、このポートが利用できます。OOB\_OUT信号は、SERDES入力バッファから FPGAインターフェイスまで直接通され、また基準クロックにはロックしません(図8-3を参照してください)。

低速信号でSERDES入力バッファをドライブするとき、SERDES入力バッファはDCモードに設定されるべきです。これはIPexpress PCSコンフィグレーションGUIのRx I/O Couplingドロップダウン・ボックスにおいてDCを選択することによって、チャネル単位で行われます(図8-25を参照して下さい)。

以上はシリアル・デジタルビデオに関する議論ですが、FPGAロジックでRx CDR(クロックデータ・リカバリ)を行い、Tx方向にデシメーションを必要とするような、低ビットレート・アプリケーションではいづれも同様な使い方をすることが意図されていることに留意して下さい。

入力BSCAN回路は、高速SERDESと並列に見え、入力データをデバイスの(クワッドでない)ほかの場所に位置する低速度デシリアライザに接続するために用いることができます。BSCANステートマシンに関与せずに入力BSCAN回路(1チャネルあたり1つ)をオンするためのイネーブル信号が必要です。

Quad Top ✓ FPGA Core 
✓ SERDES/PCS Block OOB EN RSRMODE from JTAG config logic BSCAN input cell OOB OUTn low rate data output RX power up HDINP0 EQ Input Data HDINNO I TX power up SERDES Output Data HDOUTP0 HDOUTN0 ■◀ BSCAN output cell

図8-19 考えられるシリアル・デジタルビデオのサポート実装例

LatticeECP2M 8-28 SERDES/PCS-UGJ

# コンフィグレーションGUI

IPexpress™は、SERDESとPCSブロックを生成し、構成するために用いられます。設計者は、特定のクワッドやチャネルのSERDESプロトコル規格を選択する際に、GUIを用います。IPexpressはこのGUIから入力を得て、自動構成ファイル(.txtファイル)とHDLネットリストを生成します。HDLモデルはシミュレーションと合成フローで用いられます。自動構成ファイルは属性レベルの配置情報を含んでいて、シミュレーションとispLEVER bitgen(ビットファイル生成)プログラムの入力となります。設計に変更やアップデートが生じた場合は、IPexpressに戻って自動構成ファイルを生成し直すことを、強く推奨します。いくつかの例外時に限って、ユーザは自動構成ファイルを変更しても構いません。SERDESプロトコル規格用にSERDES/PCSプロックを生成するためIPexpressを用いるときのツールフローを、図8-20に示します。

プロジェクトが異なるディレクトリに保存されるとき、この自動構成ファイルもプロジェクトファイルと同 じディレクトリに手動で移動(又はコピー)する必要があります。

#### 図8-20 SERDES PCS ispLEVERユーザフロー



図8-21は、PCSがIPexpress GUIで選択された時のメインウィンドーを示します。

LatticeECP2M 8-29 SERDES/PCS-UGJ

### 図8-21 IPexpress PCSメインウィンドー



# クワッド・セットアップタブ

図8-22は、メインウィンドーでファイル名が入力され、Customizeボタンがチェックされた時のクワッド・セットアップタブを示します。このウィンドウで必要な最初のエントリは、プロトコルモードをQuad Based ModeかChannel Based Modeから選択することです。このスクリーン上の他のエントリーは、チャネルの選択とグループの選択です。図8-23から図8-28で示す5つのタブがあり、デフォルト値設定と共にユーザアクセス可能なすべての属性を示します。

図8-22 コンフィグレーションGUI、クワッド・セットアップタブ



LatticeECP2M 8-30 SERDES/PCS-UGJ

| 表8-9 SERDES PCS GUI属性 - クワッドタブ・セット | <i>アットタフ・ヤットアッフ</i> |
|------------------------------------|---------------------|
|------------------------------------|---------------------|

| GUIテキスト                 | 属性名      | 範 囲                                                                                                                    | デフォルト値              |
|-------------------------|----------|------------------------------------------------------------------------------------------------------------------------|---------------------|
| Protocol Setup          |          | Quad Based Protocol Mode,                                                                                              | Quad Based Protocol |
| r totocor Setup         |          | Channel Based Protocol Mode                                                                                            | Mode                |
| Quad Protocol Mode      | PROTOCOL | PCI Express, Gigabit Ethernet, Generic<br>8b10b, 10-bit SERDES Only, 8-bit SERDES<br>Only, SD-SDI, HD-SDI <sup>2</sup> |                     |
| Single                  | CH_MODE  | チャネルをイネーブル                                                                                                             | Disable             |
| MCA Group1 <sup>3</sup> | CH_MODE  | Multi-Channel Alignment Group 1                                                                                        | Disable             |
| MCA Group2 <sup>3</sup> | CH_MODE  | Multi-Channel Alignment Group 2                                                                                        | Disable             |
| Disable                 | CH_MODE  | チャネルをディセーブル                                                                                                            | Disable             |
| Channel Rate 1          | CH_MODE  | Full Rate, Half Rate                                                                                                   | Full Rate           |

- 1. Channel Rate選択はChannel Based Protocol Mode内のみに適用できます。
- 2. プロトコル属性名:PCI Express=PCIE、ギガビットイーサネット=GIGE、汎用8b10b=G8B10B、8ビット SERDES Only=8BSER、10ビットSERDES Only=10BSER、SD-SDI=SDSDI(HD-SDI=HDSDI)。
- 3. マルチチャネル・アライメント (MCA) は送信レーン間スキュー調整のためのものです。レシーバのMCA はハードPCSでは提供していません。MCA Group1とMCA Group2は、ユーザがFPGAコアでMCAを構築できるように、チャネルをCTCバイパスモードに設定します。マルチプロトコル・アプリケーションで、チャネルの識別に2つのグループを指定できます。

### 基準クロック・セットアップタブ

このタブでは、TxとRx基準クロックソースの属性を選択します。クワッドベースの場合、Rx基準クロックソースとして REFCLK か CORE\_RXREFCLK の選択、Tx 基準クロックソースとして REFCLK か CORE\_TXREFCLKを選択できます。クワッドベースでは、TxとRx共に全チャネルが共通の基準クロックソースを用います。また、特定のデータレートに必要なクロックレートと乗数の設定を提供するツールがあります。選択したデータバス幅に対して、クワッドをコアとインターフェイスするために必要なクロックレートを自動計算して表示します。

図8-23 コンフィグレーションGUI、基準クロック・セットアップタブ



LatticeECP2M 8-31 SERDES/PCS-UGJ

表8-10 SERDES\_PCS GUI属性(LatticeECP2M) - 基準クロック・セットアップタブ

| GUIテキスト                                                       | 属性名                                                                     | ボタン/ボッ<br>クスタイプ | 範 囲                      | デフォル<br>ト値 | コメント                                        |
|---------------------------------------------------------------|-------------------------------------------------------------------------|-----------------|--------------------------|------------|---------------------------------------------|
| Tx Reference Clock Source Selection                           | PLL_SRC                                                                 | Radio           | REFCLK,<br>CORE_TXREFCLK | REFCLK     |                                             |
| Rx Reference Clock<br>Source Selection                        | CH0_CDR_SRC,<br>CH1_CDR_SRC,<br>CH2_CDR_SRC,<br>CH3_CDR_SRC             | Radio           | REFCLK,<br>CORE_RXREFCLK | REFCLK     |                                             |
| Serial Bit Clock Rate<br>(GHz)                                | DATARANGE <sup>1</sup>                                                  | Check Box       | 0.27 ~ 3.125             | 2.5        | LOW:<br>MEDLOW:<br>MED:<br>MEDHIGH:<br>HIGH |
| Reference Clock<br>Multiplier                                 | CH0_REFCK_MULT,<br>CH1_REFCK_MULT,<br>CH2_REFCK_MULT,<br>CH3_REFCK_MULT | Drop Down       | 表8-11参照                  | 25X        |                                             |
| Calculated Reference<br>Clock Rate (MHz) <sup>2</sup>         | CP:REFCLK_RATE                                                          | Text Box        |                          |            | 編集不可                                        |
| FPGA Interface Data<br>Bus Width                              | CH0_DATA_WIDTH,<br>CH1_DATA_WIDTH,<br>CH2_DATA_WIDTH,<br>CH3_DATA_WIDTH | Drop Down       | 表8-11参照                  | 8          |                                             |
| Calculated FPGA<br>Interface Clock Rate<br>(MHz) <sup>2</sup> | CP:<br>FPGAINTCLK_RATE                                                  | Text Box        |                          |            | 編集不可                                        |

### 1. DATARANGE;

量産用デバイス; Low 500Mbps, 500 Mbps < Medlow 1.0 Gbps, 1.0 Gbps < Med < 2.0 Gbps, 2.0 Gbps Medhigh < 2.5 Gbps, 2.5 Gbps High 3.2 Gbps

エンジニアリング・サンプル; Low 540 Mbps, 540 Mbps < Medlow 1.0 Gbps, 1.0 Gbps < Med < 2.0 Gbps, 2.0 Gbps Medhigh < 2.5 Gbps, 2.5 Gbps High 3.2 Gbps

等価な制御レジスタとビットの詳細については表8-105を参照してください。

2. SERDES Only Modeは8ビットと10ビット共にリンク/コンマ・アラインと、8b10bエンコーダ/デコーダ、およびCTCをバイパスしますが、CDRはバイパスしません。

表8-11 プロトコルごとの基準クロック乗数とFPGAインターフェイス・データバス幅

| プロトコル              | 基準クロック乗数       | FPGAインターフェイス・<br>データバス幅 |
|--------------------|----------------|-------------------------|
| PCI Express        | 20X, 25X       | 8, 16                   |
| GbE                | 10XH, 10X, 20X | 8, 16                   |
| G8B10B             | 10XH, 10X, 20X | 8, 16                   |
| 10-bit SERDES Only | 10XH, 10X, 20X | 10, 20                  |
| 8-bit SERDES Only  | 8HX, 8X, 16X   | 8, 16                   |

LatticeECP2M 8-32 SERDES/PCS-UGJ

# 基準クロック・セットアップタブ(チャネルモード)

このタブでは、選択されたTx基準クロックは全チャンネルに共通ですが、チャネルモードでのRx基準クロックは、チャネルごとにREFCLKかCORE\_RXREFCLKのどちらかを選択できます。

図8-24 コンフィグレーションGUI - 基準クロック・セットアップタブ(チャネルモード)



ユーザがQuadタブでChannel Based Protocol Modeを選択して、いづれかのチャネルをハーフレートモードとして設定すると、このタブはハーフレートモード・クロックデータを表示します。

LatticeECP2M 8-33 SERDES/PCS-UGJ

### SERDESアドバンスト・セットアップ

このタブは、全4チャネル用のSERDESの送受信用アドバンスト属性にアクセスするために使用されます。 プリエンファシス、終端、差動出力電圧の選択などの送信用属性や、等化、終端、I/Oカップリングなどの受 信用属性が選択されます。また、SERDES送信クロックとPLLの属性も指定できます。

図8-25 コンフィグレーションGUI、SERDESアドバンスト・セットアップタブ



LatticeECP2M 8-34 SERDES/PCS-UGJ

表8-12 SERDES\_PCS GUI属性 (LatticeECP2M)、SERDESアドバンスト・セットアップタブ

| GUIテキスト                           |                                                        |                                                              | ボタン/ボ        | 範囲                                                                                                                                                                                                                |                                                                        | デフォル    |
|-----------------------------------|--------------------------------------------------------|--------------------------------------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|---------|
|                                   |                                                        | 属性名                                                          | ックスタ<br>イプ   | PCI Express,<br>GIGE                                                                                                                                                                                              | G8B10B, 8bSER<br>10bSER                                                | ト値      |
|                                   | LatticeECP2M-35<br>その他の全デバイ<br>ス                       | CH0_TDRV_AMP<br>CH1_TDRV_AMP<br>CH2_TDRV_AMP<br>CH3_TDRV_AMP | Drop<br>Down | 0(1040mV: default), 1(1280mV),<br>2 (1320mV), 3 (1360mV), 4 (640mV),<br>5 (760mV), 6 (870mV), 7 (990mV)<br>0(990mV: default), 1(1250mV),<br>2 (1300mV), 3 (1350mV), 4 (610mV),<br>5 (730mV), 6 (820mV), 7 (940mV) |                                                                        | 0       |
|                                   | LatticeECP2M-35<br>その他の全デバイ<br>ス                       | CH0_TX_PRE<br>CH1_TX_PRE<br>CH2_TX_PRE<br>CH3_TX_PRE         | Drop<br>Down | Disable, 0 (0%), 1<br>3 (40%), 4 (44%),<br>Disable, 0 (0%), 1<br>3 (30%), 4 (33%),                                                                                                                                | (16%), 2 (36%),<br>5 (56%), 6 (80%)<br>(12%), 2 (26%),                 | DISABLE |
|                                   | ination (Ohms) <sup>3</sup><br>端)                      | CH0_RTERM_TX<br>CH1_RTERM_TX<br>CH2_RTERM_TX<br>CH3_RTERM_TX |              | 50 75 5K                                                                                                                                                                                                          |                                                                        | 50      |
| Equalization<br>(等化)              | 1                                                      | CH0_RX_EQ<br>CH1_RX_EQ<br>CH2_RX_EQ<br>CH3_RX_EQ             | Drop<br>Down | Mid_High,<br>Long_High                                                                                                                                                                                            | Mid_Low,<br>Mid_Med<br>Mid_High,<br>Long_Low<br>Long_Med,<br>Long_High | DISABLE |
| Rx I/O Term<br>(受信I/O終            | iination (Ohms) <sup>3</sup><br>端)                     | CH0_RTERM_RX<br>CH1_RTERM_RX<br>CH2_RTERM_RX<br>CH3_RTERM_RX | Drop<br>Down | · 1 50 60 /5 F100                                                                                                                                                                                                 |                                                                        | 50      |
| Rx I/O Coup<br>(レシーバル             |                                                        | CH0_RX_DCC<br>CH1_RX_DCC<br>CH2_RX_DCC<br>CH3_RX_DCC         | Drop<br>Down | ·   A(, 1)(,                                                                                                                                                                                                      |                                                                        | AC 2    |
| Loss of Sign<br>(LOS検出間           | nal Threshold<br>閾値)                                   | LOS_THRESHOL<br>D                                            | Drop<br>Down | 0 (default), 1 (+10%), 2 (+15%),<br>3 (+25%), 4 (-10%),<br>5 (-15%), 6 (-25%), 7 (-30%)                                                                                                                           |                                                                        | 0       |
| Termination                       | eference Clock I/O<br>(Ohms) <sup>3</sup><br>長準クロック入力の | DII TEDM                                                     | Drop<br>Down | op 50.2K                                                                                                                                                                                                          |                                                                        | 50      |
| Coupling                          | eference Clock I/O<br>基準クロック入力の                        | DLL DCC                                                      | Drop<br>Down | Δι. 1)ι.                                                                                                                                                                                                          |                                                                        | AC      |
| PLL Loss of Lock<br>(PLLロックはずれ検出) |                                                        | PLL_LOL_SET                                                  | Drop<br>Down | Lock 0 (+/-600ppmx) 1 (+/-300ppm) 2 (+/-1500ppm) 3 (+/-4000ppm)                                                                                                                                                   | Unlock 0 (+/-1200ppm) 1 (+/-2000ppm) 2 (+/-2200ppm) 3 (+/-6000ppm)     | 0       |

<sup>1.</sup> 詳細については付録Dを参照してください。

LatticeECP2M 8-35 SERDES/PCS-UGJ

<sup>2.</sup> 内部のオンチップAC結合のコンデンサーTyp.値は5pFです。

<sup>3.</sup> 終端抵抗とその使い方 Rx I/O終端:

- 50: 現状ではSMTPE以外のプロトコルはすべて50 終端抵抗を用います。
- 60: 柔軟性の目的だけに提供します。
- 75: SMPTEは75 終端抵抗を用います。
- High: PCI Expressのレシーバ検出用など。

#### Tx I/O終端:

- 50: 現状ではSMTPE以外のプロトコルはすべて50 終端抵抗を用います。
- 75: SMPTEは75 終端抵抗を用います。
- 5K: PCI Expressの電気的アイドルやレシーバ検出のような場合。

#### Tx PLL終端:

- 50: PCB上に50 終端抵抗がない場合
- 2k: PCB上に50 終端抵抗がない場合

高速I/O終端トポロジーを図8-26に示します。

#### 図8-26 高速I/O終端



### PCSアドバンスト・セットアップ

このタブは、PCSの送受信全4チャネルのアドバンスト属性にアクセスするために使用されます。各TxとRx チャネルの極性や動作モード(例えば、8b10b)を個別に選択することができます。さらに、コンマ値やコンママスク、コンマアラインなどのワードアライメント指定や、CTCブロック用パラメータを設定するためにも用いられます。

LatticeECP2M 8-36 SERDES/PCS-UGJ

図8-27 コンフィグレーションGUI - PCSのアドバンスト・セットアップタブ



表8-13 SERDES/PCS GUI 'Range' - PCSのアドバンスト・セットアップタブ

| GUIテキスト                  | 属性名                 | 8b<br>SERDES<br>Only | 10b<br>SERDES<br>Only       | G8B10<br>B           | PCI<br>Express | GIGE | SD-SDI | HD-SDI     | Default    |
|--------------------------|---------------------|----------------------|-----------------------------|----------------------|----------------|------|--------|------------|------------|
| TX Invert                | CHx_TX_SB           |                      |                             | Nor                  | mal, Inve      | rt   |        |            | Normal     |
|                          | CHx_RX_SB           |                      |                             | INOI                 | IIIai, IIIvei  | ι    |        |            | Normal     |
|                          | CHx_8B10B           | Вур                  | Bypass Normal Bypass        |                      |                |      | pass   | Normal     |            |
| value                    | COMMA_A 4           |                      |                             |                      |                |      |        | 1100000101 |            |
| Minus Comma<br>Value     | COMMA_B⁴            | N/A                  | 注1                          |                      |                | N    | N/A    | 0011111010 |            |
| Comma Mask               | COMMA_M             |                      |                             |                      |                |      |        | 1111111111 |            |
| Comma Align <sup>2</sup> | CHx_COMMA_A<br>LIGN | Bypass               | Auto,<br>Dynamic,<br>Bypass | Auto,<br>Dynami<br>c | Au             | to   | Ву     | pass       | Auto       |
| CTC <sup>3</sup>         | CHx_CTC_BYP         | Bypass               | Normal, I                   | Bypass               | Norr           | mal  | Ву     | pass       | Normal     |
| CC_MATCH1                | CC_MATCH1           |                      |                             |                      |                |      |        |            | 000000000  |
| CC_MATCH2                | CC_MATCH2           |                      |                             | 注                    | ÷a             |      |        |            | 000000000  |
| CC_MATCH3                | CC_MATCH3           |                      |                             | /王                   | J              |      |        | I/A        | 0100011100 |
| CC_MATCH4                | CC_MATCH4           |                      |                             |                      |                |      |        |            | 0100011100 |
|                          | CC_MATCH_MO<br>DE   | N/A                  | MATCH_3_4                   |                      | MATC           | CH_4 |        |            | MATCH_4    |
| RX CTC Min IFG           | RX CTC Min IFG      |                      | 0, 1, 2, 3                  |                      |                |      | 0      |            |            |
| High Watermark           | CCHMARK             |                      |                             | 0.1.2 14.15          |                |      |        | 9          |            |
| Low Watermark            | CCLMARK             |                      |                             | 0, 1, 2,, 14, 15     |                |      |        | 7          |            |

<sup>1.</sup> 詳細な情報はこのドキュメントの"ワードアラインメント"セクションを参照してください。

LatticeECP2M 8-37 SERDES/PCS-UGJ

- 2. 表8-7を参照してください。
- 3. 詳細な情報はこのドキュメントの"クロックトレランス補償"セクションを参照してください。
- 4. 定義上、COMMA\_AとCOMM\_Bは正と負のランニング・ディスパリティがある1組の8b10bコード化された制御キャラクタです。例えば、一つのデザインでBC(K28.5)とFD(K29.7)をCOMMA\_AとCOMM\_Bとして用いることはできません。8ビットモードと16ビットモードでのCOMM\_AとCOMM\_Bの使用法は全く同じです。ユーザはIs\_syncを得るためには規則に従う必要があります。例えば、1GbEがIDLEとなる(ワードアライメントと同期ステートマシン)にはK28.5+D5.6かD16.2が必要です。

#### オプションのセットアップ

このタブは、チャネルあたりのダイナミック・ロジック反転とダイナミックな外部リンクステートマシン機能を選択するのに用いられます。さらにユーザはSCI、エラーレポート、PLLの4分周クロック、およびループバック機能をイネーブルすることができます。

図8-28 コンフィグレーションGUI - オプションのセットアップタブ



表8-14 Tab5、SERDES\_PCS GUI属性(LatticeECP2M) - オプションのセットアップタブ

| GUIテキスト                           | 属性名                                | ボタン/ボッ<br>クスタイプ | 範囲                                                               | デフォル<br>ト値         |
|-----------------------------------|------------------------------------|-----------------|------------------------------------------------------------------|--------------------|
| Dynamic Inversion of Receive Data |                                    | Check Box       | TRUE, FALSE                                                      | FALSE              |
| External Link State Machine       |                                    | Check Box       | TRUE, FALSE                                                      | FALSE              |
| Loopback (Rx to Tx)               |                                    | Check Box       | TRUE, FALSE                                                      | FALSE              |
| Loopback Type                     | OS_SSLB OS_SPLBPORTS OS_PCSLBPORTS | Radio Box       | Serial Loopback, SERDES Parallel Loopback, PCS Parallel Loopback | Serial<br>Loopback |
| Reference Clock to FPGA Core      | OS_REFCK2CORE                      | Check Box       | TRUE, FALSE                                                      | FALSE              |
| PLL Quarter Clock                 | OS_PLLQCLKPORTS                    | Check Box       | TRUE, FALSE                                                      | FALSE              |
| SCI                               |                                    | Check Box       | TRUE, FALSE                                                      | FALSE              |

LatticeECP2M 8-38 SERDES/PCS-UGJ

| SCI Interrupt | OS_INT_ALL | Check Box | TRUE, FALSE | FALSE |
|---------------|------------|-----------|-------------|-------|
| Error Status  |            | Check Box | TRUE, FALSE | FALSE |

#### コンフィグレーション(自動構成)ファイル記述

IPexpressは属性レベルのマッピング情報を含むこのファイルを生成します。自動構成ファイルはファイルタイプ拡張子として "txt" を用います。

以下にファイル例を示します。

```
# This file is used by the simulation model as well as the ispLEVER bitstream
# generation process to automatically initialize the PCSC quad to the mode
# selected in the IPexpress. This file is expected to be modified by the
# end user to adjust the PCSC quad to the final design requirements.
DEVICE NAME "LFE2M35E"
PROTOCOL "G8B10B"
CHO MODE "SINGLE"
CH1 MODE "DISABLE"
CH2 MODE "DISABLE"
CH3 MODE "DISABLE"
PLL SRC "REFCLK"
DATARANGE "HIGH"
CHO CDR SRC "REFCLK"
CHO DATA WIDTH "8"
CHO REFCK_MULT "10X"
#REFCLK_RATE 250.0
#FPGAINTCLK RATE 250.0
CHO TDRV AMP "0"
CHO TX PRE "DISABLE"
CHO_RTERM_TX "50"
CHO_RX_EQ "DISABLE"
CHO_RTERM_RX "50"
CHO_RX_DCC "AC"
LOS_THRESHOLD "0"
PLL TERM "50"
PLL DCC "AC"
PLL LOL SET "0"
CHO TX SB "NORMAL"
CHO RX SB "NORMAL"
CHO 8B10B "NORMAL"
COMMA A "1100000101"
COMMA B "0011111010"
COMMA " 1111111111"
CHO COMMA ALIGN "AUTO"
CHO CTC BYP "BYPASS"
CC MATCH1 "000000000"
CC MATCH2 "000000000"
CC MATCH3 "0100011100"
CC_MATCH4 "0100011100"
CC_MATCH_MODE "MATCH 4"
CC MIN IPG "0"
CCHMARK "4"
CCLMARK "4"
OS REFCK2CORE "0"
OS PLLQCLKPORTS "0"
```

### モード特有の制御/ステータス信号

モードに依存する制御/ステータス信号名は、選択されたPCSモードで決定されます。表8-15は24ビット・デ

LatticeECP2M 8-39 SERDES/PCS-UGJ

ータバスの使い方を説明します。表8-16はすべてのIPexpress GUIで選択可能なPCSモードの制御/ステータス信号のポート名を示します。

表8-15 データバスの用途

| データバス                | I/O   | 信号名     | 記述                              |
|----------------------|-------|---------|---------------------------------|
| 送受信データバス;            | 8ビット  | バス      |                                 |
| ff_rxdata_ch0[7:0]   | 0     | 受信データバス | チャネルごと、FPGAへの8ビット受信並列データバス      |
| ff_rxdata_ch0[11:8]  | 0     | 表8-16参照 | モード特有の受信ステータスビット                |
| ff_rxdata_ch0[23:12] | 0     |         | 16ビットモード用予約                     |
| ff_txdata_ch0[7:0]   | I     | 送信データバス | チャネルごと、FPGAからの8ビット送信並列データバス     |
| ff_txdata_ch0[11:8]  | I     | 表8-16参照 | モード特有の送信制御ビット                   |
| ff_txdata_ch0[23:12] | I     |         | 16ビットモード用予約                     |
| 送受信データバス;            | 16ビット | トバス     |                                 |
| ff_rxdata_ch0[7:0]   | 0     | 受信データバス | チャネルごと、FPGAへの第一8bデータ用受信並列データバス  |
| ff_rxdata_ch0[11:8]  | 0     |         | モード特有の第一8bデータ用の受信ステータスビット       |
| ff_rxdata_ch0[19:12] | 0     | 受信データバス | チャネルごと、FPGAへの第二8bデータ用受信並列データバス  |
| ff_rxdata_ch0[23:20] | 0     |         | モード特有の第二8bデータ用の受信ステータスビット       |
| ff_txdata_ch0[7:0]   | I     | 送信データバス | チャネルごと、FPGAからの第一8bデータ用送信並列データバス |
| ff_txdata_ch0[11:9]  | I     |         | モード特有の第一8bデータ用の送信制御ビット          |
| ff_txdata_ch0[19:12] | I     | 送信データバス | チャネルごと、FPGAからの第二8bデータ用送信並列データバス |
| ff_txdata_ch0[23:20] | I     |         | モード特有の第二8bデータ用の送信制御ビット          |

注: チャネル0を示します。他のすべてのチャネルが同様に割り当てられます。

#### 表8-16 モード特有の制御/ステータス信号名

#### 受信データステータス信号、8ビットバス

| モード              | ff_rxdata_ch0[8]  | ff_rxdata_ch0[9] | ff_rxdata_ch0[10] | ff_rxdata_ch0[11] |
|------------------|-------------------|------------------|-------------------|-------------------|
| GbE, OBSAI, CPRI | ff_rx_k_cntrl_ch0 | ff_disp_err_ch0  | ff_cv_ch0         | ff_rx_even_ch0    |
| FC, SRIO, G8B10B | ff_rx_k_cntrl_ch0 | ff_disp_err_ch0  | ff_cv_ch0         | NA                |
| XAUI             | ff_rxc_ch0        | ff_disp_err_ch0  | ff_cv_ch0         | NA                |
| PCI Express      | ff_rx_k_cntrl_ch0 |                  |                   |                   |

### 送信データ制御信号、8ビットバス

| モード              | ff_txdata_ch0[8]  | ff_txdata_ch0[9]  | ff_txdata_ch0[10] | ff_txdata_ch0[11]   |
|------------------|-------------------|-------------------|-------------------|---------------------|
| GbE, OBSAI, CPRI | ff_tx_k_cntrl_ch0 | NA                | ff_xmit_ch0       | ff_correct_disp_ch0 |
| FC, SRIO         | ff_tx_k_cntrl_ch0 | ff_force_disp_ch0 | ff_disp_sel_ch0   | NA                  |
| XAUI             | ff_txc_ch0        | NA                | NA                | NA                  |
| PCI Express      | ff_tx_k_cntrl_ch0 | ff_force_disp_ch0 | ff_disp_sel_ch0   | ff_pci_ei_en_ch0    |
| G8B10B           | ff_tx_k_cntrl_ch0 | ff_force_disp_ch0 | ff_disp_sel_ch0   | ff_correct_disp_ch0 |

#### モード特有の制御/ステータス信号記述

表8-17はモード特有の制御/ステータス信号について説明します。

LatticeECP2M 8-40 SERDES/PCS-UGJ

#### 表8-17 制御信号とそれらの機能

| 信号名                          | 記述                                                                                 |
|------------------------------|------------------------------------------------------------------------------------|
| 送信制御信号                       |                                                                                    |
| ff_tx_k_cntrl_ch[3:0]        | チャネルごと、Highアクティブの制御キャラクタ・インジケータ。                                                   |
| ff_force_disp_ch[3:0]        | チャネルごと、Highアクティブの信号で、ff_disp_sel_ch(0-3)FPGAインターフェイス入力からのディスパリティ値を受け入れるようPCSに指示する。 |
| ff_disp_sel_ch[3:0]          | チャネルごとで、ディスパリティ値はFPGAロジックから与えられる。<br>ff_force_disp_ch(0-3)がhighのときに有効。             |
| ff_correct_disp_ch[3: 0]     | パケット間ギャップが負のディスパリティ·ステートで始まることを保証するために使用される。                                       |
| 受信ステータス信号                    |                                                                                    |
| ff_rx_k_cntrl_ch[3:0]        | チャネルごと、Highアクティブの制御キャラクタ・インジケータ。                                                   |
| ff_disp_error_detect_ch[3:0] | チャネルごと、PCSからドライブされるhighアクティブの信号で、関連するデータにディスパリティ・エラーが検出されたことを示す。                   |
| ff_cv_detect_ch[3:0]         | チャネルごと、Highアクティブのコードバイオレーション検出。                                                    |

1. 詳細な情報はこのドキュメントの "ギガビット・イーサネットモードのLatticeECP2M PCS" セクションを参照してください。

Generic 8b10b(G8B10B)モードにおけるデータと制御/ステータスビットのマッピング例:

```
8-bit mode
.FF TX D 0 0(ff txdata ch0[0]),
.FF TX D 0 3 (ff txdata ch0[3]),
.FF_TX_D_0_4(ff_txdata_ch0[4]),
.FF_TX_D_0_5(ff_txdata_ch0[5]),
.FF_TX_D_0_6(ff_txdata_ch0[6]),
.FF_TX_D_0_7(ff_txdata_ch0[7]),
.FF_TX_D_0_8(ff_tx_k_cntrl_ch0[0]),
.FF_TX_D_0_9(ff_force_disp_ch0[0]),
.FF TX D_0_10(ff_disp_sel_ch0[0]),
.FF_TX_D_0_11(ff_correct_disp_ch0[0]),
.FF_TX_D_0_12(fpsc_vlo),
.FF TX D 0 13 (fpsc vlo),
.FF_TX_D_0_14(fpsc_vlo),
.FF_TX_D_0_15(fpsc_vlo), .FF_TX_D_0_16(fpsc_vlo),
.FF_TX_D_0_17(fpsc_vlo),
.FF_TX_D_0_18(fpsc_vlo), .FF_TX_D_0_19(fpsc_vlo),
.FF TX D 0 20 (fpsc vlo),
.FF_TX_D_0_21(fpsc_vlo),
.FF_TX_D_0_22(fpsc_vlo),
.FF_TX_D_0_23(fpsc_vlo),
.FF_RX_D_0_1(ff_rxdata_ch0[0]),
.FF_RX_D_0_1(ff_rxdata_ch0[1]),
.FF_RX_D_0_2(ff_rxdata_ch0[2]),
.FF RX D 0 3 (ff rxdata ch0[3]),
.FF_RX_D_0_4(ff_rxdata_ch0[4]),
.FF_RX_D_0_5(ff_rxdata_ch0[5]),
.FF RX D 0 6 (ff rxdata ch0[6]),
.FF_RX_D_0_9(ff_rxdata_ch0[7]),
.FF_RX_D_0_8(ff_rx_k_cntrl_ch0[0]),
.FF_RX_D_0_9(ff_disp_err_ch0[0]),
.FF RX D 0 10 (ff cv ch0 \overline{[0]}),
.FF_RX_D_0_11(fpsc_vlo),),
.FF_RX_D_0_12(fpsc_vlo),
.FF RX D 0 13 (fpsc vlo),
.FF_RX_D_0_14(fpsc_vlo), .FF_RX_D_0_15(fpsc_vlo),
```

LatticeECP2M 8-41 SERDES/PCS-UGJ

```
.FF_RX_D_0_16(fpsc_vlo),
.FF_RX_D_0_17(fpsc_vlo),
.FF_RX_D_0_18(fpsc_vlo),
.FF_RX_D_0_19(fpsc_vlo),
.FF_RX_D_0_20(fpsc_vlo), .FF_RX_D_0_21(fpsc_vlo),,
.FF RX D 0 22(fpsc vlo),
.FF_RX_D_0_23(fpsc_vlo),
16-bit mode
.FF TX D 0 0(ff txdata ch0[0]),
.FF TX D 0 3 (ff txdata ch0[3]),
.FF_TX_D_0_4(ff_txdata_ch0[4]),
.FF_TX_D_0_5(ff_txdata_ch0[5]),
.FF_TX_D_0_6(ff_txdata_ch0[6]),
.FF TX D 0 7(ff txdata ch0[7]),
.FF_TX_D_0_8(ff_tx_k_cntrl_ch0[0]),
.FF_TX_D_0_9(ff_force_disp_ch0[0]),
.FF TX D_0_10(ff_disp_sel_ch0[0]),
.FF_TX_D_0_11(ff_correct_disp_ch0[0]),
.FF_TX_D_0_12(ff_txdata_ch0[8]),
.FF_TX_D_0_13(ff_txdata_ch0[9]),
.FF_TX_D_0_14(ff_txdata_ch0[10]),
.FF_TX_D_0_15(ff_txdata_ch0[11]), .FF_TX_D_0_16(ff_txdata_ch0[12]),
.FF TX D 0 17(ff txdata ch0[13]),
.FF_TX_D_0_18(ff_txdata_ch0[14]),
.FF_TX_D_0_19(ff_txdata_ch0[15]),
.FF_TX_D_0_20(ff_tx_k_cntrl_ch0[1]),
.FF_TX_D_0_21(ff_force_disp_ch0[1]),
.FF_TX_D_0_22(ff_disp_sel_ch0[1]),
.FF_TX_D_0_23(ff_correct_disp_ch0[1]),
.FF_RX_D_0_0(ff_rxdata_ch0[0]),
.FF_RX_D_0_1(ff_rxdata_ch0[1]),
.FF_RX_D_0_2(ff_rxdata_ch0[2]),
.FF_RX_D_0_3 (ff_rxdata_ch0[3]),
FF_RX_D_0_5(ff_rxdata_ch0[4]),
FF_RX_D_0_5(ff_rxdata_ch0[5]),
FF_RX_D_0_6(ff_rxdata_ch0[6]),
.FF_RX_D_0_7(ff_rxdata_ch0[7]),
.FF_RX_D_0_8(ff_rx_k_cntrl_ch0[0]),
.FF_RX_D_0_9(ff_disp_err_ch0[0]),
.FF_{RX}D_0_{10}(ff_{cv}ch0[0]),
.FF_RX_D_0_11(),
.FF_RX_D_0_12(ff_rxdata_ch0[8]),
.FF_RX_D_0_13(ff_rxdata_ch0[9]),
FF RX D 0 14 (ff rxdata ch0[10]),
FF RX D 0 15 (ff rxdata ch0[11]),
FF RX D 0 16 (ff rxdata ch0[11]),
.FF_RX_D_0_17(ff_rxdata_ch0[13]),
.FF_RX_D_0_18(ff_rxdata_ch0[14]),
.FF_RX_D_0_19(ff_rxdata_ch0[15]),
.FF_RX_D_0_20(ff_rx_k_cntrl_ch0[1]),
.FF_RX_D_0_21(ff_disp_err_ch0[1]),
.FF_RX_D_0_22(ff_cv_ch0[1]),
.FF_RX_D_0_23(),
```

### ギガビット・イーサネットモードのLatticeECP2M PCS

### ギガビット・イーサネット(1000BASE-X)のアイドル挿入

アイドルパターンの挿入がクロック補償と自動ネゴシエーションには必要です。自動ネゴシエーションは FPGAロジックで行われます。このモジュールは自動ネゴシエーションの間、自動的に /l2/ シンボルを受信 データストリームの中に挿入します。自動ネゴシエーション中、リンクパートナは連続して /C1/ と /C2/ の

LatticeECP2M 8-42 SERDES/PCS-UGJ

オーダーセットを送信するでしょう。クロック補償回路はこれらのオーダーセットを削除せず、/l2/ オーダーセットのみを挿入するか、または削除するように構成されています。クロック補償回路におけるオーバーランとアンダーランを防ぐため、挿入/削除する機会をクロック補償回路に与えるように定期的に /l2/ オーダーセットを挿入しなければなりません。

自動ネゴシエーションを実行している間、このモジュールは2048クロックサイクル毎に8回の /l2/ オーダーセット(それぞれ2バイト)シーケンスを挿入します。このモジュールは8b10bデコーダの後にあるため、この動作はどのようなランニング・ディスパリティ誤りを生起することはありません。GMIIインターフェイスは、自動ネゴシエーションの間、RxステートマシンによってIDLEステートに置かれるので、/l2/ オーダーセットがFPGA受信インターフェイスに送られることはありません。自動ネゴシエーションがいったん完了すると、受信データのいかなるエラーをも防ぐために、/l2/ 挿入はディセーブルされます。

このステートマシンは自動ネゴシエーションの間だけアクティブであることに留意してください。自動ネゴシエーション・ステートマシンとGbE受信ステートマシンはソフトロジックで実装されています。GbE受信ステートマシンは自動ネゴシエーション・ステートマシンからの(Txデータバス上の)信号ff\_xmit\_ch[3:0]に依存します。この信号は、特に自動ネゴシエーションの後は比較的スタティックです。GbE受信ステートマシンからは、FPGAロジック用のrx\_even\_ch[3:0]信号が受信データバス上に出力されます。

表8-18 主要なGbE IDLEステートマシン制御 / ステータス信号

| モジュール信号         | 方向 | 記述                                                                                       |
|-----------------|----|------------------------------------------------------------------------------------------|
| ff_xmit_ch[3:0] | 入力 | FPGAロジックの自動ネゴシエーション・ステートマシンから                                                            |
| rx_even_ch{3:0} | 出力 | rx_evenインジケータ入力(GbEリンクステートマシンから)<br>rx_evenインジケータ出力(FPGAロジック内の自動ネゴシエーションと受信<br>ステートマシンへ) |

### ギガビット・イーサネットのアイドル挿入とff\_correct\_disp\_ch[3:0]信号の使い方

QuadPCSの送信側でff\_correct\_disp\_ch[3:0]信号が用いられ、パケット間ギャップが負のディスパリティ状態で始まることを確実にします。イーサネットフレームのサイズとデータ内容によって、その終わりではトランスミッターのディスパリティ状態は正も負もあり得ることに留意してください。しかしながら、QuadPCSのFPGAソフトロジック側からは、QuadPCSトランスミッターの現在のディスパリティ状態は未知です。これはff\_correct\_disp\_ch[3:0]信号が役割を果たすところです。パケット間ギャップに入るとき、ff\_correct\_disp\_ch[3:0]信号がクロックの1周期間アサートされると、現在のディスパリティが正である場合は、QuadPCSトランスミッターに対して、送信データストリームにIDLE1オーダーセットを挿入するように強制します。しかしながら、現在のディスパリティが負の場合、送信データストリームは何も変更されません。

QuadPCSのFPGAソフトロジック側からは、パケット間ギャップは通常以下の通りIDLE2オーダーセットの連続伝送で特徴付けられます。

 $ff_tx_k_cntrl_ch3:0=1, \ ff_tx_data=0xBC, \ ff_tx_k_cntrl_ch3:0=0, \ ff_tx_data=0x50$ 

PCSチャネルでは、IDLE2は現在のディスパリティが保持されることに留意してください。IDLE1は、現在のディスパリティ状態が反転されるべきであることを意味します。したがって、パケット間ギャップが負のディスパリティ状態で始まることを確実にすることは有り得ます。パケット間ギャップ前のディスパリティ状態が負であるなら、パケット間ギャップギャップの間、連続したIDLE2のストリームを送信します。パケット間ギャップ前のディスパリティ状態が正であるなら、単一IDLE1がIDLE2の連続ストリームの後に送信されます。

QuadPCSのFPGAソフトロジック側では、パケット間ギャップは常にIDLE2と共にQuadPCSにドライブさ

LatticeECP2M 8-43 SERDES/PCS-UGJ

れます。パケット間ギャップが最初に始まるとき、k\_cntrl=0、data=0x50、そしてff\_correct\_disp\_ch[3:0]信号がクロックの1周期アサートされます。必要であれば、QuadPCSはこのIDLE2をIDLE1に変換します。パケット間ギャップの残りにおいては、QuadPCSにはIDLE2がドライブされるべきで、そしてff\_correct\_disparity\_chx信号はネゲートされたままです。

### PCI ExpressモードのLatticeECP2M PCS

IPexpressでPCI Expressモードに設定されたLatticeECP2Mクワッドには、仕様によって必要とされるレシーバ検出などの電気的機能をイネーブルするために、FPGAインターフェイスに追加ポートがあります。表8-19はPCI Expressモードに特有のポートについて説明します。

表8-19 PCI Express モード特有のポート

| 信号                      | 方向 | クラス                      | 記述                                                                                                   |
|-------------------------|----|--------------------------|------------------------------------------------------------------------------------------------------|
| ffs_pcie_done_ch[3:0]   | 0  | チャネル                     | 1 = 遠端レシーバの検出完了<br>0 = 遠端レシーバ検出の結果が不成功(未完了)                                                          |
| ffs_pcie_con_ch[3:0]    | 0  | チャネル                     | 1 = 遠端レシーバの検出<br>0 = 遠端レシーバの不検出                                                                      |
| ffc_pcie_det_en_ch[3:0] | ı  | エックリ.                    | FPGAロジック(ユーザロジック)はPCI Expressレシーバ検出動作の要求をSERDESブロックに通知する。<br>1 = PCI Expressレシーバ検出をイネーブル<br>0 = 通常動作 |
| ffc_pcie_ct_ch[3:0]     | I  | 1 <del>1 1 2</del> 2 11, | 1 = トランスミッターに遠端レシーバ検出を要求<br>0 = 通常のデータ動作                                                             |
| ffc_ei_en_ch[3:0]       | I  |                          | SERDESトランスミッターから電気的アイドルの伝送を制御。<br>1 = 電気的アイドル状態を出力するようにSERDESトランスミッ<br>ターを強制<br>0 = 通常動作             |

LatticeECP2M 8-44 SERDES/PCS-UGJ

#### レシーバ検出

図8-29はレシーバ検出シーケンスを示します。

クワッドの各チャネルでレシーバ検出テストを独立して実行することができます。レシーバ検出テストを始める前に、ff\_pci\_ei\_en\_ch入力をHighに設定することによって、トランスミッターを電気的アイドルにしなければなりません。ffc\_pci\_det\_en\_chをHighにすることによって、tx\_elec\_idleがHighに設定された120ns後にレシーバ検出テストを始めることができます。これはドライバ終端をハイインピーダンスに設定し、またハイインピーダンス・ドライバ終端で差動の両出力をVCCOBにプルすることによって、対応するSERDES送信バッファをレシーバ検出モードにします。

SERDES送信バッファをレシーバ検出ステートに設定するには最大120nsかかります。その後チャネルのffc\_pcie\_ct\_ch入力を4バイト(ワード)クロック周期間Highにドライブすることによって、レシーバ検出テストを開始することができます。対応するチャネルのffc\_pcie\_done\_chは非同期にクリアされます。レシーバ検出テストが終わるのに十分な時間が経過した後(送信側の時定数で決まる)、ffs\_pcie\_done\_chレシーバ検出ステータスポートはHighになり、ffs\_pcie\_con\_chポートでレシーバ検出ステータスをモニターすることができます。その時ffs\_pcie\_con\_chポートがHighであればレシーバはそのチャネルで検出され、ポートがLowならそのチャネルでレシーバは全く検出されていません。レシーバ検出テストがいったん完全すると、ff pci ei en chをネゲートすることができます。

#### 図8-29 PCI Express モード、レシーバ検出シーケンス(チャネルのの例)



#### PCI Expressビーコンのサポート

このセクションではLatticeECP2M PCSがビーコン検出と送信をどのようにサポートすることができるかを ハイライトします。PCI Expressのビーコン検出の要件は、PCSによるビーコン送信とビーコン検出のサポートで与えられます。

- ・ビーコン検出要件 (PCI Express Base Specification, Rev 1.0a, Chapter 4, pp.209-210)
  - L2(P2)ステートから抜けるにはビーコンが必要です。
  - ビーコンは周期的な任意データのDCバランスがとれている信号で、2ns(500Mhz)以上と16us(30Khz) 未満のいくつかのパルス幅を含む必要があります。
  - パルス間の最大時間は16us未満でなければなりません。
  - DCバランスは32us未満に回復される必要があります。

LatticeECP2M 8-45 SERDES/PCS-UGJ

- 500ns以上のパルス幅に関しては、出力ビーコン電圧レベルは $V_{TX-DIFFp-p}(800mV)$ から1200mV)から6dB低くなければなりません。
- 500ns以下のパルス幅に関しては、出力ビーコン電圧レベルはV<sub>TX-DIFFp-p</sub>以下で、かつ3.5dB低いレベル 以上でなければなりません。

#### ・PCSビーコン検出サポート

- 信号ロス(LOS)閾値検出回路は、指定された電圧レベルが受信バッファに存在するかどうかを探知します。これはffs\_rlos\_lo\_ch(0-3)信号によって示されます。
- PCI Express電気的アイドル検出と(パワーステートP2での)PCI Expressビーコン検出にこの設定を用いることができます。
- リモート送信デバイスはV<sub>TX-DIFFpp</sub>から6dB低いビーコン出力電圧(即ち201mV)を持つことができます。 この信号を検出することができれば、ビーコンが検出されたと言うことができます。

#### ・PCSビーコン送信のサポート

- K28.5(IDLE)キャラクタ( 5連続の1と続く5連続の0 )を送出すると、2nsの周期的なパルス(1.0UI=400ps で、5倍すると2 ns)を発生することになります。これは下側の要件を満たします。このとき出力ビーコン電圧レベルは $V_{TX-DIFFp-p}$ であり得ます。これは有効なビーコン送信です。

### PCSループバック・モード

LatticeECP2Mファミリ・デバイスは3つのループバック・モードを提供し、PCS/FPGAロジック・インターフェイスの制御信号によって制御されます。これはSERDES外部/ボード・インターフェイスと内部PCS/FPGAロジック・インターフェイスのテストに便利です。3つのループバック・モードは受信したデータを送信データパスに戻すために用意されています。ループバック・モードは、組み込みSERDESやPCSロジックのチェックと共に、高速シリアルSERDESのパッケージピン接続をチェックする為に有用です。

#### シリアル・ループバック・モード

シリアルの受信クロック/データを、CDRやデシリアライザを通さないで、送信バッファにループバックします。この機能はラティス社内でのテスト目的のために用意されていますが、ユーザも使用できます。

IPexpress GUIのシリアル・ループバック・オプションを選択すると、LB\_CTL[3:0]のみが0010に設定されます(表8-82を参照してください)。

また、TDRV\_DAT\_SEL[1:0]レジスタビットは、シリアル・ループバック・モードをイネーブルするために SCIを介して11に設定します。また、LB\_CTL[3:0]レジスタビットもSCIを通してアクセスできます。

#### SERDESパラレル・ループバック・モード

PCSロジックを通さないで、パラレル受信データを送信データパスにループバックします。各チャネル用に適切なffc\_sb\_pfifo\_lp\_ch(0-3)を 1 に設定することによって、個別にSERDESパラレル・ループバックを選択することができます。

#### PCSパラレル・ループバック・モード

PCS/FPGAインターフェイス内を通さないで、パラレル受信データを送信データパスにループバックします。 SERDES HDINパッケージピンからのシリアルデータ入力は、SERDES受信ロジックを通り、パラレルデータに変換され、PCS受信ロジックパス全体を通り、次いでPCS送信ロジックパス全体を通してループバックされます。その後SERDESトランスミッターによってシリアルデータに再変換され、HDOUT SERDESパッケージピンに送られます。各チャネル用に適切なffc\_fb\_loopback\_ch(0-3)ポートを1に設定することによって、

LatticeECP2M 8-46 SERDES/PCS-UGJ

個別にPCSパラレル・ループバックを選択することができます

図8-30は単一チャネル用の3つのループバックモードを図示します。

#### 図8-303つのループバック・モード



上述した2つのパラレル・ループバック・モードは、FPGAコアからの制御信号だけでなく制御レジスタビットでも設定できます。制御レジスタビットがループバック・モードに設定されるとき、データパスはFPGAコアからの制御信号でループバック・モードとノーマル・データフローを切り換えることができます。図8-31はこのロジックについて説明します。詳細なレジスタ設定は表8-82と表8-83を参照してください。

#### 図8-31 ループバック・イネーブル信号



LatticeECP2M 8-47 SERDES/PCS-UGJ

### FPGAインターフェイス・クロックの使い方

図8-32は概念図で、PCSコアとFPGAブリッジの後半ステージと、PCSとFPGAの境界にまたがる主要なクロックを示します。

図8-32 概念的なPCS/FPGAクロック・インターフェイス図



上図とこのセクションの各図中、接尾語 "i" がインデックス[0:3]、すなわち各チャネルの1つを示すことに留意してください。

クロックが細くなったりグリッチが出ることを防ぐロジックは、クロック・マルチプレクサのいずれも持っていません。レジスタビットへのライトによってクロック・マルチプレクサへのセレクタのどれかが変更された場合、そのマルチプレクスされたクロックによって動作するロジックをリセットすることはソフトウェア・エージェントの要件です。

PCSは15本のクロックを出力します。クワッドあたり3本の送信クロックと、4チャネル分で12本の受信クロックがあります。3本の送信クロックは、フルレート、ハーフレート、およびクオータレート・クロックで、全てTx PLLから生成されます。フルレートとハーフレート送信クロックは、FPGA中央のクロック・マルチプレクサへの専用配線で直接接続される必要があります。また受信チャネルにもそれぞれ3本のクロック(フル/ハーフ/クオータ・レート)があります。FPGAロジックに必要に応じてローカル(セカンダリ)かグローバル(プライマリ)クロックとして15本のクロックをすべて用いることができます。ギアリング(クワッドベースのみで選択可能)が2:1のモードであるとき、2分周クロックが使用されます。

送信クロックはアップサンプルFIFO(場合によっては位相シフトFIFO)のライトポートで用いられます。2本の受信クロックの1つはダウンサンプルFIFOのリードクロックに接続されます。他方のクロックはエラスティック・バッファFIFOのリードポートと、(場合により)潜在的にダウンサンプルFIFOのライトポートのクロ

LatticeECP2M 8-48 SERDES/PCS-UGJ

ックになります。

エラスティック・バッファとアップサンプルFIFOがバイパスされるかどうかと、8b10bモードか16b20bモードかによって、4つのケースが有り得ます。(図8-33~36の各図で)アクティブなパスはハイライトされています。また何本の、どのようなクロックツリーが必要であるかも示されています。一般的にユーザがより好むいくつかのモードがあります。

このセクションはサポートされる4つの異なるケースの動作について、表8-20で概説しています。

表8-20 SERDES/PCSクワッドとFPGAコア間インターフェイスの6つのケース

| インターフェイス    | データ幅   | Rx CTC FIFO | Rx位相シフト/ダウン<br>サンプルFIFO | Tx位相シフト/アップサ<br>ンプルFIFO |
|-------------|--------|-------------|-------------------------|-------------------------|
| Case I-a 1  | 8b10b  | Yes         | Yes                     | Yes                     |
| Case I-b 1  | 8b10b  | Bypass      | Yes                     | Yes                     |
| Case II-a 1 | 16b20b | Yes         | Yes                     | Yes                     |
| Case II-b 1 | 16b20b | Bypass      | Yes                     | Yes                     |

<sup>1.</sup> すべての場合でTx位相シフト(アップサンプル)FIFOはバイパスされません。SERDES/PCSブロック内部のデータパス幅は8/10ビットであり、バイトクロックはSERDESラインレートの1/10で動作します。例えばSERDESラインレートが3.125Gbpsである場合、バイトクロックは312.5MHzです。

#### 2対1ギアリング

FPGAグローバル・クロックツリーの性能を保証するために、2.5Gbpsより速いSERDESラインレートでは 16/20ビットのインターフェイスを用いることを推奨します。このインターフェイスでは、FPGAインターフェイス・クロックはバイトクロック周波数の半分です。

バイトクロック周波数の半分で動作する16/20ビット幅インターフェイスはすべてのSERDESラインレートで用いることができますが、SREDESラインレートが低く(2.5Gbps以下)、許容することができる場合は8/10ビット幅インターフェイスが好ましいでしょう。というのは、これがFPGAコア内のIPに最も効率的な実装という結果をもたらすためです。

6つのインターフェイスケースを決定するためのマトリクスを表8-21で説明しています。

表8-21 6インターフェイス決定のためのマトリクス

| SERDESラインレート       | データパス幅     | MCA必要性             | CTC必要性        | インターフェイ<br>ス・ケース       |
|--------------------|------------|--------------------|---------------|------------------------|
|                    |            | なし,                | あり            | Case I_a <sup>1</sup>  |
| 2.5Gbpsかそれ以下       | 8/10ビット    | シングルチャネル・リンク       | なし            | Case I_b <sup>2</sup>  |
| 2.300p3/3, C10/3 k | (1:1ギアリング) | あり,<br>マルチチャネル・リンク | バイパス必須(CTCなし) | Case I_b <sup>3</sup>  |
| 3.2Gbpsかそれ以下       |            | なし,                | あり            | Case II_a 4            |
|                    | 16/20ビット   | シングルチャネル・リンク       | なし            | Case II_b <sup>5</sup> |
|                    | (2:1ギアリング) | あり,<br>マルチチャネル・リンク | バイパス必須(CTCなし) | Case II_b <sup>6</sup> |

<sup>1.</sup> このケースは、クワッド内でCTCを必要とする2.5Gbpsかそれ以下のラインレート(8/10ビット幅インターフェイス)の単一チャネルリンクを意図します。相互に+/-300ppm以内にある基準クロックソースがリンクの両端にあるときはCTCが必要です。コア内のIPがRx位相シフトFIFOを必要とするなら、Case I\_aが使用されます。コア内のIPがRx位相シフトFIFOを必要としないなら、Case I\_bが使用されます。

LatticeECP2M 8-49 SERDES/PCS-UGJ

- 2. このケースは、クワッド内でCTCを必要としない2.5Gbpsかそれ以下のラインレート(8/10ビット幅インターフェイス)の単一チャネルリンクを意図します。リンクの両端が同じ基準クロックソースに接続されるとき、CTCは不要です。しばしばこれは同一回路基板上のチップ間リンクにみられるケースです。基準クロック間はOppmの違いなのでCTCは不要で、バイパスすることができます。また、この機能がコア内のIPによって実行されるとき、クワッドにCTCは不要です。
- 3. このケースは、クワッド内でCTCを必要とする2.5Gbpsかそれ以下のラインレート(8/10ビット幅インターフェイス)のマルチチャネル・リンクを意図します。マルチチャンネル・アライメント(MCA)はコア内のIPで対応しなければなりませんが、クワッド内でMCAをしなければならないという規定はありません。CTCの前でMCAをしなければならないので、MCAが必要なときにはクワッド内のCTC FIFOをバイパスしなければなりません。必要であればMCAとCTCの両方をコアのIPによって行われます。
- 4. このケースは、クワッドとFPGAコア間で2:1ギアリングが必要(16/20ビット幅インターフェイス)で、3.2Gbpsかそれ以下のラインレートの単一チャネルリンクを意図します。CTCはクワッドに含まれています。相互に+/-300ppm以内にある基準クロックソースがリンクの両端にあるときはCTCが必要です。
- 5. このケースは、クワッドとFPGAコア間で2:1ギアリングが必要(16/20ビット幅インターフェイス)で、3.2Gbpsかそれ以下のラインレートの単一チャネルリンクを意図します。CTCはクワッドに含まれていません。リンクの両端が同じ基準クロックソースに接続されるとき、CTCは不要です。しばしばこれは同一回路基板上のチップ間リンクにみられます。基準クロック間はOppmの違いなのでCTCは不要で、バイパスすることができます。また、この機能がコア内のIPによって実行されるとき、クワッドでCTCは不要です。
- 6. このケースはク、ワッドとFPGAコア間で2:1ギアリングが必要(16/20ビット幅インターフェイス)で、3.2Gbpsかそれ以下のラインレートのマルチチャネル・リンクを意図します。MCAはコア内のIPで対応しなければなりませんが、クワッド内でMCAをしなければならないという規定はありません。CTCの前でMCAをしなければならないので、MCAが必要なときにはクワッド内のCTC FIFOをバイパスしなければなりません。必要であればMCAとCTCの両方をコアのIPによって行われます。

# ケースI\_a; 8/10ビット、Elastic Buffer(EB)、およびDown-Sample(DS) FIFOはバイパスしない **図8-33 8b10b、EB、および**DS FIFOはパイパスしない



LatticeECP2M 8-50 SERDES/PCS-UGJ

- 1. アップサンプルFIFOはこの場合だけ位相シフトFIFOとして機能します。
- 2. ダウンサンプルFIFOはこの場合だけ位相シフトFIFOとして機能します。
- 3. Tx PLLからのクワッドレベル・フルレートクロック(ff\_tx\_f\_clk)は、FPGA中央のクロック・マルチプレクサに直接アクセスできます。これは比較的性能の高いパスです。デバイス中央のクロック・マルチプレクサからのグローバル・クロックツリーは、FPGA内のユーザのインタフェース・ロジックのクロックに用いられます。クロックツリーの幾つかのノードがFPGA送信入力クロック(ff\_txi\_clki)やCIBクロック入力を介してチャネル毎(ff\_ebrd\_clki)のエラスティック・バッファFIFO用リードクロックと、FPGA受信入力クロック(ff\_rxi\_clki) に接続されます。。これは恐らく最もよく見られる単一チャネルのユースケースです。

#### ケースI\_b: 8/10ピット、EB FIFOはバイパス

#### 図8-34 8b10b、EB FIFOはバイパス



- 1. アップサンプルFIFOはこの場合だけ位相シフトFIFOとして機能します。
- 2. ダウンサンプルFIFOはこの場合だけ位相シフトFIFOとして機能します。
- 3. 前の場合と同様にTx FPGAチャネル入力クロックは、FPGA中央のクロック・マルチプレクサへ直接接続されるフルレート送信FPGA出力クロックでドライブされるクロックツリーを用います。エラスティック・バッファがいったんバイパスされると、再生受信クロックは、ダウンサンプルFIFOのライトポートを制御する必要があります。各チャネルの再生受信クロックは、別々の(クワッドあたり最大4本の)ローカル或いはグローバル・クロックツリーをドライブする必要があるかもしれません。そしてクロックツリーは、ダウンサンプルFIFOのリードポートを制御するようにFPGA受信クロック入力をドライブします。この場合エラスティック・バッファFIFOをバイパスする理由は、たぶんFPGAコアでMCAを行うためです。それはエラスティック・バッファを用いるCTCをFPGAコアで行うことを暗示します。CTC FIFOは受信再生クロックかマスター受信再生クロックでライトすることができます。CTC FIFOのリードはTxクロックツリーを通してのTxクロックを

LatticeECP2M 8-51 SERDES/PCS-UGJ

用いて行われます。

### ケースII\_a: 16/20ビット、EB、およびDS FIFOはバイパスしない *図8-35 16/20ビット、EB、およびDS FIFOはバイパスしない*



- 1. アップサンプルFIFOはこの場合位相シフトFIFOおよびアップサンプルFIFOとして機能します。
- 2. ダウンサンプルFIFOはこの場合位相シフトFIFOおよびダウンサンプルFIFOとして機能します。
- 3. FPGAがフルレート・バイト周波数に動作が間に合わない場合、これは非常に一般的な単一チャネルのユースケースです。2本のクロックツリーが必要です。これらのクロックツリーは、FPGA中央のクロック・マルチプレクサに直接アクセスする送信フルレート・クロック/ハーフレート・クロックでドライブされます。フルレート・クロックツリーは、エラスティック・バッファのリードポートと、ダウンサンプルFIFOのライトポートをドライブします。ハーフレート・クロックツリーは、ダウンサンプルFIFOとFPGAロジックをドライブします。

LatticeECP2M 8-52 SERDES/PCS-UGJ

### ケースII\_b:16/20ビット、DSはバイパスしない 図8-36 16/20ビット、DS FIFOはパイパスしない



- 1. アップサンプルFIFOはこの場合位相シフトFIFOとアップサンプルFIFOとして機能します。
- 2. ダウンサンプルFIFOはこの場合位相シフトFIFOとダウンサンプルFIFOとして機能します。
- 3. FPGAの動作がフルレート・バイト周波数に間に合わない場合、これは非常に一般的なマルチチャネル・アライメント(MCA)のユースケースです。受信クロックツリー(最大4)は、ローカルかまたはグローバルで、これらはハーフレートクロックで動作しています。送信クロックツリーは、FPGA中央のクロック・マルチプレクサに直接アクセスする送信ハーフレートクロックでドライブされます。この場合、MCAが完了した後に、FPGAロジックではCTCが必要でしょう。TxクロックツリーはCTCのリードポートを、マスターチャネル受信クロックはCTCのライトポートをクロッキングします。このユースケースでは、MCAとCTCが共に16/20ビット幅で行う必要性に留意してください。

LatticeECP2M 8-53 SERDES/PCS-UGJ

### SERDES/PCSプロックのレイテンシ(遅延)

表8-22はトランスミッターとレシーバでそれぞれの機能ブロックの遅延について説明します。遅延はパラレルクロックのサイクル数で与えられています。図8-37はそれぞれのブロックの位置を示します。

表8-22 SERDES/PCS遅延の内訳(パラレル側クロック周期) 1

| 項目              | 記述                       | Min. | 平均 | Max. | Fixed | Bypass | 単位       |
|-----------------|--------------------------|------|----|------|-------|--------|----------|
| 送信データ遅          | 延                        |      |    |      |       |        |          |
| T1              | FPGAブリッジ、送信 <sup>2</sup> | 1    | 3  | 5    |       | 1      | word clk |
| T2              | 8b10bエンコーダ               | I    |    |      | 2     | 1      | word clk |
| Т3              | SERDESブリッジ、送信            |      |    |      | 2     | 1      | word clk |
| T4 <sup>3</sup> | シリアライザ、8ビットモード           |      |    |      | 15+ 1 |        | UI + ps  |
| 14              | シリアライザ、10ビットモード          |      |    |      | 18+ 1 |        | UI + ps  |
| 受信データ遅          | 延                        |      |    |      |       |        |          |
| R1 <sup>3</sup> | シリアライザ、8ビットモード           |      |    |      | 10+ 2 |        | UI + ps  |
| KI              | シリアライザ、10ビットモード          |      |    |      | 12+ 2 |        | UI + ps  |
| R2              | SERDESブリッジ、受信            |      |    |      | 2     | 1      | UI + ps  |
| R3              | ワードアライメント                |      |    |      | 4     | 0      | UI + ps  |
| R4              | 8b10bデコーダ                |      |    |      | 1     | 1      | UI + ps  |
| R5              | クロックトレランス補償              | 7    | 15 | 23   |       | 1      | UI + ps  |
| R6              | FPGAブリッジ、受信 <sup>2</sup> | 1    | 3  | 5    |       | 1      | UI + ps  |

- 1. PCS内部のパラレルクロック。このクロックレートは表8-6のrxfullclkと同じです。
- 2. FPGAブリッジの遅延はアップ/ダウン・サンプルFIFOのリード/ライトで変わります。これらの数は8/10ビット・インターフェイスで示されます。アップ/ダウン・サンプルFIFOの深さは4です。ダウンサンプルFIFOでは、ライトクロック・サイクル(1クロック)後に、最初のリードが行われます。最後のリードはFIFOがフル (4+1=5)になった後に行われます。16b/20bインターフェイスでは、値は倍になります。Min = 2, Max = 10。この遅延はFIFOの内部フラグ動作に依存します。
- 3.  $1 = \sim 245 \text{ps}$ ,  $2 = \sim 700 \text{ps}$

図8-37 トランスミッターとレシーバのブロック図



LatticeECP2M 8-54 SERDES/PCS-UGJ

### SERDESクライアント・インターフェイス(SCI)

SCIはFPGAコア内のソフトIPと、SERDES/PCSクワッドに含まれているハードロジックの両方から成ります。SCIは、SERDES/PCSクワッドがコンフィグレーション・メモリセル設定ではなくレジスタによって制御される事を可能する、簡易なレジスタ・コンフィグレーション・インターフェイスです。FPGAコアに置かれるSCIのソフトIP部分のブロック図は図8-38で示され、必要な主要信号を全て示しています。

図8-38 SCIインターフェイス・ブロック図



FPGAコアに置くソフトIPは、そのインターフェイス規定に従ってユーザが開発します。サンプル記述についてはラティス・テクニカルサポート・グループにお問い合わせ下さい。

SCIADDRバスはブロック内では6ビット幅ですが、ブロック境界におけるバス幅は11ビットです。上位5ビットはクワッドブロックとチャネルの選択に用いられます。表8-23はSERDESクワッド用のSCIアドレスマップを示します。

表8-23 最大4つのSERDES/PCSクワッドのSCIアドレスマップ

| アドレスピット      | 記述                                                                                                                         |
|--------------|----------------------------------------------------------------------------------------------------------------------------|
| SCIADDR[5:0] | レジスタ・アドレスビット<br>000000 = register 0を選択<br>000001 = register 1を選択<br><br>111110 = register 62を選択<br>111111 = register 63を選択 |

LatticeECP2M 8-55 SERDES/PCS-UGJ

|               | チャネル・アドレスビット         |
|---------------|----------------------|
|               | 000 = channel 0を選択   |
|               | 001 = channel 1を選択   |
|               | 010 = channel 2を選択   |
| SCIADDR[8:6]  | 011 = channel 3を選択   |
|               | 100 = aux channelを選択 |
|               | 101 = 未使用            |
|               | 110 = 未使用            |
|               | 111 = 未使用            |
|               | クワッド・アドレスビット         |
|               | 00 = quad 0を選択       |
| SCIADDR[10:9] | 01 = quad 1を選択       |
|               | 10 = quad 2を選択       |
|               | 11 = quad 3を選択       |

このインターフェイスを通してのリード/ライト動作は非同期です。ライトサイクル中、ライトデータとライトアドレスは、SCIWSTNの立ち下がリエッジに対してセットアップ時間とホールド時間を満たす必要があります。リードサイクルでは、タイミングはSCIRDパルスに対して規定されます。図8-39と図8-40はそれぞれライトとリードサイクルを示します。

#### 図8-39 SCIライトサイクル、重要なタイミングの注意:



- 1) tsuはライトストローブの立ち下がりエッジの前のアドレスとライトデータのセットアップ時間
- 2) thはライトストローブの立ち下がりエッジの後のアドレスとライトデータのホールド時間

注:制御レジスタに対する意図しない書き込みを避けるため、レジスタを用いて、パワーアップ・リセット 時にSCI入力ポートをLowにドライブするようにします。

LatticeECP2M 8-56 SERDES/PCS-UGJ

#### 図8-40 SCIリードサイクル、重要なタイミングの注意 3



- 1) trddvはリードパルスのアサートからリードデータが有効になるまでの時間
- 2) taddvはリードパルスのアサート中にアドレスが変更されてからデータが有効になるまでの時間
- 3) trddeはリードパルスのネゲートからリードデータが有効なホールド時間

#### 表8-24 タイミングパラメータ

| パラメータ             | Typical値 | 単位 |  |  |
|-------------------|----------|----|--|--|
| tsu, trddv, taddv | 1.127    | ns |  |  |
| th, trdde         | 0.805    | ns |  |  |

SCIインターフェイスはメモリのリード/ライトと同じ程度に簡単です。これは擬似コードの例です:

#### ライト

Cycle 1: Set sciaddr[5:0], sciwdata[7:0], scien\* = 1'b1 scisel\* = 1'b1

Cycle 2: Set sciwstn from 0 => 1

Cycle 3: Set sciwstn from 1 => 0, scien\* = 1'b0, scisel\* = 1'b0

#### リード

Cycle 1: Set sciaddr[5:0], scisel\* = 1'b1

Cycle 2 : Set scird from 0 => 1

Cycle 3: Obtain reading data from scirdata[7:0]

Cycle 4: Set scird from 1 => 0

注: ヒューズをロードするとき、scien\*の全5ビットをゼロに設定しなければなりません。

#### 割り込みとステータス

ステータスビットはSCIを通して読み出せますが、SCIはバイト幅のため、一度に8つの割り込みステータス信号を読む事ができます。SCIINT信号は割り込みイベントが起こったことを示すためHighになります。その場合ユーザは、割り込みがクワッドからなのか、どれかのチャネルから来たのかを示すQIFステータス・レジスタをリードしなければなりません。このレジスタはリードではクリアされず、クワッドまたはチャネルからのすべての割り込みソースがクリアされることでクリアされます。

割り込みソースがいったん決定されると、ユーザは実際の割り込みソースを決定するために関連するクワッドかチャネルのレジスタを読むことができます。表8-25と表8-26は割り込みのすべてのソースを記載しています。

LatticeECP2M 8-57 SERDES/PCS-UGJ

#### 表8-25 クワッド割り込みソース

| クワッド<br>SCI_INTソース                                 | 記述                                                                                                                              | レジスタ名                         |
|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| int_quad_out                                       | クワッド割り込み。割り込みイベントがクワッドの何処かであると、このレジスタビットはアクティブになります。すべての割り込みイベントがクリアされると、このレジスタビットはクリアされます。                                     | PCS Quad Status Register 1    |
| int_cha_out[0:3]                                   | チャネル割り込み。割り込みイベントがそれぞれの<br>チャネルの何処かであると、このレジスタビットは<br>アクティブになります。それぞれのチャネルにおけ<br>るすべての割り込みソースがクリアしてあるとき、<br>これらのレジスタビットはクリアされます |                               |
| Is_sync_statusn_[0:3]_int Is_sync_status_[0:3]_int | Link Status Low(同期はずれ)チャネル割り込み。<br>Link Status High(同期獲得)チャネル割り込み                                                               | PCS Quad Status Register 3    |
| ~PLOL, PLOL                                        | ~PLOLとPLOLで生成されるPLLロック外れ割り込み                                                                                                    | SERDES Quad Status Register 2 |

#### 表8-26 チャネル割り込みソース

| クワッド<br>SCI_INTソース                                                                                      | 記 述 | レジスタ名                                              |
|---------------------------------------------------------------------------------------------------------|-----|----------------------------------------------------|
| fb_tx_fifo_error_int<br>fb_rx_fifo_error_int<br>cc_overrun_int<br>cc_underrun_int                       |     | PCS Channel General<br>Interrupt Status Register 4 |
| pci_det_done_int<br>rlos_lo_int<br>~rlos_lo_int<br>rlos_hi_int<br>~rlos_hi_int<br>rlol_int<br>~rlol_int |     | SERDES Channel Interrupt<br>Status Register 5      |

### SERDESクライアント・インターフェイス (SCI) アプリケーションの例

#### 例えば:

ユーザは、Quad PCS制御レジスタser\_ctl\_3\_qd\_13のrefck\_mode[1] (D7)とrefck\_mode[0] (D6)ビットを変えることによって、基準クロックてN倍モードを10xと20xの間で切り替えることができます。レジスタのSCIアドレスは0x13でORCAstraアドレスは0x113です。この設定を有効にするためには、Quad Reset (QD\_18[5])をトグルしなければなりません。

リード/ライト動作は2つの異なる方法で達成することができます。

- 1. メインウィンドーでは、ユーザは制御レジスタの内容を読み書きでき、ステータス・レジスタを読むことができます。
- 2. サブウィンドウでは、ユーザは、ON/OFFオプションのプルダウンメニュー・オプションを選択するか、あるいはチェックするかチェックを外すことができます。

LatticeECP2M 8-58 SERDES/PCS-UGJ

#### 表8-27 SCIアドレスマップ

| アドレスピット       | 記述                      |
|---------------|-------------------------|
|               | レジスタ・アドレスビット            |
|               | 000000 = register 0を選択  |
| CCIADDDIE.01  | 000001 = register 1を選択  |
| SCIADDR[5:0]  |                         |
|               | 111110 = register 62を選択 |
|               | 111111 = register 63を選択 |
|               | チャネル・アドレスビット            |
|               | 000 = channel 0を選択      |
| CCIADDDI0.61  | 001 = channel 1を選択      |
| SCIADDR[8:6]  | 010 = channel 2を選択      |
|               | 011 = channel 3を選択      |
|               | 100 = aux channelを選択    |
|               | クワッド・アドレスビット            |
|               | 00 = quad 0を選択          |
| SCIADDR[10:9] | 01 = quad 1を選択          |
|               | 10 = quad 2を選択          |
|               | 11 = quad 3を選択          |

#### SERDES/PCSクワッドのダイナミック・コンフィグレーション

SERDES/PCSクワッドは、コンフィグレーション・メモリセルかオプションのSCIを通してアクセスされるレジスタによって制御することができます。SCIはFPGAコア内のソフトIPとSERDES/PCSクワッドに含まれているハードロジックの両方から成ります。ソフトIPがFPGAコアに存在する場合にのみSCIが利用できます。

コンフィグレーション完了後、コンフィグレーション・メモリセルが自動的にレジスタにコピーされます。 レジスタ値のその後の変更は、もちろんSERDES/PCSクワッドの動作を変えますが、コンフィグレーション・メモリセルに格納された値には影響しません。

コンフィグレーション・メモリセルによって制御される場合、コンフィグレーションが完了後に、ユーザからの干渉なしにSERDES/PCSクワッドが機能状態に至る必要があります。これは、SERDES/PCSクワッドを初期化するために必要な、特別なリセットシーケンスは、自動的にハードウェアで扱わなければならないことを意味します。言い換えると、SCIの使用はオプションのため、SERDES/PCSクワッドはソフトIPがFPGAコアに存在していると想定していません。

### SERDESデバッグ機能

ラティスには、LatticeECP2MデバイスにおけるSERDES/PCS動作のデバッグを手助けするツールがあります。

ラティスORCAstraソフトウェアはPCベースのGUIで、オンチップ・レジスタの制御ビットでLatticeECP2M デバイスの動作モードを構成・変更するためのツールです。これは、時間の掛かる再コンパイル・プロセスを実行したり、ボードの変更をすることなく、迅速に(最適な)コンフィグレーション・オプションを探ることを助けます。GUIで作成されたコンフィグレーションは、PC上のメモリに保存して、後で使用する時に再ロードすることができます。ORCAstraを用いるためには、ユーザロジックにSCI IPをインスタンスしなければなりません(訳注;ispLEVER7.1SP1から、IPexpressでORCAstraモジュールのRTLを自動生成する機能に対応しています)。

LatticeECP2M 8-59 SERDES/PCS-UGJ

スクリプトベースのコンフィグレーションとテストをサポートするために、マクロ機能も利用できます。また、リアルタイムでステータス情報を表示するためにGUIを用いることができます。ORCAstraソフトウェアの使用はFPGAのプログラミングを妨げません。

図8-41はORCAstra GUIトップレベル・ウィンドウで、各PCSチャネルのサブウィンドウを用いることなく、ユーザはAdrsセルによってデータをリード/ライトすることができます(右下部)。呼び出されると、ORCAstra は自動的にデバイスタイプを認識します。または、デバイス・プルダウンメニューの下でデバイスタイプを選択することもできます。

#### 図8-41 ORCAstraトップレベル・スクリーンショット



デフォルトで、図8-41で示すData Boxはリトルエンディアン(MSBが右)のビット順に従います。ユーザは、Optionsタブの下のData BoxでDisplay Data reversedを選択することによって、ビッグエンディアンに変更することができます。

PCS0(Quad 0)ボタン上をダブルクリックすると図8-42で示されるようなメインウィンドーが開きます。

これらの標準ウィンドウメニューはデバイスとインターフェイスの選択を制御します。また、格納されたファイルでコンフィグレーションをセットアップしたり、保存すること含む、様々なコンフィグレーション・オプションをサポートします。

LatticeECP2M 8-60 SERDES/PCS-UGJ

#### 図8-42 ORCAstraメインウィンドー



#### コントロールボックス、ボタン、ステータスボックス、およびテキストウィンドウ

コントロールボックスの上にカーソルを動かして、マウス左ボタンをクリックして、制御ビットを設定します。ともに、選択されたボックスのビット位置と機能は、テキストウィンドウに表示されます。これはデバイス・データシートのレジスタマップ表と合致します。ビット名の上にカーソルがあるとき、機能だけを表示します。ステータスボックスは、コントロールボックスと類似していますが、LED表示と色付きのバックグランドになっています。

図8-43はSERDES Buffer Optionsウィンドウを示します。プルダウンメニューからコンフィグレーション・オプションを選択することができます。

#### 図8-43 SERDES Buffer Options ウィンドウ



LatticeECP2M 8-61 SERDES/PCS-UGJ

以下のアドレスのラティスセミコンダクター・ウェブサイトにORCAstraの詳しい情報とダウンロードできるファイルがあります; www.latticesemi.com/products/devtools/software/orcastra/index.cfm

### デザインに関する他の考察

### LatticeECP2M-35対、他のLatticeECP2Mデバイス

重要な注意:LatticeECP2M-35の(.txtファイル内の)SERDES設定は、他の全LatticeECP2Mデバイスと異なっています。違いは.txtファイルの中に隠されているデフォルト設定を含んでいます。

LatticeECP2M-35から他のいづれかのLatticeECP2Mデバイスに移行する場合、ユーザはIPexpress GUIから PCSモジュールを再生成しなければなりません。

#### エンジニアリング・サンプル対量産デバイス

エンジニアリング・サンプルと生産デバイスには、それぞれのシミュレーション・モデルとライブラリがあります。エンジニアリング・サンプルのライブラリ名はpcsc\_mti\_work\_revA(訳註;これはModelSim用。Active-HDL用はpcsc\_aldec\_work\_revA)です。

#### SERDES/PCSのシミュレーション

SERDES/PCSのシミュレーションは、プリコンパイルされたモデルによってModelSim®とNC-Verilog®用に提供されます(訳註; Active-HDL用も提供)。プリコンパイルされたシミュレーション・モデルは、SERDESのビヘービアモデルとPCSのRTLです。表8-28はそれぞれのシミュレーション・モデルの場所を示します。

#### 表8-28シミュレーションモデルの場所

|          | シミュ        | レータ       |          |               | モデルの場所                       |
|----------|------------|-----------|----------|---------------|------------------------------|
| Cadence  | NC-Veril   | og/VHDL,  | NC-Sim,  |               |                              |
| Synposys | VCS,       | Mentor    | Graphics | ispTools¥cae_ | _library¥simulation¥blackbox |
| ModelSim | , Aldec Ri | viera Pro | -        | -             | -                            |

なお、配布されているモデルはzipファイルですので、使用する前に解凍する必要があります。

#### シミュレーション時のリセット方法

PCSリセット信号がいずれもGNDに接続されていない場合、設計者は同じリセット信号がFPGAコアで用いられているかどうか注意しなければなりません。例えば、リセット信号の1つがFPGAコアのカウンタとPCSの両方をリセットするのに用いられて、かつカウンタがtxfullclkを用いていると、カウンタは動作しないでしょう。リセットがアクティブなときにtxfullckが動作していないので、カウンタはそれ自体をリセットすることができません。

基準クロックソースに依存して、リセットのアサート時間は異なり得ます。シミュレーション時にのみ、PCSリセット信号に最小100nsのアクティブ期間を用いることを推奨します。

#### 16/20ビットのワードアライメント

PCSレシーバは16ビットのワード境界を認識することができません。AUTOモードによるCOMMA\_ALIGNと共に、PCSはバイトアライメントのみ行うことができます。16ビット・ワードアライメントは、FPGAファブリックで行うべきで、これはかなり素直な処理です。以下で説明されるようなアライメント機構では、機能アップすることもできます。

例えば、FPGAインターフェイスの前の送信データが、

YZABCDEFGHIJKLM.... (それぞれ8-bitか10-bitの文字)

LatticeECP2M 8-62 SERDES/PCS-UGJ

そして、8b10bデコーダ後とrx\_gearboxの前のPCSにおける入力データは:

YZABCDEFGHIJKLM....

rx\_gearboxの後、これは:

1. {ZY}{BA}{DC}{FE}{HG}{JI}{LK}.... または

(AZ){CB}{ED}{GF}{IH}{KJ}{ML}...

明らかに、シーケンス2はアラインされていません。これは1バイトのオフセットがありますが、16/20ビットのアライメントが必要です。特殊文字Aは常に下位バイトに置かれるべきです。

20ビットデータを現在の16/20ビットデータに組み合わせるて32/40ビット・データを形成すると、以下に示すようになります:16/20ビット・アライメント後の出力データは以下です。

1. {DCBA}{HGFE}{LKJI}....

^ |\*\*下位10-bit側にAを検出。オフセットを0に設定してアラインされたデータBAを送出。 次のクロック周期で; {FEDC}{JIHG}{NMLK}.... ^

|\*\*アラインされたデータDCを送出

etc.

20ビット・アライメント後の出力データは以下です。

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

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

|\*\* 上位10-bit側にAを検出。オフセットを10に設定してアラインされたデータBAを送出。 次のクロック周期で;

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

|\*\*アラインされたデータDCを送出。 etc.

20ビット・アライメント後の出力データは以下です。

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

注: 8/10ビットや16/20ビットワードのLSBが常に最初に送信され、最初に受信されます。

#### SCIを用いた10XH、10X、または20X基準クロックてい倍モードの切り替え

設計者はSCIを用いることで、基準クロックてい倍モードを10XHと、10X、または20Xの中から指定することができます。これは、レシーバが受信信号にロックするように異るレートを試すようなシステムでは役に立つ機能です。例えばシステムレートが622Mbps、1.244Gbps、2.488Gbpsを取り得る場合、それらを順次切り替えることで、いづれかのてい倍モードで受信信号にロックすることができます。

異なるレートに関連するいくつかの制御レジスタビットがあります。

LatticeECP2M 8-63 SERDES/PCS-UGJ

CH\_0A[D1]: rate\_mode\_tx CH\_0B[D1]: rate\_mode\_rx QD\_13[D6]: refclk\_mode[0] QD\_18[D5]: quad\_rst

#### 16ビットインターフェイスでの20Xと20XH、または10Xと10XHモード間の切り替え

上記制御レジスタの設定に加えて、送信インターフェイス・クロック(ffc\_txiclk\_chn)入力は表8-6にあるようにtxhalfclkからtxqtrclkに切り替える必要があります。この場合ff\_rxiclkは影響されません。CDR PLLは供給されるデータに自動的にチューニングされ、表8-6のような正しいrxhalfclkを供給します。

#### オフチップAC結合

チップ外部でAC結合が必要なとき、表8-29に推奨のコンデンサー値を示します。

#### 表8-29 外付けAC結合コンデンサー値

| プロトコル              | Min. | Тур. | Max. | コメント       | 単位 |
|--------------------|------|------|------|------------|----|
| 8b10b              | 4.7  | 10   |      | @3.125Gbps | nF |
| PCI Express rev1.1 | 75   |      | 200  |            | nF |

8b10b符号などDCバランスのとれているパターンが用いられるとき、エッジの劣化を防ぐために最小4.7nFのコンデンサーが必要です。より長いランレングスがあるパターンでは、データ依存のジッタを減らすためにより大きいコンデンサ値が必要です。詳しい情報についてはラティステクニカルノートTN1114(Electrical Recommendations for Lattice SERDES)を参照してください。

#### 未使用のクワッド/チャネルと供給電源

未使用のチャネルでもVCCTX、VCCRX、VCCP、およびVCCAUX33には電力が供給されなければなりません。VCCIB、VCCOB、HDINP/N、HDOUTP/N、およびREFCLKP/Nはフローティングのままにすべきです。未使用のチャネル出力はトライステートにされ、差動出力ペアの間の内部抵抗はおよそ10Kです。VCCAUX33は終端抵抗に電力を供給します。他の供給電源のように型フィルタを用いることをお勧めします。VCCAUX33の雑音は直接高速I/OのHDIN/HDOUTと結合されるでしょう。VCCAUX(FPGAコア供給電源)が非常にきれいであれば、それをVCCAUX33に接続することができます。

また、未使用のSERDESはデフォルトでパワーダウン・モードにコンフィグレーションされます。

#### SERDES/PCSリセットのリセットシーケンス

パワーアップとコンフィグレーションの後に、すべてのSERDESリセットとFPGAリセットが与えられます。

- 1. SERDESリセットシーケンス
  - ・SERDESリセットシーケンスを開始として、quad\_rstを最低20ns与えます。
  - ・quad\_rstネゲートの後に、plolとrlol\_ch#が非アクティブになるのを待ちます。
  - ・plolとrlol\_ch#が非アクティブの後にlane\_tx\_rst\_ch#とlane\_rx\_rst\_ch#をネゲートします。
- 2. SERDES/PCSリセットのネゲート後にFPGA Logic Resetをネゲートします。
  - ・持続時間はプロトコルに依存するかもしれません。
- 3. デバッグだけに用いられる他のリセット:
  - ・macro rstは常時Lowに接続します。
  - ・trstとrrst\_ch#は常時Lowに接続します。

リセットシーケンスは図で8-44で説明されています。

LatticeECP2M 8-64 SERDES/PCS-UGJ

#### 図8-44 リセットシーケンス



注;ユーザのシステム環境によっては、CDRプロセス中にrlol\_ch#信号はトグルする可能性があり、CDRロック後に結果的にLowになります。

通常このプロセスは3ms程度かかります。4msカウンタを用いてquad\_rstでカウント開始しrlol\_ch#がLowからHighになる度にリセットするようにすることで、FPGAロッジで適切にロック検出を検出するようにできます。

リセットシーケンス・モジュールの例はTN1153 (LatticeECP2M PRBS SERDES Demo User's Guide) に記述されています。

#### リセットとパワーダウン制御

SERDESクワッドには図8-45で示されるように、マクロ全体のリセットとパワーダウン制御、及び各トランスミッターとレシーバの個別リセットとパワーダウン制御があります。リセット信号はHighアクティブで、パワーダウン信号はLowアクティブです。様々なリセットとパワーダウン制御の動作は以下のセクションで説明されます。

注:デバイスがパワーアップ時にチップレベルのパワーオンリセットがアクティブであるとき、PCSのSERDES制御ビットはクリアされます(または、そのデフォルト値になります)。これはSERDESクワッドをパワーダウン状態にします。

LatticeECP2M 8-65 SERDES/PCS-UGJ

図8-45 SERDES/PCSクワッドリセットとパワーダウン制御



リセットの生成と分配は、クロックとリセットのブロックで扱われます。通常、すべてのリセットがハードリセットと様々なFPGAファブリック・リセットによります。リセットパルス幅は(RTL)ソースの記述によります。しかしながら、少なくとも1クロック幅でなければなりません。リセットロジックは図8-46で示され、そして表8-30は対応表です。

#### 表8-30 SERDES/PCSリセット表

| リセット信号                |                        | PCS TX PCS RX |        | SERDES SERDES |    | PCS CTRL<br>レジスタ | TV DI I | CDR |
|-----------------------|------------------------|---------------|--------|---------------|----|------------------|---------|-----|
| FPGA                  | 制御レジスタ                 | PCS IX        | PC3 KA | TX            | RX | レジスタ             | IXPLL   | PLL |
| ffc_tx_lane_rst [3:0] | lane_tx_rst[3:0]       | Х             |        |               |    |                  |         |     |
| ffc_rx_lane_rst [3:0] | lane_rx_rst[3:0]       |               | Х      |               |    |                  |         |     |
| ffc_quad_rst          | quad_rst               | Χ             | Х      | Χ             | Χ  |                  | Х       | Χ   |
| ffc_macrorst          | macrorst               |               |        | Χ             | Χ  |                  | Х       | Χ   |
| ffc_rrst[3:0]         | rrst[3:0] 3            |               |        |               | Х  |                  |         |     |
| ffc_trst[3:0]         | trst[3:0] <sup>3</sup> |               |        |               |    |                  | Х       |     |
| TRI_ION               |                        | Χ             | Х      | Χ             | Χ  | Χ                |         |     |

- 1. SB(SERDES Brdige)、PCSコア、FB(FPGA Bridge)各サブブロックを含む
- 2. ラティスセミコンダクター社内用途のみ。本リセットは常時Lowに接続すること
- 3. TX PLL loss of lock(ffx\_plol)のみをリセット

LatticeECP2M 8-66 SERDES/PCS-UGJ

#### 図8-46 SERDES/PCS リセット・ダイヤグラム



表8-31 リセット制御の記述1,2,3

| リセットイ                       | 言号        | 記述                                                                                                                  |
|-----------------------------|-----------|---------------------------------------------------------------------------------------------------------------------|
| FPGA                        | 制御レジスタ    | 10. 这                                                                                                               |
| ffc_quad_rst                | quad_rst  | Highアクティブの非同期入力。SERDESクワッドの補助(auxiliary)チャネルとPCSを含む全チャネルをリセット。本リセットはmacro_rst、txpll、cdr、lane_tx_rst、lane_rx_rstを含む。 |
| ffc_macro_rst               |           | SERDESクワッドへのHighアクティブの非同期入力。ソフトウェア制御ビットとゲートされる。本リセットはSERDESブロックのみに有効で、TXPLLとCDRPLLも含まれる。                            |
| ffc_lane_tx/rx_rst_ch [0:3] |           | Highアクティブの非同期入力。個々のTX/RXチャネルをリセットし、<br>SB、PCSコア、FB各ブロックに有効。                                                         |
| ffc_rrst_ch[0:3]            | rrst[0:3] | loss-of-lock(rlol)回路とloss-of-signal回路をリセット。                                                                         |
| ffc_trst                    | trst      | AUX PLLのloss-of-lock(plol)をリセット。                                                                                    |

- 1. フルデータレート・モードで動作するクワッドの全チャンネルにとって、パラレル側クロックは同位相であることが保証されます。
- 2. ハーフデータレート・モードで動作するクワッドでは、各チャンネルには個別の2分周回路があります。クワッドにはmacrorstのネゲート後に、2分周回路が同位相にあることを保証するメカニズムが全くないので、PCSデザインはこれらが(したがってパラレル側クロックも)同位相にないと想定するべきです。
- 3. ハーフデータレート・モードで、これはマルチチャンネル・リンクの送受信側でチャネル間スキューを与えるかもしれません。

LatticeECP2M 8-67 SERDES/PCS-UGJ

#### パワーダウン制御の記述

各RxとTxチャネルは、レジスタビットかFPGAからの制御信号で個別にパワーダウンが可能です。個別チャネルのパワーダウン制御ビットは、SERDESマクロ内の選択されたブロックと高速I/Oバッファのみをパワーダウンします。

表8-32 パワーダウン制御の記述

| 信号                  |             | 記述                                        |
|---------------------|-------------|-------------------------------------------|
| FPGA                | レジスタ        | 10 位                                      |
|                     |             | SERDESクワッドへのLowアクティブの非同期入力で、補助チャネルを含      |
| maarana             | lh.         | む全チャネルに有効。Lowにドライブされると、送信PLLを含むマクロ全体      |
| macropo             | טג          | をパワーダウンする。すべてのクロックが止められ、マクロの電力消費は         |
|                     |             | 最少になる。                                    |
|                     |             | Lowアクティブで、各チャネル用のトランスミッタ・パワーダウン。シリア       |
| ffc_txpwdnb_ch[0:3] | tpwdnb[0:3] | ライザと出力ドライバのみをパワーダウン。本モードではHDOUTは5k の      |
|                     |             | 抵抗で弱くプルアップされる。                            |
|                     |             | Lowアクティブで、各チャネル用のレシーバ・パワーダウン。CDRと入力       |
| ffc_rxpwdnb_ch[0:3] | rpwdnb[0:3] | バッファ(イコライザとデシリアライザ)、およびLoss-of-Signal検出器を |
|                     |             | パワーダウン。                                   |

#### 表8-33 リセットパルス仕様

| パラメータ                 | 記述               | Min. | Тур. | Max. | 単位 |
|-----------------------|------------------|------|------|------|----|
| t <sub>MACRORST</sub> | マクロリセットHigh時間    | 1    |      |      | ns |
| t <sub>RRST</sub>     | チャネルRXリセットHigh時間 | 3    |      |      | ns |
| t <sub>TRST</sub>     | クワッドTXリセットHigh時間 | 3    |      |      | ns |

#### 表8-34 パワーダウン/パワーアップのタイミング仕様

| パラメータ              | 記述                 | Min. | Тур. | Max. | 単位 |
|--------------------|--------------------|------|------|------|----|
| t <sub>PWRDN</sub> | macropdb後のパワーダウン時間 | 20   |      |      | ns |
| t <sub>PWRUP</sub> | macropdb後のパワーアップ時間 | 20   |      |      | ns |

### 供給電源のシーケンス要件

1.5VのVCCIBかVCCOBでSERDESを使用するとき、1.2V電源を供給しないでSERDESを1.5V電源を定常的に供給するべきではありません。1.2Vと1.5V電源の両方が同時にSERDESに供給されなければなりません。ただし供給電源と電圧レギュレータの、通常のランプアップ時の時間差は問題ではありません。

LatticeECP2M 8-68 SERDES/PCS-UGJ

### 参照ドキュメント

- ラティスセミコンダクター・テクニカルノート
- TN1029, FPSC SERDES CML Buffer Interface
- TN1084, LatticeSC/M and LatticeECP2/M SERDES Jitter
- TN1114, Electrical Recommendations for Lattice SERDES
- TN1159, LatticeECP2/M Pin Assignment Recommendations
- HB1003, LatticeECP2/M Family Handbook

### テクニカル・サポート支援

ホットライン: 1-800-LATTICE (North America)

+1-503-268-8001 (Outside North America)

e-mail: techsupport@latticesemi.com インターネット: http://www.latticesemi.com

### 変更履歴(日本語版)

| Rev.# | 日付       | 変更箇所                                                                                                                                                                     |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.6J0 |          | 日本語初版。訳註;次の原文は日本語版には意図的に含めていない(ページ番号は原文)。 ・SATAサポートに関する記述全般(オプションとしての説明を除く) ・p.8-13 プリエンファシスの記述 ・p.8-16 Txレーン間スキューの一部記述 ・p.8-27 OOB信号とSATAアプリケーション                       |
|       |          | ・p.8-38 コンフィグレーション・ファイル記述<br>・p.8-57 SERDES Client Interface アプリケーション例の前半<br>・p.8-58 SERDES/PCSクワッドのダイナミック・コンフィグの第三パラグラフ                                                 |
| 2.8J0 | Nov.2008 | ・SATA関連記述を削除(page.8-1, 表8-1, 表8-16, 表8-30)<br>・表8-5、信号追加(rx/tx_sdi_en)、脚注更新<br>・表8-23 Latency更新、表8-31/8-32 Reset Control更新、表8-33 Power Down更新<br>・(p.8-65)クロックモード切替節記述追加 |
| 2.9J  | Feb.2009 | ・PCI PIPEモード関連記述を削除(表8-4 脚注3、表8-11 プロトコル、表8-12 最上部モード、表8-16 受信・送信各モード、pp.8-45~46 "PCS in PIPE Mode"節、表8-105プロトコル)。表8-20以降の番号を順次繰り上げ。<br>・図8-44 の脚注、オリジナル復活(日本語版は対応済み)    |
|       |          |                                                                                                                                                                          |

LatticeECP2M 8-69 SERDES/PCS-UGJ

### 付録A.メモリマップ

#### コンフィグレーション・レジスタ定義

特定のクワッドレベル・レジスタとチャネルレベル・レジスタがあります。各カテゴリに、SERDESに特有のレジスタとPCSに特有のレジスタがあります。サブカテゴリ中には以下があります。

- 制御レジスタ
- ・ ステータス・レジスタ
- ・ リードでクリアされるステータス・レジスタ
- ・ 割り込み制御レジスタ
- ・ 割り込みステータス・レジスタ
- ・ 割り込みソースレジスタ(リードでクリア)

以下に示すすべてのレジスタビットは、D0がLSBです。

各レジスタがどのようなタイプかをそれぞれ以下の通り定義します(R/W = Read/Write, RO = Read Only, CR = Clear on a read; リードでクリア)。

これらのレジスタビットはそれぞれのコンフィグレーション・メモリセルがシャドーになっています。これらのメモリセルはビットストリーム制御でのみプログラマブルです。コンフィグレーションが完了後、レジスタに関連づけられたコンフィグレーション・メモリセルは自動的にレジスタにコピーされます。レジスタに関する内容をその後に変更しても、コンフィグレーション・メモリセルに格納された値には影響しませんが、SERDES/PCSクワッドの動作を変えます。

すべてのreserved(予約)ビットにはゼロが書かれます。

LatticeECP2M 8-70 SERDES/PCS-UGJ

## クワッドごとのレジスタ概要

表8-35 クワッド・インターフェイス・レジスタマップ

| BA<br>1 | レジス<br>夕名                  | D7                           | D6                           | D5                           | D4                           | D3                            | D2                            | D1                            | D0                            |  |
|---------|----------------------------|------------------------------|------------------------------|------------------------------|------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|--|
| 1. ク    | ワッド                        | 用の制御レジ                       | スタ (28)                      |                              | 1                            |                               |                               | •                             |                               |  |
| クワ      | クワッド用のPCS制御レジスタ (17)       |                              |                              |                              |                              |                               |                               |                               |                               |  |
| 00      | qd_00                      | sync_toggle                  | force_int                    | char_mode                    | xge_mode                     | rio_mode                      | pcie_mode                     | fc_mode                       | uc_mode5                      |  |
| 01      | qd_01                      | bist_rpt_ch_sel[1]<br>6      | bist_rpt_ch_sel[0]           | bist_res_sel[1]              | bist_res_sel[0]              | bist_time_sel[1]              | bist_time_sel[0]              | bist_head_sel[1]              | bist_head_sel[0]              |  |
| 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                      | min_ipg_cnt[1]               | min_ipg_cnt[0]               | match_4_enable               | match_2_enable               |                               | pfifo_clr_sel                 | asyn_mode                     | sel_test_clk                  |  |
| 04      | qd_04                      | 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]                 |  |
| 05      | qd_05                      | 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]                 |  |
| 06      | qd_06                      | 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]                 |  |
| 07      | qd_07                      | 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]                 |  |
| 80      | 9d_08                      | 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]                 |  |
| 09      | qd_09                      | udf_comma_mas<br>k[7]        | udf_comma_mas<br>k[6]        | udf_comma_mas<br>k[5]        | udf_comma_mas<br>k[4]        | udf_comma_mas<br>k[3]         | udf_comma_mas<br>k[2]         | udf_comma_mas<br>k[1]         | udf_comma_mas<br>k[0]         |  |
| 0A      | qd_0a                      | 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]                |  |
| 0B      | qd_0b                      | 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]                |  |
| 0C      | qd_0c                      | udf_comma_a[9]               | udf_comma_a[8]               | udf_comma_b[9]               | udf_comma_b[8]               | udf_comma_mas<br>k[9]         | udf_comma_mas<br>k[8]         | bist_mode                     | bist_en                       |  |
| 0D      | qd_0d                      | bist_udf_def_hea<br>der[7]   | bist_udf_def_hea<br>der[6]   | bist_udf_def_hea<br>der[5]   | bist_udf_def_hea<br>der[4]   | bist_udf_def_hea<br>der[3]    | bist_udf_def_hea<br>der[2]    | bist_udf_def_hea<br>der[1]    | bist_udf_def_hea<br>der[0]    |  |
| 0E      | qd_0e                      |                              |                              |                              |                              |                               |                               | bist_udf_def_hea<br>der[9]    |                               |  |
| 0F      | qd_0f                      | bist_bus8bit_sel             | bist_ptn_sel[2]              | bist_ptn_sel[1]              | bist_ptn_sel[0]              | bist_udf_def_hea<br>der[19]   | bist_udf_def_hea<br>der[18]   | bist_udf_def_hea<br>der[17]   | bist_udf_def_hea<br>der[16]   |  |
| 10      | qd_int_<br>10 <sup>2</sup> | ls_sync_status_3<br>_int_ctl | ls_sync_status_2<br>_int_ctl | ls_sync_status_1<br>_int_ctl | ls_sync_status_0<br>_int_ctl | ls_sync_statusn_<br>3_int_ctl | ls_sync_statusn_<br>2_int_ctl | ls_sync_statusn_<br>1_int_ctl | ls_sync_statusn_<br>0_int_ctl |  |
| クワ      | ッド用の                       | DSERDES制御                    | <b>『レジスタ (6)</b>             |                              |                              |                               |                               |                               |                               |  |
| 11      | qd_11                      | reserved                     | reserved                     | tx_refck_sel                 | refck_dcc_en                 | refck_rterm                   | refck_out_sel[2]              | refck_out_sel[1]              | refck_out_sel[0]              |  |
| 12      | qd_12                      | refck25x                     | bus8bit_sel                  | rlos_hset[2]                 | rlos_hset[1]                 | rlos_hset[0]                  | rlos_lset[2]                  | rlos_lset[1]                  | rlos_lset[0]                  |  |
| 13      | qd_13                      | refck_mode[1]                | refck_mode[0]                | reserved                     | reserved                     | reserved                      | reserved                      | cdr_lol_set[1]                | cdr_lol_set[0]                |  |
| 14      | qd_14                      | reserved                     | reserved                     | reserved                     | pll_lol_set[1]               | pll_lol_set[0]                | tx_vco_ck_div[2]              | tx_vco_ck_div[1]              | tx_vco_ck_div[0]              |  |
| 15      | qd_15                      | reserved                     | reserved                     | reserved                     | reserved                     | reserved                      | reserved                      | reserved                      | reserved                      |  |
| 16      | qd_int_<br>16 2            | lol_int_ctl                  | ~plol_int_ctl                | reserved                     | reserved                     | reserved                      | reserved                      | reserved                      | reserved                      |  |
| クワ      | ッド用の                       | <b>のクロックリセ</b>               | <b>ヹット・レジス</b>               | タ (5)                        |                              |                               |                               |                               |                               |  |
| 17      | qd_17                      | lane_rx_rst3                 | lane_rx_rst2                 | lane_rx_rst1                 | lane_rx_rst0                 | lane_tx_rst3                  | lane_tx_rst2                  | lane_tx_rst1                  | lane_tx_rst0                  |  |
| 18      | qd_18                      | macropdb                     | macro_rst                    | quad_rst                     | trst                         | rrst[3]                       | rrst[2]                       | rrst[1]                       | rrst[0]                       |  |
| 19      | qd_19                      | bist_rx_data_sel             | bist_bypass_tx_<br>gate      | bist_sync_head_<br>req[1]    | bist_sync_head_<br>req[0]    | sel_sd_rx_clk3                | sel_sd_rx_clk2                | sel_sd_rx_clk1                | sel_sd_rx_clk0                |  |
| 1A      | qd_1a                      | ff_rx_clk_sel_2[3]           | ff_rx_clk_sel_2[2]           | ff_rx_clk_sel_2[1]           | ff_rx_clk_sel_2[0]           | ff_rx_clk_sel_1[3]            | ff_rx_clk_sel_1[2]            | ff_rx_clk_sel_1[1]            | ff_rx_clk_sel_1[0]            |  |
| 1B      | qd_1b                      | ff_tx_clk_sel[2]             | ff_tx_clk_sel[1]             | ff_tx_clk_sel[0]             | reserved                     | ff_rx_clk_sel_0[3]            | ff_rx_clk_sel_0[2]            | ff_rx_clk_sel_0[1]            | ff_rx_clk_sel_0[0]            |  |
| 2. ク    | 2. クワッド用のステータスレジスタ (9)     |                              |                              |                              |                              |                               |                               |                               |                               |  |
| クワ      | ッド用の                       | DPCSステータ                     | スレジスタ (                      | 5)                           |                              |                               |                               |                               |                               |  |
| 20      | qd_20                      |                              |                              |                              | int_qua_out                  | int_cha[3]                    | int_cha[2]                    | int_cha[1]                    | int_cha[0]                    |  |
| 21      | qd_21 <mark>3</mark>       | ls_sync_status_3             | ls_sync_status_2             | ls_sync_status_1             | ls_sync_status_0             | Is_sync_statusn_<br>3         | ls_sync_statusn_<br>2         | ls_sync_statusn_<br>1         | ls_sync_statusn_<br>0         |  |
| 22      | qd_int_<br>22 4            | ls_sync_status_3<br>_int     | ls_sync_status_2<br>_int     | ls_sync_status_1<br>_int     | ls_sync_status_0<br>_int     | ls_sync_statusn_<br>3_int     | ls_sync_statusn_<br>2_int     | ls_sync_statusn_<br>1_int     | ls_sync_statusn_<br>0_int     |  |
| 23      | qd_23                      | bist_report[7]               | bist_report[6]               | bist_report[5]               | bist_report[4]               | bist_report[3]                | bist_report[2]                | bist_report[1]                | bist_report[0]                |  |

LatticeECP2M 8-71 SERDES/PCS-UGJ

| 24 | qd_24                     | bist_report[15] | bist_report[14] | bist_report[13]     | bist_report[12]     | bist_report[11]     | bist_report[10]     | bist_report[9]      | bist_report[8]      |  |
|----|---------------------------|-----------------|-----------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--|
| クワ | クワッド用のSERDESステータスレジスタ (4) |                 |                 |                     |                     |                     |                     |                     |                     |  |
| 25 | qd_25 <mark>3</mark>      | plol            | ~plol           | reserved            | reserved            | reserved            | reserved            | reserved            | Reserved            |  |
| 26 | qd_int_<br>26 4           | plol_int        | ~plol_int       | reserved            | reserved            | reserved            | reserved            | reserved            | Reserved            |  |
| 27 | qd_27                     | reserved        | reserved        | pll_calib_status[5] | pll_calib_status[4] | pll_calib_status[3] | pll_calib_status[2] | pll_calib_status[1] | pll_calib_status[0] |  |
| 28 | qd_28                     | reserved        | reserved        | reserved            | reserved            | reserved            | reserved            | reserved            | Reserved            |  |

- 1. BA=ベースアドレス(Hex)
- 2. 割り込み制御レジスタは、割り込み可能なステータス(int\_sts\_x)レジスタに関連します。
- 3. ステータス・レジスタは関連づけられる割り込み可能なステータス(int\_sts\_x)レジスタを持ちます。
- 4. 割り込み可能なステータス・レジスタ; リードでクリア(関連づけられる制御レジスタとステータス・レジスタがある)
- 5. uc\_mode; 8ビットSERDES Onlyと10ビットSERDES Only
- 6. BISTはラティスセミコンダクター社内での使用のための内蔵のPRBSジェネレータとチェッカーです。
- 注: 特に明記しないかぎり、デフォルト値は0です。

LatticeECP2M 8-72 SERDES/PCS-UGJ

# クワッド単位のSERDES制御レジスタの詳細

# 表8-36 PCS制御レジスタ1 (QD\_00)

| Bit | Name        | 記 述                                                                               | タイプ | デフォルト |
|-----|-------------|-----------------------------------------------------------------------------------|-----|-------|
| 7   | sync_toggle | 遷移 = Txレーン間スキューを最少化するためにTxシリアラ<br>イザをリセット<br>レベル = Txシリアライザの通常動作                  |     |       |
| 6   | force_int   | 1 = 割り込み信号を強制的に生成する<br>0 = 通常動作                                                   | R/W | 0     |
| 5   | char_mode   | 1 = SERDES キャラクタライズ・モードをイネーブル<br>0 = SERDESキャラクタライズ・モードをディセーブル                    | R/W | 0     |
| 4   | xge_mode    | 1 = 10Gb Ethernetモードを選択<br>0 = 1Gb Ethernetモードを選択                                 | R/W | 0     |
| 3   | rio_mode    | 1 = Rapid-IOモードを選択<br>0 = その他モード(10GbE, 1GbE)を選択                                  | R/W | 0     |
| 2   | pcie_mode   | 1 = PCI Expressモードの動作<br>0 = その他モード(RapidIO, 10GbE, 1GbE)を選択                      | R/W | 0     |
| 1   | fc_mode     | 1 = Fibre Channelモードを選択<br>0 = その他モード(PCI Express, RapidIO, 10GbE, 1GbE)を<br>選択   | R/W | 0     |
| 0   | uc_mode     | 1 = User Configuredモードの選択<br>0 = その他モード(PCI Express, RapidIO, 10GbE, 1GbE)を<br>選択 |     |       |

注: 明示される場合を除いて、いづれかのSERDES制御レジスタにライトした後は、全チャネルをリセットしなければなりません。

## 表8-37 PCS制御レジスタ2 (QD\_01)

| Bit | Name                  | 記 述                                                                                                                                | タイプ | デフォルト |
|-----|-----------------------|------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:6 | bist_rpt_ch_sel [1:0] | 00 = BISTレポート、チャネル0から<br>01 = BISTレポート、チャネル1から<br>10 = BISTレポート、チャネル2から<br>11 = BISTレポート、チャネル3から                                   | R/W | 00    |
| 5:4 | bist_res_sel [1:0]    | BIST resolution の選択<br>00 = エラーなし<br>01 < 2エラー<br>10 < 16エラー<br>11 < 128エラー                                                        | R/W | 00    |
| 3:2 | bist_time_sel [1:0]   | BIST time の選択:<br>00 = 5e+8 サイクル<br>01 = 5e+9 サイクル<br>10 = 5e+6 サイクル<br>11 = 100K サイクル                                             | R/W | 00    |
| 1:0 | bist_head_sel [1:0]   | BIST header の選択<br>00 = K28_5 (K28_5=10'h305 K28_5_=10'h0FA)<br>01 = A1A2 (MA1=10'h1F6; MA2=10'h128)<br>10 = 10'h1BC<br>11 = ユーザ定義 | R/W | 00    |

LatticeECP2M 8-73 SERDES/PCS-UGJ

#### 表8-38 PCS制御レジスタ3 (QD\_02)

|   | Bit | Name            | 記 述                                     | タイプ | デフォルト   |
|---|-----|-----------------|-----------------------------------------|-----|---------|
|   | 7:4 | high_mark [3:0] | クロック補償FIFO、high water mark。 平均は 4'b1000 | R/W | 4'b0111 |
| Ī | 3:0 | low_mark [3:0]  | クロック補償FIFO、low water mark。 平均は 4'b1000  | R/W | 4'b1001 |

## 表8-39 PCS制御レジスタ4 (QD\_03)

| Bit | Name              | 記 述                                                                          | タイプ | デフォルト |
|-----|-------------------|------------------------------------------------------------------------------|-----|-------|
| 7:6 | min_ipg_cnt [1:0] | 最少IPG to enforce                                                             | R/W | 2'b11 |
| 5   | match_4_enable    | 1 = 4キャラクのスキップマッチングをイネーブル<br>(match 4, 3, 2, 1を使用)                           | R/W | 0     |
| 4   | match_2_enable    | 1 = 2キャラクのスキップマッチングをイネーブル<br>(match 4,3を使用)                                  | R/W | 1     |
| 3   | Reserved          |                                                                              |     |       |
| 2   | pfifo_clr_sel     | 1 = pfifo_clr信号、又はチャネルレジスタビットが<br>FIFOをクリア<br>0 = pfifo_error内部信号が自らFIFOをクリア | R/W | 0     |
| 1   | asyn_mode         | テスト用途のみ。非同期リセットを選択                                                           | R/W | 0     |
| 0   | sel_test_clk      | テスト用途のみ。テストクロックを選択                                                           | R/W | 0     |

## 表8-40 PCS制御レジスタ5 – CC match1 LO (QD\_04)

| Bit | Name                | 記述                          | タイプ | デフォルト |
|-----|---------------------|-----------------------------|-----|-------|
| 7:0 | cc_match_1<br>[7:0] | ユーザ定義クロック補償のスキップパターン1、下位バイト | R/W | 8'h00 |

# 表8-41 PCS制御レジスタ6 – CC match2 LO (QD\_05)

| Bit | Name                | 記 述                         | タイプ | デフォルト |
|-----|---------------------|-----------------------------|-----|-------|
| 7:0 | cc_match_2<br>[7:0] | ユーザ定義クロック補償のスキップパターン2、下位バイト | R/W | 8'h00 |

# 表8-42 PCS制御レジスタ7 – CC match3 LO (QD\_06)

| Bit | Name                | 記 述                         |     | デフォルト |
|-----|---------------------|-----------------------------|-----|-------|
| 7:0 | cc_match_3<br>[7:0] | ユーザ定義クロック補償のスキップパターン3、下位バイト | R/W | 8'hBC |

## 表8-43 PCS制御レジスタ8 – CC match4 LO (QD\_07)

|   | Bit | Name                | 記 述                         | タイプ | デフォルト |
|---|-----|---------------------|-----------------------------|-----|-------|
| ſ | 7:0 | cc_match_4<br>[7:0] | ユーザ定義クロック補償のスキップパターン4、下位バイト | R/W | 8'h50 |

LatticeECP2M 8-74 SERDES/PCS-UGJ

#### 表8-44 PCS制御レジスタ9 – CC match HI (QD\_08)

| Bit | Name                | 記 述                                                                   | タイプ | デフォルト |
|-----|---------------------|-----------------------------------------------------------------------|-----|-------|
| 7:6 | cc_match_4<br>[9:8] | ユーザ定義クロック補償のスキップパターン4、上位バイト<br>[9] = ディスパリティエラーerror<br>[8] = Kコントロール | R/W | 2'b01 |
| 5:4 | cc_match_3<br>[9:8] | ユーザ定義クロック補償のスキップパターン3、上位バイト<br>[9] = ディスパリティエラーerror<br>[8] = Kコントロール | R/W | 2'b01 |
| 3:2 | cc_match_2<br>[9:8] | ユーザ定義クロック補償のスキップパターン2、上位バイト<br>[9] = ディスパリティエラーerror<br>[8] = Kコントロール | R/W | 2'b00 |
| 1:0 | cc_match_1<br>[9:8] | ユーザ定義クロック補償のスキップパターン1、上位バイト<br>[9] = ディスパリティエラーerror<br>[8] = Kコントロール | R/W | 2'b00 |

#### 表8-45 PCS制御レジスタ10 – UDF comma mask LO (QD\_09)

| Bit | Name                 | 記 述               | タイプ | デフォルト |
|-----|----------------------|-------------------|-----|-------|
| 7:0 | udf_comma_mask [7:0] | ユーザ定義コンママスク、下位バイト | R/W | 8'hFF |

## 表8-46 PCS制御レジスタ11 – UDF comma a LO (QD\_0A)

| Bit | Name              | 記述                      | タイプ | デフォルト |  |
|-----|-------------------|-------------------------|-----|-------|--|
| 7:0 | udf_comma_a [7:0] | ユーザ定義コンマキャラクタ "a"、下位バイト | R/W | 8'h83 |  |

## 表8-47 PCS制御レジスタ12 – UDF comma b LO (QD\_0B)

| Bit | Name              | 記述                      | タイプ | デフォルト |
|-----|-------------------|-------------------------|-----|-------|
| 7:0 | udf_comma_b [7:0] | ユーザ定義コンマキャラクタ "b"、下位バイト | R/W | 8'h7C |

## 表8-48 PCS制御レジスタ13 – UDS comma HI (QD\_0C)

| Bit | Name                 | 記述                                    | タイプ | デフォルト |
|-----|----------------------|---------------------------------------|-----|-------|
| 7:6 | udf_comma_a [9:8]    | ユーザ定義コンマキャラクタ "a"、上位ビット               | R/W | 2'b10 |
| 5:4 | udf_comma_a [9:8]    | ユーザ定義コンマキャラクタ "b"、上位ビット               | R/W | 2'b01 |
| 3:2 | udf_comma_mask [9:8] | ユーザ定義コンママスク、上位ビット                     | R/W | 2'b11 |
| 1   | bist_mode            | 1 = 連続BISTモード<br>0 = "Timed BIST" モード | R/W | 0     |
| 0   | bist_en              | 1 = PCS BISTをイネーブル<br>0 = 通常動作        | R/W | 0     |

## 表8-49 PCS制御レジスタ14 – UDF BIST header LO (QD\_0D)

| Bit | Name                      | 記 述                | タイプ | デフォルト |
|-----|---------------------------|--------------------|-----|-------|
| 7:0 | bist_udf_def_header [7:0] | ユーザ定義BISTヘッダの下位バイト | R/W | 8'h00 |

## 表8-50 PCS制御レジスタ15 – UDF BIST header MD (QD\_0E)

| Bit | Name                       | 記 述                | タイプ | デフォルト |
|-----|----------------------------|--------------------|-----|-------|
| 7:0 | bist_udf_def_header [15:8] | ユーザ定義BISTヘッダの中間バイト | R/W | 8'h00 |

## 表8-51 PCS制御レジスタ16 – UDF BIST headerHID (QD\_0F)

| Bit | Name                        | 記 述                                                                                                                                          | タイプ | デフォルト  |
|-----|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----|--------|
| 7   | bist_bus8bit_sel            | 1 = 8ビットデータBIST<br>0 = 10ビットデータBIST R/W 0                                                                                                    | R/W | 0      |
| 6:4 | bist_ptn_sel[2:0]           | BISTパターンの選択<br>000 = PRBS11<br>001 = 最大データレート<br>010 = PRBS31<br>011 = PRBS21100 = K28_5<br>101 = A1A2110 = 5150 (繰り返し)<br>111 = 2120 (繰り返し) | R/W | 00     |
| 3:0 | bist_udf_def_header [19:16] | ユーザ定義BISTヘッダの上位ビット                                                                                                                           | R/W | 3'b000 |

# 表8-52 PCS割り込み制御レジスタ17 (QD\_10)

| Bit | Name                          | 記 述                                                                                               | タイプ | デフォルト |
|-----|-------------------------------|---------------------------------------------------------------------------------------------------|-----|-------|
| 7   | ls_sync_status_<br>3_int_ctl  | 1 = ls_sync_status_3 割り込みイネーブル(同期中)<br>0 = ls_sync_status_3 割り込みディセーブル(同期中)                       | R/W | 0     |
| 6   | ls_sync_status_<br>2_int_ctl  | 1 = ls_sync_status_2 割り込みイネーブル(同期中)<br>0 = ls_sync_status_2 割り込みディセーブル(同期中)                       | R/W | 0     |
| 5   | ls_sync_status_<br>1_int_ctl  | 1 = ls_sync_status_1 割り込みイネーブル(同期中)<br>0 = ls_sync_status_1 割り込みディセーブル(同期中)                       | R/W | 0     |
| 4   | ls_sync_statusn<br>_3_int_ctl | 1 = ls_sync_statusn_3 がLowになるときの割り込みイネーブル(同期外)<br>0 = ls_sync_statusn_3 がLowになるときの割り込みディセーブル(同期外) | R/W | 0     |
| 3   | ls_sync_status_<br>0_int_ctl  | 1 = ls_sync_status_0 割り込みイネーブル(同期中)<br>0 = ls_sync_status_0 割り込みディセーブル(同期中)                       | R/W | 0     |
| 2   | ls_sync_statusn<br>_2_int_ctl | 1 = ls_sync_statusn_2 がLowになるときの割り込みイネーブル(同期外)<br>0 = ls_sync_statusn_2 がLowになるときの割り込みディセーブル(同期外) | R/W | 0     |
| 1   | ls_sync_statusn<br>_1_int_ctl | 1 = ls_sync_statusn_1 がLowになるときの割り込みイ                                                             | R/W | 0     |
| 0   | ls_sync_statusn<br>_0_int_ctl | 1 = ls_sync_statusn_0 がLowになるときの割り込みイネーブル(同期外)<br>0 = ls_sync_statusn_0 がLowになるときの割り込みディセーブル(同期外) | R/W | 0     |

LatticeECP2M 8-76 SERDES/PCS-UGJ

## クワッド単位のSERDES制御レジスタの詳細

注: 明示される場合を除いて、いづれかのSERDES制御レジスタにライトした後は、全チャネルをリセットしなければなりません。

表8-53 SERDES制御レジスタ1 (QD\_11)

| Bit | Name                | 記述                                                                                                                 | タイプ | デフォルト  |
|-----|---------------------|--------------------------------------------------------------------------------------------------------------------|-----|--------|
| 7:6 | Reserved            |                                                                                                                    |     |        |
| 5   | TX_REFCK_SEL        | TXPLL 基準クロックの選択<br>0 = refclk (差動入力)<br>1 = core_txrefclk                                                          | R/W | 0      |
| 4   | REFCK_DCC_EN        | 1 = 基準クロックのDC結合をイネーブル<br>0 = 基準クロックのDC結合をディセーブル(デフォルト)                                                             | R/W | 0      |
| 3   | REFCK_RTERM         | 基準クロック入力バッファの終端<br>0 = 50 (デフォルト)<br>1 = ハイインピーダンス                                                                 | R/W | 0      |
| 2:0 | REFCL_OUT_SEL [2:0] | Refck制御<br>[0]: 0 = refckバッファのイネーブル、1 = ディセーブル<br>[1]: 0 = refck2coreディセーブル、1 = イネーブル<br>[2]: reserved<br>図8-47を参照 | R/W | 3'b000 |

#### 図8-47 基準クロックの選択制御



LatticeECP2M 8-77 SERDES/PCS-UGJ

#### 表8-54 SERDES制御レジスタ2 (QD\_12)

| Bit | Name            | 記述                                                                                                                                     | タイプ | デフォルト  |
|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------|-----|--------|
| 7   | REFCK25X        | 1 = 内部高速ビットクロックは25x (基準クロックは<br>100MHzのみ)<br>0 = REFCK_MODEを参照                                                                         | R/W | 0      |
| 6   | BUS8BIT_SEL     | 1 = 8ビットバス幅を選択<br>0 = 10ビットバス幅を選択(デフォルト)                                                                                               | R/W | 0      |
| 5:3 | RLOS_HSET [2:0] | LOS検出器の大振幅に対する基準電流の調整<br>000 = デフォルト<br>001 = +10%<br>010 = +15%<br>011 = +25%<br>100 = -10%<br>101 = -15%<br>110 = -25%<br>111 = -30% | R/W | 3'b000 |
| 2:0 | RLOS_LSET [2:0] | (ラティス社内用途のみ)                                                                                                                           | R/W | 3'b000 |

# 表8-55 SERDES制御レジスタ3 (QD\_13)

| Bit | Name              | 記述                                                                                                                                           |     | デフォルト              |
|-----|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------|
| 7:6 | REFCK_MODE [1:0]  | 00 = 内部高速ビットクロックは 20x か 16x<br>01 = 内部高速ビットクロックは 10x か 8x<br>1X = Reserved                                                                   | R/W | 2'b00              |
| 5:2 | Reserved          |                                                                                                                                              |     |                    |
| 1:0 | CDR_LOL_SET [1:0] | CDRロックはずれの設定 ロック アンロック 00 = +/-1000ppm x2 +/-1500ppm x2 01 = +/-2000ppm x2 +/-2500ppm x2 10 = +/-4000ppm +/-7000ppm 11 = +/-300ppm +/-450ppm | R/W | 2'b10 <sup>1</sup> |

<sup>1.</sup> ispLEVER7.0SP1からのデフォルト値

## 表8-56 SERDES制御レジスタ4 (QD\_14)

| Bit | Name               | 記 述                                                                                                                                      | タイプ | デフォルト  |
|-----|--------------------|------------------------------------------------------------------------------------------------------------------------------------------|-----|--------|
| 7:5 | Reserved           |                                                                                                                                          |     |        |
| 4:3 | PLL_LOL_SET [1:0]  | Tx PLLロックはずれの設定 ロック アンロック 00 = +/-300ppm x2 +/-600ppm x2 01 = +/-300ppm +/-2000ppm 10 = +/-1500ppm +/-6000ppm 11 = +/-4000ppm +/-6000ppm | R/W | 2'b00  |
| 2:0 | TX_VCO_CK_DIV[2:0] | VCO出力周波数の選択<br>000 = 1 分周 001 = reserved<br>010 = 2 分周 011 = reserved<br>100 = 4 分周 101 = 8 分周<br>110 = 16 分周 111 = 32 分周                | R/W | 3'b000 |

LatticeECP2M 8-78 SERDES/PCS-UGJ

#### 表8-57 SERDES制御レジスタ5 (QD\_15)

| Bit | Name     | 記述 | タイプ | デフォルト |
|-----|----------|----|-----|-------|
| 7:0 | Reserved |    |     |       |

## 表8-58 SERDES割り込み制御レジスタ6 (QD\_16)

| Bit | Name     | 記 述                                                       | タイプ   | デフォルト |
|-----|----------|-----------------------------------------------------------|-------|-------|
| 7   |          | 1 = PLOLのロックはずれ割り込みをイネーブル<br>0 = PLOLのロックはずれ割り込みをイネーブルしない | RO CR | 0     |
| 6   |          | 1 = PLOLのロック時の割り込みをイネーブル<br>0 = PLOLのロック時の割り込みをイネーブルしない   | RO CR | 0     |
| 5:0 | Reserved |                                                           |       |       |

# クワッド単位のリセットとクロック制御レジスタの詳細

# 表8-59 リセットとクロック制御レジスタ1 (QD\_17)

| Bit | Name         | 記 述                          | タイプ | デフォルト |
|-----|--------------|------------------------------|-----|-------|
| 7   | lane_rx_rst3 | 1 = チャネル3 受信ロジックヘリセット信号をアサート | R/W | 0     |
| 6   | lane_rx_rst2 | 1 = チャネル2 受信ロジックヘリセット信号をアサート | R/W | 0     |
| 5   | lane_rx_rst1 | 1 = チャネル1 受信ロジックヘリセット信号をアサート | R/W | 0     |
| 4   | lane_rx_rst0 | 1 = チャネル0 受信ロジックヘリセット信号をアサート | R/W | 0     |
| 3   | lane_tx_rst3 | 1 = チャネル3 送信ロジックヘリセット信号をアサート | R/W | 0     |
| 2   | lane_tx_rst2 | 1 = チャネル2 送信ロジックヘリセット信号をアサート | R/W | 0     |
| 1   | lane_tx_rst1 | 1 = チャネル1 送信ロジックヘリセット信号をアサート | R/W | 0     |
| 0   | lane_tx_rst0 | 1 = チャネル0 送信ロジックヘリセット信号をアサート | R/W | 0     |

# 表8-60 リセットとクロック制御レジスタ2 (QD\_18)

| Bit | Name       | 記述                 | タイプ | デフォルト |
|-----|------------|--------------------|-----|-------|
| 7   | macropdb   | 0 = パワーダウンをアサート    | R/W | 1     |
| 6   | macro_rst  | 1= マクロリセットをアサート    | R/W | 0     |
| 5   | quad_rst   | 1= クワッドリセットをアサート   | R/W | 0     |
| 4   | trst       | 1 = Txリセット         | R/W | 0     |
| 3:0 | rrst [3:0] | 1 = Rxチャネルベースのリセット | R/W | 0     |

LatticeECP2M 8-79 SERDES/PCS-UGJ

表8-61 リセットとクロック制御レジスタ3 (QD\_19)

| Bit | Name                         | 記 述                                                                                | タイプ | デフォルト |
|-----|------------------------------|------------------------------------------------------------------------------------|-----|-------|
| 7   | bist_rx_data_sel             | 0 = SERDESからのデータ<br>1 = 8b10bデコーダの後からのデータ                                          | R/W | 0     |
| 6   | bist_bypass_tx_<br>gate      | 0 = ヘッダ検出後にBISTデータ送出を開始<br>1 = ヘッダ検出に係わらずBISTデータ強制送出を開始                            | R/W | 0     |
| 5:4 | bist_sync_head_<br>req [1:0] | BIST同期ヘッダカウンタの選択<br>00 = 5'd5<br>01 = 5'd8<br>10 = 5'd14<br>11 = 5'd24             | R/W | 00    |
| 3   | sel_sd_rx_clk3               | 1 = DS FIFOライトクロックにrx_clk3 <sup>1</sup> を選択<br>0 = DS FIFOライトクロックにff_ebrd_clk_3を選択 | R/W | 0     |
| 2   | sel_sd_rx_clk2               | 1 = DS FIFOライトクロックにrx_clk2 <sup>1</sup> を選択<br>0 = DS FIFOライトクロックにff_ebrd_clk_2を選択 | R/W | 0     |
| 1   | sel_sd_rx_clk1               | 1 = DS FIFOライトクロックにrx_clk1 <sup>1</sup> を選択<br>0 = DS FIFOライトクロックにff_ebrd_clk_1を選択 | R/W | 0     |
| 0   | sel_sd_rx_clk0               | 1 = DS FIFOライトクロックにrx_clk0 <sup>1</sup> を選択<br>0 = DS FIFOライトクロックにff_ebrd_clk_0を選択 | R/W | 0     |

<sup>1.</sup> rx\_clk3はチャネル3の再生クロック

# 表8-62 リセットとクロック制御レジスタ4 (QD\_1A)

| Bit | Name             | 記 述                          | タイプ | デフォルト |
|-----|------------------|------------------------------|-----|-------|
| 7   | ff_rx_clk_sel3_2 | 1 = チャネル3にff_rx_f_clkをディセーブル | R/W | 0     |
| 6   | ff_rx_clk_sel2_2 | 1 = チャネル2にff_rx_f_clkをディセーブル | R/W | 0     |
| 5   | ff_rx_clk_sel1_2 | 1 = チャネル1にff_rx_f_clkをディセーブル | R/W | 0     |
| 4   | ff_rx_clk_sel0_2 | 1 = チャネル0にff_rx_f_clkをディセーブル | R/W | 0     |
| 3   | ff_rx_clk_sel3_1 | 1 = チャネル3にff_rx_h_clkをイネーブル  | R/W | 0     |
| 2   | ff_rx_clk_sel2_1 | 1 = チャネル2にff_rx_h_clkをイネーブル  | R/W | 0     |
| 1   | ff_rx_clk_sel1_1 | 1 = チャネル1にff_rx_h_clkをイネーブル  | R/W | 0     |
| 0   | ff_rx_clk_sel0_1 | 1 = チャネル0にff_rx_h_clkをイネーブル  | R/W | 0     |

# 表8-63 リセットとクロック制御レジスタ5 (QD\_1B)

| Bit | Name             | 記 述                         | タイプ | デフォルト |
|-----|------------------|-----------------------------|-----|-------|
| 7   | ff_tx_clk_sel2   | 1 = クワッドにff_tx_f_clkをディセーブル | R/W | 0     |
| 6   | ff_tx_clk_sel1   | 1 = クワッドにff_tx_h_clkをイネーブル  | R/W | 0     |
| 5   | ff_tx_clk_sel0   | 1 = クワッドにff_tx_q_clkをイネーブル  | R/W | 0     |
| 4   | Reserved         |                             | R/W | 0     |
| 3   | ff_rx_clk_sel3_0 | 1 = チャネル3にff_rx_q_clkをイネーブル | R/W | 0     |
| 2   | ff_rx_clk_sel3_0 | 1 = チャネル2にff_rx_q_clkをイネーブル | R/W | 0     |
| 1   | ff_rx_clk_sel3_0 | 1 = チャネル1にff_rx_q_clkをイネーブル | R/W | 0     |
| 0   | ff_rx_clk_sel3_0 | 1 = チャネル0にff_rx_q_clkをイネーブル | R/W | 0     |

LatticeECP2M 8-80 SERDES/PCS-UGJ

# クワッド単位のPCSステータス・レジスタ詳細 表8-64 PCSステータス・レジスタ1 (QD\_20)

| Bit | Name              | 記 述                        | タイプ | Int? |
|-----|-------------------|----------------------------|-----|------|
| 7:6 | Reserved          |                            |     |      |
| 5   | ion_delay         | tri_ionからの遅延されたグローバルresetn | RO  | N    |
| 4   | int_qua_out       | クワッド単位の割り込みステータス           | RO  | N    |
| 3:0 | int_cha_out [3:0] | チャネル単位の割り込みステータス           | RO  | N    |

## 表8-65 PCSステータス・レジスタ2 (QD\_21)

| Bit | Name              | 記述                                                                                      | タイプ | Int? |
|-----|-------------------|-----------------------------------------------------------------------------------------|-----|------|
| 7   | ls_sync_status_3  | 1 = sync_status_3でアラームを生成<br>0 = sync_status_3でアラームは生成しない                               | RO  | Υ    |
| 6   | ls_sync_status_2  | 1 = sync_status_2でアラームを生成<br>0 = sync_status_2でアラームは生成しない                               | RO  | Υ    |
| 5   | ls_sync_status_1  | 1 = sync_status_1でアラームを生成<br>0 = sync_status_1でアラームは生成しない                               | RO  | Υ    |
| 4   | ls_sync_status_0  | 1 = sync_status_0でアラームを生成<br>0 = sync_status_0でアラームは生成しない                               | RO  | Υ    |
| 3   | Ls_sync_statusn_3 | 1 = sync_status_3がLowに遷移する際にアラームを生成(同期外)<br>0 = sync_status_3がLowに遷移する際にアラームを生成しない(同期外) | RO  | Υ    |
| 2   | Ls_sync_statusn_2 | 1 = sync_status_2がLowに遷移する際にアラームを生成(同期外)<br>0 = sync_status_2がLowに遷移する際にアラームを生成しない(同期外) | RO  | Υ    |
| 1   | Ls_sync_statusn_1 | 1 = sync_status_1がLowに遷移する際にアラームを生成(同期外)<br>0 = sync_status_1がLowに遷移する際にアラームを生成しない(同期外) | RO  | Υ    |
| 0   | Ls_sync_statusn_0 | 1 = sync_status_0がLowに遷移する際にアラームを生成(同期外)<br>0 = sync_status_0がLowに遷移する際にアラームを生成しない(同期外) | RO  | Υ    |

# 表8-66 パケット割り込みステータス・レジスタ3 (QD\_22)

| Bit | Name                      | 記述                                                                                      | タイプ   | Int? |  |
|-----|---------------------------|-----------------------------------------------------------------------------------------|-------|------|--|
| 7   | ls_sync_status_3_<br>int  | 1 = sync_status_3で割り込みを生成(同期中)<br>0 = sync_status_3で割り込みは生成しない(同期中)                     | RO CR | Υ    |  |
| 6   | s_sync_status_2           |                                                                                         |       |      |  |
| 5   | ls_sync_status_1_<br>int  | 1 = sync_status_1で割り込みを生成(同期中)<br>0 = sync_status_1で割り込みは生成しない(同期中)                     | RO CR | Υ    |  |
| 4   | ls_sync_status_0_<br>int  | 1 = sync_status_0で割り込みを生成(同期中)<br>0 = sync_status_0で割り込みは生成しない(同期中)                     | RO CR | Υ    |  |
| 3   | ls_sync_statusn_3<br>_int | 1 = sync_status_3がLowに遷移する際に割り込みを生成(同期外)<br>0 = sync_status_3がLowに遷移する際に割り込みを生成しない(同期外) | RO CR | Υ    |  |
| 2   | ls_sync_statusn_2<br>_int | 1 = sync_status_2がLowに遷移する際に割り込みを生成(同期外)<br>0 = sync_status_2がLowに遷移する際に割り込みを生成しない(同期外) | RO CR | Υ    |  |
| 1   | Is_sync_statusn_1         |                                                                                         | RO CR | Υ    |  |
| 0   | ls_sync_statusn_0<br>_int | 1 = sync_status_0がLowに遷移する際に割り込みを生成(同期外)<br>0 = sync_status_0がLowに遷移する際に割り込みを生成しない(同期外) | RO CR | Υ    |  |

LatticeECP2M 8-81 SERDES/PCS-UGJ

## 表8-67 PCS BISTステータス・レジスタ4 (QD\_23)

| Bit | Name              | 記述            | タイプ | Int? |
|-----|-------------------|---------------|-----|------|
| 7:0 | bist_report [7:0] | BISTレポート下位バイト | RO  | Ν    |

## 表8-68 PCS BISTステータス・レジスタ5 (QD\_24)

| Bit | Name               | 記             | 述 | タイプ | Int? |
|-----|--------------------|---------------|---|-----|------|
| 7:0 | bist_report [15:8] | BISTレポート上位バイト |   | RO  | N    |

# クワッド単位のSERDESステータス・レジスタ詳細

## 表8-69 SERDESステータス・レジスタ1 (QD\_25)

| Bit | Name     | 記 述           | タイプ | デフォルト |
|-----|----------|---------------|-----|-------|
| 7   | PLOL     | 1 = PLLロックはずれ | RO  | Υ     |
| 6   | ~PLOL    | 1 = PLLロック獲得  | RO  | Υ     |
| 5:0 | Reserved |               |     |       |

## 表8-70 SERDES割り込みステータス・レジスタ2 (QD\_26)

| Bit | Name      | 記 述                                      | タイプ   | デフォルト |
|-----|-----------|------------------------------------------|-------|-------|
| 7   | PLOL_INT  | 1 = PLOLで割り込み生成<br>0 = PLOLで割り込み生成されない   | RO CR | Υ     |
| 6   | ~PLOL_INT | 1 = ~PLOLで割り込み生成<br>0 = ~PLOLで割り込み生成されない | RO CR | Y     |
| 5:0 | Reserved  |                                          |       |       |

## 表8-71 SERDESステータス・レジスタ3 (QD\_27)

| Bit | Name                      | 記述                          | タイプ | デフォルト |
|-----|---------------------------|-----------------------------|-----|-------|
| 7:6 | Reserved                  |                             |     |       |
| 5:0 | PLL_CALIB_STATUS<br>[5:0] | TxPLL VCO キャリブレーション・ステータス出力 | RO  | N     |

## 表8-72 SERDESステータス・レジスタ4 (QD\_28)

| Bit | Name     | 記述 | タイプ | デフォルト |
|-----|----------|----|-----|-------|
| 7:0 | Reserved |    |     |       |

# チャネル単位のレジスタ概要

## 表8-73 チャンネル・インタフェースのレジスタマップ

| BA<br>1 | レジス<br>夕名       | D7                       | D6                       | D5                      | D4                      | D3                      | D2                     | D1                           | D0                           |
|---------|-----------------|--------------------------|--------------------------|-------------------------|-------------------------|-------------------------|------------------------|------------------------------|------------------------------|
| 1. 制    | 御レジス            | スタ (13)                  |                          |                         |                         |                         |                        |                              | ,                            |
| チャネ     | トル単位            | <b>Zの制御レジス</b>           | タ (7)                    |                         |                         |                         |                        |                              |                              |
| 00      | ch_00           | enable_cg_align          | prbs_enable 6            | prbs_lock               | ge_an_enable            |                         |                        | invert_tx                    | invert_rx                    |
| 01      | ch_01           | pfifo_clr                | pcie_ei_en               | pcs_det_time_<br>sel[1] | pcs_det_time_<br>sel[0] | rx_gear_mode            | tx_gear_mode           | rx_ch                        | tx_ch                        |
| 02      | ch_02           | bus_width8               | sb_bypass                | sb_pfifo_lp             | sb_bist_sel             | enc_bypass              | sel_bist_txd4enc       | tx_gear_bypass               | fb_loopback                  |
| 03      | ch_03           | lsm_sel                  | signal_detect            | rx_gear_bypass          | ctc_bypass              | dec_bypass              | wa_bypass              | rx_sb_bypass                 | sb_loopback                  |
| 04      | ch_int_<br>04 2 |                          |                          |                         |                         | cc_underrun_int<br>_ctl | cc_overrun_int_<br>ctl | fb_rx_fifo_error_<br>int_ctl | fb_tx_fifo_error_<br>int_ctl |
| 05      | ch_05           |                          |                          |                         |                         |                         |                        |                              | los_hi_sel                   |
| 06      | ch_06           |                          |                          |                         |                         |                         |                        |                              |                              |
| チャネ     | トル単位            | のSERDESレ                 | ジスタ (6)                  |                         |                         |                         |                        |                              |                              |
| 07      | ch_07           | req_en                   | req_lvl_set              | rcv_dcc_en              | rate_sel[1]             | rate_sel[0]             | rx_dco_ck_div<br>[2]   | rx_dco_ck_div<br>[1]         | rx_dco_ck_div<br>[0]         |
| 80      | ch_08           | lb_ctl[3]                | lb_ctl[2]                | l b_ctl[1]              | lb_ctl[0]               | rterm_rxadj[1]          | rterm_rxadj[0]         | rterm_rx[1]                  | rterm_rx[0]                  |
| 09      | ch_09           | tdrv_amp[2]              | tdrv_amp[1]              | tdrv_amp[0]             | tdrv_pre_set[2]         | tdrv_pre_set[1]         | tdrv_pre_set[0]        | tdrv_dat_sel[1]              | tdrv_dat_sel[0]              |
| 0A      | ch_0a           |                          |                          |                         | tdrv_pre_en             | rterm_tx[1]             | rterm_tx[0]            | rate_mode_tx                 | tpwdnb                       |
| 0B      | ch_0b           |                          |                          |                         | oob_en                  | rx_refck_sel[1]         | rx_refck_sel[0]        | rate_mode_rx                 | rpwdnb                       |
| 0C      | ch_int_<br>0c 2 |                          | pci_det_done_<br>int_ctl | rlos_lo_int_ctl         | ~rlos_lo_int_ctl        | rlos_hi_int_ctl         | ~rlos_hi_int_ctl       | rlol_int_ctl                 | ~rlol_int_ctl                |
| 2. ス    | テータス            | ス・レジスタ(                  | (13)                     |                         |                         |                         |                        |                              |                              |
| チャネ     | トル単位            | Zの汎用レジス                  | タ (6)                    |                         |                         |                         |                        |                              |                              |
| 20      | ch_20 3         |                          |                          |                         |                         | cc_underrun             | cc_overrun             | fb_rx_fifo_error             | fb_tx_fifo_error             |
| 21      | ch_21 5         | prbs_error_cnt<br>[7]    | prbs_error_cnt<br>[6]    | prbs_error_cnt<br>[5]   | prbs_error_cnt<br>[4]   | prbs_error_cnt<br>[3]   | prbs_error_cnt<br>[2]  | prbs_error_cnt<br>[1]        | prbs_error_cnt<br>[0]        |
| 22      | ch_22           | fb_tx_fifo_error_<br>int | fb_rx_fifo_error_<br>int |                         |                         | cc_underrun_int         | cc_overrun_int         | fb_rx_fifo_error_<br>int     | fb_tx_fifo_error_<br>int     |
| 23      | ch_int_<br>23   |                          | ffs_ls_sync_stat         | us fb_rxrst_o           | fb_txrst_o              |                         |                        | cc_re_o                      | cc_we_o                      |
| 24      | ch_24           |                          |                          |                         |                         |                         |                        |                              |                              |
| 25      | ch_25           |                          |                          |                         |                         |                         |                        |                              |                              |
| チャネ     | トル単位            | OSERDESレ                 | ジスタ (7)                  |                         |                         |                         |                        |                              |                              |
| 26      | ch_26 3         |                          | pci_det_done             | rlos_lo                 | ~rlos_lo                | rlos_hi                 | ~rlos_hi               | rlol                         | ~rlol                        |
| 27      | ch_27           | dco_calib_err            | dco_calib_done           | dco_facq_err            | dco_facq_done           |                         |                        |                              | pci_connect                  |
| 28      | ch_28           | dco_status[7]            | dco_status[6]            | dco_status[5]           | dco_status[4]           | dco_status[3]           | dco_status[2]          | dco_status[1]                | dco_status[0]                |
| 29      | ch_29           | dco_status[15]           | dco_status[14]           | dco_status[13]          | dco_status[12]          | dco_status[11]          | dco_status[10]         | dco_status[9]                | dco_status[8]                |
| 2A      | ch_ch_<br>2a 4  |                          | pci_det_done_<br>int     | rlos_lo_int             | ~rlos_lo_int            | rlos_hi_int             | ~rlos_hi_int           | rlol_int                     | ~rlol_int                    |
| 2B      | ch_2b           |                          |                          |                         |                         |                         |                        |                              |                              |
| 2C      | ch_2c           |                          |                          |                         |                         |                         |                        |                              |                              |

LatticeECP2M 8-83 SERDES/PCS-UGJ

- 1. Ba=ベースアドレス(Hex)
- 2. 割り込み制御レジスタはは割り込み可能なステータス(int\_sts\_x)レジスタに関連づけられます。
- 3. ステータス・レジスタには関連づけられる割り込み可能なステータス(int\_sts\_x)レジスタがあります。
- 4. 割り込み可能なステータス・レジスタ 1; (関連づけられる制御レジスタとステータス・レジスタ) リードでクリア。
- 5. ステータス・レジスタ、リードでクリア。
- 6. PRBSは内蔵のロジックによって生成されて、ラティスセミコンダクター社内のテスト用のためのものです。
- 注: 特に明記しないかぎり、デフォルト値は0です。

#### 表8-74 PCS制御レジスタ1 (CH\_00)

| Bit | Name            | 記 述                                                                               | タイプ | デフォルト |
|-----|-----------------|-----------------------------------------------------------------------------------|-----|-------|
| 7   | enable_cg_align | uc_modeで動作時のみ有効。<br>able_cg_align 1 = 連続コンマアライメントをイネーブル<br>0 = 連続コンマアライメントをディセーブル |     | 0     |
| 6   | prbs_enable     | 1 = PRBSジェネレータとチェッカーをイネーブル<br>0 = 通常動作                                            | R/W | 0     |
| 5   | prbs_lock       | 1 = Lock 受信PRBSチェッカーをロック<br>0 = Lock 受信PRBSチェッカーをアンロック                            | R/W | 0     |
| 4   | ge_an_enable    | 1 = GigE自動ネゴシエーションをイネーブル<br>0 = GigE自動ネゴシエーションをディセーブル                             | R/W | 0     |
| 3:2 | Reserved        |                                                                                   |     |       |
| 1   | invert_tx       | 1 = 送信データを反転 0 = 送信データを反転しない                                                      | R/W | 0     |
| 0   | invert_rx       | 1= 受信データを反転 0= 受信データを反転しない                                                        | R/W | 0     |

#### 表8-75 PCS制御レジスタ2 (CH\_01)

| Bit | Name                      | 記述                                                                                                        | タイプ | デフォルト |
|-----|---------------------------|-----------------------------------------------------------------------------------------------------------|-----|-------|
| 7   | pfifo_clr                 | 1 = クワッドレジスタ・ビット pfifo_clr_sel が 1 にセット<br>されているとPFIFOをクリアする。これは内部信号 pfifo_clr<br>と OR されている。<br>0 = 通常動作 | R/W | 0     |
| 6   | pcie_ei_en                | 1 = PCI Express 電気的アイドル 0 = 通常動作                                                                          | R/W | 0     |
| 5:4 | pcs_det_time_s<br>el[1:0] | PCS接続検出時間<br>11 = 16us 10 = 4us 01 = 2us 00 = 8us                                                         | R/W | 0     |
| 3   | rx_gear_mode              | 1 = 全チャネルの受信パスで 2:1 ギアリングをイネーブル<br>0 = 全チャネルの受信パスで 2:1 ギアリングをディセーブ<br>ル(ギアリングなし)                          | R/W | 0     |
| 2   | tx_gear_mode              | 1 = 全チャネルの送信パスで 2:1 ギアリングをイネーブル<br>0 = 全チャネルの送信パスで 2:1 ギアリングをディセーブ<br>ル(ギアリングなし)                          | R/W | 0     |
| 1   | rx_ch                     | 1 = 受信出力がテスト・キャラクタライズ用ピンでモニタ可能にする。テスト・キャラクタライズ・モード (pcs_ctl_4_qd_03[6])は 1 にする。                           | R/W | 0     |
| 0   | tx_ch                     | 1 = トランスミッタPCS入力をテスト・キャラクタライズ用<br>ポートから供給可能にする。テスト・キャラクタライズ・モ<br>ードをイネーブルにする。                             |     | 0     |

LatticeECP2M 8-84 SERDES/PCS-UGJ

## 表8-76 PCS制御レジスタ3 (CH\_02)

| Bit | Name                                                                        | 記 述                                                        | タイプ | デフォルト |
|-----|-----------------------------------------------------------------------------|------------------------------------------------------------|-----|-------|
| 7   | bus_width8                                                                  | 1 = PCSとSERの間は8ビットバス<br>0 = PCSとSERの間は10ビットバス              | R/W | 0     |
| 6   | sb_bypass                                                                   | 1 = Tx SERDESブリッジをバイパス<br>0 = 通常動作                         | R/W | 0     |
| 5   | 1 = RxからTxへFIFOを介してパラレルループバックをイネー sb_pfifo_lp ブル 0 = 通常データ動作 1 = BISTデータを選択 |                                                            | R/W | 0     |
| 4   |                                                                             |                                                            | R/W | 0     |
| 3   | enc_bypass                                                                  | 1 = 8b10bエンコーダをバイパス<br>0 = 通常動作                            | R/W | 0     |
| 2   | sel_bist_txd4enc                                                            | 1 = 8b10bエンコーダの前で送信側にBISTデータをイネーブル $0 = $ 通常動作             | R/W | 0     |
| 1   | tx_gear_bypass                                                              | 1 = PCS Txギアボックスをバイパス<br>0 = 通常動作                          | R/W | 0     |
| 0   | fb_loopback                                                                 | 1 = PCS内FPGAブリッジの前で、RxからTxのループバックを<br>イネーブル<br>0 = 通常データ動作 | R/W | 0     |

# 表8-77 PCS制御レジスタ4 (CH\_03)

| Bit | Name           | 記 述                                                               | タイプ | デフォルト |
|-----|----------------|-------------------------------------------------------------------|-----|-------|
| 7   | lsm_sel        | 1 = ワードアライメントに外部LSMを選択<br>0 = ワードアライメントに内部LSMを選択                  | R/W | 0     |
| 6   | signal_detect  | 1 = Rx LSMを強制的にイネーブル<br>0 = ffc_signal_detect 信号に依存してRx LSMをイネーブル | R/W | 0     |
| 5   | rx_gear_bypass | 1 = PCS Rxギアボックスをバイパス<br>0 = 通常動作                                 | R/W | 0     |
| 4   | ctc_bypass     | 1 = CTCをバイパス<br>0 = 通常動作                                          | R/W | 0     |
| 3   | dec_bypass     | 1 = 8b10bデコーダをバイパス<br>0 = 通常動作                                    | R/W | 0     |
| 2   | wa_bypass      | 1 = ワードアライメントをバイパス<br>0 = 通常動作                                    | R/W | 0     |
| 1   | rx_sb_bypass   | 1 = Rx SERDESブリッジをバイパス<br>0 = 通常動作                                | R/W | 0     |
| 0   | sb_loopback    | 1 = PCSのSERDESブリッジ内でTxからRxへのループバック<br>をイネーブル<br>0 = 通常データ動作       | R/W | 0     |

LatticeECP2M 8-85 SERDES/PCS-UGJ

#### 表8-78 PCS割り込み制御レジスタ5 (CH\_04)

| Bit | Name                         | 記 述                                                       | タイプ | デフォルト |  |
|-----|------------------------------|-----------------------------------------------------------|-----|-------|--|
| 7:4 | Reserved                     |                                                           |     |       |  |
| 3   | cc_underrun_int_ctl          | 1 = cc_underrunの割り込みをイネーブル<br>0 = cc_underrunの割り込みをディセーブル | R/W | 0     |  |
| 2   | cc_overrun_int_ctl           | run_int_ctl                                               |     |       |  |
| 1   | fb_rx_fifo_error_int_<br>ctl | _rx_fifo_error_int_ 1 = 受信FPGAブリッジFIFOのエンプティ/フル条件         |     | 0     |  |
| 0   | fb_tx_fifo_error_int_<br>ctl | 1 = 送信FPGAブリッジFIFOのエンプティ/フル条件<br>での割り込みをイネーブル             | R/W | 0     |  |

# 表8-79 PCS制御レジスタ6 (CH\_05)

| Bit | Name        | 記 述                                              | タイプ | デフォルト |
|-----|-------------|--------------------------------------------------|-----|-------|
| 7:1 | Reserved    |                                                  |     |       |
| 0   | low_ hi_sel | 1 = rlos_hi を選択<br>0 = rlos_lo を選択(ラティス社内での用途のみ) | R/W | 0     |

## 表8-80 PCS制御レジスタ7 (CH\_06)

| Bit  | Name     | 記述 | タイプ | デフォルト |
|------|----------|----|-----|-------|
| 7: 0 | Reserved |    |     |       |

LatticeECP2M 8-86 SERDES/PCS-UGJ

# チャネル単位のSERDES制御レジスタ詳細

注;特に明記しない限り、SERDES制御レジスタにライトアクセスした値を有効にするには、全チャネルをリセットすること。

# 表8-81 SERDES制御レジスタ1 (CH\_07)

| Bit | Name                   | 記 述                                                                                     | タイプ | デフォルト  |
|-----|------------------------|-----------------------------------------------------------------------------------------|-----|--------|
| 7   | REQ_EN                 | 1 = 受信イコライザをイネーブル<br>0 = 受信イコライザをディセーブル                                                 |     | 0      |
| 6   | REQ_LVL_SET            | イコライザのレベル設定<br>1 = ロングリーチ用等化 0 = 中距離ルート用の等化                                             | R/W | 0      |
| 5   | RCV_DCC_EN             | 1 = レシーバDCカップリングをイネーブル<br>0 = ACカップリング (デフォルト)                                          | R/W | 0      |
| 4:3 | RATE_SEL [1:0]         | イコライザの極配置を選択<br>00 = 高域周波レンジ用の極配置<br>01 = 中域周波レンジ用の極配置<br>10 = 低域周波レンジ用の極配置<br>11 = 未使用 | R/W | 2'b00  |
| 2:0 | RX_DCO_CK_DIV<br>[2:0] | VCO出力周波数選択<br>000 = 分周比 1                                                               |     | 3'b000 |

## 表8-82 SERDES制御レジスタ2 (CH\_08)

| Bit | Name                 | 記 述                                                                                                                                                                                                              | タイプ | デフォルト |
|-----|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7:4 | LB_CTL [3:0]         | ループバック制御 [3] = slb_r2t_dat_en, rx> tx シリアルループバックをイネーブル (CDRデータ) [2] = slb_r2t_ck_en, rx> tx シリアルループバックをイネーブル (CDRクロック) [1] = slb_eq2t_en, イコライザ> ドライバ・シリアルループバックをイネーブル [0] = slb_t2r_en, tx> rx シリアルループバックをイネーブル |     | 4'h0  |
| 3:2 | RTERM_RXADJ<br>[1:0] | 終端抵抗の補償(compensation)<br>00 = default<br>01= -7%<br>10= -14%<br>11= -20%                                                                                                                                         | R/W | 2'b00 |
| 1:0 | RTERM_RX [1:0]       | 00 = 50 ohm<br>01 = 75 ohm<br>10 = 2K ohm<br>11 = 60 ohm                                                                                                                                                         | R/W | 2'b00 |

LatticeECP2M 8-87 SERDES/PCS-UGJ

# 表8-83 SERDES制御レジスタ3 (CH\_09)

| Bit                           | Name                  |                                                                                                                                                                                                                              | 記 述                                                                                            |                                                               | タイプ | デフォルト |  |
|-------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-----|-------|--|
| LatticeECP2M-35用SERDES制御レジスタ3 |                       |                                                                                                                                                                                                                              |                                                                                                |                                                               |     |       |  |
| 7:5                           | TDRV_AMP[2:0]         | CMLドライバの振幅設定<br>000 = 1040(デフォルト)<br>001 = 1280<br>010 = 1320<br>011 = 1360<br>100 = 640<br>101 = 760<br>110 = 870<br>111 = 990                                                                                              | 定 (mV), VCCOB = 1.2V<br>)                                                                      |                                                               | R/W | 0     |  |
| 4:2                           | TDRV_PRE_SET [2:0]    | Txドライバ・プリエン<br>ファシス・レベル設定<br>0<br>1<br>2<br>3<br>4<br>5<br>6                                                                                                                                                                 | %<br>0<br>16<br>36<br>40<br>44<br>56<br>80                                                     |                                                               | R/W | 0     |  |
| 1:0                           | TDRV_DAT_SEL<br>[1:0] | ドライバ出力の選択  00 = シリアライザからのデータを選択 (通常動作)  01 = シリアライザからのデータクロックをドライバに選択  10 = slb_r2t_dat_en=1 の場合 Rx> Tx シリアル・ループ バック(データ)  10 = slb_r2t_ck_en=1 の場合 Rx> Tx シリアル・ループバック(クロック)  11 = slb_eq2t_en=1 の場合、イコライザからドライバにシリアル・ループバック |                                                                                                |                                                               |     | 0     |  |
| Lattice                       | ECP2M-20/50/70/1      | 00用SERDES制御レジス                                                                                                                                                                                                               | タ3                                                                                             |                                                               |     |       |  |
| 7:5                           | TDRV_AMP[2:0]         | GUIの設定(3-bit)<br>0<br>1<br>2<br>3<br>4<br>5<br>6<br>7                                                                                                                                                                        | レジスタの設定(5-bit)<br>00101<br>00001<br>00010<br>00011<br>11100<br>10100<br>10110<br>01110         | mV<br>990<br>1250<br>1300<br>1350<br>610<br>730<br>820<br>940 | R/W | 0     |  |
| 4:3                           | TDRV_PRE_SET [4:0]    | Txドライバ・プ<br>GUIの設定(3-bit)<br>0<br>1<br>2<br>3<br>4<br>5<br>6                                                                                                                                                                 | リエンファシス・レベル設定<br>レジスタの設定(5-bit)<br>00000<br>00001<br>00010<br>01010<br>10010<br>00011<br>00100 | %<br>0<br>12<br>26<br>30<br>33<br>40<br>53                    | R/W | 0     |  |

#### 表8-84 SERDES制御レジスタ4 (CH\_0A)

| Bit | Name                     | 記 述                                                                                                                                                                                                                      | タイプ | Int?  |
|-----|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|
| 7   |                          |                                                                                                                                                                                                                          |     |       |
| 6:5 | TDRV_DAT_<br>SEL [1:0] 1 | ドライバ出力の選択 00 = シリアライザからのデータを選択 (通常動作) 01 = シリアライザからのデータクロックをドライバに選択 10 = slb_r2t_dat_en=1 の場合 Rx> Tx シリアル・ループバック (データ) 10 = slb_r2t_ck_en=1 の場合 Rx> Tx シリアル・ループバック (クロック) 11 = slb_eq2t_en=1 の場合、イコライザからドライバにシリアル・ループバック | R/W | 2'b00 |
| 4   | TDRV_PRE_<br>EN          | 1 = Txドライバ・プリエンファシスをイネーブル<br>0 = Txドライバ・プリエンファシスをディセーブル                                                                                                                                                                  | R/W | 0     |
| 3:2 | RTERM_TX<br>[1:0]        | Tx終端抵抗の選択。PCI Expressが選択されるとディセーブル<br>00 = 50 ohm (デフォルト)<br>01 = 75 ohm<br>10 = 5K ohm                                                                                                                                  | R/W | 2'b00 |
| 1   | RATE_MODE<br>_TX         | 0 = トランスミッタにフルレートを選択<br>1 = トランスミッタにハーフレートを選択                                                                                                                                                                            | R/W | 0     |
| 0   | tpwdnb                   | 0 = 送信チャネルをパワーダウン<br>1= 送信チャネルをパワーアップ                                                                                                                                                                                    | R/W | 0     |

<sup>1.</sup> LatticeECP2M-20/50/70/100のみ

# 表8-85 SERDES制御レジスタ4 (CH\_0B)

| Bit | Name               | 記 述                                                                          | タイプ | デフォルト |
|-----|--------------------|------------------------------------------------------------------------------|-----|-------|
| 7:6 | TDRV_AMP[4:3]      | 送信ドライバ振幅設定上位ビット                                                              | R/W | 0     |
| 5   | Reserved           | LatticeECP2M-20/50/70/100のみ適用R/W 2'b00                                       |     |       |
| 7:5 | Reserved           | LatticeECP2M35のみ適用                                                           |     |       |
| 4   | oob_en             | 1 = バウンダリスキャン用入力パスを配線としてイネーブルし、FPGA内の低速SERDESに受信入力を供給する(OOB用途)               | R/W | 0     |
| 3:2 | rx_refck_sel [1:0] | Rx CDR基準クロックの選択<br>00 = refclk (差動入力)<br>01 = core_rxrefclk<br>1x = reserved | R/W | 2'b00 |
| 1   | RATE_MODE_RX       | 0 = レシーバにフルレートを選択<br>1 = レシーバにハーフレートを選択                                      | R/W | 0     |
| 0   | rpwdnb             | 0 = レシーバチャネルをパワーアダウン<br>1 = レシーバチャネルをパワーアップ                                  | R/W | 0     |

## 表8-86 TDRV\_AMP設定レジスタ; LatticeECP2M-20/50/70/100

| Bit         | Name          | 記 述   | タイプ | デフォルト |
|-------------|---------------|-------|-----|-------|
| CH_0B[7:6]  | TDRV_AMP[4:3] | 表8-86 | R/W | 0     |
| CH_09 [7:5] | TDRV_AMP[2:0] | 表8-84 | R/W | 0     |

LatticeECP2M 8-89 SERDES/PCS-UGJ

#### 表8-87 SERDES割り込み制御レジスタ1 (CH\_0C)

| Bit | Name                     | 記 述                                                             | タイプ | デフォルト |
|-----|--------------------------|-----------------------------------------------------------------|-----|-------|
| 7   | Reserved                 |                                                                 |     |       |
| 6   | pci_det_done_int<br>_ctl | 1 = PCI Expressでfar-endレシーバ検出割り込みをイネーブル                         | R/W | 0     |
| 5   | rlos_lo_int_ctl          | 1 = レシーバ入力レベルがLOW閾値(rlos_lset設定)より小さい場<br>合のRx LOS割り込みをイネーブル    | R/W | 0     |
| 4   | ~rlos_lo_int_ctl         | 1 = レシーバ入力レベルがLOW閾値(rlos_lset設定)に等しいか大<br>きい場合のRx LOS割り込みをイネーブル | R/W | 0     |
| 3   | rlos_hi_int_ctl          | 1 = レシーバ入力レベルがHIGH閾値(rlos_hset設定)より小さい<br>場合のRx LOS割り込みをイネーブル   | R/W | 0     |
| 2   | ~rlos_hi_int_ctl         | 1 = レシーバ入力レベルがLOW閾値(rlos_hset設定)に等しいか大<br>きい場合のRx LOS割り込みをイネーブル | R/W | 0     |
| 1   | rlol_int_ctl             | 1 = レシーバのLOL割り込みをイネーブル                                          | R/W | 0     |
| 0   | ~rlol_int_ctl            | 1 = レシーバがLOLから復帰した際の割り込みをイネーブル                                  | R/W | 0     |

# チャネル毎のPCSステータス・レジスタ詳細 表8-88 PCSステータス・レジスタ1 (CH\_20)

| Bit | Name             | 記 述                                                      | タイプ | Int? |
|-----|------------------|----------------------------------------------------------|-----|------|
| 7:5 | Reserved         |                                                          |     |      |
| 4   | pfifo_error      | 1 = パラレルFIFOエラー<br>0 = パラレルFIFOエラーなし                     | RO  | Y    |
| 3   | cc_underrun      | 1 = CC FIFOアンダーラン<br>0 = CC FIFOアンダーランなし                 | RO  | Y    |
| 2   | cc_overrun       | 1 = CC FIFOオーバーラン<br>0 = CC FIFOオーバーランなし                 | RO  | Y    |
| 1   | fb_rx_fifo_error | 1 = FPGAブリッジ(FB) Rx FIFOオーバーラン<br>0 = FB Rx FIFOオーバーランなし | RO  | Υ    |
| 0   | fb_tx_fifo_error | 1 = FB Tx FIFOオーバーラン<br>0 = FB Tx FIFOオーバーランなし           | RO  | Y    |

# 表8-89 PCSステータス・レジスタ2 (CH\_21)

| Bit | Name        | 記述                                         | タイプ | Int? |
|-----|-------------|--------------------------------------------|-----|------|
| 7:0 | prbs_errors | PRBSエラーカウント数。リードするとクリアされる。<br>FFに達すると値を保持。 | RO  | N    |

# 表8-90 PCSステータス・レジスタ3 (CH\_22)

| Bit | Name     | 記述 | タイプ | デフォルト |
|-----|----------|----|-----|-------|
| 7:0 | Reserved |    |     |       |

## 表8-91 PCS 一般割り込みステータス・レジスタ4 (CH\_23)

| Bit | Name                 | 記 述                                                             | タイプ      | Int? |
|-----|----------------------|-----------------------------------------------------------------|----------|------|
| 7:4 | Reserved             |                                                                 |          |      |
| 3   | cc_underrun_int      | 1 = cc_underrunで割り込みを生成<br>0 = cc_underrunで割り込みを生成しない           | RO<br>CR | Υ    |
| 2   | cc_overrun_int       | 1 = cc_overrunで割り込みを生成<br>0 = cc_overrunで割り込みを生成しない             | RO<br>CR | Υ    |
| 1   | fb_rx_fifo_error_int | 1 = fb_rx_fifo_errorで割り込みを生成<br>0 = fb_rx_fifo_errorで割り込みを生成しない | RO<br>CR | Υ    |
| 0   | fb_tx_fifo_error_int | 1 = fb_tx_fifo_errorで割り込みを生成<br>0 = fb_tx_fifo_errorで割り込みを生成しない | RO<br>CR | Υ    |

# 表8-92 PCSステータス・レジスタ5 (CH\_24)

| Bit | Name               | 記 述                                                 | タイプ | Int? |
|-----|--------------------|-----------------------------------------------------|-----|------|
| 7   | Reserved           |                                                     |     |      |
| 6   | ffs_ls_sync_status | 1 = LSMはSyncステート<br>0 = LSMはSyncステートにない             | RO  | N    |
| 5   | fb_rxrst_o         | 1 = 通常動作<br>0 = FPGAブリッジRxリセット                      | RO  | Ν    |
| 4   | fb_txrst_o         | 1 = 通常動作<br>0 = FPGAブリッジTxリセット                      | RO  | N    |
| 3   | Reserved           |                                                     |     |      |
| 2   | Reserved           |                                                     |     |      |
| 1   | cc_re_o            | 1 = エラスティックFIFOリードイネーブル<br>0 = エラスティックFIFOリードディセーブル | RO  | N    |
| 0   | cc_we_o            | 1 = エラスティックFIFOライトイネーブル<br>0 = エラスティックFIFOライトディセーブル | RO  | N    |

# 表8-93 PCSステータス・レジスタ6 (CH\_25)

| Bit | Name     | 記述 | タイプ | デフォルト |
|-----|----------|----|-----|-------|
| 7:0 | Reserved |    |     |       |

LatticeECP2M 8-91 SERDES/PCS-UGJ

# チャネル毎のSERDESステータス・レジスタ詳細 *表*8-94 SERDESステータス・レジスタ1 (CH\_26)

| Bit | Name         | 記 述                                                                 | タイプ      | Int? |
|-----|--------------|---------------------------------------------------------------------|----------|------|
| 7   | Reserved     |                                                                     |          |      |
| 6   | pci_det_done | 1 = SERDESトランスミッタがレシーバ検出プロセスを完了<br>0 = SERDESトランスミッタはレシーバ検出プロセスを未完了 | RO<br>CR | Υ    |
| 5   | rlos_lo      | 1 = レシーバで検出した入力信号レベルが設定されたLOW閾値<br>より低いことを示す                        | RO<br>CR | Υ    |
| 4   | ~rlos_lo     | 1 = レシーバで検出した入力信号レベルが設定されたLOW閾値<br>に等しいか大きいことを示す                    | RO<br>CR | Υ    |
| 3   | rlos_hi      | 1 = レシーバで検出した入力信号レベルが設定されたHIGH閾値<br>より低いことを示す                       | RO<br>CR | Υ    |
| 2   | ~rlos_hi     | 1 = レシーバで検出した入力信号レベルが設定されたHIGH閾値<br>に等しいか大きいことを示す                   | RO<br>CR | Υ    |
| 1   | rlol         | 1 = CDRがデータにロックしていない(LOL)で、基準クロックにロックしていることを示す                      | RO       | Υ    |
| 0   | ~rlol        | 1 = CDRがデータにロックしていることを示す                                            | RO       | Υ    |

## 表8-95 SERDESステータス・レジスタ2 (CH\_27)

| Bit | Name           | 記 述                                                               | タイプ | Int? |
|-----|----------------|-------------------------------------------------------------------|-----|------|
| 7   | DCO_CALIB_ERR  | 1 = DCOキャリブレーションが不正の可能性があることを示す(選<br>択されたL/H境界帯域)                 | RO  | N    |
| 6   | DCO_CALIB_DONE | 1 = DCOキャリブレーション完了を示す                                             | RO  | Ν    |
| 5   | DCO_FACQ_ERR   | 1 = DCO周波数アクイジション・エラーを示す(>300ppm)                                 | RO  | Ν    |
| 4   | DCO_FACQ_DONE  | 1 = DCO周波数アクイジション完了を示す                                            | RO  | N    |
| 3:1 | Reserved       |                                                                   | RO  | Ν    |
| 0   | pci_connect    | 1 = SERDESトランスミッタがレシーバを検出(Tx側)<br>0 = SERDESトランスミッタがレシーバを不検出(Tx側) | RO  | N    |

## 表8-96 SERDESステータス・レジスタ3 (CH\_28)

| Bit | Name            | 記述              | タイプ | Int? |
|-----|-----------------|-----------------|-----|------|
| 7:0 | DCO_STATUS[7:0] | setdcoidac[7:0] | RO  | N    |

# 表8-97 SERDESステータス・レジスタ4 (CH\_29)

| Bit | Name             | 記述                                                 | タイプ | Int? |
|-----|------------------|----------------------------------------------------|-----|------|
| 7:0 | DCO_STATUS[15:8] | [1:0] = setdcoidac[9:8]<br>[7:2] = setdcoband[5:0] | RO  | N    |

LatticeECP2M 8-92 SERDES/PCS-UGJ

## 表8-98 SERDES割り込みステータス・レジスタ5 (CH\_2A)

| Bit | Name             | 記述                       | タイプ   | Int? |
|-----|------------------|--------------------------|-------|------|
| 7   | Reserved         |                          |       |      |
| 6   | pci_det_done_int | 1 = pci_det_doneで割り込みを生成 | RO CR | Υ    |
| 5   | rlos_lo_int      | 1 = rlos_loで割り込みを生成      | RO CR | Υ    |
| 4   | ~rlos_lo_int     | 1 = ~rlos_loで割り込みを生成     | RO CR | Υ    |
| 3   | rlos_hi_int      | 1 = rlos_hiで割り込みを生成      | RO CR | Υ    |
| 2   | ~rlos_hi_int     | 1 = ~rlos_hiで割り込みを生成     | RO CR | Υ    |
| 1   | rlol_int         | 1 = rlolで割り込みを生成         | RO CR | Υ    |
| 0   | ~rlol_int        | 1 = ~rlolで割り込みを生成        | RO CR | Υ    |

# 表8-99 SERDESステータス・レジスタ6 (CH\_2B)

| Bit | Name     | 記 述 | タイプ | デフォルト |
|-----|----------|-----|-----|-------|
| 7:0 | Reserved |     |     |       |

# 表8-100 SERDESステータス・レジスタ7 (CH\_2C)

| Bit | Name     | 記述 | タイプ | デフォルト |
|-----|----------|----|-----|-------|
| 7:0 | Reserved |    |     |       |

## 表8-101 異なる規格ごとのKキャラクタ

| キャラクタ      | Gbe                    | XAUI    | 1xFC                                 | PCI Express                | 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 DLLP                 |           |
| K28.3 (7C) |                        | ALIGN A |                                      | IDLE                       | PD        |
| K28.4 (9C) |                        | SEQ     |                                      |                            |           |
| K28.5 (BC) | +D5.6 or<br>D16.2=IDLE | SYNC K  | +D21.4<br>+D21.5<br>+D21.5<br>= IDLE | COMMA (used for alignment) | К         |
| K28.6 (DC) |                        |         |                                      |                            |           |
| K28.7 (FC) |                        |         |                                      |                            |           |
| K29.7 (FD) | EOP                    | Т       |                                      | END                        | R (skip)  |
| K30.7 (FE) | ERR                    | ERR     |                                      | END BAD                    |           |

# 付録B. 8B10B符号語

## 表8-102 8B10B符号語

| シンボル名(モード組み合わせ表) | シンボル符号(8b10b符号) | 10-Bit GUI表記 |
|------------------|-----------------|--------------|
| K28.0            | 8`b000_11100    | 0100011100   |
| K28.5            | 8`b101_11100    | 0110111100   |
| K29.7            | 8`b111_11101    | 0011111101   |
| D16.2            | 8`b010_10000    | 0001010000   |
| D21.4            | 8`b100_10101    | 0010010101   |
| D21.5            | 8`b101_10101    | 0010110101   |
| K28.5+           | 10`b110000_0101 | 1100000101   |
| K28.5-           | 10`b001111_1010 | 0011111010   |

#### 表8-103 符号語のラティスマスク

| シンボル名(モード組み合わせ表) | シンボル符号(8b10b符号) | 10-Bit GUI表記 |
|------------------|-----------------|--------------|
| 28.5 (Mask)      | 10`b111111_1111 | 1111111111   |

# 付録C. 属性のクロスリファレンス

表8-104 属性のクロスリファレンス一覧表

英語版オリジナルを参照して下さい。

# 付録D. プロトコル依存のSERDES設定オプション

表8-105 プロトコル依存のSERDES設定オプション

| プロトコル              | DATARATE  | DATARATE<br>範囲                      | REFCK乗数      | DATA WIDTH | Rx等化                                                         |
|--------------------|-----------|-------------------------------------|--------------|------------|--------------------------------------------------------------|
| GbE                | 1.25      | MED                                 | 20X, 10X, 5X | 8, 16      | DISABLE,<br>MID_MED,<br>LONG_MED                             |
| PCI Express        | 2.5       | HIGH                                | 25X, 20X     |            | DISABLE,                                                     |
| XAUI               | 3.125     | HIGH                                | 20X          | 16         | MID_HIGH,<br>LONG_HIGH                                       |
| Generic 8b10b      |           |                                     | 20X, 10X, 5X | 8, 16      | DISABLE,                                                     |
| 8-bit SERDES_Only  | ]         | LOW,                                | 16X, 8X, 4X  | 0, 10      | MID_LOW,                                                     |
| 10-bit SERDES_Only | ANY_VALUE | MEDLOW,<br>MED,<br>MEDHIGH,<br>HIGH | 20X, 10X, 5X | 10, 20     | MID_MED,<br>MID_HIGH,<br>LONG_LOW,<br>LONG_MED,<br>LONG_HIGH |

LatticeECP2M 8-94 SERDES/PCS-UGJ