Go to the documentation of this file.
187 GlobalSimLoopExitEvent *
190 std::unique_ptr<GlobalSyncEvent, DescheduleDeleter> quantum_event;
194 inform(
"Entering event queue @ %d. Starting simulation...\n",
curTick());
202 "simulate() limit reached", 0);
208 "Quantum for multi-eventq simulation not specified");
225 assert(global_event);
229 assert(global_exit_event);
231 return global_exit_event;
249 static std::mutex mutex;
251 bool was_set =
false;
278 assert(!eventq->
empty());
280 "event scheduled in the past");
285 std::lock_guard<EventQueue>
lock(*eventq);
309 if (exit_event != NULL) {
A special global event that synchronizes all threads and forces them to process asynchronously enqueu...
Tick curTick()
The universal simulation clock.
void terminateEventQueueThreads()
Terminate helper threads when running in parallel mode.
std::vector< EventQueue * > mainEventQueue
Array for main event queues.
volatile bool async_exit
Async request to exit simulator.
std::atomic< bool > terminate
static bool testAndClearAsyncEvent()
Test and clear the global async_event flag, such that each time the flag is cleared,...
void reschedule(Tick when)
volatile bool async_statreset
Async request to reset stats.
bool inParallelMode
Current mode of execution: parallel / serial.
void operator()(BaseGlobalEvent *event)
static const Priority Progress_Event_Pri
Progress events come at the end.
void exitSimLoop(const std::string &message, int exit_code, Tick when, Tick repeat, bool serialize)
Schedule an event to exit the simulation loop (returning to Python) at the end of the current cycle (...
volatile bool async_statdump
Async request to dump stats.
Event * doSimLoop(EventQueue *)
forward declaration
void handleAsyncInsertions()
Function for moving events from the async_queue to the main queue.
Common base class for GlobalEvent and GlobalSyncEvent.
SimulatorThreads & operator=(SimulatorThreads &)=delete
volatile bool async_exception
Python exception.
uint64_t Tick
Tick count type.
Queue of events sorted in time order.
virtual BaseGlobalEvent * globalEvent()
If this is part of a GlobalEvent, return the pointer to the Global Event.
Tick simQuantum
Simulation Quantum for multiple eventq simulation.
bool empty() const
Returns true if no events are queued.
SimulatorThreads()=delete
volatile bool async_io
Async I/O request (SIGIO).
GlobalSimLoopExitEvent * simulate(Tick num_cycles)
Simulate for num_cycles additional cycles.
EventQueue * curEventQueue()
uint32_t numMainEventQueues
Current number of allocated main event queues.
void thread_main(EventQueue *queue)
The main function for all subordinate threads (i.e., all threads other than the main thread).
std::vector< std::thread > threads
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
static std::unique_ptr< SimulatorThreads > simulatorThreads
void schedStatEvent(bool dump, bool reset, Tick when, Tick repeat)
Schedule statistics dumping.
volatile bool async_event
Some asynchronous event has happened.
GlobalSimLoopExitEvent * simulate_limit_event
SimulatorThreads(uint32_t num_queues)
Generated on Wed May 4 2022 12:14:03 for gem5 by doxygen 1.8.17