提交 bb3469ac 编写于 作者: P Peter Zijlstra 提交者: Ingo Molnar

sched: hierarchical load vs affine wakeups

With hierarchical grouping we can't just compare task weight to rq weight - we
need to scale the weight appropriately.
Signed-off-by: NPeter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Srivatsa Vaddagiri <vatsa@linux.vnet.ibm.com>
Cc: Mike Galbraith <efault@gmx.de>
Signed-off-by: NIngo Molnar <mingo@elte.hu>
上级 a8a51d5e
...@@ -1073,6 +1073,25 @@ static inline int wake_idle(int cpu, struct task_struct *p) ...@@ -1073,6 +1073,25 @@ static inline int wake_idle(int cpu, struct task_struct *p)
static const struct sched_class fair_sched_class; static const struct sched_class fair_sched_class;
#ifdef CONFIG_FAIR_GROUP_SCHED
static unsigned long task_h_load(struct task_struct *p)
{
unsigned long h_load = p->se.load.weight;
struct cfs_rq *cfs_rq = cfs_rq_of(&p->se);
update_h_load(task_cpu(p));
h_load = calc_delta_mine(h_load, cfs_rq->h_load, &cfs_rq->load);
return h_load;
}
#else
static unsigned long task_h_load(struct task_struct *p)
{
return p->se.load.weight;
}
#endif
static int static int
wake_affine(struct rq *rq, struct sched_domain *this_sd, struct rq *this_rq, wake_affine(struct rq *rq, struct sched_domain *this_sd, struct rq *this_rq,
struct task_struct *p, int prev_cpu, int this_cpu, int sync, struct task_struct *p, int prev_cpu, int this_cpu, int sync,
...@@ -1093,9 +1112,9 @@ wake_affine(struct rq *rq, struct sched_domain *this_sd, struct rq *this_rq, ...@@ -1093,9 +1112,9 @@ wake_affine(struct rq *rq, struct sched_domain *this_sd, struct rq *this_rq,
* of the current CPU: * of the current CPU:
*/ */
if (sync) if (sync)
tl -= current->se.load.weight; tl -= task_h_load(current);
balanced = 100*(tl + p->se.load.weight) <= imbalance*load; balanced = 100*(tl + task_h_load(p)) <= imbalance*load;
/* /*
* If the currently running task will sleep within * If the currently running task will sleep within
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册