使用 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 应该处理所有并发线程。