gem5  v21.0.1.0
scheduler.cc
Go to the documentation of this file.
1 /*
2  * Copyright 2018 Google, Inc.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are
6  * met: redistributions of source code must retain the above copyright
7  * notice, this list of conditions and the following disclaimer;
8  * redistributions in binary form must reproduce the above copyright
9  * notice, this list of conditions and the following disclaimer in the
10  * documentation and/or other materials provided with the distribution;
11  * neither the name of the copyright holders nor the names of its
12  * contributors may be used to endorse or promote products derived from
13  * this software without specific prior written permission.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
21  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  */
27 
29 
30 #include "base/fiber.hh"
31 #include "base/logging.hh"
32 #include "sim/eventq.hh"
33 #include "sim/sim_exit.hh"
34 #include "systemc/core/kernel.hh"
40 #include "systemc/utils/report.hh"
42 
43 namespace sc_gem5
44 {
45 
47  eq(nullptr), readyEvent(this, false, ReadyPriority),
48  pauseEvent(this, false, PausePriority),
49  stopEvent(this, false, StopPriority), _throwUp(nullptr),
50  starvationEvent(this, false, StarvationPriority),
51  _elaborationDone(false), _started(false), _stopNow(false),
52  _status(StatusOther), maxTick(::MaxTick),
53  maxTickEvent(this, false, MaxTickPriority),
54  timeAdvancesEvent(this, false, TimeAdvancesPriority), _numCycles(0),
55  _changeStamp(0), _current(nullptr), initDone(false), runToTime(true),
56  runOnce(false)
57 {}
58 
60 {
61  // Clear out everything that belongs to us to make sure nobody tries to
62  // clear themselves out after the scheduler goes away.
63  clear();
64 }
65 
66 void
68 {
69  // Delta notifications.
70  while (!deltas.empty())
71  deltas.front()->deschedule();
72 
73  // Timed notifications.
74  for (auto &ts: timeSlots) {
75  while (!ts->events.empty())
76  ts->events.front()->deschedule();
77  deschedule(ts);
78  }
79  timeSlots.clear();
80 
81  // gem5 events.
82  if (readyEvent.scheduled())
84  if (pauseEvent.scheduled())
86  if (stopEvent.scheduled())
88  if (starvationEvent.scheduled())
90  if (maxTickEvent.scheduled())
92  if (timeAdvancesEvent.scheduled())
94 
95  Process *p;
96  while ((p = initList.getNext()))
97  p->popListNode();
98  while ((p = readyListMethods.getNext()))
99  p->popListNode();
100  while ((p = readyListThreads.getNext()))
101  p->popListNode();
102 
103  Channel *c;
104  while ((c = updateList.getNext()))
105  c->popListNode();
106 }
107 
108 void
110 {
111  runUpdate();
112 
113  for (Process *p = initList.getNext(); p; p = initList.getNext()) {
114  p->popListNode();
115 
116  if (p->dontInitialize()) {
117  if (!p->hasStaticSensitivities() && !p->internal()) {
119  p->name());
120  }
121  } else {
122  p->ready();
123  }
124  }
125 
126  runDelta();
127 
128  for (auto ets: eventsToSchedule)
129  eq->schedule(ets.first, ets.second);
130  eventsToSchedule.clear();
131 
132  if (_started) {
133  if (!runToTime && starved())
136  }
137 
138  initDone = true;
139 
141 
143 }
144 
145 void
147 {
148  if (initDone) {
149  // If not marked as dontInitialize, mark as ready.
150  if (!p->dontInitialize())
151  p->ready();
152  } else {
153  // Otherwise, record that this process should be initialized once we
154  // get there.
156  }
157 }
158 
159 void
161 {
162  // Pull a process from the active list.
164  if (!_current) {
165  // There are no more processes, so return control to evaluate.
167  } else {
169  _current->scheduled(false);
170  // Switch to whatever Fiber is supposed to run this process. All
171  // Fibers which aren't running should be parked at this line.
172  _current->fiber()->run();
173  // If the current process needs to be manually started, start it.
174  if (_current && _current->needsStart()) {
175  _current->needsStart(false);
176  // If a process hasn't started yet, "resetting" it just starts it
177  // and signals its reset event.
178  if (_current->inReset())
180  try {
181  _current->run();
182  } catch (...) {
183  throwUp();
184  }
185  }
186  }
187  if (_current && !_current->needsStart()) {
188  if (_current->excWrapper) {
189  auto ew = _current->excWrapper;
190  _current->excWrapper = nullptr;
191  ew->throw_it();
192  } else if (_current->inReset()) {
193  _current->reset(false);
194  }
195  }
196 }
197 
198 void
200 {
201  if (_stopNow)
202  return;
203 
204  p->scheduled(true);
205 
206  if (p->procKind() == ::sc_core::SC_METHOD_PROC_)
208  else
210 
211  if (!inEvaluate())
213 }
214 
215 void
217 {
218  if (initDone)
219  ready(p);
220  else
222 }
223 
224 bool
226 {
227  ListNode *n = list->nextListNode;
228  while (n != list)
229  if (n == target)
230  return true;
231  return false;
232 }
233 
234 bool
236 {
237  bool was_ready;
238  if (initDone) {
239  // After initialization, check if we're on a ready list.
240  was_ready = (p->nextListNode != nullptr);
241  p->popListNode();
242  } else {
243  // Nothing is ready before init.
244  was_ready = false;
245  }
246  return was_ready;
247 }
248 
249 void
251 {
253  if (!inEvaluate())
255 }
256 
257 void
259 {
260  std::lock_guard<std::mutex> lock(asyncListMutex);
262  hasAsyncUpdate = true;
263 }
264 
265 void
267 {
268  // Schedule the evaluate and update phases.
269  if (!readyEvent.scheduled()) {
271  if (starvationEvent.scheduled())
273  }
274 }
275 
276 void
278 {
279  if (!starvationEvent.scheduled()) {
281  if (readyEvent.scheduled())
283  }
284 }
285 
286 void
288 {
290 
291  bool empty = readyListMethods.empty() && readyListThreads.empty();
293 
294  // The evaluation phase.
296  do {
297  yield();
298  } while (getNextReady());
299  _current = nullptr;
300 
301  if (!empty) {
302  _numCycles++;
303  _changeStamp++;
304  }
305 
306  if (_stopNow) {
308  return;
309  }
310 
311  runUpdate();
312  if (!traceFiles.empty())
313  trace(true);
314  runDelta();
315 
316  if (!runToTime && starved())
318 
319  if (runOnce)
320  schedulePause();
321 
323 }
324 
325 void
327 {
329  if (hasAsyncUpdate) {
330  std::lock_guard<std::mutex> lock(asyncListMutex);
331  Channel *channel;
332  while ((channel = asyncUpdateList.getNext()) != nullptr)
333  updateList.pushLast(channel);
334  hasAsyncUpdate = false;
335  }
336 
337  try {
338  Channel *channel = updateList.getNext();
339  while (channel) {
340  channel->popListNode();
341  channel->update();
342  channel = updateList.getNext();
343  }
344  } catch (...) {
345  throwUp();
346  }
347 }
348 
349 void
351 {
353 
354  try {
355  while (!deltas.empty())
356  deltas.back()->run();
357  } catch (...) {
358  throwUp();
359  }
360 }
361 
362 void
364 {
367  runOnce = false;
368  if (scMainFiber.called()) {
369  if (!scMainFiber.finished())
370  scMainFiber.run();
371  } else {
372  if (scMainFiber.finished())
373  fatal("Pausing systemc after sc_main completed.");
374  else
375  exitSimLoopNow("systemc pause");
376  }
377 }
378 
379 void
381 {
383  kernel->stop();
384 
385  clear();
386 
387  runOnce = false;
388  if (scMainFiber.called()) {
389  if (!scMainFiber.finished())
390  scMainFiber.run();
391  } else {
392  if (scMainFiber.finished())
393  fatal("Stopping systemc after sc_main completed.");
394  else
395  exitSimLoopNow("systemc stop");
396  }
397 }
398 
399 void
400 Scheduler::start(Tick max_tick, bool run_to_time)
401 {
402  _started = true;
404  runToTime = run_to_time;
405 
406  maxTick = max_tick;
408 
409  if (initDone) {
410  if (!runToTime && starved())
413  }
414 
417 
418  // Return to gem5 to let it run events, etc.
420 
421  if (pauseEvent.scheduled())
423  if (stopEvent.scheduled())
425  if (maxTickEvent.scheduled())
427  if (starvationEvent.scheduled())
429 
430  if (_throwUp) {
431  const ::sc_core::sc_report *to_throw = _throwUp;
432  _throwUp = nullptr;
433  throw *to_throw;
434  }
435 }
436 
437 void
439 {
440  runOnce = true;
442  start(::MaxTick, false);
443 }
444 
445 void
447 {
448  if (pauseEvent.scheduled())
449  return;
450 
452 }
453 
454 void
456 {
457  if (scMainFiber.called() && !scMainFiber.finished()) {
459  _throwUp = &report;
461  scMainFiber.run();
462  } else {
465  }
466 }
467 
468 void
469 Scheduler::scheduleStop(bool finish_delta)
470 {
471  if (stopEvent.scheduled())
472  return;
473 
474  if (!finish_delta) {
475  _stopNow = true;
476  // If we're not supposed to finish the delta cycle, flush all
477  // pending activity.
478  clear();
479  }
481 }
482 
483 void
484 Scheduler::trace(bool delta)
485 {
486  for (auto tf: traceFiles)
487  tf->trace(delta);
488 }
489 
492 
493 namespace {
494 
495 void
496 throwingReportHandler(const ::sc_core::sc_report &r,
498 {
499  throw r;
500 }
501 
502 } // anonymous namespace
503 
504 const ::sc_core::sc_report
506 {
508  ::sc_core::sc_report_handler::set_handler(&throwingReportHandler);
509 
510  try {
511  try {
512  // Rethrow the current exception so we can catch it and throw an
513  // sc_report instead if it's not a type we recognize/can handle.
514  throw;
515  } catch (const ::sc_core::sc_report &) {
516  // It's already a sc_report, so nothing to do.
517  throw;
518  } catch (const ::sc_core::sc_unwind_exception &) {
519  panic("Kill/reset exception escaped a Process::run()");
520  } catch (const std::exception &e) {
523  } catch (const char *msg) {
526  } catch (...) {
529  "UNKNOWN EXCEPTION");
530  }
531  } catch (const ::sc_core::sc_report &r) {
533  return r;
534  }
535  panic("No exception thrown in reportifyException.");
536 }
537 
538 } // namespace sc_gem5
sc_gem5::Scheduler::reg
void reg(Process *p)
Definition: scheduler.cc:146
fatal
#define fatal(...)
This implements a cprintf based fatal() function.
Definition: logging.hh:183
sc_gem5::Process::scheduled
bool scheduled() const
Definition: process.hh:73
sc_gem5::Scheduler::readyEvent
EventWrapper< Scheduler, &Scheduler::runReady > readyEvent
Definition: scheduler.hh:467
sc_gem5::reportifyException
const ::sc_core::sc_report reportifyException()
Definition: scheduler.cc:505
kernel.hh
sc_gem5::Scheduler::StatusStopped
@ StatusStopped
Definition: scheduler.hh:374
sc_core::sc_actions
unsigned sc_actions
Definition: sc_report_handler.hh:39
sc_gem5::Scheduler::resume
void resume(Process *p)
Definition: scheduler.cc:216
sc_gem5::Scheduler::initList
ProcessList initList
Definition: scheduler.hh:524
sc_gem5::Scheduler::scheduleTimeAdvancesEvent
void scheduleTimeAdvancesEvent()
Definition: scheduler.hh:509
sc_main_fiber.hh
sc_gem5::Scheduler::scheduleStop
void scheduleStop(bool finish_delta)
Definition: scheduler.cc:469
sc_gem5::Process::inReset
bool inReset()
Definition: process.hh:131
sc_gem5::Scheduler::deschedule
void deschedule(ScEvent *event)
Definition: scheduler.hh:281
sc_gem5::Kernel::stop
static void stop()
Definition: kernel.cc:140
sc_gem5::Process::resetEvent
::sc_core::sc_event & resetEvent()
Definition: process.hh:101
sc_gem5::Scheduler::_numCycles
uint64_t _numCycles
Definition: scheduler.hh:515
Fiber::finished
bool finished() const
Returns whether the "main" function of this fiber has finished.
Definition: fiber.hh:106
sc_gem5::ListNode
Definition: list.hh:42
sc_gem5::Scheduler::StatusPaused
@ StatusPaused
Definition: scheduler.hh:373
report.hh
sc_gem5::Scheduler::asyncRequestUpdate
void asyncRequestUpdate(Channel *c)
Definition: scheduler.cc:258
sc_gem5::Scheduler::updateList
ChannelList updateList
Definition: scheduler.hh:529
X86ISA::lock
Bitfield< 5 > lock
Definition: types.hh:78
sc_gem5::Scheduler::StatusDelta
@ StatusDelta
Definition: scheduler.hh:371
sc_gem5::Scheduler::Scheduler
Scheduler()
Definition: scheduler.cc:46
Tick
uint64_t Tick
Tick count type.
Definition: types.hh:59
sc_gem5::Scheduler::getCurTick
Tick getCurTick()
Definition: scheduler.hh:244
sc_dt::list
static scfx_rep_node * list
Definition: scfx_rep.cc:368
tracefile.hh
sc_gem5::kernel
Kernel * kernel
Definition: kernel.cc:181
sc_gem5::Scheduler::timeSlots
TimeSlots timeSlots
Definition: scheduler.hh:456
X86ISA::tf
Bitfield< 8 > tf
Definition: misc.hh:569
sc_gem5::Scheduler
Definition: scheduler.hh:148
sc_gem5::Scheduler::_throwUp
const ::sc_core::sc_report * _throwUp
Definition: scheduler.hh:475
sc_gem5::Process::reset
void reset(bool inc_kids)
Definition: process.cc:169
sc_gem5::Scheduler::deltas
ScEvents deltas
Definition: scheduler.hh:455
sc_gem5::Scheduler::asyncListMutex
std::mutex asyncListMutex
Definition: scheduler.hh:532
sim_exit.hh
sc_gem5::Scheduler::runOnce
bool runOnce
Definition: scheduler.hh:522
sc_gem5::ScMainFiber::called
bool called()
Definition: sc_main_fiber.hh:54
sc_gem5::Process::run
void run()
Definition: process.cc:262
sc_gem5::Scheduler::maxTickEvent
EventWrapper< Scheduler, &Scheduler::maxTickFunc > maxTickEvent
Definition: scheduler.hh:504
sc_gem5::Scheduler::ready
void ready(Process *p)
Definition: scheduler.cc:199
sc_gem5::NodeList::pushLast
void pushLast(T *t)
Definition: list.hh:89
sc_gem5::Scheduler::scheduleReadyEvent
void scheduleReadyEvent()
Definition: scheduler.cc:266
ArmISA::n
Bitfield< 31 > n
Definition: miscregs_types.hh:450
Fiber::primaryFiber
static Fiber * primaryFiber()
Get a pointer to the primary Fiber.
Definition: fiber.cc:183
ArmISA::ts
Bitfield< 55, 52 > ts
Definition: miscregs_types.hh:89
sc_gem5::Process::excWrapper
ExceptionWrapperBase * excWrapper
Definition: process.hh:91
sc_gem5::Scheduler::pause
void pause()
Definition: scheduler.cc:363
sc_gem5::Scheduler::hasAsyncUpdate
std::atomic< bool > hasAsyncUpdate
Definition: scheduler.hh:533
sc_gem5::Scheduler::status
Status status()
Definition: scheduler.hh:394
sc_gem5::Scheduler::pauseEvent
EventWrapper< Scheduler, &Scheduler::pause > pauseEvent
Definition: scheduler.hh:472
SC_REPORT_ERROR
#define SC_REPORT_ERROR(msg_type, msg)
Definition: sc_report_handler.hh:127
sc_core::sc_report_handler::get_catch_actions
static sc_actions get_catch_actions()
Definition: sc_report_handler.cc:265
sc_gem5::reportHandlerProc
sc_core::sc_report_handler_proc reportHandlerProc
Definition: report.cc:68
sc_gem5::Scheduler::throwUp
void throwUp()
Definition: scheduler.cc:455
sc_gem5::Scheduler::lastReadyTick
Tick lastReadyTick
Definition: scheduler.hh:496
sc_gem5::ListNode::popListNode
void popListNode()
Definition: list.hh:51
sc_gem5::Scheduler::~Scheduler
~Scheduler()
Definition: scheduler.cc:59
sc_gem5::Scheduler::StatusEvaluate
@ StatusEvaluate
Definition: scheduler.hh:369
sc_main.hh
MipsISA::r
r
Definition: pra_constants.hh:95
sc_gem5::Scheduler::yield
void yield()
Definition: scheduler.cc:160
sc_gem5::Scheduler::_stopNow
bool _stopNow
Definition: scheduler.hh:491
sc_gem5::getCurrentProcess
Process * getCurrentProcess()
Definition: scheduler.cc:491
sc_core::SC_METHOD_PROC_
@ SC_METHOD_PROC_
Definition: sc_process_handle.hh:87
sc_gem5::NodeList::empty
bool empty()
Definition: list.hh:111
sc_gem5::Scheduler::runReady
void runReady()
Definition: scheduler.cc:287
sc_gem5::Scheduler::clear
void clear()
Definition: scheduler.cc:67
sc_gem5::Scheduler::initPhase
void initPhase()
Definition: scheduler.cc:109
messages.hh
sc_gem5::Scheduler::readyListMethods
ProcessList readyListMethods
Definition: scheduler.hh:526
sc_gem5::Scheduler::schedulePause
void schedulePause()
Definition: scheduler.cc:446
sc_gem5::Scheduler::suspend
bool suspend(Process *p)
Definition: scheduler.cc:235
sc_gem5::Channel::update
void update()
Definition: channel.hh:48
sc_gem5::Scheduler::initDone
bool initDone
Definition: scheduler.hh:520
Fiber::run
void run()
Start executing the fiber represented by this object.
Definition: fiber.cc:163
sc_gem5::Process
Definition: process.hh:62
sc_gem5::Scheduler::scheduleStarvationEvent
void scheduleStarvationEvent()
Definition: scheduler.cc:277
sc_gem5::Scheduler::stopEvent
EventWrapper< Scheduler, &Scheduler::stop > stopEvent
Definition: scheduler.hh:473
sc_gem5::Scheduler::_changeStamp
uint64_t _changeStamp
Definition: scheduler.hh:516
sc_core::sc_report
Definition: sc_report.hh:60
sc_core::sc_event::notify
void notify()
Definition: sc_event.cc:337
sc_gem5::scMainFiber
ScMainFiber scMainFiber
Definition: sc_main_fiber.cc:78
sc_gem5::Process::fiber
virtual Fiber * fiber()
Definition: process.hh:121
ArmISA::e
Bitfield< 9 > e
Definition: miscregs_types.hh:61
sc_gem5::Scheduler::starved
bool starved()
Definition: scheduler.hh:478
sc_gem5::Scheduler::eventsToSchedule
std::map<::Event *, Tick > eventsToSchedule
Definition: scheduler.hh:535
SC_REPORT_WARNING
#define SC_REPORT_WARNING(msg_type, msg)
Definition: sc_report_handler.hh:123
sc_gem5::NodeList::getNext
T * getNext()
Definition: list.hh:106
sc_gem5::Scheduler::stop
void stop()
Definition: scheduler.cc:380
EventQueue::schedule
void schedule(Event *event, Tick when, bool global=false)
Schedule the given event on this queue.
Definition: eventq.hh:761
sc_core::SC_ID_DISABLE_WILL_ORPHAN_PROCESS_
const char SC_ID_DISABLE_WILL_ORPHAN_PROCESS_[]
Definition: messages.cc:132
sc_report_handler.hh
sc_gem5::Scheduler::requestUpdate
void requestUpdate(Channel *c)
Definition: scheduler.cc:250
sc_gem5::Scheduler::current
Process * current()
Definition: scheduler.hh:186
sc_gem5::Scheduler::_current
Process * _current
Definition: scheduler.hh:518
sc_core::sc_report_handler_proc
void(* sc_report_handler_proc)(const sc_report &, const sc_actions &)
Definition: sc_report_handler.hh:62
PowerISA::eq
Bitfield< 29 > eq
Definition: miscregs.hh:48
sc_gem5::listContains
bool listContains(ListNode *list, ListNode *target)
Definition: scheduler.cc:225
sc_report.hh
sc_gem5::Scheduler::_started
bool _started
Definition: scheduler.hh:490
sc_gem5::Scheduler::oneCycle
void oneCycle()
Definition: scheduler.cc:438
exitSimLoopNow
void exitSimLoopNow(const std::string &message, int exit_code, Tick repeat, bool serialize)
Schedule an event as above, but make it high priority so it runs before any normal events which are s...
Definition: sim_events.cc:96
sc_gem5::Scheduler::StatusUpdate
@ StatusUpdate
Definition: scheduler.hh:370
sc_core::sc_report_handler::set_handler
static void set_handler(sc_report_handler_proc)
Definition: sc_report_handler.cc:272
sc_gem5::Scheduler::runDelta
void runDelta()
Definition: scheduler.cc:350
sc_gem5::ExceptionWrapperBase::throw_it
virtual void throw_it()=0
sc_gem5::Scheduler::timeAdvancesEvent
EventWrapper< Scheduler, &Scheduler::timeAdvances > timeAdvancesEvent
Definition: scheduler.hh:507
sc_gem5::Scheduler::inEvaluate
bool inEvaluate()
Definition: scheduler.hh:382
sc_gem5::Scheduler::start
void start(Tick max_tick, bool run_to_time)
Definition: scheduler.cc:400
logging.hh
sc_gem5::Scheduler::eq
EventQueue * eq
Definition: scheduler.hh:432
sc_gem5::Scheduler::trace
void trace(bool delta)
Definition: scheduler.cc:484
ArmISA::c
Bitfield< 29 > c
Definition: miscregs_types.hh:50
sc_gem5::Scheduler::schedule
void schedule(ScEvent *event, const ::sc_core::sc_time &delay)
Definition: scheduler.hh:254
sc_gem5
Definition: sc_clock.cc:42
sc_gem5::Scheduler::asyncUpdateList
ChannelList asyncUpdateList
Definition: scheduler.hh:531
sc_gem5::Scheduler::runUpdate
void runUpdate()
Definition: scheduler.cc:326
MipsISA::p
Bitfield< 0 > p
Definition: pra_constants.hh:323
sc_gem5::scheduler
Scheduler scheduler
Definition: scheduler.cc:490
sc_core::SC_ID_SIMULATION_UNCAUGHT_EXCEPTION_
const char SC_ID_SIMULATION_UNCAUGHT_EXCEPTION_[]
Definition: messages.cc:117
sc_gem5::Channel
Definition: channel.hh:39
sc_gem5::Kernel::status
static sc_core::sc_status status()
Definition: kernel.cc:54
sc_gem5::Scheduler::readyListThreads
ProcessList readyListThreads
Definition: scheduler.hh:527
sc_core::SC_RUNNING
@ SC_RUNNING
Definition: sc_main.hh:87
sc_gem5::Scheduler::starvationEvent
EventWrapper< Scheduler, &Scheduler::pause > starvationEvent
Definition: scheduler.hh:486
sc_gem5::Process::needsStart
bool needsStart() const
Definition: process.hh:66
sc_gem5::Scheduler::runToTime
bool runToTime
Definition: scheduler.hh:521
fiber.hh
sc_gem5::Scheduler::StatusOther
@ StatusOther
Definition: scheduler.hh:368
sc_gem5::Scheduler::traceFiles
std::set< TraceFile * > traceFiles
Definition: scheduler.hh:537
sc_core::SC_PAUSED
@ SC_PAUSED
Definition: sc_main.hh:88
MaxTick
const Tick MaxTick
Definition: types.hh:61
scheduler.hh
sc_gem5::Scheduler::getNextReady
Process * getNextReady()
Definition: scheduler.hh:460
sc_gem5::Scheduler::maxTick
Tick maxTick
Definition: scheduler.hh:495
panic
#define panic(...)
This implements a cprintf based panic() function.
Definition: logging.hh:171
eventq.hh

Generated on Tue Jun 22 2021 15:28:28 for gem5 by doxygen 1.8.17