カテゴリー「SystemC」の3件の記事

【SystemC】 cannot have more than one driverエラー

SystemCでバスのモデルを書いてみました。Read/Write Enable信号とアドレスバスはバスマスター側からドライブするから良いのだけど、データバスは双方向からドライブする必要がある。そこでsc_inoutを使って入出力ポートを指定してみました。

SC_MODULE(MOD1) {
    sc_inout<sc_uint<32> > DATA;
};

SC_MODULE(MOD2) {
    sc_signal<sc_uint<32> > DATA;
};

こんな感じにモジュールを作成して、ポートを接続すると、MOD1とMOD2の両方から駆動する事になります。

すると...ラインタイムエラーが...正確なメッセージは忘れたけど

*** signal cannot have more than one driver.

つまり、sc_signalには単一のドライバしか接続できないっちゅー事です。
バスって事はRead/Write Enable信号で切り替えるわけやから同時ドライブする事はないのやけど、SystemCのシミュレーション環境では1回のシミュレーション内でシグナルを複数プロセスからドライブする事が許されていないらしい。しかもこれ、SytemC 2.1.0までは許可されていたそうな。つまりSystemC 2.2.0での現象らしいですわ。

さて、困ったぞ。本来はバスプロトコルを変更して対応すべきなんやけど、別に論理合成するわけでもないし、単にアーキテクチャの検討したいだけなんやけどなぁ。

結論から言うとなんと環境変数の設定で、このチェックを外せるらしい。
SystemC 2.2.0のnoteに書かれていました。

set SC_SIGNAL_WRITE_CHECK=DISABLE

とやってビルドしたバイナリを実行したら無事に動作しました。ちなみに大文字でなければダメでした。いやはや、まさか環境変数とはね。

【Windows】 VisualStudio 2010 でコンソールアプリの実行中断ができない

いやはや、VisualStudioなんて随分ご無沙汰。Visual BasicやらVisual C++やら昔は色々と触ったもんやけどねぇ。

SystemCを使った回路シミュレーションをやろうとしたら、Windows環境ではVisual C++がサポートされていたみたい。Cygwinでも良いんやけど、この際なんでVisualStudio 2010 Express入れてみました。
SystemCのアプリは大抵コンソールアプリとして作るんやけど、ここで問題が発生。
デバッガでソースコードをトレースしている途中に、バグの原因が分かったのでコード修正するために実行中断をしたわけです。にも関わらず何故かコンソールウィンドウが残ってしまっている。
タスクマネージャから強制終了しようと思ったら、なんとプロセスリストにも出てこないのだ。

どうしたものかと調べてみた所、これはどうやらマイクロソフトのバグらしい。プロセスの特権が昇格されてしまうとの情報が。そうか、特権レベルで動いてしまうからユーザレベルからプロセスを止められないのか...。

Visual Studio では、Windows XP を実行しているコンピューター上でアプリケーションのデバッグを停止した後、アプリケーションのコンソール ウィンドウを閉じることはできません。

http://support.microsoft.com/kb/982551/

結局、978037のセキュリティ更新プログラムをインストールする事が対策のようです。

無事解決しました。

(2011/01/04追記)

訂正事項です。

完全に誤解を招く書き方をしていましたが、978037のセキュリティ更新プログラムをインストールする事は対策ではなく原因です。で、978037の情報ページに本件の対策パッチがリリースされているので、それを適用する事が解決方法になります。このパッチは正式なバージョンではないためダウンロードにはメールアドレス等の登録が必要です。

発生条件はWindows XP SP2 or SP3で978037のパッチをインストールしている事のようです。逆にこのセキュリティ更新プログラムをアンインストールしても良いのやけどね。

【SystemC】 SystemC with MinGW, MSYS

システムシミュレーションをするべくSystemCを勉強中やねんけど、C++が使える人にとっては、これは楽やなぁ。
HDLを使ってるデジタルハード屋さんにはちょっと厳しいかもしれへんけどね。

ってな事で、基本的にソフト屋さんな僕としてはSystemCは特に違和感なく取っ掛かる事ができました。
まださわりだけやから、これから色々と調べなくちゃならん事があるかもしれへんけど...。

SystemCの動作環境についてです。
メインマシンはubuntuなので、殆ど問題なし。SystemCのサイトからパッケージをダウンロードしたら、普通に動きました。波形データもVCDファイルに落として、GTKwaveを使って見る事ができたしね。

