SinglePortBlockRAMの作り方

  • Memories & storage Elements

から

  • RAMs & ROMs

を選択し、

  • Single Port Block Memory

をダブルクリック。

御所望のメモリを作成し、Generateを押す。

後は作成するモジュール内で、

b_ram blockram( .clk( clk), .addr( address), .dout( dataOut));

というようにモジュール宣言をすればOK.

シミュレーションの方法

作成したIPには glbl というモジュールが含まれているため、作成したIPの.vファイルでglblを検索。

synopsys translate_off から synopsys translate_onの間をコメントアウトする。

実際のシミュレーション時のコマンドは

ncverilog +ncaccess+rw -y [ライブラリのPATH] +libext+.v [テストベクトル] [作成したモジュール]

これを一々手書きで行うのは大変なので、Makefile などに記述しておくとよい。

なお、ライブラリには以下のようなものがある。
(例) ISE-10.1の場合
/home/cad/xilinx/ISE-(使用しているversion)/ISE/verilog/src/XilinxCoreLib
/home/cad/xilinx/ISE-(使用しているversion)/ISE/verilog/src/unisims
/home/cad/xilinx/ISE-(使用しているversion)/ISE/verilog/src/simprims
あと、以下にあるglbl.vも必要
/home/cad/xilinx/ISE-(使用しているversion)/ISE/verilog/src/glbl.v
(注意!!)

使用しているversionによって、パスは微妙に異なります!!

また最初の数クロックはBlockRAMの挙動が怪しいので適当なクロック数分は何も行わないことが好ましい。

ROMの初期値設定の仕方

1.coregenを起動
2.tool  -> memory editor を選択
3.Add Block を選び適当な名前をつける
4.memoryの深さとData Width を決定.
5.あとはごにょごにょやってください。多分わかるはずです(お
6.File -> Generate -> COEにチェックを入れて OK。
7.これで出来たファイルをメモリ生成時に選択タブがあるので選んでおく。
8.生成する。
9.なれてくると、.coeファイルを自分でいじくってcoregenのバッチモードから再生成を行うようになる。
10.(発展課題)bitファイルに直接メモリの値を書き込むdata2memというコマンドがある。この使い方を調べよ。
11.(発展課題)このwikiに書いて手法を確立せよ。嘘です。僕が知らないだけですごめんなさい、、

トップ   編集 凍結 差分 バックアップ 添付 複製 名前変更 リロード   新規 一覧 検索 最終更新   ヘルプ   最終更新のRSS
Last-modified: 2019-08-29 (木) 00:03:48