gem5
v19.0.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 |
typedef int8_t EventBase::Priority |
Definition at line 104 of file eventq.hh.
Referenced by EventFunctionWrapper::EventFunctionWrapper(), EventWrapper< QoS::MemSinkCtrl, &MemSinkCtrl::processNextReqEvent >::EventWrapper(), DmaReadFifo::DmaDoneEvent::kill(), and BaseGlobalEvent::BarrierEvent::~BarrierEvent().
|
static |
If we want to exit a thread in a CPU, it comes after CPU_Tick_Pri.
Definition at line 165 of file eventq.hh.
Referenced by FullO3CPU< O3CPUImpl >::FullO3CPU().
|
static |
CPU switches schedule the new CPU's tick event for the same cycle (after unscheduling the old CPU's tick event).
The switch needs to come before any tick events to make sure we don't tick both CPUs in the same cycle.
Definition at line 141 of file eventq.hh.
Referenced by pybind_init_event().
|
static |
CPU ticks must come after other associated CPU events (such as writebacks).
Definition at line 162 of file eventq.hh.
Referenced by AtomicSimpleCPU::AtomicSimpleCPU(), BaseKvmCPU::BaseKvmCPU(), FullO3CPU< O3CPUImpl >::FullO3CPU(), GarnetSyntheticTraffic::GarnetSyntheticTraffic(), DefaultCommit< Impl >::generateTrapEvent(), GpuDispatcher::GpuDispatcher(), pybind_init_event(), RubyDirectedTester::RubyDirectedTester(), RubyTester::RubyTester(), MipsISA::ISA::scheduleCP0Update(), Shader::Shader(), and TLBCoalescer::TLBCoalescer().
|
static |
Breakpoints should happen before anything else (except enabling trace output), so we don't miss any action when debugging.
Definition at line 135 of file eventq.hh.
Referenced by pybind_init_event().
|
static |
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).
Definition at line 130 of file eventq.hh.
Referenced by pybind_init_event().
|
static |
Default is zero for historical reasons.
Definition at line 149 of file eventq.hh.
Referenced by pybind_init_event().
|
static |
For some reason "delayed" inter-cluster writebacks are scheduled before regular writebacks (which have default priority).
Steve?
Definition at line 146 of file eventq.hh.
Referenced by BaseCache::BaseCache(), and pybind_init_event().
|
static |
DVFS update event leads to stats dump therefore given a lower priority to ensure all relevant states have been updated.
Definition at line 153 of file eventq.hh.
Referenced by pybind_init_event().
|
staticprotected |
Definition at line 113 of file eventq.hh.
Referenced by Event::initialized().
|
staticprotected |
Definition at line 114 of file eventq.hh.
Referenced by Event::initialized().
|
staticprotected |
Definition at line 111 of file eventq.hh.
Referenced by Event::isExitEvent().
|
staticprotected |
Definition at line 112 of file eventq.hh.
Referenced by EventQueue::serviceOne().
|
staticprotected |
Definition at line 103 of file eventq.hh.
Referenced by Event::acquire(), Event::isManaged(), Event::release(), and EventQueue::serviceOne().
|
static |
Maximum priority.
Definition at line 179 of file eventq.hh.
Referenced by X86ISA::GpuTLB::GpuTLB(), pybind_init_event(), and TLBCoalescer::TLBCoalescer().
|
static |
Event priorities, to provide tie-breakers for events scheduled at the same cycle.
Most events are scheduled at the default priority; these values are used to control events that need to be ordered within a cycle. Minimum priority
Definition at line 125 of file eventq.hh.
Referenced by pybind_init_event().
|
static |
Progress events come at the end.
Definition at line 172 of file eventq.hh.
Referenced by GPUCoalescer::GPUCoalescer(), pybind_init_event(), and simulate().
|
staticprotected |
Definition at line 99 of file eventq.hh.
Referenced by Event::getFlags(), and Event::isFlagSet().
|
staticprotected |
Definition at line 100 of file eventq.hh.
Referenced by Event::clearFlags(), Event::Event(), and Event::setFlags().
|
staticprotected |
|
staticprotected |
Definition at line 102 of file eventq.hh.
Referenced by EventQueue::checkpointReschedule(), EventQueue::deschedule(), EventQueue::reschedule(), EventQueue::schedule(), Event::scheduled(), and EventQueue::serviceOne().
|
static |
Serailization needs to occur before tick events also, so that a serialize/unserialize is identical to an on-line CPU switch.
Definition at line 158 of file eventq.hh.
Referenced by pybind_init_event().
|
static |
If we want to exit on this cycle, it's the very last thing we do.
Definition at line 176 of file eventq.hh.
Referenced by pybind_init_event().
|
staticprotected |
Definition at line 101 of file eventq.hh.
Referenced by EventQueue::deschedule(), EventQueue::reschedule(), EventQueue::serviceOne(), Event::squash(), and Event::squashed().
|
static |
Statistics events (dump, reset, etc.) come after everything else, but before exit.
Definition at line 169 of file eventq.hh.
Referenced by pybind_init_event().