

Gowin 物理制約

ユーザーガイド

SUG935-1.4J, 2023-08-18

#### 著作権について(2023)

著作権に関する全ての権利は、Guangdong Gowin Semiconductor Corporation に留保されています。

GOŴIN富云、

※、Gowin、LittleBee、Arora、及びGOWINSEMIは、当社により、中国、 米国特許商標庁、及びその他の国において登録されています。商標又はサービスマークと して特定されたその他全ての文字やロゴは、それぞれの権利者に帰属しています。何れの 団体及び個人も、当社の書面による許可を得ず、本文書の内容の一部もしくは全部を、い かなる視聴覚的、電子的、機械的、複写、録音等の手段によりもしくは形式により、伝搬 又は複製をしてはなりません。

#### 免責事項

当社は、GOWINSEMI Terms and Conditions of Sale (GOWINSEMI取引条件)に規定されている内容を除き、(明示的か又は黙示的かに拘わらず)いかなる保証もせず、また、知的財産権や材料の使用によりあなたのハードウェア、ソフトウェア、データ、又は財産が被った損害についても責任を負いません。当社は、事前の通知なく、いつでも本文書の内容を変更することができます。本文書を参照する何れの団体及び個人も、最新の文書やエラッタ(不具合情報)については、当社に問い合わせる必要があります。

# バージョン履歴

| 日付                | バージョン  | 説明                                                       |
|-------------------|--------|----------------------------------------------------------|
| 2020/05/09        | 1.0J   | 初版。                                                      |
| 2020/09/04        | 1.1J   | ● FloorPlanner のメニューバーを最適化。                              |
|                   |        | ● Back-annotate Physical Constraints 機能を追加。              |
| 2021/06/10        | 1.2J   | Port 属性制約と Vref Constraints の併用の説明を追加。                   |
| 2021/11/02        | 1.3J   | ● バージョンの説明を変更。                                           |
| 2021/11/02        | 1.00   | ● ドキュメントの構造を調整。                                          |
| 2022/10/28        | 1.3.1J | GW1NS-2 シリーズのデバイスを削除。                                    |
| 2022/12/16        | 1.3.2J | ● A.10 その他の制約を追加。                                        |
| 2022/12/10 1.5.25 |        | ● VCC を VCCIO に更新。                                       |
| 2023/03/31        | 1.3.3J | ● Slew Rate の情報を削除。                                      |
| 2023/03/31 1.3.33 |        | ● Find 機能を削除。                                            |
|                   |        | ● BUFS の説明を更新。                                           |
| 2023/05/25        | 1.3.4J | ● Clock Assignment を Clock Net Constraints に更新。          |
| 2023/03/23        | 1.5.45 | ● Quadrant Constraints を GCLK Primitive Constraints に更新。 |
|                   |        | ● Hclk Constraints を HCLK Primitive Constraints に更新。     |
| 2023/06/30        | 1.3.5J | プリミティブグループ制約/リファレンス電圧制約/グローバルクロック                        |
| 2020/00/00        | 1.0.00 | 割り当て制約の説明を更新。                                            |
| 2023/08/18        | 1.4J   | Timing Paths 機能を削除。                                      |

<u>i</u>

# 目次

| 目次                                 | i   |
|------------------------------------|-----|
| 図一覧                                | iii |
| 表一覧                                | vi  |
| 1 本マニュアルについて                       | 1   |
| 1.1 マニュアル内容                        | 1   |
| 1.2 関連ドキュメント                       | 1   |
| 1.3 用語、略語                          | 1   |
| 1.4 テクニカル・サポートとフィードバック             | 2   |
| 2 概要                               | 3   |
| 3 FloorPlanner ⊘ GUI               | 4   |
| 3.1 起動                             | 4   |
| 3.2 インターフェース                       | 6   |
| 3.2.1 メニューバー                       | 6   |
| 3.2.2 Summary ウィンドウと Netlist ウィンドウ | 18  |
| 3.2.3 Package View ウィンドウ           | 21  |
| 3.2.4 Chip Array ウィンドウ             | 26  |
| 3.2.5 Constraint 編集ウィンドウ           | 32  |
| 3.2.6 Message ウィンドウ                | 37  |
| 4 FloorPlanner の使用                 | 38  |
| 4.1 制約ファイルの新規作成                    | 38  |
| 4.2 制約ファイルの編集                      | 40  |
| 4.2.1 制約編集の例                       | 40  |
| 4.2.2 I/O 制約の編集                    | 42  |
| 4.2.3 図プリミティブ制約の編集                 | 43  |
| 4.2.4 グループ制約の編集                    | 44  |
| 4.2.5 リザーブ制約の編集                    | 48  |
| 4.2.6 グローバルクロック割り当て制約の編集           | 49  |
| 4.2.7 グローバルクロック・プリミティブ制約の編集        | 50  |
| 4.2.8 高速クロック・プリミティブ制約の編集           | 51  |

|    | <b>4.2.9</b> リファレンス電圧制約の編集 | 52   |
|----|----------------------------|------|
| 付氨 | <b>♣ A</b> 物理制約構文仕様        | 55   |
|    | A.1 I/O 位置制約               | . 55 |
|    | A.2 I/O 属性制約               | 56   |
|    | A.3 プリミティブ位置制約             | 57   |
|    | A.4 グループ制約                 | 60   |
|    | A.4.1 プリミティブグループ制約         |      |
|    | A.4.2 相対位置グループ制約           | 62   |
|    | A.5 リソースリザーブ制約             | 63   |
|    | A.6 リファレンス電圧制約             |      |
|    | A.7 グローバルクロック・プリミティブ制約     | 64   |
|    | A.8 グローバルクロック割り当て制約        | 65   |
|    | A.9 高速クロック・プリミティブ制約        | 67   |
|    | A.10 その他の制約                | 67   |
|    | A.10.1 JTAGSEL_N net の制約   | 67   |
|    | A.10.2 RECONFIG_N net の制約  | 68   |

# 図一覧

| 図 3-1 メニューバーから起動                                    | 4  |
|-----------------------------------------------------|----|
| 図 3-2 Process ウィンドウから起動                             | 5  |
| 図 3-3 Start Page ウィンドウから起動                          | 5  |
| ☑ 3-4 FloorPlanner ∅ GUI                            | 6  |
| 図 3-5 File メニュー                                     | 7  |
| ☑ 3-6 Open Physical Constraints                     | 7  |
| 図 3-7 Constraints メニュー                              | 8  |
| 図 3-8 プリミティブ検索ダイアログボックス                             | 8  |
| 図 3-9 プリミティブグループの新規作成                               | 10 |
| 図 3-10 正しいプリミティブグループ                                | 10 |
| 図 3-11 無効な位置                                        | 11 |
| 図 3-12 無効な位置                                        | 11 |
| 図 3-13 相対位置グループの作成                                  | 12 |
| 図 3-14 正しい相対位置グループ                                  | 12 |
| 図 3-15 リザーブ制約                                       | 12 |
| 図 3-16 クロック制約                                       | 13 |
| 図 3-17 グローバルクロック・プリミティブ制約の作成 (GW1N-1)               | 14 |
| 図 3-18 グローバルクロック・プリミティブ制約の作成 (GW2A-18)              | 14 |
| 図 3-19 高速クロック・プリミティブ制約の作成                           | 15 |
| 図 3-20 リファレンス電圧制約                                   | 15 |
| 図 3-21 Tools メニュー                                   | 16 |
| 図 3-22 Back-annonate Physical Constraints ダイアログボックス | 16 |
| 図 3-23 Port の配置情報                                   | 17 |
| 図 3-24 View メニュー                                    | 17 |
| 図 3-25 Windows メニュー                                 | 18 |
| 図 3-26 Summary ウィンドウ                                | 18 |
| 図 3-27 Netlist ウィンドウ                                | 19 |
| 図 3-28 BUS と非 BUS を組み合わせた表示                         | 20 |
| 図 3-29 階層表示                                         | 20 |
| 図 3-30 Netlist ウィンドウでの右クリックメニュー                     | 21 |

| 図 3-31 GW1NRF-4B-QFN48 の Package View ウィンドウ        | 22 |
|----------------------------------------------------|----|
| 図 3-32 Package View の右クリックメニュー                     | 23 |
| 図 3-33 差動ペア表示                                      | 23 |
| 図 3-34 Top View                                    | 24 |
| 図 3-35 Bottom View                                 | 24 |
| ☑ 3-36 GW1N-9-WLCSP81M Top View                    | 25 |
| 図 3-37 GW1N-9-WLCSP81M Bottom View                 | 25 |
| 図 3-38 Chip Array ウィンドウ                            | 26 |
| 図 3-39 グリッドモードでの制約                                 | 27 |
| 図 3-40 マクロセル・モードでの制約                               | 27 |
| 図 3-41 プリミティブモードでの制約                               | 28 |
| 図 3-42 Chip Array の右クリックメニュー                       | 30 |
| ☑ 3-43 Show Place View                             | 31 |
| 図 3-44 マウスオーバー表示                                   | 31 |
| 図 3-45 右クリックメニューによるハイライト表示                         | 32 |
| 図 3-46 I/O 制約ウィンドウ                                 | 33 |
| 図 3-47 プリミティブ制約ウィンドウ                               | 34 |
| 図 3-48 グループ制約ウィンドウ                                 | 34 |
| 図 3-49 リザーブ制約ウィンドウ                                 | 35 |
| 図 3-50 クロック制約ウィンドウ                                 | 35 |
| 図 3-51 グローバルクロック・プリミティブ制約ウィンドウ                     | 36 |
| 図 3-52 高速クロック・プリミティブ制約ウィンドウ                        | 36 |
| 図 3-53 Vref 制約ウィンドウ                                | 37 |
| 図 3-54 Message ウィンドウ                               | 37 |
| 図 4-1 制約ファイルの新規作成                                  | 38 |
| 図 4-2 デバイスの選択                                      | 39 |
| 図 4-3 出力ファイルの保存                                    | 40 |
| 図 4-4 Chip Array にドラッグして I/O Constraints を作成       | 42 |
| 図 4-5 Package View にドラッグして I/O Constraints を作成     | 43 |
| 図 4-6 Chip Array にドラッグして Primitive Constraints を作成 | 44 |
| 図 4-7 Group Constraints ウィンドウの右クリックメニュー            | 44 |
| 図 4-8 Primitive Group Constraints の作成              | 45 |
| ☑ 4-9 Primitive Group Constraints                  | 46 |
| 図 4-10 Relative Group Constraints の作成              | 47 |
| ☑ 4-11 Relative Group Constraints                  | 48 |
| 図 4-12 Resource Reservation 制約の作成                  | 48 |
| ☑ 4-13 Resource Reservation                        |    |
| 図 4-14 Clock Net Constraints 制約の作成                 | 50 |

