summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/sim/sim_events.hh5
-rw-r--r--src/sim/simulate.cc13
-rw-r--r--src/sim/simulate.hh2
3 files changed, 6 insertions, 14 deletions
diff --git a/src/sim/sim_events.hh b/src/sim/sim_events.hh
index 4d001f8f0..5be2609fd 100644
--- a/src/sim/sim_events.hh
+++ b/src/sim/sim_events.hh
@@ -71,11 +71,6 @@ class GlobalSimLoopExitEvent : public GlobalEvent
void process(); // process event
virtual const char *description() const;
-
- virtual ~GlobalSimLoopExitEvent() {
- // simulate()'s singleton GlobalSimLoopExitEvent is always scheduled
- deschedule();
- }
};
class LocalSimLoopExitEvent : public Event
diff --git a/src/sim/simulate.cc b/src/sim/simulate.cc
index 14dd00fc1..e0b80bbe8 100644
--- a/src/sim/simulate.cc
+++ b/src/sim/simulate.cc
@@ -71,13 +71,7 @@ thread_loop(EventQueue *queue)
}
}
-GlobalEvent*
-getLimitEvent(void) {
- static GlobalSimLoopExitEvent
- simulate_limit_event(mainEventQueue[0]->getCurTick(),
- "simulate() limit reached", 0);
- return &simulate_limit_event;
-}
+GlobalSimLoopExitEvent *simulate_limit_event = nullptr;
/** Simulate for num_cycles additional cycles. If num_cycles is -1
* (the default), do not limit simulation; some other event must
@@ -104,6 +98,9 @@ simulate(Tick num_cycles)
}
threads_initialized = true;
+ simulate_limit_event =
+ new GlobalSimLoopExitEvent(mainEventQueue[0]->getCurTick(),
+ "simulate() limit reached", 0);
}
inform("Entering event queue @ %d. Starting simulation...\n", curTick());
@@ -113,7 +110,7 @@ simulate(Tick num_cycles)
else // counter would roll over or be set to MaxTick anyhow
num_cycles = MaxTick;
- getLimitEvent()->reschedule(num_cycles);
+ simulate_limit_event->reschedule(num_cycles);
GlobalSyncEvent *quantum_event = NULL;
if (numMainEventQueues > 1) {
diff --git a/src/sim/simulate.hh b/src/sim/simulate.hh
index 18be7ea82..85d58e119 100644
--- a/src/sim/simulate.hh
+++ b/src/sim/simulate.hh
@@ -33,4 +33,4 @@
#include "sim/sim_events.hh"
GlobalSimLoopExitEvent *simulate(Tick num_cycles = MaxTick);
-GlobalEvent* getLimitEvent();
+extern GlobalSimLoopExitEvent *simulate_limit_event;