MAX1000およびCYC1000の使い方


Arduino MKR標準の小型FPGA評価ボード

Intel(旧ALTERA)のFPGAを搭載した小型のFPGAボードでMAX1000と、CYC1000というものがあります。
Arduino MKR標準という形状だそうです。DIP28ピンのような形状をしているので、ブレッドボードや万能機版に挿して使うこともできます。
PMOD端子も付いているのでFPGA用の簡単なモジュールを付けることもできます。
6個並んだピンはJTAGで、3個並んだピンはアナログ入力ピンのようです。

CYC1000

CYC1000は、Intel社のCyclone10(10CL025YU256C8G)を搭載したボードで8MB SDRAMを備えていて、NiosIIプロセッサを入れることができます。コンフィグROMのEPCQ16ASI8Nと、3軸加速度センサのLIS3DHも積んでいます。

MAX1000

MAX1000は、Intel社のMAX10(10M08SAU169C8G)を搭載したボードで8MB SDRAMを備えていて、やはりNiosIIプロセッサを入れることができます。SPI ROMのW74M64FVSSIQと、3軸加速度センサのLIS3DHも積んでいます。

Trenzか?Arrowか?

これらのボードはArrowとTrenz Electronicという2つの会社のロゴが入っています。

実は、CYC1000にはTEI0003-02、MAX1000はTEI0001-03-08-C8というもう一つの型番があります。おそらくArrow社の型番がCYC1000やMAX1000であって、Trenz社の型番がTEI0003-02やTEI0001-03-08-C8なのだと思います。(TEはTrenzElectronicの意味) Arrowの製品なのかTrenzの製品なのか、はっきりとは分かりません。
※ Arrowというのは、世界最大級の電子部品商社です。

USBとJTAGの機能

MAX1000およびCYC1000にはUSB(Micro-B)のコネクタが付いていて、その先はFTDI社のFT2232Hにつながっています。そして、FT2232HはUSB-UARTとUSB-JTAGを兼ねています。つまり、1つのUSBコネクタでシリアル通信と、FPGA書き込みの両方ができるようになっています。

ところが、このFT2232Hを使ったUSB-JTAGの仕組みはIntel(ALTERAの頃からの)USB-Blasterとは互換性がなく、そのままではQuartusから認識することができません。

USB-Blaster互換ではないからQuartusから使えない」と誤解されるるかもしれません。
それは完全なる誤解です。

以下に示すArrow USB Programmer 2の働きで、Quartusから完璧に使うことができるのです。

Arrow USB Programmer 2とは

Arrowから、Arrow USB Programmer 2というソフトウェアが提供されています。Arrow USB Programmer 2は、FT2232Hを使ったUSB-JTAGを、Quartusから接続できるようにするためのバックグラウンドで動くソフトウェアです。これを使うとQuartusからFT2232HによるUSB-JTAGが、Arrow-USB-Blasterとして認識できるようになります。

FTDIドライバのダウンロードとインストール

FT2232Hを初めて使う方は、FTDI社のD2XXライブラリも必要です。電子工作を常日頃からやっていてFTDIドライバは既に入っているという方は次のステップに進んでください。
D2XXライブラリのダウンロードページへ

Arrow USB Programmer 2のダウンロードとインストール

このソフトウェアは下記のURLで提供されています。
Arrow USB Programmer 2のダウンロードページ

この中にある最新のLinux版またはWindows版をダウンロードしてインストールします。

FTDI社のD2XXを入れて、Arrow USB Programmer 2をインストールすれば、Quartusから簡単に認識することができました。本当に何も難しいことはありませんでした。

レジストリの書き換えや、サービスの再起動が必要?

Arrow USB Programmer 2の説明を読んでいると、レジストリの書き換えやサービスの再起動が必要な場合について書いてあります。
トラブルシューティングの解説書

レジストリのHKEY_LOCAL_MACHINE\SOFTWARE\Altera Corporation\JTAGServer\Hardware_Arrow_USB_Blaster を書き換える必要性や、サービスを開いてALTERA JTAG Serverを再起動する必要性について書かれていますが、実際には必要はありませんでした。

もし、うまく動かないときにはやってみてください。

それでも外部にJTAGケーブルをつなげたい

もちろん、オンボードのUSB-JTAGを使わずに、ピンヘッダにUSB-BlasterなどのJTAGケーブルをつないで操作することも可能です。下の図はMAX1000のマニュアルの20ページからの引用です。J4につなげばよいようです。

本当にうまくいくの?

最近、Windows10をインストールしなおしたばかりで、まだFTDIもQuartusも知らないSurfaceに、D2XXドライバとArrow USB Programmer2と、Quartus18.1をインストールして試してみましたが、全く問題なくArrow USB Programmer2を認識してくれました。

サンプルプロジェクトのビルド

必要なQuartusのバージョン

必要なQuartusのバージョンは18.1です。Liteで構いません。
ただし、19.1は未対応のようです。

サンプルプロジェクトのダウンロード

MAX1000およびCYC1000のサンプルプロジェクトはTrenzElectronic社のWebサイトで提供されています。
CYC1000であればこのページのDownloadタブをつつき、Reference_Designの18.1のtest_boardの中にあります。

