gem5
v20.1.0.0
|
Common base class for Event and GlobalEvent, so they can share flag and priority definitions and accessor functions. More...
#include <eventq.hh>
Public Types | |
typedef int8_t | Priority |
Static Public Attributes | |
static const Priority | Minimum_Pri = SCHAR_MIN |
Event priorities, to provide tie-breakers for events scheduled at the same cycle. More... | |
static const Priority | Debug_Enable_Pri = -101 |
If we enable tracing on a particular cycle, do that as the very first thing so we don't miss any of the events on that cycle (even if we enter the debugger). More... | |
static const Priority | Debug_Break_Pri = -100 |
Breakpoints should happen before anything else (except enabling trace output), so we don't miss any action when debugging. More... | |
static const Priority | CPU_Switch_Pri = -31 |
CPU switches schedule the new CPU's tick event for the same cycle (after unscheduling the old CPU's tick event). More... | |
static const Priority | Delayed_Writeback_Pri = -1 |
For some reason "delayed" inter-cluster writebacks are scheduled before regular writebacks (which have default priority). More... | |
static const Priority | Default_Pri = 0 |
Default is zero for historical reasons. More... | |
static const Priority | DVFS_Update_Pri = 31 |
DVFS update event leads to stats dump therefore given a lower priority to ensure all relevant states have been updated. More... | |
static const Priority | Serialize_Pri = 32 |
Serailization needs to occur before tick events also, so that a serialize/unserialize is identical to an on-line CPU switch. More... | |
static const Priority | CPU_Tick_Pri = 50 |
CPU ticks must come after other associated CPU events (such as writebacks). More... | |
static const Priority | CPU_Exit_Pri = 64 |
If we want to exit a thread in a CPU, it comes after CPU_Tick_Pri. More... | |
static const Priority | Stat_Event_Pri = 90 |
Statistics events (dump, reset, etc.) come after everything else, but before exit. More... | |
static const Priority | Progress_Event_Pri = 95 |
Progress events come at the end. More... | |
static const Priority | Sim_Exit_Pri = 100 |
If we want to exit on this cycle, it's the very last thing we do. More... | |
static const Priority | Maximum_Pri = SCHAR_MAX |
Maximum priority. More... | |
Protected Types | |
typedef unsigned short | FlagsType |
typedef ::Flags< FlagsType > | Flags |
Static Protected Attributes | |
static const FlagsType | PublicRead = 0x003f |
static const FlagsType | PublicWrite = 0x001d |
static const FlagsType | Squashed = 0x0001 |
static const FlagsType | Scheduled = 0x0002 |
static const FlagsType | Managed = 0x0004 |
static const FlagsType | AutoDelete = Managed |
static const FlagsType | Reserved0 = 0x0008 |
This used to be AutoSerialize. More... | |
static const FlagsType | IsExitEvent = 0x0010 |
static const FlagsType | IsMainQueue = 0x0020 |
static const FlagsType | Initialized = 0x7a40 |
static const FlagsType | InitMask = 0xffc0 |
Common base class for Event and GlobalEvent, so they can share flag and priority definitions and accessor functions.
This class should not be used directly.
|
protected |
|
protected |
Definition at line 102 of file eventq.hh.
Referenced by HSAPacketProcessor::CmdQueueCmdDmaEvent::CmdQueueCmdDmaEvent(), EventFunctionWrapper::EventFunctionWrapper(), EventWrapper< QoS::MemSinkCtrl, &MemSinkCtrl::processNextReqEvent >::EventWrapper(), ComputeUnit::ScalarDataPort::MemReqEvent::MemReqEvent(), RegisterFile::RegisterEvent::RegisterEvent(), HSAPacketProcessor::UpdateReadDispIdDmaEvent::UpdateReadDispIdDmaEvent(), and BaseGlobalEvent::BarrierEvent::~BarrierEvent().
|
staticprotected |
Definition at line 111 of file eventq.hh.
Referenced by Event::initialized().
|
staticprotected |
Definition at line 112 of file eventq.hh.
Referenced by Event::initialized().
|
staticprotected |
Definition at line 109 of file eventq.hh.
Referenced by Event::isExitEvent().
|
staticprotected |
Definition at line 110 of file eventq.hh.
Referenced by EventQueue::serviceOne().
|
staticprotected |
Definition at line 101 of file eventq.hh.
Referenced by Event::acquire(), Event::isManaged(), Event::release(), and EventQueue::serviceOne().
|
staticprotected |
Definition at line 97 of file eventq.hh.
Referenced by Event::getFlags(), and Event::isFlagSet().
|
staticprotected |
Definition at line 98 of file eventq.hh.
Referenced by Event::clearFlags(), Event::Event(), and Event::setFlags().
|
staticprotected |
|
staticprotected |
Definition at line 100 of file eventq.hh.
Referenced by EventQueue::checkpointReschedule(), EventQueue::deschedule(), EventQueue::reschedule(), EventQueue::schedule(), Event::scheduled(), and EventQueue::serviceOne().
|
staticprotected |
Definition at line 99 of file eventq.hh.
Referenced by EventQueue::deschedule(), EventQueue::reschedule(), EventQueue::serviceOne(), Event::squash(), and Event::squashed().