Vitis™ プラットフォームの作成チュートリアル

xilinx.com の Vitis™ 開発環境を参照

カスタム IP を使用した Versal プラットフォームの作成

バージョン: Vitis 2021.2

Versal™ ACAP プラットフォームにカスタム IP を追加する方法を学習します。このチュートリアルは、基本の「Versal プラットフォーム作成チュートリアル」に対する「アドオン」です。そのため、各手順で必要に応じて、基本のチュートリアルの対応する部分へのリンクが表示されます。

このチュートリアルでは、VCK190ボードをターゲットとしています (https://japan.xilinx.com/products/boards-and-kits/vck190.html を参照)。

概要

チュートリアルの構成は次のとおりです。

手順 1: ハードウェア プラットフォームの作成

VCK190 ボード用にあらかじめ構築済みのデザイン例を使用して、ハードウェア プラットフォームを構築します。この方法を使用すると、IPインテグレーター ブロック デザインを手動で作成する必要がなく、時間を節約できます。

手順 0: Versal プラットフォーム作成チュートリアルの手順に従います。オプションの手順は省略できます。

手順 2: ブロックデザインへのカスタム IP の追加

この手順では、前の手順で作成したプラットフォーム デザインに DDS コンパイラ IP を追加します。DDS コンパイラ IP は、 Vivado® Design Suite のザイリンクス IP カタログに含まれています。この IP の詳細は、製品ガイド (PG141) を参照してください。これは一般公開 IP なので、シミュレーションがサポートされていますが、独自の IP コアを追加する場合は、シミュレーションをサポートするシミュレーション モデルを提供する必要があります。

  1. 前の手順で作成したシステム ブロック デザインを閉じてしまった場合は再度開きます。

  2. [Add IP] (+ アイコン) ボタンをクリックして、dds を検索します。DDS コンパイラ IP をダブルクリックしてキャンバスに追加します。

    missing image

  3. DDS IP を次のように設定します。一部の設定は必須ではなく、このデザイン例の目的にのみ使用されることに注意してください。必須要件は、この IP には AXI4 ストリーム インターフェイスが 1 つしかないため、位相出力ポートはオフにする必要があるという点のみです。

    a. [Configuration] タブの設定

    missing image

    b. [Implementation] タブの設定

    missing image

    c. [Detailed Implementation] タブの設定

    このページはデフォルト設定をそのまま使用します。

    d. [Output Frequency] タブの設定

    周波数の値は調整できますが、サンプル レートに注意してください。クロック レートは 300 MHz です。1 サイクル内でサンプルが少なすぎると、正弦波を正しくサンプリングできません。

    missing image

  4. コンフィギュレーション ページを終了して、aclk ポートを Clocking Wizard の clk_out3 信号に接続します。

  5. これでブロック デザインは次のようになるはずです。

missing image

  1. [Platform Setup] ウィンドウを開き、M_AXIS_DATA ポートをイネーブルにします。SP タグを AXIS に設定します。Vitis™ リンカーではこれが使用されて、アクセラレータに接続されます。

missing image

  1. ブロック デザインの出力ファイルを生成し直します。

  2. ハードウェア プラットフォームをエクスポートします。プラットフォーム タイプを選択するページで、[Hardware and hardware emulation] を選択して、このプラットフォームでエミュレーションを実行します。

手順 3: PetaLinux でのソフトウェア コンポーネントの作成

この手順では、Vitis 統合ソフトウェア プラットフォームの必須コンポーネントを含む PetaLinux プロジェクトを作成します。手順 2: Versal プラットフォーム作成チュートリアルの手順に従います。

手順 4: Vitis ソフトウェア プラットフォームでのプラットフォームのパッケージ

この手順では、Vitis IDE でハードウェア XSA をソフトウェア コンポーネントと共にパッケージします。手順 3: Versal プラットフォーム作成チュートリアルの手順に従います。

手順 5: プラットフォームのテスト

この手順では、簡単な vadd アプリケーションを構築し、ハードウェア エミュレーションを実行してプラットフォームをテストします。手順 4: Versalプラットフォーム作成チュートリアルの指示に従いますが、いくつか変更を加えます。

そのページでテスト 2 を実行するだけです。vadd システム プロジェクトを作成したら、次のように変更をします。

  1. vadd_kernels プロジェクトの src フォルダーの下にある krnl_vadd.cpp ファイルを開きます。このファイルの先頭に次のヘッダー ファイルを追加します。これらは、AXIS データ型および HLS ストリーム データ型をサポートするために使用されます。

#include "ap_int.h" #include "ap_axi_sdata.h" #include "hls_stream.h" 
  1. カーネル関数定義の前に pkt という名前の型を定義します。

typedef ap_axis<15, 0, 0, 0> pkt; 
  1. 最上位関数に 2 つのポートを追加します。dds_in ポートは AXI4-Stream 型で、wave_out ポートは AXI-MM 型です。

void krnl_vadd(uint32_t* in1, uint32_t* in2, uint32_t* out, int size, int *wave_out, hls::stream<pkt> &dds_in) { 
  1. このデザインでは、DDS IP からのデータは処理されず、DDR 出力へ渡されるだけです。これには、関数本体に次のように数行を追加します。

for (int i = 0; i < 1024; i++) { #pragma HLS PIPELINE II = 1 pkt value = dds_in.read(); wave_out[i] = value.data; } 

これでカーネル コードの変更が完了しました。作業を保存してファイルを閉じます。

注記: vadd カーネルを完全な修正コードについては、カーネル コードの修正を参照してください。

  1. Vitis リンカーでカーネルの AXI ストリーム ポートとプラットフォームの対応インターフェイスを正しくリンクするようにするには、system.cfg というコンフィギュレーション ファイルを作成し、次の行を追加します。

[connectivity] stream_connect = AXIS:krnl_vadd_1.dds_in 

このコマンドは、2 つの AXI4-Stream ポート間の接続を示します。コロンの前はマスター インターフェイスの名前で、コロンの後はスレーブ インターフェイスの名前である必要があります。このデザインの場合、パラメーターからの AXIS sptag はAXI マスター側を表しているため、先に配置します。ここでは、プラットフォームの作成時に定義された sptag を指定するだけで、Vitis リンカーが自動的に検出します。

system_cfg ファイルは vadd_system_hw_link プロジェクトの下に置きます。ほかのディレクトリを選択することもできますが、バイナリ コンテナー設定でそのディレクトリを正しく指定するようにしてください。

バイナリ コンテナー設定で config ファイルを指定します。

missing image

  1. 次に、ホスト コードを変更して、DDR からデータを読み取ります。vadd プロジェクトの src フォルダーの下にある vadd.cpp ファイルを開き、次のように変更します。

    a. ヘッダー ファイルを追加します。

    #include "ap_int.h" #include <stdio.h> 

    b. DDS 出力データ用に新しい cl_mem buffer を作成します。

    cl::Buffer buffer_waveout(context, CL_MEM_WRITE_ONLY, 1024*sizeof(int)); 

    c. バッファーをカーネルにボンディングします。

    krnl_vector_add.setArg(narg++,buffer_waveout); 

    d. ホスト バッファーをデバイス バッファーにマップします。

    int *ptr_waveout = (int *) q.enqueueMapBuffer (buffer_waveout , CL_TRUE , CL_MAP_READ , 0, 1024*sizeof(int)); 

    e. DDR からデータを読み出します。

    q.enqueueMigrateMemObjects({buffer_waveout},CL_MIGRATE_MEM_OBJECT_HOST); 

    f. データがファイルに保存されます。DDS コンパイラの IP 出力は 16 ビットの符号付きデータで、ホスト バッファーの 32 ビット整数データであるため、データは 17 ビット左にシフトされます。これは、追加の符号付きビットを削除し、実際のペイロード データを保持するためです。

     FILE *fp_dout; fp_dout=fopen("wave_out.txt","w"); for (int i = 0; i < 1024; i++) { fprintf(fp_dout,"%d\n",ptr_waveout[i]<<17); } fclose(fp_dout); 

    g. バッファーのマップを解除します。

    q.enqueueUnmapMemObject(buffer_waveout , ptr_waveout); 

    注記: vadd ホスト アプリケーションの完全な修正コードについては、ホスト コードの修正を参照してください。

  2. 変更した vadd アプリケーションでエミュレーションを実行します。手順 4 - エミュレーション: Versal プラットフォーム作成チュートリアルの手順に従います。

  3. コンソール ウィンドウに「Test Passed」と表示されたら、生成された wave_out.txt ファイルを QEMU ターゲットからコピーします。XSCT コンソール ウィンドウをまだ起動していない場合は、まず Xilinx メニューから起動します。

次のコマンドを使用して tcf ターゲットに接続します。

connect -host 127.0.0.1 -port 1440 

次のコマンドを使用して、tcf ターゲットからホスト マシンに wave_out.txt ファイルをコピーします。

tfile copy -to-host /mnt/sd-mmcblk0p1/wave_out.txt $(YOUR_DIR)/wave_out.txt

wave_out.txt ファイルが $(YOUR_DIR) にコピーされます。データをプロットするツールを選択します。選択可能なオプションには MATLAB® があります。MATLAB がインストールされていない場合は、Excel などのその他のサードパーティ ツールでも同様の機能が提供されます。ツールを選択して、正弦波を出力します。

missing image

サポート

GitHub 問題は、リクエストやバグの追跡に使用します。質問については、forums.xilinx.com を参照してください。

ライセンス

Apache ライセンス、バージョン 2.0 (以下「ライセンス」) に基づいてライセンス付与されています。本ライセンスに準拠しないと、このファイルを使用することはできません。

ライセンスのコピーは、http://www.apache.org/licenses/LICENSE-2.0 から入手できます。

適切な法律で要求されるか、書面で同意された場合を除き、本ライセンスに基づいて配布されるソフトウェアは、明示的または黙示的を問わず、いかなる種類の保証または条件もなく、「現状のまま」配布されます。ライセンスに基づく権限と制限を管理する特定の言語については、ライセンスを参照してください。

XD019 | © Copyright 2021 Xilinx, Inc.