| 凶 4-15 Clock Net Constraints 制約                                | 50 |
|----------------------------------------------------------------|----|
| 図 4-16 GCLK Primitive Constraints の作成                          | 51 |
| ☑ 4-17 GCLK Primitive Constraints                              | 51 |
| 図 4-18 HCLK Primitive Constraints の作成                          | 52 |
| ☑ 4-19 HCLK Primitive Constraints                              | 52 |
| 図 4-20 Vref Constraints の作成                                    | 53 |
| 図 4-21 Vref Constraints 名前の重複                                  | 53 |
| 図 4-22 Chip Array ウィンドウにドラッグして Vref Constraints Location を生成   | 53 |
| 図 4-23 Package View ウィンドウにドラッグして Vref Constraints Location を生成 | 54 |

SUG935-1.4J v

# 表一覧

SUG935-1.4J vi

1.1 マニュアルについて 1.1 マニュアル内容

# 1本マニュアルについて

# 1.1 マニュアル内容

本マニュアルは、GOWIN セミコンダクターの物理制約について説明します。Gowin ソフトウェアの FloorPlanner の使用法と構文仕様の説明により、ユーザーは物理制約を迅速に実現できます。ソフトウェアのアップデートにより、一部の内容が変更される場合があります。

# 1.2 関連ドキュメント

**GOWIN** セミコンダクターのホームページ <u>www.gowinsemi.com/ja</u>から、以下の関連ドキュメントをダウンロード及び閲覧できます。

- Gowin ソフトウェア ユーザーガイド(<u>SUG100</u>)
- Gowin FPGA 製品プログラミング・コンフィギュレーション ユーザー ガイド(UG290)
- GW2A シリーズ FPGA 製品データシート(DS102)

### 1.3 用語、略語

表 1-1 に、本マニュアルで使用される用語、略語、及びその意味を示します。

表 1-1 用語、略語

| 用語、略語  | 正式名称                       | 意味          |
|--------|----------------------------|-------------|
| BSRAM  | Block SRAM                 | ブロック SRAM   |
| CFU    | Configurable Function Unit | コンフィギャラブル機能 |
|        |                            | ユニット        |
| CLKDIV | Clock Divider              | クロック分周器     |
| CLS    | Configurable Logic Section | コンフィギャラブル論理 |

SUG935-1.4J 1(68)

| 用語、略語        | 正式名称                                  | 意味           |
|--------------|---------------------------------------|--------------|
|              |                                       | セクション        |
| DCS          | Dynamic Clock Selector                | ダイナミック・クロック・ |
|              |                                       | セレクタ         |
| DLLDLY       | DLL Delay                             | DLL 遅延       |
| DQS          | Bidirectional Data Strobe Circuit for | 双方向データストローブ  |
|              | DDR Memory                            | 回路           |
| FloorPlanner | FloorPlanner                          | 物理制約エディタ     |
| FPGA         | Field Programmable Gate Array         | フィールド・プログラマブ |
|              |                                       | ル・ゲート・アレイ    |
| GCLK         | Global Clock                          | グローバルクロック    |
| I/O          | Input/Output                          | 入力/出力        |
| IDE          | Integrated Development Environment    | 統合開発環境       |
| LUT          | Look-up Table                         | ルックアップテーブル   |
| PCLK         | Primary Clock                         | プライマリクロック    |
| PLL          | Phase-locked Loop                     | 位相同期回路       |
| SCLK         | Segmented Clock                       | セグメントクロック    |
| SSRAM        | Shadow SRAM                           | 分散 SRAM      |
| VREF         | Voltage Reference                     | リファレンス電圧     |

# 1.4 テクニカル・サポートとフィードバック

GOWIN セミコンダクターは、包括的な技術サポートをご提供しています。使用に関するご質問、ご意見については、直接弊社までお問い合わせください。

ホームページ:<u>www.gowinsemi.com/ja</u>

E-mail: <a href="mailto:support@gowinsemi.com">support@gowinsemi.com</a>

SUG935-1.4J 2(68)

# **2**概要

FloorPlanner は GOWIN セミコンダクターが市場向けに独自に研究開発した物理制約エディタです。I/O、プリミティブ、Group などの属性及び位置情報の読み出しと編集をサポートすると同時に、ユーザーの構成に基づき新しい配置ファイルと制約ファイルを生成できます。これらのファイルは、I/O の属性情報と位置情報、プリミティブや Group の位置情報などを指定しています。FloorPlanner は、シンプルで使いやすい配置および制約編集機能を提供して、物理制約ファイルの作成の効率を向上させています。

以下は、FloorPlanner の特徴です。

- ユーザーデザインの読み込み、制約ファイルの読み込み、編集、および出力をサポート
- ユーザーデザインの IO Port、Primitive、Group 制約情報などの表示を サポート
- ユーザーによる制約情報の新規作成、編集、および変更をサポート
- Chip Array のグリッドモード、マクロセル・モード、およびプリミティブモードでの表示をサポート
- Package 情報に基づく Package View 表示をサポート
- Chip Array と Package View の同期表示をサポート
- 制約位置情報のリアルタイム表示および差別化表示をサポート
- ドラッグによる位置情報の設定をサポート
- IO Port の属性のバッチ構成をサポート
- Clock Net Constraints の表示および編集をサポート
- 制約情報の有効性チェックをサポート
- Back-annotate Physical Constraints 機能をサポート

SUG935-1.4J 3(68)

3 FloorPlanner の GUI 3.1 起動

# **3**FloorPlanner Ø GUI

FloorPlanner は、物理制約を作成および編集できます。表形式の制約編集と効率的なネットリストユニット検索機能を提供することで、物理制約ファイルの作成効率を向上させることができます。

# 3.1 起動

FloorPlanner は、次の3つの方法で起動できます。

 "Gowin ソフトウェア > Tools > FloorPlanner"をクリックして開きます (図 3-1)。

図 3-1 メニューバーから起動



2. プロジェクトの"Process"ウィンドウでの"Synthesize"が成功した後、 "FloorPlanner"をダブルクリックします(図 3-2)。

SUG935-1.4J 4(68)

3 FloorPlanner  $\mathcal O$  GUI 3.1 起動

図 3-2 Process ウィンドウから起動



3. "IDE > Start Page > Tools > FloorPlanner"をクリックして "FloorPlanner"を起動します(図 3-3)。

#### 図 3-3 Start Page ウィンドウから起動



#### 注記:

- FloorPlanner による制約が必要な場合、まずネットリストファイルをロードしてくだ さい。
- 1つ目の方法と2つ目の方法でFloorPlannerを起動する場合、プロジェクトのネットリストファイルが自動的にロードされます。

SUG935-1.4J 5(68)

● **3**つ目の方法で FloorPlanner を起動する場合、"File>New"でネットリストファイルをロードする必要があります。

# 3.2 インターフェース

FloorPlanner の GUI を図 3-4 に示します。

GUI には、メニューバー、ツールバー、Netlist ウィンドウ、Summary ウィンドウ、Chip Array ウィンドウ、Package View ウィンドウ、Message ウィンドウ、及び各制約編集ウィンドウなどがあります。

#### 図 3-4 FloorPlanner の GUI



#### 3.2.1 メニューバー

FloorPlanner のメニューバーには、"File"、"Constraints"、"Tools"、"View"、および"Help"の 5 つのサブメニューがあります。

#### File メニュー

File メニューを図 3-5 に示します。

SUG935-1.4J 6(68)

#### 図 3-5 File メニュー



● New:制約を新規作成します。

● Open:制約を開きます(図 3-6)。

● Reload:物理制約ファイルや配置ファイルなどを変更した場合、ファイルをリロードできます。

● Save:現在の制約情報の変更によって元の制約ファイルを上書きします。

● Save As: 現在の制約情報の変更をユーザー指定のファイルに出力します。デフォルトの制約ファイル名はネットリストのファイル名で、変更可能です。

● Exit: FloorPlanner を終了します。

#### 図 3-6 Open Physical Constraints



#### Constraints メニュー

Constraints メニューを図 3-7 に示します。

SUG935-1.4J 7(68)

#### 図 3-7 Constraints メニュー



#### **Primitive Constraints**

Primitive を選択して対応する制約を作成します。右クリックして"Select Primitives"をクリックすると、図 3-8 に示すダイアログボックスがポップアップします。

- 1. Primitives の名前またはタイプで検索し、対応する Primitive を選択します。
- 2. "OK"をクリックして制約情報を生成します。制約情報は、メイン画面下部の"Primitive Constraints"制約編集ウィンドウに表示されます。
- 3. ユーザーは、編集ウィンドウで手入力またはドラッグによって位置情報を設定できます。

#### 注記:

制約された位置は、Chip Array ウィンドウでライトブルーのハイライトで表示されます。

図 3-8 プリミティブ検索ダイアログボックス



SUG935-1.4J 8(68)

#### **Group Constraints**

Group Constraints には、New Primitive Group および New Relative Group が含まれます。

Primitive Group を作成します。

- 1. "Primitive Group > New Primitive Group"を選択すると、図 3-9 に示す ダイアログボックスがポップアップします。
- 2. ユーザーは、Group の名前、含まれる Primitive、位置情報、及び Group の Exclusive 情報を設定できます。 "♣"と"★"の 2 つのボタンで Primitive を追加及び削除できます。図 3-10 は、正しく作成された Primitive Group です。

#### 注記:

- Group の名前、含まれる Primitive、Group の位置は入力必須項目です。
- 以下の方法で、Group の位置情報を入力できます。
  - 手入力します。
  - Group 制約の作成前に、"Chip Array"ウィンドウで位置をコピーし、"New Primitive Group>Locations"にペーストします。