このページのTEI0003-test_board-quartus_18.1-20191111104339.zipをダウンロードします。

MAX1000であれば、こちらのページTEI0001-test_board-quartus_18.1-20191111104348.zipです。

サンプルプロジェクト自体を作る

Trenz社のFPGAのプロジェクトは、Quartusのプロジェクトがそのまま入っているのではなく、Quartusのプロジェクトを生成するためのソースファイルとTclファイルと、バッチファイル(あるいはシェルスクリプト)が入っています。なぜこのような形式になっているのかというと、バージョン管理システムで管理しやすいというのと、配布するファイルサイズを減らすことができるのと、マシン間のポータビリティが向上するためでしょう。CYC1000のプロジェクトはNIOS2のコアが入っているのに763kバイトしかありません。
これはこれで素晴らしい仕組みなのですが、ほとんどの人にとっては初めて見る形式であり、プロジェクトファイルがない!?と驚かせることになります。

MAX1000やCYC1000のプロジェクトを解凍すると、以下のようなフォルダが出てきます。

最初にやることは_create_win_setup.cmd (Linuxの場合は_create_linux_setup.sh)を実行することです。
すると、次の図のような画面が出ます。ここでは c のキーを押します。

次に max と入力し、ENTERを押します。

このmaxというのはMAX1000のことではなく、最大限たくさんのコマンドファイルを作るという意味です。

すると、design_basic_settings.cmdと、quartus_create_project_batchmode.cmdと、quartus_open_existing_project_guimode.cmdという3つのファイルが作られます。

カスタマイズ

まず、design_basic_settings.cmdをメモ帳などで開き、26行目から28行目の

@set QUADIR=C:/intelFPGA_lite
@REM -Attention: These scripts support only the predefined Quartus Version. 
@set QUARTUS_VERSION=18.1

に書かれているQuartusをインストールしたディレクトリを書き換えます。私はDドライブに大きなHDDをつないでいるので、QUADIR=D:/intelFPGA_liteにしました。QUARTUS_VERSIONは18.1のままにします。

Quartusのバージョンも変更できるようだったので、Quartus 19.1でやろうとしてQUARTUS_VERSION=19.1にして実行してみたのですが、うまくいきませんでした。現時点(2020/4/15)では18.1専用と考えてください。

プロジェクトの生成と最初のビルド

quartus_create_project_batchmode.cmd を実行します。エクスプローラからダブルクリックするだけでOKです。

すると、バッチモードでQuartusが動き、TCLが起動してプロジェクトの生成からビルドまで一気に行ってくれます。最初のビルドは10分くらいかかります。

プロジェクトをGUIモードで開く

最初のビルドが終わったら、quartus_open_existing_project_guimode.cmd をダブルクリックします。同じように緑色のスクリプトが動いて・・・

いつの間にかQuartusのGUIが開きます。そして、プロジェクトが出来上がっていて、コンパイルまで終わっているというわけです。

CYC1000の合成結果を見ると、Nios2が入っているのに18%くらいでした。

プロジェクトはtest_board\quartusフォルダにあるので、2回目からはこのフォルダの中のtest_board.qpfを開くか、quartus_open_existing_project_guimode.cmdをクリックすればよいでしょう。

FPGAへの書き込み

Quartusの上からProgrammerを開きます。

最初からquartus\output_files\test_board.sofが選択されています。Startを押すだけで、何も苦労することなく書き込みできました。書き込み時間は1秒未満でした。

コンフィギュレーションROMへの書き込み

コンフィギュレーションROMに書き込むには、Add Fileを選び、ダイアログが開いたらoutput_filesのtest_board.jicを選択します。

FPGAが2つになってしまうので、ROMがつながっていない方をクリックしてDELキーを押して消します。

FPGAが1個になった状態でStartを押すと、書き込みが行われます。トータルで15秒くらいかかります。

USB-UARTはどうなっている?

CYC1000やMAX1000のUSBはFT2232Hでした。USB-JTAGのほかにもUSB-UARTが使えます。
CYC1000の場合、下の図のようなテキストベースのアプリが動いていました。LEDの点灯状態の説明のようです。Spirit levelという状態のときには、オンボードの3軸加速度センサでボードの傾きに応じたLEDの表示になります。

まとめ

いかがでしたでしょうか?

MAX1000やCYC1000は数1000円と大変安価で、無償のQuartus Lite 18.1を使って開発することができ、
ソフトコアのNios2が入ったサンプルプロジェクトも用意されています。
Arduino MKR標準のピン配置なのでブレッドボードや万能基板にのせて試すことができます。

つまり、初めてIntelのFPGAを触って試してみたいという方にも、
何かに組み込んでみたいという方にも、とてもオススメなのです。

オンボードのUSB-JTAGはUSB-UARTとして1台2役なので、
USBケーブルが1本で良いのもありがたいですね。

入手はこちらから

MAX1000とCYC1000は、TrenzElectronic社の日本代理店から購入できます。

価格は2020年4月15日の価格です。国際的な輸送の情勢が不透明なのと、ドイツTrenz社の平時とは違うようで、在庫が切れた場合の今後の入荷は不明です。