1

使用 SystemC 时出现重复的 seg 错误。在初始化期间,我将值设置为 0。在测试台运行期间,我在模块 (proc) 中将此值设置为 1。这是一个附加到另一个模块 imem 的端口的 sc_signal 变量。输入端口的类型为 sc_in。

理论上,这个赋值应该导致输入端口也被赋值为 1,当我尝试使用 .read() 函数访问它时,它应该返回一个 1 并将其分配给 imem 中的另一个内部 sc_signal。

但是,我却遇到了段错误。

根据 gdb,这发生在我进行 sc_start(10,SC_NS) 调用期间,这是有道理的,因为这是应该更新值的时候。它专门跟踪它以尝试执行 .read() 的返回。这是堆栈返回的快速片段(使用 g++ 和 gdb6.6,64 位系统的 -O0 和 -g3):

#0  0x00000000004c79a6 in sc_core::sc_in<bool>::read (this=0x881a38) at <redacted>/systemC/install_x64/include/sysc/communication/sc_signal_ports.h:515
#1  0x00000000004e4b60 in imem::reg_write (this=0x881910) at ../src/abstract_proc/mems/imem.cpp:33
#2  0x000000000050578e in sc_core::sc_simcontext::crunch(bool) ()
#3  0x00000000005042b4 in sc_core::sc_simcontext::simulate(sc_core::sc_time const&) ()
#4  0x00000000004c65b0 in sc_core::sc_start (duration=10, time_unit=sc_core::SC_NS)

港口申报:

SC_MODULE (imem) {
...
sc_in<bool> en_wr;

函数声明(发生在 SC_CTOR(imem) 中):

SC_METHOD(reg_write);
sensitive << clk.pos();

它死亡的功能:

void imem::reg_write() {
data_wr_d.write(data_wr.read());
wr_addr_d.write(addr_wr.read());
cout << "imem::reg_write()" << std::endl;
en_wr_d.write(en_wr.read());
cout << "imem::reg_write() done" << std::endl;
}

imem::reg_write()在 seg 故障发生之前打印到控制台中。

imem的port的声明和绑定:

imem_i = new imem("imem");
imem_i->en_wr(imem_wr_en);

驱动信号的声明:

sc_signal<bool> imem_wr_en;

有任何想法吗?想法?我应该尝试的事情?

编辑:有时会发生一些奇怪的事情,添加或删除代码行会导致段错误消失。一个特定的实例涉及添加一个调试cout语句修复了一些问题,但是在<< std::endl它的末尾添加了一个 seg 错误后返回。这暗示了我有一个竞争条件,但理论上 SystemC 应该处理所有并发线程。

4

2 回答 2

0

听起来像内存问题。如果您在某处过度运行缓冲区,任何事情都可能发生 - 甚至像您解释的那样:程序在随机位置崩溃。

我真的希望你有好的单元测试。尝试使用 valgrind 检测内存问题。

于 2010-10-28T21:01:19.957 回答
0

您能否告诉您是否有解决问题的方法。实际上,我们在读取布尔 sc_signal 时遇到了类似的问题,段错误。在代码中添加打印后问题就消失了。

于 2013-05-12T02:02:17.023 回答