- 3. Primitive Group を作成した後、"OK"をクリックすると、Group の位置情報が構文チェックされます。
  - 位置情報が不適切または無効の場合、図 3-11 と図 3-12 のプロンプトがポップアップし、ユーザーは位置情報を変更する必要があります。
  - エラーがない場合、"OK"をクリックすると、Chip Array に使用可能な位置が表示されます。
- 4. 新しく生成されたグループ制約は、メイン画面の下部にある"Group Constraints"制約編集ウィンドウに表示されます。"Group Constraints" 制約編集ウィンドウで、Primitive Group 制約をダブルクリックすると、図 3-10 に示すダイアログボックスが開き、再度編集できます。

SUG935-1.4J 9(68)

#### 図 3-9 プリミティブグループの新規作成



#### 図 3-10 正しいプリミティブグループ



SUG935-1.4J 10(68)

#### 図 3-11 無効な位置



#### 図 3-12 無効な位置



Relative Group を作成します。

- 1. "New Relative Group"を選択すると、② 3-13 に示すダイアログボックスがポップアップします。
- ユーザーは、Group の名前、含まれる Primitive、位置情報、及び各 Primitive の相対位置情報を設定できます。"→"と"

  "で Primitive を 追加及び削除できます。図 3-14 は、作成された Relative Group 制約です。

#### 注記:

- Group の名前、含まれる Primitive、及びその Relative Location は入力必須項目です。
- 以下の方法で、Group の位置情報を入力できます。
  - 手入力します。
  - Group 制約の作成前に、"Chip Array"ウィンドウで位置をコピーし、"New Relative Group>Relative Location"にペーストします。
- 3. 構成が完了したら、"OK"をクリックして制約情報を生成します。
- 4. 生成される制約情報は、メイン画面下部の"Group Constraints"制約編集ウィンドウに表示されます。編集ウィンドウで制約をダブルクリックすると、図 3-14 に示すダイアログボックスが開き、再度編集できます。

SUG935-1.4J 11(68)

#### 図 3-13 相対位置グループの作成



#### 図 3-14 正しい相対位置グループ



#### **Resource Reservation**

- 1. Resource Reservation 制約を作成します。メイン画面下部の"Resource Reservation"制約編集ウィンドウで右クリックして Reserve Resources を選択し、制約を新規作成します。
- 2. 手入力またはドラッグによって位置情報を設定できます。
- 3. "Attribute"列をダブルクリックし、そのドロップダウン・リストから、 リザーブ位置の属性を設定できます(図 3-15)。

#### 注記:

Name 属性は、リザーブ制約を区別するために使用され、変更できません。

#### 図 3-15 リザーブ制約



SUG935-1.4J 12(68)

#### **Clock Net Constraints**

グローバルクロック割り当て制約を作成します。この制約の数に制限があるため、制約の有効性のチェックが行われます。"Clock Net Constraints"を選択すると、図 3-16 に示すダイアログボックスが表示されます。

- 1. "\*\*\*ボタンをクリックし、Net を選択します。
- 2. "Type"のドロップダウン・リストから"BUFG"、"BUFG[0]~[7]"、"BUFS"、 "LOCAL CLOCK"を選択します。
- 3. "CE"、"CLK"などのチェックボックスで Signal を構成します。構成完了後、"OK"をクリックすると、制約情報がメイン画面下部の"CLOCK Net Constraints"制約編集ウィンドウに表示されます。編集ウィンドウでダブルクリックすると、制約情報は再度編集できるようになります。

#### 注記:

Type として LOCAL\_CLOCK が選択されている場合、Signal チェックボックスはグレーアウトします。

#### 図 3-16 クロック制約



#### **GCLK Primitive Constraints**

DCS と DQCE のグローバルクロック制約を作成するために使用されます。デバイスのグローバルクロックの分布に基づき、指定される Instance を特定のグローバルクロックに制約します。メイン画面下部の"GCLK Primitive Constraints"制約編集ウィンドウで右クリックして"Select GCLK Primitive"を選択すると、図 3-17 に示すダイアログボックスがポップアップします。以下は、その操作です。

1. "
■"ボタンをクリックして対応する GCLK プリミティブを選択します。
GCLK プリミティブがデザインにない場合は、追加できません。

SUG935-1.4J 13(68)

2. "Position"の下にあるラジオボタンと対応するドロップダウンリストを 使用して、グローバルクロックの位置を構成します。

3. "OK"をクリックすると、制約情報が生成され、メイン画面下部の"GCLK Primitive Constraints"制約編集ウィンドウに表示されます。編集ウィンドウで制約をダブルクリックすると、制約情報は再度編集できるようになります。

図 3-17 グローバルクロック・プリミティブ制約の作成 (GW1N-1)

