Go to the documentation of this file.
   43 #include "params/QoSPropFairPolicy.hh" 
   59         "weight must be a value between 0 and 1");
 
   65 template <
typename Requestor>
 
   74     history.push_back(std::make_pair(
id, score));
 
   77         "Policy's maximum number of requestors is currently dictated " 
   78         "by the maximum number of priorities\n");
 
   95     const double old_score, 
const uint64_t served_bytes)
 const 
   97     return ((1.0 - 
weight) * old_score) + (
weight * served_bytes);
 
  105     { 
return lhs.second > rhs.second; };
 
  112     const double served_bytes = 
static_cast<double>(pkt_size);
 
  114     uint8_t pkt_priority = 0;
 
  115     for (
auto m_hist = 
history.begin(); m_hist != 
history.end(); m_hist++) {
 
  118         double& curr_score = m_hist->second;
 
  120         if (curr_id == pkt_id) {
 
  122             pkt_priority = std::distance(
history.begin(), m_hist);
 
  124             curr_score = 
updateScore(curr_score, served_bytes);
 
  
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 ~PropFairPolicy()
GEM5_DEPRECATED_NAMESPACE(QoS, qos)
const double weight
PF Policy weight.
double updateScore(const double old_score, const uint64_t served_bytes) const
virtual uint8_t schedule(const RequestorID id, const uint64_t pkt_size) override
Schedules a packet based on proportional fair configuration.
System * system() const
read the system pointer
Abstract superclass for simulation objects.
void initRequestor(const Requestor requestor, const double score)
void initRequestorName(const std::string requestor, const double score)
Initialize the requestor's score by providing the requestor's name and initial score value.
uint8_t numPriorities() const
Gets the total number of priority levels in the QoS memory controller.
PropFairPolicy(const Params &)
@ invldRequestorId
Invalid requestor id for assertion checking only.
void initRequestorObj(const SimObject *requestor, const double score)
Initialize the requestor's score by providing the requestor's SimObject pointer and initial score val...
std::vector< RequestorHistory > history
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Generated on Wed May 4 2022 12:14:01 for gem5 by  doxygen 1.8.17