diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/systemc/core/event.cc | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/src/systemc/core/event.cc b/src/systemc/core/event.cc index 77e47fba6..4f3d4f9c1 100644 --- a/src/systemc/core/event.cc +++ b/src/systemc/core/event.cc @@ -37,18 +37,23 @@ #include "sim/core.hh" #include "systemc/core/module.hh" #include "systemc/core/scheduler.hh" +#include "systemc/ext/core/sc_main.hh" +#include "systemc/ext/core/sc_module.hh" namespace sc_gem5 { -Event::Event(sc_core::sc_event *_sc_event) : Event(_sc_event, "") {} +Event::Event(sc_core::sc_event *_sc_event) : Event(_sc_event, nullptr) {} -Event::Event(sc_core::sc_event *_sc_event, const char *_basename) : - _sc_event(_sc_event), _basename(_basename), +Event::Event(sc_core::sc_event *_sc_event, const char *_basename_cstr) : + _sc_event(_sc_event), _basename(_basename_cstr ? _basename_cstr : ""), delayedNotify([this]() { this->notify(); }) { Module *p = currentModule(); + if (_basename == "" && ::sc_core::sc_is_running()) + _basename = ::sc_core::sc_gen_unique_name("event"); + if (p) parent = p->obj()->sc_obj(); else if (scheduler.current()) |