Go to the documentation of this file.
   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),
 
   53     maxTickEvent(this, false, MaxTickPriority),
 
   54     timeAdvancesEvent(this, false, TimeAdvancesPriority), _numCycles(0),
 
   55     _changeStamp(0), _current(nullptr), initDone(false), runToTime(true),
 
   71         deltas.front()->deschedule();
 
   75         while (!
ts->events.empty())
 
   76             ts->events.front()->deschedule();
 
  116         if (
p->dontInitialize()) {
 
  117             if (!
p->hasStaticSensitivities() && !
p->internal()) {
 
  150         if (!
p->dontInitialize())
 
  240         was_ready = (
p->nextListNode != 
nullptr);
 
  365     using namespace gem5;
 
  375             fatal(
"Pausing systemc after sc_main completed.");
 
  384     using namespace gem5;
 
  397             fatal(
"Stopping systemc after sc_main completed.");
 
  435         const ::sc_core::sc_report *to_throw = 
_throwUp;
 
  500 throwingReportHandler(const ::sc_core::sc_report &
r,
 
  508 const ::sc_core::sc_report
 
  519         } 
catch (const ::sc_core::sc_report &) {
 
  522         } 
catch (const ::sc_core::sc_unwind_exception &) {
 
  523             panic(
"Kill/reset exception escaped a Process::run()");
 
  524         } 
catch (
const std::exception &
e) {
 
  527         } 
catch (
const char *msg) {
 
  533                     "UNKNOWN EXCEPTION");
 
  535     } 
catch (const ::sc_core::sc_report &
r) {
 
  539     panic(
"No exception thrown in reportifyException.");
 
  
#define fatal(...)
This implements a cprintf based fatal() function.
const ::sc_core::sc_report reportifyException()
void run()
Start executing the fiber represented by this object.
void scheduleTimeAdvancesEvent()
void deschedule(ScEvent *event)
::sc_core::sc_event & resetEvent()
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...
gem5::EventWrapper< Scheduler, &Scheduler::runReady > readyEvent
static scfx_rep_node * list
const ::sc_core::sc_report * _throwUp
gem5::EventWrapper< Scheduler, &Scheduler::stop > stopEvent
std::mutex asyncListMutex
static Fiber * primaryFiber()
Get a pointer to the primary Fiber.
void reset(bool inc_kids)
ExceptionWrapperBase * excWrapper
std::atomic< bool > hasAsyncUpdate
#define SC_REPORT_ERROR(msg_type, msg)
static sc_actions get_catch_actions()
sc_core::sc_report_handler_proc reportHandlerProc
gem5::EventWrapper< Scheduler, &Scheduler::pause > pauseEvent
std::map< gem5::Event *, gem5::Tick > eventsToSchedule
uint64_t Tick
Tick count type.
void requestUpdate(Channel *c)
Process * getCurrentProcess()
void asyncRequestUpdate(Channel *c)
void scheduleStarvationEvent()
gem5::EventWrapper< Scheduler, &Scheduler::timeAdvances > timeAdvancesEvent
ProcessList readyListMethods
void scheduleReadyEvent()
#define SC_REPORT_WARNING(msg_type, msg)
const char SC_ID_DISABLE_WILL_ORPHAN_PROCESS_[]
void(* sc_report_handler_proc)(const sc_report &, const sc_actions &)
bool finished() const
Returns whether the "main" function of this fiber has finished.
bool listContains(ListNode *list, ListNode *target)
static void set_handler(sc_report_handler_proc)
virtual void throw_it()=0
void scheduleStop(bool finish_delta)
void schedule(Event *event, Tick when, bool global=false)
Schedule the given event on this queue.
gem5::EventWrapper< Scheduler, &Scheduler::maxTickFunc > maxTickEvent
void schedule(ScEvent *event, const ::sc_core::sc_time &delay)
ChannelList asyncUpdateList
const char SC_ID_SIMULATION_UNCAUGHT_EXCEPTION_[]
static sc_core::sc_status status()
ProcessList readyListThreads
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
gem5::EventWrapper< Scheduler, &Scheduler::pause > starvationEvent
void start(gem5::Tick max_tick, bool run_to_time)
std::set< TraceFile * > traceFiles
virtual gem5::Fiber * fiber()
#define panic(...)
This implements a cprintf based panic() function.
Generated on Thu Jul 28 2022 13:32:33 for gem5 by  doxygen 1.8.17