40 #ifndef __MEM_QOS_POLICY_PF_HH__ 41 #define __MEM_QOS_POLICY_PF_HH__ 44 #include "params/QoSPropFairPolicy.hh" 61 using Params = QoSPropFairPolicyParams;
100 template <
typename Master>
101 void initMaster(
const Master master,
const double score);
104 updateScore(
const double old_score,
const uint64_t served_bytes)
const;
117 #endif // __MEM_QOS_POLICY_PF_HH__
void initMaster(const Master master, const double score)
PropFairPolicy(const Params *)
virtual uint8_t schedule(const MasterID m_id, const uint64_t pkt_size) override
Schedules a packet based on proportional fair configuration.
virtual ~PropFairPolicy()
Proportional Fair QoS Policy Providing a configurable fair scheduling policy based on utilization; ut...
double updateScore(const double old_score, const uint64_t served_bytes) const
std::vector< MasterHistory > history
const Params * params() const
void initMasterName(const std::string master, const double score)
Initialize the master's score by providing the master's name and initial score value.
const double weight
PF Policy weight.
void initMasterObj(const SimObject *master, const double score)
Initialize the master's score by providing the master's SimObject pointer and initial score value...
const SimObjectParams * _params
Cached copy of the object parameters.
Abstract superclass for simulation objects.