

### ALTERA SoC 向け HWLib 構成とサンプルコードについて v15.0

2015年7月 Rev.1

### HWLib の構成(API が用意される機能)



| MPU Subsystem           | Timers            | Cache/MMU Mgmt | Serial Interface          |  |
|-------------------------|-------------------|----------------|---------------------------|--|
| Memory Map Cntl         | Watchdog          | MMU Mgmt       | UART                      |  |
| Address Filters         | General Purpose   | Cache Mgmt     | SPI                       |  |
| Mem Coherence           |                   |                | I2C                       |  |
| Interrupt Ctrl          | Bridge Management | Flash Memory   |                           |  |
| Interrupt Ctrl          | FPGA2HPS          | QSPI           | SDRAM Ctrl                |  |
| FPGA Manager            | HPS2FPGA          | NAND           | Memory Tests              |  |
| Full Configuration      | LWHPS2FPGA        | SD/MMC         | Pin I/O Cnf Mgmt          |  |
| System Manager          | Clock Manager     | Parity Mgmt    | GPIO                      |  |
| DMA                     | Reset Manager     | ECC Mgmt       |                           |  |
| SoCAL Layer (non ARM IF | P)                | 各構成要素の対応時期(S   | 各構成要素の対応時期(SoC EDS バージョン) |  |
|                         |                   | ver15.0        |                           |  |
|                         |                   | 将来             | のバージョンでサポート               |  |

詳細は、SoC EDS 付属のドキュメントを参照ください。

- HWMgr (HWLib API): <SoC EDS installation directory>/ip/altera/hps/altera\_hps/doc/hwmgr/html/index.html.
- SoCAL: <SoC EDS installation directory>/ip/altera/hps/altera\_hps/doc/socal/html/index.html

### HWLib API のカバー範囲





### SoC EDS 付属のサンプル (ベアメタル)



- ▶ Hello World のサンプル
  - Altera-SoCFPGA-HelloWorld-Baremetal-ARMCC.tar.gz
  - Altera-SoCFPGA-HelloWorld-Baremetal-GNU.tar.gz
- ▶ UART を初期化しターミナルとして動作させるサンプル
  - Altera-SoCFPGA-HardwareLib-16550-CV-ARMCC.tar.gz
  - ◆ Altera-SoCFPGA-HardwareLib-16550-CV-GNU.tar.gz
  - ◆ 関連 API:
    - UART / Interrupt / etc
- ▶ FPGA のコンフィギュレーション、HPS-FPGA 間のブリッジのマネジメント等を実行するサンプル
  - Altera-SoCFPGA-HardwareLib-FPGA-CV-ARMCC.tar.gz
  - ◆ Altera-SoCFPGA-HardwareLib-FPGA-CV-GNU.tar.gz
  - ◆ 関連 API:
    - DMA / AXI Bridge / etc

### SoC EDS 付属のサンプル (ベアメタル)



- ▶ L2 ECC のサンプル
  - ◆ Altera-SoCFPGA-HardwareLib-ECCL2-CV-ARMCC.tar.gz
  - Altera-SoCFPGA-HardwareLib-ECCL2-CV-GNU.tar.gz
- ▶ MPL のサンプル
  - Altera-SoCFPGA-HardwareLib-MPL-CV-ARMCC.tar.gz
- ▶ SPI のサンプル
  - Altera-SoCFPGA-HardwareLib-SPI-RW-CV-ARMCC.tar.gz
  - Altera-SoCFPGA-HardwareLib-SPI-RW-CV-GNU.tar.gz
- ▶ Timer のサンプル
  - Altera-SoCFPGA-HardwareLib-Timer-CV-ARMCC.tar.gz
  - Altera-SoCFPGA-HardwareLib-Timer-CV-GNU.tar.gz

### SoC EDS 付属のサンプル (ベアメタル)



- ► SoC EDS 付属のサンプル以外に、アルテラサイト内の「SoC Design Examples」にも多数のサンプルが公開されています。 (Altera Home > Support > Support Resources > Design Examples)
  - https://www.altera.com/support/support-resources/designexamples.html#socdesignexamples
  - ◆ 参考:2015年7月時点の公開サンプル
    - HPS DMA
    - Error correction code
    - GPIO
    - **I**2C
    - Quad SPI
    - SD/MMC
    - Timer
    - Quad SPI Porting
    - Unhosted
    - HPS Peripheral Mapping to FPGA
    - Power Optimization NEW!

### SoC EDS 付属のサンプル ( Linux )



- ► ARM Development Studio™5 (DS-5™) 向けサンプル
  - Altera-SoCFPGA-Blinking-LED-Linux-GNU.tar.gz
  - Altera-SoCFPGA-HelloWorld-Linux-GNU.tar.gz
  - Altera-SoCFPGA-Push-Button-Linux-GNU.tar.gz
- ▶ その他、Linux 関連の情報は以下を参照
  - http://www.rocketboards.org/



## アルティマ/エルセナ が提供する HWLib サンプル集



- ► GPIO
- Global Timer
- Clock Manager
- FPGA Manager
- Watchdog Timer
- General Purpose Timer
- Cache Management
- Interrupt Controller[SGI]
- DMA Controller
- MMU
- ▶ Global Timer を使って時間計測
- ECC (On-Chip RAM)
- ► DMA x ACP NEW!

### **GPIO**



#### サンプルの概要

Helio ボードの HPS 用 DIPSW、PUSHSW を入力信号として利用可能となるように GPIO のコンフィギュレーションを行い、各 SW の操作に連動する形で デバッガのコンソール上に GPIO 入力レジスタの値の変化を表示させます。

#### サンプルで確認する HWLib API カテゴリ

- ➤ The General Purpose Input/Output Manager API
  - General-Purpose IO Configuration Functions
  - General-Purpose IO Interrupt Functions
  - General-Purpose IO via Bit Index
  - General-Purpose IO Utility Functions

### アーカイブ名 (注1)

SoCFPGA-HWLib-Sample\_GPIO.tar.gz

注1:実際のアーカイブ名の終端にはバージョン識別用の文字列(例:"\_150\_r01")を付けています。 別のサンプルも同様です。

### **Global Timer**



#### サンプルの概要

Global Timer を動作させ以下の機能の動作を確認します。

- Prescaler の設定に応じて Timer カウンタの周期が変わる事。
- Comparation モードが有効な場合に以下の機能が動作する事。
  - Auto Increment 機能 (Comparation 結果が一致する毎に自動加算される)
  - Global Timer からの割り込み発生(Comparation 結果が一致する付近で発生)

### サンプルで確認する HWLib API カテゴリ

➤ The Global Timer Manager API

#### アーカイブ名

SoCFPGA-HWLib-Sample\_GlobalTimer.tar.gz

### **Clock Manager**



#### サンプルの概要

3種の PLL (Main PLL, Peripheral PLL, SDRAM PLL) のコンフィギュレーション情報を取得・表示します。また、Clock Manager から発生する割り込み(3種の PLL の Lock/Unlock ) の発生契機でコンソール表示を行うように対応しています。他、HPS 用 DIPSW / PUSHSW 契機で、特定の API を試行できるよう実装しています。(HPS の Main クロック周波数を変更する処理も確認できます。)

### サンプルで確認する HWLib API カテゴリ

- > The Clock Manager API
  - Clock Manager Status
  - Safe Mode Options
  - PLL Bypass Control
  - Clock Gating Control
  - Clock Source Selection
  - Clock Frequency Control
  - Clock Manager Interrupt Management
  - Clock Group Configuration

#### アーカイブ名

SoCFPGA-HWLib-Sample\_ClockManager.tar.gz

### **FPGA** Manager



### サンプルの概要

Altera SoC EDS 付属のサンプル「Altera-SoCFPGA-HardwareLib-FPGA-CV-GNU.tar.gz」をベースに、付属サンプルでは使用していない HWLib API を追加実装した環境です。

サンプルを実行すると、各種 API が実行され結果が DS-5 のコンソールへ表示されます。 また、FPGA コンフィギュレーション処理を含めて各処理に要した処理時間も表示します。

Makefile内の定義 USE\_DMA を変更することで、FPGA コンフィギュレーション処理での DMA 利用有無が選択可能です。( USE\_DMA=0: DMA未使用 / 1: DMA使用)

#### サンプルで確認する HWLib API カテゴリ

- > The FPGA Manager
  - FPGA Manager Status and Control
  - FPGA Configuration
  - FPGA Manager Interrupt Control
  - SoC to FPGA General Purpose I/O Signals

#### アーカイブ名

Altera-SoCFPGA-HardwareLib-FPGA-CV-GNU\_TimeMeas.tar.gz

### **Watchdog Timer**



#### サンプルの概要

HWLib から参照できる Watchdog Timer 関連レジスタの初期値を全て表示した上で下記の3種類の Watchdog を全て起動します。

CPU Private Watchdog Timer (ALT\_WDOG\_CPU)

L4 Watchdog 0 (ALT\_WDOG0)

L4 Watchdog 1 (ALT WDOG1)

また、Watchdogタ イムアウトを契機とする割り込み(3種類)を全て有効に設定し、発生契機でコンソール表示を行うように対応しています。

### サンプルで確認する HWLib API カテゴリ

- The Watchdog Timer Manager API
  - Watchdog Timer Enable, Disable, Restart, Status
  - Watchdog Timer Counter Configuration
  - Watchdog Timer Interrupt Management
  - Watchdog Timer Miscellaneous Configuration
- > The Reset Manager
  - Reset Status
  - Reset Control

### アーカイブ名

SoCFPGA-HWLib-Sample\_WatchDogTimer.tar.gz

### **General Purpose Timer**



### サンプルの概要

HWLib から参照できる General Purpose Timer (以下、GPT) 関連レジスタの 初期値を全て表示した上で、全ての GPT (下記の4個)を全て起動します。

- OSC1 timer 0 ... osc1 clk で動作する 32bit タイマ (動作クロック固定)
- OSC1 timer 1 ... osc1 clk で動作する 32bit タイマ (動作クロック固定)
- SP timer 0 ..... I4\_sp\_clkで動作する 32bit タイマ
- SP timer 1 ..... I4\_sp\_clkで動作する 32bit タイマ

また、各 GPT のタイムアウトを契機とする割り込み(4系統)を全て有効に設定し、発生契機でコンソール表示を行うように対応しています。

### サンプルで確認する HWLib API カテゴリ

- The General Purpose Timer Manager API
  - Enable, Disable, and Status
  - Counters Interface
  - Interrupts
  - Mode Control

#### アーカイブ名

SoCFPGA-HWLib-Sample\_GeneralPurposeTimer.tar.gz

### **Cache Management**



### サンプルの概要

当該カテゴリの全ての API を試行します。

また、Cache の効果を検証するために、要素数 8194×N(1~8) の配列を引数として memset 関数および浮動小数点(float 型)同士の乗算処理の実行時間を計測・表示させます。

#### ※注意:

本サンプルでは MMU を構成していない為、Cache 有効時の本来の性能は確認できておりません。(HWLib の API 呼び出し動作の確認用としてご利用下さい。)

### サンプルで確認する HWLib API カテゴリ

- Cache Management API
  - System Level Cache Management API
  - L1 Cache Management API
  - L2 Cache Management API

#### アーカイブ名

SoCFPGA-HWLib-Sample\_CacheManagement.tar.gz

### **Interrupt Controller [SGI]**



### サンプルの概要

本サンプルでは SGI (Software Generated Interrupt )を動かすための設定を行い、HPS 用 PUSHSW の操作を契機に SGI を発行します。

- PUSHSW1 .. SGI 発行元のコアへ割り込みを通知する。(Core#0宛)
  - → Core#0 にてSGIのコールバックが動作。
- PUSHSW2 .. SGI 発行元のコアを除く全コアへ割り込みを通知する。(Core#1宛)
  - → Core#1 を動かさないので何も反応しない。
- PUSHSW3 .. SGI 発行元のコアを含む全コアへ割り込みを通知する。(Core#0,#1宛)
  - → Core#0 のみコールバックが動作。Core#1 は無反応。

SGI のコールバック関数が動作すると、DS-5 のアプリケーション・コンソールにメッセージが表示されます。

### サンプルで確認する HWLib API カテゴリ

- Interrupt Controller Low-Level API [Secure]
  - Interrupt Controller Global Interface [Secure]
  - Interrupt Controller Distributor Interface [Secure]
  - Software Generated Interrupts [Secure]
  - Interrupt Controller CPU Interface [Secure]
  - Interrupt Service Routine [Secure]
  - Interrupt Utility Functions [Secure]

#### アーカイブ名

SoCFPGA-HWLib-Sample\_InterruptControllerSGI.tar.gz

### **DMA Controller**



### サンプルの概要

HWLib で用意される下記の API を利用して DMA 転送を試すサンプルです。

- alt\_dma\_memory\_to\_memory()
- alt\_dma\_zero\_to\_memory()
- alt\_dma\_memory\_to\_register()
- alt\_dma\_register\_to\_memory()

転送結果の確認は、デバッガを F9 でブレイクさせた上でメモリビュー上のデータを確認します。DMA 転送パラメータは、全 8CH 分をテーブルとして定義しているので、テーブル書き換える事でアドレス/サイズを変更してテストできます。

### サンプルで確認する HWLib API カテゴリ

- DMA Controller API
  - DMA API for Configuration, Control, and Status
  - DMA API for Standard Operations
- DMA Controller Programming API
- ➤ The Address Space Manager
  - Address Space Mapping Control
  - L2 Cache Address Filter
  - ACP Memory Coherence and ID Mapping

#### アーカイブ名

SoCFPGA-HWLib-Sample DMAController.tar.gz

### **MMU**



### サンプルの概要

#### 下記のメモリ配置となるように MMU を構成するサンプルです。

| [0] SDRAM PA:0x00000000~0x003FFFFF <> VA:0x00000000~0x003FFFFF (PA=VA |
|-----------------------------------------------------------------------|
|-----------------------------------------------------------------------|

- [1] SDRAM2 ...... PA:0x00800000~0x00BFFFFF <--> VA:0x00400000~0x007FFFFF (PA≠VA)
- [2] SDRAM3 ...... PA:0x02000000~0x03FFFFFF <--> VA:0x02000000~0x03FFFFFF (PA=VA)
- [3] HPS2FPGA ....... PA:0xC0000000~0xFBFFFFFF <--> VA:0xC0000000~0xFBFFFFFF (PA=VA)
- [4] LW HPS2FPGA . PA:0xFF200000~0xFF3FFFF <--> VA:0xFF200000~0xFF3FFFF (PA=VA)
- [5] PERIPHRALS .... PA:0xFF400000~0xFFEFFFFF <--> VA:0xFF400000~0xFFEFFFFF (PA=VA)
- [6] BOOTROM ....... PA:0xFFFD0000~0xFFFDFFFF <--> VA:0xFFFD0000~0xFFFDFFFF (PA=VA)
- [7] MPUSCU ........... PA:0xFFFEC000~0xFFFEDFFF <--> VA:0xFFFEC000~0xFFFEDFFF (PA=VA)
- [8] MPUL2 ..... PA:0xFFFEE000~0xFFFEEFFF <--> VA:0xFFFEE000~0xFFFEEFFF (PA=VA)
- [9] ONCHIPRAM ..... PA:0xFFFF0000~0xFFFFFFFF <--> VA:0xFFFF0000~0xFFFFFFF (PA=VA)

Running (F8)した状態で、PUSHSW / DIPSW を操作して MMU の設定を変更。 Break (F9)してメモリビューを参照することで MMU の動作を確認します。 (PUSHSW1 を契機に、Translation Table を書き換えも試行できます。)

#### サンプルで確認する HWLib API カテゴリ

- MMU Management API
  - MMU Management
  - MMU Virtual Address Space Creation

### アーカイブ名

SoCFPGA-HWLib-Sample\_MMU.tar.gz

### Global Timerを使って時間計測



### サンプルの概要

HWLib の The Global Timer Manager APIを用いて、処理時間計測の仕組みを実装したサンプルプログラム。

下記のソース/ヘッダファイルを別のプロジェクトに追加することで 同様の仕組みで処理時間を計測することができます。

- util time measurement.c
- util\_time\_measurement.h

### サンプルで確認する HWLib API カテゴリ

該当なし(Global Timer 他、各種 API は利用します)

#### アーカイブ名

SoCFPGA-HWLib-Sample\_TimeMeasurement.tar.gz

### ECC (On-Chip RAM)



#### サンプルの概要

On-Chip RAM の ECC 機能について、HWLib を利用して以下の動作を確認します。

- ECC エラーインジェクション
- ECC 割り込みの発生
- ECC エラー時の読み出しデータ(メモリチェック)
- Cache 有効/無効による ECC 動作の違い

### サンプルで確認する HWLib API カテゴリ

> Error Correcting Code ( ECC ) Management

### アーカイブ名

SoCFPGA-HWLib-Sample\_ECC\_onchipRAM.tar.gz

### **DMA x ACP**



#### サンプルの概要

HPS内臓DMA(DMA-330)を使って、メモリ to メモリのDMA転送を行うサンプルです。 本サンプルでは MMU および L1, L2 キャッシュ、ならびにACPポートを有効化した 環境下で転送を行います。

Helioボードのスイッチ操作により下記のオプションが選択可能となっています。

- Cacheメンテナンス操作のON/OFF
- ACPポート利用のON/OFF

上記のオプション選択と合わせて、キャッシュ有効の環境下におけるDMA転送動作の検証が可能となるように、DMA転送時間、転送データのベリファイ結果の表示も行います。

#### サンプルで確認する HWLib API カテゴリ

該当なし(ACPの検証を目的とする)

#### アーカイブ名

SoCFPGA-HWLib-Sample\_DMAxACP.tar.gz



# サンプルコード公開サイトのご紹介

### アルティマ オリジナル FPGA / CPLD 情報サイト



製品情報サイト「FPGA2.0」

FPGA の新しい入口 <a href="http://www.altima.jp">http://www.altima.jp</a>

登録制技術情報サイト「EDISON」



アルテラ製品、パートナ製品選びに!



アルティマ オリジナル 日本語資料で分かり易く!

※ (株) エルセナからご購入のお客様は、エルセナのテクニカル・データベース elspear および ETS をご利用ください。

### エルセナ オリジナル FPGA / CPLD 情報サイト



FPGA の新しい入口 <a href="http://www.elsena.co.jp/elspear/index.html">http://www.elsena.co.jp/elspear/index.html</a>

製品情報サイト「Telspear」



アルテラ製品、パートナ製品選びに!

登録制技術情報サイト「ETS」



エルヤナ オリジナル 日本語資料で分かり易く!

※ (株) アルティマからご購入のお客様は、アルティマのテクニカル・データベース FPGA2.0 および EDISON をご利用ください。

### 改版履歴



| Revision | on 年月 概要   |
|----------|------------|
|          | 2015年7月 初版 |

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

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

- 1. 本資料は非売品です。許可無く転売することや無断複製することを禁じます。
- 2. 本資料は予告なく変更することがあります。
- 3. 本資料の作成には万全を期していますが、万一ご不明な点や誤り、記載漏れなどお気づきの点がありましたら、本資料を入手されました下記代理店までご一報いただければ幸いです。

株式会社アルティマ ホームページ: <a href="http://www.altima.co.jp">http://www.altima.co.jp</a> 技術情報サイト EDISON: <a href="https://www.altima.jp/members/index.cfm">https://www.altima.jp/members/index.cfm</a> 株式会社エルセナ 大ームページ: <a href="https://www.elsena.co.jp">https://www.elsena.co.jp</a> 技術情報サイト ETS: <a href="https://www.elsena.co.jp/elspear/members/index.cfm">https://www.altima.jp/members/index.cfm</a>

- 4. 本資料で取り扱っている回路、技術、プログラムに関して運用した結果の影響については、責任を負いかねますのであらかじめご了承ください。
- 5. 本資料は製品を利用する際の補助的な資料です。製品をご使用になる際は、各メーカ発行の英語版の資料もあわせてご利用ください。