インテルのみ表示可能 — GUID: ewa1399503956920
Ixiasoft
1. インテル® FPGA SDK for OpenCL™ の概要
2. インテル® FPGA SDK for OpenCL™オフライン・コンパイラーのカーネル・コンパイル・フロー
3. ソフトウェア、コンパイラー、カスタム・プラットフォームに関する一般的な情報の取得
4. FPGAボードの管理
5. OpenCLカーネルの構築
6. ホスト・アプリケーションの設計
7. OpenCL カーネルのコンパイル
8. OpenCLカーネルのエミュレーションとデバッグ
9. カーネルのreport.htmlファイルのレビュー
10. OpenCLカーネルのプロファイリング
11. インテル® Code Builder for OpenCL™ を使用するOpenCL™アプリケーションの開発
12. インテル® FPGA SDK for OpenCL™ のアドバンスト機能
A. OpenCL機能のサポート状況
B. インテル® FPGA SDK for OpenCL™ プロ・エディション・プログラミング・ガイドの改訂履歴
3.1. ソフトウェア・バージョンの表示 (version)
3.2. コンパイラー・バージョンの表示 (-version)
3.3. インテル FPGA SDK for OpenCL ユーティリティー・コマンド・オプション・リストの表示 (help)
3.4. インテル FPGA SDK for OpenCL オフライン・コンパイラー・コマンド・オプション・リストの表示 (引数なし、-help、-h)
3.5. 利用可能なFPGAボードとカスタム・プラットフォームのリスト表示 (-list-boardsおよび-list-board-packages)
3.6. OpenCLバイナリーのコンパイル環境の表示 (env)
5.1. カーネルの命名ガイドライン
5.2. データの処理効率を最適化するためのプログラミング手法
5.3. ローカル・メモリー・サイズへのポインターの最適化に向けたプログラミング手法
5.4. インテル® FPGA SDK for OpenCL™ チャネル拡張の実装
5.5. OpenCLパイプの実装
5.6. 任意精度での整数の実装
5.7. 条件付きコンパイルにおける定義済みプリプロセッサー・マクロの使用
5.8. __constantアドレス空間修飾子の宣言
5.9. 構造体データ型をOpenCLカーネルに引数として含める
5.10. レジスターの推論
5.11. 倍精度浮動小数点演算の有効化
5.12. 単一ワークアイテム・カーネルに向けた単一サイクル浮動小数点アキュムレーター
5.13. 整数のプロモーション規則
6.6.2.1. ホスト・アプリケーションとKhronos ICD Loader Libraryのリンク
6.6.2.2. ホスト・アプリケーションをコンパイルするためのフラグの表示 (compile-config)
6.6.2.3. OpenCLホスト・ランタイム・ライブラリーおよびMMDライブラリーへのパスの表示 (ldflags)
6.6.2.4. OpenCLホスト・ランタイム・ライブラリーおよびMMDライブラリーのリスト表示 (ldlibs)
6.6.2.5. OpenCLホスト・ランタイム・ライブラリーおよびMMDライブラリーに関する情報の表示 (link-config または linkflags)
7.1. ハードウェアのコンフィグレーション・ファイルを作成するためのカーネルのコンパイル
7.2. ハードウェアを構築せずに行うカーネルのコンパイル (-c)
7.3. ハードウェアを構築せずに行うカーネルまたはオブジェクト・ファイルのコンパイルおよびリンク (-rtl)
7.4. ヘッダーファイル位置の指定 (-I=<directory>)
7.5. インテル® FPGA SDK for OpenCL™オフライン・コンパイラーの出力ファイル名の指定 (-o <filename>)
7.6. 特定のFPGAボードとカスタム・プラットフォームに対するカーネルのコンパイル (-board=<board_name>) および (-board-package=<board_package_path>)
7.7. カーネルコンパイル時のハードウェア生成フィッティング・エラーの解決 (-high-effort)
7.8. カーネルのFmaxターゲットのスケジュール指定 (-fmax=<fmax target in MHz>)
7.9. カーネル・パラメーターを指定するためのプリプロセッサー・マクロの定義 (-D<macro_name>)
7.10. コンパイル進捗レポートの生成 (-v)
7.11. リソース推定使用率要約の画面表示 (-report)
7.12. インテル® FPGA SDK for OpenCL™オフライン・コンパイラーの警告メッセージの抑制 (-W)
7.13. インテル® FPGA SDK for OpenCL™オフライン・コンパイラーの警告メッセージのエラーメッセージへの変換 (-Werror)
7.14. コンパイラー・レポートのデバッグデータの削除および.aocxファイルのソースコードの削除 (-g0)
7.15. グローバルメモリーのバーストインターリーブの無効化 (-no-interleaving=<global_memory_type>)
7.16. グローバルメモリーのリング型相互接続の強制 (-global-ring)
7.17. グローバルメモリーへの書き込みスループット向上に向けたストアリングの複製 (-duplicate-ring)
7.18. コンスタント・メモリー・キャッシュ・サイズのコンフィグレーション (-const-cache-bytes=<N>)
7.19. 浮動小数点演算処理順序の緩和 (-fp-relaxed)
7.20. 浮動小数点演算における丸め処理の削減 (-fpc)
7.21. OpenCLコンパイルの高速化 (-fast-compile)
7.22. カーネルのインクリメンタル・コンパイル (-incremental)
7.23. メモリーの誤り訂正符号をともなうカーネルのコンパイル (-ecc)
7.24. ハードウェアのカーネル呼び出しキューの無効化 (-no-hardware-kernel-invocation-queue)
7.25. ハンドシェイク・プロトコルの変更 (-hyper-optimized-handshaking)
8.1. 高速エミュレーターの設定
8.2. エミュレーションに向けたチャネル・カーネル・コードの変更
8.3. エミュレーションに向けたカーネルのコンパイル (-march=emulator -fast-emulator)
8.4. OpenCLカーネルのエミュレーション
8.5. LinuxにおけるOpenCLカーネルのデバッグ
8.6. インテル® FPGA SDK for OpenCL™ Emulatorの制限
8.7. ハードウェアとエミュレーターの結果の不一致
8.8. 高速エミュレーターの環境変数
8.9. 高速エミュレーターでサポートされている拡張機能
8.10. 高速エミュレーターの既知の問題
8.11. レガシー・エミュレーターの使用
12.1.1. RTLモジュールとOpenCLパイプラインの理解
12.1.2. OpenCLライブラリーに向けたOpenCLヘルパー関数ファイルのパッケージ化
12.1.3. OpenCLライブラリーに向けたRTLコンポーネントのパッケージ化
12.1.4. RTLモジュールの検証
12.1.5. 複数のオブジェクト・ファイルのライブラリー・ファイルへのパッケージ化
12.1.6. OpenCLカーネルコンパイル時のOpenCLライブラリーの指定
12.1.7. シミュレーションによるOpenCLライブラリーのデバッグ (プレビュー)
12.1.8. シンプルな関数で動作するOpenCLライブラリーの使用 (例1)
12.1.9. 外部メモリーと動作するOpenCLライブラリーの使用 (例2)
12.1.10. OpenCLライブラリーのコマンドライン・オプション
12.1.1.1. インテルFPGA SDK for OpenCLパイプラインのアプローチの概要
12.1.1.2. RTLモジュールのインテル FPGA SDK for OpenCLパイプラインへの統合
12.1.1.3. ストールのないRTL
12.1.1.4. RTLモジュール・インターフェイス
12.1.1.5. Avalon Streaming (Avalon-ST) インターフェイス
12.1.1.6. RTLリセットおよびクロック信号
12.1.1.7. RTLモジュールのXML構文
12.1.1.8. RTLモジュールと外部メモリーの通信
12.1.1.9. RTLモジュールに入るスレッドの順序
12.1.1.10. RTLモジュールのOpenCL Cモデル
12.1.1.11. RTLモジュールとパーシャル・リコンフィグレーションにおける潜在的な非互換性
インテルのみ表示可能 — GUID: ewa1399503956920
Ixiasoft
8. OpenCLカーネルのエミュレーションとデバッグ
インテル® FPGA SDK for OpenCL™ Emulatorは、カーネルの機能性を評価します。
インテル® FPGA SDK for OpenCL™ Emulatorは、x86-64 Windows または Linuxホストで実行する.aocxファイルを生成します。この機能により、カーネルの機能性をエミュレーションし、毎回実際のFPGAで実行することなくデザインを反復することが可能になります。Linuxのプラットフォームでは、エミュレーターを使用し機能のデバッグを実行することも可能です。
重要: エミュレーションは、ARM®プロセッサーへのクロスコンパイルをサポートしていません。ARM SoCデバイスをターゲットにするデザインのエミュレーションを実行する場合は、SoC以外のボードでエミュレーションしてください (例えばINTELFPGAOCLSDKROOT/board/s10_ref、INTELFPGAOCLSDKROOT/board/a10_refなど)。エミュレーション結果が満足のいく内容となれば、続く最適化の手順に向けてデザインをSoCボードへターゲットにすることが可能です。
エミュレーターは、64ビットのWindowsおよびLinuxのオペレーティング・システムをサポートしています。Linuxシステムでは、GNU C Library (glibc) version 2.15以降のバージョンが必要です。お使いのLinuxシステムがこの要件を満たさない場合、レガシー・エミュレーターを利用できる可能性があります。詳細は、レガシー・エミュレーターの使用 を確認ください。
- 高速エミュレーターの設定
インテル® FPGA SDK for OpenCL™ プロ・エディションを管理者権限でインストールしている場合、次の手順を実行する必要はありません。 インテル® FPGA SDK for OpenCL™ を管理者権限でインストールしていない場合は、高速エミュレーターを有効にするための作業を行う必要があります。 - エミュレーションに向けたチャネル・カーネル・コードの変更
I/Oチャネルの読み書きを行うチャネルを持つアプリケーションをエミュレーションするには、カーネルを変更し、I/Oチャネルに代わる読み取りまたは書き込みチャネルを追加します。また、そのチャネルを使用するソースコードを条件付きにします。 - エミュレーションに向けたカーネルのコンパイル (-march=emulator -fast-emulator)
エミュレーションに向けてOpenCL™カーネルをコンパイルするには、-march=emulatorおよび-fast-emulatorオプションをaocコマンドに含めます。 - OpenCLカーネルのエミュレーション
OpenCL™カーネルをエミュレーションするには、カーネルを構築したプラットフォームで.aocxエミュレーション・ファイルを実行します。OpenCL高速エミュレーターは、FPGAハードウェアをターゲットとする際とは異なるOpenCLプラットフォームを使用します。 - LinuxにおけるOpenCLカーネルのデバッグ
Linux システムでは、 インテル® FPGA SDK for OpenCL™ Emulatorに、デバッガーでOpenCLカーネルを実行し、ホスト・アプリケーションの一部として機能的にデバッグするよう指示することができます。 - インテル FPGA SDK for OpenCL Emulatorの制限
インテル® FPGA SDK for OpenCL™ Emulatorのフィーチャーには、いくつかの制限があります。 - ハードウェアとエミュレーターの結果の不一致
カーネルをエミュレーションすると、OpenCLシステムは、ハードウェアにコンパイルされたカーネルとは異なる結果を生成することがあります。シミュレーションでカーネルを実行することで、ハードウェアにカーネルをコンパイルする前にさらにカーネルをデバッグすることが可能です。 - 高速エミュレーターの環境変数
高速エミュレーターの動作を変更する環境変数をいくつか利用することが可能です。 - 高速エミュレーターでサポートされている拡張機能
高速エミュレーターは、さまざまなOpenCL拡張機能に対し、さまざまなレベルのサポートを提供しています。 - 高速エミュレーターの既知の問題
高速エミュレーターの使用は、いくつかの既知の問題に影響を受ける可能性があります。起こりうる問題を回避するため、高速エミュレーターを使用する際はこれらの問題を考慮ください。 - レガシー・エミュレーターの使用
インテル® FPGA SDK for OpenCL™ バージョン18.1および、それ以前のバージョンにおけるデフォルトのエミュレーターは現在も入手可能であり、利用することができます。 ただし、インテルFPGA OpenCLシステムのエミュレーションには、高速エミュレーターの利用を推奨しています。