

# はじめての インテル® SoC FPGA 演習マニュアル (Atlas-SoC / DE10-Nano ボード版)

Ver.18.1



## はじめての インテル® SoC FPGA 演習マニュアル (Atlas-SoC / DE10-Nano ボード版)

## <u>目次</u>

| 目次   | 7                                                        | 2  |
|------|----------------------------------------------------------|----|
| 本書   | <mark>をお読みになる前に</mark>                                   | 4  |
| 1. 概 | [要                                                       | 5  |
| 1-3  | 1. 使用環境                                                  | 6  |
| 2. ボ | 三一ドの設定                                                   | 7  |
| 2-2  | 1. ボードレイアウト                                              | 7  |
| 2-2  | 2. 電源およびケーブルの接続                                          | 7  |
| 2-3  | 3. SW10 の設定                                              | 7  |
| 3. 演 | 習 1: ハードウェア演習                                            | 8  |
| 3-2  | 1. ステップ 1 : ハードウェア演習デザイン・プロジェクトのオープン                     | 9  |
| 3-2  | 2. ステップ 2 : HPS コンポーネントの追加                               | 15 |
| 3-3  | 3. ステップ 3 : HPS ペリフェラルの設定(MAC、UART、I2C、SDIO、USB)         | 21 |
| 3-4  | 4. ステップ 4 : HPS クロックの設定                                  | 26 |
| 3-5  | 5. ステップ 5 : SDRAM の設定                                    | 28 |
| 3-6  | 6. ステップ 6 : HPS のクロックとエクスポート信号の設定                        | 34 |
| 3-7  | 7. ステップ 7 : HPS コンポーネントと他のコンポーネントの接続                     | 36 |
| 3-8  | 8. ステップ 8 : リセットの接続とベースアドレスの割り当て                         | 38 |
| 3-9  | 9. ステップ 9 ː Platform Designer システムの確認                    | 39 |
| 3-2  | 10. ステップ 10 : Platform Designer システムの生成                  | 41 |
| 3-2  | 11. ステップ 11 : ピン・アサインメントの設定と Quartus® Prime プロジェクトのコンパイル | 45 |
| 3-2  | 12. ステップ 12 : 出力ファイルの確認                                  | 49 |
| 4. 演 | 『習 2: ソフトウェア演習(1) Preloader の生成                          | 50 |
| 4-1  | 1. ステップ 1 : Embedded Command Shell の起動                   | 51 |
| 4-2  | 2. ステップ 2 : bsp-editor(Preloader Generator)の起動           | 52 |
| 4-3  | 3. ステップ 3 : プロジェクトの作成と設定                                 | 52 |
| 4-4  | 4. ステップ 4 : Preloader のビルド                               | 56 |
| 5. 演 | 習 3: ソフトウェア演習(2) ベアメタル・アプリケーション                          | 57 |
| 5-1  | 1. FPGA デザインのダウンロード                                      | 58 |



## はじめての インテル® SoC FPGA 演習マニュアル (Atlas-SoC / DE10-Nano ボード版)

| 5-2. Hello World サンプル・アプリケーションの実行               | 61  |
|-------------------------------------------------|-----|
| 5-3. LED Blink サンプル・アプリケーションの実行                 | 70  |
| 5-4. 演習 2 で作成した Preloader による初期化 (オプション演習)      | 77  |
| 5-5. システム・ヘッダーファイルによるアドレスの解決 (オプション演習)          | 79  |
| 6. 演習 4: Linux アプリケーション演習 (オプション演習)             | 82  |
| 6-1. microSD カードの準備                             | 82  |
| 6-2. Linux 起動とログイン                              | 84  |
| 6-3. Linux での IP アドレスとパスワードの設定                  | 86  |
| 6-4. ホスト PC 側のネットワーク設定                          | 87  |
| 6-5. DS-5™ の起動と Linux サンプル・アプリケーションのインポートおよびビルド | 90  |
| 6-6. リモート・システム・エクスプローラー(RSE)の設定                 | 95  |
| 6-7. Linux アプリケーションの実行・デバッグ                     | 99  |
| 7. 今後の参考資料について                                  | 105 |
| 改版履歴                                            | 106 |



## 本書をお読みになる前に

この資料の内容は 2020 年 6 月現在のものです。

この資料で紹介しているソフトウェアやハードウェア、操作手順などは、指定バージョンやデバイス等以外でも 共通のものもありますが、一部については共通にならないものもありますので、ご注意ください。

## 文書中の記号

| i Note | 補足情報などを記載しています。                         |
|--------|-----------------------------------------|
| Point  | 重要なポイントを記載しています。                        |
| ■ 参考   | 理解を深めるため、参考となる資料やサイトを紹介しています。           |
| ▲ 注記   | この資料の中では具体的には触れませんが、必要となる知識や情報を記載しています。 |
| ○ 禁止   | 注意点や、してはいけないことを記載しています。                 |

## 文中の表記

| 下線      | クリックする事で、資料中の別の章や、外部のサイトにジャンプします。         |
|---------|-------------------------------------------|
| 太字斜体    | 画面の操作をする際の、メニューやウィンドウなどに表示されている文字を示しています。 |
| XXXXXXX | 入力するコマンド文字列を示しています。                       |
| 網掛け     | 使用するツールを示しています。                           |



## 1. 概要

この演習では、Cyclone® V SoC FPGA 評価キット「DEO-Nano-SoC Kit / Atlas-SoC Kit」(以下、Atlas-SoC ボード)、または「DE10-Nano Kit」(以下、DE10-Nano ボード)を使用して、Cyclone® V SoC のハードウェア、ソフトウェア それぞれの開発方法について解説します。

この演習を実行することにより、インテル® SoC FPGA の開発環境である インテル® Quartus® Prime 開発ソフトウェアやシステム構成ツールである Platform Designer (旧: Qsys システム統合ツール)、およびソフトウェア開発環境である インテル® SoC FPGA エンベデッド開発スイート (以下、SoC EDS) の基本的な操作を学ぶことができます。

演習は、以下の 4 つで構成されています。

● 演習 1: ハードウェア演習

● 演習 2: ソフトウェア演習(1)

● 演習 3: ソフトウェア演習(2)

● 演習 4: Linux アプリケーション演習 (オプション演習)

演習 1 では、Quartus® Prime を使用して Arm® プロセッサーを含むハードウェアを構成し、簡易的な SoC システムを設計します。

演習 2 では、SoC EDS ツールを使用して 28nm 世代のブートローダーである Preloader の生成を行います。

演習 3 では、Arm® Development Studio 5 Intel® SoC FPGA Edition(以下、DS-5™)を利用したソフトウェア開発 およびベアメタル・アプリケーションのデバッグを実施します。

演習 4 では、SD カードイメージを使用し、SoC デバイス上で Linux を動作させ、その上でアプリケーションを DS-5™ を使用して実行・デバッグします。

#### Note:

演習 4 は、弊社開催の「SoC スタートアップ・トライアル・セミナー」では、時間の都合上実施しないオプション演習となります。



#### 1-1. 使用環境

この演習では、以下のソフトウェアを使用します。

● インテル® Quartus® Prime Standard Edition v18.1 (Lite Edition でも可能)

また Device データとして Cyclone® V を登録しておく必要があります。 ダウンロードとインストール方法については以下のサイトをご参照ください。

<u>インテル® Quartus® Prime 開発ソフトウェアおよび ModelSim® - Intel® FPGA Edition のダウンロード方法</u> インテル® Quartus® Prime 開発ソフトウェアおよび ModelSim® - Intel® FPGA Edition のインストール方法

- インテル® SoC FPGA エンベデッド開発スイート Standard Edition v18.1 (以下、SoC EDS)
  インストール方法に関しては以下のサイトをご参照下さい。
  インテル® SoC FPGA エンベデッド・デベロップメント・スイート(SoC EDS)のインストール方法
- 演習データ( SoC-Trial\_Seminer\_Lab\_data\_atlas\_de10nano\_v18.1\_r1.exe )

演習データの .exe ファイルをダブルクリックすると、デフォルトでは次の場所に展開されます:

C:\lab\langlesoc\_lab\langlesoc\_lab

本資料では演習データを上記の場所に展開したものとして説明しています。

● ホスト PC の OS: Windows® 10 Enterprise

この演習では、Windows® 10 Enterprise を使用して動作の確認を行っております。

#### ↑ 注記:

<u>ホスト PC の OS が Windows® 10 の場合、Preloader の生成でエラーが発生する場合が確認されております。</u>

### 【エラー内容】

この問題は、SOC EDS ツールを使用してプリローダーを生成するときに発生します。 新しい HPS および BSP 設定ファイルを作成した後、make コマンドが失敗します。

 $tar\ zxf\ /cygdrive/c/intelFPGA/18.1/embedded/host\_tools/altera/preloader/uboot-socfpga.tar.gz$ 

tar: Error opening archive: Failed to open '/cygdrive/c/intelFPGA/18.1/embedded/host\_tools/altera/preloader/uboot-socfpga.tar.gz'
make: \*\*\* [uboot-socfpga/.untar] Error 1

もしご使用の OS が Windows® 10 でエラーが発生する場合は、以下の参考情報サイトで説明されている対策が必要となりますのでご注意ください。

## 【参考情報サイト】

■ 参考: アルティマ技術サポート「Windows® 10 における Preloader のビルドエラー」



## 2. ボードの設定

このセクションでは、演習 1、2、3 を実施するために必要なボードのセットアップに関して解説します。

#### 2-1. ボードレイアウト

本演習で使用する Atlas-SoC ボードのレイアウト図を以下に示します。

DE10-Nano ボードも基本的には同じです。



図 2-1. Atlas-SoC ボードレイアウト図

#### 2-2. 電源およびケーブルの接続

AC アダプターの接続や各種ケーブルは以下の通り接続してください。

- 電源(AC アダプター)を DC 入力(J14) に接続します。
- Mini USB ケーブルで作業用 PC とオンボード USB-Blaster™ II コネクター(J13)を接続します。

#### 2-3. SW10 の設定

SW10(MSEL 設定スイッチ)が以下の通り設定されていることを確認します。 この設定により、FPGA は FPPx32 モードとなります。

表 2-1. SW10 の設定

| ボード・リファレンス | 信 <del>号</del> 名 | 設定        |
|------------|------------------|-----------|
| SW10. 1    | MSEL0            | ON ("0")  |
| SW10. 2    | MSEL1            | OFF ("1") |
| SW10. 3    | MSEL2            | ON ("0")  |
| SW10. 4    | MSEL3            | OFF ("1") |
| SW10. 5    | MSEL4            | ON ("0")  |
| SW10. 6    | N/A              | N/A       |



図 2-2. ジャンパーの設定



## 3. 演習 1: ハードウェア演習

このセクションでは、Quartus® Prime および Platform Designer を使用し、以下に示す Arm® プロセッサーを含むハードウェアの設計を行います。

インテル® SoC FPGA では Cyclone® V に限らず、Quartus® Prime に含まれている Platform Designer というツールを使用してシステムを構成します。この Platform Designer では Hard Processor System(以下、HPS)のブロックをはじめ、FPGA 側に実装することのできるコンポーネント群が用意されており、所望のコンポーネントのみを実装することでリソースの最適化を図ることができます。また作成したシステムはペリフェラルが対応していれば、簡単に他のデバイスに移植できますので、それ自体も設計資産として活用していただくことが可能です。

本演習では演習時間を短縮するため、あらかじめ Platform Designer システム内にいくつかのコンポーネントとクロックソース・コンポーネントが実装してあります。このため、HPS ブロック (太枠で囲われた青色のブロック) の追加と既存コンポーネントの接続を実施します。演習内容は以下の通りです。

## 演習内容:

- HPS コンポーネントを既存の Platform Designer システムへ追加
- HPS インターフェイスと他のパラメーターの設定
- 既存コンポーネントと HPS との接続
- Platform Designer システムの生成



図 3-1. 演習 1 で設計する SoC システムのブロック図



## 3-1. ステップ 1: ハードウェア演習デザイン・プロジェクトのオープン

演習を進めるにあたり、本演習マニュアルの各ステップに記載されている全ての説明をよく読み慎重に作業を 進めてください。

本資料では作業ディレクトリーを C:¥lab¥soc\_lab フォルダーとして説明をします。作業フォルダーを変更された場合は設定した環境に合わせて読み直してください。

では、はじめましょう。

\_\_\_\_1. インストールされている Quartus® Prime 18.1 Standard Edition (Lite Edition でも可能) 開発ソフトウェア内の、Quartus® Prime を起動します。デフォルトのままであれば下記にあります。

Windows  $\mathcal{A}\mathcal{S}$ — $\mathcal{F}$   $\Rightarrow$  Intel FPGA 18.1.0.625 Standard Edition / Lite Edition  $\Rightarrow$  Quartus (Quartus Prime 18.1)



図 3-2. Quartus® Prime の起動



\_\_\_\_2. **Quartus® Prime** メニューバーから、*File* ⇒ *Open Project* を選択し、C:¥lab¥soc\_lab¥cv\_soc\_lab にある soc\_system.qpf を選択します。この qpf ファイルは Quartus® Prime でのプロジェクト・ファイルとなっています。



図 3-3. Quartus® Prime プロジェクトのオープン

- \_\_\_\_3. ボードの選択を行います。図を参考に、使用するボードを設定してください。
  - DEO-Nano-SoC / Atlas-SoC ボードの場合 : atlas を選択
  - DE10-Nano ボードの場合: DE10-Nano を選択

この設定を行うことにより、今回使用するボードに合わせ、あらかじめ設定済みのピンの配置や使用するデバイスなどの情報を使用することができるようになります。



図 3-4. 使用ボードの選択



\_\_\_\_4. Quartus® Prime の *Tools* ⇒ *Platform Designer* を起動します。または、ツールバーにある Platform Designer のアイコン 🙏 をクリックし、Platform Designer を起動します。



図 3-5. Platform Designer の起動

\_\_\_\_5. soc\_system.qsys ファイルを開きます。



図 3-6. Platform Designer ファイルのオープン



まずは簡単に Platform Designer の使い方について説明します。

Platform Designer では主に IP Catalog と System Contents、そして Message Window の 3 つの画面があります。

IP Catalog には Platform Designer で使用できるコンポーネントがラインナップされています。この中から実装したいコンポーネントを System Contents に追加します。そして System Contents 内のコンポーネント同士を接続し、システムを作成します。

HPS と呼ばれるチップ内のハードマクロ化された部分に関してもソフト・コンポーネントとして IP Catalog 上に ラインナップされており、このコンポーネントを Platform Designer システムに実装することで SoC デバイスの HPS 側が使用できるようになります。



図 3-7. Platform Designer 画面



オープンした Platform Designer システムは以下のコンポーネント(白色)が実装済みとなっています。このシステムに対して HPS ブロック(青色)の追加と設定、そして実装済みコンポーネントの接続を行います。

## 実装済みのコンポーネント(白色):

- クロックソース
- オンチップ・メモリー
- LED / Button 制御用 PIO ペリフェラル
  - DIP スイッチ PIO
  - ▶ ボタン PIO
  - ➤ LED PIO

## 演習で追加するコンポーネント (青色):

HPS



図 3-8. 設計する Platform Designer システム

Platform Designer では各 IP ごとに設定画面が用意されており、System Contents 内のコンポーネントをダブルクリックすると、そのコンポーネントの設定画面を開くことができます。



- \_\_\_\_6. Clock Source コンポーネント(clk\_0)をダブルクリックして、*Clock Frequency* は開発ボード上の発振器と一致させるため、50 MHz に設定されていることを確認してください。
- \_\_\_\_7. Clock frequency is known がチェックされていることを確認してください。



図 3-9. Clock Source の確認

\_8. Parameters **タブ**の [閉じる] (× マーク) をクリックし、Parameters タブを閉じます。

Platform Designer の各コンポーネントの設定は *Parameters* タブを閉じても Platform Designer を閉じない限り 保持されます。



## 3-2. ステップ 2 : HPS コンポーネントの追加

HPS は、Dual-core Arm® Cortex™-A9 MPCore™ プロセッサーと様々なペリフェラルから構成されています。また、以下に示す通り、インテル® SoC FPGA には、大きく分けて HPS 部と FPGA 部の 2 つのブロックから構成されます。

このステップでは、Platform Designer システムに HPS ブロックの追加と設定を行います。この Platform Designer システム上の HPS ブロックにおいて、HPS 部の設定を行うことができます。

HPS を設定するために使用する GUI には複数のタブ (FPGA interfaces、Peripheral Pins、HPS Clocks、SDRAM) が用意されており、それぞれについて設定を行います。



図 3-10. Platform Designer システムに追加する HPS ブロック

次ページより、Platform Designer システムに HPS ブロックを追加および各種設定を行います。



1. IP Catalog タブの下の 検索ボックスに、processor と入力します。



図 3-11. IP Catalog の検索ボックス

\_2. Arria V/Cyclone V Hard Processor System をダブルクリックします。

このコンポーネントが HPS コンポーネントを設定するブロックです。これから設定する HPS コンポーネントのダイアログボックスが表示されます。このウィンドウは初回のみ別ウィンドウとして起動します。 [Finish] ボタンをクリック後、2 回目以降に再表示させる場合には、System Contents タブから HPS コンポーネントをダブルクリックしてください。

FPGA Interfaces タブではデバイス内部で接続される HPS と FPGA 間の信号の使用有無を設定することができます。設定次第で HPS 側のステータスを FPGA に通知したり、FPGA 側から HPS 側を制御したりすることがで

きます。



図 3-12. HPS のペリフェラルと FPGA との内部バス



\_\_\_\_3. FPGA Interfaces タブをクリックして、デフォルトで有効になっている Enable MPU standby and event signals のチェックを外して無効にします。



図 3-13. FPGA Interface タブの設定

## i Note:

これは、マイクロ・プロセッサーがスタンバイモードであるか、CPU がウェイクアップ可能かを示す内部信号です。恒久的に有効にするためこの入力信号を論理 High に接続する、もしくはプロセッサーのイベントとして接続することもできます。

\_ 4. Enable HLGPI Interface のチェックが外れて無効(デフォルト)になっていることを確認します。

### i Note:

これは、SDRAM インターフェイスで未使用のピン(14bit)を入力専用の汎用ピンとして使用する際のオプションです。この演習では、この信号は必要ありません。



次に HPS と FPGA 間のブリッジの設定を行います。

HPS と FPGA 間にはそれぞれがマスター、スレーブになるポートがあります。ポート数としては HPS から FPGA へ 2 系統、FPGA から HPS へ 1 系統です。 HPS から FPGA への 2 系統ポートはそれぞれ HPS-to-FPGA interface、Lightweight HPS-to-FPGA interface です。 FPGA から HPS への1系統のポートは FPGA-to-HPS です。 すべてのポートについて、アクセスするパスに応じたバス幅の設定やポートの使用有無を設定することができます。

Arm® プロセッサー や HPS 側の Master からアクセスする場合は、

「ブリッジのアドレス + FPGA 側のコンポーネントのオフセットアドレス」のアドレスを指定することでアクセスすることができます。ブリッジのアドレスは下記の図のように

HPS-to-FPGA interface が 0xC000\_0000

Lightweight HPS-to-FPGA interface が 0xFF20 0000

と決まっています。



図 3-14. HPS と FPGA の内部バスと Arm から見たアドレスマップ

## ■ 参考:

HPS - FPGA 間のインターフェイスに関しては、マクニカ・ホームページ技術情報にも資料がございますので、 併せてご参照ください。

SoC はじめてガイド - HPS-FPGA 間のアクセス方法

次ページより設定を行います。



\_\_\_\_5. AXI Bridges セクションにて、FPGA-to-HPS interface width を Unused、HPS-to-FPGA interface width を 64-bit、 Lightweight HPS-to-FPGA interface width を 32-bit に設定してください。



図 3-15. AXI Bridges の設定

### i Note:

FPGA-to-HPS interfaces を有効にすると、FPGA 内のマスターが HPS のペリフェラルにアクセスすることができます。この演習では使用しません。

HPS-to-FPGA interface を有効にすると、HPS がマスターとなり FPGA のペリフェラルにアクセスすることができます。HPS-to-FPGA interfaces は、32 / 64 / 128 bit 幅を選択できますが、この演習では中間の 64bit 幅を使用します。

- \_\_\_\_6. FPGA interface ページを下にスクロールすると、FPGA-to-HPS SDRAM interface、Resets および DMA Peripheral Request セクションなどさらに多くのオプションがあります。
- \_\_\_\_7. FPGA to HPS SDRAM Interface が表示されるまで FPGA interface ウィンドウをスクロールします。
- \_\_\_\_8. *f2h\_sdram0* インターフェイスをクリックし、 ボタンをクリックして、インターフェイスを**削除**します。

こちらは FPGA から HPS 側の SDRAM ヘダイレクトにアクセスできる広帯域ポートです。インターコネクトと ACP(アクセラレーター・コヒーレンシー・ポート)を介さないので高速にアクセスできます。その反面、データの コヒーレンシーはユーザーがとる必要があります。

今回は使用しませんのでポートを削除します。



図 3-16. FPGA-to-HPS SDRAM インターフェイスの設定



- 9. Resets セクションまでスクロールダウンします。
- 10. Resets セクションでは、HPS リセットのためのすべてのオプションが無効になっていることを確認します。
- \_\_\_\_11. DMA Peripheral Request セクションでは、Enabled **列**の下のすべての行が No と表示されていることを確認しま す。

## i Note:

DMA peripheral request を有効にすると、HPS 側の DMA コントローラーの Peripheral Request 信号を FPGA ファブリック側へ接続可能になります。

Peripheral Request 信号を利用した DMA 転送を行う場合を除き、通常は No をセットします。

\_\_\_\_12. *Interrupts* セクションの、*Enable FPGA-to-HPS interrupts* オプションが**無効**になっていることを確認します。 今回は FPGA に実装したコンポーネントから Arm® プロセッサーに対して割り込みは使用しません。

Resets / DMA / Interrupts の設定は以下の通りです (デフォルトから変更はありません):



図 3-17. Resets/DMA/Interrupts の設定



#### 3-3. ステップ 3 : HPS ペリフェラルの設定(MAC、UART、I2C、SDIO、USB)

Peripheral Pins タブは HPS 内部にハードコーデットされている HPS ペリフェラルを有効にするタブです。

HPS のピンの多くは最大 4 つのペリフェラルで共有されています。しかしながら使用できるのは 1 つのペリフェラルのみです。そのため、有効にするペリフェラル同士でピンが競合しないように、ピンの割り当てを指定する必要があります。ピンの割り当ては最大 3 通りのパラメーター (HPS I/O Set 0~3) から選択することができます。



図 3-18. HPS I/O のピン・マルチプレクサー



| 1.  | Peripheral Pins タブを選択します。                                                          |
|-----|------------------------------------------------------------------------------------|
| 2.  | Ethernet Media Access Controller の EMAC1 pin を HPS I/O Set 0 に設定します。               |
| 3.  | Ethernet Media Access Controller の EMAC1 mode を RGMII に設定します。                      |
| 4.  | SD/MMC Controller の SDIO pin を HPS I/O Set 0 に設定します。                               |
| 5.  | SD/MMC Controller の SDIO mode を 4-bit Data に設定します。                                 |
| 6.  | USB Controllers の USB1 pin を HPS I/O Set 0 に設定します。                                 |
|     | USB Controllers の USB1 PHY interface mode を SDR with PHY clock output mode に設定します。 |
| 8.  | SPI Controllers の SPIM1 pin を HPS I/O Set 0 に設定します。                                |
|     | SPI Controllers の SPIM1 mode を Single Slave Select に設定します。                         |
| 10  | UART Controllers の UARTO pin を HPS I/O Set 0 に設定します。                               |
|     | UART Controllers の UARTO mode を No Flow Control に設定します。                            |
|     |                                                                                    |
|     | I2C Controllers の I2C0 pin を HPS I/O Set 0 に設定します。                                 |
| 13. | I2C Controllers の I2C0 mode を I2C に設定します。                                          |
| 14. | I2C Controllers の I2C1 pin を HPS I/O Set 0 に設定します。                                 |
| 15. | I2C Controllers の I2C1 mode を I2C に設定します。                                          |
|     |                                                                                    |

設定後のパラメーターは次ページを参照してください。







図 3-19. HPS ペリフェラルの設定



Peripherals Mux Table セクションでは設定したピンの配置を確認することができます。

1 つのピンには 1 つの役割しか与えることはできません。そのため、HPS の複数ペリフェラルが同じピンを使用したり、同じピンに HPS ペリフェラルと GPIO の役割を与えたりすることはできません。そのため、この Peripherals Mux Table セクションで、各ピンの用途を確認してください。

左側の列はピン名を示しており、そのピンが使用されている場合は太字になります。ペリフェラルのピンとして使用していないピンは HPS の GPIO ピンとして使用可能です。その場合はピンごとの各 GPIO のボタンを押すことで有効になります。

ピンに対して競合が起きている場合は Message Window に Error が表示され、またそのピンの欄が赤くハイライトされますので、どのピンが競合を起こしているのかをリアルタイムに知ることができます。

では実際に使用していないピンを GPIO ピンに設定してみましょう。

16. Peripherals Mux Table セクションで GPIO09 をクリックすることにより、GPIO09 を有効にします。

## P Point:

反応に時間がかかる場合がありますので、何度も押さないように注意してください。



図 3-20. HPS GPIO09 の設定

#### Point:

もしクリックできなかった場合は、HPS component ダイアログボックスの右下にある [*Finish*] を選択、または Parameters タブの "x" をクリックして HPS component ダイアログボックスを一旦閉じた後、再度 hps\_0 コンポーネントをダブルクリックしてパラメーター・ウィンドウを開き作業を続けてください。



図 3-21. GPIO 設定時にクリックできなかった場合の対応方法



17. 同様に GPIO35、GPIO40、GPIO53、GPIO54、GPIO61 を有効にします。



図 3-22. HPS GPIO の設定

\_\_18. 設定後、下図のように2つのエラー以外に、エラーが出ていないことを確認してください(この2つのエラーは後で解決します)。



図 3-23. ピン競合エラーが無いときの表示例

例えば、<u>図 3-24</u> のようなエラーが出ている場合、*SPISO* と *UARTO* のピンの競合が起きていますので、設定に誤りがないか確認し、修正を行ってください。

この例では、本来使用しない *SPISO* を使用することとなっているため、エラーになっています。設定を *Unused* とすると、エラーが消えます。



図 3-24. ピン競合エラーがあるときの表示例



## 3-4. ステップ 4: HPS クロックの設定

**HPS Clocks** タブでは、Clock ソースと周波数が設定されます。これらのパラメーターは、すべて Clock Manager Component で管理されます。

このタブで設定されたパラメーターは、ブートローダー (Preloader ソフトウェア) の生成時に使用されます。 Preloader は「演習 2: ソフトウェア演習(1) Preloader の生成」で生成します。

- 1. HPS Clocks タブを選択します。
- \_\_\_\_2. Input Clocks タブを選択します。
- \_\_\_3. *EOSC1 / EOSC2 clock frequency* が *25MHz* に設定されていることを確認します。また、すべての *FPGA-to-HPS PLL Reference clocks* が無効になっていることを確認します。EOSC1 は HPS 側の専用ピンで HPS の MPU の クロックを生成するために必要なクロックソースです。今回使用している Atlas-SoC ボードや DE10-Nano ボードでは、25MHz が入っているためこのように設定しています。



図 3-25. HPS to FPGA Clock の設定



- \_\_\_\_4. Output Clocks タブを選択します。
- \_\_\_\_5. 下図のように設定されていることを確認します(デフォルトから変更はありません)。こちらのタブでは HPS の各ペリフェラルの動作周波数を設定することができます。設定した値に応じて PLL の設定値が自動計算されます。



図 3-26. HPS to FPGA Clock の設定



#### 3-5. ステップ 5 : SDRAM の設定

**SDRAM** タブには、HPS 側の SDRAM コントローラーおよび接続する DDR に関するパラメーターを設定するオプションがあります。 **SDRAM** タブの内部には SDRAM 構成のためさらに 4 つのタブ (**PHY Settings、Memory Parameters、Memory Timing、Board Settings**) があります。

\_\_\_1. Arria V/Cyclone V Hard Processor System ウィンドウの下部の [Finish] をクリックします。

この操作により、HPS コンポーネントが Platform Designer システムに追加されます(次の手順で *Presets* ウィンドウを表示するために必要な操作です)。



図 3-27. Parameters ウィンドウ表示の準備

\_\_\_\_2. **System Contents** ウィンドウの HPS コンポーネントをダブルクリックして再度 HPS のオプション設定を **Parameters** ウィンドウ内に表示させます。

これは、次の手順で Preset ウィンドウを表示するために必要な操作です。



図 3-28. HPS パラメーター設定ウィンドウを再表示



3. Parameters ウィンドウの SDRAM タブをクリックします。

今回はあらかじめ用意されている Atlas-SoC ボード に載っている SDRAM の Preset を使用します。 **Presets** ウィンドウが表示されていることを確認します。

## i Note:

**Preset** ウィンドウが表示されていない場合は、Platform Designer の **View** メニュー ⇒ **Presets** を選択し表示させてください。

それでも表示されない場合は、Platform Designer の *View* メニュー ⇒ *Reset to System Layout* を選択後、 再度 *Preset* を選択してみてください。

\_\_\_4. **Presets** ウィンドウの **Atlas\_HPS\_SDRAM** プリセットを選択します。



図 3-29. プリセットの選択

- \_\_\_\_5. Apply をクリックすると、*Atlas\_HPS\_SDRAM* が太字でハイライトされるはずです。この状態になっていれば 設定が正しく反映されています。
- \_\_\_\_6. SDRAM タブが表示されていない場合は、SDRAM タブをクリックします。
- 7. PHY Settings タブをクリックし、下図の設定となっていることを確認します。



図 3-30. PHY Settings の確認



8. Memory Parameters タブをクリックし、下図の設定となっていることを確認します。



図 3-31. Memory Parameters

\_\_\_\_9. *Memory Initialization Options* セクションまでスクロールダウンし、*ODT Rtt nominal value* に *RZQ/6* が設定されていることを確認します。



図 3-32. Memory Initialization Options



## \_ 10. Memory Timing タブをクリックし、下図の通りの設定となっていることを確認します。



図 3-33. Memory Timing



\_\_\_\_11. Board Settings タブをクリックし、Setup and Hold Derating セクションおよび Channel Signal Integrity セクションで、 Use Altera's default settings が選択されていることを確認します。

| PGA Interfaces Peripheral Pins HPS Clocks SDRAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                               |                                              |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------|
| DRAM Protocol: DDR3 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                               |                                              |
| PHY Settings Memory Parameters Memory Timing Board                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | d Settings                                                                    |                                              |
| Use the Board Settings to model the board-level effects in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                               |                                              |
| an universa (100 m.). Sen nu san de anales a francescon de antronomis secución de desarrol de la como de la como de<br>Se                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                               |                                              |
| The wizard supports single—and multi—rank configurations<br>effects on the output signaling of these configurations and<br>rate and the channel uncertainty within the UniPHY Mega                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | has stored the effects                                                        |                                              |
| These values are representative of specific Altera boards,<br>the board level effects for your board. You can use Hypert<br>values that are representative of your board.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                               |                                              |
| Setup and Hold Derating                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                               |                                              |
| The slew rate of the output signals affects the setup and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | d hold times of the men                                                       | nory device.                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                               |                                              |
| You can specify the slew rate of the output signals to re<br>both the address and command signals and the DQ signs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                               |                                              |
| Derating method:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | lse Alte                                                                      | ra's default settings                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                               | slew rates to calculate setup and hold times |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                               | The Manufacture 1975 W.                      |
| CK/CK# slew rate (Differential)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2.0                                                                           | setup and hold times directly                |
| Address and command slew rate:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                               | V/ns                                         |
| DQS/DQS# slew rate (Differential):                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1.0                                                                           | V/ns                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2.0                                                                           | V/ns                                         |
| DQ slew rate:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1.0                                                                           | V/ns                                         |
| tIS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0.325                                                                         | ns                                           |
| tIH.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0.35                                                                          | rs                                           |
| tDS:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0.2                                                                           | ns                                           |
| tDH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0.225                                                                         | ns                                           |
| Channel Signal Integrity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                               |                                              |
| Channel Signal Integrity is a measure of the distortion of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Etha as a dua ta intara                                                       | mbal lutarfamaa                              |
| or crosstalk or other effects. Typically when going from a configuration there is an increase in the channel loss as reflections. Please perform your channel signal integrity uncertainty as compared to Altera's reference eye diagnostic.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | a single-rank configura<br>there are multiple stub<br>simulations and enter t | tion to a multi−rank<br>os causing           |
| Derating Method:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ( ) Jse Alte                                                                  | ra's default settings                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                               | channel uncertainty values                   |
| Address and command eye reduction (setup):                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0.0                                                                           | ns                                           |
| The state of the s |                                                                               |                                              |

図 3-34. Board Settings (1)



\_\_12. Board Skew セクションまでスクロールダウンし、ボードスキューが下図の通りであることを確認します。

| Channel Signal Integrity is a measure of the distortion of the eye of                                                                                                                                                                                                             | 4                                                                 |                                                |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|------------------------------------------------|--|
| or crosstalk or other effects. Typically when going from a single—re<br>configuration there is an increase in the channel loss as there are<br>reflections. Please perform your channel signal integrity simulation<br>uncertainty as compared to Altera's reference eye diagram. | ank configura<br>multiple stul                                    | tion to a multi <del>ra</del> nk<br>os causing |  |
| Derating Method:                                                                                                                                                                                                                                                                  | Use Altera's default settings  Specify channel uncertainty values |                                                |  |
|                                                                                                                                                                                                                                                                                   |                                                                   |                                                |  |
| Address and command eye reduction (setup):                                                                                                                                                                                                                                        | 0.0                                                               | ns                                             |  |
| Address and command eye reduction (hold)                                                                                                                                                                                                                                          | 0.0                                                               | ns                                             |  |
| Write DQ eye reduction:                                                                                                                                                                                                                                                           | 0.0                                                               | ns                                             |  |
| Write Delta DQS arrival time                                                                                                                                                                                                                                                      | 0.0                                                               | ns                                             |  |
| Read DQ eye reduction:                                                                                                                                                                                                                                                            | 0.0                                                               | ns                                             |  |
| Read Delta DQS arrival time:                                                                                                                                                                                                                                                      | 0.0                                                               | ns                                             |  |
| Board Skews PCB traces can have skews between them that can cause timing                                                                                                                                                                                                          |                                                                   |                                                |  |
| skews between different ranks can further reduce the timing marg                                                                                                                                                                                                                  | in in multi-ra                                                    | nk topologies.                                 |  |
|                                                                                                                                                                                                                                                                                   |                                                                   |                                                |  |
| Restore default values                                                                                                                                                                                                                                                            |                                                                   |                                                |  |
| Maximum CK delay to DIMM/device:                                                                                                                                                                                                                                                  | 0.6                                                               | ns                                             |  |
| Maximum CK delay to DIMM/device:<br>Maximum DQS delay to DIMM/device:                                                                                                                                                                                                             | 0.6                                                               | ns<br>ns                                       |  |
| Maximum CK delay to DIMM/device:<br>Maximum DQS delay to DIMM/device:<br>Minimum delay difference between CK and DQS:                                                                                                                                                             |                                                                   |                                                |  |
| Maximum CK delay to DIMM/device:<br>Maximum DQS delay to DIMM/device:                                                                                                                                                                                                             | 0.6                                                               | ns                                             |  |
| Maximum CK delay to DIMM/device:<br>Maximum DQS delay to DIMM/device:<br>Minimum delay difference between CK and DQS:                                                                                                                                                             | 0.6<br>-0.01                                                      | ns<br>ns                                       |  |
| Maximum CK delay to DIMM/device: Maximum DQS delay to DIMM/device: Minimum delay difference between CK and DQS: Maximum delay difference between CK and DQS:                                                                                                                      | 0.6<br>-0.01<br>0.01                                              | ns<br>ns<br>ns                                 |  |
| Maximum CK delay to DIMM/device: Maximum DQS delay to DIMM/device: Minimum delay difference between CK and DQS: Maximum delay difference between CK and DQS: Maximum skew within DQS group:                                                                                       | 0.6<br>-0.01<br>0.01<br>0.02                                      | ns<br>ns<br>ns                                 |  |
| Maximum CK delay to DIMM/device: Maximum DQS delay to DIMM/device: Minimum delay difference between CK and DQS: Maximum delay difference between CK and DQS: Maximum skew within DQS group: Maximum skew between DQS groups:                                                      | 0.6<br> -0.01<br> 0.01<br> 0.02<br> 0.02                          | ns<br>ns<br>ns<br>ns                           |  |

図 3-35. Board Settings (2)

\_\_\_\_13. Platform Designer の *File* メニュー ⇒ *Save* を選択し、ここまでの手順で指定した HPS のパラメーター設定内容を保存します。



#### 3-6. ステップ 6 : HPS のクロックとエクスポート信号の設定

このステップでは、HPS の H2F ブリッジのクロックと LWH2F ブリッジのクロックの設定を行います。

ここで設定するクロックは、各ブリッジの FPGA 側のクロック(下図の h2f\_axi\_clk と h2f\_lw\_axi\_clk)です。 HPS 側のクロックは「<u>3-4. ステップ 4 : HPS クロックの設定</u>」で設定した l3\_main\_clk や l4\_mp\_clk となり、 これから設定するクロックとは異なります。クロックの違いは、ブリッジ内で吸収されます。

また、HPS のエクスポート信号の設定も行います。このエクスポート信号は Platform Designer 外部との通信に使用されます。たとえば、Platform Designer と FPGA の他のロジックとの接続やピンへの配置に使用されます。



図 3-36. HPS と FPGA 間のクロック



- \_\_\_\_1. **System Contents** タブに移動します。
- \_\_\_\_\_2. **Export** 列に信号名を記述することで、Platform Designer システムの外部に信号線を出すことができます。先ほ ど追加した HPS コンポーネントの **hps\_io** ポートが **hps\_io** という信号名でエクスポートされていることを確認し ます。
- \_\_\_\_3. 同様に HPS コンポーネントの *memory* ポートが *memory* という信号名でエクスポートされていることを確認し ます。こちらは先ほど設定した HPS 側の SDRAM の IO です。
- \_\_\_\_\_4. HPS コンポーネントの *h2f\_resest* をエクスポートします。 *h2f\_reset* の *Export* 列をダブルクリックし、" *h2f\_reset*" にリネームした後、Enter キーを押してエクスポートします。
- \_\_\_\_5. HPS 上の Clock Input インターフェイス *h2f\_axi\_clock* の設定を行います。 *h2f\_axi\_clock* の横の *Clock* 列のプルダウンメニューで *clk\_0* を選択し、*h2f\_axi\_clock* に *clk\_0* を接続します。
- \_\_\_\_6. 同様に HPS 上の Clock Input インターフェイス *h2f\_lw\_axi\_clock* の設定を行います。 *h2f\_lw\_axi\_clock* の横 の *Clock* 列のプルダウンメニューで clk\_0 を選択し、h2f\_lw\_axi\_clock に clk\_0 を接続します。



図 3-37. クロックとエクスポート信号の設定

この時点で *clk0* が接続されたので、図 3-23 において *Message Window* に出ていた<u>2つのエラーメッセー</u>ジが無くなっているはずです。



#### 3-7. ステップ 7: HPS コンポーネントと他のコンポーネントの接続

このステップでは、Platform Designer システムに追加した HPS コンポーネントと Platform Designer システムに実装済みのコンポーネントを接続します。今回 FPGA 側は clk\_0 (50MHz) で動作させるため、あらかじめ clk 0 が各コンポーネントに接続されています。

- \_\_\_\_1. *onchip\_memory2\_0* コンポーネントの Clock Input インターフェイスが、*clk\_0* に接続されていることを確認しま す。
- \_\_\_\_2. *led\_pio* コンポーネントの Clock Input インターフェイスが、*clk\_0* に接続されていることを確認します。
- 3. dipsw\_pio コンポーネントの Clock Input インターフェイスが、clk\_0 に接続されていることを確認します。
- \_\_\_\_\_4. button\_pio コンポーネントの Clock Input インターフェイスが、clk\_0 に接続されていることを確認します。
- \_\_\_\_5. *onchip\_memory2\_0* の *s1* を選択した後、右クリックをすることにより表示される接続サブメニューから *hps\_0.h2f\_axi\_master* を選択します。これにより **HPS h2f\_axi\_master** に、*onchip\_memory2\_0* コンポーネント の *s1* インターフェイスが接続されます。この設定で Arm® プロセッサー から FPGA 側の onchip\_memory へ アクセスすることができます。



図 3-38. コンポーネント間の接続

- \_\_\_\_6. 同様に button\_pio の s1 を右クリックし、接続サブメニューから hps\_0.h2f\_lw\_axi\_master を選択します。これにより HPS h2f\_lw\_axi\_master に、button\_pio コンポーネントの s1 インターフェイスが接続されます。接続先が h2f\_lw\_axi\_master であることに注意してください。続く各 PIO コンポーネントも同様です。
- \_\_\_\_\_7. 同様に dipsw\_pio の s1 を右クリックし、接続サブメニューから hps\_0.h2f\_lw\_axi\_master を選択します。これにより HPS h2f\_lw\_axi\_master に、dipsw\_pio コンポーネントの s1 インターフェイスが接続されます。
- \_\_\_\_\_8. 同様に led\_pio の s1 を右クリックし、接続サブメニューから hps\_0.h2f\_lw\_axi\_master を選択します。これにより HPS h2f\_lw\_axi\_master に、led\_pio コンポーネントの s1 インターフェイスが接続されます。



\_\_\_9. HPS コンポーネントを選択し *System Contents* ウィンドウの左側にある、Platform Designer ツールバーの**上下ボ** タンを ▼▼▲▼ 使用して、 HPS コンポーネントを clk\_0 の下に移動してください。

設定完了後の Platform Designer システムは以下の通りです。



図 3-39. 設定完了後の Platform Designer システム

led\_pio へのアクセスを考えてみます。

led\_pio の右から 2 つ目の *Base* 列を見ると 0x0001\_0040 と設定されています。これが led\_pio の Platform Designer でのオフセットアドレスです。先の \_\_\_\_\_ 8. で設定したように led\_pio にアクセスするマスターは **HPS h2f\_lw\_axi\_master** です。Lightweight HPS-to-FPGA のブリッジのベースアドレスは 0xFF20\_0000 でしたので、この led\_pio にアクセスする場合は以下の値になります。

ブリッジのベースアドレス(0xFF20\_0000) + Platform Designer のオフセットアドレス (0x0001\_0040) = **0xFF21\_0040** 

ほかのコンポーネントも同様に考えることができ、dipsw\_pio であれば 0xFF21\_0080 です。

次に、onchip\_memory へのアクセスを考えてみます。

HPS から FPGA に対してのもうひとつのパスである HPS h2f\_axi\_master ブリッジのベースアドレスは 0xC000\_0000 でした。今回は HPS h2f\_axi\_master に接続した onchip\_memory の Platform Designer のオフセットアドレスが 0x0 なので、この場合はブリッジのベースアドレス (0xC000\_0000) がそのまま onchip\_memory にアクセスするベースアドレスとなります。



### 3-8. ステップ 8 : リセットの接続とベースアドレスの割り当て

このステップでは、リセットの一括接続とベースアドレスの自動割り当てを行います。

- \_\_\_\_\_1. Platform Designer の *System* メニュー ⇒ *Create Global Reset Network* を選択し、デザインのすべてのリセット・インターフェイスを**一括**で接続します。
- \_\_\_\_2. 重複アドレスが存在しないように、すべてのコンポーネントのためにベースアドレスを自動割り当てします。 System メニュー ⇒ Assign Base Addresses を選択します。



図 3-40. リセットの一括接続とベースアドレスの自動割り当て

Assign Base Address を行っても、何も起こらなかったのではないでしょうか。

この演習では、事前に各ペリフェラルのベースアドレスを固定してあったため、自動的にアドレスがアサインされませんでした。

図 3-41 に示すように、ベースアドレスの横にある鍵マーク ● を使用することにより、アドレス設定を固定できます。クリックするごとに固定されるかどうかトグルします。アドレスを固定したい場合は、アドレス設定後に鍵マークで固定してください。Platform Designer の *Edit* メニュー ⇒ *Lock Base Address* でも固定できます。



図 3-41. ベースアドレスの固定



#### 3-9. ステップ 9 : Platform Designer システムの確認

\_\_1. 設計した Platform Designer システムが以下の「<u>表 3-1. 設計後の Platform Designer システムの接続状況</u>」 の通りであることを確認します。「図 3-39. 設定完了後の Platform Designer システム」も参考にしてください。

演習用の Quartus® Prime プロジェクトとの整合性を取るため、エクスポート信号が適切にエクスポートされていること、および正しく命名されていることを確認してください。実際の設計においては任意の信号名を利用いただくことが可能です。また、コンポーネントの順序に規定はありません。

| コンポーネント    | ポート名                | 接続                                       |
|------------|---------------------|------------------------------------------|
| clk_0      | clk_in              | clk としてエクスポート                            |
|            | clk_in_reset        | reset としてエクスポート                          |
|            | clk                 | すべてのコンポーネントに接続                           |
|            | clk_reset           | hps_0 を除く、すべてのコンポーネントに接続                 |
| led_pio    | external_connection | led_pio_external_connection としてエクスポート    |
| dipsw_pio  | external_connection | dipsw_pio_external_connection としてエクスポート  |
| button_pio | external_connection | button_pio_external_connection としてエクスポート |
| hps_0      | h2f_axi_master      | onchip_memory2_0.s1 に接続                  |
|            | h2f_lw_axi_master   | led_pio.s1 に接続                           |
|            |                     | dipsw_pio.s1 に接続                         |
|            |                     | button_pio.s1 に接続                        |

表 3-1. 設計後の Platform Designer システムの接続状況

\_\_\_\_\_2. Platform Designer の *View* メニュー ⇒ *Device Family* を選択し、

Device Family が Cyclone V になっていること、

Device が Atlas-SoC ボードの場合は 5CSEMA4U23C6、 DE10-Nano ボードの場合は 5CSEBA6U23I7DK にな

っていることを確認します。



図 3-42. Device Family タブ



\_\_3. Platform Designer の View メニュー ⇒ Interconnect Requirements を選択し、

Limit interconnect pipeline stages to を 1 に設定します。段数を増やすとタイミングに余裕がでますが、同時に FPGA のロジックも大きくなります。

Clock crossing adapter type が Handshake になっていることを確認します。



図 3-43. プロジェクト・パラメーターの設定



3-10. ステップ 10: Platform Designer システムの生成

完成した Platform Designer システムを生成します。

\_\_\_\_1. *System Contents* タブの *Message* ボックスに、残りのエラーがあるかどうかを確認します。エラーがある場合は、 続行する前にそれらを修正する必要があります。

青字で表示される Warning に関しては、今回は無視してください。

| ĕ≣ Mess  | õ≣ Messages 🌣 🗖 e     |                                                                                                                               |  |
|----------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------|--|
| Туре     | Path                  | Message                                                                                                                       |  |
|          | 2 Warnings            |                                                                                                                               |  |
| <u> </u> | soc_system.hps_0      | "Configuration/HPS-to-FPGA user 0 clock frequency" (desired_cfg_clk_mhz) requested 100.0 MHz, but only achieved 97.368421 MHz |  |
| <u> </u> | soc_system.hps_0      | 1 or more output clock frequencies cannot be achieved precisely, consider revising desired output clock frequencies.          |  |
| =0       | 5 Info Messages       |                                                                                                                               |  |
| 1        | soc_system.button_pio | PIO inputs are not hardwired in test bench. Undefined values will be read from PIO inputs during simulation.                  |  |
| 1        | soc_system.dipsw_pio  | PIO inputs are not hardwired in test bench. Undefined values will be read from PIO inputs during simulation.                  |  |
| 0        | soc_system.hps_0      | HPS Main PLL counter settings: n = 0 m = 73                                                                                   |  |
| 1        | soc_system.hps_0      | HPS peripherial PLL counter settings: n = 0 m = 39                                                                            |  |
| 0        | soc_system.led_pio    | PIO inputs are not hardwired in test bench. Undefined values will be read from PIO inputs during simulation.                  |  |

図 3-44. Message ウィンドウの表示

\_\_\_\_\_2. *File* メニュー ⇒ *Save* を選択して、Platform Designer システムを保存します。 *Save System Completed* がポップ アップされたら [*Close*] します。



図 3-45. Platform Designer システムの保存

\_\_\_\_3. Generate メニュー ⇒ Generate HDL を選択します。



図 3-46. Platform Designer システムの生成



4. Generation ウィンドウの設定を確認し、[Generate] を実行します。



図 3-47. Platform Designer システムの Generate 実行画面

\_\_\_\_5. Platform Designer の *Generate* メニュー ⇒ *Show Instantiation Template* ではトップデザインにインスタンスする際に使用できるインスタンスの例が表示されます。

今回はインスタンス済みですので、特に作業は発生しませんが実際に使用する場合にはとても有効です。



図 3-48. Platform Designer システムのインスタンス例



\_\_\_\_6. Platform Designer の生成が完了した後に、[*Close*] ボタンをクリックし、Platform Designer のシステム生成ダイア ログボックスを閉じて Quartus<sup>®</sup> Prime に戻ります。



図 3-49. Platform Designer システムの生成完了

\_\_\_\_7. Quartus<sup>®</sup> Prime の *Project* メニュー ⇒ *Add/Remove Files in Project* を選択します(*Settings* ダイアログボック スが *Files* カテゴリーが選択された状態で表示されます)。



図 3-50. Add/Remove Files in Project を選択

\_\_\_\_\_8. Settings ダイアログボックス内の File name フィールドの横にある ..... ボタンを押し、Select File ウィンドウから soc\_system/synthesis フォルダーを参照します。



図 3-51. Settings ダイアログボックス



\_\_\_\_\_9. **soc\_system.qip** ファイルを選択し、[*開く* **(O)**] をクリックします。この qip ファイルは Platform Designer で Generate したコンポーネントを紐づけているファイルです。 Generate したファイルをひとつずつ登録するので はなく、こちらの qip ファイルの登録のみで、 Platform Designer システムをプロジェクトに追加することができま す。



図 3-52. qip ファイルの指定

10. ファイルが追加されたことを確認します。



図 3-53. qip ファイルの登録

11. Settings ダイアログボックスを [OK] ボタンで閉じます。



3-11. ステップ 11 : ピン・アサインメントの設定と Ouartus® Prime プロジェクトのコンパイル

HPS 専用 IO に関しては、ピン配置が決まっているため基本的にピン・アサインメントはツールが自動で行います。例外として、SDRAM インターフェイス は、ツールが生成したスクリプトを設計者が実行する必要があります。スクリプトを実行するためには、まずネットリストを生成し、その後にスクリプトを実行します。

そのため、まずはネットリスト作成のための Analysis & Synthesis を実行後、スクリプトを実行し、再度 FPGA のコンパイルを行います。

\_\_1. Quartus® Prime の *Processing* メニュー ⇒ *Start ⇒ Start Analysis & Synthesis* を選択します。

(または、GUI 上の Start Analysis & Synthesis ボタン 🔀 をクリックします)。





図 3-54. Start Analysis & Synthesis



図 3-55. Start Analysis & Synthesis の正常終了確認



3. Quartus<sup>®</sup> Prime の *Tools* メニュー ⇒ *TCL scripts* を選択します。



図 3-56. Tcl Scripts ウィンドウの起動

\_\_\_\_4. soc\_system ⇒ synthesis ⇒ submodules にある hps\_sdram\_p0\_pin\_assignments.tcl を選択し、[Run] ボタンをクリックします(反映されるまで少し時間がかかります)。

この作業により SDRAM の IO Standard の設定や OCT の設定など HPS の SDRAM Controller タブで設定した内容が反映されます。



図 3-57. Tcl Script の実行



## 5. 完了したら [OK] ボタンをクリックします。



図 3-58. Tcl Script の完了

\_\_6. Tcl Scripts ウィンドウを [*Close*] します。



図 3-59. Tcl Scripts ウィンドウの Close



\_\_\_\_7. Quartus<sup>®</sup> Prime の *Processing* メニュー ⇒ *Start Compilation* を選択(または、GUI 上の Start Compilation ボタン ▶ をクリック)し、FPGA のコンパイルを行います。このコンパイルで HW の動作イメージとなる .sof ファイル、そして次のソフトウェア開発に引き渡すハンドオフ・ファイルを作成します。



図 3-60. Start Compilation の実行

8. コンパイルの完了を確認します。



図 3-61. コンパイルの完了



### 3-12. ステップ 12 : 出力ファイルの確認

Quartus® Prime および Platform Designer で出力したファイルを確認します。

\_\_\_\_1. Windows® OS のエクスプローラーを使用して、出力ファイルのフォルダー(下記)に移動します。
C:¥lab¥soc\_lab¥cv\_soc\_lab¥output\_files

2. 上記フォルダーに .sof ファイルが出力されていることを確認します。

Atlas-SoC ボードの場合は atlas.sof、

DE10-Nano ボードの場合は **DE10-Nano.sof** が出力されている事を確認してください。

先ほど説明したように、この ファイルは FPGA の動作イメージファイルです。

このファイルは後の演習で Programmer というツールを使用してボード上の FPGA に書き込みます。

\_\_\_\_3. Windows® OS のエクスプローラーを使用して、ハードウェア/ソフトウェアのハンドオフ・ディレクトリーに移動します。

C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\footnote{C:\foo

上記フォルダー以下にツールによって生成されたハードウェア・ソフトウェアのハンドオフ・ファイルがあります。 これらのファイルは Platform Designer の HPS コンポーネント画面で設定した各種データや HPS の SDRAM インターフェイスの情報などの各種ファイルが格納されており、Preloader という HPS 側の初期化に使用されるファイルの生成に利用します。

これらのファイルを用いて後の演習で Preloader の作成を行います。

### 演習 1 ハードウェア演習のまとめ

このセクションでは、以下の作業を実施し、Arm® プロセッサーを含むハードウェアを構成しました。

- Platform Designer システムへの HPS コンポーネントの追加
- HPS コンポーネントの設定
- HPS コンポーネントと他のコンポーネントの接続
- Platform Designer システムの生成
- Quartus® Prime / Platform Designer が出力するファイルの確認

以上で 演習 1 は完了です。



## 4. 演習 2: ソフトウェア演習(1) Preloader の生成

このセクションでは、「<u>演習 1: ハードウェア演習</u>」で作成したハンドオフ・ファイルを使用して Preloader を生成します。

Preloader は U-boot second program loader (以後、u-boot spl) をベースにインテル SoC FPGA 向けにカスタマイズが加えられたブートローダーです。 Preloader の役割は以下の通りです。

- HPS ピン・マルチプレクスの設定
- HPS IOCSR の設定
- HPS PLL とクロックの設定
- HPS ペリフェラルのリセット解除
- SDRAM の初期化(キャリブレーションなど)
- SDRAM へ次ステージのブート・イメージの展開

上記の通り、Preloader は HPS ブロックの初期化と、U-boot や OS を SDRAM にロードする機能を提供します。Preloader は Quartus® Prime / Platform Designer の設計時に自動生成されるハンドオフ・ファイルを用いることで自動生成されます。このため、ユーザー側で初期化用ソフトウェアの構築をすることなく Quartus® Prime / Platform Designer で設定した内容を HPS ブロックに反映することができます。先ほど確認した sof ファイルは FPGA 側の動作イメージでした。それに対して HPS 側の動作イメージがこの Preloader というファイルです。 FPGA 側、HPS 側でそれぞれ異なるファイルを使用して動作イメージを実行するという点にご注意ください。

では Preloader Generator というツールを使用し、Preloader を作成する手順を行ってみましょう。



### 4-1. ステップ 1: Embedded Command Shell の起動

\_\_1. SoCEDS に含まれている Embedded Command Shell 上より DS-5™ を起動します。
Embedded Command Shell は、Windows® のスタートメニュー、または SoCEDS のインストール・フォルダー以下
に格納されている起動用スクリプト Embedded\_Command\_Shell.bat をダブルクリックして起動します。



図 4-1. Embedded Command Shell の起動



- 4-2. ステップ 2 : bsp-editor (Preloader Generator) の起動
- \_\_\_\_\_1. <mark>Embedded Command Shell</mark> から **bsp-editor** とタイプし、bsp-editor(Preloader Generator)の GUI を起動 します。
  - \$ bsp-editor →



図 4-2. bsp-editor の起動

- 4-3. ステップ 3 : プロジェクトの作成と設定
- \_\_\_\_1. File メニュー ⇒ New HPS BSP を選択し、プロジェクトを新規作成します。



図 4-3. 新規プロジェクトの作成



\_\_\_\_2. Preloader settings directory: にハンドオフ・ファイルを指定します。 \_\_\_\_ を押して、フォルダーを指定します。

指定するフォルダーは、c:\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\footnote{lab\fo







図 4-4. ハンドオフ・ファイルの指定



3. Preloader のユーザーオプション(Common)を確認します。本演習ではデフォルトのままで結構です。

こちらでは Preloader がどこのソースに格納されているか、また次段のソフトウェアの格納番地など、様々な設定を GUI で設定することができます。デフォルトでは SDMMC に格納されているものとして設定されており、本演習ではこの設定で行います。



図 4-5. ユーザーオプションの確認

4. Preloader のユーザーオプション(Advanced ⇒ spl ⇒ boot)を設定します。

「<u>演習 3: ソフトウェア演習(2) ベアメタル・アプリケーション</u>」では、ベアメタル・アプリケーションを使用するため、*WATCHDOG\_ENABLE のチェックを外します*。

(ベアメタル・アプリケーションでは WATCHDOG TIMER を使用できないというわけではありません。デバッグ初期において、不用意に WATCHDOG TIMER によるリセットを発生させないために、ディセーブルにしておきます)。



図 4-6. Advanced 設定(1)



5. Preloader のユーザーオプション (Advanced ⇒ spl ⇒ debug) を設定します。

「<u>演習 3: ソフトウェア演習(2) ベアメタル・アプリケーション</u>」では、DS-5™ のセミホスティング機能を使用するので、*SEMIHOSTING* のチェックボックスを **ON** にします。このセミホスティング機能を使用すると UART などのコンソール入出力を DS-5™ のコンソールを用いて行うことができます。今回は DS-5™ でのデバッグを行うため、チェックを入れますが、スタンドアローン動作(DS-5™ などを使用せず、製品化時のように自律動作する場合)の場合にはこちらのチェックを外した Preloader を使用してください。



図 4-7. Advanced 設定(2)

6. [Generate] ボタンをクリックして、bsp プロジェクトを生成します。

生成完了を確認後、「Exit ] ボタンをクリックし BSP Editor を終了します。



図 4-8. bsp プロジェクトの生成

これにより Software フォルダー下の spl\_bsp に設定したデータ用のソースファイルが生成されます。 このソースファイルと一緒に Makefile も自動生成されますので、こちらを使用して Preloader を作成します。



4-4. ステップ 4: Preloader のビルド

1. Embedded Command Shell のカレント・ディレクトリーを bsp プロジェクト・ディレクトリーへ移動します。

\$ cd "C:¥lab¥soc\_lab¥cv\_soc\_lab¥software¥spl\_bsp" ↓



図 4-9. bsp プロジェクト・ディレクトリーへの移動

2. **make all** コマンドを実行し Preloader を生成します。

\$ make all ↓

### ↑ 注記:

ホスト PC の OS が Windows® 10 の場合、Preloader の生成でエラーが発生する場合が確認されております。 こちらをご確認ください。

この演習では、前のステップで C:\(\frac{1}{2}\) Lab\(\frac{1}{2}\) Soc\_lab\(\frac{1}{2}\) Soc\_lab\(\frac{1}\) Soc\_lab\(\frac{1}{2}\) Soc\_lab\(\frac{1}2\) Soc\_lab\(\frac{1}2\) Soc\_lab\(\frac{1}2\) Soc\_lab\(\frac{1}2\) So

ifeq (\$(HOSTOS),cygwin)

UNTAR := \$(SOCEDS\_DEST\_ROOT)/host\_tools/cygwin/bin/tar zxf





図 4-10. Preloader の生成

3. 実行後、エラーがなく終了したことを確認します。

エラーなく終了したことを確認後 **1s** □ コマンドにて preloader-mkpimage.bin が生成されていることを確認します。このファイルは、BootROM にて参照される Preloader 用のヘッダ情報を付加したバイナリ・ファイルとなっており、SD カードや QSPI フラッシュ・メモリーへ書き込むファイルとなります。

## 以上で 演習 2 は完了です。



## 5. 演習 3: ソフトウェア演習(2) ベアメタル・アプリケーション

このセクションでは、DS-5™ を使用し、SoC EDS に付属の Hello World サンプル・アプリケーションおよび本演習用に用意された LED Blink サンプル・アプリケーションを実行し、ソフトウェアの開発手法およびデバッグ手法について解説します。

以下にサンプル・アプリケーションの概要を記述します。

● Hello World サンプル・アプリケーションの概要

このサンプル・アプリケーションは、DS-5™ が持つセミホスティング機能を使用して、デバッガ・コンソールに "Hello Tim" というメッセージを出力します。

この方法ではデバイスのペリフェラルは使用されず、すべての通信は JTAG を通じて行われます。

実行するアプリケーションは、64KB のオンチップ RAM にダウンロードされ実行が開始されます。このため、ボード上の SDRAM メモリーの設定を必要としません。

上記の理由から、インテル® SoC FPGA が実装されたすべてのボードで実行することが可能です。

● LED Blink サンプル・アプリケーションの概要

このサンプル・アプリケーションでは、「<u>演習 1: ハードウェア演習</u>」にて作成した FPGA デザインを用い、Arm® プロセッサーから FPGA ファブリック側に実装された PIO ペリフェラルにアクセスし LED の点灯、消灯を制御します。

このサンプル・アプリケーションはメイン・アプリケーションを実行する前に、Preloader と呼ばれる HPS ブロックの初期化ソフトウェアを実行し、SDRAM のキャリブレーション、クロックの設定、HPS-FPGA 間のブリッジの初期化等を行います。これにより、FPGA ファブリック側のペリフェラルにアクセスすることが可能な状態でメイン・アプリケーションを実行します。また、メイン・アプリケーションは SDRAM にロードされ実行を開始します。

### ↑ 注記:

- この演習を行う前に、Linux<sup>®</sup>(または他の OS)が、ボード上で実行されていないことを確認してください。OS は、ベアメタル・アプリケーションのダウンロードおよびデバッグ機能を妨げる可能性があります(microSD カードが挿入されている場合は、外してください)。
- このセクションでの説明、画面スナップショットおよびコマンドは、SoC EDS の Windows® バージョンを使用して作成されたものですが、Linux ホスト PC 上でも同様の方法で実行することができます。
- このセクションで示すパスは、デフォルトのインストール・パスを使用したと仮定します。標準以外の場所が使用されている場合は、それに応じて調整してください。
- ベアメタル・アプリケーションを DS-5™ でデバッグする場合、ライセンスが必要となります。ライセンスは、MAC Address に紐づけられています。

紐づけられているネットワーク・インターフェイスを PC に認識させておいてください。



### 5-1. FPGA デザインのダウンロード

ソフトウェアの演習を開始する前に、「<u>3. 演習 1: ハードウェア演習</u>」で作成したハードウェア・デザイン(sof ファイル)を FPGA にダウンロードします。「<u>2. ボードの設定</u>」のセクションを参照し、ボードのセットアップが完了していることを再度確認してください。セットアップに問題がなければ、J14 に AC アダプターを接続してください。

- \_\_\_\_1. Quartus<sup>®</sup> Prime の *Tools* メニュー ⇒ *Programmer*、または *Programmer* アイコン <mark>≫</mark> をクリックし、 Programmer を起動します。
- \_\_\_\_2. **Programmer** 内にある [**Hardware Setup**] ボタンをクリックし、Hardware Setup ウィンドウ内の **Currently selected hardware** のプルダウンリストから **DE-SoC** を選択し、ウィンドウを Close します。



図 5-1. Hardware Setup

- 3. 「Auto Detect〕 ボタンをクリックし、基板上の JTAG チェインに接続されている FPGA を検出します。
- \_\_\_\_4. *Select Device* ウィンドウから <u>Atlas-SoC ボードの場合は *5CSEMA4*</u> を、<u>DE10-Nano ボードの場合は *5CSEBA6* を選択し、[*OK*] をクリックします。</u>



図 5-2. デバイスの選択



5. 以下のダイアログボックスが表示された場合は、[Yes] を選択します。



図 5-3. ダイアログボックス

これにより、JTAG Chain 上に SOCVHPS と 5CSMA4/5CSEBA6 が表示されます。SOCVHPS は HPS 側、5CSMA4/5CSEBA6 は FPGA 側が認識されたことをそれぞれ示しています。

\_\_6. ダウンロードするファイルを選択します。

**Device** 欄の 5CSEMA4/5CSEBA6 上で右クリックし、**Change File** をクリックします。 **Select New Programming File** ダイアログボックスで、c:¥lab¥soc\_lab¥cv\_soc\_lab¥output\_files をブラウズし Atlas-SoC ボードの場合は
<u>atlas.sof</u> を、<u>DE10-Nano</u> ボードの場合は **DE10-Nano.sof** を選択します。



図 5-4. sof ファイルの選択



\_\_\_\_7. *Program/Configure* にチェックを入れた後、[*Start*] ボタンをクリックしてコンフィグレーションを行います。 右上の Progress パーが 100% になったら FPGA 側に動作イメージが書き込まれた状態となります。







図 5-5. sof のダウンロード



#### 5-2. Hello World サンプル・アプリケーションの実行

続いて HPS 上でサンプル・アプリケーションを動作させてみましょう。 はじめに Eclipse を立ち上げます。

\_\_\_\_1. SoCEDS に含まれている Embedded Command Shell 上より DS-5™ を起動します。
Embedded Command Shell は、Windows® のスタートメニュー、または SoCEDS のインストール・フォルダー以下
に格納されている起動用スクリプト *Embedded\_Command\_Shell.bat* をダブルクリックして起動します。



図 5-6. Embedded Command Shell の起動

\_\_\_\_\_2. Embedded Command Shell 上で eclipse とタイプし、DS-5™ を起動します。このように Embedded Command Shell 上から起動することで、Intel® SoC FPGA Edition 用の環境変数が設定されます。

# \$ eclipse ←



図 5-7. DS-5™ の起動と起動画面



\_\_\_\_3. Eclipse ツールを使用するワークスペース・フォルダーを設定します。

この演習では、「3. 演習 1: ハードウェア演習」の作業フォルダーに workspace を作成します。

以下のパスを指定して [OK] をクリックします (フォルダーが存在しない場合は、自動的に作成されます)。

C:\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\footslab\



図 5-8. DS-5™ のワークスペースの指定

\_\_\_\_4. DS-5™ の Welcome 画面が表示されます。これは、ドキュメント、チュートリアルやビデオにアクセスするために 使用することができます。

[閉じる] (×マーク) をクリックします。



図 5-9. DS-5™ の Welcome 画面



続いて、Hello World サンプル・アプリケーションをインポートします。

Hello World サンプル・アプリケーションは SoC EDS に Software Example として入っています。

5. 「*ファイル*」メニュー ⇒「*インポート*」を選択します。



図 5-10. 「インポート」メニュー

6. 「一般」⇒「既存プロジェクトをワークスペースへ」を選択し、[次へ (N)] をクリックします。



図 5-11. 既存プロジェクトのインポート



### 7. **アーカイブ・ファイルの選択(A)**: オプションを選択します。

[参照(R)] ボタンより、サンプル・プロジェクトを指定します。

サンプル・プロジェクトは SoC EDS に含まれており、デフォルトでは以下のインストール・フォルダーにあります。

C:\forall C:\forall intelFPGA\forall 18.1\forall embedded\forall examples\forall software\forall Altera-SoCFPGA-HelloWorld-Baremetal-GNU.tar.gz

選択後、[終了 (F)] ボタンをクリックします。



図 5-12. Hello World サンプル・アプリケーションの選択

この作業を実施すると、Eclipse 左側の プロジェクト・エクスプローラーにプロジェクトに含まれる各種ファイルが表示されます。



次に Hello World サンプル・アプリケーションをコンパイルします。

- 8. プロジェクト・エクスプローラー・タブよりプロジェクトを選択しハイライトします。
- \_\_\_\_9. 「*プロジェクト*」⇒「*プロジェクトのビルド*」を選択します。もしくは、プロジェクト・エクスプローラー上でプロジェ クトを選択し、**右クリック** ⇒「*プロジェクトのビルド*」を実行します。





図 5-13. Hello World プロジェクトのビルド

プロジェクトがコンパイルされ、上記の図に示すように、プロジェクト・エクスプローラーに *hello.axf* という DS-5™ 上での実行可能バイナリが出力されます。

コンソール・ウィンドウ上には、実行可能バイナリを生成する際に実行されたコマンドが表示されています。



最後に、先ほど生成した Hello World サンプル・アプリケーション (hello.axf) を実行します。

10. 「**実行**」メニュー ⇒「*デバッグの構成*」を選択します。



図 5-14. デバッグの構成の選択

\_\_11. デバッグ構成ウィンドウにある左側のパネルから、

**DS-5 デバッガ** ⇒ **Altera-SoCFPGA-HelloWorld-Baremetal-Debug** を選択します (表示されない場合は、DS-5™ デバッガの横にある (+) をクリックしてください)。

ターゲット接続は、インテル® FPGA ダウンロード・ケーブル (USB-Blaster™) を利用し、

Altera ⇒ Cyclone V SoC (Dual Core) ⇒ Bare Metal Debug ⇒ Debug Cortex-A9\_0 となるように設定されています。

12. 接続セクションの右側にある [参照] ボタンを押下し、USB-Blaster™ 接続の選択画面を表示させます。



図 5-15. デバッグの構成



\_\_\_\_13. 接続ブラウザ・ウィンドウで、目的の USB-Blaster™(この例では DE-SoC on localhost)をハイライトして、[*選択*] をクリックします。



図 5-16. デバッグ・ケーブルの選択

14. デバッグ構成ウィンドウの右下にある [ デバッグ (D)] ボタンをクリックします。



図 5-17. デバッグの実行



\_\_\_\_15. Eclipse は、デバッグ パースペクティブに切り替えるかどうかを尋ねます。 [*はい (Y)*] をクリックしてそれを受 け入れてください。



図 5-18. パースペクティブスイッチの確認

Windows Defender ファイアウォールの警告が出た場合は、[アクセスを許可する(A)]をクリックします。



図 5-19. セキュリティの警告

### **□** Note:

ダウンロード時にエラーが発生した場合は、以下の確認を行ってください。

- (1) DS-5™ のライセンスが紐づけられているネットワーク・インターフェイス (例えば USB-Ethernet Interface アダプター) が有効になっているか確認してください。
- (2) 評価ボードの電源入切および PC の再起動で復旧しないか確認してください。評価ボードの電源を切った場合は、再度 FPGA のデータをダウンロードすることを忘れないでください。

デバッガは起動スクリプトの指示に従いセミホスティング機能を有効にした後、JTAG を経由してアプリケーションをボードにダウンロードします。プログラム・カウンタ が main 関数に到達するとブレークされデバッグが開始出来る状態となります。この段階では、DS-5™ のすべてのデバッグ機能を使用することができます(レジスタや変数の表示と編集、逆アセンブリ・コードの参照、など)。



\_\_\_ 16. 緑色の *Continue* ボタン 🕟 をクリック (または F8 キーを押して) アプリケーションを実行します。これによ

り、アプリケーション・コンソール に Hello Tim メッセージを表示します



図 5-20. Hello Tim の表示

- \_\_\_\_ 17. 接続の切断ボタン 🤏 をクリックし CPU との接続を切断します。
- \_\_\_\_18. 画面右上のパースペクティブボタン 🖺 🔠 🌞 をクリックし編集画面に戻ります。



### 5-3. LED Blink サンプル・アプリケーションの実行

Hello World サンプル・アプリケーションと同様に事前に用意された LED Blink サンプル・アプリケーションをDS-5™ にインポートします。

\_\_\_\_1. 「*ファイル*」メニュー ⇒「*インポート*」を選択します。



図 5-21. 「インポート」メニュー

2. 「一般」⇒「既存プロジェクトをワークスペースへ」を選択し、[次へ (N)] をクリックします。



図 5-22. 既存プロジェクトのインポート



3. **アーカイブ・ファイルの選択(A)**オプションを選択します。

[参照(R)] ボタンより、以下のサンプル・プロジェクトを指定します。

C:\frac{1}{2}\delta \frac{1}{2}\delta \frac{1}{2

### ■ Note:

これはツールのインストール・ディレクトリーではなく **演習データのディレクトリー以下である** ことに注意してください。

選択後、[終ア(F)] ボタンを押します。



図 5-23. LED Blink サンプル・アプリケーションの選択

この作業を実施すると、Eclipse 左側の プロジェクト・エクスプローラーにプロジェクトに含まれる各種ファイルが表示されます。



次に、LED Blink サンプル・アプリケーションをコンパイルします。

- 4. プロジェクト・エクスプローラー タブより Atlas-Blinking-LED-Baremetal-GNU プロジェクトを選択しハイライトします。
- \_\_\_\_5. 「*プロジェクト*」メニュー ⇒「*プロジェクトのビルド*」を選択します。もしくは、プロジェクト・エクスプローラー上で プロジェクトを選択し、 **右クリック** ⇒ 「*プロジェクトのビルド*」を実行します。





図 5-24. LED Blink サンプル・アプリケーションのビルド



最後に、LED Blink サンプル・アプリケーションを実行します。

- \_\_\_\_6. 「**実行**」メニュー ⇒ 「*デバッグの構成*」を選択します。サンプル・プロジェクトには、Atlas-SoC ボード上で実行するための事前設定を付属しています。
- 7. デバッグ構成ウィンドウにある左側のパネルから、

**DS-5 デバッガ** → Atlas-Blinking-LED-Baremetal-Debug を選択します (表示されない場合は、DS-5™ デバッガの横にある (+) をクリックしてください)。

ターゲット接続は、USB-Blaster™ を利用し、

Altera ⇒ Cyclone V SoC (Dual Core) ⇒ Bare Metal Debug ⇒ Debug Cortex-A9\_0 となるように既に設定されています。



図 5-25. LED Blink サンプル・アプリケーションのデバッグ構成

\_\_\_8. 以下の確認ポップアップが出た場合は、[*はい*] を選択してください。



図 5-26. 確認ポップアップ



- 9. 接続セクションの右側にある [**参照**] ボタンを押下し、USB-Blaster™ 接続を選択します。
- \_\_\_\_10. 接続ブラウザ・ウィンドウで、目的の USB-Blaster™(この例では DE-SoC on localhost)をハイライトして、 [**選択**]をクリックします。



図 5-27. デバッグ・ケーブルの選択

11. デバッグ構成ウィンドウの右下にある [デバッグ(D)] ボタンをクリックします。



図 5-28. LED Blink サンプル・アプリケーションのデバッグ



\_\_ 12. Eclipse は、デバッグ パースペクティブに切り替えるかどうかを尋ねます。 [*はい (Y)*] をクリックしてそれを受け 入れてください。



図 5-29. パースペクティブスイッチの確認

Windows Defender ファイアウォールの警告が出た場合は、[アクセスを許可する(A)]をクリックします。



図 5-30. セキュリティの警告

## i Note:

ダウンロード時にエラーが発生した場合は、以下の確認を行ってください。

- (1) DS-5™ のライセンスが紐づけられているネットワーク・インターフェイス (例えば USB-Ethernet Interface アダプター) が有効になっているか確認してください。
- (2) 評価ボードの電源入切および PC の再起動で復旧しないか確認してください。評価ボードの電源を切った場合は、再度 FPGA のデータをダウンロードすることを忘れないでください。



13. ブレークポイントを設定します。

atlas\_main.c の 22 行目にブレークポイントを設定します。行数表示の左横のスペースをダブルクリックすることで設定可能です。



図 5-31. ブレークポイントの設定

- \_\_\_\_15. もう 2 回、緑色の *Continue* ボタン ▶ をクリックして(または F8 キーを押して)アプリケーションを実行します。これにより、*アプリケーション・コンソール* に **LED [0]** メッセージ が表示され、Atlas-SoC ボード上のユーザー LED ( LED [3:0] )の点灯状態が変化することを確認します。
- \_\_\_\_16. さらに ► を押すごとに LED の状態が変化することを確認してください。
- \_\_\_\_17. 接続の切断ボタン 🞇 をクリックし CPU との接続を切断します。

## 以上で 演習 3 は完了です。 お疲れ様でした。

次のページ以降にオプション演習があります。時間がある方は、こちらも実施してみてください。



## 5-4. 演習 2 で作成した Preloader による初期化 (オプション演習)

演習 3 では、前もって準備されていた Preloader を使用して HPS を初期化していました。

ここでは、「<u>演習 2: ソフトウェア演習(1) Preloader の生成</u>」で作成した Preloader にて HPS の初期化を実施します。

## 1. 演習 2 で Preloader イメージが作成されていることを確認します。

Preloader は、C:\footnote{italign} C:\footnote{italign} C:\footnote{ital

もし、生成されていない場合は、再度 演習 2 を実施してください。



図 5-32. u-boot-spl ファイルの確認

#### Note:

ここで確認した "u-boot-spl" ファイルは、Arm® Executable and Linkable Format (ELF) ファイルです。 DS-5™ の初期化スクリプトにて読み出され、ユーザー・アプリケーション実行前に実行されています。

詳細は、「SoC はじめてガイド - DS-5 によるベアメタル・アプリケーション・デバッグ」の「カスタム・ボードへの対応方法」をご参照ください。

■ 参考: SoC はじめてガイド - DS-5 によるベアメタル・アプリケーション・デバッグ



2. 演習 3 で使用した "u-boot-spl.axf" ファイルをリネームします。

C:¥lab¥soc\_lab¥cv\_soc\_lab¥workspace¥Atlas-Blinking-LED-Baremetal-GNU に "u-boot-spl.axf" ファイルがありますので、このファイルを、"\_u-boot-spl.axf" 等にリネームします。

\_\_\_\_3. 演習 2 で作成した "u-boot-spl" をコピーします。

C:¥lab¥soc\_lab¥cv\_soc\_lab¥software¥spl\_bsp¥uboot-socfpga¥spl ディレクトリーの下にある、"u-boot-spl" ファイルを、C:¥lab¥soc\_lab¥cv\_soc\_lab¥workspace¥Atlas-Blinking-LED-Baremetal-GNU ディレクトリーにコピーします。

\_\_\_\_4. コピーした "u-boot-spl" ファイルを "u-boot-spl.axf" という名前にリネームします。

ここまでの作業で、デバッグ時に使用する Preloader が変更されました。

実際に、動作するか確認していきます。

\_\_\_5.LED Blink サンプル・アプリケーションを再度実行します。

73 ページの "\_\_\_\_6.「実行」メニュー ⇒「デバッグの構成」を選択します。サンプル・プロジェクトには、Atlas-SoC ボード上で実行するための事前設定を付属しています。" から実行してください。

## i Note:

演習 2 で作成した Preloader はセミホスティング機能が有効となっているので、先程のデバッグ実行時と 異なり、DS-5™ の アプリケーション・コンソール(App Console)ウィンドウに Preloader のログが表示され ることが確認できるはずです。

U-Boot SPL 2013.01.01 (Jan 16 2020 - 17:59:35)

 ${\tt BOARD}$  : Altera  ${\tt SOCFPGA}$  Cyclone V  ${\tt Board}$ 

CLOCK: EOSC1 clock 25000 KHz

CLOCK: EOSC2 clock 25000 KHz

CLOCK: F2S\_SDR\_REF clock 0 KHz

CLOCK: F2S\_PER\_REF clock 0 KHz

CLOCK: MPU clock 925 MHz

CLOCK: DDR clock 400 MHz

CLOCK: UART clock 100000 KHz

CLOCK: MMC clock 50000 KHz

CLOCK: QSPI clock 3613 KHz

RESET: COLD

SDRAM: Initializing MMR registers

SDRAM: Calibrating PHY

SEQ.C: Preparing to start memory calibration

SEQ.C: CALIBRATION PASSED

SDRAM: 1024 MiB



## 5-5. システム・ヘッダーファイルによるアドレスの解決(オプション演習)

演習 3 の LED Blink サンプル・アプリケーションでは、ソースコード上で、LED PIO のアドレスを直接指定していました。

```
② atlas_main.c ⋈
2  * Copyright Altera 2013
7
8 #include <stdio.h>
9 #include "socal.h"
10
11 #define LED_BASE_ADDR (0xFF210040)
12
13 int main(int argc, char** argv)
14 {
15 int i;
```

図 5-33. 今までのアドレス指定方法

ここでは、SoC EDS のシステム・ヘッダーファイル生成コマンド(sopc-create-header-files)を使用してシステム・ヘッダーファイルを生成し使用してみましょう。

- \_\_\_\_1. Embedded Command Shell が起動していない場合は起動します。
- \_\_\_2. C:¥lab¥soc\_lab¥cv\_soc\_lab に移動します。

```
$ cd "C:¥lab¥soc_lab¥cv_soc_lab" ↓
```

図 5-34. ディレクトリーの移動



\_\_\_\_\_3. <mark>Embedded Command Shell</mark> 上で、システム・ヘッダーファイル生成コマンド(sopc-create-header-files)を実行しま す。

\$ sopc-create-header-files soc\_system.sopcinfo



図 5-35. システム・ヘッダーファイル生成コマンドの実行

## 5 つのファイルが生成されたことを確認します。

soc system.h : Platform Designer 内のすべてのマスターに対するモジュール情報を定義

hps O.h : HPS の各ブリッジ (H2F, LWH2F) に接続されているモジュール情報を定義

hps\_0\_bridges.h : HPS の各ブリッジ(F2H, H2F, LWH2F)に接続されているモジュール情報を定義

hps\_0\_arm\_a9\_0.h: hps\_0\_arm\_a9\_0 向けのモジュール情報を定義。各ブリッジのオフセットも付加されている

hps\_0\_arm\_a9\_1.h: hps\_0\_arm\_a9\_1 向けのモジュール情報を定義。各ブリッジのオフセットも付加されている

ここでは、hps\_0\_arm\_a9\_0.h を使用します。



4. システム・ヘッダーファイルを LED Blink サンプル・アプリケーション・プロジェクトにコピーします。

ファイル名: hps\_0\_arm\_a9\_0.h

コピー元: C:¥lab¥soc\_lab¥cv\_soc\_lab

コピー先: C:¥lab¥soc\_lab¥cv\_soc\_lab¥workspace¥Atlas-Blinking-LED-Baremetal-GNU

\_\_\_\_5. LED Blink サンプル・アプリケーションのソースコード atlas\_main.c を変更します。

変更時に「書き込み可能にしますか?」というポップアップが表示される場合は「はい」を選択します。

## 記述追加:

#include "hps\_0\_arm\_a9\_0.h"

## 記述変更:

<変更前> #define LED\_BASE\_ADDR (0xFF210040)

<変更後> #define LED\_BASE\_ADDR LED\_PIO\_BASE

以下の図では、比較しやすいように以前の LED\_BASE\_ADDR 記述をコメントアウトしてあります。

参考までに、"hps 0 arm a9 0.h" の該当箇所も図示します。

```
    *atlas_main.c 
    □

  2⊕ * Copyright Altera 2013
8 #include <stdio.h>
9 #include "socal.h"

10 #include "hps_0_arm_a9_0.h"
 11
      *#define LED_BASE_ADDR (0xFF210040)*/
 13 #define LED BASE ADDR LED PIO BASE
 14
 15 int main(int argc, char** argv)
 16 {
         printf("Hello from Atlas. \n");
         while(1)
 21
 22
 23
              for(i=0; i < 16; i++){
                   alt_write_word(LED_BASE_ADDR,i);
 24
 25
                   printf("LED [%x] \n",i);
 26
 27
         }
 28
 29
         return 0;
 30 }
```

```
729/
      * Macros for device 'led_pio', class 'altera_avalon_pio'
* The macros are prefixed with 'LED_PIO_'.
  73
  74
       * The prefix is the slave descriptor
  75
  76
77 #define LED_PIO_COMPONENT_TYPE altera_avalon_pio
78 #define LED_PIO_COMPONENT_NAME led_pio
79 #define LED_PIO_BASE 0xff210040
  80 #define LED_PIO_SPAN 32
  81 #define LED_PIO_END 0xff21005f
  82 #define LED PIO BIT CLEARING EDGE REGISTER 0
  83 #define LED_PIO_BIT_MODIFYING_OUTPUT_REGISTER 1
  84 #define LED_PIO_CAPTURE 0
  85 #define LED_PIO_DATA_WIDTH 8
  86 #define LED_PIO_DO_TEST_BENCH_WIRING 0
  87 #define LED_PIO_DRIVEN_SIM_VALUE 0
  88 #define LED_PIO_EDGE_TYPE NONE
  89 #define LED_PIO_FREQ 50000000
  90 #define LED_PIO_HAS_IN 1
  91 #define LED_PIO_HAS_OUT 1
  92 #define LED_PIO_HAS_TRI 0
  93 #define LED_PIO_IRQ_TYPE NONE
  94 #define LED_PIO_RESET_VALUE 0
  95
```

図 5-36. ソースコードの変更箇所とシステム・ヘッダーファイルの該当箇所

- 6. 変更した atlas main.c をセーブして、LED Blink サンプル・アプリケーションをビルドします。
- 7. ビルド後、LED Blink サンプル・アプリケーションを実行し、演習 3 と同様の結果となることを確認します。

## 以上で 演習 3 (オプション) は完了です。



## 6. 演習 4: Linux アプリケーション演習 (オプション演習)

この演習では DS-5™ 上から Linux のアプリケーションのひとつとして用意されている Hello World を実行、 デバッグします。

## ■ Note:

この演習では、弊社がお貸し出しする「SoC FPGA Seminar in a Box」をご利用のお客様は、同梱されている microSD カードを使用します。

この microSD カードには Linux OS を起動するためのデザインが入っています。

SoC FPGA Seminar in a Box 以外でこの演習を実行されるお客様は、以下の「6-1. microSD カードの準備」の手順により、ご自身で microSD カードをご用意ください。

#### 6-1. microSD カードの準備

SoC FPGA Seminar in a Box に同梱されている microSD カードを使用する場合は、このセクションはとばして次の 「6-2. Linux 起動とログイン」に進んでください。 ご自身で microSD カードを書き込む場合は以下の手順で行ってください。

- \_\_\_\_1. 下記のサイトから使用するボード向けの SD カード・イメージファイルをダウンロードします。 ダウンロードしたファイルは任意のフォルダーに解凍しておきます。解凍したフォルダー内に .img イメージファ イルがあることを確認します。
  - Atlas-SoC ボード向け SD カード・イメージファイル
  - DE10-Nano ボード向け SD カード・イメージファイル
- \_\_\_\_2. Windows をご使用の場合、SD カード・イメージファイルの書き込みには汎用のソフトウェアを利用します。 ここでは Win32DiskImager を紹介します。以下よりダウンロード可能です。
  - Win32DiskImager
- \_\_\_\_3. microSD カード(8GB 以上を推奨)を PC の SD カードスロットに挿入します(または USB カードリーダー/ ライターを使用します)。microSD カードに割り当てられたドライブ(この例では、ドライブ E)を確認します。



図 6-1. microSD カードに割り当てられたドライブの確認



- 4. あらかじめ PC にインストールしておいた Win32DiskImager を起動します。
  - ① Device として PC に挿入した microSD カードのドライブが選択されていることを確認します。
  - ② 先ほど解凍した SD カード・イメージファイルを選択して開きます。
  - ③ [Write] ボタンをクリックして イメージファイルを書き込みます。
  - ④ 書き込みが完了したら [OK] ボタンをクリックします。
  - ⑤ [Exit] ボタンをクリックして Win32DiskImager を終了します。





図 6-2. Win32DiskImager

5. PC から microSD カードを安全に取り外します。

## ↑ 注記:

ホスト PC の OS が Windows® 10 の場合、SD カードの書き込みの際に、カード内に FAT 以外のパーティション(ボリューム)が存在している場合は、以下の現象が発生することがあります。

- カード挿入時に警告ウィンドウが表示される
- SD カードイメージの書き込みに失敗する

これらの現象への対処方法については、以下の参考情報サイトの記事をご参照ください。

## ■ 参考:

アルティマ技術サポート「Windows® 10 で SD カードイメージの書き込みに失敗する場合の対処法」



## 6-2. Linux 起動とログイン

この演習では、以下のインターフェイスを使用します。

DE10-Nano ボードも基本的には同じです。



図 6-3. 本演習で使用するインターフェイス

- \_\_\_\_1. ボードの 5V DC ジャック (J14) に電源アダプターが接続されている場合は、一旦ケーブルを抜きます。
- \_\_\_\_\_2. ボードの UART USB コネクター(J4)へ USB Mini-B ケーブルを接続します。ケーブルの反対側のコネクターを PC の USB コネクターへ接続します。
- \_\_\_\_3. ボードの HPS Ethernet コネクター(J10)へ、イーサーネット・ケーブルを接続します。ケーブルの反対側のコネクターを PC のイーサーネット・コネクターへ接続します。
- 4. ボード裏側の microSD カードスロット(J11)に microSD カードを挿入します。
- \_\_\_\_\_5. 電源アダプターケーブルをボードの 5V DC ジャック (J14) に接続し、ボードに電源を投入します。



\_\_\_\_6. Windows の「*デバイス マネージャー*」を開きます。 *デバイスマネージャー* の「*ポート*(COM と LPT)」を展開してボードの UART が何番の COM ポートに接続されているかを確認します(この例では COM4)。 確認できたら *デバイスマネージャー* を閉じます。



図 6-4. COM ポートの確認

\_\_\_\_\_7. あらかじめインストールしておいた<mark>ターミナルソフト</mark>を起動して、シリアルポートの設定を行います。 先ほど確認 した COM ポートを選択して下図のように設定します(この例では COM4)。



図 6-5. シリアルポートの設定

\_\_\_\_8. ボードの WARM リセットボタン (KEY3) を押します。ターミナルに起動メッセージが表示されます。



図 6-6. WARM リセットボタン (KEY3)

\_\_\_\_\_9. Linux カーネルが起動したら、root 🏻 でログインします。



図 6-7. root でログイン



6-3. Linux での IP アドレスとパスワードの設定

- \_\_\_\_1. <mark>ターミナル</mark>から ifconfig コマンドで、ボードの IP アドレスを設定します (この例では 192.168.1.30 を設定しています)。
  - # ifconfig eth0 192.168.1.30 ↓
- \_\_\_\_2. その後 ifconfig コマンドで設定内容を確認します。
  - # ifconfig eth0 🗸
- \_\_\_\_3. passwd コマンドで任意のパスワードを設定します。このパスワードは後でリモート・システムによるデバッグで 使用します。
  - # passwd ↓
- 4. 再度パスワードを入力します。

図 6-8. IP アドレスとパスワードの設定



## 6-4. ホスト PC 側のネットワーク設定

DS-5™ での リモート・システム・エクスプローラー(RSE)を使用した Linux アプリの実行・デバッグを行う上で、ホスト PC 側のネットワーク設定を行います。

\_\_\_\_1. まずホスト PC 側の IP アドレスを設定します。「*コントロール パネル*」から「*ネットワークと共有センター*」を クリックし、左側の「*アダプターの設定の変更*」をクリックします。



図 6-9. アダプターの設定の変更

2. 「イーサネット」をダブルクリックします。



図 6-10. 「イーサネット」をダブルクリック



- 3. [プロパティ] ボタンをクリックします。
- 4. 「*インターネット プロトコル バージョン 4*(TCP/IPv4)」をダブルクリックします。





図 6-11. ローカル エリア接続のプロパティ

\_\_\_\_5. 「次の IP アドレスを使う (s):」にチェックを入れて「IP アドレス」と「サブネット マスク」を設定します(この例では、IP アドレスを 192.168.1.31、サブネット マスクを 255.255.255.0 に設定しています)。

設定後、[OK] をクリックします。



図 6-12.「IP アドレス」と「サブネット マスク」の設定



\_\_\_\_6. ネットワークの接続を確認します。 ボードの Linux からホスト PC に対して ping を実行して接続を確認してみます(この例では、PC の IP アドレスを 192.168.1.31 に設定しています)。

# ping 192.168.1.31 ↓

\_\_\_\_\_7. Ctrl + C をキー入力して ping を停止します。

```
root@cyclone5:~# ping 192.168.1.31

PING 192.168.1.31 (192.168.1.31): 56 data bytes
64 bytes from 192.168.1.31: seq=0 ttl=128 time=0.655 ms
64 bytes from 192.168.1.31: seq=1 ttl=128 time=1.026 ms
64 bytes from 192.168.1.31: seq=2 ttl=128 time=0.953 ms
64 bytes from 192.168.1.31: seq=3 ttl=128 time=0.920 ms
^C
--- 192.168.1.31 ping statistics ---
4 packets transmitted, 4 packets received, 0% packet loss
round-trip min/avs/max = 0.655/0.888/1.026 ms
root@cyclone5:~#
```

図 6-13. PC に対して ping を実行して接続を確認

\_\_\_\_\_8. もし ping 応答が無い場合は Windows Defender ファイアウォール設定を確認します。 「*パブリックネットワークの設定*」を確認し、Windows Defender ファイアウォールが "**有効**" に設定されている場合は **"無効**" に設定して、再度 ping を実行して接続を確認してください。



図 6-14. Windows ファイアウォール設定



6-5. DS-5™ の起動と Linux サンプル・アプリケーションのインポートおよびビルド

\_\_\_1. Windows® のスタートメニューまたは、SoC EDS のインストール・フォルダー (intelFPGA¥<バージョン
>¥embedded) に格納されている起動用スクリプト *Embedded\_Command\_Shell.bat* をダブルクリックして、
Embedded Command Shell を起動します。



図 6-15. Embedded Command Shell を起動

\_2. Embedded Command Shell から eclipse と入力して DS-5™ を起動します。

## \$ eclipse ←



図 6-16. Embedded Command Shell から eclipse と入力



3. Eclipse ツールを使用するワークスペース・フォルダーを設定します。

この演習では、「<u>3. 演習 1: ハードウェア演習</u>」の作業フォルダーに workspace を作成します。 以下のパスを指定して [*OK*] をクリックします(フォルダーが存在しない場合は自動的に作成されます)。

C:\flab\frac{1}{ab\frac{1}{ab}}cv\_soc\_lab\frac{1}{ab}workspace



図 6-17. workspace の作成

4. DS-5™ の Welcome 画面が表示された場合は、[**閉じる**] (×マーク) をクリックして閉じます。



図 6-18. DS-5™ の Welcome 画面



- 5. DS-5™ のメニューから「*ファイル*」⇒「*インポート*」を選択します。
- \_\_\_\_6. 「一般」⇒「既存プロジェクトをワークスペースへ」を選択し [次へ (N)] をクリックします。



図 6-19.「ファイル」⇒「インポート」



\_\_\_\_7. 「*アーカイブ・ファイルの選択*(A):」オプションを選択し、[*参照* (R)] ボタンよりサンプル・プロジェクトを指定し ます。

サンプル・プロジェクトは SoC EDS に含まれており、デフォルトでは以下のインストール・フォルダーにあります。

C:\(\)intelFPGA\(\)18.1\(\)\(\)\(\)embedded\(\)\(\)\(\)examples\(\)\(\)software\(\)\(\)Alternative Altera-SoCFPGA-HelloWorld-Linux-GNU.tar.gz

(〈SoC EDS インストール・ディレクトリー〉¥examples¥software¥Altera-SoCFPGA-HelloWorld-Linux-GNU.tar.gz をインポートしています)。

選択後、[終了 (F)] ボタンをクリックします。



図 6-20. サンプル・プロジェクトのインポート



\_\_\_\_8. Eclipse 左側のプロジェクト・エクスプローラーに Altera-SoCFPGA-HelloWorld-Linux-GNU プロジェクトが追加され、Altera-SoCFPGA-HelloWorld-Linux-GNU をクリックして展開するとプロジェクトに含まれる各種ファイルが表示されます。



図 6-21. 追加された Altera-SoCFPGA-HelloWorld-Linux-GNU プロジェクト

9. Altera-SoCFPGA-HelloWorld-Linux-GNU アプリケーションをビルドします。

プロジェクト・エクスプローラーより Altera-SoCFPGA-HelloWorld-Linux-GNU プロジェクトをハイライトし、「*プロジェクト*」⇒「*プロジェクトのビルド*」を選択します。または、プロジェクト・エクスプローラー上でプロジェクトを選択し、**右クリック** ⇒「*プロジェクトのビルド*」を実行します。

プロジェクト・エクスプローラーに新たに生成された hello 実行可能ファイルが出力されます。



図 6-22. プロジェクトのビルド



## 6-6. リモート・システム・エクスプローラー (RSE) の設定

DS-5™ では、リモート・システム・エクスプローラー (RSE) を使用する事で、Linux アプリケーション・プログラムをターゲット上で実行・デバッグすることが可能です。

1. 「ウィンドウ」メニュー ⇒「Perspective」⇒「パースペクティブを開く」⇒「その他」を選択します。



図 6-23. 「パースペクティブを開く」⇒「その他」を選択

\_\_\_\_2. 「*リモート・システム・エクスプローラ*ー」を選択して[**OK**]をクリックします。



図 6-24.「リモート・システム・エクスプローラー」の選択



\_\_\_\_3. リモート・システム・エクスプローラーのビューで 🔐 ボタンまたは、空白部分を右クリックして「*新規接続*」を 選択します。



図 6-25.「リモート・システム・エクスプローラー」での新規接続

\_\_\_\_4.リモート・システム・タイプの選択のビューで「*SSH のみ*」を選択し [*次へ (*N)] をクリックします。



図 6-26. 「SSH のみ」を選択

\_\_\_\_5. 「*ホスト名:*」の欄には設定しておいたボードの IP アドレス(この例では 192.168.1.30)を入力し、「*接続名:*」と「*記述/説明:*」には "Atlas SoC" または "DE10 Nano" と入力し「*ホスト名を検証*」にチェックを入れて [終了 (F)] ボタンをクリックします。



図 6-27. 接続設定



- \_\_\_\_6. リモート・システム・エクスプローラーのビューで、「*Atlas SoC*」(または「*DE10 Nano*」)⇒「*Sftp ファイル*」⇒ 「*ルート*」をクリックすると、ユーザー ID とパスワードを入力するウィンドウが表示されます。
- \_\_\_\_\_7. 「*ユーザー ID:*」には "root"、「*Password*」には設定したパスワードを入力して [*OK*] をクリックします。



図 6-28. ユーザー ID とパスワードを入力

8. 下図の警告が出た場合は [*はい*] をクリックします。



図 6-29. 警告表示



9. 接続が成功すると、リモート・システム・エクスプローラーに現在のボード上のファイル群が表示されます。



図 6-30. リモート・システム・エクスプローラーに現在のボード上のファイル群が表示

- \_\_\_\_10. エラーが出て接続できない場合は、ホスト PC のプロキシ設定の問題が考えられます。この場合は「*コントロール パネル*」⇒「*インターネット オプション*」をクリックし、「*接続*」タブの「*LAN の設定*」をクリックします。



図 6-31. プロキシサーバーの設定

12. 再度 Atlas SoC(または DE10 Nano)のルートへの接続を試みてください。



## 6-7. Linux アプリケーションの実行・デバッグ

ここからは、デバッガ設定方法と実行・デバッグ方法について確認します。

- \_\_\_\_1. メニューバーの「*C/C++ パースペクティブ*」ボタン 🛅 をクリックして C/C++ パースペクティブに戻ります。
- \_\_\_\_2. プロジェクト・エクスプローラー・タブより *Altera-SoCFPGA-HelloWorld-Linux-GNU を右クリックして 「<i>デバッグ*」⇒「*デバッグの構成*」を選択します。



図 6-32.「デバッグ」⇒「デバッグの構成」を選択

3. 「*DS-5 デバッガ*」を**右クリック**し「*新規*」を選択して、新しいデバッグ・コンフィグレーションを作成します。



図 6-33. 新しいデバッグ・コンフィグレーションを作成



- 4. 「*名前*」フィールドに"HelloWorld"と入力します。
- \_\_\_\_\_5. 「接続」タブの「*ターゲットの選択*」フィールドにおいて、 *Altera ⇒ Cyclone V SoC (Dual Core) ⇒ Linux Application Debug ⇒ Download and debug application を*選択します。
- \_\_\_\_\_6. 「*接続*」フィールドでは、生成した RSE 接続(この例では **Atlas SoC**)を選択し、その他はデフォルト値を使用します。



図 6-34. デバッグ構成の設定(1)



\_\_\_\_7. 「*ファイル*」タブの「*ダウンロードするホスト上のアプリケーション:*」に Hello World の実行体を設定します。 「*ワークスペース*」ボタンを使用して hello を選択し [*OK*] をクリックします。



図 6-35. デバッグ構成の設定(2)

\_8. 「*ターゲットダウンロードディレクトリ:*」と「*ターゲット作業ディレクトリ:*」には "/home/root" を設定します。



図 6-36. デバッグ構成の設定(3)

\_\_\_\_9. 「*デバッガ*」タブで、実行制御フィールドは「*シンボルからデバッグします*」を選択し、シンボル名に "main" と 入力します。



図 6-37. デバッグ構成の設定(4)



- \_\_\_\_\_10. [*デバッグ*] ボタン デバッグ(D) をクリックしてデバッグセッションを開始します。
  - 11. デバッグ パースペクティブへの切り替えのプロンプトが表示されたら「*はい*」を選択します。



図 6-38. パースペクティブ切り替えのプロンプト

12. アプリケーションは、ロードされてから main 関数でブレークします。

```
le hello.c Si
2 * Copyright (c) 2013, Altera Corporation <www.altera.com>
27
28 #include <stdio.h>
29

*30 int main(int argc, char** argv) {
31     printf("Hello SoC FPGA!\n");
32     return 0;
33 }
34
```

図 6-39. main 関数でブレーク

\_\_\_\_13. ソースコードの左余白をダブルクリックすると、赤い点 🧿 で示すようにデバッガがそこにブレークポイントを設定します。

```
29
*30 int main(int argc, char** argv) {

*31 printf("Hello SoC FPGA!\n");

32 return 0;

33 }

34
```

図 6-40. ブレークポイントの設定

\_\_\_\_14. [*続行*] ボタン 🕟 を押すと、アプリケーションが実行されてブレークポイントで停止します。

図 6-41. ブレークポイントで停止

\_\_\_\_15. ソースコードの左余白に赤い点 © で示されたブレークポイントをダブルクリックすると、ブレークポイント設定が 解除されます。



- \_\_\_16. [**ソース行のステップ実行**]ボタン 👧 (または F5)を押すと、実行コードが 1 ライン進みます。
- \_\_\_\_17. 「*レジスタ*」ビューは、ターゲット・レジスタの内容を表示します。また、書き込み可能なレジスタの値を変更できます。

| レジスター セッ        | -: すべてのレジス! | ター   |      |
|-----------------|-------------|------|------|
| 名前              | 値           | サイス。 | アクセス |
| P 🗁 Core        | 17/17 レジスタ  |      |      |
| - ● R0          | 0x00000010  | 32   | R/W  |
| - ● R1          | 0x00000000  | 32   | R/W  |
| • R2            | 0x00000001  | 32   | R/W  |
| - ● R3          | 0x000083CD  | 32   | R/W  |
| - ● R4          | 0xBEFFFBB8  | 32   | R/W  |
| - ● R5          | 0x00000000  | 32   | R/W  |
| - ● R6          | 0x00000000  | 32   | R/W  |
| - ● R7          | 0xBEFFFB98  | 32   | R/W  |
| - ● R8          | 0x00000000  | 32   | R/W  |
| - ● R9          | 0×00000000  | 32   | R/W  |
| • R10           | 0xB6FFEFA4  | 32   | R/W  |
| - ● R11         | 0x00000000  | 32   | R/W  |
| ● R12           | 0x00000004  | 32   | R/W  |
| - o SP          | 0xBEFFFB98  | 32   | R/W  |
| - • LR          | 0xB6F6F363  | 32   | R/W  |
| - ● PC          | 0x000083E2  | 32   | R/W  |
| ● ● CPSR        | 0x600F0030  | 32   | R/W  |
| <b>⊕</b>        | 65/65 レジスタ  |      |      |
| <b>B</b> ⊜ SIMD | 16/16 レジスタ  |      |      |

図 6-42.「レジスタ」ビュー

\_\_\_\_18. 「**変数**」ビューは、現在有効範囲にある変数の内容を表示します。また、現在有効範囲にある変数の値を変更できます。



図 6-43.「変数」ビュー

- \_\_\_\_19. 「*App Console*」(アプリケーション・コンソール)ビューは、Arm C ライブラリーでのセミホスティングの実装によって提供されるコンソール I/O 機能を使用できます。アプリケーション内の print 文の内容が表示されます。
  - \_\_\_\_ 20. [*続行*]ボタン ▶ を押すと、アプリケーションが続行され Hello SoC FPGA! と表示されます。



図 6-44.「App Console」(アプリケーション・コンソール)ビュー



| 21. | [ <i>エントリポイントからデバッグ</i> ] ボタン <mark>⇔</mark> をクリックすると、アプリケーションの先頭 main に戻ってブレークします。                            |
|-----|----------------------------------------------------------------------------------------------------------------|
| 22. | 再度 [ <i>続行</i> ] ボタン <b>&gt;</b> を押すと、アプリケーションが先頭から実行され、「 <i>App Console</i> 」ビューに<br>Hello SoC FPGA! と表示されます。 |
| 23. | [ <b>ターゲットから切断</b> ] ボタン 🔯 をクリックしてデバッグセッションを終了します。                                                             |
| 24. | [ <b>すべての接続の削除</b> ] ボタン 🍇 をクリックしてデバッグセッションを削除します。                                                             |
| 25. | メニューバーの [ <i>C/C++ パースペクティブ</i> ] ボタン ቬ をクリックすると C/C++ パースペクティブに戻ります。                                          |

おめでとうございます。これで全ての演習が完了しました。



## 7. 今後の参考資料について

本演習ではインテル® SoC FPGA の開発環境であるインテル® Quartus® Prime 開発ソフトウェアやシステム構成 ツールである Platform Designer システム統合ツール、およびソフトウェア開発環境である SoC EDS の基本的な 操作を学ぶことを中心に紹介しました。今後さらなる知識向上につなげたい場合はさまざまな情報源があります のでこちらをご利用ください。

また同様の内容として「SoC はじめてガイド」をご参照いただくと、さらに理解が深まると思いますのでご利用ください。

## ■ 参考:

● SoC はじめてガイド

インテル の SoC FPGA

SoC はじめてガイド - HPS-FPGA 間のアクセス方法

SoC はじめてガイド - Preloader Generator の使用方法

SoC はじめてガイド - DS-5 によるベアメタル・アプリケーション・デバッグ

● SoC 関連情報

マクニカ・ホームページ技術情報: SoC 関連記事/ドキュメント

マクニカ・ホームページ技術情報: SoC 関連 FAQ

アルティマ技術サポート: SoC 関連記事/ドキュメント

アルティマ技術サポート: SoC 関連 FAQ

デバイスやツールについての説明

Intel FPGA and SoC

● SoC デバイスで Linux を使用する上で参考となる各種ドキュメントやプロジェクト RocketBoards.org

● 代理店からの各種情報サイト

マクニカ・ホームページ技術情報

アルティマ技術サポート



# <u>改版履</u>歴

| Revision | 年月      | 概要                                                                                                  |
|----------|---------|-----------------------------------------------------------------------------------------------------|
| 1        | 2020年1月 | 初版                                                                                                  |
| 2        | 2020年6月 | (5ページ)                                                                                              |
|          |         | 「インテル® SoC Embedded Development Suite」を「インテル® SoC FPGA<br>エンベデッド開発スイート」に変更                          |
|          |         | (6 ページ)                                                                                             |
|          |         | ・「Quartus® Prime Standard Edition v18.1」を「インテル® Quartus® Prime<br>Standard Edition v18.1」に変更        |
|          |         | ・「SoC Embedded Development Suite v18.1」を「インテル® SoC FPGA エ<br>ンベデッド開発スイート Standard Edition v18.1」に変更 |

## 免責およびご利用上の注意

弊社より資料を入手されましたお客様におかれましては、下記の使用上の注意を一読いただいた上でご使用ください。

- 1. 本資料は非売品です。許可無く転売することや無断複製することを禁じます。
- 2. 本資料は予告なく変更することがあります。
- 3. 本資料の作成には万全を期していますが、万一ご不明な点や誤り、記載漏れなどお気づきの点がありましたら、本資料を入手されました下記代理店までご一報いただければ幸いです。 株式会社マクニカ 半導体事業 お問い合わせフォーム
- 4. 本資料で取り扱っている回路、技術、プログラムに関して運用した結果の影響については、責任を負いかねますのであらかじめご了承ください。
- 5. 本資料は製品を利用する際の補助的な資料です。製品をご使用になる際は、各メーカ発行の英語版の資料もあわせてご利用ください。