AMD(Xilinx)のFPGA開発キットであるVivadoに付属している標準のロジックシミュレータVivado Simulator(xsim)はライセンスフリーで使える。なのでFPGA開発に限らず、特に個人でRTLのロジックシミュレーションをやりたい様な場合には大変重宝する。世の中にはフリーで使えるシミュレータは他にもあるが、今日のRTL開発やテストベンチ開発では必須となったSystemVerilogを十分にサポートしているものはVivado Simulator以外にはない(あったら教えて!)。しかも、UVM(Universal Verification Methodology)までにも対応している。なんて寛容な。大変ありがたい。(2024/8/31追記:Metrics社のDsim Desktopと言うシミュレータがフリーで使える事を教えてもらいました。SVAやDPI-C、UVMもフリーで使えます!言語サポートも十分です。)
しかし、Vivado Simulator(xsim)を使ったSystemVerilog(等)のロジックシミュレーションの方法を紹介したまとまった記事があまりない。なのでその方法を紹介しておこうと思う。
ここで紹介する方法はプロジェクトファイル等は使わず、全てコマンドでの実行方法のみ。また、Linuxの環境を想定する。Windowsは知らん。以下、テストベンチトップのモジュール名はtb_topを想定。
■ 事前設定
まず、事前に以下を実行し、xvlog/xelab/xsimコマンドがPATHへ追加される様にしておく。
% source <Vivado Install Directory>/settings64.sh
> source <Vivado Install Directory>/settings64.csh
以下/tools/Xilinx/Vivado/2022.2/にVivadoがインストールされている場合で、シェルにbashを使用している場合の例
% source /tools/Xilinx/Vivado/2022.2/settings64.sh
上記PATH設定はやらなくても良いが、やらない場合にはそれぞれ<Vivado Install Directory>/bin/
にあるコマンドを直接実行する必要がある。
シミュレーションの実行およびデバッグの仕方として以下大きく分けて3種類のやり方がある。
- コマンドでSimのBatch実行後、ログを確認
- GUIを立ち上げてInteractiveにSimを実行
- 信号波形データダンプでSim実行した後GUIで確認
以下でそれぞれやり方を説明。
■ BATCH実行
<2 step実行>
アナライズ後に-Rオプションを付けてエラボレーションを行い、その後xsimが即時に自動で実行される。規模の小さいデザイン等をちょっとお試しで実行してログを確かめるだけならこれが一番簡単でお手軽。
% xvlog --sv <SystemVerilog Files>
% xelab tb_top --R
<3 Step実行>
xsimに何かしらのオプションを付けて実行する場合に、エラボレーションの後にxsimを明示的に実行する。その際に--runallオプションを付けてSimulationを自動で最後まで実行させる。
% xvlog --sv <SystemVerilog Files>
% xelab tb_top
% xsim tb_top --runall <Option>
<Standalone実行>
上の3 stepでの実行に似ているが、Simulationの実行にxsimを使うのではなく、事前に生成したスタンドアローンの実行ファイルを使う。xsimのライセンスチェックは不要なので高速。Sim実行速度自体もxsimを使う場合より高速。その代わりデバッグオプションとかが付けられない。なのでデバッグ方法はログでの確認のみ。上記の3 step実行をやるぐらいならstandaloneでやった方が良い。このstandaloneの方法はあまり説明されていないのだが、絶対におススメする。
xelab実行時にシェルスクリプトの./axsim.shが自動で生成されるのでそれを実行すれば良い。オプションも受け付ける。中身は生成された実行ファイル./xsim.dir/work.tb_tp/axsimをたたいているだけ。なのでそれを直接実行しても良い。
% xvlog --sv <SystemVerilog Files>
% xelab tb_top --standalone
% ./axsim.sh <Option>
Or
% ./xsim.dir/work.tb_tp/axsim <Option>
■ GUI実行
上の3 step実行のエラボレーションの際に--debug all/typical/waveのいずれかを付ける。特にこだわりなければallで良い。その後、xsimの際に--guiを付けてGUIを立ち上げる。シミュレーションの実行はGUI上のTCLコマンドラインからrun allを実行するか、三角のボタンを押して実行。或いはF3ボタンを押す。信号の波形表示はあらかじめ信号をWaveform Windowにドラッグ&ドロップしてからシミュレーションを実行。シミュレーションを最初からやり直す場合にはRestartボタンを押して再度Run。
% xvlog --sv <SystemVerilog Files>
% xelab tb_top --debug all <Option>
% xsim tb_top --gui <Option> &
GUIの操作の仕方は以下とか参照。
■ 波形ダンプと表示
<波形データダンプ>
GUI実行と同様に、Batchでの3 step実行のエラボレーションの際に--debug all/typical/waveのいずれかを付ける。特にこだわりなければallで良い。その後xsimで実行する際にTCLファイルの指定と、ダンプする波形ファイルの指定を行う。
% xvlog --sv <SystemVerilog Files>
% xelab tb_top --debug all
% xsim tb_top --tclbatch dump_all.tcl --wdb all.wdb <Option>
TCLファイルにはダンプする信号の指定とrun allとquitを実行するように記述。以下の例では全ての信号をダンプするように指定。
log_wave -r *
run all
quit
逆に言うと、Batch実行で波形ダンプするには、この様にTCLファイルを作ってlog_waveでやる必要がある。そのような事をやってくれるコマンド実行のオプションは用意されていないみたい。
<波形データ表示>
*.wdbとしてダンプされた波形データは以下の様にして読み込んでGUI表示する。
% xsim all.wdb --gui <Option> &
ダンプが再実行された場合には立ち上げ直す必要はなく、TCLコマンドラインで上矢印キーを押してダンプデータの読み込みコマンドを再実行すればよい。信号のWavewindown表示も上矢印で再度実行できる。
■ Makefileの例
以上を踏まえて以下の様なMakefileを作ると良いだろう。
ワークディレクトリは何も指定しなければ./xsim.dirと言うのが作られ、そこにいろいろとコンパイルやエラボレーションのファイルが作られる。
スタンドアローン実行用エラボレーションデータとGUIおよびダンプ実行用のエラボレーション用のディレクトリは-snapshotのオプション指定で./xsim.dir/aloneおよび./xsim.dir/debugと言うそれぞれと別のディレクトリを作るようにしてある。Sim実行時にはそれぞれのスナップショット名を指定して実行する。-snapshotを指定しないとデフォルトではトップのモジュール名のtb_topがスナップショット名となる。エラボレーションデータ本体はそれぞれのエラボレーションディレクトリ内にaxsimおよびxsimkというファイル名で作られる。
また、生成したファイルやディレクトリを削除するcleanやxvlog,xelab,xsimの使い方やオプションの説明を表示をするhelpの各コマンドも作ってある。
#-------------- Config ------------------------
VIVADO_DIR := /tools/Xilinx/Vivado/2022.2
XVLOG := $(VIVADO_DIR)/bin/xvlog
XELAB := $(VIVADO_DIR)/bin/xelab
XSIM := $(VIVADO_DIR)/bin/xsim
SRC_DIR := .
SRC_FILES := $(shell ls $(SRC_DIR)/*.sv)
TOP := tb_top
#---------------------------------------------
#------------ Commands -----------------------
run : alone
once :
$(XVLOG) -sv $(SRC_FILES)
$(XELAB) $(TOP) -R
alone : ./xsim.dir/alone/axsim
./axsim.sh
gui : ./xsim.dir/debug/xsimk
$(XSIM) debug -gui &
dump : ./xsim.dir/debug/xsimk ./dump_all.tcl
$(XSIM) debug -t ./dump_all.tcl -wdb all.wdb &
wave : all.wdb
$(XSIM) all.wdb -gui &
help : ./help.txt
gview $<
cat $<
clean :
rm -rf *.log *.jou *.pb xsim.dir *.sh *.wdb .Xil
#---------------------------------------------
#------------ Files --------------------------
./xsim.dir/alone/axsim : $(SRC_FILES)
$(XVLOG) -sv $(SRC_FILES)
$(XELAB) $(TOP) -snapshot alone -standalone
./xsim.dir/debug/xsimk : $(SRC_FILES)
$(XVLOG) -sv $(SRC_FILES)
$(XELAB) $(TOP) -snapshot debug -debug all
./dump_all.tcl :
echo 'log_wave -r *' > $@
echo 'run all' >> $@
echo 'quit' >> $@
./help.txt :
$(XVLOG) --help > $@
$(XELAB) --help >> $@
$(XSIM) --help >> $@
#---------------------------------------------
% make run
% make gui
% make dump wave
■ 参考リンク
本家AMD(Xilinx)の日本語サポートページのプロジェクトを使用しない手順(スタンドアローンモード)の説明。
Vivado Simulatorのコマンド実行について軽く説明。
Vivado Simulatorのコマンドライン実行とGUI実行によるデバッグの方法について説明している。波形ダンプによるデバッグ方法に関しては特に言及無し。
波形ダンプについて言及有り。この例ではVCDファイルにダンプしてる。VCDフォーマットでダンプするにはlog_vcdを使うみたい。TCLにlog_waveの代わりそれを書けばばよい。