2

MacBook (Mac OS X 10.10) でオープン ソースの SystemC ベースの NoC シミュレーターであるnirgam 3.0を実行しています。nirgam ソース コードを正常にコンパイルしましたが、実行しようとすると、次のように「セグメンテーション エラー」がスローされます。

╰─$ ./nirgam

        SystemC 2.3.1-Accellera --- May  3 2015 19:32:31
        Copyright (c) 1996-2014 by all Contributors,
        ALL RIGHTS RESERVED
[1]    5067 segmentation fault  ./nirgam

    (lldb) r
    Process 5076 launched: './nirgam' (x86_64)

エラーを見つけるために使用しようとしlldbましたが、次のヒントが得られました。

        SystemC 2.3.1-Accellera --- May  3 2015 19:32:31
        Copyright (c) 1996-2014 by all Contributors,
        ALL RIGHTS RESERVED
Process 5076 stopped
* thread #1: tid = 0x7321, 0x00000001000c9d8d nirgam`sc_main(argc=1, argv=0x00000001004060f0) + 45 at main.cpp:62, queue = 'com.apple.main-thread', stop reason = EXC_BAD_ACCESS (code=2, address=0x7fff5eb2dd18)
    frame #0: 0x00000001000c9d8d nirgam`sc_main(argc=1, argv=0x00000001004060f0) + 45 at main.cpp:62
   59
   60   int sc_main(int argc, char *argv[])
   61   {
-> 62       system("rm -rf *.txt");
   63       system("rm -rf jitter/GT/*");
   64       system("rm -rf jitter/BE/*");
   65       cout<<"---------------------------------------------------------------------------"<<endl;
(lldb) bt
* thread #1: tid = 0x7321, 0x00000001000c9d8d nirgam`sc_main(argc=1, argv=0x00000001004060f0) + 45 at main.cpp:62, queue = 'com.apple.main-thread', stop reason = EXC_BAD_ACCESS (code=2, address=0x7fff5eb2dd18)
  * frame #0: 0x00000001000c9d8d nirgam`sc_main(argc=1, argv=0x00000001004060f0) + 45 at main.cpp:62
    frame #1: 0x0000000100238778 libsystemc-2.3.1.dylib`sc_elab_and_sim + 184
    frame #2: 0x00007fff879a65c9 libdyld.dylib`start + 1
    frame #3: 0x00007fff879a65c9 libdyld.dylib`start + 1

次の事実がヒントになります。

  1. システム環境で記述した Noxim やその他のコードを含む他の SystemC ベースをコンパイルして実行できます。

  2. sc_mainlldb 情報は、SystemC ベースのモデリングの主要な機能であるに行くときにエラーが発生したことを示しています。

私の質問は:

  1. 関数EXC_BAD_ACCESSを呼び出すとはどういう意味ですか?sc_main

  2. このバグの原因に近づくために使用できる方法はありますか?

4

0 に答える 0