MMAV - Denali Software

MMAV ユーザ • ガイド
バージョン 2.0
DENALI SOFTWARE, INC.
1000 Hamlin Court,
Sunnyvale, CA 94089
Tel: (408) 743-4200
Fax: (408) 743-4209
info@denali.com
sales@denali.com
www.denali.com/support
www.ememory.com
All rights reserved
機密保持告知
Denali Software, Inc. Sunnyvale, CA 94089
© 2006 Denali Software, Inc. All rights reserved.
公開:2008 年 10 月 30 日
本情報製品のいかなる部分も、デナリソフトウエア社からの書面による事前の許可を得ずに、
電子的、機械的、手作業、光学的、またはその他のいかなる形式または手段によっても、複
製、送信、または翻訳することはできません。本製品内の情報は予告なく変更されることが
あり、デナリソフトウエア社側の義務を表すものではありません。
本書に含まれている情報は、デナリソフトウエア社またはそのライセンサが所有権を持つ機
密情報であり、デナリソフトウエア社とお客様の間の契約書に従って提供され、デナリソフ
トウエア社のお客様のみが使用することができます。当該契約書に明記されていない限り、
デナリソフトウエア社は、本書に含まれている情報の整合性、正確性、または実用性につい
て、いかなる表明も保証も行わず、明確に放棄します。デナリソフトウエア社は、当該情報
の使用によって第三者の権利が侵害されないことを保証しません。また、デナリソフトウエ
ア社は、当該情報の使用に起因するいかなる種類の損害または費用に対する責任も負いま
せん。
制限された権利の表示
政府による使用、複製、または開示は、DFARS 252.227-7013 の「Rights in Technical Data and
Computer Software」の節のサブパラグラフ (c)(1)(ii) で定められた制限の対象となります。
仕向地規制の表示
本製品に含まれているすべての技術データは、アメリカ合衆国の輸出規制法の対象となりま
す。合衆国法に反する諸外国の国民に開示することは禁じられています。お客様の責任にお
いて、適用される規則を調べ遵守していただきます。
MMAV ユーザ • ガイド
10/30/08
2
1
はじめに . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.1
読者としての前提条件 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.2
表記規則 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.3
ヘルプ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
1.4
2
1.3.1
製品のマニュアル . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
1.3.2
関連情報 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
1.3.3
技術サポートへの連絡 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
1.3.4
トレーニング • コース . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
このマニュアルの使用方法 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
PUREVIEW グラフィカル • ツールの使用 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
2.1
PureView の起動 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
2.2
デナリ SOMA ファイルへのアクセス . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
2.2.1
2.3
2.4
3
4
eMemory.com からの SOMA ファイルの入手 . . . . . . . . . . . . . . . . . . . . . . . . . . 13
PureView GUI の使用 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
2.3.1
PureView での SOMA ファイルの表示 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
2.3.2
PureView の [File] プルダウン • メニュー . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
2.3.3
PureView の [Options] プルダウン • メニュー . . . . . . . . . . . . . . . . . . . . . . . . . . 20
2.3.4
HDL シェルの作成 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
2.3.5
SOMA ファイルの作成または変更. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
コマンド • ラインからの HDL シェルの作成 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
PUREVIEW でのメモリのデバッグ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
3.1
デナリ • メモリ • データベース • ファイル . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
3.2
シミュレーション時の対話型デバッグ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
3.2.1
UNIX シェルの起動 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
3.2.2
シミュレータおよびテストベンチの起動 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
3.3
シミュレーション結果ファイルの表示 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
3.4
メモリ • インスタンスの選択 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
3.5
PureView の [Debugging] ウィンドウ. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
3.5.1
[Memory Contents] ウィンドウ. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
3.5.2
メモリ内容トランザクション • サマリ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
3.5.3
トランザクション履歴の表示 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
3.6
PureView での後処理 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
3.7
Mentor Graphic's の Seamless HW/SW Co-Verification での PureView の使用 . . . . . . . . 36
デナリの MEMORY MODELER ADVANCED VERIFICATION (MMAV) の使用. . . . . . . . . . . . . . . 38
4.1
.denalirc ファイルを使用したメモリ • シミュレーション • モデルの制御 . . . . . . . . . 38
4.1.1
レジスタ • ファイル固有の .denalirc パラメータ . . . . . . . . . . . . . . . . . . . . . . . 46
4.1.2
IBM-EDRAM 固有の .denalirc パラメータ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
4.1.3
RDRAM 固有の .denalirc パラメータ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
4.1.4
RLDRAM 固有の .denalirc パラメータ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
MMAV ユーザ • ガイド
11/6/08
3
4.1.5
DDR-II SDRAM 固有の .denalirc パラメータ. . . . . . . . . . . . . . . . . . . . . . . . . . . 48
4.1.6
DDR-II と DDR3 に固有の .denalirc パラメータ . . . . . . . . . . . . . . . . . . . . . . . . 48
4.1.7
ESSRAM 固有の .denalirc パラメータ. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
4.1.8
Mentor Graphics ModelSim 固有の .denalirc パラメータ . . . . . . . . . . . . . . . . . . 49
4.1.9
Mentor Graphics Seamless HW/SW Co-Verification 固有の .denalirc パラメータ . .49
4.1.10
OneNand Flash の .denalirc パラメータ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
4.1.11
アサーションの .denalirc パラメータ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
4.1.12
.denalirc の概要をまとめた一覧表. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
4.2
シミュレーション時の .denalirc オプションの動的設定 . . . . . . . . . . . . . . . . . . . . . . . . 55
4.3
ライセンスに関するソリューション . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
4.4
4.5
4.3.1
デナリのライセンスのためのシミュレータ • キューイング . . . . . . . . . . . . . 56
4.3.2
ライセンスのチェックアウトの高速化 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
デナリの Tcl インターフェイス. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
4.4.1
ModelSim での使用 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
4.4.2
NCSIM や他の Tcl インタープリタでの使用. . . . . . . . . . . . . . . . . . . . . . . . . . . 57
4.4.3
Tcl のコマンド . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
4.4.4
コールバック • コマンド . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
デナリのメモリの初期化 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
4.5.1
メモリ • アドレスの判定 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
4.5.2
メモリの初期の内容 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
4.5.3
ファイルからのメモリのロード . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
4.5.4
メモリ内容ファイルの形式 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
4.6
メモリ • インスタンスの指定 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
4.7
メモリの内容のリセット . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68
4.8
メモリのリードとライト . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
4.8.1
4.9
メモリの内容の保存と比較 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
4.10
クロック • サイクル時間の再計算 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
4.11
シミュレーション時の SOMA ファイルの再ロードとタイミング • パラメータの
“オンザフライ”での変更 . . . . . . . . . . . . . . . . . . . . . . . . . 73
4.12
エラー • メッセージの制御 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
4.13
クロック • サイクルの強制的な再計算 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
4.14
RDRAM (Rambus) 固有モデルの考慮事項 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
4.14.1
5
マスクされたメモリ • ライト . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
RAMBUS 向け Turbo Channel Model . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
MMAV の特別な検証機能 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
5.1
メモリ • トランザクションのアサーションの設定 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
5.1.1
メモリ • アクセスのアサーション . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
5.1.2
データ • アクセスのアサーション . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
5.1.3
グローバルなメモリ • アクセスのアサーション . . . . . . . . . . . . . . . . . . . . . . . 85
5.1.4
パリティ • チェックのアサーション . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86
MMAV ユーザ • ガイド
11/6/08
4
5.2
アサーションの動的な有効化および無効化 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86
5.3
エラー挿入ルーチン . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
5.4
5.5
5.3.1
エラー挿入 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
5.3.2
故障モデリング . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90
XML を使用した MMAV での論理アドレス指定 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92
5.4.1
XML の基本 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92
5.4.2
深さおよび幅の拡張 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93
5.4.3
インターリーブ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
5.4.4
アドレスのスクランブル . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
5.4.5
データ • ビットの並べ替えおよびマスキング . . . . . . . . . . . . . . . . . . . . . . . . . 97
5.4.6
ホールの作成 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98
5.4.7
統合 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 98
5.4.8
MMAV とのインターフェイス . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100
PLI/FLI/Tcl を使用した、MMAV での論理アドレス指定 . . . . . . . . . . . . . . . . . . . . . . 101
5.5.1
幅の拡張 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
5.5.2
深さの拡張 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
5.5.3
インターリーブ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
5.5.4
マスキング . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102
5.6
アドレスのスクランブル . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105
5.7
スクラッチパッドのメモリ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106
5.8
MMAV と Mentor Graphic's の Seamless HW/SW Co-Verification 製品の併用 . . . . . . . 109
5.9
エンベデッド ASIC メモリのための MMAV の使用 . . . . . . . . . . . . . . . . . . . . . . . . . . 110
5.9.1
6
レジスタ • ファイル . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
5.9.2
エンベデッド SRAM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 112
5.9.3
エンベデッド DRAM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
MMAV テストベンチの統合. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .114
6.1
Verilog インターフェイス . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114
6.1.1
6.2
6.3
6.4
MMAV と Verilog の概要 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114
6.1.2
MMAV と Verilog のシミュレーション . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114
6.1.3
コールバックの処理 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118
VHDL インターフェイス . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123
6.2.1
MMAV と VHDL の概要 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123
6.2.2
MMAV と VHDL のシミュレーション . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123
SystemC インターフェイス . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126
6.3.1
MMAV と SystemC の概要 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126
6.3.2
MMAV と SystemC のシミュレーション . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126
Specman インターフェイス . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128
6.4.1
MMAV と Specman の概要 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128
6.4.2
MMAV と Specman のシミュレーション . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 129
6.4.3
コンフィギュレーション • レジスタおよびメモリへのアクセス . . . . . . . . 131
MMAV ユーザ • ガイド
11/6/08
5
6.5
6.6
6.7
A
6.4.4
sn_denali_unit を拡張してすべての MMAV 関数をメソッドとして含める . . .131
6.4.5
波形でのメモリ • トランザクションの表示 . . . . . . . . . . . . . . . . . . . . . . . . . . 133
6.4.6
テストケースの例 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133
Vera インターフェイス . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 134
6.5.1
MMAV と Vera の概要. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 134
6.5.2
MMAV と Vera のシミュレーション. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 135
6.5.3
Vera テストベンチからのデナリ • メモリ • モデルの初期化 . . . . . . . . . . . . 136
6.5.4
コールバックの処理 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137
6.5.5
Vera テストベンチからの他のデナリ関数の使用 . . . . . . . . . . . . . . . . . . . . . . 139
6.5.6
テストケースの例 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140
NTB インターフェイス. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141
6.6.1
MMAV と NTB の概要 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141
6.6.2
MMAV と NTB のシミュレーション . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141
6.6.3
インスタンスとトランザクション • クラス . . . . . . . . . . . . . . . . . . . . . . . . . . 141
6.6.4
コールバックの処理 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161
6.6.5
テストケースの例 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 162
SystemVerilog インターフェイス . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 164
6.7.1
MMAV と SystemVerilog の概要 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 164
6.7.2
MMAV と SystemVerilog のシミュレーション . . . . . . . . . . . . . . . . . . . . . . . . 164
6.7.3
コンフィギュレーション • レジスタおよびメモリへのアクセス . . . . . . . . 166
技術サポート . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 191
A.1
A.2
デナリ履歴ファイル . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 193
A.1.1
デナリの履歴ファイルについて (.denalirc の HistoryFile) . . . . . . . . . . . . . . . 193
A.1.2
HistoryDebug モード (.denalirc の HistoryFile と HistoryDebug) . . . . . . . . . . . 194
履歴ファイルについて . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196
A.2.1
SIM READ エントリ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196
A.2.2
MASKED SIM ライト • エントリ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196
A.2.3
デバッグ • リード . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196
A.2.4
デバッグ • ライト . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196
A.2.5
ファイル • ロード . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196
MMAV ユーザ • ガイド
11/6/08
6
CHAPTER
1
1
はじめに
MMAV ユーザ • ガイドへようこそ。このマニュアルでは、デナリの Memory Modeler Advanced
Verification (MMAV) および PureView ソフトウエアについて説明します。
1.1
読者としての前提条件
このマニュアルで説明する製品は、チップの設計者および検証エンジニアを対象にしていま
す。読者は Verilog または VHDL を確実に理解している必要があります。
1.2
表記規則
このマニュアルでは、次の表記規則を採用しています。
• コマンド、
ファイル名、およびコマンド • ライン • オプションの文字列値は等幅フォントで
表記します。
例:.denalirc ファイルを使用すると、実行時モデリング • パラメータを変更できます。
注意: レジスタ名などの文字は通常のフォントで表記します。
• コンテキストによって特定される値で置き換える必要がある変数は、かぎかっこで囲ん
で示します。
例:ファイルを検索するには、
「grep <filename> 」と入力します。<filename> には
ファイルの名前を入力します。
• UNIX 環境変数は、標準の表記法を採用して示します。
例:$DENALI 環境変数は、製品のインストール • ホーム • ディレクトリを指定します。
• 一連のオプションから任意で選択できるオプションの場合は、かぎかっこおよびパイプ
を使用して構文を示します。
myscript
[-option1 <value>|option2]
したがって、
server1 というマシンを指定して myscript をデバッグ • モードで実行する
と仮定すると、構文は次のようになります。
myscript –server server1 –debug
• 構文の例をテキスト • ボックスに示します。
% verilog [all of your regular arguments]
$DENALI/ddvapi/verilog/denaliPcie.v \
+incdir+$DENALI/ddvapi/verilog
MMAV ユーザ • ガイド
11/6/08
\
7
1.3
ヘルプ
次のセクションで、ヘルプ、トレーニング • マニュアル、およびオンライン • マニュアルにつ
いて説明します。
1.3.1
製品のマニュアル
デナリ製品の使用について不明な点がある場合は、ネットワークにインストールされている
マニュアルかデナリソフトウエア • リリース内にある該当製品のマニュアルを参照してくだ
さい。
$DENALI/docs/
ここで、$DENALI はデナリのホーム • ディレクトリです。
1.3.2
関連情報
次の関連情報にアクセスできます。
こ
• 『スタート • ガイド』
。デナリ VIP 製品を初めて使用するときの詳細が記載されています。
のマニュアルには、ソフトウエアのダウンロード、インストール • ディレクトリの作成、
インストール•パッケージの解凍、ソフトウエア•ライセンスのインストールについての詳
細と、サポートされているツールおよびプラットフォームのリストが記載されています。
GettingStartedUserGuide.pdf は $DENALI/docs/ にあります。
• デナリ製品に関する Web 上の FAQ は、次の URL にあります。
http://www.denali.com/support
• SOMA ファイルは、次の URL から入手できます。
http://www.ememory.com
• MMAV のリリースは、次の URL から入手できます。
http://www.denali.com/support
デナリとデナリ製品の詳細については、次の URL を確認してください。
http://www.denali.com
1.3.3
技術サポートへの連絡
有効なソフトウエア • ライセンスを購入していると、技術サポートを受けることができます。
デナリのサポート • センターには、次の方法で問い合わせることができます。
電子メールによるサポート :
• www.denali.com/support を利用します。
• 左側から、Support > Product Support > Create New Ticket を選択します。
MMAV ユーザ • ガイド
11/6/08
8
• 次のように .denalirc コンフィギュレーション • オプションを設定したシミュレーショ
ンの TraceFile と共に、問題の詳細な情報が含まれているサポート • チケットを開きます。
Historyfile denali.his
Historydebug on
Tracefile denali.trc
(.denalirc ファイルおよびトレース • ファイルの設定の詳細については、38 ページのセ
クション「.denalirc ファイルを使用したメモリ • シミュレーション • モデルの制御」を参照
してください。)
• 最寄りのサポート • センターのお問い合わせ電話番号
− 米国
: 408-743-4200、内線 3
− ヨーロッパ
: +44-1494-481030、support@denali.com
− 日本
: +81-3-3511-2460、support@denalisoft.co.jp
1.3.4
トレーニング • コース
デナリでは、製品の完全なトレーニング • コースを用意しています。現在提供されているコー
スの情報については、最寄りの技術サポート • センターにお問い合わせください。
1.4
このマニュアルの使用方法
このマニュアルは次の章で構成されています。
• 第 1 章:
「はじめに」では、このマニュアルの概要を説明します。
新しい PureView GUI の SOMA パラ
「PureView グラフィカル • ツールの使用」では、
• 第 2 章:
メータの表示機能と編集機能の両方について説明します。
• 第 3 章:
「PureView でのメモリのデバッグ」には、シミュレーション中のメモリ内容を固
有の図に表示する PureView デバッガの詳細が記載されています。
• 第 4 章:
「デナリの Memory Modeler Advanced Verification (MMAV) の使用」には、メモリの
サブシステム検証の強化を目的とした、高度な検証機能を有するデナリの世界有数のメ
モリ • モデリング機能を拡張する MMAV 製品の詳細な使用方法が記載されています。
• 第 5 章:
「MMAV の特別な検証機能」には、検証の確認をテストベンチに追加し、物理的
なメモリ表示を論理的なメモリ表示に整理できる一連の追加的な検証機能が示されてい
ます。
• 第 6 章:
「MMAV テストベンチの統合」では、サポートされているさまざまなテストベン
チのインターフェイスを示し、それについて説明します。
• 付録 A:
「技術サポート」には、デナリソフトウエア社の技術サポートを利用するための
さまざまな方法が記載されています。
MMAV ユーザ • ガイド
11/6/08
9
CHAPTER
2
2
PureView グラフィカル • ツールの使用
PureView グラフィカル • ユーザ • インターフェイス (GUI) を使用すると、メモリ • アーキテク
チャ (SOMA) ファイルの仕様を設定したり、以前の Memory Maker のすべての機能を、強化
された PureView のデバッグ機能と組み合わせたりすることができます。これによって、デナ
リ製品で必要とされるデスクトップ • ウィンドウの数を抑えることができます。
この章では、PureView GUI のデバッグ機能と共に、SOMA の表示機能と編集機能について説
明します。
2.1
PureView の起動
PureView GUI は、
次のコマンドを Unix または Linux シェル • コマンド • ラインから入力すると
起動できます。
shell >
MMAV ユーザ • ガイド
$DENALI/bin/pureview &
11/6/08
10
次の GUI が起動します。
図 2-1: PureView GUI
2.2
デナリ SOMA ファイルへのアクセス
PureView を使用して、
新しい SOMA ファイルの作成、デナリ • パラメータまたはメモリ • ベン
ダが作成した SOMA ファイルの表示および編集、シミュレーションで使用できる HDL ラッ
パーの生成を実行できます。詳細については、22 ページの「HDL シェルの作成」を参照して
ください。
デナリのメモリ • モデリング • ソリューションの中核となるのは、
よく知られているあらゆる
メモリ • クラスアーキテクチャの 'C' モデルに基づくクラスです。これらの 'C' モデルは、特定
のデバイス • ファミリーの全メモリ • クラスにわたるすべての機能に対応します。たとえば、
デ
ナリには次のメモリ • クラス用の 'C' モデルがあります。
SRAM
DRAM
不揮発性
揮発性
エンベデッド ASIC/
FPGA
同期 SRAM
DRAM
フラッシュ
カード • メモリ
DRAM
非同期 SRAM
EDO-DRAM
同期フラッシュ
マルチメディア •
カード *
SRAM
DDR SRAM
SDRAM
EEPROM
メモリスティック *
フラッシュ
MMAV ユーザ • ガイド
11/6/08
11
SRAM
DRAM
不揮発性
揮発性
エンベデッド ASIC/
FPGA
QDR SRAM
SGRAM
SEPROM
メモリスティック
Pro*
レジスタ • ファイル /
配列
SigmaRAM
拡張 SDRAM
PROM
SecureDigital **
FIFO
DDR-SGRAM
SMROM
SecureDigital IO**
Cellular RAM
DDR/DDRII-SDRAM
コンパクト • フラッ
シュ
* = ライセンスのみの場合
ライセンシー専用
Mobile RAM
FCRAM/FCRAM2
Atmel Serial/
Parallel/SPI フラッ
シュ
** = SDA メンバ専用
RDRAM
AND/NAND/NOR
フラッシュ
RLDRAM
Sharp フラッシュ
RLDRAM2
SST シリアル •
フラッシュ
GDDR2
One NAND
GDDR3
DDR-NVM
GDDR4
LPDDR2-NVM
GDDR5
DDR3
前述のメモリ • クラスは、
さまざまなメモリ • ベンダから数多くのバリエーションが出ている
ため、デナリでは SOMA ファイルを使用して特定の部品番号の特定のメモリ機能とタイミン
グを記述します。
これらの SOMA ファイルでは高度に最適化された 'C' コア • モデルが一意に
パラメータ化され、SOMA の仕様に従って動作とタイミングが調整されます。
SOMA ファイルは、メモリ • コンポーネントの動作を使用するためにメモリ • ベンダに幅広く
使用されており、多くのメモリ • ベンダの Web サイトから無料でダウンロードできます。こ
れらのベンダと連携し、デナリでも eMemory Web サイト (http://www.eMemory.com) に SOMA
ファイルのリポジトリを保持しています。対象デバイスの SOMA ファイルが見つからない場
合は、ご要望に応じて当社から SOMA ファイルをお届けすることになっています。通常、
SOMA ファイルを入手する場合は次の手順を実行します。
1. デナリの eMemory Web サイトを検索する (http://www.eMemory.com)。
2. メモリ • ベンダの Web サイトで該当する SOMA ファイルを検索する。
3. 類似デバイスの場合は、既存の SOMA ファイルを修正する。
4. http://www.eMemory.com から SOMA ファイルを要求する ( 該当するデバイスの仕様とデー
タシートへの参照を必ず含める )。
MMAV ユーザ • ガイド
11/6/08
12
2.2.1
eMemory.com からの SOMA ファイルの入手
デナリの SOMA ファイルでは、特定のベンダおよび動作速度に合わせて当社の C ベースのメ
モリ • モデルが完全に特性付けされます。
デナリでは、
ベンダ • データシートとメモリ • デバイ
スにおける当社の専門技術を使用して、これらのファイルの作成と検証が慎重に行われてい
ます。
特定のメモリ • ベンダの部品番号に対応した SOMA ファイルは、eMemory Web サイトから入
手できます。URL は http://www.eMemory.com です。このページに初めてアクセスすると、ダ
ウンロードのために登録を求められます。登録すると、ご使用の SOMA ファイルが更新され
たときに、最新バージョンのダウンロードが可能であるとの通知を受け取れます。
図 2-2: eMemory.com の登録ページ
MMAV ユーザ • ガイド
11/6/08
13
eMemory.com のユーザ登録を行うと、SOMA ファイルを検索できます。
図 2-3: eMemory.com の SOMA 検索ページ
ベンダ、クラス、データ幅、サイズ、または部品番号のいずれかを指定して、特定のメモリ
を簡単に検索することができます。
メモリの検索は、特定のベンダ、クラス、データ幅、サイズ、または部品番号に限定する必
要があります。検索エンジンによって、サブ文字列と [Part #] フィールドにユーザが入力した
ものとの検索が実行されます。ここで、* はワイルドカードとして受け入れられます。
その後、関連する SOMA を選択してカートに追加します。こうすると、Download Cart が表
示されます。このインターフェイスでは、電子メールで SOMA ファイルを入手できる [Send
cart now]、SOMA ファイルの [Remove Selected] または [Remove All] を選択できます。
MMAV ユーザ • ガイド
11/6/08
14
図 2-4: eMemory.com のダウンロード • カート
ファイルが電子メールで送信されると、PureView でその設定内容を確認することができます。
詳細については、16 ページの「PureView GUI の使用」を参照してください。
注意: 探している部品が見つからない場合は、次のインターフェイスを使用して SOMA を要
求できます。
MMAV ユーザ • ガイド
11/6/08
15
図 2-5: SOMA のリクエスト
2.3
PureView GUI の使用
PureView を起動するには、UNIX シェルから次のコマンド • ラインを入力します。
$DENALI/bin/pureview &
これで PureView ウィンドウが表示され、新しい SOMA 仕様ファイルを作成するか、既存の
SOMA ファイルを開くかを選択できるようになります。SOMA ファイルには、メモリ • デバイ
スをモデル化するために必要なあらゆる機能仕様とタイミング仕様が含まれています。
MMAV ユーザ • ガイド
11/6/08
16
2.3.1
PureView での SOMA ファイルの表示
既存の SOMA ファイルで読み込むには、PureView メイン • ウィンドウで [Open SOMA file] ボ
タンを選択します。SOMA ファイルには、XML の .soma サフィックスか、テキスト • ファイ
ルの .spc ファイル • サフィックスを付けることができます。現在のディレクトリ ( または別
のディレクトリ ) で SOMA ファイルを選択し、最初の選択ウィンドウの [Open] ボタンをク
リックします。SOMA ファイルが現在のディレクトリにない場合は、ファイル選択ウィンド
ウの上部でディレクトリ参照機能を使用します。
図 2-6: PureView の [Open SOMA File] ウィンドウ
MMAV ユーザ • ガイド
11/6/08
17
2.3.2
PureView の [File] プルダウン • メニュー
図 2-7: PureView の [File] メニュー
[New SOMA File]
特定のメモリ•クラス用にデナリのデフォルトのSOMAファイルを使用して独自のSOMAファ
イルを作成するときに使用します。
[Open a SOMA File]
別の SOMA ファイルを開くことができます。PureView で表示する別の SOMA ファイルを選
択できるダイアログ • ボックスが表示されます。
[Check a SOMA File for Errors]
SOMA ファイルの構文エラーと不正な機能の組み合わせを確認します。最初から独自の
SOMA ファイルを作成する場合は、その SOMA ファイルを保存したり、シミュレーションで
使用する前にファイルを確認することをお勧めします。
注意: このチェックでは、タイミングおよび機能の観点から SOMA ファイルの正確性は確認
されません。SOMA ファイルに設定された不正なパラメータのチェックのみが行われ
ます。
MMAV ユーザ • ガイド
11/6/08
18
注意: この後説明する [Save SOMA] または [Save SOMA As...] コマンドは [Check SOMA] コ
マンドと同様のチェック結果となり、保存をキャンセルしたりそのままの問題を開始
したりするオプションを提供します。
[Save SOMA] ファイル • オプション
このオプションを使用すると、SOMA ファイルを保存できます。[Save SOMA] オプションは、
SOMA ファイルへの変更が検出されると使用可能になります。デナリが作成した SOMA ファ
イルを表示する場合は、パラメータを変更しない限り、SOMA ファイルを再保存する必要は
ありません。
[Save SOMA As] ファイル • オプション
このオプションを使用すると、
新たに作成された SOMA ファイルを保存したり、
既存の SOMA
ファイルを別のファイル名で保存したりすることができます。
[Save Source] オプション
このオプションを使用すると、22 ページの図 2.3.4「HDL シェルの作成」で生成された HDL
ラッパー• ファイルをディスクに保存することができます。このオプションでは、SOMA ファ
イルの名前を使用します。また、デフォルトで .vhdl または .v のファイル拡張子 ( それぞれ
VHDL および Verilog ソース用 ) を使用します。
[Save Source As] オプション
このオプションを使用すると、22 ページの図 2.3.4「HDL シェルの作成」で生成された HDL
ラッパー • ファイルをディスクに保存することができます。このオプションでは、メモリ • モ
デル • クラスの名前を使用します。また、デフォルトで .vhdl または .v のファイル拡張子 ( そ
れぞれ VHDL および Verilog ソース用 ) を使用します。3.2 では新たに、モデル化するインター
フェイスの HTML データシートを保存できます。
[Close] オプション
このオプションを使用すると現在の PureView ウィンドウが閉じられますが、PureView アプリ
ケーションは終了しません。
[Exit] オプション
現在の PureView ウィンドウに加えてその他の開いている PureView ウィンドウを閉じ、
PureView を終了します。
MMAV ユーザ • ガイド
11/6/08
19
2.3.3
PureView の [Options] プルダウン • メニュー
図 2-8: PureView の [Options] メニュー
[SOMA Output Format]
サポートされている 3 つの形式で SOMA ファイルを保存できます。デフォルトでは、
eMemory.com からダウンロードされるすべての SOMA ファイルは XML 形式で圧縮されます。
これらのファイルは、
XML 形式として圧縮されずに保存されるか、テキスト • ファイル ( バー
ジョン 0.001) として保存されます。
[Simulation Environment]
HDL シェルの生成プロセスで使用するシミュレーション環境を選択します。Verilog、VHDL、
HTML Datasheet、および SystemC から選択できます。選択すると、PureView の [Source] ウィ
ンドウに HDL シェル • ファイルが表示され、
[File] -> [Save Source] メニューを使用してシミュ
レーション用の HDL シェルを保存することができます。
MMAV ユーザ • ガイド
11/6/08
20
データシート • オプションを使用すると、モデル化する HTML インターフェイスのデータシー
トを保存できます。これによって、機能をすばやくドキュメンテーションに展開できます。
この例は次のとおりです。
図 2-9: PureView のデータシート • ソース • ウィンドウ
[Bit-blast Pins]
このオプションは、
すべてのデータ•バスをHDLシェル•ファイルの個別の信号ビット•ポート
に展開します。さらに個別のピンは、[Functionality] タブの [Pins] の ( 右 ) 半分にある [Blast
Bits] チェック • ボックスでビットブラストできます。このウィンドウの例については、図 2-11
「PureView の [Functionality] ウィンドウ」を参照してください。
[STD_ULOGIC for VHDL Ports]
このオプションは、すべての VHDL ポートの信号タイプを STD_ULOGIC に変換します。デ
フォルトの信号タイプは STD_LOGIC です。
[Balloon Help]
このオプションは、マウスを重ねると表示されるヘルプ情報をオンにします。このボックス
のチェックを解除すると無効にできます。
MMAV ユーザ • ガイド
11/6/08
21
2.3.4
HDL シェルの作成
SOMA ファイルが正常にロードされたら、シミュレーション環境に合わせて HDL シェルを
作成する必要があります。これを行うには、PureView の SOMA の詳細を表示したウィンドウ
の右下隅にある [Source] タブを選択します。
図 2-10: PureView HDL [Source] ウィンドウ
最初は、[Source] ウィンドウには何も表示されていません。ウィンドウの一番上にある
[Options] メニューから [Simulation Environment] を選択します。次に、シミュレータがサポー
トしている HDL 言語に応じて [Verilog] または [VHDL] を選択します。次に、使用するシミュ
レータを選択します。その HDL シミュレータ用のコードが [Source] ウィンドウに表示されま
す。一部のフィールドを編集できることがわかります。これらのフィールドには、読み込ん
だ SOMA ファイルから適切なデータがあらかじめロードされているので、変更する必要はあ
りません。.spc ファイルまたは初期内容ファイルの場所を変更する場合は、これらのフィー
ルドの隣にある [...] ボタンをクリックすると、ファイル選択ボックスが表示されます。この
ボックスを使用して別のファイルを選択します。
HDL シェルでは、初期ファイル (init_file) を指定できます。モデルの初期化時にロードさ
れるファイルを示すパス名を編集できます。このファイル形式は、65 ページの「メモリ内容
ファイルの形式」に記載されているメモリ内容ファイル形式と同じです。
最後の手順は、この HDL シェルをデザイン内でインスタンス化できるようにファイルに書き
出すことです。これを行うには、[Source] ウィンドウの左上にある [File] メニューから [Save
Source As] を選択します。
HDL ソース • ファイルに名前を付けて適切なディレクトリに書き込
めるファイル選択ボックスが表示されます。これを実行すると、SOMA ファイルに指定され
ている特定のメモリ • デバイスでシミュレーションを開始するために必要なことはすべて実
行したことになります。
MMAV ユーザ • ガイド
11/6/08
22
注意: verilog シミュレータのすべてのオプションは、1 つのソース • ウィンドウにまとめられ
ています。PLI 標準インターフェイスにより、ここで、Verilog HDL ラッパーはすべて
の Verilog シミュレータで同じものになります。すべての Verilog シミュレータについ
て [All] オプションを選択します。
2.3.5
SOMA ファイルの作成または変更
PureView を使用すると、新しい SOMA ファイルを最初から作成したり、既存の SOMA ファ
イルを変更したりすることができます。これを行うには、次の手順を実行します。
1. インターフェイス • クラスを選択するか、既存の SOMA ファイルを読み込みます。
PureView を起動し、既存の SOMA ファイルを変更するために [Open SOMA file] を選択す
るか、[Select an interface class] を選択します。下部に 4 つのタブ ([Overview]、
[Functionality]、[Timing]、[Source]) がある PureView クラス • ウィンドウが表示されます。
2. サイズ、機能パラメータ、およびピン名を選択します。
図 2-11: PureView の [Functionality] ウィンドウ
MMAV ユーザ • ガイド
11/6/08
23
ウィンドウの下部の [Functionality] タブを選択します。[Functionality] ウィンドウでは、選
択したメモリ • クラスについて、
シミュレーション • モデルをパラメータ化できます。
各ク
ラスには、
メモリ•クラスのサイズと機能を記述する一連の独自のパラメータがあります。
これらのオプションは、表示される左側のウィンドウでオンまたはオフにすることがで
きます。右側のウィンドウを使用すると、各ピン • タイプのピン名と幅を指定できます。
デバイスのサイズは、アドレスおよびデータ • ポートのピン幅によって決まります。
ピンに名前を付けると、複数のピンの名前を一意に識別できます。PureView は、Pins セ
クションに次の構文を取得します。
name_prepend{port1_specifier, port2_ specifier, port3_specifier}name_postpend
例:
2 ポート • デバイスおよび、
OE_port1_N および OE_port2_N の目的の HDL シェル出力有効
ピン名の場合、PureView に次のように出力有効ピン名を入力します。
OE_{port1,port2}_N
3. タイミング • パラメータの指定
図 2-12: PureView の [Timing] ウィンドウ
MMAV ユーザ • ガイド
11/6/08
24
メモリの適切な機能とサイズを選択したら、設定したこのクラスとパラメータに関連す
るタイミング•パラメータを指定する必要があります。タイミング•パラメータを編集する
には、タイミング • パラメータの値の上で左マウス • ボタンをクリックします。このパラ
メータの説明と値は、
タイミング•パラメータの関連性を示すタイミング•チャートと同様
に、ウィンドウの右上隅に表示されます。このタイミング • パラメータは、[Value] フィー
ルドで右マウスをクリックし、正しい値を入力すると修正できます。値の絶対値は、
[Value] フィールドの右側にあるプルダウン • メニューをクリックすると変更できます。
パ
ラメータの値を変更するには、カーソルが [Value] 入力ボックス内にあるときに RETURN
キーを押します。
指定したタイミングの関連性がシミュレーション時に違反となる場合、そのエラーの報
告を有効または無効にすることができます。これを実行するには、チェック • マークをク
リックしてチェックを解除します。[Enabled] 列の空白部分をクリックすると、タイミン
グのチェックがオンに戻ります。[Functionality] タブで設定したパラメータに適さないタ
イミング • チェックは灰色で表示され、編集することはできません。
4. SOMA ファイルを保存します。
メモリのすべての機能およびタイミング • パラメータの設定が終了したら、
SOMA ファイ
ルをディスクに書き出す必要があります。これを行うには、ウィンドウの左上隅にある
プルダウン • メニューから [File] > [Save SOMA As] を選択します。SOMA ファイルの名前
を選択できるファイル選択ダイアログ • ボックスが表示されます。
SOMA ファイルのファ
イル名を指定したら、[Save] をクリックします。既存の SOMA ファイルを修正した場合
は、[File] > [Save SOMA] を選択します。元のファイルは、[Functionality] および [Timing]
ウィンドウから入力した新しい仕様に上書きされます。
5. HDL シェルを書き出します。
最後の手順は、メモリをシミュレーション環境に追加できるように、作成または修正し
たメモリの HDL シェルを書き出すことです。これを実行するには、22 ページの図 2.3.4
「HDL シェルの作成」で説明されている指示に従ってください。注意:HDL シェルは最
後に書き出してください。こうすることで、SOMA ファイルがユーザのデザインでイン
スタンス化されるときに、HDL シェルが正しい SOMA ファイルを特定します。SOMA
ファイルを保存する前に HDL シェルを書き出すと、古い SOMA ファイルが示される可
能性があります。
2.4
コマンド • ラインからの HDL シェルの作成
PureView は、シミュレーションのインスタンス化に必要な HDL シェルの作成に最も一般的
に使用されています。この HDL シェルには、SOMA ファイルに記述されているデバイスの
Verilog でのモジュール定義または VHDL でのエンティティとアーキテクチャのペアが含まれ
ています。
デバイスのピンは、"C" の特定のメモリ • クラス • オブジェクトへの呼び出しと同様
に定義されます。このオブジェクトは、デナリのソフトウエアに提供されているライブラリ
• オブジェクトを共有する denali.so を経由してシミュレーションにリンクしています。
次のコ
マンドを入力すると、PureView のオプションのリストを確認できます。
pureview -batch -help
コマンド • ラインから HDL シェルを作成するための構文は次のようになります。
pureview -batch -generate <target environment> <model name> -genoption
option1,option2 -genoutput <HDL shell file name> <soma file>
MMAV ユーザ • ガイド
11/6/08
25
例:
pureview -batch -generate mti essram_denali -genoption
init_file="../loadfiles/essram.dat" -genoutput essram.v essram.soma
このコマンドはデバイスに、
../loadfiles/essram.datの初期ファイルをプリロードして、
essram.soma SOMA ファイルでかつ、essram_denali のモジュールの essram.v ファイルを作
成します。この HDL シェル • ファイル (essram.v) は、MTI Verilog シミュレータに対して生
成されます。
次に、PureView のコマンド • ラインで使用できるオプションの完全なリストを示します。
表 2-1: PureView のコマンド • ライン • オプション
オプション
-batch
説明
-usage
PureView コマンドのヘルプ使用状況情報を出力します。
-help
PureView コマンドのヘルプ情報を出力します。
-quiet
メッセージはコンソールに表示されません。
ウィンドウは開かれず、コマンド • ラインに指定された動作が終わると終了します。
-new <class name>
指定されたメモリ • クラスの新しい SOMA を作成します。
-convert <format>
入力 SOMA を指定された形式に変換します。有効なオプションは、"xml" および
"uncompressedxml"( または "uxml") です。
-convoutput <file
name>
変換された SOMA (「-convert」を参照 ) を、コンソールではなく指定されたファイ
ルに書き込みます。
-generate
Verilog モジュールまたは VHDL エンティティに指定された名前を使用して、指定さ
れた環境に対応するシミュレーション • ソース • コードを生成します。以下の
target_environments のリストを参照してください。
<target env>
<model name>
名前を付けたオプションを指定した値か、値を指定しない場合は 1 に設定します。
<option>[=<value>] コマンド • ラインに対する複数の -genoption 引数の効果は累積的です。複数のオ
プションは、スペースではなくコンマで区切ります。以下のオプションのリストを
参照してください。
-genoutput
HDL ソース • コード (「-generate」を参照 ) を、コンソールではなく指定された
ファイルに書き込みます。
<file name>
-genoption
シミュレーション • データベース • ファイルに結び付けます。
-instance <instance シミュレーション • データベースに表示するインスタンス名 (-simdb が必要 )
name>
-simdb <file name>
表 2-2:
-generate オプションのターゲット環境
パラメータ
Co-Design
環境
CoWare
CoWare Simulator
Verilog
all
すべての Verilog シミュレータ
VHDL
leapfrog
VHDL コンフィギュレーション • テンプレート
Cadence Leapfrog/NC-VHDL
mentor-unix
Mentor MTI Modelsim (UNIX)
configuration
mti-unix
MTI V-System/Mentor QuickHDL (UNIX)
package
VHDL パッケージ • テンプレート
MMAV ユーザ • ガイド
11/6/08
26
表 2-2:
-generate オプションのターゲット環境
パラメータ
scirocco
環境
Synopsys Scirocco
voyager
Ikos Voyager
Datasheet
datasheet
HTML データシート
SystemC
systemC
SystemC
表 2-3:
パラメータ
init_file"file name"
-genoption のパラメータ
説明
init_file パラメータ / ジェネリックの値。
注意 : ファイル名には、関連パス (../../this_initfile.txt) に加えて環境
変数 ($denali_loadfiles/mem1.dat) も使用できます。
bitblast[=<value>]
1、yes、またはtrueに設定すると、追加ビットベースのHDLシェルが生成されます。
注意 : すべてのバスがブラストされます。ブラストを選択するには PureView GUI
を使用します。
blastModelName=
< モデル名 >
ビットベースまたは追加的な HDL シェルのモジュール名またはエンティティ名
(blastModelName=rbt12_75 など )
注意 : blastModelName パラメータでは、大文字と小文字が区別されます。
combinesetuphold
1 に設定すると、 $setup/$hold の条件を 1 つの $setuphold 条件にまとめ
ます。
configurationName
VHDL コンフィギュレーション • テンプレートのコンフィギュレーション名。
packageName
VHDL パッケージ • テンプレートのパッケージ名。
libraryName
VHDL コンフィギュレーション • テンプレートのライブラリ名。
vhdl_std_ulogic
1 に設定すると、VHDL のポート • タイプは、std_logic か std_ulogic のいず
れかになります ( デフォルトは常に std_logic)。
MMAV ユーザ • ガイド
11/6/08
27
CHAPTER
3
3
PureView でのメモリのデバッグ
PureView デバッガでは、
シミュレーション中のメモリ内容が独自なグラフィック • ビューに表
示されます。
このビューはポスト • プロセス • デバッグと同様に対話することを目的としてお
り、検証デバッグ用に次の機能が提供されています。
• 物理および論理アドレス内容の表示
• ポスト • プロセス • データベース
• シミュレーション実行後のメモリ内容の対話型ブラウズ
• メモリ内容を表示中の時間的前後移動
• 特定アドレスの履歴
• メモリ位置のダブルクリックよるメモリのトランザクション履歴の表示
• シミュレータとの時刻同期
• 「ライブ」モードでの実行時の PureView とシミュレータの同期
• ユーザによる選択が可能なメモリ空間 / 内容のレイアウトおよび表示
PureView デバッガは、デナリのクライアントアプリケーションインターフェイスを使用して
シミュレーションと同期します。
このため、メモリのリード / ライト • データが正確に PureView
ウィンドウに反映されるようになります。
3.1
デナリ • メモリ • データベース • ファイル
ポスト • プロセス機能を有効にするには、
作成するデータベース • ファイルを指定する必要が
あります。このファイルにはデナリの高度データベース圧縮技術が使用され、シミュレーショ
ン時のパフォーマンスに与える影響を最小限に抑えます。シミュレーション時のすべてのメ
モリ • イベントは、このバイナリ • ファイルに記録されます。
このファイルは、シミュレーションの開始時またはシミュレーション中にいつでも指定する
ことができます。
注意: シミュレーションの開始後にデータベース • ファイルが指定されると、先に行われた
シミュレーション•データベース作成のシステム•メモリ定義に関する情報が抑制され
る場合があります。
作成するデータベース • ファイルを指定するには、次のいずれかの方法で行います。
1. シミュレーションの開始時に、.denalirc ファイルから指定する。:
SimulationDatabase
MMAV ユーザ • ガイド
simdb
11/6/08
28
2. シミュレーション中、Tcl インターフェイスから RTL で動的に指定する。
Verilog/VHDL:
mmtcleval("mmsimulationdatabase simdb_filename");
Tcl:
mmsimulationdatabase simdb_filename
.denalirc オプション • メソッドはシミュレーションの開始時からデータベース全体を記録
するため、このメソッドを使用することをお勧めします。両方のメソッドを使用した場合、
mmsimulationdatabase が起動されると、.denalirc ファイルの記録が停止します。
3.2
シミュレーション時の対話型デバッグ
前述のように、PureView は、シミュレーション時の対話型モードとポスト • プロセス • モード
の 2 つのモードで使用することができます。PureView は、シミュレーション前やシミュレー
ション中にいつでも起動できます。いずれの場合でも、データベース • ファイルを生成する必
要があります。データベース • ファイルの指定方法の詳細については、28 ページの図 3.1「デ
ナリ • メモリ • データベース • ファイル」を参照してください。
3.2.1
UNIX シェルの起動
UNIX シェルから PureView を起動するには、次のコマンドを使用します。
pureview &
コマンド•ライン•スイッチを使用して、
特定のデータベース•ファイルとメモリ•インスタンス
を呼び出すことができます。
• -simdb filename - PureView を自動的にシミュレーション • データベース • ファイルと結び
付けます。
• -instance instance_name - シミュレーション • データベースで表示するインスタンス名を
指定します。
たとえば、test1.simdb データベースでインスタンス test.memory.ddr0 を開きます。
pureview -simdb ./test1.simdb -instance test.memory.ddr0
次のコマンド • ラインを入力すると、コマンド • ライン • スイッチの完全なリストを入手でき
ます。
pureview -batch -usage
MMAV ユーザ • ガイド
11/6/08
29
pureview & を使用して PureView を起動すると、
次のクライアント • ウィンドウが表示されます。
図 3-1: PureView の [Debugger] ウィンドウ
3.2.2
シミュレータおよびテストベンチの起動
ユーザのデザインまたはテストベンチから PureView を直接起動することもできます。デナリ
では、ユーザのテストベンチやシミュレータのコマンド • ラインから PureView を直接起動す
る、PLI、FLI、および TCL コマンドを用意しています。
例:
• ModelSim TCL:
mmstartpureview
• NC-SIM VHDL TCL:
call mmtcleval "mmstartpureview"
• Verilog PLI:
success = $mmstartpureview;
• VHDL FLI (ModelSim のみ ):
success := mmstartpureview;
• Verilog コマンド • ライン:
$system("$DENALI/bin/pureview &");
MMAV ユーザ • ガイド
11/6/08
30
3.3
シミュレーション結果ファイルの表示
PureView を起動したら、デバッグを開始するためにデータベースを開きます。シミュレー
ション• データベース • ファイルを見つけて開くには、
[Open an existing file] の下の[Simulation
Results] ボタンをクリックします。
注意: 1 回の PureView セッションでは、1 つのデータベース • ファイルしか開けません。
図 3-2: PureView の [Open Simulation Results] ウィンドウ
3.4
メモリ • インスタンスの選択
PureView を使用し、
ユーザのデザインでインスタンス化された物理メモリ • インスタンスを表
示したり、MMAV の機能を使用して作成した論理的にアドレス指定されたメモリを表示した
りすることができます。論理的にアドレスを指定されたメモリを物理メモリと組み合わせて、
深さ、幅、およびインターリーブ拡張を使用して、メモリ • サブシステムのまとまったシステ
ム表示ができます。これらの「論理的にアドレス指定された」メモリ表示の作成方法の詳細
については、81 ページの「MMAV の特別な検証機能」を参照してください。
MMAV ユーザ • ガイド
11/6/08
31
データベース•ファイルを開くと、
PureViewにメモリ•インスタンス•ウィンドウが表示されま
す。1 つまたは複数のメモリインスタンスを選択し、[OK] をクリックします。
図 3-3: PureView の [Open Instance] ウィンドウ
3.5
PureView の [Debugging] ウィンドウ
デバッグするメモリを選択すると、PureView に 2 つのウィンドウが表示されます。1 つ目の
[Memory Contents] ウィンドウには、指定したシミュレーション時刻のメモリ内容が表示され
ます。2 つ目の [Transaction History] ウィンドウには、記録したメモリ • トランザクションが連
続して表示されます。
これらの 2 つのウィンドウは、互いに同期がとれています。たとえば、[Memory Contents] ウィ
ンドウで時刻を設定すると [Memory Contents] ウィンドウが自動的に更新され、その時刻また
はその時刻に近いトランザクションが示されます。また、[Transaction History] ウィンドウで
特定のトランザクションをダブルクリックすると、自動的に [Memory Contents] ウィンドウが
調整され、シミュレーション中のその時刻のメモリ内容が表示されます。
MMAV ユーザ • ガイド
11/6/08
32
メモリ内容の表示
赤色のタグ:最後にリードされた
アドレス
白色のタグ:最後にライトされた
アドレス
これらのタグは、履歴の最後ではな
く、現在表示されている時刻を基準
にしています。
点滅している
黄色のタグ:ダブルクリックして
要求したアドレス。
トランザクション履歴
の表示
図 3-4: PureView の [Debugger] ウィンドウ
3.5.1
[Memory Contents] ウィンドウ
[Memory Contents] ウィンドウには、デバッグを支援する補足機能がいくつかあります。これ
らは、プルダウン • メニューでアクティブにします。このウィンドウを以下に示します。
図 3-5: PureView の [Memory Contents] ウィンドウのオプション
MMAV ユーザ • ガイド
11/6/08
33
次に、これらの機能について説明します。
[File] オプション • プルダウン • メニューから、次の機能を使用できます。
• [Open Instance...]:PureView メモリ • インスタンス • ウィンドウを開きます。追加デバッグ •
ウィンドウを開くことができます。
• [Run Tcl Command...]:必要に応じて、Tcl コマンドを発行できます。
• [Debug]:PureView GUIでの問題をデナリ•サポートに報告するデバッグ•オプション•ウィ
ンドウを表示します。
• [Close Window]:現在の [Memory Content] ウィンドウを閉じます。
• [Exit]:すべてのウィンドウを閉じて PureView を終了します。
[View] プルダウン • メニューから、次の機能を使用できます。
• [Value Format]:データの値の形式を設定できます(アドレスは常に16進数形式で表示され
ます )。次のいずれかを選択できます。
− 2 進数
− 10 進数
− 16 進数
− 8 進数
• [Contents Table Origin]:
• [Top Left]:開始アドレスをウィンドウの左上から始めてメモリの内容が表示されます。
• [Top Right]:開始アドレスをウィンドウの右上から始めてメモリの内容が表示されます。
• [Bottom Left]:開始アドレスをウィンドウの左下から始めてメモリの内容が表示されます。
• [Bottom Right]:開始アドレスをウィンドウの右下から始めてメモリの内容が表示され
ます。
• [Show Last Read]:最後に読み込まれたアドレスが表示されます。
• [Show Last Write]:最後に書き込まれたアドレスが表示されます。
• [Refresh]:[Memory Content] ウィンドウをリフレッシュします。
MMAV ユーザ • ガイド
11/6/08
34
3.5.2
メモリ内容トランザクション • サマリ
特定のアドレスを「ダブルクリック」すると、そのアドレスのすべてのメモリ • トランザク
ションのサマリを入手できます。
ダブルクリックしたアドレスにメモリ • トランザクションが
あると、すべてのアクティビティを要約する次のポップアップ • ウィンドウが表示されます。
図 3-6: PureView の [Transaction Summary] ウィンドウ
3.5.3
トランザクション履歴の表示
PureView では、全体的な情報を提供するトランザクション履歴が表示されます。PureView を
起動すると、この表示ですべてのメモリ • トランザクションのリストを確認できます。トラン
ザクション履歴ウィンドウの情報レベルは、次のように .denalirc ファイル内のパラメータ
で制御できます (.denalirc ファイルの詳細については、38 ページの「.denalirc ファイルを
使用したメモリ • シミュレーション • モデルの制御」を参照してください )。
1. HistoryFile:基本的なリード / ライト動作とメモリ動作 (precharge、nop、refresh など ) に
関する詳細が提示されます。
MMAV ユーザ • ガイド
11/6/08
35
2. HistoryDebug:HistoryFile の情報に加え、バンク、行、および列のアドレス、バンクの状
態など、詳細なデバッグ情報も表示されます。
図 3-7: PureView の [Transaction History] ウィンドウ
[Transaction History] ウィンドウの特定の行をダブルクリックすると、[Memory Contents] ウィ
ンドウの該当する時刻とアドレスが表示されます。
3.6
PureView でのポスト • プロセス
前述のように、PureView は、シミュレーション時の対話型モードとポスト • プロセス • モード
の 2 つのモードで使用することができます。ポスト • プロセス • モードでを使用するには、
デー
タベース • ファイルがあらかじめ存在しなければなりません。ポスト • プロセス • モードで
PureView を使用するには、次の手順を実行します。
1. .denalirc ファイル内またはテストベンチ内から SimulationDatabase を設定し、シ
ミュレーションを実行します。
2. PureView を起動し、シミュレーション • データベース • ファイルを開きます。
3. デバッグするメモリ • インスタンスを開きます。
上記のすべての機能は、すでに有効になっています。
3.7
Mentor Graphic's の Seamless HW/SW Co-Verification
での PureView の使用
DenaliOwn と DenaliOwnClass という Seamless 内のメモリの制御をデナリに渡す 2 つの新し
い .denalirc の機能があります。
注意: Seamless 環境内で PureView を使用するには、これらの設定を使用してメモリの所有
権をデナリに渡す必要があります。
MMAV ユーザ • ガイド
11/6/08
36
DenaliOwn .denalirc設定を使用して、
デナリへの特定のインスタンスを"own"に渡します。
たと えば、Seamless でメ モリ • イン スタ ンス "testbench.rams.sdram0" を表 示す るに は、
.denalirc 変数を次のように設定します。
DenaliOwn /testbench/rams/sdram0
また、デナリがメモリ • クラス全体を所有できるように Seamless で指示することもできます。
メモリ • クラスとは特定のメモリ • タイプ (SDRAM, DDR_SDRAM、Flash、
SRAM など ) のこと
です。たとえば、Seamless で実行しているときに PureView で SDRAM メモリ • インスタンス
を表示するには、.denalirc 変数を次のように設定します。
DenaliOwnClass sdram
注意: DenaliOwn および DenaliOwnClass パラメータに複数のメモリ • クラスを追加するには、
セミコロンでメモリ • クラスを分割し、これらのクラスをテキストの同一行に置くよ
うにしてください。
例:
DenaliOwn /testbench/rams/sdram0;/testbench/rams/sdram1;*ddr*
DenaliOwnClass sdram;ddr
MMAV ユーザ • ガイド
11/6/08
37
CHAPTER
4
4
デナリの Memory Modeler Advanced Verification
(MMAV) の使用
デナリの MMAV 製品は、デナリの世界有数のモデリング機能を詳細な検証機能によって拡張
します。この検証機能は、メモリ • サブシステムの検証を強化することを目的としています。
データとデータ • トランザクションを使用してシステムを検証することにより、
検証サイクル
時間を大幅に短縮する一方で、検証の対象範囲を拡大することができます。
4.1
.denalirc ファイルを使用したメモリ • シミュレーション • モ
デルの制御
MMAV の機能を最大限に発揮させるために、デナリはランタイム制御初期設定ファイルの
$DENALI/.denalirc を使用しています。このファイルは、シミュレーション中のモデルの
動作を制御する設定を保存したものです。最大 4 つの $DENALI/.denalirc ファイルを使用
して、この設定を保存することができます。たとえば、特定のシミュレーションの 1 つの設
定だけを変更するには、.denalirc ファイルをワーキング • ディレクトリに作成して、特定
のシミュレーションの設定を保存します。これらの初期設定ファイルが置かれている場所は
以下のとおりで、リストの順番での優先度になります。
表 4-1: .denalirc の優先度
場所
説明
$DENALIRC
環境変数
./.denalirc
特定シミュレーションのデフォルト
~/.denalirc
ユーザ • デフォルト
$DENALI/.denalirc
システム • デフォルト
通常、.denalirc ファイルは、初期設定に使用されるキーワードと値がペアで記述されるテ
キスト•ファイルです。#で始まる行はすべてコメントとして無視されます。
インストレーショ
ン • ディレクトリに格納されているデフォルトの .denalirc ファイルには、コメントによっ
てすべてのスイッチの使用方法が記載されています。説明では、明確にするために大文字と
小文字を混在させて使用しますが、スイッチでは、その値には大文字と小文字の区別があっ
ても、名前には大文字と小文字の区別はありません。
次のセクションでは、
メモリ • モデル動作を変更するために初期設定ファイルに設定できるス
イッチ ( またはフラグ ) についていくつか説明します。
MMAV ユーザ • ガイド
11/6/08
38
HistoryFile
HistoryFile スイッチを設定すると、履歴ファイルが作成されます。このファイルには、各
メモリに対するリードとライトの処理がすべて記載されます。デフォルトの .denalirc で
は、このスイッチはオフになっています。このスイッチを設定するには、該当する行のコメ
ントを解除し、履歴を記述するファイル名を指定してください。たとえば、履歴ファイルを
memresults.his として保存するには、
.denalirc ファイルの該当行を次のようにしてくだ
さい。
HistoryFile memresults.his
HistoryDebug
HistoryDebug スイッチを使用すると、
さらに詳細な情報が HistoryFile の結果に保存され
ます。デフォルトの .denalirc では、このスイッチはオフになっています。このスイッチを
設定するには、該当する行のコメントを解除してください。例:
HistoryDebug On
HistoryDebugLoad
HistoryDebugLoad スイッチを使用すると、
上記よりさらに詳細な情報が HistoryFile の結
果に保存されます。これには、履歴ファイルに対する個別のアドレス • ロードもそれぞれ含ま
れます。したがって、このスイッチを設定すると、HistoryFile のサイズが大幅に増えま
す。デフォルトの .denalirc では、このスイッチはオフになっています。このスイッチを設
定するには、該当する行のコメントを解除してください。例:
HistoryDebugLoad On
HistoryInSimLog
HistoryInSimLog を1に設定すると、
シミュレータからの出力(これはシミュレータによって
異なります ) と共に反映され、履歴メッセージを確認することができます。これによって、デ
ナリの履歴はテストベンチ出力と合わせて出力されます。デフォルトは 0 ( オフ ) です。
HistoryInSimLog
0
TraceFile
TraceFile スイッチを設定すると、リードやライトなど、メモリ上で行われたイベントをす
べて記載したファイルが作成されます。このファイルは主に、ユーザのメモリ • シミュレー
ション環境を理解し、再現するために、デナリのサポート部門が貴重な診断ツールとして使
用するものです。デフォルトの .denalirc では、このスイッチはオフになっています。この
スイッチを設定するには、適切な行のコメントを外し、データを保存するファイル名を指定
します。たとえば、トレース • ファイルを testcase.trc として保存するには、.denalirc
ファイルの該当行を次のようにしてください。
TraceFile testcase.trc
TraceTimingChecks
TraceTimingChecks を使用すると、
シミュレーション時のすべてのタイミング • チェックを
トレースできます。デフォルトの .denalirc では、このスイッチはオフになっています。
TraceTimingChecks スイッチをオンにするには、値を 1 に設定します。例:
TraceTimingChecks 1
MMAV ユーザ • ガイド
11/6/08
39
LicenseQueueTimeout
LicenseQueueTimeout を使用すると、ライセンスを使用することができない場合にサスペ
ンド状態で待たなければならない時間 ( 単位は分 ) を指定することができます。次の例では、
ライセンスが使用できるようになるまで、デナリは 120 分間待ちます。
LicenseQueueTimeout 120
LicenseQueueRetryDelay
LicenseQueueRetryDelay は、
ライセンスを要求する ping を開始するまでの待ち時間 ( 単位
は秒 ) を指定します ( こうすることにより、ライセンスのログ • ファイルがオーバーフローす
ることはなくなります )。次の例では、デナリはデナリ • ライセンスを要求して 60 秒ごとに
ping を行います。
LicenseQueueRetryDelay 60
SimulationDatabase
SimulationDatabaseは、
ポストプロセスのシミュレーション•データベースのファイル名と
場所を指定します。
SimulationDatabase /tmp/simdbxxx
ここで、XXX は他のユーザとの衝突を避けるための一意の数です。必要に応じて、上記以外
のデータベース場所を指定することもできます。ただし、パフォーマンス上の理由により、
データベースをローカル • ディスク上に配置することを強くお勧めします。
注意: データベースを生成するときには、HistoryFile パラメータを有効にする必要があり
ます。
データベースの生成を無効 ( デフォルト ) にするには、次のコマンドを使用します。
SimulationDatabase Off
SimulationDatabasePattern
データベース情報を特定のインスタンスに限定するには、次のステートメントを使用してく
ださい。
SimulationDatabasePattern instance2
ワイルドカード • パターンを使用する場合 ( たとえば、インスタンス名のパスに [] を使用 ) に、
SimulationDatabasePattern パラメータに指定するには、エスケープを使用する必要があ
ります。
たとえば、"top.m_system.bank[0].index[0].mem" の場合は、次のコマンドを使用します。
SimulationDatabasePattern top.m_system.bank\[0\].index\[0\].mem
これらすべてを 1 つのパターンにまとめるには、次のコマンドを使用します。
SimulationDatabasePattern top.m_system.bank???.index???.mem
MMAV ユーザ • ガイド
11/6/08
40
SimulationDatabaseBuffering
データベースをディスクに直ちにフラッシュするために、シミュレーション • データベース •
バッファリングの有効 / 無効を切り替えることができます。
直ちにフラッシュするとパフォー
マンスが低下しますが、
「異常終了」の状況をデバッグしている場合は便利です。
SimulationDatabaseBuffering on/off
TimingChecks
TimingChecks スイッチは、
メモリ • モデルのタイミング • チェック ( つまり、
セットアップ時
間やホールド時間など ) をオンまたはオフにします。デフォルトの .denalirc では、このス
イッチはオンになっています。
タイミング • チェックをオフにするには、値を 0 に設定します。
例:
TimingChecks 0
RefreshChecks
RefreshChecks スイッチは、
DRAM モデルのリフレッシュ• タイミング • チェックをオンまた
はオフにします。DRAM モデルのシミュレーションをしていない場合は、このスイッチは無
視されます。デフォルトの .denalirc では、このスイッチはオンになっています。リフレッ
シュ • チェックをオフにするには、値を 0 に設定します。例:
RefreshChecks 0
RefreshOnReadWrite
リードとライトをその特定の行に対するリフレッシュ処理として数える場合は、パラメータ
RefreshOnReadWrite を 1 に設定します。その部分の該当する動作では、リードとライトを
その行に対するリフレッシュ処理として数える場合もありますが、デナリのデフォルトは、
数えない設定になっています。デフォルト値がこのように設定されているのは、コントロー
ラが適切なリフレッシュ• レートを取得するために一部のメモリ • アクセスに依存するのを防
ぐためです。これがサポートされているメモリの種類は、EDRAM、RLDRAM、SDRAM、
DDR SDRAM、および DDR II SDRAM だけです。
RefreshOnReadWrite 1
ReadDQSContentionCheck
リード時に DQS でのバスの競合がないかどうかをチェックするには、
ReadDQSContentionCheck を 1 に設定します。
サポート対象は DDR SDRAM だけです。DDR
SDRAM モデルは、リード時に DQS でのバスの競合がないかどうかをチェックします。この
チェックを無効にするには、ReadDQSContentionCheck を 0 に設定します。
ReadDQSContentionCheck 1
InitialMemoryValue
デフォルトでは、メモリ • モデルは X に初期化されます。次のいずれかの値を指定して、メモ
リを初期化することができます。
• InitialMemoryValue 0 - すべて 0 に初期化します。
• InitialMemoryValue 1 - すべて 1 に初期化します。
• InitialMemoryValue X - すべて X に初期化します。
• InitialMemoryValue U - すべて U に初期化します。
MMAV ユーザ • ガイド
11/6/08
41
あるいは、16 進数値を指定することもできます。この値は "0x" で始まり、0 ~ 9 と A ~ F
( または a ~ f) の 16 進数値で構成される必要があります。例:
InitialMemoryValue
0x3018
この文字列をメモリのワード幅 ( 通常はデータ • サイズ ) より長く拡張することはできません。
ワード幅より短い場合、指定されないビットには 0 が入力されます。
値が上記以外の場合は、メモリはすべて X に初期化されます。
次のように指定することによって、
初期データのためにランダム • データを生成することもで
きます。
• InitialMemoryValue randomNoUpdate - モデルはランダム • データによって更新され
ません ( つまり、ランダム • データはモデルにライトされません )。したがって、途中にラ
イトが発生しないそれ以降のリードで、新しいランダム • データを取得します。
• InitialMemoryValue randomWithUpdate - モデルはランダム • データによって更新さ
れます ( つまり、ランダム • データはモデルにライトされます )。したがって、途中にライ
トが発生しないそれ以降のリードで、初めて返されたのと同じランダム • データを取得し
ます。
あるいは、任意の C 関数を使用して、初期データ ( ランダム • データやパリティ付きランダム
• データなど ) を指定することもできます。
具体例については、$DENALI/ddvapi/example/fillValue を参照してください。
InitMessages
InitMessages を設定すると、
初期化時にデザイン内でインスタンス生成された各メモリ • コ
ンポーネントに関する情報メッセージが、システムによってレポートされます。デフォルト
の .denalirc では、InitMessages がオンになっています。InitMessages をオフにする
には、次のように値を Off に設定します。
InitMessages Off
TracePattern
TracePattern を使用すると、特定のインスタンス名パラメータのみを取り込むことによっ
て、トレース • ファイル ( 上記を参照 ) のサイズを制限できます。*、?、[] などのシェル "glob"
パターンを使用することができます。TraceFile のコメントを解除する必要があります。
たとえば、"sdram" というパターンを持つメモリ • インスタンスだけをトレースするには、次
のコマンドを使用します。
TracePattern *sdram*
ワイルドカード • パターンを使用する場合 ( たとえば、インスタンス名のパスに [] を使用 ) に、
TracePattern パラメータに指定するには、エスケープを使用する必要があります。
たとえば、"top.m_system.bank[0].index[0].mem" の場合は、次のコマンドを使用します。
TracePattern top.m_system.bank\[0\].index\[0\].mem
これらすべてを 1 つのパターンにまとめるには、次のコマンドを使用します。
TracePattern top.m_system.bank???.index???.mem
MMAV ユーザ • ガイド
11/6/08
42
HistoryPattern
HistoryPattern を使用すると、特定のインスタンス名パラメータだけを取り込むことに
よって、履歴ファイル ( 上記を参照 ) のサイズを制限することができます。*、?、[] などの
シェル "glob" パターンを使用することができます。
たとえば、
"sdram" というパターンを持つメモリ • インスタンスだけの履歴を記録するには、
次
のコマンドを使用します。
HistoryPattern *sdram*
ワイルドカード • パターンを使用する場合 ( たとえば、インスタンス名のパスに [] を使用 ) に、
HistoryPattern パラメータに指定するには、エスケープを使用する必要があります。
たとえば、"top.m_system.bank[0].index[0].mem" の場合は、次のコマンドを使用します。
HistoryPattern top.m_system.bank\[0\].index\[0\].mem
これらすべてを 1 つのパターンにまとめるには、次のコマンドを使用します。
HistoryPattern top.m_system.bank???.index???.mem
IrregularClock
ランダム出力の遅延スケジューリング機能を備えたモデル (DDR SDRAM、DDR-II、FCRAM、
RDRAM、RLDRAM など ) では、出力スケジューリングと一部のタイミング • チェックは、実
際のクロック • サイクル時間の影響を受けます。クロック • サイクル時間は通常、シミュレー
ションの最初の数サイクルの間だけ、モデルによって測定されます。ただし、次のフラグの
いずれかが使用されている場合を除きます。
不均一クロック ( 一定でないクロック幅 ) で実行している場合は、この機能を設定する必要
があります。
通常の ( 均一 ) クロックで実行している場合は、
デナリ • モデルは許容できるデー
タ有 効範 囲内 で、デー タ出 力を「ラ ンダ ム化」す るこ とが で きま す
(
下 記の
「RandomOutputDelay」を参照 )。IrregularClock を 1 に設定すると、このランダム化は
自動的にオフになります。
このスイッチを設定すると、サイクルごとにクロック幅が測定され、ランダム出力の遅延ス
ケジューリング機能はオフになります。
IrregularClock 1
ClockStableCycles
これは、クロックが安定していると MMAV が見なす場合での 1 行内のサイクル数を設定する
ときに使用します。これは、DDR、FCRAM、および RLDRAM で必要です。通常はクロック
数が安定するまでにしばらく時間がかかるからです。
ClockStableCycles 1000
RandomOutputDelay
このパラメータは、ランダム出力の遅延スケジューリング機能を備えたモデル (DDR、
FCRAM、DDR など ) で使用します。そうすることにより、メモリ • コントローラの機能が向
上します。検証サイクルの初期段階でオフにしてもかまいません。デフォルトでは、この値
はオンです。
RandomOutputDelay 1
MMAV ユーザ • ガイド
11/6/08
43
OutputTiming
デフォルトでは、デナリのメモリ • モデルはデータ出力を駆動します。このとき、SOMA ファ
イル • パラメータに基づく遅延が発生します。出力の遅延をゼロにするには、OutputTiming
変数を "0" に設定する必要があります。
これは主にサイクル • ベースのシミュレーションで使
用します。
OutputTiming 0
InitChecks
DRAM の初期化チェック機能は、InitChecks パラメータを使用してオフにすることができ
ます。初期化チェック機能がオフにされると、適切な DRAM 初期化シーケンスがあるかどう
かをデナリはチェックしません。このコマンドは注意して使用してください。オフにすると、
実際のエラーが隠されてしまうことがあるからです。
初期化チェックをオフにするには、次のように設定します。
InitChecks 0
InitChecksPauseTime
この変数は、DRAM モデルで実行される tpause/tinit チェック、および SSRAM モデルで実行
される DLL Lock Time チェックをデナリ • モデルが無視するときに使用します。
InitChecksPauseTime 0
ErrorMessages
このオプションを使用すると、警告メッセージとエラー• メッセージを全面的にオンまたはオ
フにすることができます。
エラーと警告はデナリの履歴ファイルとトレース • ファイルに引き
続き取り込まれますが、シミュレータの出力 / コンソールにはメッセージが表示されなくな
くります。
ErrorMessages on
ErrorMessages off
ErrorMessagesStartTime
デナリでは、特定の時刻にエラー• メッセージと警告メッセージをオンにする機能も用意して
あります。これにより、デナリ • モデルがエラーのレポートを開始する前にリセットやデバイ
スの初期化を行うための時間を確保することができます。エラーと警告はデナリの履歴ファ
イルとトレース • ファイルに引き続き取り込まれますが、シミュレータの出力 / コンソールに
はメッセージが表示されなくなくります。構文については、次の例を参照してください。
ErrorMessagesStartTime
ErrorMessagesStartTime
ErrorMessagesStartTime
ErrorMessagesStartTime
0ps
# default
"20 us"
"200ms"
200000 ns
ExitOnErrorCount
この変数を使用すると、デナリのエラーが指定件数だけ発生したらシミュレーションを終了
するよう指定することができます。エラーのしきい値を .denalirc ファイルに次のように指
定します。
ExitOnErrorCount 10
MMAV ユーザ • ガイド
#exits simulation after 10 Denali errors
11/6/08
44
ErrorCount
Verilog コードでは、整数変数を使用して、デナリ • メモリ • モデルで検出したエラーの数を知
ることができます。テストベンチで整数変数を宣言した後、.denalirc ファイル内の
ErrorCount スイッチを通じてエラー• カウント変数として登録します。
デナリ • モデルでは、
エラーを検出するたびに、この変数の値が 1 つずつ増えます。エラー • カウント変数をモニタ
したり、その値によって分岐したりできます。
使用例:
テストベンチで、次のように指定します。
module testbench;
integer errCount;
// monitor, display this
.denalirc で、次の行のコメントを解除します。
ErrorCount testbench.errCount
TclInterp
この設定は NC Sim ユーザが使用します。デフォルトでは、NC Sim を備えたデナリの Tcl イ
ンタープリタはオフになっています。これは、以前に NC Sim の Tcl インタープリタとの互換
性に問題があったからです。NC Sim でのデナリの Tcl インタープリタをオンにするには、次
の .denalirc 設定を使用して、明示的にオンにする必要があります。
TclInterp
1
TrackAccessFromInit
init_file またはmmloadをメモリに事前にロードしてから、
ブレークポイントを設定してお
り、かつこれらのアクションをメモリ • ライト • アクセスとして数える場合は、次の変数を設
定してください ( デフォルト値は 0 です )。
TrackAccessFromInit 1
これは、ブレークポイントをアクセス対象外のメモリ位置に設定するときに便利です。
EiMessages
ソフト • エラー挿入のメッセージがレポートされないようにします。デフォルトでは、挿入エ
ラーはすべてレポートされます。
EiMessages off
DifferentialClockChecks
この設定により、差動クロック • チェックは実行されなくなります。デフォルトでは、モデル
は負のクロック信号をチェックして、正のクロック信号との同期をとります。
DifferentialClockChecks 0
MMAV ユーザ • ガイド
11/6/08
45
DifferentialClockSkew
この設定を使用すると、差動クロック • チェックを行うために、正のクロック信号と負のク
ロック信号の間の許容スキューを指定することができます。スキューは 2 つのうちどちらか
一方の信号が切り替わってから、逆の信号が切り替わるまでの時間で測定されます。デフォ
ルトでは、スキューは許容されません。実際のデバイスでは、差動クロック • スキューは無意
味であることに注意してください。これは、クロック • エッジが、正のクロック信号と負のク
ロック信号との交点として定義されているからです。このパラメータは、立ち上がり時間と
立ち下がり時間が、シミュレーションにモデル化されておらず、その値がベンダによって提
供されていない、という事実を考慮したものです。スキューは時刻の値と単位を使用して指
定されます。
DifferentialClockSkew 150 ps
AssertionMessages
アサーションがトリガされたときに表示されるメッセージを表示しないようにします。デ
フォルトでは、アサーションがトリガされるとメッセージが出力されます。
AssertionMessages off
TraceBackdoorReadWrite
バックドア • リード / ライトのトレースを無効にします。デフォルトでは、デナリのトレース •
ファイル ( 指定されている場合 ) でトレースされます。
TraceBackdoorReadWrite 0
DenaliByPass
デナリのすべてのモデルを機能しないものとし、シミュレーション時にライセンスをチェッ
クアウトしません。デフォルト値は 0 です。
DenaliByPass 1
4.1.1
レジスタ • ファイル固有の .denalirc パラメータ
SuppressUnknownAddrReadError
名前が "InstNamePattern" に一致するインスタンスから不明なアドレスからリードされたとき
に表示されるエラー • メッセージを表示しないようにします。
SuppressUnknownAddrReadError
InstNamePattern
ワイルドカード • パターンを使用する場合 ( たとえば、インスタンス名のパスに [] を使用 ) に、
SuppressUnknownAddrReadError パラメータに指定するには、エスケープを使用する必要
があります。
たとえば、"top.m_system.bank[0].index[0].mem" の場合は、次のコマンドを使用します。
SuppressUnknownAddrReadError top.m_system.bank\[0\].index\[0\].mem
これらすべてを 1 つのパターンにまとめるには、次のコマンドを使用します。
SuppressUnknownAddrReadError top.m_system.bank???.index???.mem
MMAV ユーザ • ガイド
11/6/08
46
4.1.2
IBM-EDRAM 固有の .denalirc パラメータ
SuppressRefreshInfoMessages
SuppressRefreshInfoMessages 1 を使用すると、エラーでも警告でもないときには、実際
のリフレッシュ• ウィンドウ • サイズについての情報メッセージが表示されなくなります。デ
フォルト値は 0 であり、リフレッシュ • サイクルごとにレポートされます。
SuppressRefreshInfoMessages 0
4.1.3
RDRAM 固有の .denalirc パラメータ
WarnSuppress
通常のタイミングとプロトコルのエラー状況に加えて、デナリの RDRAM モデルは、次の危
険な操作についても警告を発行します。
• ライト • バッファが廃棄される前の上書き (WR-WR-RD-RD-RTR など )
• バンクが廃棄される前のプリチャージ ( ルール CR8)
これらの警告は、次のように .denalirc ファイルの WarnSuppress パラメータを設定する
ことによって、表示しないようにすることができます。
WarnSuppress 1
TimingChecksReportOnly
このオプションをオンにすると、タイミング • エラーが発生したときに、メモリを破壊して
データ • バス上に "X" を駆動するデナリ • モデルの機能がオフになります。
このオプションを
使用すると、
タイミング • エラーが発生してもモデルはメッセージを発行するだけになり、
"X"
を駆動することはなくなります。これは、エラーの初期評価で非常に便利な場合があります。
ただし、エラーがレポートされてもシミュレーションは続行されます。
TimingChecksReportOnly 1
TimingChecksStartTime
デナリでは、特定の時刻にタイミング • チェックをオンにする機能も用意してあります。これ
により、デナリ • モデルがタイミング • エラーのチェックを開始する前に、リセットとデバイ
ス初期化を行うための時間を確保することができます。構文については、次の例を参照して
ください。
TimingChecksStartTime
TimingChecksStartTime
TimingChecksStartTime
TimingChecksStartTime
MMAV ユーザ • ガイド
0ps
"20 us"
"200ms"
200000 ns
11/6/08
47
4.1.4
RLDRAM 固有の .denalirc パラメータ
RldramInitCyclesCheck
初期化時の各リフレッシュ間の 2000 サイクル • チェックをオフにします。
RldramInitCyclesCheck 0
RldramInitRefreshChecks
初期化時の各バンクへのリフレッシュ• チェックをオフにするには、これを "0" に設定します。
RldramInitRefreshChecks 0
InitMrsAddressStable
この設定は、Init MRS 時のアドレス安定性チェックをオンにするときに使用します。
InitMrsAddressStable を次のように設定して、チェックを強制的に行わせることもでき
ます。
InitMrsAddressStable 1
4.1.5
DDR-II SDRAM 固有の .denalirc パラメータ
OffChipDriveImpedanceChecks
OffChipDriveImpedanceChecks 変数は、OCD チェックをオフにするときに使用します。こ
の変数が 0 であると、OCD レベルが有効範囲外であっても、警告メッセージは発行されず
データも破壊されません。OCD をオンにする SOMA 機能もあることに注意してください。
SOMA 機能がオフであると、OCD はモデルによって完全に無視されます。
OffChipDriverImpedanceChecks 0
MRSmsgsInSimLog
MRS/EMRS 情報メッセージが、履歴とシミュレーション • ログ / トランスクリプト • ファイル
に常に記録されます。このメッセージをシミュレーション • ログに記録しないようにするに
は、MRSmsgsInSimLog パラメータを 0 に設定します。デフォルトでは、このパラメータは
"1" に設定されています。
MRSmsgsInSimLog 0
4.1.6
DDR-II と DDR3 に固有の .denalirc パラメータ
noXsInReadData
モデル駆動リード • データの無効な範囲が、X で埋められません。
noXsInReadData 0
RandomInsteadOfXInReadData
モデル駆動リード • データの無効な範囲が、X 以外のランダム • データで埋められます。
RandomInsteadOfXInReadData 0
MMAV ユーザ • ガイド
11/6/08
48
4.1.7
ESSRAM 固有の .denalirc パラメータ
SuppressPortContention
SuppressPortContention 変数は、
InstNamePattern で指定されたパターンに名前が一致
するインスタンスで、
リード • ライト • ポート競合エラー• メッセージを表示しないようにする
ときに使用します。
SuppressPortContention InstNamePattern
ワイルドカード • パターンを使用する場合 ( たとえば、インスタンス名のパスに [] を使用 ) に、
SuppressPortContention パラメータに指定するには、
エスケープを使用する必要があり
ます。
たとえば、"top.m_system.bank[0].index[0].mem" の場合は、次のコマンドを使用します。
SuppressPortContention top.m_system.bank\[0\].index\[0\].mem
これらすべてを 1 つのパターンにまとめるには、次のコマンドを使用します。
SuppressPortContention top.m_system.bank???.index???.mem
4.1.8
Mentor Graphics ModelSim 固有の .denalirc パラメータ
ModelSimTimeDefinitionToggle
デナリは ModelSim シミュレータのために時間の上位ビットと下位ビットをできるだけ正確
に解釈しようと努めます。ModelSim ではこの動作はプラットフォームとリリースによって異
なります。デナリの自動的な動作があらゆるケースで適切であるとは限りません。そこで、
次のスイッチが用意してあり、デナリの自動的な動作をユーザが制御することができます。
時間の上位ビットと下位ビットを自動的に解釈する動作を無効にして、切り替わる動作をオ
フにするには、次のコマンドを使用します。
ModelSimTimeDefinitionToggle off
切り替わりをデフォルトの動作に設定する ( 一部のメッセージを表示しない ) には、次のコ
マンドを使用します。
ModelSimTimeDefinitionToggle on
4.1.9
Mentor Graphics Seamless HW/SW Co-Verification 固有の
.denalirc パラメータ
デナリの 3.0 がリリースされる以前には、Seamless の顧客はデナリの PureView デバッガを
Seamless で使用することができませんでした。これは、Seamless がメモリを「所有する」デ
ザインになっていたからです。リリース 3.0 でデナリと Mentor Graphics はこの問題を解決し
ました。.denalirc の新機能が 2 つあり、DenaliOwn と DenaliOwnClass といいます。こ
れらは Seamless 内のメモリの制御をデナリに渡します。その結果、PureView を使用してメモ
リの内容をデバッグできるようになりました。
Seamless 環境内で PureView を使用するには、デナリの次の設定を使用して、メモリの所有権
をデナリに渡す必要があります。
MMAV ユーザ • ガイド
11/6/08
49
DenaliOwn
DenaliOwn 設定を使用して、特定のインスタンスをデナリに渡してデナリが「所有」できる
ようにします。
たとえば、Seamless のメモリ • インスタンス "testbench.rams.sdram0" を表示するには、変数を
次のように設定します。
DenaliOwn /testbench/rams/sdram0
ワイルドカード • パターンを使用する場合 ( たとえば、インスタンス名のパスに [] を使用 ) に、
DenaliOwn パラメータに指定するには、エスケープを使用する必要があります。
たとえば、"top.m_system.bank[0].index[0].mem" の場合は、次のコマンドを使用します。
DenaliOwn top.m_system.bank\[0\].index\[0\].mem
これらすべてを 1 つのパターンにまとめるには、次のコマンドを使用します。
DenaliOwn top.m_system.bank???.index???.mem
DenaliOwnClass
また、デナリにメモリ • クラス全体を所有させるよう Seamless に指示することもできます。メ
モリ • クラスとは特定のメモリの種類 (SDRAM、DDR_SDRAM、Flash、SRAM など ) のこと
です。たとえば、SDRAM を Seamless で実行している場合に、PureView で SDRAM メモリ • イ
ンスタンスを表示するには、変数を次のように設定します。
DenaliOwnClass sdram
ワイルドカード • パターンを使用する場合 ( たとえば、インスタンス名のパスに [] を使用 ) に、
DenaliOwnClass パラメータに指定するには、エスケープを使用する必要があります。
たとえば、"top.m_system.bank[0].index[0].mem" の場合は、次のコマンドを使用します。
DenaliOwnClass top.m_system.bank\[0\].index\[0\].mem
これらすべてを 1 つのパターンにまとめるには、次のコマンドを使用します。
DenaliOwnClass top.m_system.bank???.index???.mem
4.1.10
OneNand Flash の .denalirc パラメータ
minimizeCallbacks
oneNand Flash にはバッファ RAM と Flash 配列があり、データがバッファ RAM から Flash 配列、
または Flash 配列からバッファRAM に移動されたときに使用されます。minimizeCallbacks
がオンの場合、該当するコールバックだけが発生します。たとえば、バッファ RAM をリー
ドして Flash 配列にライトするプログラム • コマンドを発行し、かつ minimizeCallbacks が有効
である場合は、Flash 配列へのライト • コールバックだけが発生します。
minimizeCallback 1
MMAV ユーザ • ガイド
11/6/08
50
oneNandEnableReadArrayCBs
この変数がオンであり、しかもたとえば、ロードが実行されると、Flash 配列からの真のリー
ドが行われます。その結果、Flash 配列の各リードに対してコールバックが発行されます。
oneNandEnableReadArrayCBs 1
4.1.11
アサーションの .denalirc パラメータ
AssertionCoverageFile
アサーション • カバレッジをオンにして、シミュレーションの最後にカバレッジ統計情報を
ファイルに出力するには、このパラメータをそのファイル名に設定します。このパラメータ
をオフに設定するか、または .denalirc ファイルに含めない場合は、シミュレーションでア
サーション • カバレッジは使用されません。
AssertionCoverageFile filename
AssertionPassMessages
アサーション • チェックに合格するたびに履歴メッセージが表示されるようにするには、
この
パラメータを 1 に設定します。AssertionCoverageFile が存在しないか、またはオフに設
定されている場合は、モデルはこのパラメータを無視します。
AssertionPassMessages 0
AssertionPassCallbacks
アサーション • チェックに合格するたびにコールバックが生成されるようにするには、
このパ
ラメータを 1 に設定します。AssertionCoverageFile が存在しないか、またはオフに設定
されている場合は、モデルはこのパラメータを無視します。
AssertionPassCallbacks 0
LogUncoveredAssertions
アサーション • カバレッジ • ログにアサーションの種類をすべて記録する ( 合格 / 不合格を問わ
ず ) には、このパラメータを 1 に設定します。カバレッジ外のアサーションの総数も記録さ
れます。
LogUncoveredAssertions 0
AssertionChecklistFile
カバレッジ統計値を指定ファイルに出力して、エラー ID ではなくリファレンス ID (PCISIG ID
など ) でソートするには、このパラメータをそのファイル名に設定します。
AssertionCoverageFile を .denalirc ファイルに含めて、
かつ AssertionCoverageFile
に指定されたファイル名とは別のファイル名にする必要があります。
AssertionChecklistFile filename
MMAV ユーザ • ガイド
11/6/08
51
AssertionCoverageByTest
1 に設定すると、各 PureSuite テストの結果が、カバレッジ • ファイルとチェックリスト • ファ
イルに各テスト名の後に出力されます。PureSuite を実行していなければ、モデルはこのパラ
メータを無視します。
AssertionCoverageByTest 0
AssertionCoverageSummary
1 に設定すると、シミュレーション全体のアサーション • カバレッジの累積統計情報が、カバ
AssertionCoverageByTest
レッジ • ファイルとチェックリスト • ファイルに出力されます。
も 1 に設定すると、カバレッジ • ファイルとチェックリスト • ファイルに各テストの結果、そ
の後に結果の概要が記載されます。
AssertionCoverageSummary 1
.denalirc の概要をまとめた一覧表
4.1.12
表 4-2:
キーワード
値
.denalirc のキーワード
デフォルト
説明
HistoryFile
ファイル名
なし
デナリのリード / ライト情報を記載したファイルを保存
します。
HistoryDebug
On/Off
Off
HistoryFile を使用して作成したファイルにデバッグ
HistoryDebugLoad
On/Off
Off
ファイルからロードされた場合、各アドレスの追加情報を
追加します。
HistoryInSimLog
0/1
0
ユーザのシミュレーション•ログと HistoryFile で指定
されたファイル名に履歴ファイルをリダイレクトします。
TraceFile
ファイル名
なし
トレース情報をファイルに保存します。主にデナリのサ
ポート部門がお客様の問題をデバッグするときに使用し
ます。
TraceTimingChecks
0/1
0
TraceFile を使用して作成したファイルにタイミング •
LicenseQueueTimeout
時刻値 ( 単位は分 ) なし
情報を追加します。
チェック情報を追加します。
LicenseQueueTimeout を使用すると、ライセンスを
使用することができない場合にサスペンド状態で待たなけ
ればならない時間 ( 単位は分 ) を指定することができます。
LicenseQueueRetryDelay
時刻値 ( 単位は秒 ) なし
LicenseQueueRetryDelay は、ライセンスを要求す
る ping を開始するまでの待ち時間 ( 単位は秒 ) を指定しま
す ( こうすることにより、ライセンスのログ • ファイルが
オーバーフローすることはなくなります )。
SimulationDatabase
ファイル名
このパラメータを設定すると、シミュレーション • データ
ベースのファイルが指定されます。
Off
注意 : HistoryFile も設定する必要があります。
SimulationDatabasePattern
パターン文字列
SimulationDatabaseBuffering
On/Off
MMAV ユーザ • ガイド
す べ て の イ 指定した「パターン」に関する情報のみをシミュレーショ
ンスタンス ン • データベース • ファイルに追加します。データベース •
ファイルにダンプされる情報の量を制限するときに使用
します。
Off
データベースをディスクに直ちにフラッシュする場合は、
simdb バッファリングをオフにしてください。直ちにフ
ラッシュするとパフォーマンスが低下しますが、「異常終
了」の状況をデバッグしている場合は、便利です。
11/6/08
52
表 4-2:
キーワード
値
.denalirc のキーワード ( 続き )
デフォルト
説明
TimingChecks
0/1
1
セットアップ / ホールドのタイミング違反をチェックし
ます。
RefreshChecks
0/1
1
DRAM リフレッシュ違反をチェックします。
RefreshOnReadWrite
0、1
0
リードとライトをその特定の行に対するリフレッシュ処理
として数える場合は、
パラメータ RefreshOnReadWrite
を 1 に設定します。その部分の該当する動作では、リード
とライトをその行に対するリフレッシュ処理として数え
る場合もありますが、デナリのデフォルトは、数えない設
定になっています。デフォルト値がこのように設定されて
いるのは、コントローラが適切なリフレッシュ•レートを取
得するために一部のメモリ • アクセスに依存するのを防ぐ
ためです。これがサポートされているメモリの種類は、
EDRAM、RLDRAM、SDRAM、DDR SDRAM、および DDR
II SDRAM だけです。
ReadDQSContentionCheck
0、1
0
リード時に DQS でのバスの競合がないかどうかをチェッ
クするようモデルに指示します。
InitialMemoryValue
X、1、0
Off/On
X
すべてのメモリの初期値。
InitMessages
On
デザイン内のインスタンスに関するメッセージをオンま
たはオフにします。
TracePattern
パターン文字列
す べ て の イ 指定した「パターン」に関する情報のみをトレース • ファイ
ンスタンス ルに追加します。トレース•ファイルにダンプされる情報の
量を制限するときに使用します。
HistoryPattern
パターン文字列
IrregularClock
0/1
ClockStableCycles
サイクル数
RandomOutputDelay
0/1
OutputTiming
0/1
InitChecks
0/1
す べ て の イ 指定した「パターン」に関する情報のみを履歴ファイルに
ンスタンス 追加します。履歴ファイルにダンプされる情報の量を制限
するときに使用します。
0
クロックが定期的でない場合は、1 に設定する必要があり
ます。こうすると、データがクロック • エッジに整列され
ます。
0
クロックのサイクル時間を判断するときに使用される安
定したクロック • サイクルの数を指定します。
1
IrregularClock が 0 の場合、このパラメータで一部の
メモリ • デバイスに対して、出力のランダム化のオン / オフ
を指定することができます。
1
デフォルトでは、メモリ•モデルは出力を遅延しながら駆動
します。0 に設定すると、遅延はゼロになります。主にサ
イクル • ベースのシミュレーションで使用します。
1
初期化チェックをオンまたはオフにします。
InitChecksPauseTime
0/1
1
この変数は、DRAM モデルで実行される tpause/tinit チェッ
ク、および SSRAM モデルで実行される DLL Lock Time
チェックをデナリ • モデルが無視するときに使用します。
ErrorMessages
On/Off
On
エラー•メッセージを完全にオフにするときに使用します。
履歴ファイルとトレース•ファイルが有効な場合は、これら
のファイルにメッセージが記録されます。
ErrorMessagesStartTime
時刻値
0 ns
エラー • メッセージのレポートの開始時刻を指定するとき
に使用します。初期化中やリセット中にメッセージが表示
されないようにすることができます。履歴ファイルとト
レース•ファイルが有効な場合は、これらのファイルにメッ
セージが記録されます。
ExitOnErrorCount
変数名
なし
この Verilog 機能では、発生したエラーの数をチェックす
るために HDL コード内で照会する変数を設定することが
できます。
MMAV ユーザ • ガイド
11/6/08
53
表 4-2:
キーワード
値
.denalirc のキーワード ( 続き )
デフォルト
説明
ErrorCount
変数名
なし
この Verilog 機能では、発生したエラーの数をチェックす
るために HDL コード内で照会する変数を設定することが
できます。
TclInterp
0/1
0
NC-Sim 使用時のデナリの Tcl インタープリタをオンまた
はオフにします。
TrackAccessFromInit
Off/On
Off
事前ロード処理とバックドア処理が、初期化されていない
メモリ • アクセス時にブレークポイントのメモリ「ライト」
アクセスとして数えられるようにします。
EiMessages
On/Off
On
エラー挿入のエラー • メッセージをオフにします。
DifferentialClockChecks
0/1
1
差動クロック • チェックを無効にします。デフォルトでは、
モデルは負のクロック信号をチェックして、正のクロック
信号との同期をとります。
DifferentialClockSkew
時刻の値と単位
0 ns
差動クロック•チェックを行うために、正のクロック信号と
負のクロック信号の間の許容クロック • スキューを指定す
ることができます。
AssertionMessages
On/Off
On
デナリのアサーションがトリガされたときにアサーショ
ン•メッセージを表示するかどうかを指定します。デフォル
ト値は、メッセージを表示する設定です。
TraceBackdoorReadWrite
0/1
1
トレース•ファイルのバックドア•リード/ライト•メッセー
ジを無効にすることができます。デフォルトでは、メッ
セージはトレース • ファイルに生成されます。
レジスタ • ファイル固有のパラメータ
SupressUnknownAddrReadError インスタンス •
パターン文字列
インスタン 不明なアドレスが、名前が「インスタンス • パターン文字
スなし
列」に一致するインスタンスからリードされたときに表示
されるエラー • メッセージを表示しないようにします。
IBM eDRAM 固有のパラメータ
SuppressRefreshInfoMessages
0/1
0
エラーでも警告でもないときには、実際のリフレッシュ •
ウィンドウ • サイズについての情報メッセージが表示され
なくなります。デフォルト値は 0 であり、リフレッシュ •
サイクルごとにレポートされます。
RDRAM 固有のパラメータ
WarnSuppress
0/1
0
特定のプロトコル • チェックでの警告メッセージを表示し
ないようにします ( 詳細については上記を参照 )。
TimingChecksReportOnly
0/1
0
タイミング • エラーが発生したときに、メモリを破壊して
データ • バス上に "X" を駆動するデナリ • モデルの機能をオ
フにします。
TimingChecksStartTime
時刻値
0 ps
エラー • メッセージのレポートの開始時刻を指定するとき
に使用します。初期化中やリセット中にメッセージが表示
されないようにすることができます。履歴ファイルとト
レース•ファイルが有効な場合は、これらのファイルにメッ
セージが記録されます。
RLDRAM 固有のパラメータ
RldramInitCyclesCheck
0/1
1
初期化時にリフレッシュ • コマンド間の 200 サイクルを
チェックします。
RldramInitRefreshCheck
0/1
1
初期化時の各バンクへのリフレッシュ • チェックをオフに
します。
InitMrsAddressStable
0/1
0
この設定は、Init MRS 時のアドレス安定性チェックをオン
にするときに使用します。
MMAV ユーザ • ガイド
11/6/08
54
表 4-2:
キーワード
値
.denalirc のキーワード ( 続き )
デフォルト
説明
DDR-II SDRAM 固有のパラメータ
OffChipDriveImpedanceChecks 0/1
1
OCD チェックをオフにします。この変数が 0 であると、
OCD レベルが有効範囲外であっても、警告メッセージは
発行されずデータも破壊されません。OCD をオンにする
SOMA 機能もあることに注意してください。SOMA 機能
がオフであると、OCD はモデルによって完全に無視され
ます。
eSSRAM 固有のパラメータ
SuppressPortContention
なし
名前が InstNamePattern で指定されたパターンに一
致するインスタンスで、リード•ライト•ポート競合エラー•
メッセージを表示しないようにします。
On
ModelSim シミュレータで、時間の上位ビットと下位ビッ
トを自動的に解釈します。
パターン文字列
ModelSim シミュレータ固有のパラメータ
ModelSimTimeDefinitionToggle On/Off
デナリの PureView または Mentor Seamless 固有のパラメータ
DenaliOwn
/path/to/memory/ なし
instance
デナリがデバッグのために「所有」する、Seamless に対
する特定のインスタンスを指定します。
デナリがデバッグのために「所有」する特定のメモリ • クラ
スを指定します。
SaveDataRadix
ddr_sdram、
なし
sdram、flash、
sram、およびそ
の他のメモリ • ク
ラス
2、8、10、または 16 16
SaveAddressRadix
2、8、10、または 16 16
mmsave* アドレスの形式設定を 2 (2 進数 )、8 (8 進数 )、10
(10 進数 )、または 16 (16 進数 ) として指定します。
DenaliOwnClass
4.2
mmsave* データの形式設定を2 (2進数)、8 (8進数)、10 (10
進数 )、または 16 (16 進数 ) として指定します。
シミュレーション時の .denalirc オプションの動的設定
Tcl コマンド mmsetvar を使用すると、テストベンチから .denalirc の設定を直接制御する
ことができます。テストベンチ内で mmsetvar を使用するために、デナリの PLI/FLI 呼び出
し mmtcleval コマンドを呼び出して、Tcl コマンド mmsetvar を解釈することができます。
たとえば、履歴ファイル ( 名前は denali.his) の生成をテストベンチから動的にオンにするに
は、次の構文を使用します。
Verilog:
success = $mmtcleval("mmsetvar historyfile denali.his");
VHDL:
success := mmtcleval("mmsetvar historyfile denali.his");
Tcl:
mmsetvar historyfile denali.his
MMAV ユーザ • ガイド
11/6/08
55
4.3
4.3.1
ライセンスに関するソリューション
デナリのライセンスのためのシミュレータ • キューイング
ライセンス•キューイングを使用すると、
シミュレーションをロードしたときにデナリのライセン
スを使用できない場合にライセンスに空きができるのを「待つ」ことができます。ライセンス •
キューイングをオンにできるのは、
シェル環境に環境変数 DENALI_LICENSE_QUEUE_TIMEOUT を
設定し、かつデナリのライセンスを待つ時間 ( 単位は分 ) を指定した場合だけです。たとえ
ば、最長 60 分間待つには、次のコマンドを使用します。
setenv DENALI_LICENSE_QUEUE_TIMEOUT 60
デフォルトでは、この機能はオフになっています。
MMAV ライセンスを要求する ping を実行するまでの経過秒数を指定する ( こうして、ライセ
ンス • ログ • ファイルのオーバーフローを防ぐ ) には、次のように環境変数を設定します。
setenv DENALI_LICENSE_QUEUE_RETRY_DELAY 60
4.3.2
ライセンスのチェックアウトの高速化
デナリ関連のライセンス•ファイルを環境変数 DENALID_LICENSE_FILE で指定できるように
なりました。
例:
setenv DENALID_LICENSE_FILE /home/denali/licenses/license.dat
この場合、デナリは /home/denali/licenses/license.dat ファイルをホストしている
サーバに関連付けられたライセンス • サーバだけを検索します。LM_LICENSE_FILE 環境変数
は無視されます。その結果、ライセンスのチェックアウトが高速化されます。デナリのライ
センスを提供しているライセンス • サーバだけがチェックされるからです。また、ライセン
ス • ファイル • パスで区切り文字としてコンマがサポートされるようになりました。
4.4
デナリの Tcl インターフェイス
デナリはその機能すべてのために直接の Tcl インターフェイスを用意しています。Tcl は検証
言語として普及し続けており、非常に強力です。また、Tcl を複数のシミュレータ間で移植す
ることもできます。VHDL シミュレータは、Verilog シミュレータとは異なり共通の C イン
ターフェイスを共有せず、大半のシミュレータが Tcl をサポートしているからです。このマ
ニュアルの後の方で説明するデナリのすべての機能が、使いやすいように Tcl に移植されて
います。
MMAV ユーザ • ガイド
11/6/08
56
4.4.1
ModelSim での使用
ModelSim には組み込み Tcl インタープリタがあるので、デナリのすべての Tcl コマンドを
ModelSimコマンド•ラインまたはModelSimの.doファイルから直接実行することができます。
例:
mmwriteword testbench.uut1 0 11110000
4.4.2
NCSIM や他の Tcl インタープリタでの使用
NCSIM ( と他のシミュレータ ) には独自の組み込み Tcl インタープリタがあるので、デナリ •
ライブラリ libmmcalls.so を任意の Tcl インタープリタからロードして、2 つの Tcl イン
タープリタが互いに通信できるようにする必要があります。ロードが完了すると、デナリの
すべての mm* 呼び出しを ModelSim の場合と同様に Tcl コマンドとして使用することができ
ます。
例:
ncsim> load /<denali path>/libmmcalls.so
ncsim> set x [mminstanceid .....]
ncsim> set a [mmreadword .....]
あるいは、限られた個数のデナリの C 外部関数ルーチン (mmtcleval など ) を外部から呼び
出すための代替手段として、デナリの CFC ライブラリを使用することもできます。
libdencfc.soライブラリは$DENALIにあり、
den_CFCPtrという名前のブートストラップ関
数を備えています。もっとも、libmmcalls.so をロードすることをお勧めします。デナリ
の Tcl 呼び出しはシミュレータの Tcl インタープリタ内部にロードされるからです。こうし
て、関数呼び出しと変数はシミュレータのインタープリタから直接見ることができるように
なります。シミュレータにとって外部であるデナリの Tcl インタープリタを使用すると、直
接見ることはできません。
4.4.3
Tcl のコマンド
mmtcleval - 別のデナリの Tcl コマンドを評価するために、VHDL または Verilog のテストベン
チ内部で使用します。
正常に実行できたときには値 "0"、エラー発生時には値 "-1" を返します。
Tcl を使用して「バックドア」リードを行います。リード先はアドレス =0 のメモリ • インスタ
ンス /testbench/top/sdram です。
Verilog:
success = $mmtcleval("set memid [mminstanceid testbench.top.sdram]");
success = $mmtcleval("mmreadword $memid 0");
MMAV ユーザ • ガイド
11/6/08
57
VHDL:
Cadence NC-VHDL を使用している場合:
success := mmtcleval("set memid [mminstanceid :testbench:top:sdram]");
success := mmtcleval("mmreadword $memid 0");
Mentor Graphics ModelSim を使用している場合:
success := mmtcleval("set memid [mminstanceid /testbench/top/sdram]");
success := mmtcleval("mmreadword $memid 0");
mmtclcallback - アサーションがトリガされたときに Tcl 関数を呼び出す場合に使用します。ア
サーションについては、82 ページの「メモリ • トランザクションのアサーションの設定」を参
照してください。正常に実行できたときには値 "0"、エラー発生時には値 "-1" を返します。
Tcl コールバックを使用して、アサーションがトリガされたときに、Tcl スクリプト
"functions.tcl" に記述されている別の Tcl プロシージャ ("Func1") を呼び出します ( アサーショ
ンについては、82 ページの「メモリ • トランザクションのアサーションの設定」を参照してく
ださい )。
Verilog:
success = $mmtcleval("source functions.tcl");
success = $mmtclcallback(memid, bkpt, "Func1");
VHDL:
success := mmtcleval("source functions.tcl");
success := mmtclcallback(memid, bkpt, "Func1");
Tcl:
source functions.tcl
mmtclcallback memid bkpt Func1
Verilog または VHDL テストベンチから mmtcleval コマンドも使用して、Tcl ハンドラ • スク
リプト (functions.tcl) を入手する必要があることに注意してください。この Tcl ハンドラ関数
は、次のパラメータも要求します。
• bkpid - アサーションのブレークポイント ID
• instid - インスタンス ID
• addr - アサーションに関連付けられているアドレス
• bkptype - アサーションのタイプ (assert_datavalue、assert_access、assert_parity)
• access - アクセスのタイプ ( リード、ライトなど )
• data - 上記アドレスに関連付けられているデータ
• mask - マスクされたビット ( 存在する場合 )
• compare - 比較文字列 ( 存在する場合 )
MMAV ユーザ • ガイド
11/6/08
58
この Tcl コールバック • ハンドラの一例は、次のようになります。
proc Func1 {bkpid instid addr bkptype access data mask compare}
{
set curtime [mmtime] //displays the time of assertion
puts ""$curtime:$bkpid $instid $addr $bkptype $access $data $mask
$compare""
mmbreak
}
4.4.3.1 Tcl コールバック • ヘルパのコマンド
コールバック「ヘルパ」のコマンドがいくつか追加されています。このコマンドはアサーショ
ン • コールバック関数内部から呼び出すことができます。説明は次のとおりです。
mmgetids - デザインで使用されるメモリ ID を返します。ID は整数値です。
mmgetids
メモリ • インスタンスが 1 つのデザインには、{0} を返します。
mmgetinfobyid - 参照対象メモリ • インスタンスの幅 ( ビット数 )、アドレス位置の値、インス
タンス名、およびメモリのタイプを返します。
mmgetinfobyid 0
{9 2097152 testbench.uut1 sdram} を返します。ここで、9 はデバイスの幅 ( ビット数 )、2097152
はアドレス位置の 10 進数値、testbench.uut はインスタンス名で、メモリのタイプは SDRAM
です。
mmnote - 発生したアサーションについての情報を出力します。アサーション•コールバック関
数内部で呼び出すことができます。
mmnote "This is a callback note"
mmbreak - シミュレーションを停止します。このコマンドは通常、アサーション • コールバッ
ク関数内部で呼び出します。
mmbreak
mmexit - シミュレーションを終了します。このコマンドは通常、アサーション • コールバック
関数内部で呼び出します。
mmexit
mmtime - シミュレーションの現在の時刻を取得します。時刻を文字列として返します。この
コマンドは通常、アサーション • コールバック関数内部で呼び出します。
mmtime
MMAV ユーザ • ガイド
11/6/08
59
4.4.4
コールバック • コマンド
mmdisablecallbackall:データ • ドリブン検証 API (DDV-API) に設定したすべてのコールバック
のセットアップを無効にするときに使用します。mmtcleval コマンドを使用して、Verilog ま
たは VHDL から呼び出すことができます。
Verilog:
success = $mmtcleval("mmdisablecallbackall");
VHDL:
success := mmtcleval("mmdisablecallbackall");
Tcl:
mmdisablecallbackall
mmenablecallback:データ • ドリブン検証 API (DDV-API) に設定した特定のメモリ • インスタン
スのセットアップで、コールバックを有効にするときに使用します。mmtcleval コマンドを
使用して、Verilog または VHDL から呼び出すことができます。
注意: デフォルトではすべてのコールバックが有効なので、個々のコールバックを有効にす
る前に、mmdisablecallbackall を使用する必要があります。
Verilog:
success = $mmtcleval("set mem_id [mminstanceid tb.mem.sdram0 ]");
success = $mmtcleval("mmenablecallback $mem_id");
VHDL:
Cadence NC-VHDL を使用している場合:
success = $mmtcleval("set mem_id [mminstanceid :to:mem:sdram0]");
success = $mmtcleval("mmenablecallback $mem_id");
Mentor Graphics ModelSim を使用している場合:
success = $mmtcleval("set mem_id [mminstanceid /to/mem/sdram0]");
success = $mmtcleval("mmenablecallback $mem_id");
Tcl:
set mem_id [mminstanceid tb.mem.sdram0]
mmenablecallback $mem_id
mmdisablecallback:データ•ドリブン検証API (DDV-API)に設定した特定のメモリ•インスタン
スのセットアップで、コールバックを無効にするときに使用します。mmtcleval コマンドを
使用して、Verilog または VHDL から呼び出すことができます。
MMAV ユーザ • ガイド
11/6/08
60
Verilog:
success = $mmtcleval("set mem_id [mminstanceid tb.mem.sdram0 ]");
success = $mmtcleval("mmenablecallback $mem_id");
VHDL:
Cadence NC-VHDL を使用している場合:
success = $mmtcleval("set mem_id [mminstanceid :to:mem:sdram0]");
success = $mmtcleval("mmenablecallback $mem_id");
Mentor Graphics ModelSim を使用している場合:
success = $mmtcleval("set mem_id [mminstanceid /to/mem/sdram0]");
success = $mmtcleval("mmenablecallback $mem_id");
Tcl:
set mem_id [mminstanceid tb.mem.sdram0]
mmdisablecallback $mem_id
mmsetaccesscallbackmask:データ•ドリブン検証API (DDV-API)に設定した特定のメモリ•イン
スタンスのセットアップのライト • マスク • フィールドに基づいて、
コールバックを有効にす
るときに使用します。コールバックがトリガされるのは、指定した文字列にライト • マスクが
一致したときだけです。mmtcleval コマンドを使用して、Verilog または VHDL から呼び出
すことができます。
Verilog:
success = $mmtcleval("set mem_id [mminstanceid tb.mem.sdram0 ]");
success = $mmtcleval("mmsetaccesscallbackmask $mem_id hff00");
VHDL:
Cadence NC-VHDL を使用している場合:
success = $mmtcleval("set mem_id [mminstanceid :to:mem:sdram0]");
success := mmtcleval("mmsetaccesscallbackmask $mem_id hff00");
Mentor Graphics ModelSim を使用している場合:
success = $mmtcleval("set mem_id [mminstanceid /to/mem/sdram0]");
success := mmtcleval("mmsetaccesscallbackmask $mem_id hff00");
Tcl:
set mem_id [mminstanceid tb.mem.sdram0]
mmsetaccesscallbackmask $mem_id 'hff00
MMAV ユーザ • ガイド
11/6/08
61
4.5
4.5.1
デナリのメモリの初期化
メモリ • アドレスの判定
デナリ • モデル ( フラッシュ、SRAM、レジスタ • ファイルなど ) は、単純な直接アドレスを使
用して、メモリの内容にアクセスします。DRAM など他のものは、別のアドレス指定方式を
使用して、バンク、行、および列というデバイスの物理的コンフィギュレーションに関連付
けます。
単純なメモリ • マップを提供するために、デナリはこれらのデバイスにアクセスするためのフ
ラット化されたアドレスのマップを使用します。このアドレスは、バンク • ビットを行ビット
および列ビットを連結して実際のアドレスを形成することによって生成されます。たとえば、
4 つのバンク (2 つのバンク • ビット )、9 つの行ビット、および 12 個の列ビットがある DDRDRAM デバイスの場合、デナリ • モデルのアドレスは次のようになります。
Address [22:0] = "B B R R R R R R R R R C C C C C C C C C C C C"
こうすることにより、23 ビットのアドレスが得られます。このアドレスは物理的な DRAM デ
バイスの任意の位置を一意にアドレス指定することができます。
4.5.2
メモリの初期の内容
デフォルトでは、メモリの初期値は "X" に設定されています。つまり、初期化されていない
メモリをリードすると、シミュレーションで値 "X" が返されます。
次の 2 つの方法のどちらかを使用して、このデフォルト値を変更することができます。
• .denalirc の変数 InitialMemoryValue を使用する方法:
InitialMemoryValue
InitialMemoryValue
InitialMemoryValue
InitialMemoryValue
0
1
X
U
-
for
for
for
for
all
all
all
all
'0's
'1's
'X's
'U's
あるいは、16 進数値を使用して、指定した値にすべてのワードを初期化することもでき
ます。
例:
InitialMemoryValue
0x3018
この文字列をメモリのワード幅 ( 通常はデータ • サイズ ) より長く拡張することはできま
せん。ワード幅より短かければ、指定されないビットには 0 が入力されます。
値が上記以外の場合は、メモリはすべて X に初期化されます。次のように指定すること
によって、初期データのためにランダム • データを生成することもできます。
− InitialMemoryValue randomNoUpdate - 複数回のリードの後に新しいランダム •
データを得ることができます。
− InitialMemoryValue randomWithUpdate - 複数回のリードの後に同じランダム •
データを得ることができます。
注意: 論理的にアドレス指定されたメモリでは、InitialMemoryValue randomWithUpdate を使
用する場合、ライト•コールバックが有効であるとライト•コールバックが得られます。
詳細については、
38 ページの「.denalirc ファイルを使用したメモリ • シミュレーション • モ
デルの制御」を参照してください。
MMAV ユーザ • ガイド
11/6/08
62
あるいは、任意の C 関数を使用して、初期データ ( ランダム • データやパリティ付きラン
ダム • データなど ) を指定することもできます。
例については、$DENALI/ddvapi/example/fillValue を参照してください。
• シミュレーションのテストベンチで mmsetfillvalue を使用する方法:
注意: mmsetfillvalue が設定するのは、ライトされていない位置のための値だけです。値のリ
セットは行いません。メモリ位置をリセットするには、$mmreset を使用してくださ
い。詳細については、68 ページの「メモリの内容のリセット」を参照してください。
充填値のサイズは、メモリ • デバイスの幅です。16 進形式 "0x" を使用して、実際の充填値
を指定してください。Verilog と VHDL で、充填値 0x55 を 8 ビット幅の SDRAM インス
タンス "tb.mem.sdram0" に設定の方法の例は、次のとおりです。
オプションの 3 番目の引数は、mmsetfillvalue に最近追加されたものです。この引数
は情報メッセージを表示しないようにするときに使用します。3 番目の引数の値が 1 の場
合、どの情報メッセージも表示されません。値が 0 か、または 3 番目の引数として値が
提供されない場合は、メッセージがすべて通常どおり表示されます。
正常に実行できたときには値 "0"、エラー発生時には値 "-1" を返します。
Verilog:
status = $mmsetfillvalue("tb.mem.sdram0", "0x55", "1"); //suppress the
informational messages
VHDL:
Cadence NC-VHDL を使用している場合:
status := mmsetfillvalue("<instance_id>",":tb:mem:sdram0","0x55");
No message suppression (default)
//
Mentor Graphics ModelSim を使用している場合:
status := mmsetfillvalue("<instance_id>","/tb/mem/sdram0","0x55");
No message suppression (default)
//
Tcl:
mmsetfillvalue /tb/mem/sdram0 0x55 1
# supress messages
注意: mmsetfillvalue が関係するのは、物理メモリだけです。このコマンドを使用して、論理
的にアドレス指定されたメモリの充填値を設定することはできません。これを行うに
は、論理的にアドレス指定されたメモリの一部である各物理メモリ • インスタンスで、
mmsetfillvalue を使用する必要があります。
4.5.3
ファイルからのメモリのロード
デナリのメモリ • モデルはどれも、1 つのファイルからロードすることができます。ファイル
からロードするコマンドは、2 つの引数を取ります。1 つ目はロードするデナリ • モデルのイ
ンスタンス名、2 つ目はアドレスとデータ値を格納したファイルです。ロード • ファイルに格
納したデータ値の幅は、ロードしようとしているデバイスの幅に一致している必要がありま
す。ファイルの構文は次のとおりです。
<start_addr>:<end_addr>/<data>;
MMAV ユーザ • ガイド
11/6/08
63
あるいは
<addr>/<data>;
すべてのアドレスおよびデータ値は HEX 形式です。ロード • ファイルには空白行を含めるこ
とができ、コメント文字は "#" です。
例:
# File name: load.dat
0/21;
1/22;
3/23;
4:1F/55;
20:1FFF/FF;
# End of load.dat
mmload コマンドの例を次に示します。
Verilog:
status = $mmload("tb.mem.sdram0",”load.dat");
VHDL:
Cadence NC-VHDL を使用している場合:
status := mmload(":tb:mem:sdram0",”load.dat");
Mentor Graphics ModelSim を使用している場合:
status := mmload("/tb/mem/sdram0",”load.dat");
Tcl:
mmload tb.mem.sdram0 load.dat
mmload /tb/mem/sdram0 load.dat
# Verilog
# VHDL
Tcl コードでは [] も特殊なシーケンスであることに注意してください。Tcl の mmload コマン
ドを呼び出すには、このかぎかっこを波かっこかバックスラッシュで囲む必要があります。
たとえば、
メモリ • インスタンスのパスが top.m_system.bank [0].index[0].mem である
場合、次のコマンドを使用します。
mmload {top.m_system.bank[0].index[0].mem} some.dat
mmload top.m_system.bank\[0\].index\[0\].mem some.dat
注意: モデルの初期化が済んだらすぐにロードするファイルを指定することもできます。指
定は、作成した HDL シェル • ファイルで行います。詳細については、22 ページの「HDL
シェルの作成」を参照してください。
MMAV ユーザ • ガイド
11/6/08
64
4.5.4
メモリ内容ファイルの形式
メモリ形式ファイルは、
標準的なテキスト • ファイルを使用するメモリ • インスタンスの内容
の保存、ロード、および比較を行うときに使用されます。
メモリ形式ファイルはそれぞれ、一組のレコードで構成されます。各レコードは ASCII テキ
ストの 1 行内に記述する必要がありますが、複数のレコードを 1 行に記述することもできま
す。このようなファイルを作成するときには、次の構文を使用します。
start_addr [:|- end_addr] / data;
start_addr / data [data ...];
[# comment]
"[]" はレコードのオプションの構成要素を示します。"|" は論理 OR を示します。上記のレコー
ド仕様では、これは文字 ":" と "-" のどちらかを使用して、start_addr と end_addr を分け
ることができることを示します。
コメントは文字 "#" で示され、その行の終わりまで続きます。1 行に複数のコメントを記述す
ることはできません。
基数指定子の接頭辞
mmload コマンドと mmcomp コマンドの start_addr と end_addr およびデータは、
基数指定子
の接頭辞を使用して、2 進数、8 進数、16 進数、または 10 進数の形式で指定することができ
ます。デフォルトでは、基数指定子が使用されていない場合は、16 進数が基数となります。
基数指定子として次の接頭辞を使用してください。
'b
'o
'd
'h
-
binary
octal
decimal
hexadecimal
start_addr はメモリ形式レコードに必須の構成要素です。end_addr と併用すると、連続的
で包括的なアドレス範囲の値がレコードによって指定されます。単独で使用した場合、デー
タ値を 1 つしか提供しないと、1 つだけのアドレスのメモリ内容がレコードによって指定さ
れます。データ値を複数提供すると、アドレス start_addr で始まる一連のメモリ内容がレ
コードによって指定されます。
アドレス範囲の末尾を指定するには、end_addr を使用してください。
start_addr と end_addr を分けるには、文字 ":" か "-" のどちらかを使用してください。
mmsave コマンドと mmsaverange コマンドの場合、
設定できる出力データの形式は 16 進数だ
けです。この形式設定を変更するには、SaveDataRadix と SaveAddressRadix という
.denalirc の変数を使用します。保存ファイルの出力に採用する「基数」に応じて、この変
数を 2 (2 進数 )、8 (8 進数 )、10 (10 進数 )、または 16 (16 進数 ) に設定することができます。
あるいは、テストベンチから動的に設定することもできます。デフォルト値は 16 です。
MMAV ユーザ • ガイド
11/6/08
65
たとえば、アドレスの基数を 2 進数に動的に変更するには、次のコマンドを使用することが
できます。
success = $mmtcleval("mmsetvar SaveAddressRadix 2");
たとえば、データの基数を 2 進数に動的に変更するには、次のコマンドを使用することがで
きます。
success = $mmtcleval("mmsetvar SaveDataRadix 2");
アドレスと同様に、デフォルトではデータとアドレスは 16 進数です。不正値も許されてお
り、
文字 "X" または "x" で示されます。ただし、
不正値を 10 進値と併用することはできません。
データをメモリ • インスタンスのデータ幅と等しい幅で指定することは、
優れたスタイルであ
り良い慣行ですが、必須ではありません。この値がメモリ • インスタンスのデータ幅より小さ
い場合は、データの先頭に 0 が補充されます。
値が大きすぎるなら、形式ファイルは該当するインスタンスにとって無効になります。
メモリ形式レコードの末尾を示すには、文字 ";" を使用してください。ただし、ファイルの最
後のレコードには必須ではありません。1 行のテキストに複数のレコードを入力することが
できます。
Motorola S-record と Intel Hex の形式ファイルの変換
デナリには Tcl スクリプトがあり、これを使用して Motorola S-record 形式ファイルまたは Intel
hex 形式ファイルをデナリのロード • ファイルに変換することができます。この Tcl スクリプ
トをご希望の場合は、support@denalisoft.co.jp までお問い合わせください。
パリティ • ビット
一部のメモリ • タイプ ( 主に SRAM デバイス ) では、
パリティ• ビットをオプションでメモリ •
モデルに指定することができます。パリティに使用するビット数は、特定のデバイスの SOMA
ファイル設定で決まります。通常のデバイスでは、1 ビットのパリティで 8 ビットのデータ
をカバーします。パリティ • ビットは常に、ロードするデータ • フィールドの最下位のビット
となります。たとえば、データ • ビットが 8、パリティ• ビットが 1 の SDRAM デバイスを使用
する場合、データ • ビットは [8:1] から取り出され、パリティ• ビットはビット [0] になります。
データ • ビットが 16、
パリティ• ビットが 2 のデバイスでは、データ • ビットは [17:2] から取り
出され、パリティ• ビットは [1:0] になります。ここで、ビット [1] はデータ • ビット [17:10] を
カバーし、ビット [0] はデータ • ビット [9:2] をカバーします。このようなデバイスにデータを
ロードするときには、この点を考慮する必要があります。
例 1:
次の例では、16 進値 "70FF" が、16 進数 "AB73" で指定されるアドレスにロードされます。
AB73 / 70FF;
MMAV ユーザ • ガイド
11/6/08
66
例 2:
次の例では、複数の 16 進値が、16 進数 "AB73" で指定されるアドレスで始まる複数のアドレ
ス ( 末尾のアドレスは 16 進数 "AB7A" で指定されます ) にロードされます。
AB73 / 70FF 7100 7101 7102 7103 7104 7105 7106;
例 3:
次の例ではどちらも、2 進値 "1100XXXX" ( 不正値が含まれています ) が、開始アドレス 0 で
始まり 10 進アドレス "2478" で終わるアドレス範囲にロードされます。アドレス範囲の区切
り文字として ":" または "-" を使用することができます。
0:'d2478/'b1100XXXX;
0-'d2478/'b1100XXXX;
例 4:
次の例では、1 行に複数のレコードを指定でき、1 行を 1 つのコメントで終了する様子が示さ
れています。
0/00; 1/01; 2/02; 3/03; # pattern loading
4.6
メモリ • インスタンスの指定
デナリ MMAV-2001 は、デザイン内のモデルの HDL インスタンス名を使用することによって、
デザイン内のメモリを参照します。
2 つの関数が用意されており、
Verilog には mminstanceid、
VHDL には mmgetinstanceid です。このコマンドを使用して、インスタンス名を抽出し、
デナリの全メモリ • モデル • コマンドで特定のメモリ • デバイスを参照することができます。
一般的な使用方法は、指定したインスタンス名に変数または整数を割り当てることです。そ
して、この変数を「ショートカット」として使用して、デナリのメモリ • モデルを参照します。
コマンドの形式には 2 種類があります。1 つ目ではメモリ • インスタンス名として完全なイン
スタンス • パス名を取り、
2 つ目では相対パスを取ります。
メモリ • モデルまでの階層的なフル •
パスを知っている場合、後者の方が好ましい方法です。
移植性をさらに必要としており、かつ上位の階層レベルをよく知らない場合は、相対パスを
使用して、特定のモジュール内またはアーキテクチャ• ブロック内のメモリ • モデルを特定す
ることができます。相対パスが有効なのは、mminstanceid または mmgetinstanceid が、
モジュール内またはアーキテクチャ• ブロック内で使用されている場合だけです。結果として
得られる変数または整数は、こうしてそのインスタンスに関連付けられるので、他のコマン
ドで使用することができるようになります。
VHDL においては、別の問題があります。GENERATE ステートメントを使用してモデルを初
期化する際に、特別な形の mmgetinstanceid が必要とされます。path_name パラメータが
必要です。これにより、デナリは GENERATE ブロックから完全なパス名を抽出して、正確
なインスタンス名を構成することができます。
MMAV ユーザ • ガイド
11/6/08
67
例 ( 階層的なフル • インスタンス名 ):
Verilog:
memory_id0 = $mminstanceid("testbench.top.device0");
VHDL:
Cadence NC-VHDL を使用している場合:
memory_id0 := mmgetinstanceid(":testbench:top:device0");
Mentor Graphics ModelSim を使用している場合:
memory_id0 := mmgetinstanceid("/testbench/top/device0");
例 ( インスタンス生成のモジュールに対して相対的なインスタンス名 ):
Verilog:
memory_id0 = $mminstanceid("device0");
VHDL:
memory_id0 := mmgetinstanceid("device0");
例 (GENERATE ステートメントで使用される相対的なインスタンス名 ):
VHDL:
memory_id0 := mmgetinstanceid(device0'path_name);
4.7
メモリの内容のリセット
シミュレーション時にいつでも、指定したメモリ • インスタンスの内容をリセットして、初期
状態に戻すことができます。これは、mmreset コマンドで実行することができます。
Verilog:
success = $mmreset("tb.mem.sdram0");
VHDL:
success := mmreset("tb.mem.sdram0");
Tcl:
mmreset tb.mem.sdram0
MMAV ユーザ • ガイド
11/6/08
68
4.8
メモリのリードとライト
MMAV ではテストベンチから任意のメモリ位置のリードとライトを行うことができます。こ
のコマンドはシミュレーション時にいつでも発行することができます。リードまたはライト
を行うインスタンスとアドレスを指定する必要があります。Verilog では、リードまたはライ
トを行うコマンドが複数あります。
メモリのリードまたはライトを行う Verilog のコマンドは、明示的なインスタンス名または暗
黙的なインスタンス ID を取ることができます。この ID は mminstanceid コマンドから取得
します。この 2 つの相違点は、暗黙的なインスタンス ID の方が明示的なインスタンス名より
高速である、ということです。テストベンチで頻繁にメモリのリードとライトを行う場合は、
インスタンス ID コマンドを使用してください。1 つのコマンドで連続する位置のリードまた
はライトを行うこともできます。これを行うには、開始アドレスと、リードまたはライトを
行う位置の数を指定します。コマンドの構文を次に示します。このコマンドは正常に実行で
きたときには値 "0"、エラー発生時には値 "-1" を返します。
注意: 一部の SRAM デバイスでは、パリティ• ビットがデータ • ビットに関連付けられていま
す。このパリティ • ビットの取り扱いの詳細については、66 ページの図「パリティ •
ビット」を参照してください。
また、アドレス入力は、mmreadword の使用時には文字列値 ("0x00")、mmreadword2 または
mmreadword3 の使用時には Verilog 形式 ('h00) である必要がある点にも注意してください。
$mmreadword("<instance name>",”<address>",<param>);
$mmreadword2(<instance id>,<address>,<param>);
$mmreadword3(<instance id>,<address>,<number>,<param>,...,<param>);
Verilog:
status = $mmreadword("tb.mem.sdram0",”0x000a",tmp_read);
m_id = $mminstanceid("tb.mem.sdram0");
status = $mmreadword2(m_id,'h200,tmp_read);
status = $mmreadword3(m_id,'h200,2,tmp_read,tmp_read2);
Verilog のライト • コマンドには構文が数種類あり、ライト • データがコマンドにとって明示的
なのか、それともシミュレーションのレジスタまたはパラメータ内に存在するのかによって
異なります。アプリケーションに適したコマンドを選択してください。これらのコマンドの
構文は次のとおりです。
注意: データ値 <value> は、2 進数の文字列値である必要があります。mmwriteword の使用
時には、アドレス入力は文字列値 ("0x00") である必要があります。mmwriteword2 ~ 5
の使用時には、アドレス入力は Verilog 形式 ('h00) か変数である必要があります。
$mmwriteword("<instance
$mmwriteword2(<instance
$mmwriteword3(<instance
$mmwriteword4(<instance
$mmwriteword5(<instance
MMAV ユーザ • ガイド
name>",”<addr>",”<value>");
id>,<addr>,<value>);
id>,<addr>,<num>,<value>,...,<value>);
id>,<addr>,<param>);
id>,<addr>,<num>,<param>,...,<param>);
11/6/08
69
例:
status = $mmwriteword("tb.mem.sdram0",”0x200",”01010101");
m_id = $mminstanceid("tb.mem.sdram0");
status
status
status
status
=
=
=
=
$mmwriteword2(m_id,'h200,"01010101");
$mmwriteword3(m_id,'h200,2,"01010101",”10101010");
$mmwriteword4(m_id,'h200,tmp_write);
$mmwriteword5(m_id,'h200,2,tmp_write,tmp_write2);
VHDL と Tcl の場合、メモリ位置のリードとライトを行うためのコマンドは、現時点では 2
つしかありません。構文は次のとおりです。コマンドのステータスは、<status> 変数で返さ
れます。戻り値 TRUE はデータのライトに成功し、FALSE は失敗したことを意味します。
VHDL:
mmreadword(<instance id>,<addr>,<param>,<status>);
mmwriteword(<instance id>,<addr>,<data>,<status>);
Cadence NC-VHDL を使用している場合:
m_id := mmgetinstanceid(":tb:mem:sdram0");
mmreadword(m_id,200,tmp_read,status);
mmwriteword(m_id,200,tmp_write,status);
Mentor Graphics ModelSim を使用している場合:
m_id := mmgetinstanceid("/tb/mem/sdram0");
mmreadword(m_id,200,tmp_read,status);
mmwriteword(m_id,200,tmp_write,status);
Tcl:
set <param> [mmreadword <instance id> <addr>]
mmwriteword <instance id> <addr> <data>
set tmp_read [mmreadword /tb/mem/sdram0 200]
mmwriteword /tb/mem/sdram0 200 10100101
4.8.1
マスクされたメモリ • ライト
この Verilog と VHDL 限定の関数は、Verilog の $mmwriteword2 関数と基本的には同じです。
ただし、マスクで "1" に設定されたビット位置だけが、"value" ( ビット文字列 ) からインス
タンス ID <instance_id> のアドレス <address> にコピーされる点が異なります。インス
タンス ID <instance_id> のアドレス <address> にある残りのビット位置は、前のビット
値が保持されます。この関数は成功すると 0 を返します。
MMAV ユーザ • ガイド
11/6/08
70
Verilog:
$mmwritewordmasked (<instance_id>, <address>, "value", "mask")
i2 = $mminstanceid("testbench.uut1");
success = $mmwriteword2(i2, 'h14, "00001111");
success = $mmwritewordmasked(i2, 'h14, "01010101", "00110011");
この例では、値 "00011101" がアドレス 'h14、インスタンス "i2" にライトされます。
VHDL:
mmwritewordmasked (<instance_id>, <address>, "value", "mask", status)
i2 := mmgetinstanceid("testbench.uut1");
mmwritewordmasked(i2, 0, "01010101", "00110011", status);
Tcl:
( 使用できません。)
4.9
メモリの内容の保存と比較
デナリのメモリではいずれも、メモリの内容をファイルに保存したり、その保存ファイルと
比較したりすることができます。
これらの機能のために、mmsave、mmsaverange、および mmcomp という 3 つのコマンドがあ
ります。最初の 2 つのコマンドでは、それぞれ内容全体またはアドレスの特定範囲だけを保
存することができます。3 つ目のコマンドでは、メモリの内容全体を指定ファイルと比較す
ることができます。mmsave コマンドと mmsaverange コマンドの場合、設定できる出力デー
タの形式は 16 進数だけです。mmcomp コマンドのファイル形式については、65 ページのセク
ション 4.5.4「メモリ内容ファイルの形式」で説明しています。
Verilog と VHDL のコマンドの説明は、次のとおりです。正常に実行できたときには値 "0"、
エラー発生時には値 "-1" を返します。
Verilog:
$mmsave("<instance name>,"<file name>");
$mmsaverange("<instance name>",”<file_name>",<start addr>,<end addr>);
$mmcomp("<instance name>,"<file name>");
status = $mmsave("tb.mem.sdram0",”save.dat");
status = $mmsaverange("tb.mem.sdram0",”save.dat",'h0,'h1f);
status = $mmcomp("tb.mem.sdram0",”save.dat");
MMAV ユーザ • ガイド
11/6/08
71
VHDL:
mmsave("<instance name>",”<file name>");
mmsaverange("<instance name>",”<file name>",<start addr>,<end addr>);
mmcomp("<instance name>",”<file name>");
status := mmsave("/tb/mem/sdram0",”save.dat");
status := mmsaverange("/tb/mem/sdram0",”save.dat",0,31);
status := mmcomp("/tb/mem/sdram0",”save.dat");
Tcl:
mmsave <instance name> <file name>
mmsaverange <instance name> <file name> <start addr> <end addr>
mmcomp <instance name> <file name>
mmsave /tb/mem/sdram0 save.dat
mmsaverange /tb/mem/sdram0 save.dat 0 31
mmcomp /tb/mem/sdram0 save.dat
mmcomp コマンドを使用すると、指定ファイルを調べて、そこに列挙されたアドレスとデータ
のペアのうち、比較対象メモリと一致しないものがないかどうかを判断することができます。
注意: mmcomp コマンドでは、その逆のこと ( つまり、メモリ全体を調べて、指定ファイル
と比較すること ) は行いません。したがって、ファイルに記述されていないアドレス
にライトしても、このコマンドはキャッチしません。その方向では比較を行わないか
らです。
回避策として、特定の値を持たない複数の行をファイルに作成して、初期値に設定す
ることができます。これを行うには、load.dat ファイルで mmload を実行した後に、
mmsave を使用して直ちに comp.dat として保存します。こうすることにより、アドレ
スを指定しなかったすべての位置に初期値が自動的に挿入されます。そして、後から
mmcomp コマンドを使用して、comp.dat と比較することができます。
注意: VHPI では、mmSave コマンドを直接使用することはできません。代替策として、
mmtcleval コマンドを使用することができます。
注意: システム • メモリでは、任意の位置にライトされたデータがメモリの「充填値」と一
致しても、システム • メモリが mmsave と mmsaverange のためにそのデータをダンプす
ることはありません。
4.10
クロック • サイクル時間の再計算
一部のメモリ • クラスでは、
クロック • サイクル時間を再計算するオプションを使用すること
ができます。この機能を有効にすると、デナリのメモリ • モデルはクロックの次の立ち上がり
エッジでクロック • サイクルを再計算します。これは、"IrregularClock = 0" の設定 (43 ページ
の「IrregularClock」を参照 ) がある場合に便利です。クロックに基づく一部のタイミング • パ
ラメータの中には、デナリ • モデルがクロック • サイクル時間の変更を通知されないと、不正
確になるものもあるからです。
mmrecalculatecycle( "instance_name" )
MMAV ユーザ • ガイド
11/6/08
72
Verilog:
success = $mmrecalculatecycle( "testbench.uut1" );
VHDL:
success := mmtcleval("mmrecalculatecycle testbench.uut1");
Tcl:
mmrecalculatecycle testbench.uut1
4.11
シミュレーション時の SOMA ファイルの再ロードとタイ
ミング • パラメータの“オンザフライ”での変更
バージョン 3.00 から、メモリ • クラスのサブセットのために 2 つの新機能が追加されました。
これらの機能を使用すると、SOMA ファイルのパラメータを動的に変更できるだけでなく、
HDL ラッパで参照されているのとはまったく異なる SOMA ファイルにロードすることもで
きます。現時点でこれらの機能が有効なるのは、次のメモリ • クラスです。
• DDR3-SDRAM
• DDR2-SDRAM
• DDR-SDRAM
• FLASH-AMD
• FLASH-INTEL
• FLASH-NAND
• FLASH-ONE-NAND
• GDDR3
• GDDR4
• SDRAM
• RLDRAM
• FCRAM
• RDRAM
• QDR-SSRAM
• NVM_DDR
• MS
• MS-PRO
mmsomaset - 元の SOMA ファイルのごく少数の (<3) タイミング数を変更します。さらに変更
を行う場合は、次に述べるように mmsomaload を使用する方が効率的です。これを呼び出す
には、pli ($mmsomaset) または mmtcleval を使用します。
MMAV ユーザ • ガイド
11/6/08
73
mmsomaset ("<instance_name>", "<parameter_name>", "<parameter_value>",
"<parameter_units>");
シミュレーションはその新しい数でその時点から続行されます。メモリの内容は影響を受け
ません。parameter_value フィールドと parameter_units フィールドの両方が必要であることに
注意してください。
元の SOMA ファイルで指定されているように、parameter_units は "ns" でナノ秒、"clk" で
クロック時間の単位を表すことができます。
Verilog:
success = $mmsomaset ( "tb.mem0", "toh", "15.0", "ns" );
VHDL:
次の Tcl コマンドでは mmtcleval を使用してください。
Cadence NC-VHDL を使用している場合:
ex. mmtcleval"mmsomaset :tb:mem0 toh 15 ns";
Mentor Graphics ModelSim を使用している場合:
ex. mmtcleval"mmsomaset /tb/mem0 toh 15 ns";
Tcl:
mmsomaset /tb/mem0 toh 15 ns
mmsomaload - 複数のタイミング値またはピン幅を変更します。複数のタイミング値を変更す
る場合は、一連の mmsomaset コマンドよりこちらの方がさらに効率的です。チェック処理の
多くが一度しか行われず、しかも clks などに基づくタイミングの再計算も一度しか行われな
いからです。この SOMA ファイルは、変更対象を内部に記述している必要があると同時に、
完全な SOMA ファイルでなければならないことに注意してください。
mmsomaload ("<instance_name>", "<file_name>");
mmsomaload が発行されると、メモリは再割り当てされ、内容がすべて破棄されます。ピン
のサイズを変更し、そのサイズが、シミュレータの保持する値と異なると、警告が表示され
ます。任意の信号のサイズがシミュレータの保持する値より大きいと、致命的なエラーが発
生します。シミュレータ側の値が、ピンに設定できる最大値です ( この幅は Verilog または
VHDL のシェルからの幅です )。
初期設定ファイルは読み込まれず ( 今ここにはおそらく該当しないので )、まったく新しいメ
モリで必要とされる手順をすべて実行する必要があります。ただし、デザイン内に他にメモ
リがあっても、それらは影響を受けません。これは基本的には、そのメモリに関して「初め
からやり直す」ことを意味します。ただし、シミュレーション時間は前回の続きから計測さ
れるので、シミュレータを終了したり再コンパイルしたりする必要はありません。
実施時の注意:タイミングの変更だけが目的で、メモリのリセットを行わない場合は、代わ
りに一連の mmsomaset コマンドを実行する必要があります。
MMAV ユーザ • ガイド
11/6/08
74
制限事項:
• この方法でクラスを変更することはできません。いったん DDR メモリにしたら、常に
DDR メモリのままとなります。
• ピンの幅を元の HDL シェルより広げることはできません。小さくしてから、元の HDL
シェルの幅まで広げることはできます。
Verilog:
success = $mmsomaload ( "tb.mem0", "new_soma.spc" );
VHDL:
Cadence NC-VHDL を使用している場合:
mmtcleval "mmsomaload :tb:mem0 new_soma.spc";
Mentor Graphics ModelSim を使用している場合:
mmtcleval "mmsomaload /tb/mem0 new_soma.spc";
Tcl:
mmsomaload tb.mem0 new_soma.spc
4.12
エラー • メッセージの制御
mmerrormessageson コマンドと mmerrormessagesoff コマンドを使用すると、
エラー報告
機能を柔軟にオンまたはオフにすることができます。これらの関数をいつでも呼び出して、
デナリ • モデルのエラー• メッセージの表示をオンまたはオフにすることができます。デフォ
ルトでは、メッセージ表示は常にオンです。
Verilog:
success = $mmtcleval("mmerrormessageson");
success = $mmtcleval("mmerrormessagesoff");
VHDL:
次の Tcl コマンドでは mmtcleval を使用してください。
mmtcleval "mmerrormessageson";
mmtcleval "mmerrormessagesoff";
Tcl:
mmerrormessageson
mmerrormessagesoff
上記コマンド以外にコマンドが 2 つあり、
シミュレーション時に履歴とトレース • ファイルの
生成をそれぞれ動的にオンまたはオフにすることができます。
MMAV ユーザ • ガイド
11/6/08
75
$mmdebugon - 履歴とトレース • ファイルの情報のウィンドウを作成できます。.denalirc
ファイルで HistoryFile オプションと TraceFile オプションが有効であると、このコマン
ドは、無効になります。成功すると、0 が返されます。
Verilog:
initial #5000 success = $mmdebugon;
VHDL:
wait for 5000 ns;
success := mmdebugon;
$mmdebugoff - 履歴 / トレース情報のウィンドウを閉じます。成功すると、0 が返されます。
Verilog:
initial begin
#50000 success = $mmdebugon;
#50000 success = $mmdebugoff;
end
VHDL:
wait for 50000 ns;
success := mmdebugon;
wait for 50000 ns;
success := mmdebugoff;
end
4.13
クロック • サイクルの強制的な再計算
メモリ • クラスがこの機能をサポートしている場合、クロックの次の立ち上がりエッジで
MMAV はクロック • サイクルを再計算します。これは IrregularClock = 0 の場合に便利で
すが、至る所でクロック • サイクルが変わります。モデルに通知しないと、クロックに基づく
タイミング • パラメータが不正確になることがあります。
Verilog:
$mmrecalculatecycle( "instance_name" )
MMAV ユーザ • ガイド
11/6/08
76
4.14
4.14.1
RDRAM (Rambus) 固有モデルの考慮事項
RAMBUS 向け Turbo Channel Model
概要
Rambus の個々の Direct-RDRAM コンポーネント用の高パフォーマンス • モデルに加えて、デ
ナリは "Turbo Channel Model" も提供しています。このモデルは市販されているどの DirectRDRAM チャネル • シミュレーション • モデルよりも高いパフォーマンスを発揮します。この
Turbo Channel Model というオプションは、
シミュレーション • パフォーマンスを加速するアル
ゴリズムを採用しており、精度を犠牲にすることなく個別の RDRAM インスタンスを 1 つの
モデル • オブジェクトに「分割」します。ほとんどの場合、シミュレーション • パフォーマン
スは、個々の RDRAM モデルの "n" 倍となります。ここで、"n" はシミュレーションする
Rambus チャネル上の RDRAM コンポーネントの数を表します。
ライセンス
追加ライセンスである Denali_SIM_rdram_turbo は、
RDRAM Turbo Channel Model のシミュレー
ションに必要です。このオプションについては、デナリソフトウエア社 (info@denalisoft.com)
までお問い合わせください。
デバイス数
RDRAM Turbo Model を使用するには、汎用パラメータ device_number を指定する必要があり
ます。この文字列パラメータは、1 つの Rambus チャネルで使用するデバイスの数を指定しま
す。HDL レベルでは、1 つのインスタンスが 1 つのチャネルです。したがって、テストベン
チで個々のデバイスからインスタンスを生成すべきではありません。
チャネル上のデバイスには、次の形式の名前が与えられます。
<channel_name>_d%d
たとえば、チャネル • インスタンス名が ch1 であり、このチャネルに合計で 8 つのデバイスが
ある場合、デバイス名は次のようになります。
ch1_d0, ch1_d1, ch1_d2, ch1_d3, ch1_d4, ch1_d5, ch1_d6, ch1_d7
mmload 関数を使用してメモリの内容をロードする際には、この命名規則に従う必要があり
ます。
注意:汎用の device_number が定義されていないか 0 に等しい場合は、Turbo モードはオフに
なります。つまり、インスタンスは 1 つのチャネル • インスタンスではなく、1 つのデバイス •
インスタンスとして扱われます。この場合、チャネル上のすべてのインスタンスからインス
タンスを作成する必要があります。シリアル • ピンを手動で接続する必要もあります。
デバイス ID
Turbo モードでは、モデルはデバイス ID を 0、1、...、n-1 に自動的に設定します。mmload は
不要です。ただし、デフォルトの ID を有効にするために、checkInitialization の選択を解除す
る必要があります。
MMAV ユーザ • ガイド
11/6/08
77
チャネルの反転
RAC モデル ( またはテストベンチ ) の中には、物理的な電圧レベルで ROW/COL/DQA/DQB
を駆動するものもあります。パラメータ invertChannel が、PureView の SOMA ファイルで設
定されている場合、モデルでは結果として、論理信号 ROW/COL/DQA/DQB を内部で反転し
ます。
チャネル遅延の設定
デナリ RDRAM Turbo Channel Model は、未使用の RDRAM 制御レジスタ 0xf にチャネル遅延
設定を格納します。0xf の最後の 3 ビットは、デナリ • チャネルの配線遅延を CFM/CTM サイ
クルに関して 0 ~ 7 サイクルの範囲で指定するときに使用します。たとえば、次のパラメー
タを見てください。
0f/'b0000000000000110; channel delay=6cyc
このパラメータによって、チャネルの配線遅延はレジスタの TPARM 値と TCDLY1 値に追加
され、次のような tCAC リード • データ遅延が新たに設定されます。
tCAC = channel_delay + 3*tCYCLE + tCLS_C + tCDLY0_C + tCDLY1_C
レジスタ 0xf のチャネル遅延は、マスタとの間の往復遅延であるため、CFM/CTM サイクルの
数 ( 半分のサイクル数ではありません ) として指定されることに注意してください。
.denalirc のオプション
• WarnSuppress
通常のタイミングとプロトコルのエラー状況に加えて、デナリの RDRAM モデルは、次
の危険な操作についても警告を発行します。
− ライト • バッファが廃棄される前の上書き (WR-WR-RD-RD-RTR など )
− バンクが廃棄される前のプリチャージ ( ルール CR8)
これらの警告は、次のように .denalirc ファイルの WarnSuppress パラメータを設定
することによって、表示しないようにすることができます。
WarnSuppress 1
• TimingChecksReportOnly
このオプションをオンにすると、タイミング • エラーが発生したときに、メモリを破壊し
てデータ • バス上に "X" を駆動するデナリ • モデルの機能がオフになります。
このオプショ
ンを使用すると、タイミング • エラーが発生してもモデルはメッセージを発行するだけに
なり、"X" を駆動することはなくなります。これは、エラーの初期評価で非常に便利な場
合があります。ただし、エラーがレポートされてもシミュレーションは続行されます。
TimingChecksReportOnly 1
MMAV ユーザ • ガイド
11/6/08
78
• TimingChecksStartTime
デナリでは、特定の時刻にタイミング • チェックをオンにする機能も用意してあります。
これにより、
デナリ • モデルがタイミング • エラーのチェックを開始する前に、
リセットと
デバイス初期化を行うための時間を確保することができます。構文については、次の例
を参照してください。
TimingChecksStartTime
TimingChecksStartTime
TimingChecksStartTime
TimingChecksStartTime
0ps
"20 us"
"200ms"
200000 ns
デバイス • リフレッシュのオプション
デナリのどのメモリ•モデルにも、
高度なダイナミック•メモリ•アロケーション•アルゴリズム
が採用されており、シミュレーション時のメモリ使用量が最小限に抑えられます。RDRAM
Turbo Channel Model のメモリ要件は、さらに下げることができます。これを行うには、チャ
ネル内の全デバイスではなく1つのデバイスでリフレッシュ•チェックを実施するように指定
します。汎用パラメータ device_number は、チャネル上の特定のデバイスについて、次のよう
にリフレッシュ間隔を指定するときに使用します。
device_number = "32;RefreshCheckOneDev:1"
上記の例では、デバイス数が 32 のチャネルでインスタンスが作成され、リフレッシュ• チェッ
クは 1 つのデバイスしか行われません。
注意:リフレッシュ用の各種コマンドは通常、チャネル • ブロードキャストを通じて発行され
ます。したがって、1 つのデバイスしかチェックしないのにモデルの正確さが低下するよう
なことがないようにする必要があります。
マルチバンク • リフレッシュのオプション
マルチバンク • リフレッシュは、numBanksPerRefresh パラメータによって制御されます。リフ
レッシュ• コマンドを 1 回実行すると複数のバンクがリフレッシュされる場合、それらのバン
クは同じ下位のアドレス • ビットを共有することになります。例:
numBanksPerRefresh 2
上記の設定をバンクが 16 あるデバイスで使用すると、最初のリフレッシュはバンク 0 と 8 で
行われます。次のリフレッシュはバンク 1 と 9 で行われ、以下同じように続きます。
MMAV ユーザ • ガイド
11/6/08
79
Turbo モード - 同一チャネル上でのサイズの異なるデバイスのサポート
以前には、同じチャネル上のデバイスはすべて、同じ SOMA ファイルを共有していました。
したがって、コンフィギュレーションは同じでなければなりませんでした。汎用パラメータ
"device_number" の機能が拡張され、同じチャネル上でサイズの異なるデバイスがサポートさ
れるようになりました。例:
1 つのチャネル上で 128 M デバイス 8 つと 64 M デバイス 16 からインスタンスを作成するに
は、次のようにします。
device_number => "24;8:128M_800.spc;16:64M_800.spc";
memory_spec は既に無効であることに注意してください。
デナリの RDRAM バイト • オーダリングのオプション
デナリの RDRAM モデルは、( ファイルのロードと保存で ) デュアルオクトをメモリ内で次の
ように扱います。
DQA[8]...DQA[0] DQB[8]...DQB[0] ..... DQA[8]...DQA[0] DQB[8]...DQB[0]
\..........................cfm clk 0 ................./
\................... cfm clk 7 ......................./
0
71
72
143
その結果、ビット • オーダリングは次のようになります。
データ [0] はチック 0 の DQA[8]、データ [143] はチック 7 の DQB[0]
マスク配列も同じバイト • オーダリングを使用して作成されるので、
デュアルオクトがリード
されると、データは同じ順序で提示されます。
このバイト • オーダリングは RMC/RAC とは異なります。RMC/RAC では、デュアルオクトは
次のように DQA/DQB に分割されます。
DQB(clk 7) ...DQB(clk 0)
\------------------------------/
143
72
DQA(clk 7) ...DQA(clk 0)
\......................................./
71
0
メモリ内容ファイルの比較またはロードのためにRMC/RACのバイト•オーダリングを使用す
る場合、このコンフィギュレーションを使用できるように、.denalirc の環境変数を設定す
ることができます。
RdramRMCByteOrder 1
このケースでは、デナリの RDRAM モデルはデュアルオクトを上記のように RMC/RAC のバ
イト • オーダリングで保存またはロードします。
MMAV ユーザ • ガイド
11/6/08
80
CHAPTER
5
5
MMAV の特別な検証機能
MMAV では、テストベンチに検証チェックを追加できます。また、物理メモリを論理メモリ •
ビューに組み込むこともできます。これらの機能は回帰テストの一部として使用するための
もので、システム全体が正常に機能しているかどうかを検証するのに役立ちます。シミュレー
ションでメモリ • トランザクションが発生するたびにこれらを追跡して、
システムの多くの部
分を検証できます。この例として、電気通信パケットを扱うシステムを挙げることができま
す。パケットがソースから受信され、メモリにライトされます。その後これらのパケットは
メモリからリードされ、変更されてもう一度送信されます。このシステムの特性の 1 つとし
て、メモリの特定のアドレスにパケットがライトされた場合、それがリードされた後でしか
次のパケットをそのメモリの位置にライトできないという性質があります。このシステムの
確認に役立つ検証機能は、メモリ内の位置が 2 回続けてライトされる場合にチェックを行う
アサーションです。このアサーションでは、特定のメモリへのすべてのメモリ • アクセスが監
視され、ある位置への 1 回目と 2 回目のライトの間にリードが行われない場合、エラーが報
告されます。この機能を使用すると、システムでこのパケット • プロトコルが守られなかった
ときにすぐに察知できます。
また MMAV により、物理メモリのコンポーネントについて、論理的にアドレス指定された
ビューを作成することもできます。これらの論理的なビューは、デバッグおよびテストベン
チの生成とサポートを行う場合に重要です。論理的にアドレス指定されたビューの例として、
複数の SDRAM デバイスを 1 つのメモリ • バンクに集める場合があります。SDRAM メモリの
論理的な 32 ビット • バンクは、8 ビットの SDRAM の物理インスタンス 4 つから作成できま
す。論理メモリ • ビューを作成すると、このメモリ • ビューに対してロード、格納、比較、リー
ド、およびライトができ、MMAV の関数が正しい物理インスタンスに自動的にアクセスし
ます。
MMAV のもう 1 つの検証機能は、トランザクション • リストです。トランザクション • リスト
により、メモリのセグメントで予想されるリード動作およびライト動作のシーケンスを検証
できます。リード / ライト動作、それらのアドレス、およびそれらの値 ( オプション ) は、
シーケンスでトランザクション • リストに追加されます。
トランザクション • リストに追加さ
そのリード / ライトのシーケンスがトランザクション • リ
れたメモリ • セグメントは監視され、
ストに登録されているリード / ライト動作と一致するかどうかが確認されます。シーケンス、
アドレス、または値が登録されたトランザクションのリストと一致しない場合、アサーショ
ンがトリガされ、3 つのアクション ( 通知が発行される、メッセージが表示されてシミュレー
ションが中止される、またはメッセージが表示されてシミュレーションが終了する ) のいず
れかが実行されます。登録されたそれぞれのリード / ライトは、1 つのリード / ライトまたは
N 個 (N > 0) のリード / ライトと比較できます。これは、それぞれの動作ベースで制御できます。
MMAV ユーザ • ガイド
11/6/08
81
5.1
メモリ • トランザクションのアサーションの設定
メモリの参照を追跡するアサーションを設定するには、シミュレーションのテストベンチで
コマンドを実行し、アサーションを登録する必要があります。このコマンドにより、シミュ
レーション中にアサーションを無効または有効にするときに使用できる一意の数字が返され
ます。各コマンドとその構文については、次のセクションで説明します。
5.1.1
メモリ • アクセスのアサーション
このアサーションにより、特定のメモリに指定された方法でアクセスが行われた場合にア
サーションがトリガされます。このアサーションは、一般的には、不要なアクセスから特定
のアドレス範囲を保護することを目的としています。データではなくコードとして指定され
たアドレス空間へのライトを登録できるため、そのアドレス空間に誤ったライトが行われる
と、アサーションがトリガされてシミュレーションが停止します。このアサーションの構文
は、次のとおりです。
mmassert_access(<instance id>,"<access>","<action>",<start address>,<end
address>,[<address increment>]);
各パラメータについては、以下で説明します。
<access> - <access> の使用可能な型を以下に示します。
• Read - メモリ位置のリード
• Write - メモリ位置へのライト
• ReadorWrite - リードまたはライトのいずれか
• ReadnoWrite - 以前にライトされていないメモリ位置のリード
• ReadRead - 同じメモリ位置への連続した 2 回のリード
• WriteWrite - 同じメモリ位置への連続した 2 回のライト
注意: 上記のアクセスの型には、大文字と小文字の区別がありません。わかりやすくするた
めこのように表記されています。
<action> - <action> の使用可能な値を以下に示します。
• Note - シミュレーション • ログの記録が印刷され、シミュレーションは続行します。
• Break - シミュレーション•ログの記録が印刷され、シミュレーションは中断(一時中止)し
ます。
• Exit - シミュレーション • ログの記録が印刷され、シミュレーションは終了します。
• Callback - アサーションがトリガされると、Verilog のコールバックが生成されます。
<start address>、<end address>、<address increment>
これらのエントリは、アサーションが適用されるアドレスの範囲を示します。開始アドレス
と終了アドレス間の範囲内の連続したアドレス (addr increment=1)、または範囲内で選択され
た他のアドレス (addr increment =/ 1) が、アドレスのインクリメント値として許可されてい
ます。
MMAV ユーザ • ガイド
11/6/08
82
開始アドレスと終了アドレスの両方が与えられている場合は、追加のパラメータ <address
increment> ( オプション ) を指定できます。このパラメータで、その特定のアドレス範囲内の
アドレスのインクリメントの段階を指定できます。たとえば、開始アドレスが 20H、終了ア
ドレスが 30H と指定されており、パラメータ <address increment> が 2 に設定されている場合
は、すべてのアサーション • チェックが 2 段階ごとに行われることを意味します。終了アドレ
スの 30H に達するまで、20H、22H、24H などのアドレス位置で確認が行われます。開始アド
レスおよび終了アドレスが指定されていない場合は、メモリ • インスタンス全体に対して確認
が行われます。また、開始アドレスしか指定されていない場合は、指定のアドレスからアド
レス空間の最後まで確認が行われます。
例:
0x0 ~ 0x4000 の位置がライトされた場合にシミュレーションを停止するには、次のようにし
ます。
Verilog:
m_id = $mminstanceid("tb.mem.sdram0");
a_id = $mmassert_access(m_id,"write",”break",'h0,'h400,'h1);
VHDL:
m_id := mmgetinstanceid("/tb/mem/sdram0");
a_id := mmAssert_Access(m_id,"write",”break",0,400,1);
Tcl:
set id [mminstanceid tb.mem.sdram0]
mmassert_access $id write break 0 1024 1
注意: アドレスの値 (1024) は 10 進数です。16 進数ではありません。
5.1.2
データ • アクセスのアサーション
任意のアクセス• アサーションを修飾して、
データ •チェック •コンポーネントを追加すること
もできます。
リードまたはライトされるデータのみに基づいてトリガされるアクセス • アサー
ションを作成できます。このアサーションは、リードまたはライトされている実際のデータ
に対して指定されたデータの比較関数に基づいてトリガされます。マスク値を指定して、デー
タの特定のビットのみを確認することもできます。このコマンドの構文は、次のとおりです。
mmassert_datavalue(<memory id>,"<access>",”<action>",<data
value>,[<mask>],
"<comparison>",<start address>,<end
address>,<address increment>);
<comparison>
ビット単位でマスクが実行された後、得られたワードで比較が実行されます。使用可能な値
は次のとおりです。
•
== は、アクセスされた(マスクされた)データが指定された(マスクされた)データと等し
い場合に指定します。
•
MMAV ユーザ • ガイド
!=
は、アクセスされた(マスクされた)データが、指定された(マスクされた)データと等し
くない場合に指定します。
11/6/08
83
>
•
は、
アクセスされた ( マスクされた ) データが、
指定された ( マスクされた ) データより大
きい場合に指定します。
•
は、
アクセスされた ( マスクされた ) データが、指定された ( マスクされた ) データ以上
である場合に指定します。
•
は、
アクセスされた ( マスクされた ) データが、
指定された ( マスクされた ) データより小
さい場合に指定します。
•
は、
アクセスされた ( マスクされた ) データが、指定された ( マスクされた ) データ以下
の場合に指定します。
>=
<
<=
<data value>、<mask>
このエントリで、比較に使用するデータおよびマスク (16 進数形式 ) を指定できます。コン
マ記号は、データ値とオプションのマスク値を区切る場合に使用します。マスクを指定しな
い場合は、すべてのビットが比較されます。マスク値が与えられている場合は、アクセスさ
れているデータのマスクされた部分のみが、指定されたデータと比較されます。そのデータ
位置のマスク • ビットが "1" である場合は、
比較が実行されます。
マスク • ビットが "0" である
場合、そのデータ位置の比較は考慮されません。
<start address>、<end address>、<address increment>
これらのエントリは、アサーションが適用されるアドレスの範囲を示します。開始アドレス
と終了アドレス間の範囲内の連続したアドレス (addr increment=1)、または範囲内で選択され
た他のアドレス (addr increment =/ 1) が、アドレスのインクリメント値として許可されてい
ます。
開始アドレスと終了アドレスの両方が与えられている場合は、追加のパラメータ <address
increment> ( オプション ) を指定できます。このパラメータで、その特定のアドレス範囲内の
アドレスをインクリメントさせる段階を指定できます。たとえば、開始アドレスが 20H、終
了アドレスが 30H と指定されており、パラメータ <address increment> が 2 に設定されている
場合は、すべてのアサーション • チェックが 2 段階ごとに行われることを意味します。終了ア
ドレスの 30H に達するまで、20H、22H、24H などのアドレス位置で確認が行われます。開始
アドレスおよび終了アドレスが指定されていない場合は、メモリ • インスタンス全体に対して
確認が行われます。また、開始アドレスしか指定されていない場合は、指定のアドレスから
アドレス空間の最後まで確認が行われます。
例:
メモリで、0x4000 よりも大きいアドレスに 0x0 よりも大きい値がライトされた場合にシミュ
レーションで記録するようにアサーションを設定するには、次のようにします。
Verilog:
m_id = $mminstanceid("tb.mem.sdram0");
a_id = $mmassert_datavalue(m_id,"write",”note",'h0,'h1f,">”,'h400,
'h1ffff,'h1);
MMAV ユーザ • ガイド
11/6/08
84
VHDL:
m_id := mminstanceid("/tb/mem/sdram0");
a_id :=
mmassert_datavalue(m_id,"write",”note",”0",”00011111",”>",1024,131071,
1);
Tcl:
set m_id [mminstanceid tb.mem.sdram0]
mmassert_datavalue $m_id write note 0 00011111 > 1024 131071 1
注意: アドレスの値 (1024、131071) は 10 進数です。16 進数ではありません。
5.1.3
グローバルなメモリ • アクセスのアサーション
これまでのアサーションのコマンドでは、
特定のメモリ • インスタンスに対するアサーション
が登録されます。以下のアサーションでは、テストベンチのすべてのメモリ • インスタンスに
特定のアサーションが設定されます。このようなアサーションを次に示します。
mmassert_uma("<action>");
このアサーションは、シミュレーション時、まだライトされていなかったり、ロード • コマ
ンドで初期化されていなかったりするメモリ内のある位置でリードが行われるとトリガさ
れます。
mmassert_rwa("<action>");
このアサーションは、メモリ内の 1 つの位置で、リードが発生する前に 2 回ライトが行われ
るとトリガされます。
mmassert_rra("<action>");
このアサーションは、メモリ内の 1 つの位置で、ライトされる前に 2 回リードが行われると
トリガされます。
Verilog:
a_id = $mmassert_uma("break");
a_id = $mmassert_rwa("note");
a_id = $mmassert_rra("exit");
VHDL:
a_id := mmassert_uma("break");
a_id := mmassert_rwa("note");
a_id := mmassert_rra("exit");
Tcl:
mmassert_uma break
mmassert_rwa note
mmassert_rra exit
MMAV ユーザ • ガイド
11/6/08
85
5.1.4
パリティ • チェックのアサーション
パリティ• ビットで保護されたメモリがある場合、誤ったパリティでメモリのワードがリード
またはライトされたときにトリガされるアサーションを設定できます。このコマンドの構文
は、次のとおりです。
mmassert_parity(m_id,"<access>",”<action>",<parity>,<start addr>,<end
addr>, <addr increment>);
パラメータ <parity> では、奇数のパリティが "1"、偶数のパリティが "0" としてエンコードさ
れます。
例:
0 ~ 20 のアドレスでリードが行われ、データのパリティが奇数 ("1") ではない場合、メッセー
ジが出力されます。
Verilog:
m_id = $mminstanceid("tb.mem.sdram0");
a_id = $mmassert_parity(m_id, "read", "note", 1, 0, 20, 1);
VHDL:
m_id := mmgetinstanceid("/tb/mem/sdram0");
a_id := mmassert_parity(m_id, "read", "note", 1, 0, 20, 1);
Tcl:
set m_id [mminstanceid tb.mem.sdram0]
mmassert_parity $m_id read note 1 0 20 1
5.2
アサーションの動的な有効化および無効化
次の MMAV 関数を使用して、テストベンチ内からアサーションを動的に有効化および無効化
( 非アクティブ化 ) できます。
mmenableassertion(assertion_id);
mmdisableassertion(assertion_id);
例:
assertion_id は、アサーション定義の呼び出しに割り当てられる変数です。この例では、
assertion_id が "a_id" となっています。
a_id = $mmassert_parity(m_id, "read", "note", 1, 0, 20, 1);
このアサーション定義を無効にするには、次のようにします。
status = $mmdisableassertion(a_id);
MMAV ユーザ • ガイド
11/6/08
86
Verilog:
status = $mmenableassertion(a_id);
status = $mmdisableassertion(a_id);
VHDL:
status := mmenableassertion(a_id);
status := mmdisableassertion(a_id);
Tcl:
mmenableassertion a_id
mmdisableassertion a_id
特定のテスト用に簡単にアサーションを追加したり、変更したりできるよう、すべてのアサー
ションを Verilog、VHDL、または Tcl の 1 つのファイルに配置し、mmdisableassertion の
呼び出しを使用してすべてのアサーションを無効にすることをお勧めします。その後、
mmenableassertion の呼び出しを使用して、特定のテストでアサーションを個別に有効に
できます。
5.3
エラー挿入ルーチン
シミュレーション時、デナリ • メモリにエラーを挿入し、ECC チェック • ロジック機能および
ハードウエア • テスト機能を実行できます。エラー挿入ルーチンは 2 種類あります。最初の
ルーチンでは、リード時、メモリのワイヤ上のランダムなビットが一定の間隔で不規則に反
転されます。このルーチンにより、実際のシステムでの信号の整合性エラーがシミュレーショ
ンされます。
2 番目の種類のルーチンは、
デナリ • メモリ • モデルにおけるスタック • エラーお
よびカップリング • エラーを生成できる、ハード故障ルーチンです。これは、実際のシステム
内の故障メモリ • デバイスを検出するソフトウエアまたはハードウエアをテストする場合に
役立ちます。これらの呼び出しの構文および説明を次に示します。
5.3.1
エラー挿入
デナリのリリース 2.900 からエラー挿入ルーチンが強化され、複数ビットのエラーに対応可
能となったため、より柔軟にエラーのランダム化を実行できます。
注意: 挿入されるエラーの頻度には制限があります。実装により、挿入間の最小間隔は 2 と
なっています。
mmerrinject(<instance id>, "error_type_string");
<error_type_string>
• seed <seed_value>:乱数のシード。デフォルトでは、システム時間がシードとして使用さ
れます。このため、実行のたびに異なる結果が生成されます。反復可能なシーケンスを
取得するには、このオプションを使用する必要があります。
• reads <number_of_reads_per_error> <range>:1 つのエラーにつき行われるリード数を表
す整数値。2 番目の整数 ( オプション ) で、範囲を指定できます。デフォルト値は 100 です。
MMAV ユーザ • ガイド
11/6/08
87
• bits <bit number> <bit number 2> ...:オプションの整数フィールドで、ビット • エラーの
さまざまな数値を示します。
たとえば、1 ビット • エラーおよび 2 ビット • エラーを作成す
るには、1 と 2 の値を指定します。デフォルト値は 1(1 ビット • エラーのみ ) です。
• percent <percentage integer> <percentage integer 2>:それぞれの整数は、上記の -bits オプ
ションで定義されるビット • エラーの発生数の分布を示すパーセンテージです。整数の合
計は 100 になる必要があります。デフォルトでは、それぞれの種類ごとに均等な割合に
なります。
例:
1、2、および 4 ビットのエラーを、1 ビット • エラーは 80%、2 ビット • エラーは 15%、および
4 ビット • エラーは 5% の割合で生成します。5 ~ 10 リード後に、(12 のシードを使用して ) 不
規則なエラー発生が開始します。
Verilog:
m_id = $mminstanceid("tb.mem.sdram0");
success = $mmerrinject(m_id, "-seed 12 -reads 5 10 -bits 1 2 4 -percent
80 15 5");
VHDL:
m_id := mmgetinstanceid("/tb/mem/sdram0");
err_id := mmerrinject(m_id, "-seed 12 -reads 5 10 -bits 1 2 4 -percent
80 15 5");
Tcl:
set m_id [mminstanceid tb.mem.sdram0]
mmerrinject $m_id -seed 12 -reads 5 10 -bits 1 2 4 -percent 80 15 5
mmerrinject を使用したエラー挿入の設定を無効にするには、次のコマンドを使用します。
Verilog:
success = $mmsetallerrinject(0);
VHDL:
m_id := mmgetinstanceid("/tb/mem/sdram0");
success := mmseterrinject(m_id, 0); -- Turns OFF error injection
success := mmseterrinject(m_id, 1); -- Turns ON error injection
Tcl:
set m_id [mminstanceid tb.mem.sdram0]
mmseterrinject $m_id 0
MMAV ユーザ • ガイド
11/6/08
88
または
mmsetallerrinject 0
すべてのリードにエラー挿入を行うには、次のコマンドを使用します。
$mmerrinject (id, 1); /* inject every read */
同様に、512 リードごとに 1 回ずつ 1 ビット • エラーを挿入する必要がある場合は、次のコマ
ンドを使用します。
$mmerrinject (id, 512); /* inject error every 512th read*/
「バックドア」リードでのエラー挿入の有効化
バックドア • リード (mmreadword を使用する場合、
または Specman や VERA などのテストベ
ンチ • ツールからのリードの場合 ) では、デフォルトではエラー挿入が行われません。エラー
挿入は、デフォルトでは、ピンを介して実行されるリードでしか実行されません。ただし、
mmseterrinject の 3 番目のパラメータ ( オプション ) を次のように使用すると、
バックドア •
リードのエラー挿入をオンにできます。
mmseterrinject(id, status, [backdoorstatus]);
この関数により、指定したメモリ • インスタンスのエラー挿入がオンまたはオフになります。
<id>
エラー挿入のメモリ ID を指定します。すべての場合に -1 となります。
<status>
エラー挿入ステータスを指定します。値は 0 ( オフにする ) または 1 ( オンにする ) です。
[backdoorstatus]
この引数はオプションです。値は 0 ( オフにする ) または 1 ( オンにする ) です。バックドア •
リードのデフォルトでは、エラー挿入はオフです ( バックドア • リードとは、ピンではなく、
PLI または DDVAPI のインターフェイスを介したリードです )。バックドア • リードで有効に
できるエラー挿入については、3 番目のパラメータを 1 に設定します。
Verilog:
m_id = $mminstanceid("tb.mem.sdram0");
success = $mmsetallerrinject(m_id, 1, 1); // Turns ON backdoor error
injection
VHDL ( 現在、ModelSim VHDL のみサポートされています ):
m_id := mmgetinstanceid("/tb/mem/sdram0");
success := mmseterrinject(m_id, 1, 1); -- Turns ON backdoor error
injection
MMAV ユーザ • ガイド
11/6/08
89
Tcl:
set m_id [mminstanceid tb.mem.sdram0]
mmtcleval("mmseterrinject $m_id 1 1");
5.3.2
故障モデリング
メモリの故障の作成
デナリのメモリ • デバイスには、論理メモリ故障を適用できます。故障ロジックおよび BIST
( ビルトイン • セルフ • テスト ) ロジックをテストしてメモリ配列を検証するときに、
これらの
機能は大変便利です。mmfault コマンドを次に示します。
mmfault(<instance id>,"<type>",<addr>,<bit>,<value>,<slave addr>,<slave
bit>);
<type>
有効な <type> フィールドを次に示します。
• stuck-at
stuck-at 故障を指定すると、指定アドレスにある指定ビットが指定値で縮退するように固
定できます。
• transition
transition 故障を指定すると、指定アドレスにある指定ビットの指定値を取得できなくなり
ます。
• coupling
coupling 故障を指定すると、指定アドレスにある指定ビットが遷移するときに、スレーブ
• アドレスのスレーブ • ビット上での遷移が強制的に実行されます。
例:
メモリ • インスタンス tb.mem.sdram0 のアドレス 0x20 のビット 5 を 1 でスタックするように設
定します。
Verilog:
m_id = $mminstanceid("tb.mem.sdram0");
//Stick bit 5 of address=0x20 to "1"
err_id = $mmfault(m_id, "stuck-at", 'h20, 'h5, 'h1);
//Make bit 1 of address=0x20 unable to transition to a '0'
err_id = $mmfault(m_id, "transition", 'h20, 'h1, 'h0);
//In this example, a change in bit 0 at address 7 will cause a
transition //to that value at bit 2 at address 20 (if that bit does not
already have
//the value).
err_id = $mmfault(m_id, "coupling", 'h7, 'h0, 'h0, 'h20, 'h2);
MMAV ユーザ • ガイド
11/6/08
90
VHDL:
m_id := mminstanceid("/tb/mem/sdram0");
--Stick bit 5 of address=0x20 to "1"
err_id := mmfault(m_id, "stuck-at", 16#20#, 5, 1, 0, 0);
--Make bit 1 of address=0x20 unable to transition to a '0'
err_id := mmfault(m_id, "transition", 16#20#, 1, 0, 0, 0);
--In this example, a change in bit 0 at address 7 will cause a
transition --to that value at bit 2 at address 20 (if that bit does not
already have
--the value)
err_id := mmfault(m_id, "coupling", 7, 0, 0, 16#20#, 2);
注意: VHDL では、mmfault コマンドにはすべてのフィールドを使用する必要があります。し
たがって、使用しないフィールドには "0" を設定する必要があります。
Tcl:
--Stick bit 5 of address=0x20 (dec=32) to "1"
mmfault tb.mem.sdram0 stuck-at 32 5 1 0
--Make bit 1 of address=0x20 (dec=32) unable to transition to a '0'
mmfault tb.mem.sdram0 transition 32 1 0
# In this example, a change in bit 0 at address 7 will cause a
transition # to that value at bit 2 at address 20 (dec=32) (if that bit
does not
# already have the value)
mmfault tb.mem.sdram0 coupling 7 0 0 32 2
故障チェックの有効化 / 無効化
一度有効化されると、デナリのメモリの故障は常にアクティブになります。次のコマンドを
使用すると、故障の定義を無効にできます。
mmsetfault(<fault id>, <flag>);
これにより、故障 ID ( 上記の例では err_id) によって指定される特定の故障が、オン ( フラ
グ =1) またはオフ ( フラグ =0) になります。
mmsetallfault(<flag>);
この場合は、すべての故障がオン ( フラグ =1) またはオフ ( フラグ =0) になります。
Verilog:
success = $mmsetfault (5, 0); //Turn off(0) fault id=5
success = $mmsetallfault(0); //Turn off all faults
MMAV ユーザ • ガイド
11/6/08
91
VHDL:
success = $mmsetfault (5, 0); //Turn off(0) fault id=5
success = $mmsetallfault(0); //Turn off all faults
Tcl:
mmsetfault 5 0 #Turn off(0) fault id=5
mmsetallfault 0 #Turn off all faults
5.4
XML を使用した MMAV での論理アドレス指定
注意: 論理メモリが作成されると、テストベンチの階層の最上位に新しいインスタンスの名
前が生成されます。したがって、mmwriteword、mmreadword、mmsave などの他の
MMAV コマンドを使用する場合、論理メモリの定義で指定されるインスタンス名を階
層なしで使用する必要があります。" address.space name='<name>' " という XML タグ
は、新しい論理メモリ • インスタンスのインスタンス " 名 " を表します。
このセクションでは、MMAV でのシステム • メモリの作成方法について説明します。システ
ム • メモリは仮想メモリまたは論理メモリと考えることもできますが、この章では、システ
ム • メモリと呼びます。これらによってデザインの物理メモリの仮想ビューが提供され、デ
バッグしやすいよう、ビュー上にデータが整理されます。たとえば、データとパリティ • ビッ
トを区別したり、アドレスとデータのビットの順序を変更したり、メモリをインターリーブ
したりすることなどができます。
バージョン 3.0 およびそれ以前のバージョンでは、すべてのシステム • メモリが PLI、VHDL、
または DDVAPI の呼び出しを介して作成されていました。複数の呼び出しでまずメモリが作
成された後、それらが追加されました。この実装には限界があり、ホールのない MxN グリッ
ドにメモリを配置する必要がありました。新しい仕様は、非常に柔軟性のある XML になっ
ています。3.0 のインターフェイスはまだサポートされていますが、メモリをより柔軟に整理
する場合は、新しい XML 形式の使用をお勧めします。3.0 のインターフェイスについては、
101 ページのセクション 5.5「PLI/FLI/Tcl を使用した、MMAV での論理アドレス指定」で説
明しています。
5.4.1
XML の基本
XML (Extensible Markup Language) の構文は大変簡単で、基本的な規則は少ししかありません。
XML は言語そのものではなく、ユーザが使用する言語の定義方法に関する基準です。デナリ
では、システム • メモリの作成のために使用されています。構文は、タグ (< > で区切られま
す )、内容、および属性の組み合わせです。XML を記述するときに考慮すべき規則を次に示
します。
• すべての開始タグは、一致する終了タグと組み合わせるか、または自己終了タグである
必要があります。
• タグをオーバーラップさせることはできません ( 正しくネストする必要があります )。
• XML 文書は、1 つのルート要素しか持つことができません。
• XML には大文字と小文字の区別があります。
MMAV ユーザ • ガイド
11/6/08
92
デナリの場合、ファイルまたは文字列のどちらからでも XML を受け入れることができます。
詳細については、100 ページのセクション 5.4.8「MMAV とのインターフェイス」を参照して
ください。
まず、ルート要素について説明します。XML が含まれているファイルまたは文字列には、
ルート要素が 1 つ含まれている必要があり、このルート要素はデナリによって認識されるも
のである必要があります。デナリでは将来、システム • メモリ以外についても XML でサポー
トする予定であるため、最上位レベルのルートは "advanced.verification" です。
たとえば、MMAV で処理できる最も簡単な XML は次のとおりです。
<advanced.verification>
</advanced.verification>
この場合、何も実行されません。
対応するする終了タグが必要であることに注意してください。終了タグは、< > の中を "/" で
開始します。< と "/" の間にはスペースを入れません。XML をこのタグで開始および終了し
ないと、MMAV で処理できません。
システム • メモリを定義する場合は、タグを <system.addressing> にします。したがって、空の
システム宣言は次のようになります。
<advanced.verification>
<system.addressing>
<!-- This is a comment -->
</system.addressing>
</advanced.verification>
インデントは必須ではありませんが、例では、わかりやすく表示するために使用されてい
ます。
また、XML 内にコメントを挿入することもできます。構文は次のとおりです。
<!--
5.4.2
comment
-->
深さおよび幅の拡張
system.addressing のタグの間に、システム • メモリを作成できます。
それぞれのシステム • メモリは、address.space タグで定義されます。これらに、一意の名前、
幅、および深さを指定する必要があります。メモリの中に、物理メモリまたは他のシステム •
メモリを配置できます。
MMAV ユーザ • ガイド
11/6/08
93
幅の拡張の例:
<advanced.verification>
<system.addressing>
<!-- Four 16mb X 8 bit memories, width expanded -->
<address.space name='ram' width='32' depth='16777216'>
<place baseaddr='0' bitpos='0'>
<memory name='testbench.i0' />
</place>
<place baseaddr='0' bitpos='8'>
<memory name='testbench.i1' />
</place>
<place baseaddr='0' bitpos='16'>
<memory name='testbench.i2' />
</place>
<place baseaddr='0' bitpos='24'>
<memory name='testbench.i3' />
</place>
</address.space>
</system.addressing>
</advanced.verification>
この例は、幅 32 ビット、深さ 16Mb の "ram" というシステム • メモリの作成方法を示していま
す。このシステム • メモリは、幅 8 ビットの物理メモリ 4 つが、ビット位置 0、8、16、および
24 に並べて配置されて作成されています。
次の XML の論理メモリの例を示す図を参照してください。
0
31
testbench.i0
7
07
testbench.i1
testbench.i2
07
testbench.i3
0 7
0
"ram"
図 5-1: XML の論理メモリの例 - 幅の拡張
MMAV ユーザ • ガイド
11/6/08
94
深さの拡張の例:
<advanced.verification>
<system.addressing>
<!-- Two 32mb X 16 bit memories, depth expanded -->
<address.space name='myview' width='16' depth='64M'>
<place baseaddr='0' bitpos='0'>
<memory name='testbench.i5' />
</place>
<place baseaddr='32M' bitpos='0'>
<memory name='testbench.i6' />
</place>
</address.space>
</system.addressing>
</advanced.verification>
これは次のようになります。
15
0
0
testbench.i5
32M
testbench.i6
"myview"
図 5-2: XML の論理メモリの例 - 深さの拡張
5.4.3
インターリーブ
インターリーブは、影響を受けるメモリの位置にインターリーブ属性を配置し、それに応じ
て baseaddr を調整して行います。
MMAV ユーザ • ガイド
11/6/08
95
インターリーブの 例:
<advanced.verification>
<system.addressing>
<!-- Four 4k X 32 bit memories, interleaved -->
<address.space name='cache' width='32' depth='16K'>
<place baseaddr='0' bitpos='0' interleave='4'>
<memory name='processor.c1' />
</place>
<place baseaddr='1' bitpos='0' interleave='4'>
<memory name='processor.c2' />
</place>
<place baseaddr='2' bitpos='0' interleave='4'>
<memory name='processor.c3' />
</place>
<place baseaddr='3' bitpos='0' interleave='4'>
<memory name='processor.c4' />
</place>
</address.space>
</system.addressing>
</advanced.verification>
これは次のようになります。
31
0
0
Processor.c1
1
Processor.c2
2
Processor.c3
3
Processor.c4
4
Processor.c1
5
Processor.c2
6
Processor.c3
7
Processor.c4
......
.......
16380
Processor.c1
16381
Processor.c2
16382
Processor.c3
16383
Processor.c4
"cache"
図 5-3: XML の論理メモリの例 - インターリーブの拡張
MMAV ユーザ • ガイド
11/6/08
96
5.4.4
アドレスのスクランブル
必要に応じて、アドレスのビットを配置し直すこともできます。105 ページのセクション 5.6
「アドレスのスクランブル」の例を次に示します。この例では、scram1 を介して tb.uut1 にア
クセスする場合に使用される、各アドレスのビット 4 ~ 7 と 12 ~ 15 を入れ替えています。
<advanced.verification>
<system.addressing>
<address.space name='scram1' width='24' depth='1M'>
<place baseaddr='0' bitpos='0' >
<address.map bits='19:16 12:15 11:8 4:7 3:0' />
<memory name='tb.uut1' />
</place>
</address.space>
</system.addressing>
</advanced.verification>
5.4.5
データ • ビットの並べ替えおよびマスキング
データ • ビットを異なる順序で表示したり、それらのサブセットのみを特定の場所で使用した
りすることもできます。
<advanced.verification>
<system.addressing>
<address.space name='data' width='30' depth='1M'>
<place baseaddr='0' bitpos='0' >
<data.map>
<word bits='31:17 15:1' />
</data.map>
<memory name='tb.uut2' />
</place>
</address.space>
<address.space name='parity' width='2' depth='1M'>
<place baseaddr='0' bitpos='0' >
<data.map>
<word bits='16 0' />
</data.map>
<memory name='tb.uut2' />
</place>
</address.space>
</system.addressing>
</advanced.verification>
代わりに、以下を実行して address.space の幅を 32 に変更することで、これらを組み合わせて
右側にパリティがある 32 ビット • メモリを作成できます。
<word bits='31:17 15:1 16 0' />
MMAV ユーザ • ガイド
11/6/08
97
5.4.6
ホールの作成
この仕様では、システム • メモリに「ホール」を残すこともできます。ホールとは、物理シス
テム • メモリまたは子システム • メモリによって占有されていない空間です。
空間を完全に指
定する必要はありません。たとえば、システム • メモリの一番下の 64K を空のままにする場合
は、64K に相当する baseAddr からメモリの配置を開始します。
5.4.7
統合
これらの概念をまとめる場合の例を次に示します。
256KB x 8 のメモリをビッグ • エンディアンの 32 ビット • ワードでアドレス指定します。
幅を
32KB x 64 で拡張し、リトル • エンディアンの 32 ビット • ワードでアドレス指定します。
<advanced.verification>
<system.addressing>
<address.space name='wide' width='64' depth='64K'>
<place baseaddr='0' bitpos='0' >
<data.map>
<word bits='7:0 15:8 23:16 31:24' />
</data.map>
<memory name='narrow' />
</place>
<place baseaddr='0' bitpos='32' >
<data.map>
<word bits='31:0' />
<word bits='63:32' />
</data.map>
<memory name= 'extra_wide' />
</place>
</address.space>
</system.addressing>
</advanced.verification>
論理メモリの図
0
31 32
ワード 0
ワード 1
ワード 2
ワード 3
[7:0]
[15:8]
[23:16]
[31:24]
ワード 4
ワード 5
ワード 6
ワード 7
[7:0]
[15:8]
[23:16]
[31:24]
"narrow"
MMAV ユーザ • ガイド
63
[31:0]
[63:32]
"extra_wide"
11/6/08
98
0
31 32
.
.
.
63
.
.
.
ワード
256K
これまでの例で仕様の大部分はわかりやすく説明されていますが、それぞれの XML 要素に
ついて詳しく説明します。それぞれの要素の後に、その属性の説明があります。
<system.addressing> - 論理アドレス指定を記述するためのコンテナ。
<address.space> - 論理アドレス空間を記述します ( 必須項目:name、width、depth)。
−
−
−
name - 物理メモリのインスタンス名に類似するアドレス空間の識別子。
width - このアドレス空間の各ワードのビット数。
depth - アドレス空間のワード数。
<memory> 物理メモリのインスタンスを指します ( 必須項目:name)。
−
name - 物理メモリまたは子のシステム • メモリのインスタンス名。
<place> 物理メモリまたは論理アドレス空間内の論理アドレス空間の配置属性を指定します
( 必須項目:baseaddr、オプション:bitpos、interleave)。
−
−
−
baseaddr - 論理空間内で子が開始されるアドレス。
bitpos - 子の LSB に対応する論理空間のビット数 (LSB = 0)。デフォルトは 0 です。
interleave - 子の内部の連続する位置間の論理空間のオフセット数値。たとえば、
インターリーブが 2 である場合、子のワードは論理アドレスに 1 つおきに対応しま
す。同様に 2 番目のインターリーブを '2' に、その baseaddr を最初の baseaddr よ
り 1 つ大きい値に設定し、もう 1 つの子をインターリーブできます。デフォルトは 1
です。つまり、この場合アドレスはスキップされません。
<data.map> 囲まれている位置 ( つまり <place>) を変更し、元のビット順 (width-1 : 0) の完全
なワード以外の方法で子を表示できるようにします。
MMAV ユーザ • ガイド
11/6/08
99
<word> - <data.map> に 1 つまたはそれ以上の <word> がある場合、配置されたメモリを表示
するためのビットの配置が記述されます ( 必須:bits)。
−
bits - スペースで区切られた、ビット番号およびビット範囲のリスト。ビットには番
号が付きます。最初に最下位のビットに 0 が付けられます。ビット範囲は、コロンで
結合された 2 つのビット番号です。範囲は、開始から終了までのすべてのビットを表
します。範囲は昇順または降順のどちらも可能で、左側の番号が小さい場合は昇順、
大きい場合は降順になります ( 完全を期すため、ビット範囲が N:N である場合は、
ビット番号 N と同じであると考えます )。
<word> が 1 つである場合、配置されたメモリのビットを論理的に異なる順番で配置し直すこ
とができます。本来の幅よりも広いバス幅でメモリを表示するには、"bits" 属性に (width-1)
より大きいビット番号を含めることができます。ビット番号 N * width + B は、連続する N 番
目のワードのビット B を示します。上記の例の最初の <word> を参照してください。
本来のバス幅よりも狭い幅でメモリを表示するには、複数の <word> を使用します。このと
き、"bits" 属性を使用して、論理ワード間でのワードのビットの割り当て方法を示します。上
記の例の 2 番目の <data.map> を参照してください。
<address.map> 囲まれている位置を変更し、昇順アドレスの連続した順番以外の方法で子を
表示できるようにします ( 必須:bits)。
−
bits - 空白で区切られた、ビット番号およびビット範囲のリスト。ビットには番号が
付きます。最初に最下位のビットに 0 が付けられます。範囲について説明した、上記
の <word> の bits 属性を参照してください。
<address.map> の適用方法を理解するため、アドレス • マッピングがない状態での配置済みメ
モリのアドレスの計算を考えてみます。囲まれているアドレス空間のアドレスから、子の
baseaddr を減算し、そのインターリーブで割り、配置場所内の <data.map> によって決定され
る子ワード対論理ワードの比を乗算します。これにより、論理アドレスが対応する子メモリ
のアドレスを得ることができます。また、複数の子の位置からビットを組み合わせる
<data.map> の場合は、その最初のアドレスを得ることができます。<address.map> が位置に
適用されるときには、計算されたこのアドレスのビットが、bits 属性の指定に従って再配置
されます。
5.4.8
MMAV とのインターフェイス
ファイルまたはテストベンチの文字列にこれらのメモリを定義した後は、次の方法でデナリ
の環境にメモリを作成できます。
Verilog:
success = $mmxmleval("xmlString");
success = $mmxmlfile("filename");
VHDL:
success := mmXmlEval(xmlString);
success := mmXmlFile(filename);
ルーチンの複数の呼び出しを作成できます。
すべてのシステム • メモリを同じファイルまたは
文字列のバッファに存在させることはできますが、必ずしもその必要はありません。
MMAV ユーザ • ガイド
11/6/08
100
$mminstanceid を使用してこのメモリのインスタンスIDを調べ、
後続の呼び出しで使用でき
ます。後続の呼び出しでは、名前ではなく ID 番号が使用されます。
5.5
PLI/FLI/Tcl を使用した、MMAV での論理アドレス指定
デナリ MMAV のバージョン 3.1 のセクション 5.4「XML を使用した MMAV での論理アドレ
ス指定」の前に、テストベンチの PLI/FLI または Tcl の呼び出しを使用して、幅、深さを拡張
し、インターリーブを行ったメモリを簡単に定義しました。最初のコマンドは、論理アドレ
スの " 形 " を指定するために使用します。次にそれ以降のコマンドを使用して、特定の物理
メモリを論理的にアドレス指定されたメモリにマップします。
論理アドレスが作成されると、リード、ライト、保存、およびリストアに関する PLI/FLI/Tcl
の標準的な関数を、物理メモリと同様に論理的にアドレス指定されたメモリで使用できます。
ただし、比較のコマンドは除きます。
これらのコマンドでサポートされる論理アドレスは、以下の組み合わせで作成されます。
5.5.1
幅の拡張
複数の物理メモリを組み合わせて、より多くのビットを持つ論理アドレスのワードを形成で
きます。この方法で組み合わされた物理メモリは同じ幅である必要はありませんが、同じア
ドレス空間を持つ必要があります。
5.5.2
深さの拡張
複数の物理メモリを組み合わせて、論理的にアドレス指定されたメモリでより大きいアドレ
ス空間を形成できます ( 構成メモリのすべてのアドレス空間の合計に相当します )。この方法
で組み合わされた物理メモリは同じアドレス空間を保持する必要はありませんが、同じワー
ド • サイズである必要があります。
5.5.3
インターリーブ
複数の物理メモリをインターリーブさせて、論理的にアドレス指定されたメモリ内のアドレ
スを通過させることで、インターリーブされた物理メモリを繰り返し使用できます。インター
リーブされた物理メモリは、同じ幅および深さである必要があります。
MMAV ユーザ • ガイド
11/6/08
101
5.5.4
マスキング
マスクは、論理的にアドレス指定されたワードを定義するときに、物理メモリのワードの一
部のビットのみを選択する場合に使用できます。これらのビットはメモリ内で連続している
必要はありませんが、ビットを並べ替える仕組みは存在しません。マスキングは、論理的に
アドレス指定されたメモリを構成するそれぞれの物理メモリに対して固定されています。ま
た、深さが拡張されている場合、深さの拡張に関連しているすべての物理メモリについて、
マスクが一貫している必要があります。マスキングが使用される例として、物理メモリのワー
ドが 2 つ ( またはそれ以上 ) の異なる値を表す場合が挙げられます。たとえば、最初の 4 ビッ
トが優先される値、つまりポインタを表し、残りのビットがデータを表すとします。適切な
マスクを使用することで、論理的にアドレス指定された 2 つのメモリを、これら 2 つの値に
対応させて定義できます。結果として得られる論理的にアドレス指定されたメモリは通常、
物理メモリの MxN 配列となり、インターリーブおよびマスクはある場合とない場合があり
ます。
id = $mmcreatesysmem( "logically addressed memory name",
"logically addressed memory instance id",
width,
depth,
[numinterleaves] );
• logically addressed memory name - 論理的にアドレス指定されたメモリのインスタンス名
に対する、ユーザ指定の名前
• logically addressed memory instance id - 論理的にアドレス指定されたメモリのユーザ指定
インスタンス ID
注意:これは、mmload、mmsave、mmwriteword、mmreadword など、以降の MMAV コ
マンドと共に使用されるインスタンス ID です。
• width - 幅の拡張で使用される物理メモリの数
• depth - 深さの拡張で使用される物理メモリの数
• interleaves - インターリーブのレベル
このコマンドは、論理的にアドレス指定されたメモリのコンフィギュレーションを作成する
ために使用されます。物理メモリは "MxN" の配列に配置され、インターリーブはある場合と
ない場合があります。論理的にアドレス指定されたメモリに対応する ID が返されます。物理
メモリは論理的にアドレス指定されたメモリにマップされていないため、このコマンドの使
用後であっても、論理的にアドレス指定されたメモリはまだ使用可能な状態ではありません。
使用可能にするには、次のコマンドを使用します。
result = $mmaddtosysmem( <logically addressed memory id>,
<instance id>,
<width position>,
<depth position>,
[<interleave position>])
このコマンドを使用して、mmcreatesysmem コマンドで以前に作成された論理アドレスのメ
モリに、物理メモリを追加します。この種類のコマンドは、メモリが使用可能になる前に、
mmcreatesysmem コマンドで定義されるマトリックスのすべての位置について発行される必
要があります。
logically addressed memory id - mmcreatesysmem によって返される論理的にアドレス指定さ
れたメモリの ID
MMAV ユーザ • ガイド
11/6/08
102
instance id - 論理的にアドレス指定されたメモリに追加される物理メモリの ID
width position - このメモリが配置される MxN マトリックス内の幅の位置 ( 値は 0 ~ width-1
である必要があります )。
depth position - このメモリが配置される MxN マトリックス内の深さの位置 ( 値は 0 ~ depth1 である必要があります )。
interleave position - このメモリのインターリーブのレベル ( 値は 0 ~ interleave-1 である必要
があります )。
この関数は、成功した場合は 0 を、成功しなかった場合は -1 を返します。
result = $mmaddtosysmemmask( <logically_addressed_memory_id>,
<physical_id>,
"mask string" ,
<width position>,
<depth position>,
[interleave position])
この関数は、マスクのバイナリ表現を表す文字列が指定される点を除いて、以前説明した
mmaddtosysmem と同じです。マスクは、特定の幅の位置のすべての物理メモリについて同じ
である必要があることに注意してください。
この関数は、成功した場合は 0 を、成功しなかった場合は -1 を返します。
Verilog:
m_id1
m_id2
m_id3
m_id4
=
=
=
=
$mminstanceid("tb.mem.sdram0");
$mminstanceid("tb.mem.sdram1");
$mminstanceid("tb.mem.sdram2");
$mminstanceid("tb.mem.sdram3");
vid = $mmcreatesysmem("logical", "new_memory_name", 2, 2, 1);
success = $mmaddtosysmem(vid, m_id1, 0, 0, 0);
success = $mmaddtosysmem(vid, m_id2, 1, 0, 0);
success = $mmaddtosysmem(vid, m_id3, 0, 1, 0);
success = $mmaddtosysmem(vid, m_id4, 1, 1, 0);
VHDL:
m_id1
m_id2
m_id3
m_id4
:=
:=
:=
:=
mmgetinstanceid("/tb/mem/sdram0");
mmgetinstanceid("/tb/mem/sdram1");
mmgetinstanceid("/tb/mem/sdram2");
mmgetinstanceid("/tb/mem/sdram3");
vid := mmcreatesysmem("logical", "new_memory_name", 2, 2, 1);
success := mmaddtosysmem(vid, m_id1, 0, 0, 0);
success := mmaddtosysmem(vid, m_id2, 1, 0, 0);
success := mmaddtosysmem(vid, m_id3, 0, 1, 0);
success := mmaddtosysmem(vid, m_id4, 1, 1, 0);
MMAV ユーザ • ガイド
11/6/08
103
Tcl:
set
set
set
set
m_id1
m_id2
m_id3
m_id4
[mminstanceid
[mminstanceid
[mminstanceid
[mminstanceid
tb.mem.sdram0]
tb.mem.sdram1]
tb.mem.sdram2]
tb.mem.sdram3]
set vid [mmcreatesysmem logical
mmaddtosysmem $vid $m_id1 0 0 0
mmaddtosysmem $vid $m_id2 1 0 0
mmaddtosysmem $vid $m_id3 0 1 0
mmaddtosysmem $vid $m_id4 1 1 0
new_memory_name 2 2 1]
上記の例では、論理的にアドレス指定されたメモリが物理メモリの 2x2 の配列から作成され
ます。
次の例では、論理的にアドレス指定された 2 つのメモリ ( データおよびポインタ ) が、マス
クを使用して、幅 8 ビットの 2 つの物理メモリから作成されます。論理的にアドレス指定さ
れた最初のメモリは、最初の物理メモリの 5 つの最上位ビットで構成されています。例では、
これが 5 ビットのポインタを表します。論理的にアドレス指定された 2 番目のメモリは、最
初の物理メモリの最下位のビットおよび 2 番目の物理メモリのすべてのビットから作成され
ます。例では、これは 11 ビットの論理的にアドレス指定されたワードを表します。
Verilog:
//Pointer
m_id1 = $mminstanceid("tb.mem.sdram0");
m_id2 = $mminstanceid("tb.mem.sdram1");
vid = $mmcreatesysmem("logical", "data", 1, 1, 1);
success = $mmaddtosysmemmask(vid, m_id1, "11111000", 0, 0, 0);
//Data
vid1 = $mmcreatesysmem("logical", "pointer", 2, 1, 1);
success = $mmaddtosysmemmask(vid1, m_id1, "00000111", 0, 0, 0);
success = $mmaddtosysmemmask(vid1, m_id2, "11111111", 1, 0, 0);
VHDL:
-- Pointer
m_id1 := mmgetinstanceid("/tb/mem/sdram0");
m_id2 := mmgetinstanceid("/tb/mem/sdram1");
vid := mmcreatesysmem("logical", "data", 1, 1, 1);
success := mmaddtosysmemmask(vid, m_id1, "11111000", 0, 0, 0);
-- Data
vid1 := mmcreatesysmem("logical", "pointer", 2, 1, 1);
success := mmaddtosysmemmask(vid1, m_id1, "00000111", 0, 0, 0);
success := mmaddtosysmemmask(vid1, m_id2, "11111111", 1, 0, 0);
MMAV ユーザ • ガイド
11/6/08
104
Tcl:
# Pointer
set m_id1 [mminstanceid tb.mem.sdram0]
set m_id2 [mminstanceid tb.mem.sdram1]
set vid [mmcreatesysmem logical data 1 1 1]
mmaddtosysmemmask $vid $m_id1 11111000 0 0 0
-- Data
set vid1 [mmcreatesysmem logical pointer 2 1 1]
mmaddtosysmemmask $vid1 $m_id1 00000111 0 0 0
mmaddtosysmemmask $vid1 $m_id2 11111111 1 0 0
5.6
アドレスのスクランブル
アドレスのスクランブルを使用して、物理メモリから「スクランブルされた」メモリを作成
できます。スクランブルは、スクランブルされたアドレスに対する元のアドレスのビットご
との変換で構成されます。これにより、特定のアドレスをメモリにマッピングする方法を再
定義できます。
mid = $mmaddressmap("scrambled memory name", memory_id, "<address map>",
[output message level]);
説明:
• scrambled memory name - スクランブルされたアドレスの新しく作成されスクランブル
されたメモリ
• memory_id - 「スクランブルされた」メモリにマップされる物理メモリ
• "address map" - 物理アドレスから「クランブルされた」アドレスへのビットごとの変換
• [output message level] - ( オプション ) 物理アドレスから「スクランブルされた」アドレス
への変換を示す詳しいメッセージ
アドレス • マップの最初の整数は、スクランブルされたアドレスの最上位のビットの値を指定
します。つまり、最初の整数で、元のアドレスのどのビットがスクランブルされたアドレス
の最上位のビットに使用されるかを指定します。同様に、最後の整数で最下位のビットが指
定されます。たとえば、4 ビット • アドレスのビットを入れ替える場合、アドレス • マップは "0
1 2 3" です。ここで、スクランブルされたアドレスの MSB は、元のアドレスのビット 0 で表
されます。LSB は、元のアドレスのビット 3 によって表されます。たとえば、このマッピン
グでは、アドレス 0xa が 0x5 にスクランブルされます (1010 -> 0101)。
アドレス • マップで有効な整数は 0 .. n の範囲内で、n は、メモリ • インスタンスでアドレス指
定可能な最大のメモリ位置を表すのに必要なビットの数です。たとえば、0x1fffff がアドレス
指定可能な最大のメモリ位置である場合、21 のマッピング整数を指定する必要があります。
この場合、マッピング整数に有効な値は 0 ~ 20 です。
MMAV ユーザ • ガイド
11/6/08
105
スクランブル時に詳しいメッセージを表示するには、$mmaddressmap の引数 [output message
level] に 1 の値を使用します。これにより、
標準出力に次のようなメッセージが表示されます。
*Denali* (write) scramble:address 255 maps to 8160
デフォルトの場合、stdout にこのようなメッセージは表示されません。
Verilog:
mid = $mmaddressmap( "scram1", id1, "19 18 17 16 12 13 14 15 11 10 9 8
4 5 6 7 3 2 1 0", 1 );
このコマンドにより、スクランブルされたメモリ "scram1" へのすべてのライトおよびリード
がスクランブルされます。このメモリは、物理メモリ 'id1' で構成されています。スクランブ
ルのスキームは、特定のアドレスのビット 4 ~ 7 と 12 ~ 15 の入れ替えで構成されます。
VHDL:
mid := mmaddressmap( "scram1", id1, "19 18 17 16 12 13 14 15 11 10 9 8
4 5 6 7 3 2 1 0", 1 );
Tcl:
set id1 [mminstanceid tb.mem.sdram0]
mmaddressmap scram1 $id1 "19 18 17 16 12 13 14 15 11 10 9 8 4 5 6 7 3 2
1 0" 1
5.7
スクラッチパッドのメモリ
スクラッチパッドのメモリを使用して、C をベースとした簡単な MxN メモリ配列を作成でき
ます。これは、キャッシュやエンベデッド • メモリの配列などのモデリングに大変便利です。
$mmcreatescratchpad(<name>,<width>,<depth>,<init_val>);
• name - mmcreatescratchpad によって返されるスクラッチパッドの名前
• width - ビット単位のスクラッチパッドの幅 ( 整数 )
• depth - スクラッチパッドのワード数 ( 整数 )
• init_val - スクラッチパッドの最初のメモリの値 (0、1、x、X、"")
このコマンドは、PLI または Tcl を介して使用できます。引数 init_val はオプションではあ
りませんが、空の文字列 "" にすることができます。この場合、MMAV ではデフォルト値で
ある "X" が使用されます。
例:
32 ビット x1024 のスクラッチパッドのメモリ "scratchpad1" を作成します。
Verilog:
sp_id = $mmcreatescratchpad (scratchpad1, 32, 1024, 1);
MMAV ユーザ • ガイド
11/6/08
106
VHDL:
VHDL の場合、デナリでは func_lf.vhd (NC-VHDL 用 ) および func_mti.vhd (MTI 用 ) に 2 つの直接
関数を作成しています。
FUNCTION mmCreateScratchpad( name
: STRING;
width : INTEGER;
depth : INTEGER;
initvalue : STD_LOGIC_VECTOR ) return
INTEGER;
attribute FOREIGN of mmCreateScratchpad:function is
"Clib:mmcreatescratchpad";
2 回以上インスタンスが生成されるエンティティ/ アーキテクチャ内にこの呼び出しを置く場合、
VHDL の path_name 属性を使用することで、新しく作成されたスクラッチ • パッドのメモリへの
パス名を一意にできます。
entity simple_mem is
port (
a
: in std_logic_vector (9 downto 0);
data : inout std_logic_vector(7 downto 0);
cs, we, clk : in std_logic
);
end simple_mem;
use work.memory_modeler.all;
architecture behavior of simple_mem is
signal width: integer := 8;
signal size:integer := 1024;
signal id: integer := -1 ;
begin
process
begin
id <= mmcreatescratchpad(simple_mem'path_name & "storage",
width, size, "00000000");
wait;
end process;
これについて、次のようにテストベンチで 2 回インスタンスの生成が行われるとします。
i_simple_mem: simple_mem
port map( a => tb_a, data => tb_data1, cs => tb_cs, we => tb_we, clk
=> tb_clk);
j_simple_mem: simple_mem
port map( a => tb_a, data => tb_data2, cs => tb_cs, we => tb_we, clk
=> tb_clk);
MMAV ユーザ • ガイド
11/6/08
107
次のように一意のパス名が与えられます。
*Denali* Class: scratchpad Instance:
":simple_tb:j_simple_mem:simple_memstorage" Size: 1Kx8
*Denali* Memory id: 0 created of size 1024, width 8.
*Denali* Class: scratchpad Instance:
":simple_tb:i_simple_mem:simple_memstorage" Size: 1Kx8
*Denali* Memory id: 1 created of size 1024, width 8.
または、mmcreatescratchpad から返される ID でメモリを参照することもできます。
Tcl:
set sp_id [mmcreatescratchpad scratchpad1 32 1024 1]
上記の例では、幅 32 ビット、深さ 1024 ワード ( 変更されるまで、それぞれに FFFFFFFF が含
まれています ) の scratchpad1 というスクラッチ • パッド • メモリが作成されます。変数 sp_id
には、コマンドから返される整数値が含まれています。これは、作成されたメモリの ID です。次
のメッセージがデナリの履歴ファイルに表示されます。
*Denali* Memory id: 1 created of size 1024, width 32.
その後、mmreadword と mmwriteword ( および他の MMAV の呼び出し ) を使用して、"1"
( お勧めしません ) または sp_id (Tcl の場合は $sp_id) を参照し、テストベンチからこのメ
モリにアクセスできます。 また、PureView を使用して、これらのメモリ内容を表示することも
できます。
MMAV ユーザ • ガイド
11/6/08
108
5.8
MMAV と Mentor Graphic's の Seamless HW/SW CoVerification 製品の併用
Mentor Graphic's の Seamless Hardware/Software Co-Verification 製品は、デナリ MMAV のバー
ジョンとセットで販売されています。以前は、新しいデナリのリリースを Seamless と併用す
る場合は、お客様に Seamless の新しいリリースをお待ちいただく必要がありました。デナリ
および Seamless の両方が新しくリリースされたため、もうこのようなことはありません。
新しいデナリのリリースを現在の Seamless のリリースと併用するには、$CVE_HOME/denali
にデナリの新しいリリースをインストールするだけで済みます。また、$CVE_HOME/denali
を別の場所にあるデナリ MMAV のリリースにシンボリック • リンクさせることもできます。
この方法によりリリースをより簡単に変更し、古いリリースも維持できます。
Seamless とデナリの PureView を併用するには、第 2 章 「PureView
:
グラフィカル • ツールの使
用」および第 3 章 :「PureView でのメモリのデバッグ」を参照してください。
MMAV ユーザ • ガイド
11/6/08
109
5.9
エンベデッド ASIC メモリのための MMAV の使用
このセクションでは、MMAV でエンベデッド ASIC メモリを作成する方法について説明し
ます。
デナリのエンベデッド• メモリ• ソリューションは、
標準的なベンダ •モデルに比べユーザビリ
ティおよび検証機能が大幅に向上しています。デナリでは、レジスタ • ファイル、エンベデッ
ド SRAM、エンベデッド DRAM、およびエンベデッド Flash について、MMAV 製品からシ
ミュレーション • モデルを提供しています。これらの高品質モデルにより、デナリの事実上の
外部メモリ • モデルと同じ機能が提供されます。
デナリのエンベデッド • メモリ • ソリューションを使用する主なメリットとして、
これらのモ
デルが、デナリのすべての検証ツールおよびデバッグ • ツールと連動する点が挙げられます。
デナリのすべてのメモリ • モデルの主な機能の一部を次に示します。
• ファイルからメモリに事前にロードできます。
• モデルに対して、
「バックドア」でリードおよびライトができます。
• メモリの内容を「ゴールデン」ファイルと比較できます。
• ファイルにメモリ内容を保存できます。
• メモリのトランザクションにアサーションをセットアップできます。
• エラー挿入機能および BIST 機能をセットアップできます。
• PureView を使用して、メモリ内容を対話形式で表示および編集できます。
デナリのモデルのもう 1 つの主な長所は、シミュレーションの占有領域が小さい点です。通
常、ベンダのモデルでは、メモリの記憶領域に大きな静的配列が使用されますが、デナリで
はダイナミック • メモリ • アロケーションが使用され、シミュレーション時に使用されるメモ
リしかアロケートされません。
デナリの PureView グラフィカル • デバッガを使用して、シミュレーション時にエンベデッド •
メモリの内容を表示でき、シミュレーション中に内容を " オンザフライ " で編集できます。
MMAV ユーザ • ガイド
11/6/08
110
5.9.1
レジスタ • ファイル
PureView を使用すると、独自のレジスタ • ファイルを簡単に作成できます。次の図を参照して
ください。
図 5-4: PureView のレジスタ • ファイル • セクションの GUI
Auxiliary ピンのセクションも存在することに注意してください。
これによりエンベデッド • デ
バイスで共通の他のテスト • ピンなどを定義できます。これで Verilog または VHDL の正確な
シェルを作成し、
デザインに接続できます。ASIC サプライヤのデータシートのレジスタ • ファ
イルの特長を比較するだけで、簡単にデナリのレジスタ • ファイル • モデルを作成し、デザイ
ンでインスタンスを生成できます。デザインにデナリのレジスタ • ファイルを追加すると、メ
モリ• モデルのすべての機能を利用できます。
デナリがデファクトのメモリ •モデル •ソリュー
ションとして位置付けられる理由は、まさにこの点にあります。
MMAV ユーザ • ガイド
11/6/08
111
5.9.2
エンベデッド SRAM
デナリのエンベデッド SRAM モデルは、可能な限り多くのライブラリを対象とすることを目
的とした汎用モデルです。通常、ベンダのメモリには、ここで説明するモデルの機能のサブ
セットが含まれています。
PureView のエンベデッド SRAM モデルのスクリーン • ショットを次に示します。
図 5-5: PureView のエンベデッド SRAM の GUI
デナリのエンベデッド SRAM モデルでは複数のデータ • ポートを定義でき、これらをリー
ド、ライト、またはリードとライトに柔軟に設定できます。
Read Pins Bit String フィールドおよび Write Pins Bit String フィールドは、I/O ポートのビッ
ト • マップ用に指定する必要があります。"1" は使用可能なポート、"0" は使用不可能なポート
を表します。たとえば、1 つのポートのメモリ部分に、次のように指定できます。
"Read Pins Bit String" = "1"
"Write Pins Bit String" = "1"
これは、データ入力ピンが 1 つ、データ出力ピンが 1 つあることを示します。2 つのポート
のメモリについて、次のように指定するとします。
"Read Pins Bit String" = "10"
"Write Pins Bit String" = "01"
MMAV ユーザ • ガイド
11/6/08
112
この場合、ポート 0 にデータ入力ピンが 1 つあり、データ出力ピンがないことを示します。
ポート 1 にはデータ入力ピンがなく、データ出力ピンが 1 つあることを示します。
2 つのポートのメモリについて、次のように指定するとします。
"Read Pins Bit String" = "11"
"Write Pins Bit String" = "11"
この場合は、ポート 0 にデータ入力ピンおよびデータ出力ピン ( リード / ライト ) が 1 つずつ
あることを示し、ポート 1 には、データ入力ピンおよびデータ出力ピンが 1 つずつあること
を示します。
5.9.3
エンベデッド DRAM
デナリでは、エンベデッド DRAM モデルも提供しています。今回、このモデルは、IBM の
SA27-E および Cu-11 のエンベデッド DRAM モデルにも完全に対応しています。PureView
の IBM エンベデッド DRAM モデルのスクリーン • ショットを次に示します。
図 5-6: PureView のエンベデッド DRAM の GUI
MMAV ユーザ • ガイド
11/6/08
113
CHAPTER
6
6
MMAV テストベンチの統合
この章では、サポートされているさまざまなテストベンチ • インターフェイスと MMAV との
統合について説明します。
6.1
Verilog インターフェイス
このセクションでは、Verilog テストベンチから MMAV を使用する方法について説明します。
6.1.1
MMAV と Verilog の概要
MMAV では、PLI を使用して Verilog を直接統合できます。PureView を使用することで、メ
モリ • モデル • インスタンスの Verilog ラッパーを生成できます。
詳細については、
10 ページの
「PureView グラフィカル • ツールの使用」を参照してください。
注意: 現在、デナリでは、言語ごとに専用のラッパーをサポートしています。たとえば、
ミックスド • モードのシミュレーションでは、Verilog ラッパーを使用している場合、
Verilog テストベンチでしかインスタンスを生成できません。VHDL ラッパーを使用し
ている場合は、VHDL テストベンチでしかインスタンスを生成できません。
また、MMAV では、メモリへのアクセス時に Verilog テストベンチへのコールバックを生成
できます。詳細については、20 ページの「[Simulation Environment]」を参照してください。
6.1.2
MMAV と Verilog のシミュレーション
Cadence Verilog-XL
Cadence Verilog シミュレータをモデルにリンクするには、Cadence リリースで提供される
vconfig スクリプトを実行します。このスクリプトは、いくつかのオプションを対話形式で要
求してくるので、適切な設定環境情報を回答してください。回答が不明の場合は、<RETURN>
キーを押してデフォルト値を選択してください。
veriuser.c ファイルの質問に対しては、たとえば、次のように ${DENALI}/verilog/
veriuser.c と入力します。
The user template file 'veriuser.c' must always be included in the link
statement. What is the path name of this file?
[veriuser.c] : ${DENALI}/verilog/veriuser.c
MMAV ユーザ • ガイド
11/6/08
114
Verilog 実行ファイルにリンクされる他のファイルに関する質問に対しては、たとえば、次の
ように ${DENALI}/verilog/denverlib.o と入力します。
List the files one at a time, terminating the list with a single '.'
-----------> ${DENALI}/verilog/denverlib.o
-----------> .
このプログラムが完了すると、cr_vlog という名前のスクリプトが作成されます。このスク
リプトを実行することにより、デナリ • モデルを含む新しい Verilog 実行ファイルが作成され
ます。
コンパイルスクリプトの例は次のとおりです。
#!/bin/csh -f
#
# Script to create : Dynamic PLI library
#
set verbose
mkdir $DENALI/verilog/lib
# Verilog XL
gcc -c $DENALI/verilog/veriuser.c \
-I$CDS_INST_DIR/tools/verilog/include
-o $DENALI/verilog/veriuser.o
\
# Linking step
ld -G
\
$DENALI/verilog/veriuser.o \
$DENALI/verilog/denverlib.o \
-o $DENALI/verilog/lib/libpli.so
unset verbose
Cadence NC-Verilog
デナリ PLI を NC-Verilog にスタティックにリンクする ( すべてのプラットフォーム ):
1. CDS_INST_DIR 環境変数を NC-Verilog のインストールディレクトリに設定します。
% setenv CDS_INST_DIR <nc_install_dir>
setenv INSTALL_DIR $CDS_INST_DIR
setenv ARCH to sun4v or lnx86 as appropriate
2. $CDS_INST_DIR/tools/inca/files/Makefile.nc ファイルをワーキング•ディレクト
リに Makefile としてコピーします。
% cp $CDS_INST_DIR/tools/inca/files/Makefile.nc Makefile
3. 以下のように Makefile のコピーを編集します。
VERIUSER_C ステートメントをデナリのコピーを指すように編集します。
VERIUSER_C = $(DENALI)/verilog/veriuser.c
ステートメントにデナリ PLI オブジェクト • モジュールを追加します。
PLI_OBJECTS = $(DENALI)/verilog/denverlib.o
MMAV ユーザ • ガイド
11/6/08
115
ダイナミック • リンクに使用する ARCH_RELOCATE_OPT 定義をコメントにします。
# ARCH_RELOCATE_OPT = ...
4. スタティックな実行形式コードを構築します。
% make static
Synopsys VCS
VCS で MMAV を実行する場合、シミュレータにデナリのメモリ • モデルをリンクする必要が
あります。他の Verilog PLI と異なり、VCS は veriuser.c を使用しません。その代わり、PLI
テーブルを読むことによってどの PLI 関数が存在するかを確認します。
VCS を実行する場合は、例は次のように、既存のコマンド • ラインに pli.tab ファイルとオ
ブジェクト • ファイルの場所を追加して MMAV とリンクさせます。
vcs -M -P $DENALI/verilog/pli.tab \
-LDFLAGS "$DENALI/verilog/denverlib.o" \
<your verilog files>
注意: 特定のプラットフォーム ( 特に Linux) では、次のような「ダイナミック • リンク • ライ
ブラリ」(-ldl を使用 ) とリンクさせる必要があります。
vcs -M -P $DENALI/verilog/pli.tab \
-LDFLAGS "$DENALI/verilog/denverlib.o" -ldl \
<your verilog files>
これで、simv を使用できようになります。
デナリ VCS PLI テーブル • ファイル
$DENALI/verilog 内に、
2 つの VCS PLI テーブル • ファイル (pli.tab と pli-fast.tab) があ
ります。
pli.tab ファイルは、ACC 機能が有効になる領域がデザイン全体となるように "*" ワイルド
カードを使用しています。
通常、初期化パフォーマンスの問題が発生しないようであれば、$DENALI/verilog/pli.tab
を使用するようにしてください。
pli-fast.tab ファイルは、ACC 機能が有効になる領域を制限するために、%TASK ワイルド
カードを使用しています。これによって、シミュレーション実行時の初期化が高速になり
ます。
このファイルを使用する際に以下のようなエラー•メッセージが表示されることがあります。
Error: acc__handle_by_name: Object memory_spec not found
この場合は、デナリのタスクが 1 つ以上の領域で使用されており、タスクをモジュールごと
に有効にするか、または $DENALI/verilog/pli.tab 内でワイルドカード "*" を使用するこ
とによって有効にする必要があります。
MMAV ユーザ • ガイド
11/6/08
116
Mentor Graphics ModelSim
Modelsim 用の PLI アプリケーションの指定
PLI アプリケーションはシミュレータによってダイナミックにロードされるため、どのアプ
リケーションをロードするかを指定する必要があります ( 各アプリケーションはダイナミッ
クにロード可能なライブラリでなければなりません )。詳細については、
『ModelSim User's
Manual』の「Compiling and linking PLI/VPI C applications」を参照してください。
注意: pliapp2 リファレンスと pliappn リファレンスはデナリの PLI アプリケーションではあ
りませんが、複数の PLI オブジェクトとデナリの PLI のリンク方法を説明するために
例を示してあります。
ModelSim 用の PLI アプリケーションを指定するには、次の 3 つの方法があります。ModelSim
用のデナリ PLI 共有オブジェクト • ファイルは、Unix/Linux の場合は mtipli.so です。この
ような共有ライブラリの使用方法は、次のように指定します。
1. modelsim.ini ファイル内の Veriuser エントリのリストとして
Unix:
Veriuser = $DENALI/mtipli.so
pliapp2.so
pliappn.so
2. PLIOBJS 環境変数のリストとして
Unix:
setenv PLIOBJS "$DENALI/mtipli.so
pliapp2.so pliappn.so"
\
3. シミュレータの -pli 引数として ( 複数の引数を使用可能 )
Unix:
% vsim -pli $DENALI/mtipli.so -pli pliapp2.so -pli pliappn.so
PLI アプリケーションの複数の指定方法を同時に使用することができます。システム • ライブ
ラリは上記の順序でロードされます。どの場合も、ライブラリへのパス内で環境変数の参照
を使用することができます。
ModelSim のタイムスケール
ModelSim でシミュレーションを実行するとき、デナリのタイムスタンプが正しく記録される
ように、ModelSim シミュレータではデザイン • モジュールの最小時間精度が使用されます。
つまり、
"-t" タイムスケール • コマンド • ライン • オプションを使用して時間精度を指定する必
要はありません。
"-t" タイムスケール • オプションを使用すると、タイミング • チェックに使用
されるタイムスタンプが間違っているというタイミング • エラー• メッセージが誤って表示さ
れます。
Aldec Rivera-PRO および Active-HDL
デナリ • モデルは、Verilog モジュールとしてインスタンス化することができます。このモデル
は、denali.so 共有オブジェクト • ライブラリ (Solaris、Linux) を介して Riviera-PRO と通信
します。ライブラリは Riviera-PRO および Active-HDL と共に配布されます。
MMAV ユーザ • ガイド
11/6/08
117
Verilogデザインでデナリ • メモリ• モデルをインスタンス化するには、次の手順を実行します。
• $DENALI 環境変数をデナリ • インストール • ディレクトリに設定します。この変数は、シ
ミュレータ (Riviera-PRO または Active-HDL) を実行する前に設定する必要があります。
• denali.so 共有オブジェクト • ライブラリ (Solaris、Linux) を、シミュレータに表示される PLI
アプリケーションのリストに追加します。
• メモリ • モデルを制御するためのデナリ Verilog プロシージャおよびタスクは、denali.so 共
有オブジェクト • ライブラリ (Solaris、Linux) にあります。Verilog コードでこれらのタスク
および関数を使用する場合、これらのタスクと関数が適切な引数を受け取っていること
を確認します。
致命的なエラー ( モデル • コンフィギュレーションを持つファイルが見つからない場合など )
が検出されるとデナリ • メモリ • モデルは終了し、シミュレーションが停止し、シミュレータ
が終了する場合があります。コマンド • ライン • モードでシミュレーションを実行すると、エ
ラーの原因を示すメッセージが OS コンソール • ウィンドウに表示されます。Riviera-PRO GUI
または Active-HDL を使用すると、GUI が閉じます。エラーの原因を確認するには、現在の
ディレクトリに作成される denali.error ファイルを参照してください。
6.1.3
コールバックの処理
MMAV Verilog コールバック • インターフェイスには、
モデル • コールバック初期化およびハン
ドリングの機能があります。
コールバック • インターフェイス
denaliMemCallback モジュールには、モデル内でイベントが発生すると、モデルによって
変更される整数変数が含まれています。この変数が変更されると、テストベンチ内でプロシー
ジャ • ブロックがトリガされ、コールバック • イベントが処理されます。
コールバック初期化
デナリ MMAV Verilog コールバックを使用するには、他の Verilog ファイルと共に $DENALI/
ddvapi/verilog/ddvapi.v ファイルをコンパイルする必要があります。このファイルに含
まれているタスクによって、
コールバック • ルーチンを実装するための必須タスクが提供され
ます。
コールバックは、MMAV アサーションがトリガされると生成されます。MMAV アサーショ
ンを設定する場合、"callback" <action> タイプを使用する必要があります。コールバック • ア
サーションの設定方法については、82 ページの「メモリ • トランザクションのアサーションの
設定」を参照してください。
モデル•イベント(またはモデル• イベントのセット)に対するコールバックをセットアップす
るには、
モデル • インスタンスのコールバックに付加される denaliMemCallback モジュール
をインスタンスします。
各モデル • インスタンスに対応する別のコールバック • インスタンス
が存在するため、各モデル • インスタンスのコールバックは、独立したプロシージャ • ブロッ
クによって処理されます。
denaliMemCallback モジュールがインスタンス化されると、モデル • インスタンス ID を持
つ setCallback() を呼び出して、有効なイベントを denaliMemCallback.Event 変数に付
加することによって、モデル • コールバックがセットアップされます。
MMAV ユーザ • ガイド
11/6/08
118
例 ( リードまたはライトの発生によるインスタンス testbench.uut1 でのコールバックの
セットアップ ):
denaliMemCallback cb
();
denaliMemTrans
trans ();
integer id0, asrt0, i;
initial
begin
id0 = $mminstanceid ("testbench.uut1");
asrt0 = $mmassert_access (id0, "ReadorWrite", "callback", 0,
'h7FFFFFFF);
// Enable All the Callback Types
for (i = 0; i < DENALI_CB_TOTAL; i = i + 1)
cb.enableReason [i] = i;
cb.setCallback (id0);
#1000000000;
$finish;
end
コールバック • ハンドリング
モデルからのコールバックの処理は、denaliMemCallback インスタンス内のイベント変数
によってトリガされた always ブロックで実行されます。シミュレーションの任意の時点で、
モデル内のさまざまな場所で同時に複数のコールバック • イベントが発生している場合があ
ります。コールバック • モデルは、モデル内でトリガされたイベントのリストを処理し、後続
の getCallback() 呼び出しごとにコールバック • モジュールのレジスタ変数を指定します。
この関数によって、追加イベントが存在する間は 1 が返され、最後のイベントが処理される
と 0 が返されます。
MMAV ユーザ • ガイド
11/6/08
119
getCallback() 関数の呼び出しごとに、
reason およびトランザクション ID (transId) 変数が
次に使用可能なコールバック • イベントと共にロードされます。次に、transId が、
denaliMemCallback transGet() タスクに渡され、イベントに関連付けられている実際の
パケットを検索します。
always @(cb.Event)
begin
while (cb.getCallback(id0))
begin
trans.transGet (cb.transId);
$display
$display
$display
$display
$display
$display
$display
$display
(
(
(
(
(
(
(
(
"time
"reason
"assertion
"reason
"address
"width
"data
"mask
:
:
:
:
:
:
:
:
%0t"
%0s"
%0h"
%0h"
%0h"
%0h"
%0h"
%0h"
,
,
,
,
,
,
,
,
$time
cb.reasonStr (cb.reason)
trans.assertion
trans.reason
trans.address
trans.width
trans.data
trans.mask
);
);
);
);
);
);
);
);
$display;
end
$display;
end
denaliMemCallback レジスタ
enableReason
enableReason は、
有効にするすべてのコールバック•イベントを指定するための32ビット値
の配列です。これらの値は、setCallback() タスクの呼び出しの前にユーザがロードする
必要があります。setCallback() は、ロケーション enableReason[0] から始まるこの配
列全体をステップ • スルーし、
最初の未初期化領域まで指定された各コールバック • イベント
を有効にします。最初の未初期化領域より上の enableReason[ ] 値はすべて無視されます。
この配列にロードされた値は、DENALI_CB_* などの ddvapi.vh の DENALIDDVCBpointT セ
クションで定義された使用可能なコールバック • イベントのセットから取得する必要があり
ます。
Event
Event は、モデル • コールバック関数に付加される整数変数です。有効な内部イベントがモデ
ルで発生すると、Event 変数が変更されます。この変数の値が変更されると、テストベンチ内
のプロシージャ • ブロックがトリガされ、現在のコールバック • イベントが処理されます。
MMAV ユーザ • ガイド
11/6/08
120
reason
reason は、
現在のコールバック • イベントを識別する整数値変数で、getCallback() 関数に
よってロードされます。
同じシミュレーション時刻に複数のコールバック • イベントが発生す
ると、reason が更新され、後続の getCallback() 呼び出しごとに次に使用可能なイベント
が識別されます。
transId
transId は、
現在のコールバック•イベントに関連付けられているトランザクションを識別する
整数値変数で、getCallback() 関数によってロードされます。同じシミュレーション時刻に
複数のコールバック • イベントが発生すると、transId が更新され、後続の getCallback()
呼び出しごとに次に使用可能なイベントのトランザクションが識別されます。
denaliMemCallback タスクおよび関数
setCallback()
モデル • インスタンス内でコールバックをセットアップし、
選択されたコールバック • イベン
トを denaliMemCallback モジュールの Event 変数に付加します。setCallback() を呼び
出す前に、有効にするコールバック • イベントが enableReason 配列内で初期化されている
必要があります。
task setCallback;
input [31:0] instId;
instId は、
デナリ • インスタンス ID ( ハンドル ) であり、
特定の MMAV インスタンスを識別し
ます。
getCallback()
現在のシミュレーション時刻にモデルからのコールバック • イベント全体をステップ • スルー
します。reason および transId 変数を設定し、後続の getCallback() 呼び出しごとに次に
使用可能なイベントを識別します。イベントが検出されると、戻り値は 1'b1 となります。ま
たは、イベントがすべて処理され、使用可能なイベントが存在しない場合は、1'b0 となります。
function getCallback;
input [31:0] instId;
instId は、
デナリ • インスタンス ID ( ハンドル ) であり、
特定の MMAV インスタンスを識別し
ます。
clearCallback()
デナリ • インスタンス ID が指定されたコールバックをクリアします。
function clearCallback;
input [31:0] instId;
MMAV ユーザ • ガイド
11/6/08
121
instId は、
デナリ • インスタンス ID ( ハンドル ) であり、
特定の MMAV インスタンスを識別し
ます。
reasonStr()
コールバック理由を ASCII 文字列として返します。
function [30*8:1] reasonStr;
input [31:0] reason;
case (reason)
DENALI_CB_None
DENALI_CB_Read
DENALI_CB_Write
DENALI_CB_ReadOrWrite
DENALI_CB_ReadNoWrite
DENALI_CB_ReadRead
DENALI_CB_WriteWrite
default
endcase
endfunction
:
:
:
:
:
:
:
reasonStr
reasonStr
reasonStr
reasonStr
reasonStr
reasonStr
reasonStr
=
=
=
=
=
=
=
"None";
"Read";
"Write";
"ReadOrWrite";
"ReadNoWrite";
"ReadRead";
"WriteWrite";
: reasonStr = "INVALID";
reason は、
$DENALI/ddvapi/verilog/ddvapi.vh で定義される DENALIDDVCBpointT 値の
1 つです。例:
$display ( "access : %0s" ,
cb.reasonStr (cb.reason));
これは、上記リストの reason 文字列の 1 つを表示します。
MMAV ユーザ • ガイド
11/6/08
122
6.2
VHDL インターフェイス
このセクションでは、VHDL テストベンチから MMAV を使用する方法について説明します。
6.2.1
MMAV と VHDL の概要
MMAV では、各シミュレータ固有の C インターフェイスを使用して VHDL を直接統合でき
ます。PureView を使用する場合、VHDL ラッパーには各シミュレータ固有の情報があるため、
使用するシミュレータを選択して、
メモリ • モデル • インスタンスのラッパーを生成する必要
があります。詳細については、10 ページの「PureView グラフィカル • ツールの使用」を参照
してください。
注意: 現在、デナリでは、言語ごとに専用のラッパーをサポートしています。たとえば、
ミックスド • モードのシミュレーションでは、Verilog ラッパーを使用している場合は、
Verilog テストベンチでしかインスタンスを生成できません。VHDL ラッパーを使用し
ている場合は、VHDL テストベンチでしかインスタンスを生成できません。
6.2.2
MMAV と VHDL のシミュレーション
Synopsys VCS
VHDL 内からデナリ呼び出しにアクセスするには、次の手順を実行する必要があります。
1. $DENALI/vhpi/memory_modeler.vhd ファイルをコンパイルします。
2. 以下をエンティティのトップ • レベルに含めます。
use work.Memory_Modeler.all;
Mentor Graphics ModelSim
Mentor Graphics ModelSim を使用して MMAV および VHDL のシミュレーションを実行するに
は、次のように入力します。
#!/bin/csh -fx
rm -rf work
vlib work
vcom $DENALI/mti/memory_modeler.vhd
vcom *.vhd
vsim -c testbench -do 'run -all'
MMAV ユーザ • ガイド
11/6/08
123
Cadence NC-VHDL (Leapfrog)
Cadence NC-VHDL を使用して MMAV および VHDL のシミュレーションを実行するには、次
のように入力します。
/bin/rm -rf WORK
mkdir WORK
ncvhdl -v93 -m -work WORK $DENALI/leapfrog/memory_modeler.vhd
ncvhdl -v93 -m -work WORK *.vhd
ncelab -messages -update WORK.TESTBENCH:BEHAVIOR
ncsim -messages -input -logfile simulation.log -LOADFMI $DENALI/
libdenfmi:den_FMIPtr WORK.TESTBENCH:BEHAVIOR
Aldec Rivera-PRO および Active-HDL
デナリ • モデルは、VHDL モジュールとしてインスタンス化することができます。
注意: バージョン 2007.06 までの Riviera-PRO の前バージョンおよびバージョン 7.3 までの
Active-HDL の前バージョンでサポートされていたのは、Verilog インスタンス生成の
みでした。
モデルは、denali.so 共有オブジェクト • ライブラリを介して Riviera-PRO と通信します
(Solaris、Linux)。ライブラリは Riviera-PRO および Active-HDL と共に配布されます。
VHDL デザインでデナリ • メモリ • モデルをインスタンス化するには、次の手順を実行します。
• $DENALI 環境をデナリ • インストール • ディレクトリに設定します。この変数は、シミュ
レータ (Riviera-PRO または Active-HDL) を実行する前に設定する必要があります。
10 ページの「PureView
• PureView で生成された VHDL ラッパー• ファイル ( 詳細については、
グラフィカル • ツールの使用」を参照 ) で、形式が異なるアーキテクチャの属性を次の形
式となるように編集します。
attribute foreign of <architecture> : architecture is "VHPI \
denali;initDenali"
MMAV ユーザ • ガイド
11/6/08
124
現在、PureView では、[Options] > [Simulation Environment] > [VHDL] を選択しても、
リストに表示される他のシミュレー
Riviera-PRO または Active-HDL はリストされません。
タのラッパー • ファイルを生成して、形式の異なる属性が上記の仕様と一致するように編
集することは可能です。
次の例は、PureView を使用して生成した後、Aldec の要件に一致するように編集したサン
プル • モデルです (regfile001.vhdl ファイル )。
-- Entity: regfile001
-- SOMA file: /home/joe/mems/regfile001.soma
-- Initial contents file:
-- Simulation control flags:
LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.all;
ENTITY regfile001 IS
GENERIC (
memory_spec: string := "regfile001.soma";
init_file:
string := "init.txt";
sim_control: string := ""
);
PORT (
addressWR : in STD_LOGIC_VECTOR(14 downto 0);
dataIn
: in STD_LOGIC_VECTOR(7 downto 0);
we
: in STD_LOGIC;
clk
: in STD_LOGIC;
addressRD : in STD_LOGIC_VECTOR(14 downto 0);
dataOut
: out STD_LOGIC_VECTOR(7 downto 0);
cs
: in STD_LOGIC
);
END regfile001;
ARCHITECTURE behavior of regfile001 is
attribute foreign: string;
attribute foreign of behavior: architecture is "VHPI denali;
initDenali";
BEGIN
END behavior;
• メモリ • モデルを制御するためのデナリ VHDL プロシージャと関数は、
memory_modeler.vhd
パッケージ内にあります。VHDL コードで 3 つの関数を使用する場合、Memory_Modeler
パッケージをコンパイルし、適切な library ステートメントと use ステートメントを追加
します。パッケージのソース • コードを入手するには、Riviera-PRO または Active-HDL イ
ンストール • ディレクトリにある memory_modeler.vhd ファイルにアクセスします。
注意: このインターフェイスについては、Aldec 社にお問い合わせください。
MMAV ユーザ • ガイド
11/6/08
125
6.3
SystemC インターフェイス
MMAV では、SystemC を直接統合できます。PureView を使用することで、メモリ • モデル • イ
ンスタンスの SystemC ラッパーを生成できます。デナリの SystemC 統合では、Yukon C イン
ターフェイスを使用してシミュレーション • パフォーマンスを大幅に向上させます。
6.3.1
MMAV と SystemC の概要
SystemC は、主にシステム • レベルの設計に使用される C++ シミュレーション環境です。
SystemC は、C++ クラス • ライブラリと、動作レベルおよびレジスタ転送レベルのシミュレー
ション•カーネルで構成されるモデリング•プラットフォームです。
SystemC自体の詳細につい
ては、http://www.systemc.org を参照してください。
SystemC 環境と MMAV の統合は、次の内容で構成されます。
• MMAV モデル用 SystemC ラッパー
• デナリ • ライブラリ
• ラッパーとデナリ Yukon ライブラリ間のインターフェイスに使用されるインテグレー
ション • ファイル
MMAV モデル用 SystemC ラッパーは、PureView インターフェイスを使用して生成できます。
[Options] > [Simulation Environment] > [SystemC] を選択します。ラッパーが生成されると、
SystemC テストベンチでトップ • レベルの sc_module のインスタンスを生成できます。
6.3.2
MMAV と SystemC のシミュレーション
メモリ • モデルの DDR クラスを使用した例については、
$DENALI/yukon/example ディレクトリ
を参照してください。このディレクトリには、サンプルのテストベンチと、MMAV と SystemC
をリンクするための Makefile もあります。
$DENALI リリースの yukon ディレクトリには、関連するデナリ • ライブラリ (libyukon.o および
libyukon.so) があります。
このディレクトリのREADMEファイルの説明に従って例をコンパイルおよび実行することを
お勧めします。これによって、使用する環境が適切に設定され、適切なデナリ • ライセンスが
機能します。
GNU C++ コンパイラはバージョン 2.95 以降を使用する必要があります。
SystemC
の例は、バージョン 2.95.2 を使用して検証済みです。
この例を正常に実行したら、この例をコピーし、使用する環境と目的に合わせて変更します。
この例には、次の 3 つの C++ ファイルがあります。
• main.cc
このファイルはテストベンチの例です。このファイルは実際のテストベンチと置き換え
られます。この例に示すように、保留になっているトランザクションを正常にダンプす
るために、シミュレーションの終了時に DENALIterminate を呼び出すことが重要です。
• simulator.cc
このファイルは、Yukon インターフェイスを介してデナリと SystemC のインターフェイ
スの役目をするファイルです。
MMAV ユーザ • ガイド
11/6/08
126
• ddr.cc
このファイルは、PureView を使用して生成されたモデル用のデナリ • ラッパーです。
MMAV ユーザ • ガイド
11/6/08
127
6.4
Specman インターフェイス
このセクションでは、Specman 環境で MMAV を使用する方法について説明します。
このマニュアルで説明するコールバック • メソッドを使用するには、Specman 3.3.1 以降を使用
して MMAV バージョン 3.2 が実行されている必要があります。
Specman によってデナリ MMAV を使用する方法の詳細については、
『Specman Elite Denali
MMAV Interface Guide』の第 14 章の「Usage and Concepts Guide for Specman 」を参照してくだ
さい。これらのマニュアルは、Cadence Specman リリースの docs ディレクトリにあります。
6.4.1
MMAV と Specman の概要
ユーザは、
デナリ • メモリ • モデルにアクセスしたり、デナリ • メモリ • モデルからアクティビ
ティを取得したりできます。
Specman Elite/ Denali Interface (SNDI) には、以下を使用して、e テストベンチからデナリ • メモ
リと通信する方法が 2 つあります。
• e に移植されたデータ • ドリブン検証 (DDV) 手法
• コールバック
メモリには、デナリ DDV API 関数を使用してアクセスできます。
Specman からデナリ • メモリ • モデルにアクセスするには、最初に通常どおり PureView を使用
して HDL シェルを作成し、テストベンチまたは DUT でこのシェルのインスタンスを生成し
ます。詳細については、10 ページの「PureView グラフィカル • ツールの使用」を参照してく
ださい。
SNDI インターフェイス用にあらかじめ定義されたユーザによるアクセス可能な e 構造体が 2
sn_denali の 1 つのグローバル • インス
つあります (sn_denali および sn_denali_unit)。
タンスには、
グローバル • ベースでメモリ • モデルと対話するために 4 つのメソッドが関連付
けられています。2 番目の構造の sn_denali_unit は、組み込みリード / ライト • メソッドに
アクセスできるようにするために継承する必要がある抽象ユニット • タイプです。
これを実行
するには、Spec-man Elite SN_DENALI_MEMORY_UNIT テンプレート • マクロを使用します。こ
のマクロを使用するには、幅を指定する必要があります。以下はその例です。
<'
SN_DENALI_MEMORY_UNIT demo_denali64 using width = 64;// model width must
// be defined
extend sys {
mem1: demo_denali64 is instance;
keep mem1.hdl_path() == "/top/mem1";
};
'>
SNDI は、sn_denali_unit の最初のインスタンスが生成されると、自動的に初期化されま
す。この初期化時に、デナリ共有ライブラリがロードされ、デナリ • シミュレータが初期化さ
SN_DENALI_MEMORY_UNIT インスタンスが API の対応するインスタンスに結合されます。
れ、
MMAV ユーザ • ガイド
11/6/08
128
次の図は、Specman、デナリ、および検証環境の関係を示しています。
図 6-1: 検証環境
6.4.2
MMAV と Specman のシミュレーション
Mentor Graphics ModelSim
Mentor Graphics ModelSim を使用して MMAV および Specman のシミュレーションを実行する
には、次の手順を実行します。
1. 環境変数を設定します。
SPECMAN_AUTO_PRE_COMMANDS=false; export SPECMAN_AUTO_PRE_COMMANDS
SN_AUTO_PRE_COMMANDS=false; export SN_AUTO_PRE_COMMANDS
2. デナリを含む共有ライブラリ libqvlsn_basic.so を作成します。
sn_compile.sh -sim qvl -l "$DENALI/mtipli.so"
3. 作成した共有ライブラリを使用します。
SPECMAN_LIBQVL=`pwd`/libqvlsn_basic.so; export SPECMAN_LIBQVL
4. コンパイル前にクリーン • アップします。
rm -rf verilog/specman.v work
vlib work
5. Verilog スタブ • ファイルを作成します。
specman -commands "define VERILOG_ENV; load e_code/mem_top.e; write
stubs -verilog verilog/specman.v;"
6. verilog をコンパイルします。
vlog verilog/tb.v verilog/essram.v verilog/specman.v +incdir+verilog
7. 次のコマンドで Specview と ModelSim GUI が起動したら、次の手順を実行します。
− シミュレータ GUI プロンプトで sn を入力した後、RETURN キーを押します。
MMAV ユーザ • ガイド
11/6/08
129
−
Specman GUI で、テストケース ($DENALI/example/specman/e_code/mem_tc1.e
or e_code/mem_tc2.e) をロードします。
−
−
−
Specman GUI で [Test] をクリックします。
RETURN キーを押して、シミュレータ GUI に移動します。
ModelSim GUI で run -all を入力し、シミュレーションを実行します。
specview -p "define VERILOG_ENV;\
set wave -mode=interactive mti; load e_code/mem_mti_wave; \
load e_code/mem_top;" \
vsim -keepstdout tb specman specman_wave &
Synopsys VCS
Synopsys VCS 使用して MMAV および Specman のシミュレーションを実行するには、次の手
順を実行します。
1. スタブ • ファイル specman.v を作成します。
specman -commands "define VERILOG_ENV; load e_code/mem_top.e; write
stubs -verilog verilog/specman.v;"
2. デナリを含むシミュレータ -Specman リンク実行ファイルをコンパイルします。
sn_compile.sh
-vcs_flags
-vcs_flags
-vcs_flags
-vcs_flags
-sim vcs \
"+incdir+verilog" \
"-I verilog/tb.v verilog/essram.v verilog/specman.v" \
"-P $DENALI/verilog/pli.tab" \
"-LDFLAGS $DENALI/verilog/denverlib.o"
3. 次のコマンドで Specview および VCS GUI が起動したら、次の手順を実行します。
− シミュレータ GUI プロンプトで $sn を入力した後、RETURN キーを押します。
− Specman GUI で、テストケース (e_code/mem_tc1.e or e_code/mem_tc2.e) をロード
します。$DENALI/example/specman を参照してください。
− Specman GUI で [Test] をクリックします。
− RETURN キーを押して、シミュレータ GUI に移動します。
− 波形ビューアに HDL 信号を追加します。
− vcs GUI プロンプトで「.」を入力し、シミュレーションを実行します。
specview -p "define VERILOG_ENV; load e_code/mem_top.e;" vcs \
-Mupdate -o ./vcs_specman -RIG verilog/tb.v verilog/essram.v \
verilog/specman.v &
MMAV ユーザ • ガイド
11/6/08
130
6.4.3
コンフィギュレーション • レジスタおよびメモリへのアクセス
MMAV インターフェイスとの Specman の統合によって、メモリをリード / ライトできるよう
になります。
SNDI メソッド
Specman Elite/ デナリ • インターフェイス • メソッドは、DDVAPI を介して sn_denali タイプお
よび sn_denali_unit タイプに移植されている MMAV の関数です。この統合によって、
Specman 環境のままデナリ • データ • ドリブン検証インターフェイスへのアクセスが可能にな
ります。ただし、すべての MMAV 関数が Specman に統合されているわけではありません。e
コード内で使用できるのは Specman デナリのあらかじめ定義されたメソッドのみです。
また、e は unknown 値を理解しないため、SNDI インターフェイスでは、unknown 値をリード
し、
デナリ • メモリ • モデルにライトするためのメソッドが開発されています。read_unk() や
write_unk() がその例です。
sn_denali メソッドと sn_denali_unit メソッドの詳細については、
Specmanインストール •
ディレクトリの using_sn_denali_interface.pdf を参照してください。
6.4.4
sn_denali_unit を拡張してすべての MMAV 関数をメソッドとし
て含める
MMAV のすべての関数が sn_denali_unit のメソッドに移植されているわけではありませ
ん。これらのメソッドを含めるために sn_denali_unit を簡単に拡張できます。これを示す
単純なコードは次のとおりです。
MMAV ユーザ • ガイド
11/6/08
131
// Sample Code Snippet for extending sn_denali_unit
<'
define SN_DENALI_ADDR_SIZE
32; //Define the Max Addr Size in Bits
define SN_DENALI_DATA_SIZE
512; // Define the Max Data Size in Bits
define SN_DENALI_SMALL_STRING_SIZE 96; // Define the Max String Size in
// Bits
define SN_DENALI_STRING_SIZE 2048;// Define the Max String Size in Bits
extend sn_denali_add_on {
instance : string;
mem_id : uint;
!verilog_instance : list of byte;
str_e2v(e_string : string): list of byte is {
var packed_str: list of byte;
packed_str = pack(packing.network, e_string);
result = packed_str[1..]; // skip the first 0 byte
}; // End Method str_e2v
}; // End Struct sn_denali_add_on
extend sn_denali_unit {
run() is also {
add_on.instance = me.full_hdl_path();
add_on.verilog_instance = add_on.str_e2v(add_on.instance);
add_on.mem_id = me.get_id();
};
verilog function '~/$mmassert_uma' ( action :
SN_DENALI_SMALL_STRING_SIZE ) : 1;
assert_uma ( action : string ) @sys.any is {
var packed_val : list of byte;
var status : uint (bits:1);
packed_val = add_on.str_e2v(action);
status = '~/$mmassert_uma'(packed_val) ;
check that (status == 0) else dut_error(appendf("%12d ns (%s) ERROR:
Denali method call to assert_uma(%s) failed RC=%d",
sys.time,add_on.instance,packed_val,status));
};
'>
MMAV ユーザ • ガイド
11/6/08
132
この e ファイルによって MMAV のすべての関数が sn_denali_unit にメソッドとして拡張
されるわけではありませんが、代表的な関数は拡張されます。MMAV 関数が追加されたこと
で、メモリ • サブシステム用のテスト環境を構築できます。
ここで定義されているメソッドは、$DENALI/example/sndi_example/sn33_denali.e に
あります。
6.4.5
波形でのメモリ • トランザクションの表示
Specman Elite を使用することで、波形ウィンドウで信号を表示できるだけでなく、メモリの
イベントまたはトランザクションも表示できます。次の図は、memory_0 のアクションが波
形ウィンドウに表示された様子を示しています。
図 6-2: 波形ウィンドウに表示されたイベントの波形
6.4.6
テストケースの例
$DENALI/example/specmanディレクトリからコールバックが含まれている基本的なサンプ
ルにアクセスできます。この例には、SRAM、SDRAM、SMROM、および ESSRAM の例が含
まれています。
また、$DENALI/examples/specman には SNDI の詳細な例があります。このテストケース
では、SNDI からのコールバックと共に、デナリからのシステム • メモリを使用します。
MMAV ユーザ • ガイド
11/6/08
133
6.5
Vera インターフェイス
このセクションでは、Vera テストベンチから MMAV を使用する方法について説明します。
Vera でデナリ MMAV を使用する方法の詳細については、$VERA_HOME/lib/denali/
README_DDVAPI を参照してください。
6.5.1
MMAV と Vera の概要
デナリのデータ • ドリブン検証 (DDV) 手法は Vera に移植されています。MMAV-Vera 関数およ
びタスクについては、$VERA_HOME/lib/denali/denali_ddv.vrh を参照してください。
MMAV で使用可能な関数の一部は、MMAV-Vera インターフェイスに統合されません。この
ようなデナリ関数は、
デナリTCLインタープリタから呼び出してアクセスします。
Vera DirectC
関数 DenaliDDVTclEval() を使用して、デナリ TCL インタープリタから TCL ルーチンを実
行できます。この TCL ルーチンによって、デナリ関数のいずれかが呼び出されるか、いずれ
かの TCL スクリプトが実行されます。
次の例は、この呼び出しによって実行される TCL スクリプトを示しています。
// Tcl call from within Vera Testbench
integer iErr;
iErr = DenaliDDVTclEval ("source MyDenaliTclFile.tcl");
// Tcl Routine -- MyDenaliTclFile.tcl
mmsaverange /tb/mem/sdram0 save.dat 0 31
mmcomp /tb/mem/sdram0 golden.dat
この例では、
メモリ • インスタンス /tb/ mem/sdram0 のアドレス 0 ~ 31 の内容が save.dat
ファイルに保存され、メモリ /tb/mem/ sdram0 全体の内容がゴールデン • ファイル
golden.dat と比較されます。
MMAV ユーザ • ガイド
11/6/08
134
アーキテクチャ
次の図は、MMAV-Vera インターフェイス • アーキテクチャを示しています。
図 6-3: MMAV と Vera のアーキテクチャの概要
6.5.2
MMAV と Vera のシミュレーション
シミュレータで MMAV および Vera を使用するには、最初にマニュアルの指示に従って適切
なライブラリをリンクします。
Vera 環境で MMAV を使用するための手順は次のとおりです。
1. Vera からデナリ • メモリ • モデルにアクセスするには、最初に PureView を使用して HDL
シェルを作成し、テストベンチまたは DUT でこのシェルのインスタンスを生成します。
詳細については、
10ページの
「PureViewグラフィカル•ツールの使用」を参照してください。
2. Vera に移植された DDV 関数へのアクセスを取得するには、
ヘッダ • ファイルを Vera テス
トベンチにインクルードする必要があります。
#include <denali_ddv.vrh>
注意: MMAV は、これまでの CAPI インターフェイスをサポートしていません。MMAV Vera
インターフェイスでは、DDVAPI を使用します。DDVAPI 関数の詳細については、
$DENALI/doc/ddvapi.pdf を参照してください。
このマニュアルには、CAPI から DDVAPI
への移行についての説明も記載されています。Vera のドキュメント『$VERA_HOME/
lib/denali/README_DDVAPI』には、CAPI から DDVAPI への変更内容について記載さ
れています。
3. Vera テストベンチからデナリ • メモリを初期化します。詳細については、136 ページの
「Vera テストベンチからのデナリ • メモリ • モデルの初期化」を参照してください。
4. コールバックをセットアップします ( オプション )。詳細については、137 ページの「コー
ルバックの処理」を参照してください。
MMAV ユーザ • ガイド
11/6/08
135
5. 必要に応じて、Vera テストベンチから他のデナリ関数を呼び出します ( オプション )。詳
細については、139 ページの「Vera テストベンチからの他のデナリ関数の使用」を参照し
てください。
6. デナリ、Vera、およびシミュレータをリンクし、テストベンチを実行します。
Synopsys VCS
Synopsys VCS 使用して MMAV および Vera のシミュレーションを実行するには、次のように
入力します。
#! /bin/sh -f
vera -cmp display.vr
make -f Makefile_vcs
注意: Makefile_vcs は、$DENALI/example/vera/denali_vera.tar.gz に用意されています。
$VERA_HOME/lib/denali/README_DDVAPI ファイルでも、別のプラットフォームの
run スクリプトが用意されています。
6.5.3
Vera テストベンチからのデナリ • メモリ • モデルの初期化
任意の関数を使用してデナリ • メモリ • モデルにアクセスするには、最初に Vera 内からシミュ
レータ API を初期化する必要があります。この手順は、
デナリ • メモリ • モデルが Vera と対話
するために実行される必要があり、メモリの事前ロード、バックドア • リード / ライトの発行、
メモリの内容のダンプなどの他のデナリ関数を発行する前に呼び出す必要があります。
メモリ • シミュレータ API の初期化は、シミュレーション時に 1 回だけ呼び出す必要がありま
す。初期化を呼び出すには、Vera 内から DENALDDVIinitialize 関数を呼び出します。
DENALIDDVinitialize (string init, string reportFunc, var integer
unknownsP, string elabDone, string clientName);
引数
init
タイプ
string
reportFunc
string
unknownsP
var integer
説明
これらの 2 つの引数は、エクスポートされた VERA タスクの
名前を付ける文字列が、デナリによるコールバックの初期化お
よびアクセス時に登録されるように指定します。Null 文字列引
数は、コールバックを無効にします。
この変数は、シミュレータにアドレス内容データに unknown
を保存する方法を通知します。オプションには 3 つの形式が
あります。
•
•
•
MMAV ユーザ • ガイド
11/6/08
unknownsNBit1- 不明ビットはデータのビットごとに保存
されます。
unknowns1Bit1 - 不明ビットはデータのアドレス内容ごと
に保存されます。
unknowns0Bit0 - 不明ビットはデータのアドレス内容ごと
に保存されます。
136
引数
elabDone
タイプ
string
clientName
string
説明
エクスポートされた VERA タスクの名前がシミュレーション
の開始時にデナリによって呼び出されるように指定します。こ
れは、クライアントがメモリの所有権を取得するというまれな
事例でのみ設定されます。一般的には、設定する必要はありま
せん。Null 文字列引数は、このコールバックを無効にします。
クライアント名を指定します。
例:
integer iErr;
iErr = DenaliDDVinitialize( "DramInitCbk", "DramAccCbk1", iUnkMode,"",
"DDVAPI Denali Vera Example");
この例では、成功の場合、iErr に 0 が返されます。
6.5.4
コールバックの処理
コールバック • タスクは、初期中または AccessSetCallback 関数の呼び出し後に宣言され
ます。
Vera および MMAV インターフェイスには次の 3 種類のコールバックがあります。
• 初期化コールバック
• アクセス • コールバック
• 反復コールバック
詳細については、$VERA_HOME/lib/denali/README_DDVAPI を参照してください。
MMAV ユーザ • ガイド
11/6/08
137
次の例は、コールバックの例を示します。
integer iErr;
iErr = DenaliDDVaccessSetCallback("regCbFunc");
export task regCbFunc(integer id, integer access, integer portNum)
{
bit [31:0] bData;
bit [31:0] bMask;
bit [63:0] address;
integer iWidth, iErr;
integer memId;
iErr = DenaliDDVgetIdByName("testbench.i0", memId);
if (id == memId) {
iErr = DenaliDDVaccCbkGetDataAndMask( iWidth, bData, bMask,
address);
}
}
この例では、成功の場合、iErr に 0 が返されます。
すべてのコールバックを無効にしたり、
特定のメモリ • コールバックのみを無効にしたりでき
ます。
すべてのコールバックを無効にするには、次のように入力します。
iErr = DenaliDDVTclEval("mmdisablecallbackall");
特定のメモリのコールバックを無効にするには、次のように入力します。
iErr = DenaliDDVTclEval("mmdisablecallback -user <instance_id>");
すべてのコールバックまたは特定の 1 つのメモリ • インスタンスのみを無効にした場合、
それ
ぞれのコールバックを有効にできます。
iErr = DenaliDDVTclEval("mmenablecallback -user <instance_id>");
MMAV ユーザ • ガイド
11/6/08
138
コールバックのブロックキング割り当て
コールバック関数として設定された Vera エクスポート • タスクは、ブロックされずに返され
ます。このようなブロックは、明示的には "@(posedge clock)" などによって、暗黙的には HDL
信号のリードまたはライトによって発生し、
信号に関連付けられたクロック • エッジをブロッ
クキングします。
コールバック応答のブロッキング • コードを実行する必要がある場合、このコードは、コール
バック • タスクから fork-join-none コンストラクトの個別のスレッドで作成可能です。ただし、
メインのコールバック • スレッドは、ブロックキングされずに返されます。
コールバック • コードは、ブロックが実行されるように記述できます。このような場合、最初
のコールバックがアクティブである間に 2 番目のコールバックが発生する場合があります。
Vera では、この状態を検知して、2 番目のコールバックを破棄します。
Vera では、コールバック • ブロック • エラーを 2 回検出します。最初のエラーは、コールバッ
クが「非同期的に」返されなかった場合 ( ブロック未実行 ) で、この場合、最初のコールバッ
クがアクティブであっても 2 番目のコールバックが発生します。両方の場合とも、エラーの
DENALIerror_NoError の代わりに DENALIerror_Unknown が
発生が Vera によって示され、
デナリに返されます。
ただし、Vera DirectC 関数呼び出し DenaliDDVwarnDiscardedCbk(1) が実行された場合、
エラー • メッセージまたは警告メッセージがいずれの場合も出力されます。
6.5.5
Vera テストベンチからの他のデナリ関数の使用
必要に応じて、Vera テストベンチから他のデナリ関数を使用できます。これはオプションです。
次の例を参照してください。この例では、DenaliDDVgetIdByName によって特定のインス
タンス名に対応するインスタンス ID が返され、DenaliDDVload によってファイル file.dat
のデータを持つメモリ•インスタンスがロードされます。また、
この例は、DenaliDDVTclEval
を使用した mmsomaset の使用方法も示しています。
integer id;
integer iErr;
integer unk = 0;
string
string
string
string
inst =
file =
init =
access
iErr
iErr
iErr
iErr
DenaliDDVinitialize("", "", unk, "", "API");
DenaliDDVgetIdByName(inst, id);
DenaliDDVload(id, file);
DenaliDDVTclEval("mmsomaset testbench.i0 tds 0.4 ns");
=
=
=
=
"testbench.i0";
"file.dat";
"";
= "";
この例では、成功の場合、iErr によって 0 が返されます。
MMAV ユーザ • ガイド
11/6/08
139
6.5.6
テストケースの例
テストケースは、$DENALI/example/vera/denali_vera.tar.gz からダウンロードでき
ます。
テストケースの例では、デナリ -Vera インターフェイスの多くの共通の機能を示すために、
DRAM を使用します。
図 6-4: デナリ -Vera の例の図
MMAV ユーザ • ガイド
11/6/08
140
6.6
6.6.1
NTB インターフェイス
MMAV と NTB の概要
MMAV は、NTB テストケースをサポートするネイティブ • クラスベースのオブジェクト指向
インターフェイスを備えています。このインターフェイスは、NTB クラスと、メモリへのア
クセスを追跡し、バックドア • リード / ライトを実行するためのメソッドで構成されます。ま
た、このような NTB クラスを使用して、(PLI ベース ) Verilog プロシージャ • インターフェイ
スで使用可能なその他の操作を実行することもできます。
6.6.2
MMAV と NTB のシミュレーション
このセクションでは、Synopsys VCS シミュレータを使用した MMAV と NTB のシミュレー
ションについて説明します。
Synopsys VCS
Synopsys VCS 使用して MMAV および NTB のシミュレーションを実行するには、次の手順を
実行します。
1. Verilog および Vera ソース / テストベンチ • ファイルと共に denaliMem.vr ファイルと
denaliMemVrIf.c ファイルをコンパイルします。
2. デナリ Verilog ライブラリ (denverlib.o) にリンクします。
vcs \
-ntb +vc+allhdrs \
-M -P $DENALI/verilog/pli.tab \
-CFLAGS "-DDENALI_USE_NTB=1 -I/usr/local/include -I${DENALI} I${DENALI}/ddvapi -c " \
-LDFLAGS "-rdynamic $DENALI/verilog/denverlib.o" \
$DENALI/ddvapi/vera/denaliMemVrIf.c \
-ntb_define DENALI_USE_NTB=1 $DENALI/ddvapi/vera/denaliMem.vr \
+incdir+$DENALI/ddvapi/verilog \
*.vr *.v;
注意: この例で使用される '-rdynamic' フラグは、Linux 専用です。
6.6.3
インスタンスとトランザクション • クラス
NTB メモリ • アクセス機能によって、メモリ • リファレンスを追跡して、リード / ライト動作
を実行できます。
メイン • クラスは次のとおりです。
• 142 ページの「クラス denaliMemInstance」
• 153 ページの「クラス denaliMemInstanceList」
MMAV ユーザ • ガイド
11/6/08
141
• 154 ページの「クラス denaliMemTransaction」
これらのクラスの各フィールドでは、フィールド値の取得に必要な get<field_name> アクセ
ス • メソッドがフィールドに関連付けられています。また、すべてのライト可能なフィールド
には、フィールド値の設定に必要な set<field_name> があります。このようなフィールドはパ
ブリックであるため、これらのフィールドに直接アクセスすることができます。
ステータス • コードを返すメソッドはすべて、失敗の場合は "-1" を、成功の場合は "0" を返し
ます。別途指定されていない限り、デフォルトのコンストラクタのみを使用できます。
set<field_name> メソッドと get<field_name> メソッドの指定フィールド名の最初の文字は大文
字です。したがって、Address の値を取得する場合、メソッドは getAddress となります。
クラス denaliMemInstance
NTB 環境で MMAV を使用してメモリにアクセスするには、denaliMemInstance のインス
タンスを生成します。denaliMemInstance は、テストベンチでインスタンス生成されたか、
コンフィギュレーション空間などのデナリ • モデルによって作成されたメモリ • インスタンス
に対応します。
次のセクションでは、denaliMemInstance クラスについて説明します。
コンストラクタ
task new(string instName, string cbTaskName = "")
引数
名前
instName
タイプ
string
説明
cbTaskName
string
コールバック • タスク名。
インスタンス名。
説明
新しいインスタンス • オブジェクトを作成します。
instName は完全なパス名である必要があり、
コンストラクタに対して cbTaskName を null に
できます。ただし、明示的な DPI コールバック • タスクを定義する場合、コールバック • ポイ
ントをモニタ用に追加する前に設定する必要があります。
注意: cbTaskName フィールドの使用は、お勧めしません。
戻り値
このタスクは、新しく作成されたオブジェクトを返します。
MMAV ユーザ • ガイド
11/6/08
142
例
denaliMemInstance inst;
inst = new("ddr0");
メソッド
名前
getId()
説明
getInstName()
インスタンス名を取得します。
setCbTaskName()
DPI コールバック • タスク名を設定します。
getCbTaskName()
DPI コールバック • タスク名を取得します。
setCallback()
メモリへのアクセス時のコールバックを設定します。
write()
メモリ内容をライトします。
read()
メモリ内容を返します。
tclEval()
埋め込み Tcl インタープリタを使用して Tcl コマンドを実行します。
ReadCbT()
このタスクは、リード・コールバックが発生すると呼び出されます。
WriteCbT()
このタスクは、ライト・コールバックが発生すると呼び出されます。
DefaultCbT()
このタスクは、有効なコールバックが発生すると呼び出されます。
LoadCbT()
このタスクは、ロード・コールバックが発生すると呼び出されます。
LoadDoneCbT()
このタスクは、ロード完了コールバックが発生すると呼び出されます。
ResetCbT()
このタスクは、リセット・コールバックが発生すると呼び出されます。
CompCbT()
このタスクは、比較コールバックが発生すると呼び出されます。
CompDoneCbT()
このタスクは、比較完了コールバックが発生すると呼び出されます。
ReadEiCbT()
このタスクは、現在のメモリ • リード動作にエラーが挿入されると呼び出されます。
ID を取得します。
getId()
デナリ • メモリへのアクセスに使用される ID を取得します。
構文
virtual function integer getId()
引数
なし
戻り値
この関数は、ID を返します。
MMAV ユーザ • ガイド
11/6/08
143
例
denaliMemInstance inst;
inst = new("ddr0");
$display("MemId = %d\n ", inst.getId());
getInstName()
インスタンス名を取得します。
構文
virtual function string getInstName()
引数
なし
戻り値
この関数は、インスタンス名を返します。
例
denaliMemInstance inst;
inst = new("ddr0");
$display("InstName = %s", inst.getInstName());
setCbTaskName()
DPI コールバック • タスク名を設定します。
注意: デナリでは、ユーザ定義の DPI タスクの使用をお勧めしません。
構文
virtual task setCbTaskName(string cbTaskName)
引数
名前
cbTaskName
タイプ
string
説明
コールバック • タスク名。
戻り値
なし
MMAV ユーザ • ガイド
11/6/08
144
例
denaliMemInstance inst;
inst = new("ddr0");
inst.setCbTaskName("myCbFunc");
getCbTaskName()
DPI コールバック • タスク名を取得します。
注意: デナリでは、ユーザ定義の DPI タスクの使用をお勧めしません。
構文
virtual function string getCbTaskName()
引数
なし
戻り値
この関数は、コールバック • タスク名を返します。
例
denaliMemInstance inst;
inst = new("ddr0");
inst.setCbTaskName("myCbFunc");
$display("TaskName = %s", inst.getCbTaskName());
setCallback()
メモリへのアクセス時のコールバックを設定します。
構文
virtual function integer setCallback(DENALIDDVCBpointT cbRsn)
引数
名前
cbRsn
MMAV ユーザ • ガイド
タイプ
DENALIDDVCBpointT
説明
コールバックの理由。
11/6/08
145
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
integer status;
denaliMemInstance inst;
inst = new("ddr0");
status = inst.setCallback(DENALI_CB_Write);
write()
メモリ内容をライトします。
構文
virtual function integer write(var denaliMemTransaction tr)
引数
名前
tr
タイプ
説明
denaliMemTransaction ライト動作のデータ、アドレス、およびその他の関連フィー
ルドを含んでいます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
MMAV ユーザ • ガイド
11/6/08
146
例
task writeMem(reg [63:0] addr)
{
integer i;
integer status;
reg [7:0] data [*];
denaliMemTransaction tr = new;
tr.setAddress(addr);
data = new[8]; // memory width is 64 bits
for (i = 0; i < 8; i++) {
data[i] = 'h10 + i;
}
tr.setData(data);
status = mem.write(tr);
printf("## MEM WRITE : %x -> ", tr.getAddress());
for (i = 0; i < data.size(); i++) {
printf("%x ", data[i]);
}
printf("\n");
}
program main
{
denaliMemInstance mem;
mem = new("ddr0");
writeMem('h569);
}
read()
メモリ内容を返します。
構文
virtual function integer read(var denaliMemTransaction tr)
引数
名前
tr
タイプ
denaliMemTransaction
説明
リード動作のアドレスおよびその他の関連フィールドを含
んでいます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
MMAV ユーザ • ガイド
11/6/08
147
例
task readMem(reg [63:0] addr)
{
integer i;
integer status;
reg [7:0] data [*];
denaliMemTransaction tr = new;
tr.setAddress(addr);
status = mem.read(tr);
tr.getData(data);
printf("## MEM READ : %x -> ", tr.getAddress());
for (i = 0; i < data.size(); i++) {
printf("%x ", data[i]);
}
printf("\n");
}
program main
{
denaliMemInstance mem;
mem = new("ddr0");
readMem('h68);
}
tclEval()
埋め込み Tcl インタープリタを使用して Tcl コマンドを実行します。
構文
virtual function integer tclEval(string cmd)
引数
名前
cmd
タイプ
string
説明
Tcl コマンド。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
MMAV ユーザ • ガイド
11/6/08
148
例
integer status;
denaliMemInstance inst;
inst = new("ddr0");
status = inst.tclEval("mmsetvar tracefile -gzip denali.trc.gz");
ReadCbT()
このタスクは、リード・コールバックが発生すると呼び出されます。このタスクは、コール
バック DENALI_CB_Read が有効で、ユーザ定義コールバック • タスクが設定されていない場
合にのみ呼び出されます。
構文
virtual task ReadCbT(var denaliMemTransaction tr)
引数
名前
tr
タイプ
denaliMemTransaction
説明
リード動作のアドレスおよびその他の関連フィールドを含
んでいます。
説明
denaliMemInstance を拡張して、このタスクを独自に実装できます。
162 ページの「テストケースの例」の例を参照してください。
戻り値
なし
WriteCbT()
このタスクは、ライト・コールバックが発生すると呼び出されます。このタスクは、コール
ユーザ定義コールバック • タスクが設定されていない場
バック DENALI_CB_Write が有効で、
合にのみ呼び出されます。
構文
virtual task WriteCbT(var denaliMemTransaction tr)
MMAV ユーザ • ガイド
11/6/08
149
引数
名前
tr
タイプ
説明
denaliMemTransaction ライト動作のデータ、アドレス、およびその他の関連フィー
ルドを含んでいます。
説明
denaliMemInstance を拡張して、このタスクを独自に実装できます。
162 ページの「テストケースの例」の例を参照してください。
戻り値
なし
DefaultCbT()
このタスクは、有効なコールバックが発生し、ユーザ定義コールバック • タスクが設定されて
いない場合に呼び出されます。
構文
virtual task DefaultCbT(var denaliMemTransaction tr)
引数
名前
tr
タイプ
説明
denaliMemTransaction 動作のデータ、アドレス、およびその他の関連フィールドを
含んでいます。
説明
denaliMemInstance を拡張して、このタスクを独自に実装できます。
162 ページの「テストケースの例」の例を参照してください。
戻り値
なし
LoadCbT()
このタスクは、ロード・コールバックが発生すると呼び出されます。
構文
virtual task LoadCbT(var denaliMemTransaction tr)
MMAV ユーザ • ガイド
11/6/08
150
引数
名前
tr
タイプ
説明
denaliMemTransaction 動作のデータ、アドレス、およびその他の関連フィールドを
含んでいます。
説明
denaliMemInstance を拡張して、このタスクを独自に実装できます。
戻り値
なし
LoadDoneCbT()
このタスクは、ロード完了コールバックが発生すると呼び出されます。
構文
virtual task LoadDoneCbT(var denaliMemTransaction tr)
引数
名前
tr
タイプ
説明
denaliMemTransaction 動作のデータ、アドレス、およびその他の関連フィールドを
含んでいます。
説明
denaliMemInstance を拡張して、このタスクを独自に実装できます。
戻り値
なし
ResetCbT()
このタスクは、リセット・コールバックが発生すると呼び出されます。
構文
virtual task ResetCbT(var denaliMemTransaction tr)
引数
名前
tr
MMAV ユーザ • ガイド
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールドを
含んでいます。
11/6/08
151
説明
denaliMemInstance を拡張して、このタスクを独自に実装できます。
戻り値
なし
CompCbT()
このタスクは、比較コールバックが発生すると呼び出されます。
構文
virtual task CompCbT(var denaliMemTransaction tr)
引数
名前
tr
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールドを
含んでいます。
説明
denaliMemInstance を拡張して、このタスクを独自に実装できます。
戻り値
なし
CompDoneCbT()
このタスクは、比較完了コールバックが発生すると呼び出されます。
構文
virtual task CompDoneCbT(var denaliMemTransaction tr)
引数
名前
tr
MMAV ユーザ • ガイド
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールドを
含んでいます。
11/6/08
152
説明
denaliMemInstance を拡張して、このタスクを独自に実装できます。
戻り値
なし
ReadEiCbT()
このタスクは、現在のメモリ • リード動作にエラーが挿入されると呼び出されます。
構文
virtual task ReadEiCbT(var denaliMemTransaction tr)
引数
名前
tr
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールドを
含んでいます。
説明
denaliMemInstance を拡張して、このタスクを独自に実装できます。
戻り値
なし
クラス denaliMemInstanceList
このクラスは、
インスタンスが生成されたすべてのデナリ • メモリ • インスタンスのコンテナ
です。
注意: デナリでは、このクラスの使用をお勧めしません。このクラスは、コールバック • ポ
イントでインスタンス名を検索するために使用されていましたが、MMAV NTB の新し
いコールバック手法が代わりに使用されるようになりました。
getInstanceFromId()
指定したインスタンス ID のインスタンス名を取得します。
構文
function denaliMemInstance getInstanceFromId(integer id)
引数
名前
id
MMAV ユーザ • ガイド
タイプ
説明
整数
インスタンス ID。
11/6/08
153
戻り値
この関数は、メモリ • インスタンス • オブジェクト名を返します。
クラス denaliMemTransaction
このクラスは、メモリへのアクセス動作に関連するフィールドを含んでいるデータ構造です。
コンストラクタ
function new()
説明
リードまたはライトに使用されるこのクラスの新しいメモリ • トランザクション • オブジェク
トを作成します。
戻り値
この関数は、メモリ • トランザクション • オブジェクトを返します。
例
denaliMemTransaction tr;
tr = new;
フィールド
名前
rand
(Y/N)
コールバック
N
タイプ
説明
DENALIDDVCB コールバック理由。
pointT
幅
Y
アドレス
Data []
Y
整数
reg [63:0]
リードまたはライト対象のアドレス位置。
Y
reg [7:0]
ライトするデータまたはリード専用データ。
Mask []
Y
reg [7:0]
使用するマスク (1 の場合はライト )。
MMAV ユーザ • ガイド
11/6/08
データの幅 ( 単位はビット )。
154
メソッド
名前
説明
getCallback()
コールバック理由を返します。
getWidth()
メモリ幅を取得します ( 単位はビット )。
setAddress()
リードまたはライト対象のアドレス位置を設定します。
getAddress()
アドレス位置を返します。
setData()
ライトする必要があるデータを設定します。
getData()
リードまたはライトされるデータ配列を返します。
getDataSize()
データ • サイズを返します。
setMask()
リードまたはライトされるデータに使用するマスクを設定します (1= ライト )。
getMask()
データに使用されるマスクを返します。
getMaskSize()
マスク • サイズを返します。
printInfo()
トランザクション • オブジェクトの内容を出力します。
getCallback()
コールバック理由を返します。
構文
virtual function DENALIDDVCBpointT getCallback()
引数
なし
説明
コールバック • ポイントでトランザクション • オブジェクトが取得されると、
この関数によっ
てコールバック理由が返されます。
戻り値
この関数は、コールバック理由を返します。
例
virtual task WriteCbT(var denaliMemTransaction tr)
{
printf("Callback : %s\n", tr.getCallback());
super.WriteCbT(tr);
}
getWidth()
メモリ幅を取得します ( 単位はビット )。
構文
virtual function integer getWidth()
MMAV ユーザ • ガイド
11/6/08
155
引数
なし
戻り値
この関数は、メモリ幅を返します。
例
virtual task WriteCbT(var denaliMemTransaction tr)
{
printf("Memory Width : %d\n", tr.getWidth());
super.WriteCbT(tr);
}
setAddress()
リードまたはライト対象のアドレス位置を設定します。
構文
virtual task setAddress(reg [63:0] Address)
引数
名前
アドレス
タイプ
reg [63:0]
説明
アドレスを指定します。
戻り値
なし
例
denaliMemTransaction tr = new;
tr.setAddress('h100);
getAddress()
アドレス位置を返します。
構文
virtual function reg [63:0] getAddress()
引数
なし
MMAV ユーザ • ガイド
11/6/08
156
戻り値
この関数は、アクセス中のアドレスを返します。
例
printf("## MEM WRITE : %x -> ", tr.getAddress());
setData()
ライトする必要があるデータを設定します。
構文
virtual task setData(reg [7:0] Data [*])
引数
名前
Data [*]
タイプ
reg [7:0]
説明
データを指定します。
戻り値
なし
例
tr.setData(data);
status = mem.write(tr);
getData()
リードまたはライトされるデータ配列を返します。
構文
virtual task getData(var reg [7:0] Data [*])
引数
名前
Data [*]
タイプ
reg [7:0]
説明
データ配列。
戻り値
この関数は、リードまたはライトされるデータ配列を返します。アクセスされたデータは、
Data 引数で返されます。
MMAV ユーザ • ガイド
11/6/08
157
例
integer status;
reg [7:0] data *;denaliMemTransaction tr = new;
tr.setAddress('h100);
status = mem.read(tr);
tr.getData(data);
getDataSize()
データ • サイズを返します。
構文
virtual function integer getDataSize()
引数
なし
戻り値
この関数は、データ配列のサイズを返します。
例
virtual task WriteCbT(var denaliMemTransaction tr)
{
printf("Data Size : %d\n", tr.getDataSize());
super.WriteCbT(tr);
}
setMask()
リードまたはライトされるデータに使用するマスクを設定します (1= ライト )。
構文
virtual task setMask(reg [7:0] Mask [*])
引数
名前
Mask [*]
タイプ
reg [7:0]
説明
マスクを指定します。
戻り値
なし
MMAV ユーザ • ガイド
11/6/08
158
例
integer i;
reg [7:0] mask [*];
denaliMemTransaction tr = new;
tr.setAddress('h40);
mask = new[8]; // our memory width is 64 bits
for (i = 0; i < 8; i++) {
mask[i] = 'b01010101;
}
tr.setMask(mask);
getMask()
Mask 引数のデータに使用されるマスクを返します。
構文
virtual task getMask(var reg [7:0] Mask [*])
引数
名前
Mask [*]
タイプ
説明
整数
データ • マスクを指定します。
戻り値
この関数は、リードまたはライトされるマスク配列を返します。アクセスされたマスクは、
Mask 引数で返されます。
例
virtual task WriteCbT(var denaliMemTransaction tr)
{
integer i;
reg [7:0] mask [*];
tr.getMask(mask);
printf("## MASK : ");
for (i = 0; i < mask.size(); i++) {
printf("%x ", mask[i]);
}
super.WriteCbT(tr);
}
MMAV ユーザ • ガイド
11/6/08
159
getMaskSize()
マスク • サイズを返します。
構文
virtual function integer getMaskSize()
引数
なし
戻り値
この関数によって、マスク配列のサイズが返されます。
例
virtual task WriteCbT(var denaliMemTransaction tr)
{
printf("Mask Size : %d\n", tr.getMaskSize());
super.WriteCbT(tr);
}
printInfo()
トランザクション • オブジェクトの内容を出力します。
構文
virtual task printInfo(integer arrayDepth = 32)
引数
名前
arrayDepth
タイプ
説明
整数
出力する必要がある配列要素の最大数を指定します。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
virtual task DefaultCbT(var denaliMemTransaction tr)
{
tr.printInfo();
super.DefaultCbT(tr);
}
MMAV ユーザ • ガイド
11/6/08
160
6.6.4
コールバックの処理
MMAV では、メモリへのアクセス時に NTB テストベンチへのコールバックを生成できます。
MMAV NTB コールバック • インターフェイスには、モデル • コールバック初期化およびハンド
リングの機能があります。
このために、適切なコールバックをデバイスに追加する必要があります。コールバック関数
は、denaliMemInstance ( インスタンス • クラス ) を拡張して、組み込みコールバック関数
(cbTaskName パラメータを設定せずに指定 ) をオーバーロードして、設定できます。仮想タ
スクは、クラスのコールバック理由ごとにオーバーロードできます。
コールバック処理の詳細な例については、162 ページの「テストケースの例」を参照してく
ださい。
MMAV ユーザ • ガイド
11/6/08
161
6.6.5
テストケースの例
次の例は、DDR メモリのインスタンス化しバックドア • リードとライトを示しています。ま
た、コールバック処理のための denaliMemInstance クラスの拡張についても示されてい
ます。
#include "denaliMemTypes.vrh"
task writeMem(reg [63:0] addr)
{
integer i;
integer status;
reg [7:0] data [*];
denaliMemTransaction tr = new;
tr.setAddress(addr);
data = new[8]; // memory width is 64 bits
for (i = 0; i < 8; i++) {
data[i] = 'h10 + i;
}
tr.setData(data);
status = mem.write(tr);
printf("## MEM WRITE : %x -> ", tr.getAddress());
for (i = 0; i < data.size(); i++) {
printf("%x ", data[i]);
}
printf("\n");
}
task readMem(reg [63:0] addr)
{
integer i;
integer status;
reg [7:0] data [*];
denaliMemTransaction tr = new;
tr.setAddress(addr);
status = mem.read(tr);
tr.getData(data);
printf("## MEM READ : %x -> ", tr.getAddress());
for (i = 0; i < data.size(); i++) {
printf("%x ", data[i]);
}
printf("\n");
}
continued...
MMAV ユーザ • ガイド
11/6/08
162
...continued
class MyDenaliMemInstance extends denaliMemInstance
{
task new(string instName)
{
super.new(instName);
}
virtual task WriteCbT(var denaliMemTransaction tr)
{
printf("**********************************\n");
tr.printInfo();
printf("**********************************\n");
WriteCbT = super.WriteCbT(tr);
}
virtual task ReadCbT(var denaliMemTransaction tr)
{
printf("**********************************\n");
tr.printInfo();
printf("**********************************\n");
ReadCbT = super.ReadCbT(tr);
}
}
program main
{
integer status;
MyDenaliMemInstance mem;
denaliMemTransaction tr;
status = denaliMemInit();
if (status == -1) {
error("Denali DDV-MMAV initialization failed. Cannot continue
...\n");
exit(1);
}
mem = new("simple_tb.simple_mem.storage");
status = mem.setCallback(DENALI_CB_Read);
status = mem.setCallback(DENALI_CB_Write);
writeMem('h68);
readMem('h68);
while (1) {
@(posedge CLOCK);
}
@(posedge CLOCK);
}
MMAV ユーザ • ガイド
11/6/08
163
6.7
SystemVerilog インターフェイス
このセクションでは、SystemVerilog テストベンチで MMAV を使用する方法について説明し
ます。
6.7.1
MMAV と SystemVerilog の概要
MMAV は、SystemVerilog テストベンチをサポートするネイティブ • クラスベースのオブジェ
クト指向インターフェイスを備えています。このインターフェイスは、SV クラスと、メモリ
へのアクセスを追跡し、
バックドア • リードおよびライトを実行するためのメソッドで構成さ
れます。(PLI ベース ) Verilog プロシージャ • インターフェイスの他の動作は、このような SV
クラスでも実行可能です。
6.7.2
MMAV と SystemVerilog のシミュレーション
このセクションでは、いくつかの一般的に使用される Verilog シミュレータのシミュレーショ
ン手順について説明します。
Mentor Graphics Questa
Mentor Graphics Questa を使用して MMAV および SV のシミュレーションを実行するには、次
の手順を実行します。
1. デナリのインストール • ルート • ディレクトリに環境変数 $DENALI を設定します。
2. SystemVerilog シミュレータのパスを設定します。
3. PureView を使用して、MMAV モデル • シェルを生成します。詳細については、10 ページ
の「PureView グラフィカル • ツールの使用」を参照してください。
4. user.sv テストベンチを作成します。
5. SV ファイルをコンパイルします。-dpiheader オプションを使用すると、次の C コンパ
イルに使用されるヘッダ • ファイルが作成されます。
vlog \
+incdir+$DENALI/ddvapi/sv -dpiheader denaliMemSvIf.h \
$DENALI/ddvapi/sv/denaliMem.sv *.sv *.v
6. C ファイルをコンパイルおよびリンクします。これらのファイルには、C データ構造を
SV に変換する ( または SV を C データ構造に変換する ) コードが含まれています。
gcc -c -g -fPIC -I$MTI_HOME/include -I. -I$DENALI \
-I$DENALI/ddvapi $DENALI/ddvapi/sv/denaliMemSvIf.c
7. 共有オブジェクトを作成します。
gcc -shared -o denaliMemSvIf.so \
$DENALI/mtipli.so
8. 不要なファイルをすべて削除します。
rm -f denaliMemSvIf.h denaliMemSvIf.o
MMAV ユーザ • ガイド
11/6/08
164
9. シミュレーションを実行します。'-svlib <lib>' オプションを使用すると、作成したインター
フェイス共有オブジェクトがロードされます。-dpioutoftheblue 1 オプションを使用
すると、
PLI 1.0 から呼び出された C コードから SV エクスポート • タスクを呼び出すこと
ができます。-pli <lib> オプションを使用すると、C モデルを含むデナリ • ライブラリ
がロードされます。
vsim -c top -sv_lib denaliMemSvIf -do "run -all; quit" -pli \
$DENALI/mtipli.so -dpioutoftheblue 1
Cadence NC-Verilog
Cadence NC-Verilog を使用して MMAV および SV のシミュレーションを実行するには、次の
手順を実行します。
1. デナリのインストール • ルート • ディレクトリに環境変数 $DENALI を設定します。
2. SystemVerilog シミュレータのパスを設定します。
3. PureView を使用して、MMAV モデル • シェルを生成します。詳細については、10 ページ
の「PureView グラフィカル • ツールの使用」を参照してください。
4. user.sv テストベンチを作成します。
SV ファイルをコンパイルします。-dpiheader オプションを使用すると、次の C コンパイ
ルに使用されるヘッダ • ファイルが作成されます。ncverilog
+sv \
+elaborate \
+ncdpiheader+denaliMemSvIf.h \
+licq \
+define+DENALI_SV_NC \
+incdir+$DENALI/ddvapi/sv \
$DENALI/ddvapi/sv/denaliMem.sv
5. C ファイルをコンパイルします。これらのファイルには、C データ構造を SV に変換する
( または SV を C データ構造に変換する ) コードが含まれています。
gcc -c -g -fPIC -DDENALI_SV_NC=1 \
-I$CDS_TOOLS/include -I. -I$DENALI \
-I$DENALI/ddvapi \
$DENALI/ddvapi/sv/denaliMemSvIf.c -m32
6. C ファイルをリンクします。
ld -G -o denaliMemSvIf.so denaliMemSvIf.o $DENALI/verilog/
libdenpli.so -melf_i386
7. 共有オブジェクトを作成します。
gcc -shared -o denaliMemSvIf.so \
$DENALI/mtipli.so
8. シミュレーションを実行します。
ncverilog +loadpli1=$DENALI/verilog/libdenpli.so:den_PLIPtr \
+access+rw \
+nbasync \
+sv \
+sv_lib=$PROJ_HOME/run/denaliMemSvIf.so \
+incdir+$DENALI/ddvapi/sv \
+licq \
+define+DENALI_SV_NC \
*.sv *.v
MMAV ユーザ • ガイド
11/6/08
165
Synopsys VCS
Synopsys VCS 使用して MMAV および SV のシミュレーションを実行するには、次の手順を
実行します。
1. デナリのインストール • ルート • ディレクトリに環境変数 $DENALI を設定します。
2. SystemVerilog シミュレータのパスを設定します。
3. PureView を使用して、MMAV モデル • シェルを生成します。詳細については、10 ページ
の「PureView グラフィカル • ツールの使用」を参照してください。
4. user.sv テストベンチを作成します。
SV ファイルをコンパイルします。 vcs -CFLAGS "-DDENALI_SV_VCS=1
-I${DENALI} \
-I${DENALI}/ddvapi -g -c" \
-sverilog +vcs+lic+wait \
-ntb_opts svp -ntb_opts rvm -ntb_opts dtm \
-Mupdate -P $DENALI/verilog/pli.tab \
-LDFLAGS "-rdynamic $DENALI/verilog/denverlib.o" \
-debug_pp
+ntb_enable_solver_trace=0 \
+dmprof \
+define+DENALI_SV_VCS \
+incdir+$DENALI/ddvapi/sv \
$DENALI/ddvapi/sv/denaliMemSvIf.c \
$DENALI/ddvapi/sv/denaliMem.sv \
*.sv *.v
5. シミュレーションを実行します。
./simv -l vcs.log
6.7.3
コンフィギュレーション • レジスタおよびメモリへのアクセス
SystemVerilog メモリ • アクセス関数は、すべてのデナリ検証 IP 製品で使用できます。
これらの
関数を使用すると、メモリ • リファレンスを追跡して、リード / ライト動作を実行できます。
メイン • クラスは次のとおりです。
• クラス denaliMemInstance
• クラス denaliMemTransaction
これらのクラスの各フィールドでは、フィールド値の取得に必要な get<field_name> アクセ
ス • メソッドがフィールドに関連付けられています。また、すべてのライト可能なフィールド
には、フィールド値の設定に必要な set<field_name> があります。このようなフィールドはパ
ブリックであるため、これらのフィールドに直接アクセスすることができます。
ステータス • コードを返すメソッドはすべて、失敗の場合は "-1" を、成功の場合は "0" を返し
ます。
set<field_name> メソッドと get<field_name> メソッドの指定フィールド名の最初の文字は大文
字です。したがって、Address の値を取得する場合、メソッドは getAddress となります。
MMAV ユーザ • ガイド
11/6/08
166
いくつかのフィールドは rand とマークされ、SV のランダム関数によってそれらの値が生成
されます。
クラス denaliMemInstance
メモリにアクセスするための SystemVerilog 環境で、denaliMemInstance のインスタンスを
生成します。denaliMemInstance は、テストベンチでインスタンス生成されたか、コンフィ
ギュレーション空間などのモデルによって作成されたメモリ • インスタンスに対応します。
次のセクションでは、denaliMemInstance クラスについて説明します。
コンストラクタ
function new(string instName, string cbFuncName = "") ;
フィールド
名前
instName
cbFuncName
rand
(Y/N)
タイプ
説明
N
string
インスタンス名。
N
string
コールバック関数名。
instName は完全なパス名である必要があり、
コンストラクタに対して cbFuncName を null に
できます。ただし、明示的な DPI コールバック関数を定義する場合、コールバック • ポイント
をモニタ用に追加する前に設定する必要があります。
注意: cbFuncName フィールドの使用は、お勧めしません。
メソッド
名前
new()
説明
getInstName()
インスタンス名を取得します。
getId()
ID を取得します。
getSize()
メモリのサイズを取得します。
getWidth()
メモリの幅を取得します。
setCbFuncName()
DPI コールバック関数名を設定します。
新しいインスタンス • オブジェクトを作成します。
getCbFuncName()
DPI コールバック関数名を取得します。
setCallback()
メモリへのアクセス時のコールバックを設定します。
write()
メモリ内容をライトします。
read()
メモリ内容を返します。
tclEval()
埋め込み Tcl インタープリタを使用して Tcl コマンドを実行します。
tclEvalGetResult()
埋め込み Tcl インタープリタを使用して Tcl コマンドを実行し、文字列パラメータの
結果を返します。
setBackdoorCbMode() この関数は、パラメータ値 0 で呼び出され、バックドア • アクセス • コールバックを
無効にします。1 に設定すると、このコールバックは有効になります。
ReadCbF()
この関数は、リード・コールバックが発生すると呼び出されます。
WriteCbF()
MMAV ユーザ • ガイド
この関数は、ライト・コールバックが発生すると呼び出されます。
11/6/08
167
名前
DefaultCbF()
説明
この関数は、有効なコールバックが発生し、コールバック関数が設定されていない
場合に呼び出されます。
LoadCbF()
この関数は、ロード・コールバックが発生すると呼び出されます。
LoadDoneCbF()
この関数は、ロード完了コールバックが発生すると呼び出されます。
ResetCbF()
この関数は、リセット・コールバックが発生すると呼び出されます。
CompCbF()
この関数は、比較コールバックが発生すると呼び出されます。
CompDoneCbF()
この関数は、比較完了コールバックが発生すると呼び出されます。
ReadEiCbF()
この関数は、現在のメモリ • リード動作にエラーが挿入されると呼び出されます。
new()
新しいインスタンス • オブジェクトを作成します。
構文
function new(string instName, string cbFuncName = "") ;
引数
名前
instName
タイプ
string
説明
cbFuncName
string
コールバック名。
インスタンス名。
説明
指定のインスタンスから起動できるように新規パケットを作成し、新規作成した空のパケッ
トを指すパケット • ハンドルを返します。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
denaliMemInstance inst;
inst = new("i0");
getId()
ID を取得します。
構文
virtual function int getId() ;
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
MMAV ユーザ • ガイド
11/6/08
168
例
denaliMemInstance inst;
inst = new("i0");
$display("MemId = %d\n ", inst.getId());
getInstName()
インスタンス名を取得します。
構文
function string getInstName() ;
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
denaliMemInstance inst;
inst = new("i0");
$display("InstName = %s", inst.getInstName());
getSize()
メモリのサイズを取得します。
構文
virtual function longint unsigned getSize() ;
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
denaliMemInstance inst;
inst = new("i0");
$display("MemSize = %d\n ", inst.getSize());
getWidth()
メモリの幅を取得します。
構文
virtual function int unsigned getWidth() ;
MMAV ユーザ • ガイド
11/6/08
169
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
denaliMemInstance inst;
inst = new("i0");
$display("MemWidth = %d\n ", inst.getWidth());
getCbFuncName()
DPI コールバック関数名を取得します。
注意: デナリでは、ユーザ定義 DPI 関数の使用をお勧めしません。
構文
function string getCbFuncName() ;
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
denaliMemInstance inst;
inst = new("i0");
inst.setCbFuncName("myCbFunc");
$display("FuncName = %s", inst.getCbFuncName());
setCallback()
この関数は、メモリへのアクセス時のコールバックを設定するために使用されます。
構文
function integer setCallback(DENALIDDVCBpointT cbRsn) ;
引数
名前
cbRsn
タイプ
DENALIDDVCBpointT
説明
コールバック理由。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
MMAV ユーザ • ガイド
11/6/08
170
int status;
denaliMemInstance inst;
inst = new("i0");
status = inst.setCallback(DENALI_CB_Write);
write()
この関数によって、メモリ内容がライトされます。
構文
function int write(ref denaliMemTransaction trans);
引数
名前
trans
タイプ
denaliMemTransaction
説明
ライト動作のデータ、アドレス、およびその他の関連フィー
ルドを含んでいます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
function void writeData(reg [63:0] addr);
reg [7:0] data [];
denaliMemTransaction trans;
trans = new;
trans.setAddress(addr);
data = new[4];
data[0] = 'h01;
data[1] = 'h34;
data[2] = 'h78;
data[3] = 'h90;
trans.setData(data);
assert(inst.write(trans) == 0);
endfunction
denaliMemInstance inst;
inst = new("i0");
inst.writeData('h569);
MMAV ユーザ • ガイド
11/6/08
171
read()
この関数は、メモリ内容を返します。
構文
function int read(ref denaliMemTransaction trans);
引数
名前
trans
タイプ
denaliMemTransaction
説明
リード動作のアドレスおよびその他の関連フィールドを含
んでいます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
task readData(reg [63:0] addr);
reg [ 7:0] data [];
int status;
denaliMemTransaction trans;
string str;
trans = new;
trans.setAddress(addr);
assert(ddr_II_Den.read(trans) == 0)
trans.getData(data);
for (int i = 0; i < data.size(); i++) begin
$swrite(str, "%s%0h", str, data[i]);
end
$display("******** Data Read = %s", str);
endtask
tclEval()
埋め込み Tcl インタープリタを使用して Tcl コマンドを実行します。
構文
function int tclEval(string cmd);
引数
MMAV ユーザ • ガイド
11/6/08
172
名前
cmd
タイプ
string
説明
Tcl コマンド。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
denaliMemInstance inst;
inst = new("i0");
assert(inst.tclEval("mmsetvar tracefile -gzip denali.trc.gz") == 0);
tclEvalGetResult()
埋め込み Tcl インタープリタを使用して Tcl コマンドを実行し、文字列パラメータの結果を返
します。
構文
function int tclEvalGetResult(string cmd, output string result, input
int resultSize = 1024);
引数
名前
cmd
タイプ
string
説明
result
string
Tcl 評価の結果。
resultsize
int
結果の最大サイズ。
Tcl コマンド。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
denaliMemInstance inst;
string res;
int status;
inst = new("i0");
status = inst.tclEvalGetResult("mmsetvar tracefile -gzip
denali.trc.gz", res);
$display("status = %d / res = %s", status, res);
MMAV ユーザ • ガイド
11/6/08
173
setBackdoorCbMode()
この関数は、パラメータ値 0 で呼び出され、バックドア • アクセス • コールバックを無効にし
ます。1 に設定すると、このコールバックは有効になります。
注意: コールバック処理時のテストベンチ • コードによって、同時に同じデルタ • サイクルで
別のアクセス• コールバックを発生させるデナリMMAV バックドア•メソッドが呼び出
された場合、一部のシミュレータではこれを処理できない場合があります。バックド
ア • メソッドが別のコールバック内から呼び出されるようにするには、メモリ • インス
タンスのバックドア • アクセス • コールバックを無効にするようにしてください。
構文
virtual function int setBackdoorCbMode(bit onOrOff);
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
denaliMemInstance inst;
inst = new("testbench.i1");
// this will turn off backdoor access cb's for inst
assert(inst.setBackdoorCbMode(0));
ReadCbF()
この関数は、リード・コールバックが発生すると呼び出されます。このタスクは、コールバッ
ク DENALI_CB_Read が有効で、コールバック関数が設定されていない場合にのみ呼び出され
ます。
構文
virtual function int ReadCbF(ref denaliMemTransaction trans) ;
引数
名前
trans
タイプ
denaliMemTransaction
説明
リード動作のアドレスおよびその他の関連フィールドを含
んでいます。
説明
denaliMemInstance を拡張して、このメソッドを独自に実装できます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
MMAV ユーザ • ガイド
11/6/08
174
virtual function int ReadCbF(ref denaliMemTransaction trans);
void'(trans.printInfo());
return super.ReadCbF(trans);
endfunction
WriteCbF()
この関数は、ライト・コールバックが発生すると呼び出されます。このタスクは、コールバッ
ク DENALI_CB_Write が有効で、コールバック関数が設定されていない場合にのみ呼び出さ
れます。
構文
virtual function int WriteCbF(ref denaliMemTransaction trans) ;
引数
名前
trans
タイプ
説明
denaliMemTrans ライト動作のデータ、アドレス、およびその他の関連フィールド
action
を含んでいます。
説明
denaliMemInstance を拡張して、このメソッドを独自に実装できます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
virtual function int WriteCbF(ref denaliMemTransaction trans);
void'(trans.printInfo());
return super.WriteCbF(trans);
endfunction
DefaultCbF()
この関数は、有効なコールバックが発生し、コールバック関数が設定されていない場合に呼
び出されます。
構文
virtual function int DefaultCbF(ref denaliMemTransaction trans) ;
引数
MMAV ユーザ • ガイド
11/6/08
175
名前
trans
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールド
を含んでいます。
説明
denaliMemInstance を拡張して、このメソッドを独自に実装できます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
virtual function int DefaultCbF(ref denaliMemTransaction trans);
void'(trans.printInfo());
return super.DefaultCbF(trans);
endfunction
LoadCbF()
この関数は、ロード・コールバックが発生すると呼び出されます。
構文
virtual function int LoadCbF(ref denaliMemTransaction trans) ;
引数
名前
trans
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールド
を含んでいます。
説明
denaliMemInstance を拡張して、このメソッドを独自に実装できます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
virtual function int LoadCbF(ref denaliMemTransaction trans);
void'(trans.printInfo());
return super.LoadCbF(trans);
endfunction
MMAV ユーザ • ガイド
11/6/08
176
LoadDoneCbF()
この関数は、ロード完了コールバックが発生すると呼び出されます。
構文
virtual function int LoadDoneCbF(ref denaliMemTransaction trans) ;
引数
名前
trans
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールド
を含んでいます。
説明
denaliMemInstance を拡張して、このメソッドを独自に実装できます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
virtual function int LoadDoneCbF(ref denaliMemTransaction trans);
void'(trans.printInfo());
return super.LoadDoneCbF(trans);
endfunction
ResetCbF()
この関数は、リセット・コールバックが発生すると呼び出されます。
構文
virtual function int ResetCbF(ref denaliMemTransaction trans) ;
引数
名前
trans
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールド
を含んでいます。
説明
denaliMemInstance を拡張して、このメソッドを独自に実装できます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
MMAV ユーザ • ガイド
11/6/08
177
例
virtual function int ResetCbF(ref denaliMemTransaction trans);
void'(trans.printInfo());
return super.ResetCbF(trans);
endfunction
CompCbF()
この関数は、比較コールバックが発生すると呼び出されます。
構文
virtual function int CompCbF(ref denaliMemTransaction trans);
引数
名前
trans
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールド
を含んでいます。
説明
denaliMemInstance を拡張して、このメソッドを独自に実装できます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
virtual function int CompCbF(ref denaliMemTransaction trans);
void'(trans.printInfo());
return super.CompCbF(trans);
endfunction
CompDoneCbF()
この関数は、比較完了コールバックが発生すると呼び出されます。
構文
virtual function int CompDoneCbF(ref denaliMemTransaction trans) ;
MMAV ユーザ • ガイド
11/6/08
178
引数
名前
trans
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールドを
含んでいます。
説明
denaliMemInstance を拡張して、このメソッドを独自に実装できます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
virtual function int CompDoneCbF(ref denaliMemTransaction trans);
void'(trans.printInfo());
return super.CompDoneCbF(trans);
endfunction
ReadEiCbF()
この関数は、現在のメモリ • リード動作にエラーが挿入されると呼び出されます。
構文
virtual function int ReadEiCbF(ref denaliMemTransaction trans) ;
引数
名前
trans
タイプ
denaliMemTransaction
説明
動作のデータ、アドレス、およびその他の関連フィールド
を含んでいます。
説明
denaliMemInstance を拡張して、このメソッドを独自に実装できます。
ReadEiCbF() コールバック関数は、$mmerrinject() 関数と共に動作し、主に DRAM での
ECC 検証のために使用されます。
$mmerrinject() 関数の使用方法の詳細については、$DENALI/doc/mmav/mmavUserGuide.pdf
にある『MMAV User's Guide』を参照してください。
MMAV ユーザ • ガイド
11/6/08
179
次の例は、$mmerrinject() 関数の使用方法を示します。
denaliMemInstance inst;
inst = new("i0");
assert(inst.tclEval("mmerrinject id -seed 12 –reads 1000 1200 –bits 1 2
4 –percent 80 15 5") == 0);
この例のモデルでは、1 ビット、2 ビット、および 4 ビット • エラーをそれぞれ 80%、15%、お
よび 5% の割合で生成し、1000 ~ 1200 のリード動作にランダムにエラーが挿入されます。
1000 ~ 1200 の範囲の特定の N 回リード動作はランダムで、特定のビットが反転します。
$mmerrinject() 関数呼び出しには、いくつかのバリエーションがあります。たとえば、範
囲を指定する必要がない場合、"-reads 1000" と指定すれば、インスタンスの 1000 リード
動作ごとにエラーを挿入できます。
注意: ReadEiCbF() 関数は、常に true で、エラーが挿入される N 回リード動作についてト
リガされます。Data フィールドは、値を返し、このときのマスクは !=NULL になり
ます。Mask[i] = 1 は、Data[i] が実際のメモリ内容で、Mask[i]=0 は、Data[i] が反転
(0->1 または 1->0) することを示します。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
virtual function int ReadEiCbF(ref denaliMemTransaction trans);
void'(trans.printInfo());
return super.ReadEiCbF(trans);
endfunction
MMAV ユーザ • ガイド
11/6/08
180
クラス denaliMemTransaction
このクラスは、メモリへのアクセス動作に関連するフィールドを含んでいるデータ構造です。
コンストラクタ
function new() ;
フィールド
名前
rand
(Y/N)
コールバック
N
幅
Y
アドレス
Data []
Mask []
タイプ
説明
DENALIDDVCB コールバック理由。
pointT
データの幅 ( 単位はビット )。
Y
整数
reg [63:0]
Y
reg [7:0]
ライトするデータまたはリード専用データ。
Y
reg [7:0]
使用するマスク (1= ライト )。
リードまたはライト対象のアドレス位置。
メソッド
名前
説明
new()
メモリ • トランザクション • オブジェクトを作成します。
printInfo()
トランザクション • オブジェクトの内容を出力します。
AVM メソッド
clone()
AVM オブジェクトのコピーを返します。
comp()
2 つのトランザクション • オブジェクトを比較します。
convert2string()
オブジェクトの文字列表現を返します。
VMM メソッド
psdisplay()
is_valid()
文字列として読み取り可能な形式で、このインスタンスによって記述されたトランザ
クションまたはデータの現在の値のイメージを返します。
任意で指定した kind または形式に従って、このインスタンスによって記述されたト
ランザクションまたはデータの現在の値が有効で、エラーがないかどうかを確認しま
す。
注意 : このメソッドはまだ実装されていません。
copy()
オブジェクト•インスタンスの現在の値を、指定したオブジェクト•インスタンスにコ
ピーします。目的のオブジェクト • インスタンスが指定されていない場合、新しいイ
ンスタンスが割り当てられます。
allocate()
オブジェクト • インスタンスと同じ種類の新しいインスタンスを割り当てます。
compare()
指定した kind に従って、オブジェクト • インスタンスの現在の値と、指定したオブ
ジェクト • インスタンスの現在の値を比較します。値が同じ場合は、TRUE を返しま
す (0 以外の場合など )。
byte_pack()
配列の指定されたオフセットから 8'h00 に設定されたバイトまで、アクション記述子
の名前をバイトの指定されたダイナミック配列にパックします。
注意 : このメソッドはまだ実装されていません。
byte_unpack()
指定されたダイナミック配列の指定されたオフセットから8'h00に設定されたバイト
まで、指定されたバイト数がアンパックされているか、配列の最後に達している場
合、アクション記述子の名前をアンパックします。
注意 : このメソッドはまだ実装されていません。
byte_size()
記述子の内容のパックに必要な数のバイトを返します。
注意 : このメソッドはまだ実装されていません。
MMAV ユーザ • ガイド
11/6/08
181
new()
新しいメモリ • トランザクション • オブジェクトを作成します。
構文
function new() ;
説明
リードまたはライトに使用されるこのクラスの新しいメモリ • トランザクション • オブジェク
トを作成します。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
denaliMemTransaction trans;
trans = new;
printInfo()
トランザクション • オブジェクトの内容を出力します。
構文
virtual function integer printInfo(integer arrayDepth = 32) ;
引数
名前
arrayDepth
タイプ
説明
整数
出力する必要がある配列要素の最大数を指定します。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
virtual function int DefaultCbF(ref denaliMemTransaction tr);
assert(tr.printInfo() == 0);
return super.DefaultCbF(tr);
endfunction
clone()
AVM オブジェクトのコピーを返します。
MMAV ユーザ • ガイド
11/6/08
182
構文
virtual function denaliMemTransaction clone() ;
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
static denaliMemTransaction trQ [$];
virtual function int DefaultCbF(ref denaliMemTransaction tr);
trQ.push_front(tr.clone());
return super.DefaultCbF(tr);
endfunction
comp()
2 つのトランザクション • オブジェクトを比較します。
構文
virtual function bit comp(input denaliMemTransaction item) ;
引数
名前
item
タイプ
説明
denal
現在のオブジェクトの比較対象のオブジェクトを指定します。
iMemTransaction
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
static denaliMemTransaction trQ [$];
virtual function int DefaultCbF(ref denaliMemTransaction tr);
if ((trQ.size == 1) && (tr.comp(trQ[0]))) begin
$display("Match found!");
end
return super.DefaultCbF(tr);
endfunction
convert2string()
オブジェクトの文字列表現を返します。
MMAV ユーザ • ガイド
11/6/08
183
構文
virtual function string convert2string() ;
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
例
virtual function int DefaultCbF(ref denaliMemTransaction tr);
tr.convert2string();
return super.DefaultCbF(tr);
endfunction
psdisplay()
文字列として読み取り可能な形式で、このインスタンスによって記述されたトランザクショ
ンまたはデータの現在の値のイメージを返します。
構文
virtual function string psdisplay(string prefix = "");
説明
この文字列には、複数行のイメージを分割するための改行文字が含まれている場合がありま
す。出力の各行には、指定した接頭辞を使用する必要があります。
戻り値
文字列として読み取り可能な形式で、このインスタンスによって記述されたトランザクショ
ンまたはデータの現在の値のイメージを返します。
is_valid()
注意: この関数はまだ実装されていません。
任意で指定した kind または形式に従って、このインスタンスによって記述されたトランザク
ションまたはデータの現在の値が有効で、エラーがないかどうかを確認します。
構文
virtual function bit is_valid(bit silent = 1, int kind = -1);
説明
任意で指定した kind または形式に従って、このインスタンスによって記述されたトランザク
ションまたはデータの現在の値が有効で、エラーがないかどうかを確認します。オブジェク
トの内容が有効な場合は、TRUE を返します (0 以外の場合など )。それ以外の場合は、FALSE
を返します。kind 引数の意味 ( および使用方法 ) は記述子固有で、このメソッドのユーザ拡
張によって定義されます。
MMAV ユーザ • ガイド
11/6/08
184
silent が TRUE の場合 (0 以外の場合など )、内容が無効でもエラーまたは警告メッセージは発
行されません。silent が FALSE の場合、内容が無効でも警告またはエラー • メッセージが発行
される場合があります。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
copy()
オブジェクト • インスタンスの現在の値を、
指定したオブジェクト • インスタンスにコピーし
ます。目的のオブジェクト • インスタンスが指定されていない場合、新しいインスタンスが割
り当てられます。
構文
virtual function vmm_data copy(vmm_data to = null);
説明
オブジェクト • インスタンスの現在の値を、
指定したオブジェクト • インスタンスにコピーし
ます。目的のオブジェクト • インスタンスが指定されていない場合、新しいインスタンスが割
り当てられます。ターゲット • インスタンスのリファレンスを返します。次の単純な実装は機
能しません。コンストラクタのコピーは、表面的なコピーです。オブジェクトでインスタン
スが生成されたオブジェクト ( ログによって参照され、プロパティを通知するオブジェクト
など ) は、コピーされず、両方のコピーは、同じサービス • インターフェイスのリファレンス
を共有します。また、to 引数が null の場合、このケースは適切に処理されません。
戻り値
この関数によって、ターゲット • インスタンスのリファレンスが返されます。
allocate()
オブジェクト • インスタンスと同じ種類の新しいインスタンスを割り当てます。
構文
virtual function vmm_data allocate();
説明
新しいインス
オブジェクト • インスタンスと同じ種類の新しいインスタンスを割り当てます。
タンスのリファレンスを返します。これは、基本的なクラス • タイプを使用してライトされた
ジェネリック • コードで、クラス • ファクトリを実装して、ユーザ定義の派生クラスのインス
タンスを作成するときに役立ちます。
戻り値
この関数によって、成功の場合は 0 が返され、失敗の場合はゼロ以外の値が返されます。
MMAV ユーザ • ガイド
11/6/08
185
compare()
指定した kind に従って、
オブジェクト • インスタンスの現在の値と指定したオブジェクト • イ
ンスタンスの現在の値を比較します。
値が同じ場合は、
TRUE を返します (0 以外の場合など )。
構文
virtual function bit compare(input vmm_data to, output string diff,
input int kind = -1)'
説明
指定した kind に従って、オブジェクト • インスタンスの現在の値と指定したオブジェクト •
インスタンスの現在の値を比較します。値が同じ場合は、TRUE を返します (0 以外 )。値が
異なる場合は、FALSE が返され、検出された最初の差異のテキスト記述が、指定した文字列
変数で返されます。別の比較関数 ( 完全比較、rand プロパティのみの比較、プロトコルなどに
物理的に実装されたすべてのプロパティの比較など ) を実装するために、kind 引数が使用さ
れる場合があります。
戻り値
値が同じ場合、この関数によって 0 が返されます。
byte_pack()
注意: この関数はまだ実装されていません。
配列の指定されたオフセットから 8'h00 に設定されたバイトまで、アクション記述子の名前
をバイトの指定されたダイナミック配列にパックします。
構文
virtual function int unsigned byte_pack(ref logic [7:0] bytes[],
input int unsigned offset = 0, input int kind = -1);
説明
デフォルトの実装時に、配列の指定したオフセットから 8'h00 に設定されたバイトまで、ア
クション記述子の名前を、バイトの指定したダイナミック配列にパックします。配列のサイ
ズは、適切に変更されます。
戻り値
この関数によって、配列に追加されたバイト数が返されます。
byte_unpack()
注意: この関数はまだ実装されていません。
指定されたダイナミック配列の指定されたオフセットから 8'h00 に設定されたバイトまで、
指
定されたバイト数がアンパックされているか、配列の最後に達している場合、アクション記
述子の名前をアンパックします。
構文
MMAV ユーザ • ガイド
11/6/08
186
virtual function int unsigned byte_unpack(const ref logic [7:0]
bytes[], input int unsigned offset = 0, input int len = -1, input
int kind = -1);
説明
デフォルトの実装時に、指定されたダイナミック配列の指定されたオフセットから 8'h00 に
設定されたバイトまで、指定されたバイト数がアンパックされているか、配列の最後に達し
ている場合、アクション記述子の名前をアンパックします。
戻り値
この関数は、アンパックされたバイト数を返します。
byte_size()
注意: この関数はまだ実装されていません。
記述子の内容のパックに必要な数のバイトを返します。
構文
virtual function int unsigned byte_size(int kind = -1);
説明
このメソッドは、パックが実際に実行されないため、記述子が必要とするバイト数を通知す
るだけであれば、vmm_data::byte_pack() よりも効率的です。
データが別の方法で解読またはパックされる場合、kind 引数を使用して、使用する解釈また
はパックを指定できます。
戻り値
この関数は、この記述子の内容のパックに必要なバイト数を返します。
コールバック処理
デナリでは、メモリへのアクセス時に SystemVerilog テストベンチへのコールバックを生成で
きます。
SystemVerilog コールバック • インターフェイスには、モデル • コールバック初期化およびハン
ドリングの機能があります。
このために、適切なコールバックをデバイスに追加する必要があります。コールバック関数
は、denaliMemInstance ( インスタンス • クラス ) を拡張して、組み込みコールバック関数
(cbFuncName パラメータを設定せずに指定 ) をオーバーロードして、設定できます。仮想関
数は、クラスのコールバック理由ごとにオーバーロードできます。次のテストケースの例を
参照してください。
MMAV ユーザ • ガイド
11/6/08
187
テストケースの例
module top;
import DenaliSvMem::*;
/* extend the denaliMemInstance
*/
class MyMemInstance extends denaliMemInstance;
function new (string instName);
super.new (instName);
endfunction
/* overload the write callback function
*/
virtual function int WriteCbF (ref denaliMemTransaction trans);
$display ("WriteCbF ()");
void'(trans.printInfo());
return super.WriteCbF (trans);
endfunction
/* overload the read callback function
*/
virtual function int ReadCbF (ref denaliMemTransaction trans);
$display ("ReadCbF ()");
void'(trans.printInfo ());
return super.ReadCbF (trans);
endfunction
endclass
continued...
MMAV ユーザ • ガイド
11/6/08
188
...continued
MyMemInstance inst;
task init_tb();
assert(denaliMemInit() == 0);
// instantiate MyMemInstance for the momory model/configuration
space
inst = new("top.i0");
// set the read and write callback points
assert(inst.setCallback(DENALI_CB_Write) == 0);
assert(inst.setCallback(DENALI_CB_Read) == 0);
endtask
initial
begin
init_tb();
writeData('h569);
readData('h569);
end
function void writeData(reg [63:0] addr);
reg [7:0] data [];
denaliMemTransaction trans;
trans = new;
trans.setAddress(addr);
data = new[4];
data[0] = 'h01;
data[1] = 'h34;
data[2] = 'h78;
data[3] = 'h90;
trans.setData(data);
assert(inst.write(trans) == 0);
endfunction
function void readData(reg [63:0] addr);
reg [7:0] data [];
int status;
denaliMemTransaction trans;
trans = new;
trans.setAddress(addr);
assert(inst.read(trans) == 0);
trans.getData(data);
$display("Data = %x", data);
endfunction
endmodule
MMAV ユーザ • ガイド
11/6/08
189
MMAV ユーザ • ガイド
11/6/08
190
APPENDIX
A
A
技術サポート
デナリでは、自社製品の技術問題を解決するための迅速かつ簡単な手順を用意しています。
シミュレーション中にデナリ • ツールに問題があると思われた場合は、
次の 3 つの手順を実行
してください。シミュレーションに関係がない場合は、手順 3 に進みます。
手順 1:デナリ MMAV FAQ を確認する。
デナリ MMAV FAQ は、http://www.denali.com/support にあります。数多くのよくある質問が
FAQ ナレッジ • データベースに追加されているので、最初にこのサイトを確認してください。
FAQ で解決できない場合は、手順 2 に進みます。
手順 2:シミュレーションの結果を生成する。
履歴ファイルとトレース • ファイルは、モデルの動作を再現するために不可欠です。これらの
ファイルを生成するには、ローカルな .denalirc ファイルで次の行のコメントを解除してか
らシミュレーションを実行します。
HistoryFile <historyfile.his>
HistoryDebug On
TraceFile <tracefile.trc>
この履歴ファイルとトレース • ファイルは、
特定のメモリ • インスタンスに制限することがで
きます。これを実行するために、.denalirc ファイルには次の項目を制御する 2 つの設定が
あります。
TracePattern
TracePattern を使用すると、特定のインスタンス名パラメータのみを取り込むことによって、
トレース • ファイル ( 上記を参照 ) のサイズを制限することができます。*, ?, [] などのシェル
「グロブ」パターンを使用することができます。また、TraceFile のコメントを解除する必
要があります。
たとえば、"sdram" というパターンを持つメモリ • インスタンスのみをトレースするには、次
の構文を使用します。
TracePattern *sdram*
MMAV ユーザ • ガイド
11/6/08
191
HistoryPattern
HistoryPattern を使用すると、特定のインスタンス名パラメータのみを取り込むことによって、
トレース • ファイル ( 上記を参照 ) のサイズを制限することができます。*, ?, [] などのシェル
「グロブ」パターンを使用することができます。
たとえば、
"sdram" というパターンを持つメモリ • インスタンスのみの履歴を記録するには、
次
の構文を使用します。
HistoryPattern *sdram*
手順 3:シミュレーション • ファイルを圧縮する。
履歴ファイルおよびトレース • ファイルが非常に大きい場合があるため、電子メールのメッ
セージに添付する前にこれらのファイルを ( シミュレーション時に使用された SOMA ファイ
ルも一緒に ) 圧縮することをお勧めします。たとえば、ファイルを圧縮するには次の手順を
実行できます。
tar cf mail.tar <historyfile.his> <tracefile.trc>
gzip mail.tar
this will result in a "mail.tar.gz" file which you can E-mail to
"support@denalisoft.co.jp".
手順 4:電子メールのメッセージを作成する。
support@denalisoft.co.jp 宛ての電子メールには、次の情報を記載してください。
• 特定のエラー• メッセージや予期していなかった動作のタイム • スタンプを含む体験した
問題の簡潔な説明
• シミュレーション環境 ( シミュレータ、オペレーティング • システムなど )
• 連絡先 ( 電話番号、返信先の電子メールアドレスなど )
• 電子メール • メッセージの添付ファイルとして mail.tar.gz ファイル ( 手順 2 から )
この手順を実行することで、
デナリ • サポート • スタッフが素早く効果的に技術的な問題に対
応できるようになります。
MMAV ユーザ • ガイド
11/6/08
192
A.1
デナリ履歴ファイル
デナリの履歴ファイルには、
デナリ • メモリ • モデルに関する非常に重要なデバッグ情報が含
まれています。履歴ファイルはすべてのバス • トランザクションをデコードし、すべてのメモ
リ • イベントを記録します。必要に応じて、さらに多くのデバッグ情報を履歴ファイルで捕捉
するように選択することができます。これについては後述します。
A.1.1
デナリの履歴ファイルについて (.denalirc の HistoryFile)
.denalirc ファイルの HistoryFile パラメータを設定してデフォルトの履歴ファイルを生
成するように選択した場合、基本的なメモリのリード / ライト動作に加え、デコードされた
メモリのコマンドも表示されます。その履歴ファイルの例は次のとおりです。
Instance
Time Action
Address Value
testbench.uut1
LOAD FILE: init2.dat
testbench.uut1
LOAD FILE: done
testbench.uut1
LOAD FILE: init.dat
testbench.uut1
LOAD FILE: done
testbench.uut1
15 ns Cycle: 1 Command Nop
testbench.uut1 105 ns Cycle: 4 Command Precharge All
testbench.uut1 135 ns Cycle: 5 Command Mode Register Set
testbench.uut1 135 ns Setting Burst Length = 8 Cas Latency = 2 interleave
testbench.uut1 165 ns Cycle: 6 Bank 1 Command Activate
testbench.uut1 195 ns Cycle: 7 Command Nop
testbench.uut1 315 ns Cycle: 11 Bank 0 Command Activate
testbench.uut1 345 ns Cycle: 12 Command Nop
testbench.uut1 465 ns Cycle: 16 Bank 0 Command Write
000040+0
000 (1FF)
testbench.uut1 465 ns MASKED SIM WRITE
testbench.uut1 495 ns Cycle: 17 Command Nop
000041+0
001 (1FF)
testbench.uut1 495 ns MASKED SIM WRITE
000042+0
002 (1FF)
testbench.uut1 525 ns MASKED SIM WRITE
testbench.uut1 555 ns MASKED SIM WRITE
000043+0
003 (1FF)
000044+0
004 (1FF)
testbench.uut1 585 ns MASKED SIM WRITE
000045+0
005 (1FF)
testbench.uut1 615 ns MASKED SIM WRITE
testbench.uut1 645 ns MASKED SIM WRITE
000046+0
006 (1FF)
000047+0
007 (1FF)
testbench.uut1 675 ns MASKED SIM WRITE
testbench.uut1 795 ns Cycle: 27 Bank 0 Command Read
testbench.uut1 825 ns Cycle: 28 Command Nop
000040+0
000
testbench.uut1 825 ns
SIM READ
000041+0
001
testbench.uut1 855 ns
SIM READ
testbench.uut1 885 ns
SIM READ
000042+0
002
000043+0
003
testbench.uut1 915 ns
SIM READ
000044+0
004
testbench.uut1 945 ns
SIM READ
testbench.uut1 975 ns
SIM READ
000045+0
005
testbench.uut1 1005 ns Cycle: 34 Command Burst Stop
000046+0
006
testbench.uut1 1005 ns
SIM READ
MMAV ユーザ • ガイド
11/6/08
193
A.1.2
HistoryDebug モード (.denalirc の HistoryFile と
HistoryDebug)
.denalirc ファイルで HistoryDebug オプションをオンにすると、追加デバッグ情報を入手で
きます。この情報は、特定のメモリ • デバイスの内部設定を決定するときに役立ちます。デ
バッグありのサンプルの DRAM 履歴ファイルを以下に示します。
Instance
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
testbench.uut1
MMAV ユーザ • ガイド
Time Action
Address Value
LOAD FILE: init2.dat
LOAD FILE: done
LOAD FILE: init.dat
LOAD FILE: done
15 ns Debug: Cycle 1: State Bank 0: idle 1: idle
15 ns Cycle: 1 Command Nop
45 ns Debug: Cycle 2: State Bank 0: idle 1: idle
75 ns Debug: Cycle 3: State Bank 0: idle 1: idle
105 ns Debug: Cycle 4: State Bank 0: idle 1: idle
105 ns Cycle: 4 Command Precharge All
135 ns Debug: Cycle 5: State Bank 0: idle 1: idle
135 ns Cycle: 5 Command Mode Register Set
135 ns Setting Burst Length = 8 Cas Latency = 2 interleave
165 ns Debug: Cycle 6: State Bank 0: Mode Register Access 1: Mode Register Access
165 ns Cycle: 6 Bank 1 Command Activate
195 ns Debug: Cycle 7: State Bank 0: idle 1: active
195 ns Cycle: 7 Command Nop
225 ns Debug: Cycle 8: State Bank 0: idle 1: active
255 ns Debug: Cycle 9: State Bank 0: idle 1: active
285 ns Debug: Cycle 10: State Bank 0: idle 1: active
315 ns Debug: Cycle 11: State Bank 0: idle 1: active
315 ns Cycle: 11 Bank 0 Command Activate
345 ns Debug: Cycle 12: State Bank 0: active 1: active
345 ns Cycle: 12 Command Nop
375 ns Debug: Cycle 13: State Bank 0: active 1: active
405 ns Debug: Cycle 14: State Bank 0: active 1: active
435 ns Debug: Cycle 15: State Bank 0: active 1: active
465 ns Debug: Cycle 16: State Bank 0: active 1: active
465 ns Cycle: 16 Bank 0 Command Write
465 ns Debug: Write (0, 000, 040)
000040+0
000 (1FF)
465 ns MASKED SIM WRITE
495 ns Debug: Cycle 17: State Bank 0: active 1: active
495 ns Cycle: 17 Command Nop
495 ns Debug: Write (0, 000, 041)
000041+0
001 (1FF)
495 ns MASKED SIM WRITE
525 ns Debug: Cycle 18: State Bank 0: active 1: active
525 ns Debug: Write (0, 000, 042)
000042+0
002 (1FF)
525 ns MASKED SIM WRITE
555 ns Debug: Cycle 19: State Bank 0: active 1: active
555 ns Debug: Write (0, 000, 043)
000043+0
003 (1FF)
555 ns MASKED SIM WRITE
585 ns Debug: Cycle 20: State Bank 0: active 1: active
585 ns Debug: Write (0, 000, 044)
000044+0
004 (1FF)
585 ns MASKED SIM WRITE
615 ns Debug: Cycle 21: State Bank 0: active 1: active
615 ns Debug: Write (0, 000, 045)
000045+0
005 (1FF)
615 ns MASKED SIM WRITE
645 ns Debug: Cycle 22: State Bank 0: active 1: active
645 ns Debug: Write (0, 000, 046)
000046+0
006 (1FF)
645 ns MASKED SIM WRITE
675 ns Debug: Cycle 23: State Bank 0: active 1: active
675 ns Debug: Write (0, 000, 047)
000047+0
007 (1FF)
675 ns MASKED SIM WRITE
705 ns Debug: Cycle 24: State Bank 0: active 1: active
735 ns Debug: Cycle 25: State Bank 0: active 1: active
765 ns Debug: Cycle 26: State Bank 0: active 1: active
795 ns Debug: Cycle 27: State Bank 0: active 1: active
795 ns Cycle: 27 Bank 0 Command Read
825 ns Debug: Cycle 28: State Bank 0: active 1: active
825 ns Cycle: 28 Command Nop
825 ns Debug: Read (0, 000, 040)
000040+0
000
825 ns
SIM READ
855 ns Debug: Cycle 29: State Bank 0: active 1: active
855 ns Debug: Read (0, 000, 041)
000041+0
001
855 ns
SIM READ
885 ns Debug: Cycle 30: State Bank 0: active 1: active
885 ns Debug: Read (0, 000, 042)
11/6/08
194
testbench.uut1 885 ns
SIM READ
000042+0
002
testbench.uut1 915 ns Debug: Cycle 31: State Bank 0: active 1: active
testbench.uut1 915 ns Debug: Read (0, 000, 043)
000043+0
003
testbench.uut1 915 ns
SIM READ
testbench.uut1 945 ns Debug: Cycle 32: State Bank 0: active 1: active
testbench.uut1 945 ns Debug: Read (0, 000, 044)
000044+0
004
testbench.uut1 945 ns
SIM READ
testbench.uut1 975 ns Debug: Cycle 33: State Bank 0: active 1: active
testbench.uut1 975 ns Debug: Read (0, 000, 045)
000045+0
005
testbench.uut1 975 ns
SIM READ
testbench.uut1 1005 ns Debug: Cycle 34: State Bank 0: active 1: active
testbench.uut1 1005 ns Cycle: 34 Command Burst Stop
testbench.uut1 1005 ns Debug: Read (0, 000, 046)
000046+0
006
testbench.uut1 1005 ns
SIM READ
これらの追加的なデバッグコメントから、次のような貴重な情報が提供されます。
1. バンクの状態 (DRAM デバイスの場合 ):
testbench.uut1
945 ns
Debug: Cycle 32: State Bank 0: active 1: active
2. DRAM をデコードするために使用するデコードされたバンク、行、および列のアドレス:
testbench.uut1
975 ns
Debug:
Read (0, 000, 045)
この場合、このリード動作では、バンクアドレスが 0x0、行アドレスが 0x000、列アドレスが
0x045 になります。
MMAV ユーザ • ガイド
11/6/08
195
A.2
履歴ファイルについて
記述する履歴ファイルには、いくつかのトランザクションがあります。次に示されているデ
バッグ • エントリは、HistoryDebug をオンにした場合にのみ履歴ファイルに発生します。
A.2.1
A.2.2
SIM READ エントリ
インスタンス名
時間
アクション
testbench.uut1
25095 ns
SIM READ
testbench.x
A.2.4
A.2.5
000060+0
リード •
データ
024
MASKED SIM ライト • エントリ
インスタンス名
A.2.3
アドレス + オフセット
時間
202500 ps
アクション
アドレス + オフセット
MASKED SIM WRITE
00002+0
ライト •
データ
( マスク )
0000C
(3FFFF)
デバッグ • リード
インスタンス名
時間
デバッグ
testbench.uut1
945 ns
Debug:
アクション ( バンク • アドレス、
行アドレス、列アドレス )
Read (0, 000, 044)
デバッグ • ライト
インスタンス名
時間
testbench.uut1
615 ns
デバッグ
アクション ( バンク • アドレス、
行アドレス、列アドレス )
Debug:
Write (0, 000, 045)
ファイル • ロード
インスタンス名
testbench.uut1
testbench.uut1
32-Bit-Data
32-Bit-Data
MMAV ユーザ • ガイド
アクション (VIRT=" 論理 " メモリ ):ファイル名 / 実行
LOAD FILE: init.dat
LOAD FILE: done
VIRT LOAD FILE: mem32x8.dat
VIRT LOAD FILE: done
11/6/08
196
記号
.denalirc 55
A
AssertionMessages 46, 54
B
[Bit-blast Pins] 21
C
ClockStableCycles 43, 53
[Close Window] 34
[Contents Table Origin] 34
coupling 故障 90
D
DDR-II 55
DDR-II SDRAM 固有の .denalirc パラメータ 48
[Debug] 34
DenaliMemCallback 120
denaliMemCallback 118, 120, 121
DenaliOwn 36, 55
DenaliOwnClass 36, 55
denaliPcieCallback 118
denalirc 38
DifferentialClockChecks 45, 54
DifferentialClockSkew 46
DifferentialClockSkewClock Skew 46
DRAM 11
E
eDRAM 54
EiMessages 45, 54
enableReason 120
ErrorCount 54
ErrorMessages 44, 53
ErrorMessagesStartTime 44, 53
eSSRAM 55
ESSRAM 固有の .denalirc パラメータ 49
Event 120
ExitOnErrorCount 44, 53
F
FAQ 8
G
getCallback() 121
H
HDL シェル 22
HistoryDebug 39, 52, 191
HistoryDebugLoad 39, 52
HistoryFile 39, 52
HistoryInSimLog 39, 52
HistoryPattern 43, 53
I
IBM-EDRAM 固有の .denalirc パラメータ 47
InitChecks 53
InitChecksPauseTime 45, 53
InitialMemoryValue 41, 53
InitMessages 42, 53
InitMrsAddressStable 48, 54
MMAV ユーザ • ガイド
11/6/08
197
IrregularClock 43, 53
L
LicenseQueueRetryDelay 40, 52
LicenseQueueTimeout 40, 52
M
[Memory Contents] ウィンドウ 33
Mentor Graphics ModelSim 固有の .denalirc パラメータ 49
Mentor Graphics Seamless HW/SW Co-Verification 固有の .denalirc パラメータ 49
Mentor Seamless 109
mmassert_access 83
MMAV での論理アドレス指定 92
mmbreak 59
mmcomp 71
mmCreateScratchpad 107
mmcreatescratchpad 106, 108
mmdebugoff 76
mmdebugon 76
mmdisablecallback 60
mmdisablecallbackall 60
mmenablecallback 60
mmerrinject 87
mmerrormessagesoff 75
mmerrormessageson 75
mmexit 59
mmfault 90
mmgetids 59
mmgetinfobyid 59
mmgetinstanceid 67
mminstanceid 67
mmload 64
mmnote 59
mmreadword 69
mmreadword2 69
mmreadword3 69
mmrecalculatecycle 72
mmreset 68
mmsave 71
mmsaverange 71
mmsetaccesscallbackmask 61
mmsetallerrinject 88
mmsetallfault 91
mmsetfault 91
mmSetFillValue 63
mmsetvar 55
mmsomaload 74
mmsomaset 73, 74
mmstartpureview 30
mmTclCallback 58
mmTclEval 57
mmtcleval 55, 73
mmtime 59
mmwriteword 69
mmwriteword2 69
mmwriteword3 69
mmwriteword4 69
mmwriteword5 69
mmwritewordmasked 70, 71
ModelSim 55
ModelSimTimeDefinitionToggle 48, 49, 50, 51, 52, 55
ModelSim での Tcl の使用 57
MMAV ユーザ • ガイド
11/6/08
198
N
NCSIM 57
NCSIM での Tcl の使用 57
O
OffChipDriveImpedanceChecks 55
[Open Instance] 34
OutputTiming 53
P
PureSpec
ヘルプとマニュアル 8
PureView 10, 29
R
RAMBUS 77
RAMBUS - .denalirc のオプション 78
RAMBUS - Turbo モード 80
RAMBUS - チャネル遅延の設定 78
RAMBUS - デバイス ID 77
RAMBUS - デバイス数 77
RAMBUS - デバイス • リフレッシュのオプション 79
RAMBUS - マルチバンク • リフレッシュのオプション 79
RandomOutputDelay 43, 53
RDRAM (Rambus) 固有のオプション 44
RDRAM 固有の .denalirc パラメータ 47
RDRAM - バイト • オーダリングのオプション 80
ReadDQSContentionCheck 41, 53
reason 121
[Refresh] 34
RefreshChecks 41, 53
RefreshOnReadWrite 41, 53
RLDRAM 54
RldramInitCyclesCheck 48, 54
RldramInitRefreshChecks 48
RLDRAM 固有の .denalirc パラメータ 48
[Run Tcl Command] 34
S
[Save SOMA] 19
[Save SOMA As] 19
[Save Source] 19
[Save Source As] 19
Seamless 55
setCallback 120
[Show Last Read] 34
[Show Last Write] 34
SimulationDatabase 36, 40, 52
SimulationDatabaseBuffering 41, 52
SimulationDatabasePattern 40, 52
[SOMA Output Format] 20
SOMA ファイルの再ロード 73
SRAM 11
[STD_ULOGIC for VHDL Ports] 21
SuppressPortContention 55
SuppressRefreshInfoMessages 54
SuppressUnknownAddrReadError 46
T
Tcl 57
TclInterp 44, 45, 54
Tcl インターフェイス 56
MMAV ユーザ • ガイド
11/6/08
199
Tcl コールバック • ヘルパのコマンド 59
TimingChecks 41, 53
TimingChecksReportOnly 47, 78
TimingChecksStartTime 47, 79
TraceBackdoorReadWrite 54
TraceBackdoorReadWrite 0 46
TraceFile 39, 52, 191
TracePattern 42, 53
TraceTimingChecks 39, 52
TrackAccessFromInit 45, 54
transGet 120
transId 120, 121
transition 故障 90
V
[Value Format] 34
Vera インターフェイス
概要 142, 167
シミュレーション 164
Verilog コールバック 118
W
WarnSuppress 47
X
XML の基本 92
あ
アサーション 82
アサーションの動的な有効化および無効化 86
アサーション • メッセージ 46
アドレス 62
アドレス指定方式 62
アドレスのスクランブル 97, 105
い
インターリーブ 95, 101
インターリーブの例 96
え
エラー • カウント変数 45
エラー挿入 87
エラー • メッセージの制御 75
エンベデッド ASIC/FPGA 11
き
技術サポート 8, 191
規則、表記 7
く
グローバルなメモリ • アクセスのアサーション 85
クロック • サイクルの再計算 72, 76
こ
コールバック 118
コールバック • インターフェイス 118
顧客サポート 8
故障チェックの有効化 / 無効化 91
故障モデリング 90
MMAV ユーザ • ガイド
11/6/08
200
し
シミュレーション
Vera インターフェイス 164
シミュレータ • キューイング 56
縮退故障 90
出力タイミング 44
初期化チェック 44
す
スクラッチパッドのメモリ 106
た
タイミング • パラメータの変更 73
て
データ • アクセスのアサーション 83
データ • ビットの並べ替えおよびマスキング 97
デナリ技術サポート 8
と
トランザクション • サマリ 35
トランザクション履歴 35
は
「バックドア」リードでのエラー挿入の有効化 89
バックドア • リード / ライトのトレース 46
幅の拡張 93, 94, 101
パリティ • チェックのアサーション 86
ひ
表記規則 7
ふ
ファイルからのメモリのロード 63
深さの拡張 93, 95, 101
不揮発性 / フラッシュ • メモリ 11
ま
マスキング 102
マスクされたメモリ • ライト 70
め
メモリ • アクセスのアサーション 82
メモリ • アドレスの判定 62
メモリ内容ファイルの形式 65
メモリの故障の作成 90
メモリの初期化 62
メモリの内容の保存と比較 71
メモリのパリティ • ビットのビット位置 66
メモリのホール 98
メモリのリードとライト 69
ら
ライセンスに関するソリューション 56
ライセンスのチェックアウト 56
り
履歴ファイル 191, 193
MMAV ユーザ • ガイド
11/6/08
201
れ
レジスタ • ファイル固有の .denalirc パラメータ 46
MMAV ユーザ • ガイド
11/6/08
202