Screenshotgtkwave_halfaddrvcd_2 ←半加算器を実装して波形観測した様子。





さて問題はWindows環境や。
Windows環境では僕は通常MinGW+MSYSを使ってるんやけど、SystemCのパッケージはcygwinを推奨しているみたい。
configureがMinGWには対応してないんですわ。そこで、ちょこちょこ〜っと変更してMinGW版のlibsystemc.aを作成してみました。以下、そのやり方を覚え書き。

MinGWで動作させるSystemC

  1. パッケージをダウンロードする
  2. ソースコードをコピー
  3. ソースを一部変更
  4. MinGW用のmakefileを作成してビルド
  5. オブジェクトファイルを抽出(バージョン2.2.0で78ファイル)
  6. アーカイバでライブラリ作成

こんな感じ。

1. は http://www.systemc.org/ にアクセスして、利用者登録してパッケージをダウンロードすればOK。
今現在の最新版は 2.2.0 ですわ。

2. 上でダウンロードしたパッケージを解凍すると

tar -zxvf systemc-2.2.0.tar.gz

config, docs, examples, src ...といったディレクトリができまする。
この内、srcのみを使いまする。
srcディレクトリを適当な場所にそっくりコピー。
元ファイルを取っておかなくてもよければ、このコピーは不要ですわ。

3. ソースを一部変更しまする。
SystemCのkernelやdatatypeといったコードはcygwinのg++に対応させているらしく、一部MinGWのg++ではエラーになる記述が存在するねん。あと、僕がgcc4を使っているからって事もあるのやけど、型不一致のエラーも出てたみたい。
という事で、以下のように修正します。

sysc/datatypes/int/sc_nbdefs.cpp
sysc/datatypes/int/sc_int64_mask.cpp

ファイルの先頭に以下の行を追加

#undef WIN32

これは、WIN32定義があると i64 記述子を使うようになっているためです。
MinGWのgccではi64記述子は使われへんようやね。コマンドオプションで何かあったような気がするんやけど、とりあえず手っ取り早くコードを変更しちゃいました。ご丁寧にもWIN32以外やったら、ULL記述子を使うようにコードが書かれてるし。

sysc/datatypes/int/sc_nbcommon.inc
2985行目で型不一致エラーになるので、std::_Ios_Fmtflagsへのキャストを追加。

os.setf((std::_Ios_Fmtflags)old_flags, ::std::ios::basefield);


sysc/kernel/sc_cor_fiber.h

PVOIDとかが未定義やってエラーになるんで、ファイル先頭に以下の行を追加。

#include <windows.h>

sysc/utils/sc_utils_ids.cpp
getenv関数とstrcmpの定義が見つからんってエラーになる。よってファイル先頭に以下の行を追加。

#include <stdlib.h>
#include <string.h>

110行目辺り、getenv関数を呼び出している所が、std::getenvを呼び出している。
stdlib.hのgetenvを使うので、stdスコープは余計ですな。削除しまする。

const char* deprecation_warn = getenv("SC_DEPRECATION_WARNINGS");

さぁ、これでコード修正が完了。

4. MinGW用のMakefileを作ってビルド。
まぁ、これは各自サクっとやっちゃってください。
僕の場合は普段から使っているmake ruleがあるんで、それで一期にやっちゃいました。
必要なんは、オブジェクトファイルを作る事なんで、リンクは不要っす。(というかできひん)
コンパイルだけやっちゃってくださいな。
findコマンドとg++でも一応できるけどね。
ちなみにコンパイル対象のディレクトリは

  • communications
  • datatypes
  • kernel
  • tracing
  • utils

だけでOKです。cygwinの環境では qt まで含めてるんやけど、とりあえず使わんでしょう。

5. コンパイルしてできた .oファイルをどこかのフォルダにコピーしてまとめて...

6. アーカイバでライブラリを作成しまする。

$ ar cq libsystemc.a *.o

こんな感じかな。
これで、MinGW環境で使えるlibsystemc.aがでけました。
あとは普通にSystemCのコード書いて、このライブラリをリンクしちゃってくださいな。

ふぅ、cygwinってシェルのパス変更するから好きやないんよなぁ。
という事で、何がなんでもMinGW+MSYSでという方向けの情報ですな。