Go to the documentation of this file.
38 #ifndef __MEM_QOS_POLICY_HH__
39 #define __MEM_QOS_POLICY_HH__
47 #include "debug/QOS.hh"
55 struct QoSPolicyParams;
81 virtual void init()
override {};
100 template <
typename Requestor,
typename T>
111 const uint64_t
data) = 0;
127 template <
typename Requestor,
typename T>
134 "Unable to find requestor %s\n", requestor);
137 "Requestor %s [id %d] associated with QoS data %d\n",
138 requestor,
id, value);
MemCtrl * memCtrl
Pointer to parent memory controller implementing the policy.
RequestorID lookupRequestorId(const SimObject *obj) const
Looks up the RequestorID for a given SimObject returns an invalid RequestorID (invldRequestorId) if n...
virtual void regStats() override
Callback to set stat parameters.
std::pair< RequestorID, T > pair(Requestor requestor, T value)
Builds a RequestorID/value pair given a requestor input.
GEM5_DEPRECATED_NAMESPACE(QoS, qos)
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
System * system() const
read the system pointer
void setMemCtrl(MemCtrl *mem)
Setting a pointer to the Memory Controller implementing the policy.
virtual void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
Abstract superclass for simulation objects.
#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...
virtual uint8_t schedule(const RequestorID requestor_id, const uint64_t data)=0
Schedules data - must be defined by derived class.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
@ invldRequestorId
Invalid requestor id for assertion checking only.
Generated on Wed Jul 28 2021 12:10:28 for gem5 by doxygen 1.8.17