40 #ifndef __MEM_QOS_POLICY_HH__ 41 #define __MEM_QOS_POLICY_HH__ 44 #include "debug/QOS.hh" 68 virtual void init()
override {};
87 template <
typename M,
typename T>
113 template <
typename M,
typename T>
120 "Unable to find master %s\n", master);
123 "Master %s [id %d] associated with QoS data %d\n",
virtual void regStats() override
Callback to set stat parameters.
virtual uint8_t schedule(const MasterID mId, const uint64_t data)=0
Schedules data - must be defined by derived class.
MemCtrl * memCtrl
Pointer to parent memory controller implementing the policy.
std::pair< MasterID, T > pair(M master, T value)
Builds a MasterID/value pair given a master input.
virtual void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
void setMemCtrl(MemCtrl *mem)
Setting a pointer to the Memory Controller implementing the policy.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
MasterID lookupMasterId(const SimObject *obj) const
Looks up the MasterID for a given SimObject returns an invalid MasterID (invldMasterId) if not found...
System * system() const
read the system pointer Implemented for completeness with the setter
Declaration of the Packet class.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
The QoS::MemCtrl is a base class for Memory objects which support QoS - it provides access to a set o...
Abstract superclass for simulation objects.
Invalid master id for assertion checking only.