| <b>₩</b> GCLK F | rimitive Constraints ? | ×      |
|-----------------|------------------------|--------|
| Instance [      |                        | -      |
| LEFT            | RIGHT                  |        |
|                 | OK C                   | Cancel |

図 3-18 グローバルクロック・プリミティブ制約の作成(GW2A-18)

| ₩ GCLK Primitive Constraints |          | ?      | ×      |
|------------------------------|----------|--------|--------|
| Instance Position            |          |        | 4      |
|                              | TTOMLEFT | BOTTON | MRIGHT |
|                              | OK       | C      | ancel  |

#### 注記:

- "Instance"を選択すると、"Position"がハイライト表示されます。
- 使用可能な Position はデバイスとグローバルクロック・プリミティブによって異なります。

#### **HCLK Primitive Constraints**

HCLK プリミティブの制約を作成してデバイスの高速クロックの位置に制約します。メイン画面下部の"HCLK Primitive Constraints"制約編集ウィンドウで右クリックして"Select HCLK Primitive"を選択すると、図 3-19 に示すダイアログボックスがポップアップします。以下は、その操作です。

1. "**\***"ボタンをクリックして対応する **HCLK** プリミティブを選択します。 デザインに対応するプリミティブがない場合は、追加できません。

SUG935-1.4J 14(68)

2. "Position"の下にあるラジオボタンと対応するドロップダウンリストを使用して、高速クロックの位置を構成します。

3. "OK"をクリックすると、制約情報が生成され、メイン画面下部の"HCLK Primitive Constraints"制約編集ウィンドウに表示されます。編集ウィンドウで制約をダブルクリックすると、制約情報は再度編集できるようになります。

図 3-19 高速クロック・プリミティブ制約の作成



#### 注記:

- "Instance"を選択すると、"Position"がハイライト表示されます。
- 使用できる Position は、プロジェクトのデバイスによって異なります。使用できない Position はグレーアウトします。

#### **Vref Constraints**

IO Port のリファレンス電圧の構成に使用される Vref Driver を作成します。メイン画面下部の"Vref Constraints"制約編集ウィンドウで右クリックして Define Vref Driver を選択し、制約を作成します(図 3-20)

図 3-20 リファレンス電圧制約



#### 注記:

- ドラッグで Vref 制約位置を指定できます。
- Vref の名前は、ダブルクリックして変更できます。

SUG935-1.4J 15(68)

#### Tools メニュー

Tools メニューを図 3-21 に示します。

Back-annotate Physical Constraints: 各プリミティブと IO Port の配置情報を物理制約ファイルにバックアノテーションします。

図 3-21 Tools メニュー



- "Tools > Back-annotate Physical Constraints"をクリックすると、バックアノテーション対象選択ダイアログボックスが表示されます(図 3-22)。Back-Annotate Physical Constraints 機能を有効にするには、まずプロジェクトで Place&Route を正常に実行する必要があります。
- 2. Back-annonate Physical Constraints ダイアログボックスでは 1 つ以上のオブジェクトを選択できます。OK ボタンをクリックすると、"Save as"ダイアログボックスがポップアップし、その配置情報を物理制約ファイルに出力することができます。
- 3. Back-annonate Physical Constraints ダイアログボックスで Port および Port Attribute をチェックした後に生成された物理制約ファイルは図 3-23 に示すとおりです。

#### 図 3-22 Back-annonate Physical Constraints ダイアログボックス



SUG935-1.4J 16(68)

#### 図 3-23 Port の配置情報

#### View メニュー

View メニューは、主にツールバー、ウィンドウの表示の設定及び Chip Array Package View ウィンドウの拡大・縮小のなどに使用されます(図 3-24)。以下は、各サブメニューの紹介です。

- Toolbars:ツールバーのボタンの表示を制御するために使用されます。
- Windows:各ウィンドウの表示を制御するために使用されます(図 3-25)。
- Zoom In: Chip Array ビューまたは Package View ビューを拡大します。
- Zoom Out: Chip Array ビューまたは Package View ビューを縮小します。
- Zoom Fit: ウィンドウのサイズに合わせて Chip Array ビューまたは Package View ビューを拡大または縮小します。

#### 図 3-24 View メニュー



SUG935-1.4J 17(68)

#### 図 3-25 Windows メニュー



#### Help メニュー

Help メニュー > About をクリックすると、ソフトウェアのバージョン番号と著作権情報が表示されます。

# 3.2.2 Summary ウィンドウと Netlist ウィンドウ

Summary ウィンドウと Netlist ウィンドウには、現在のプロジェクトの Device、Part Number、ユーザーデザインと制約ファイルのパス情報、および Netlist 情報などが表示されます。

#### Summary ウィンドウ

図 3-26 に示すように、現在のプロジェクトで使われるデバイスの情報 (Device、Part Number)、設計ファイルと制約ファイルのパスなどが表示されます。

#### 図 3-26 Summary ウィンドウ



#### Netlist ウィンドウ

図 3-27 に示すように、Netlist ウィンドウは、ツリー構造でユーザーデザ

SUG935-1.4J 18(68)

インの Ports、Primitives、Nets、Module、及びそれらの数の情報を表示します。

#### 注記:

- Port、Primitive などの名前はフルパスの形式で表示され、デフォルトではアルファベットの昇順で並べ替えられます。
- Port と Net は、Bus と非 Bus の組み合わせで表示されます(図 3-28)。
- Module は階層表示されます。各 Module の後の括弧に各種 Instance の数が表示されます(図 3-29)。

#### 図 3-27 Netlist ウィンドウ



SUG935-1.4J 19(68)

#### 図 3-28 BUS と非 BUS を組み合わせた表示



#### 図 3-29 階層表示



SUG935-1.4J 20(68)

Netlist ウィンドウは右クリックメニューを提供し、その右クリックメニューには以下の機能があります。

- Highlight: Chip Array で対応する制約位置をハイライト表示できます。
- Edit Constraint:対応する制約情報を編集します。

#### 注記:

現在 Primitive または Port に位置制約がない場合、ハイライト機能は使用できません(図 3-30)。

図 3-30 Netlist ウィンドウでの右クリックメニュー



# 3.2.3 Package View ウィンドウ

例えば、GW1NRF-4B-QFN48 の場合、Package View は図 3-31 に示すとおりです。このウィンドウには、当該デバイスとパッケージの組み合わせの場合のユーザーI/O、電源、およびグランドピンが表示されます。カーソルを特定の位置に置くと、その位置の I/O 情報(I/O のタイプ、Bank、LVDS 情報など)が表示されます。

SUG935-1.4J 21(68)



#### 図 3-31 GW1NRF-4B-QFN48 の Package View ウィンドウ

ユーザーI/O、電源、およびグラウンドピンは異なる記号と色により区別されています。IO ピンの色は BANK により異なります。上図のピンの記号の説明は次のとおりです。

- "型"はユーザーI/O を表します。
- "量"は VCCIO を表します。
- "**□**"は VSS を表します。
- "<sup>™</sup>"は Bluetooth インターフェースを表します。

Package View は、右クリックメニューをサポートします(図 3-32)。以下は、その右クリックメニューの機能の説明です。

- Zoom In: Package View を拡大します。
- Zoom Out: Package View を縮小します。
- Zoom Fit: ウィンドウのサイズに合わせて Package View を拡大または 縮小します
- Show Differential IO Pairs: 差動ペアを表示します。赤線で繋がっているのは差動ペアです(図 3-33)。
- Top View: トップビュー(デフォルト)。図 3-34 は、GW1N-9-WLCSP64 のトップビューで、座標の原点は左上隅にあります。図 3-36 は、

SUG935-1.4J 22(68)

GW1N-9-WLCSP81M のトップビューで、座標の原点は右上隅にあります。

● Bottom View: ボトムビュー。図 3-35 は、GW1N-9-WLCSP64 のボトムビューで、座標の原点は右上隅にあります。図 3-37 は、GW1N-9-WLCSP81M のボトムビューで、座標の原点は左上隅にあります。

図 3-32 Package View の右クリックメニュー



図 3-33 差動ペア表示



SUG935-1.4J 23(68)

#### 図 3-34 Top View



#### 図 3-35 Bottom View



SUG935-1.4J 24(68)

#### 図 3-36 GW1N-9-WLCSP81M Top View



#### 図 3-37 GW1N-9-WLCSP81M Bottom View



Package View は、IO Port の制約位置の表示をサポートしています。IO ポートを Netlist ウィンドウまたは下部の I/O Constraints ウィンドウから Package View ウィンドウにドラッグすることで IO Port の位置を制約する

SUG935-1.4J 25(68)

ことができます。ドラッグすると、ドラッグされたポートの名前はマウスのそばに表示され、制約できないピンはグレーアウトします。

# 3.2.4 Chip Array ウィンドウ

は、FloorPlanner の Chip Array ウィンドウです。Chip Array ウィンドウはチップの行と列情報によってチップの I/O、CFU、CLU、DSP、PLL、BSRAM、および DQS などの分布を表示し、すべての制約位置のリアルタイム表示を実現すると同時に、拡大・縮小、位置コピー、マウスオーバー表示、ドラッグなどの機能をサポートします。

そのうち、I/O は色によって区別されます。

- 白色:このパッケージでボンディングされている I/O。
- 赤色:このパッケージでボンディングされていない **IO**。
- 青色: SIP パッケージの GW2AR-18、GW1NR-4、および GW1NR-9 デバイスの場合、I/O が青でマークされ、組み込みの構成用 I/O の位置を示します。

#### 図 3-38 Chip Array ウィンドウ



Chip Array にはグリッドモード、マクロセル・モード、プリミティブモードの3つの表示モードがあります。

SUG935-1.4J 26(68)

- グリッドモード: GRID 単位で制約位置を表示します(図 3-39)。
- マクロセル・モード: CLS、BLOCK など単位で制約位置を表示します (図 3-40)。
- プリミティブモード: REG、LUT など単位で制約位置を表示します(図 3-41)。

図 3-39 グリッドモードでの制約



図 3-40 マクロセル・モードでの制約



SUG935-1.4J 27(68)



#### 図 3-41 プリミティブモードでの制約

Chip Array は以下のドラッグ機能をサポートします。

- Netlist ウィンドウから Array ウィンドウまでドラッグ:制約の生成と 位置の指定に使用されます。
- 制約編集ウィンドウから Array ウィンドウまでドラッグ:制約位置の 指定に使用されます。

Chip Array ウィンドウには、デバイス全体に対する現在のウィンドウの位置をリアルタイムで表示するために使用される chip サブウィンドウがあります。サブウィンドウの白いボックスをドラッグすると、Chip Array のビューも一緒に移動します。また、Chip Array ウィンドウは、さまざまな色を使用して制約タイプを区別します。以下は、各色の意味です。

- 白色:選択状態にある制約位置、またはハイライト表示されている制 約位置を表示します。
- ネイビー:リザーブ制約の位置を表示します。この位置を占有できないことを示します。
- 水色:あるグリッドまたは範囲内に制約されている **I/O** とプリミティブの位置を表示します。

**Chip Array** ウィンドウは右クリックメニューをサポートし、その機能は以下のとおりです。

- Zoom In: Chip Array ビューを拡大します。
- Zoom Out: Chip Array ビューを縮小します。
- Zoom Fit: ウィンドウのサイズに合わせて Chip Array ビューを拡大または縮小します。
- Show Constraints View: Chip Array の instance 制約ビューを表示しま

SUG935-1.4J 28(68)

3 FloorPlanner  $\phi$  GUI 3.2  $4 \nu \beta - 7 x - 7 x$ 

す。

● Show Place View: Chip Array の instance 配置ビューを表示します。 Place & Route が実行されて FloorPlanner が起動した場合にのみ有効 です。それ以外の場合は、グレーアウトします。

- Show Multi-View: Chip Array の instance 制約および配置ビューを表示します。Place & Route が実行されて FloorPlanner が起動した場合にのみ有効です。それ以外の場合は、グレーアウトします。
- Show In-Out Connection: Place View で instance の入力および出力接続の instance 位置を表示および選択します。これは、Show Place View > All Instance の時にある instance が選択されている場合にのみ使用できます。それ以外の場合は、グレーアウトします。
- Show In Connection: Place View で instance の入力接続の instance 位置を表示および選択します。これは、Show Place View > All Instance の時にある instance が選択されている場合にのみ使用できます。それ以外の場合は、グレーアウトします。
- Show Out Connection: Place View で instance の出力接続の instance 位置を表示および選択します。これは、Show Place View > All Instance の時にある instance が選択されている場合にのみ使用できます。それ以外の場合は、グレーアウトします。
- Unhighlight All: すべてをハイライト表示解除します。
- Copy Location: 選択した対象の位置をコピーします。 Chip Array ウィンドウで GRID、Block などが選択されている場合にのみ使用できます (図 3-42)。

Show Place View で、Lut、Reg の密度を表示できます(図 3-43)。詳細は次のとおりです。

- ALL Instance: すべての Instance の配置状況を表示します。5 個以下の場合は薄緑色、6-10 個の場合は緑色、11 個以上の場合は濃い緑色です。
- Only Lut: すべての Lut の配置状況のみを表示します。2個以下の場合は薄緑色、3-4個の場合は緑色、5個以上の場合は濃い緑色です。
- Only Dff: すべての Reg の配置状況を表示します。2 個以下の場合は薄緑色、3-4 個の場合は緑色、4 個以上の場合は濃い緑色です。

Show Place View > ALL Instance で、デザイン内のすべての instance の配置を確認できます。

- Chip Array ウィンドウで、マウスを instance の配置位置に合わせると、 その instance の名前が表示されます。
- Netlist ウィンドウで特定の instance を右クリックして Highlight を選択 すると、この instance の配置位置が Chip Array ウィンドウでハイライ

SUG935-1.4J 29(68)

ト表示されます(図 3-45)。

#### 注記:

"Ctrl"キー+左クリックでドラッグすることで、領域を選択できます。領域を右クリックして"Copy Location"を選択すると、その領域の位置情報をコピーできます。コピーされた位置は、任意の制約編集ウィンドウにペーストできます。

# 図 3-42 Chip Array の右クリックメニュー



SUG935-1.4J 30(68)

#### 図 3-43 Show Place View



# 図 3-44 マウスオーバー表示



SUG935-1.4J 31(68)

3 FloorPlanner  $\phi$  GUI 3.2  $4 \nu \beta - 7 x - 7 x$ 



#### 図 3-45 右クリックメニューによるハイライト表示

# 3.2.5 Constraint 編集ウィンドウ

Constraint 編集ウィンドウは、"I/O Constraints"、"Primitive Constraints"、"Group Constraints"など8つの編集ウィンドウで構成され、制約編集機能と位置ドラッグ機能を提供します。以下は、各ウィンドウの紹介です。

### **I/O Constraints**

I/O Constraints はデザインの port を制約します。I/O 制約ウィンドウは 図 3-46 に示すとおりで、その各機能は以下のとおりです。

- Port 的 Direction、Bank、IO Type、Pull Mode など、ユーザーデザイン のすべての IO Port の属性及び制約情報を表示します。
- 制約位置、属性などの編集機能を提供します。
- ドラッグするか、ダブルクリックして入力することで制約情報を変更できます。

#### 注記:

- I/O の位置は、ドラッグで設定するか、ダブルクリックして入力できます。
- IOをドラッグする時、ドラッグされる IOの名前が表示されます。
- IO を Chip Array ウィンドウにドラッグすると、配置できる位置が明るくなり、配置できない位置の明るさは変わりません。
- IO を Chip Array ウィンドウにドラッグする時、配置できる位置の明るさは変わらず、 配置できない位置の明るさは暗くなります。

SUG935-1.4J 32(68)

3 FloorPlanner  $\phi$  GUI 3.2  $4 \nu \beta - 7 x - 7 x$ 

● 設定完了後、Chip Array ウィンドウの制約の位置は水色でハイライト表示され、 Package View ウィンドウの制約の位置はオレンジ色でハイライト表示されます。 ウィンドウは右クリックメニューを提供します。詳細は次のとおりです。

● Unplace:配置をキャンセルします。

● Reset Properities: Port の属性の設定をリセットします。

● Highlight:制約位置をハイライト表示します。

● **IO Type**: レベル規格を設定します。

● Drive:ドライブ強度を設定します。

● Pull Mode: プルモードを設定します。

● PCI Clamp: PCI プロトコルのオンIオフを設定します。

● Hysteresis:ヒステリシスを設定します。

● Open Drain:オープンドレイン回路のオン/オフを設定します。

● Vref:外部リファレンス電圧を設定します。

● Single Resistor:シングルエンド抵抗のオン/オフを設定します。

● **Diff Resistor**: 差動抵抗のオン/オフを設定します。

● Bank Vccio: BANK 電圧を設定します。

#### 注記:

右クリックメニューで、ユーザーはバッチで Port 属性を変更できます。ユーザーは複数 Port を選択できます。複数の Port に同じ構成可能な属性値がある場合、右クリックメニューで一括構成できます。詳しくは、『GW2A シリーズ FPGA 製品データシート(DS102)』を参照してください。

## 図 3-46 I/O 制約ウィンドウ

|   | Port    | Direction | Diff Pair | Location       | Bank | Exclusive | Ю Туре   | Drive | Pull Mode | PCI Clamp | Hys ^ |
|---|---------|-----------|-----------|----------------|------|-----------|----------|-------|-----------|-----------|-------|
| 2 | cin     | input     | Un        | place          |      | False     | LVCMOS18 | N/A   |           | N/A       | N     |
| 3 | clk     | input     |           | set Properties |      | False     | LVCMOS18 | N/A   | UP        | N/A       | N     |
| 4 | clko    | output    | Hig       | hlight         |      | False     | LVCMOS18 | 8     | UP        | N/A       | 1     |
| 5 | cout    | output    |           | Type •         |      | False     | LVCMOS18 | 8     | UP        | N/A       | 1     |
| 6 | data[0] | input     |           | steresis +     |      | False     | LVCMOS18 | N/A   | UP        | N/A       | N     |
| 7 | data[1] | input     | Ba        | nk Vccio 🕨     |      | False     | LVCMOS18 | N/A   | UP        | N/A       | N     |

#### **Primitive Constraints**

Primitive Constraints により、プリミティブの位置を制約できます。図 3-47 にプリミティブ制約ウィンドウを示します。

- 現在のすべての Primitive 制約の名前、タイプ、位置、および Exclusive 情報を表示します。
- このウィンドウは、制約位置のハイライト表示、制約の削除と追加を サポートする右クリックメニューを提供します。

SUG935-1.4J 33(68)

#### 注記:

- ドラッグするか、ダブルクリックして入力することで位置情報を変更できます。
- ダブルクリックして Exclusive 属性を設定することができます。
- Primitive 制約位置を手入力する時、位置の構文と有効性がチェックされます。図 3-11
   と図 3-12 はそのエラーメッセージです。

#### 図 3-47 プリミティブ制約ウィンドウ



# **Group Constraints**

Group Constraints により、デザインの I/O および一部のプリミティブに対してグループ制約を実行できます。グループ制約ウィンドウを図 3-48 に示します。その機能は次のとおりです。

- Primitive と Relative の2つの Group があります。現在のすべての Group 制約の名前、タイプ、含まれる Primitive の数、位置、及び Exclusive 情報を表示します。 Group をダブルクリックすると、図 3-10 または図 3-14 に示すダイアログボックス表示され、制約情報を編集および変更できます。
- このウィンドウは、制約位置のハイライト表示、制約の削除と追加を サポートする右クリックメニューを提供します。

図 3-48 グループ制約ウィンドウ



#### **Resource Reservation**

Resource Reservation は現在のパッケージにおける利用可能なリソースをリザーブ制約します。リザーブ制約ウィンドウを図 3-49 に示します。その機能は次のとおりです。

- 現在のすべてのリザーブ制約の位置情報を表示します。
- このウィンドウは、制約位置のハイライト表示、制約の削除と追加を サポートする右クリックメニューを提供します。
- Name 属性は、各リザーブ制約を区別するために使用され、ユーザー

SUG935-1.4J 34(68)

はそれを変更できません。

#### 注記:

ドラッグするか、ダブルクリックして入力することで位置情報を変更できます。

#### 図 3-49 リザーブ制約ウィンドウ



## **Clock Net Constraints**

Clock Net Constraints により、net に対してグローバルクロック割り当て制約を実行できます。クロック割り当て制約ウィンドウを図 3-50 に示します。

- 現在のすべてのクロック割り当て制約に関する情報を表示します。
- このウィンドウは、クロック割り当て制約の追加と削除をサポートする右クリックメニューを提供します。

#### 注記:

- 制約をダブルクリックして編集することができます。
- CLOCK Net に位置情報がないため、ドラッグ機能はサポートされません。
- 図 3-16 はグローバルクロック割り当て制約の新規作成のウィンドウです。

#### 図 3-50 クロック制約ウィンドウ



#### **GCLK Primitive Constraints**

GCLK Primitive Constraints により、グローバルクロック・プリミティブ制約を行うことができます。グローバルクロック・プリミティブ制約ウィンドウを図 3-51 に示します。

● Instance の名前、タイプ、および位置を含むすべてのグローバルクロック制約を表示します。

SUG935-1.4J 35(68)

・ ウィンドウは、グローバルクロック・プリミティブ制約の追加と削除 をサポートする右クリックメニューを提供します。

#### 注記:

はグローバルクロック制約の新規作成のウィンドウです。

#### 図 3-51 グローバルクロック・プリミティブ制約ウィンドウ



#### **HCLK Primitive Constraints**

HCLK Primitive Constraints により、高速クロック・プリミティブに対して制約を行うことができます。高速クロック・プリミティブ制約ウィンドウを図 3-52 に示します。

- 高速クロック関連 Instance の位置制約を表示します。これには Instance の名前、タイプ、高速クロックの位置が含まれます。
- ウィンドウは、高速クロック・プリミティブ制約の追加と削除をサポートする右クリックメニューを提供します。図 3-19 は高速クロック・プリミティブ制約の新規作成のウィンドウです。

#### 図 3-52 高速クロック・プリミティブ制約ウィンドウ



#### **Vref Constraints**

Vref Constrains により、Bank の外部リファレンス電圧を制約できます。 Vref 制約ウィンドウを図 3-53 に示します。その機能は次のとおりです。

- ユーザーカスタマイズの Vref Driver 情報の表示に使用され、ユーザーは Vref の名前、位置情報をカスタマイズできます。
- このウィンドウは、制約の位置のハイライト表示、制約情報の追加と 削除をサポートする右クリックメニューを提供します。

SUG935-1.4J 36(68)

#### 注記:

位置情報は、ドラッグでのみ設定できます。

#### 図 3-53 Vref 制約ウィンドウ



# 3.2.6 Message ウィンドウ

Message ウィンドウは、出力結果を表示します(図 3-54)。

図 3-54 Message ウィンドウ

```
Message

> Info (FP0001): Reading device GW1N-9 package PBGA256 partnumber GW1N-LV9PG256C6/I5
> Reading netlist file: "E:/counter/impl/gwsynthesis/counter.vg"
> Parsing netlist file "E:/counter/impl/gwsynthesis/counter.vg" completed
> Processing netlist completed
> Physical Constraint parsed completed
> Info (FP0002): Reading posp file E:/counter/impl/pnr/counter.db
> Info (FP0003): Reading timing paths file E:/counter/impl/pnr/counter.timing_paths
```

SUG935-1.4J 37(68)

# $oldsymbol{4}_{ ext{FloorPlanner}}$ の使用

FloorPlanner は、制約を作成および編集し、配置配線で使用する物理制約ファイルを生成できます。

# 4.1 制約ファイルの新規作成

FloorPlanner は、新規作成した物理制約ファイルと変更した物理制約ファイルを出力できます。以下は、その操作手順です。

- 1. 3.1 起動の説明に従い、FloorPlanner を起動します。
- 2. "File>New"をクリックして"New"ダイアログを開きます(図 4-1)。

#### 注記:

または、以下の2つの方法で"New"ダイアログボックスを開きます。

- ショートカットキーCtrl+N を使用します。
- ツールバーの"New"アイコンをクリックします。
- 3. プロジェクトのネットリストファイルとデバイスを選択し、"OK"をクリックします。

# 図 4-1 制約ファイルの新規作成

| ◇ New Physical Constraints | ?     | ×  |
|----------------------------|-------|----|
| Netlist File:              | Brows | e  |
| Part Number:               | Selec | t  |
| ОК                         | Cano  | el |

SUG935-1.4J 38(68)

# 図 4-2 デバイスの選択



#### 注記:

- Select …ボタンは、デバイスおよびパッケージの選択に使用されます。 GOWIN セミコンダクターのすべての FPGA デバイスがサポートされます(図 4-2)。
- 3.1 起動の 1 つ目の方法を使用して FloorPlanner を起動します。

物理制約を新規作成した後、FloorPlanner のメイン画面で以下のような操作が可能です。

- 1. ドラッグなどによってピン位置を割り当てます。
- 2. ツールバーの"Save"アイコンをクリックして制約ファイルを出力できます。
- 3. ポップアップした"Save"ダイアログボックスで、ファイル名を変更できます(oximes 4-3)。

SUG935-1.4J 39(68)

#### 図 4-3 出力ファイルの保存



# 4.2 制約ファイルの編集

FloorPlanner は、I/O 制約、プリミティブ制約、グループ制約、リソースリザーブ制約、グローバルクロック割り当て制約、グローバルクロック・プリミティブ制約、高速クロック・プリミティブ制約、リファレンス電圧制約などの作成をサポートします。 Constraints メニューから Constraints を編集および作成できます。詳細は 3.2.1 メニューバーを参照してください。

#### 注記:

制約は他の方法でも作成できます。このセクションでは主にドラッグアンドドロップおよ び編集で制約を生成する方法を紹介します。

# 4.2.1 制約編集の例

例としてユーザーデザイン counter.v を使用して、制約の作成方法を示します。

module counter1(out, cout, data, load, cin, clk, ce, clko);
output [7:0] out;
output cout;

SUG935-1.4J 40(68)

```
output clko;
input ce;
input [7:0] data;
input load, cin, clk;
reg [7:0] out;
always @(posedge clk)
begin
  if (load)
     out = data;
  else
     out = out + cin;
end
assign cout = &out & cin;
wire clkout;
CLKDIV clkdiv_inst (
    .CLKOUT(clkout),
    .HCLKIN(clk),
    .RESETN(1'b1),
    .CALIB(1'b0)
);
defparam clkdiv_inst.DIV_MODE = "2";
defparam clkdiv_inst.GSREN = "false";
DQCE dqce_inst (
    .CLKOUT(clko),
    .CLKIN(clkout),
    .CE(ce)
);
endmodule
```

SUG935-1.4J 41(68)

# 4.2.2 I/O 制約の編集

**Chip Array** にドラッグして **I/O** 制約を作成します。その手順は次のとおりです。

- 1. Chip Array ウィンドウをマクロセル・モードに拡大します。
- 2. 図 4-4 に示すように、Port "ce"を Chip Array ウィンドウの"G9"の位置 にドラッグします。
- 3. Port "ce"の位置情報は G9 になります。





Package View にドラッグして I/O Constraints を作成します。手順は次のとおりです。

- 1. "IO Constraints"編集ウィンドウをクリックします。
- 2. 図 4-5 に示すように、Port "ce"を Package View ウィンドウの **G9** の位置にドラッグします。
- 3. Port "ce"の位置情報は G9 になります。

SUG935-1.4J 42(68)



## 図 4-5 Package View にドラッグして I/O Constraints を作成

# 4.2.3 図プリミティブ制約の編集

- 1. "Primitive Constraints"編集ウィンドウで、右クリックして"Select Primitives"を選択します。"Select Primitives"ダイアログボックスが表示されたら、Primitive "cout\_d\_s"を選択して"OK"をクリックします。
- 2. 作成されたプリミティブ制約を Chip Array ウィンドウの"R5C5"位置にドラッグします(図 4-6)。
- 3. Primitive "cout d s"の位置情報は R5C5 になります。

SUG935-1.4J 43(68)



# 図 4-6 Chip Array にドラッグして Primitive Constraints を作成

# 4.2.4 グループ制約の編集

図 4-7 に示すように、Group Constraints ウィンドウで右クリックし、Primitive Group 制約と Relative Group 制約を作成します。





# プリミティブグループ制約の編集

- 1. Group Constraints 編集ウィンドウで右クリックして"New Primitive Group"を選択すると、"New Primitive Group"ダイアログボックスがポップアップします。
- 2. Group Name "grp1"を入力し、"<mark>1</mark>"をクリックすると、"Select

SUG935-1.4J 44(68)

Primitives"ダイアログボックスがポップアップします。

- 3. 設定したい Primitive "n14\_s0"、"n14\_s1"を選択して"OK"をクリックし、 Members リストに追加します。
- 4. Locations で制約位置"R9C7"を入力します(図 4-8)。
- 5. "OK"をクリックして Primitive Group Constraints を作成します(図 4-9)。

# 図 4-8 Primitive Group Constraints の作成



SUG935-1.4J 45(68)



#### **図 4-9 Primitive Group Constraints**

## 注記:

Primitive Group Constraints の Location 情報は、手動で入力するか、Chip Array ウィンドウからコピーしてペーストします。ドラッグでは入力できません。

# 相対位置グループ制約の編集

- 1. "Group Constraints"編集ウィンドウで右クリックして"New Relative Group"を選択すると、"New Relative Group"ダイアログボックスがポップアップします。
- 3. Select Primitives ダイアログボックスで設定したい Primitives "cout\_d\_s"、"n14\_s0" を選択して "OK" をクリックします。
- 4. これらの Primitive に相対位置"R0C0"、"R4C5"を追加します(図 4-10)。
- 5. "OK"をクリックして Relative Group Constraints を作成します(図 4-11)。

SUG935-1.4J 46(68)

# 図 4-10 Relative Group Constraints の作成



SUG935-1.4J 47(68)



#### **図 4-11 Relative Group Constraints**

# 4.2.5 リザーブ制約の編集

- 1. "Resource Reservation"編集ウィンドウで、右クリックメニューから "Reserve Resources"をクリックして Resource Reservation 制約を追加します(図 4-12)。
- 2. 作成された Resource Reservation 制約を Chip Array ウィンドウにドラッグします。図 4-13 に示すように、BSRAM\_R10[1]にドラッグアンドドロップして、Resource Reservation 制約を完了します。

図 4-12 Resource Reservation 制約の作成



SUG935-1.4J 48(68)

#### **図 4-13 Resource Reservation**



# 4.2.6 グローバルクロック割り当て制約の編集

- 1. Clock Net Constraints 編集ウィンドウで右クリックして"Clock Net Constraints"を選択すると、"Clock Net Constraints"ダイアログボックスがポップアップします。
- 2. "♣"をクリックすると、"Select Net"ダイアログボックスが表示されます。制約したい Net を選択して"OK"をクリックします。
- 3. Type ドロップダウン・リストからタイプを選択し、Signal タイプを設定します( $\boxtimes$  4-14)。
- 4. "OK"をクリックして Clock Net Constraints の作成を完了します(図)。

SUG935-1.4J 49(68)



#### 図 4-14 Clock Net Constraints 制約の作成

## 図 4-15 Clock Net Constraints 制約



# 4.2.7 グローバルクロック・プリミティブ制約の編集

GCLK Primitive Constraints は、DCS と DQCE に対する制約のみをサポートします。

GCLK Primitive Constraints の作成手順は以下のとおりです。

- 1. GCLK Primitive Constraints 編集ウィンドウで右クリックして "Select GCLK Primitive" を選択すると、"GCLK Primitive Constraints" ダイアログボックスが表示されます。
- 2. "➡"をクリックすると GCLK 選択ダイアログボックスがポップアッ

SUG935-1.4J 50(68)

プします。Instance を選択して "OK" をクリックし、Instance の設定を完了します。

- 3. 図に示すように、"GCLK Primitive Constraints"ダイアログボックスの "Position"で制約したいグローバルクロック位置を選択します。
- 4. GCLK Primitive Constraints ダイアログボックスで"OK"をクリックして、制約を GCLK Primitive Constraints 編集ウィンドウに追加します(図 4-17)。

#### 図 4-16 GCLK Primitive Constraints の作成

| <b>⋘</b> GCLK Primit | ?        | ×          |          |      |  |  |  |
|----------------------|----------|------------|----------|------|--|--|--|
| Instance dcs_inst    |          |            |          |      |  |  |  |
| ✓ TOPLEFT            | TOPRIGHT | BOTTOMLEFT | BOTTOMES | IGHT |  |  |  |
|                      |          | OK         | Can      | cel  |  |  |  |

#### **図 4-17 GCLK Primitive Constraints**



# 4.2.8 高速クロック・プリミティブ制約の編集

HCLK Primitive Constraints は、CLKDIV と DLLDLY Instance に対する制約のみをサポートします。

HCLK Primitive Constraints の作成手順は以下のとおりです。

- 1. HCLK Primitive Constraints 編集ウィンドウで右クリックして "Select HCLK Primitive" を選択すると、"HCLK Primitive Constraints" ダイアログボックスが表示されます。
- 2. "♪"をクリックすると HCLK ダイアログボックスがポップアップします。Instance を選択して"OK"をクリックし、Instance の設定を完了します。

SUG935-1.4J 51(68)

- 3. 図に示すように、"HCLK Primitive Constraints"ダイアログボックスの "Position"で制約したい高速クロック位置を選択します。
- 4. HCLK Primitive Constraints ダイアログボックスクリックで"OK"をクリックして、制約を HCLK Primitive Constraints 編集ウィンドウに追加します(図 4-19)。

#### 図 4-18 HCLK Primitive Constraints の作成



#### 図 4-19 HCLK Primitive Constraints



# 4.2.9 リファレンス電圧制約の編集

Chip Array ウィンドウにドラッグして Constraints を作成します。 手順は次のとおりです。

- 1. "Vref Constraints"編集ウィンドウで右クリックメニューから"Define Vref Driver"を選択してこの Vref Constraints 制約を追加します(図 4-20)。
- 2. Chip Array ウィンドウをマクロセル・モードに拡大し、Vref Constraints 編集ウィンドウで新しく作成された Vref Constraints を選択して Chip Array ウィンドウの B7 の位置にドラッグします。 Vref Constraints の Location 情報は、B7 になります(図 4-22)。

SUG935-1.4J 52(68)

## 図 4-20 Vref Constraints の作成



Vref 制約名はカスタマイズできます。Vref 名の重複は許可されません。 設定中に名前が重複する場合、プロンプトが表示されます(図 4-21)。

## 図 4-21 Vref Constraints 名前の重複



# 図 4-22 Chip Array ウィンドウにドラッグして Vref Constraints Location を生成



Package View にドラッグして Vref Constraints を作成します。手順は次のとおりです。

1. "Vref Constraints"編集ウィンドウで右クリックメニューから"Define

SUG935-1.4J 53(68)

- Vref Driver"を選択してこの Vref Constraints 制約を追加します(図 4-20)。
- 2. "Vref Constraints"編集ウィンドウで新しく作成された Vref Constraints を選択して Package View ウィンドウの B7 の位置にドラッグします。 Vref Constraints の Location 情報は、B7 になります(図 4-23)。
- 図 4-23 Package View ウィンドウにドラッグして Vref Constraints Location を生成



SUG935-1.4J 54(68)

付録 A 物理制約構文仕様 A.1 I/O 位置制約

# 付録 A 物理制約構文仕様

# A.1 I/O 位置制約

I/O 位置制約により、port、buffer を指定の IOB 位置に制約することができます。

## 構文

IO\_LOC "obj\_name" obj\_location [exclusive];

#### 制約要素

# obj\_name

obj name は、例えば port、buffer の name です。

# obj\_location

**obj\_location** は **IOB** 位置( "A11"、"B12"など)で、複数の位置を指定する場合、"A11,B2"のようにコンマで区切る必要があります。

#### exclusive

exclusive はオプションであり、制約位置の後にあります。これは、制約ステートメントの obj\_location には、obj\_name で指定されたプリミティブのみを配置できることを示します。

#### 注記:

obj\_name が escaped name フォーマット(スラッシュで始まり、スペースで終わる)の場合、obj\_name の前後に引用符が必要です。

#### 適用例

例 1

IO\_LOC "io\_1" A1;

SUG935-1.4J 55(68)

付録 A 物理制約構文仕様 A.2 I/O 属性制約

// io\_1 を pin A1 に制約します。

例 2

IO LOC "io 1" A1, B14, A15;

// io\_1 を pin A1、B14、A15 に制約し、配置の時、3 つの位置の何れか 1 つの位置に配置します。

例 3

IO\_LOC "io\_2" A1 exclusive;

// io\_2 を pin A1 に制約し、かつ A1 位置は io\_2 専用です。

例 4

IO\_LOC "io\_2" A1, B14, A15 exclusive;

// io\_2 を pin A1、B14、A15 に制約し、かつ A1、B14、A15 は io\_2 専用です。

# A.2 I/O 属性制約

I/O 属性制約は、I/O の属性値の設定に使用されます。例えば、port のレベル規格(IO\_TYPE)、プルアップ/プルダウンモード(PULL\_MODE)、ドライブ強度(DRIVE)等。属性設定の詳細については、『GW2A シリーズ FPGA製品データシート(DS102)』を参照してください。

#### 構文

IO\_PORT "port\_name" attribute = attribute\_value;

1 つの制約ステートメントにおいては複数の属性を設定できます。各属性はスペースで区切ります。

## 制約要素

属性制約が必要な I/O の name、attribute、および attribute value。

#### 適用例

例 1

IO\_PORT "port\_1" IO\_TYPE = LVTTL33;

// port 1のIO TYPEをLVTTL33に設定します。

例 2

IO\_PORT "port\_2" IO\_TYPE = LVTTL33 PULL\_MODE =KEEPER;

// port 2のIO TYPEをLVTTL33に設定し、PULL MODEの属性値を

SUG935-1.4J 56(68)

KEEPER に設定します。

例 3

IO PORT "port 3" IO TYPE=LVDS25;

// port\_3 に接続されている Buffer が IBUF の場合、この制約により、IBUF を TLVDS\_IBUF に変換できます。

# A.3 プリミティブ位置制約

Primitive Constraints は、instance を指定の GRID に配置するために使用されます。Primitive Constraints により LUT、BSRAM、SSRAM、DSP、PLL、DQS などの instance を制約することができます。

#### 構文

INS\_LOC "obj\_name" obj\_location [exclusive];

#### 制約要素

# obj name

制約オブジェクトの instance の name。

# obj\_location

obj location には、以下の数タイプがあります:

LUT 制約位置

- LUT に指定される単一の位置情報(RxCy[0-3][A-B]など)。
- 以下のように複数の行または列を指定した位置情報の範囲:
  - 複数の CLS または LUT を含む:"RxCy"、"RxCy[0-3]"。
  - 複数の行を指定する:"R[x:y]Cm"、"R[x:y]Cm[0-3]"、 "R[x:y]Cm[0-3][A-B]"。
  - 複数の列を指定する:"RxC[m:n]"、"RxC[m:n][0-3]"、 "RxC[m:n][0-3][A-B]"。
  - 複数の行及び列を指定する:"R[x:y]C[m:n]"、"R[x:y]C[m:n][0-3]"、"R[x:y]C[m:n][0-3][A-B]"。

#### 注記:

1 つの制約ステートメントに複数の ins\_locations を含めることができます。この場合、"," で区切ります。

#### PLL 制約位置

PLL 位置制約の形式は"PLL\_L"または"PLL\_R"です。左側に複数の PLL を配置できる場合、"PLL L[0]"、"PLL L[1]" …のように、右側に複数の PLL

SUG935-1.4J 57(68)

を配置できる場合、"PLL\_R[0]"、"PLL\_R[1]"…のように設定することができます。

BSRAM 制約位置

BSRAM 位置制約の形式は"BSRAM\_R10[0]"(10 行目の最初のBSRAM),"BSRAM R10[1]"…です。

DSP 制約位置

DSP 位置制約の形式は"DSP\_R19[0]"(19 行目の最初の DSP Block), "DSP\_R19[1]"…です。マクロセルを指定したい場合、DSP\_R19[0][A]または DSP R19[0][B]のようにマークすることができます。

exclusive

exclusive はオプションであり、制約位置の後にあります。これは、制約ステートメントの obj\_location には、obj\_name で指定された instance のみを配置できることを示します。

## 適用例

例 1

INS\_LOC "lut\_1" R2C3, R5C10[0][A];

// lut\_1 を R2C3 と R5C10 の 1 つ目の CLS の 1 つ目の LUT の位置に制 約します。

例 2

INS LOC "ins 2" R5C6[2] exclusive;

// ins\_2 を R5C6 の 3 つ目の CLS の位置に制約し、かつこの位置は当該 instance 専用です。

例 3

INS\_LOC "ins\_3" R[2:6]C2;

#ins 3を2行目から6行目、かつ2列目の範囲に制約します。

例 4

INS LOC "ins 4" R[2:4]C[2:6] exclusive;

// ins\_4 を 2 行目から 4 行目、かつ 2 列目から 6 列目の範囲に制約し、かつこの範囲はこの instance 専用です。

例 5

INS\_LOC "ins\_5" R[2:4]C[2:6][1];

SUG935-1.4J 58(68)

// ins\_5 を 2 行目から 4 行目、かつ 2 列目から 6 列目の範囲内の何れか 1 つの GRID の 2 つ目の CLS に制約します。

例 6

INS\_LOC "reg\_name" B14;

// REGISTER、IOLOGIC の INS\_LOC 制約によりこれを IOB の B14 位置に制約します。

例 7

INS\_LOC "pll\_name" PLL\_L;

// PLL の INS LOC 制約によりこれを PLL left に制約します。

例 8

INS\_LOC "bsram\_name" BSRAM\_R10[2];

// BSRAM の INS\_LOC 制約によりこれを 10 行目の 3 つ目の BSRAM に制約します。

例 9

INS\_LOC "dsp\_name" DSP\_R19[2];

// DSP の INS\_LOC 制約によりこれを 19 行目の 3 つ目の DSP Block に制約します。

1 つの LUT4 には LUT1、LUT2、LUT3、LUT4 を配置できます。LUT5 は 2 つの LUT4(1 CLS)、LUT6 は 4 つの LUT4(2 CLS)、LUT7 は 4 CLS(1 GRID)、LUT8 は 8 つの CLS(2 GRID)の位置を占有します。したがって、制約位置の最小ユニットは Instance のタイプによって異なります。BSRAM、SSRAM、DSP の場合も同じです(各 DSP ブロックには 2 つのマクロセルがあります)。例えば:

例 10

LUT4 制約:

INS LOC "lut4 name" R5C15[1][A];

// lut4 name を R5C15 の 2 つ目の CLS の最初の LUT に制約します。

例 11

CLS 制約:

INS LOC "lut5 name" R5C15[3];

// lut5 name を R5C15 の 4 つ目の CLS に制約します。

SUG935-1.4J 59(68)

付録 A 物理制約構文仕様 A.4 グループ制約

例 12

CLS 制約:

INS LOC "lut6 name" R5C15[0];

// lut6\_name を R5C15 の 1 つ目の CLS(CLS[0]と CLS[1]を占有する)に 制約します。

例 13

GRID 制約:

INS\_LOC "lut7\_name" R5C15;// lut7\_name を R5C15 に制約し、LUT7 は 1 つの GRID を占有します。

例 14

GRID 制約:

INS\_LOC "lut8\_name" R5C15;

// lut8\_name を R5C15 に制約します(lut8\_name は R5C15 と R5C16 の 2 つの GRID を占有します)。

例 15

DSP MACRO 制約:

INS LOC "mult name" DSP R19[1][A];

// mult name を 19 行目 2 番目の DSP の最初の macro に制約します。

# A.4 グループ制約

Group Constraints には、Primitive Group Constraints と Relative Group Constraints があります。

# A.4.1 プリミティブグループ制約

Primitive Group 制約は、グループ制約の定義に使用されます。グループは、さまざまな Instance オブジェクトのコレクションです。Primitive Group 制約により、LUT、DFF、BSRAM、SSRAM、DSP、PLL、DQS などの Instance、または Buffer、IOLOGIC などを 1 つのグルームに追加でき、このグループの位置を制約することでグループ内の全てのオブジェクトを位置制約できます。

#### 構文

GROUP の定義:

SUG935-1.4J 60(68)

付録 A 物理制約構文仕様 A.4 グループ制約

GROUP group\_name = { "obj\_names" } [exclusive];

Instance をグループに追加します:

GROUP group name += { "obj names" } [exclusive];

グループの位置を制約します:

GRP LOC group name group location[exclusive];

#### 注記:

group\_name が escaped name フォーマット(スラッシュで始まり、スペースで終わる)の場合、group\_name の前後に引用符が必要です。

## 制約要素

## group\_name

グループの名前。

## obj\_name

**obj\_name** は指定の **Instance** オブジェクトをグループに追加するために 使用されます。

## group\_location

この group の制約位置を指定し、group\_location を IOB、GRID、BSRAM、DSP、PLL の位置にできます。

#### exclusive

キーワード"exclusive"はオプションで、これはグループ定義ステートメントまたは位置制約ステートメントの後にあります。

1 つのオブジェクトを複数のグループに含めることができますが、グループ定義ステートメントの最後の "exclusive"キーワードは、グループ内のオブジェクトをこのグループにのみ含められることを表します。

位置制約ステートメントの後の"exclusive"は、この制約位置がこのグループ内のオブジェクトにより独占されることを表します。

#### 適用例

例 1

// group\_1 という名前のグループを作成し、オブジェクト ins\_1、ins\_2、ins\_3、ins\_4 をこのグループに追加します。

例 2

SUG935-1.4J 61(68)

付録 A 物理制約構文仕様 A.4 グループ制約

```
GROUP group_2 = { "ins_5" "ins_6" "ins_7" } exclusive;
 // group 2 という名前のグループを作成し、オブジェクト ins 5、ins 6、
ins 7 はこのグループにのみ含まれます。
 例 3
 GROUP group_1 += { "io_1" "io_2"};
 // io 1、io 2を group 1 に追加します。
 例 4
 GRP LOC group 1 R3C4, A14, B4;
 // group 1 内のオブジェクトを R3C4、A14、B4 に配置できます。
 例 5
 GRP_LOC group_2 R[2:3]C[2:4] exclusive;
 // group 2内の Instance オブジェクトを R[2:3]C[2:4]の範囲内に配置で
き、かつこの範囲は group 2内の Instance オブジェクト専用です。
 例 6
 GRP_LOC group_3 PLL_L, BSRAM_R10[0], DSP_R19[0];
 // group 3内のオブジェクトを、PLL L、BSRAM R10[0]、DSP R19[0]
に配置できます。
```

# A.4.2 相対位置グループ制約

Relative Group Constraints により、Instance オブジェクト(例えば LUT、 REG、MUX)に対して相対位置制約をすることができます。

#### 構文

obj name

```
Relative 制約のグループを定義します:
REL_GROUP group_name = { "obj_names" };
Instance を定義済みのグループに追加します:
REL_GROUP group_name += { "obj_names"};
グループ内の instance に対して相対位置制約を実行します:
INS_RLOC "obj_name" relative_location;
```

SUG935-1.4J 62(68)

制約オブジェクトの名前。

## relative location

行と列の相対位置情報。

## 適用例

```
REL_GROUP grp_1 = { "ins_1" "ins_2" "ins_3" "ins_4" };

INS_RLOC "ins_1" R0C0;

INS_RLOC "ins_2" R2C3;

INS_RLOC "ins_3" R3C5;
```

//  $grp_1$  という名前のグループ制約を定義し、 $ins_1$ 、 $ins_2$ 、 $ins_3$ 、 $ins_4$  を  $grp_1$  に追加します。 $ins_1$  を相対位置の原点 R0C0 とし、 $ins_2$  を  $ins_1$  に対して R2C3 に制約し、 $ins_3$  を  $ins_1$  に対して R3C5 に制約します。

# A.5 リソースリザーブ制約

Resource Reservation 制約により、指定の位置または範囲の配置を回避できます。

# 構文

LOC\_RESERVE location [ res\_obj ];

#### 適用例

例 1

LOC RESERVE R2C3[0][A] -LUT;

LOC\_RESERVE R2C3[0][A] -REG;

例 2

LOC RESERVE IOR3, IOR6, R2C3, R3C4;

例 3

LOC RESERVE R[2:5]C[3:6], R3C[8:9];

# 上記の例の制約の位置は配置の段階で予約されます。

# A.6 リファレンス電圧制約

チップは、BANK 全体で有効な外部リファレンス電圧入力をサポートします。Vref Constraints を使用して、外部リファレンス電圧の入力ピンの名前と位置を制約することができます。

SUG935-1.4J 63(68)

#### 注記:

- 外部リファレンス電圧の入力ピンの位置には、IOLOGIC リソースが必要です。
- Vref Constraints は、Port 属性制約と併用する必要があります。入力または入出力タイプのシングルエンド PORT の IO 規格が SSTL / HSTL の場合、Vref 属性を作成された Vref Constraints に設定できます。これは、PORT のリファレンス電圧として Vref Constraints 位置の外部入力リファレンス電圧が使用されることを意味します。

## 構文

USE\_VREF\_DRIVER vref\_name [location];

#### 制約要素

## vref name

ユーザーカスタマイズの VREF pin name。

#### location

チップ内の任意の I/O 位置(IOLOGIC リソースを含む)は、VREF pin 制約の location として使用できます。

# 適用例

例 1

USE\_VREF\_DRIVER vref\_pin;

IO PORT "port 1" IO TYPE = SSTL25 I VREF=vref pin;

IO PORT "port 2" IO TYPE = SSTL25 | VREF=vref pin;

// "vref\_pin"という名前の VREF pin を定義し、port\_1 と port\_2 の VREF 属性を vref pin に設定します。

例 2

USE VREF DRIVER vref pin E16;

IO LOC "port 1" C16;

IO\_PORT "port\_1" IO\_TYPE = SSTL25\_I VREF=vref\_pin;

//"vref\_pin"という名前の VREF pin を定義し、それを E16 に制約します。 port\_1 の VREF 属性を vref\_pin に設定して C16 に制約します。 port\_1 が 制約された位置は、E16 と同じ Bank 上にある必要があります。

# A.7 グローバルクロック・プリミティブ制約

GCLK Primitive Constraints は、DCS、DQCE などのグローバルクロックオブジェクトを指定された位置に制約するために使用されます。

SUG935-1.4J 64(68)

#### 構文

INS\_LOC "obj\_name" position;

## 制約要素

## obj\_name

制約オブジェクトの名前。

#### position

LittleBee®ファミリー: GW1N-9、GW1NR-9、GW1N-9C、GW1NR-9Cの場合は"TOPLEFT"、"TOPRIGHT"、"BOTTOMLEFT"、または"BOTTOMRIGHT"位置に制約でき、その他のデバイスの場合は、"LEFT"または"RIGHT"位置にのみ制約できます。

Arora ファミリー: "TOPLEFT"、"TOPRIGHT"、"BOTTOMLEFT"、または"BOTTOMRIGHT"位置に制約できます。

#### 適用例

INS LOC "dcs name" LEFT;

// DCS オブジェクト dcs name を LEFT 位置に制約します。

# A.8 グローバルクロック割り当て制約

Clock Net Constraints は、特定の net の、グローバルクロック配線または非クロック配線の制約です。この制約を使用して、特定の signal\_type(CLK、CE、SR、LOGIC)の net に対してグローバルクロックラインの配線制約を実行することができます。

- BUFG[0-7]は、net を PCLK 配線に制約することを示します。
- BUFS は、net を SCLK 配線に制約することを示します。
- LOCAL CLOCK は、net を非クロック配線に制約することを示します。

CLK 信号はクロックピンに接続される信号、CE 信号はクロックイネーブルピンに接続される信号、SR 信号は SET、RESET、CLEAR、および PRESET ピンに接続される信号、LOGIC はロジック入力ピンに接続される信号です。

## 構文

CLOCK LOC "net name" global clocks = signal type;

# 制約要素

#### net name

SUG935-1.4J 65(68)

net の名前。

## global clocks

BUFG[0-7]: 特定の PCLK 配線。

BUFG: PCLK 配線。

BUFS: SCLK 配線。

**LOCAL\_CLOCK**: 非クロック配線。

# signal\_type

CLK: signal type がクロックピンである net。

CE: signal\_type がクロックイネーブルピンである net。

SR: signal\_type が SET、RESET、CLEAR、PRESET である net。

LOGIC: signal type が上記 signal type でない net。

複数の signal type を指定する場合、"|"を使用して区切ることができます。

#### 注記:

global\_clocks として LOCAL\_CLOCK を選択した場合、signal\_type は選択不可になります。

#### 適用例

例 1

CLOCK LOC "net" BUFG[0] = CLK;

// signal\_type がクロックピンである net を 1 つ目の PCLK リソースに配線制約します。

例 2

CLOCK\_LOC "net" BUFG = CLK|CE;

NET LOC "net" BUFG = CLK|CE;

// signal\_type がクロックピンまたはクロックイネーブルピンである net をチップの PCLK リソースに配線制約します。

例 3

CLOCK LOC "net" BUFS = CE;

NET LOC "net" BUFS = CE;

// signal\_type がクロックイネーブルピンである net をチップの SCLK リソースに配線制約します。

SUG935-1.4J 66(68)

例 4

CLOCK LOC "net" LOCAL CLOCK;

//"net"を非クロック配線に制約します。

# A.9 高速クロック・プリミティブ制約

HCLK Primitive Constraints 制約により、CLKDIV、DLLDLY を指定の高速クロック位置に制約できます。CLKDIV、DLLDLY の制約位置は、通常のInstance オブジェクトの制約位置とは異なります。 "TOPSIDE"、"BOTTOMSIDE"、"LEFTSIDE"、および"RIGHTSIDE"は、制約位置の四辺を示します。

#### 構文

INS\_LOC "obj\_name" position;

### 制約要素

# obj\_name

obj name は、CLKDIV/DLLDLY の instance name です。

## position

"TOPSIDE[0-1]"

"BOTTOMSIDE[0-1]"

"LEFTSIDE[0-1]"

"RIGHTSIDE[0-1]"

# 適用例

INS LOC "clkdiv name" TOPSIDE[0];

// clkdiv name を TOPSIDE[0]位置に制約します。

# A.10 その他の制約

# A.10.1 JTAGSEL\_N net の制約

FPGA の内部ロジックで JTAGSEL\_N 機能を制御する場合、すなわち、JTAGSEL\_N を Low にプルダウンすることで JTAG ピンをコンフィギュレーション機能に切り替え、電源を落とさずに再度ダウンロードできるようにするには、JTAGSEL\_N の net の物理制約を追加する必要があります。 詳しくは、『Gowin FPGA 製品プログラミング・コンフィギュレーション ユ

SUG935-1.4J 67(68)

付録 A 物理制約構文仕様 A.10 その他の制約

ーザーガイド(UG290)』を参照してください。

## 構文

NET LOC "obj name" V JTAGSELN;

## 制約要素

## obj\_name

obj\_name として内部ロジックの1本の net を指定します。

# 適用例

NET LOC "netname" V JTAGSELN;

// この netname という net を使用して JTAGSEL\_N の機能を制御します

# A.10.2 RECONFIG N net の制約

FPGA の内部ロジックで RECONFIG\_N 機能を制御する場合、すなわち、 RECONFIG\_N を Low にプルダウンすることで FPGA をコンフィギュレーションのリセット状態に切り替え、電源を落とさずに再度ダウンロードできるようにするには、RECONFIG\_N の net の物理制約を追加する必要があります。詳しくは、『Gowin FPGA 製品プログラミング・コンフィギュレーション ユーザーガイド(UG290)』を参照してください。

#### 構文

NET\_LOC "obj\_name" V\_RECONFIGN;

## 制約要素

#### obj name

obj name として内部ロジックの1本の net を指定します。

#### 適用例

例

NET LOC "netname" V RECONFIGN;

// この netname という net を使用して RECONFIG\_N の機能を制御します

SUG935-1.4J 68(68)

