diff options
| -rw-r--r-- | kernel/sched/fair.c | 11 | ||||
| -rw-r--r-- | kernel/sched/sched.h | 6 |
2 files changed, 14 insertions, 3 deletions
diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c index d0cc03b3e70b..c219bf8d704c 100644 --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c | |||
| @@ -3387,6 +3387,14 @@ static int tg_load_down(struct task_group *tg, void *data) | |||
| 3387 | 3387 | ||
| 3388 | static void update_h_load(long cpu) | 3388 | static void update_h_load(long cpu) |
| 3389 | { | 3389 | { |
| 3390 | struct rq *rq = cpu_rq(cpu); | ||
| 3391 | unsigned long now = jiffies; | ||
| 3392 | |||
| 3393 | if (rq->h_load_throttle == now) | ||
| 3394 | return; | ||
| 3395 | |||
| 3396 | rq->h_load_throttle = now; | ||
| 3397 | |||
| 3390 | rcu_read_lock(); | 3398 | rcu_read_lock(); |
| 3391 | walk_tg_tree(tg_load_down, tg_nop, (void *)cpu); | 3399 | walk_tg_tree(tg_load_down, tg_nop, (void *)cpu); |
| 3392 | rcu_read_unlock(); | 3400 | rcu_read_unlock(); |
| @@ -4293,11 +4301,10 @@ redo: | |||
| 4293 | env.src_rq = busiest; | 4301 | env.src_rq = busiest; |
| 4294 | env.loop_max = min(sysctl_sched_nr_migrate, busiest->nr_running); | 4302 | env.loop_max = min(sysctl_sched_nr_migrate, busiest->nr_running); |
| 4295 | 4303 | ||
| 4304 | update_h_load(env.src_cpu); | ||
| 4296 | more_balance: | 4305 | more_balance: |
| 4297 | local_irq_save(flags); | 4306 | local_irq_save(flags); |
| 4298 | double_rq_lock(this_rq, busiest); | 4307 | double_rq_lock(this_rq, busiest); |
| 4299 | if (!env.loop) | ||
| 4300 | update_h_load(env.src_cpu); | ||
| 4301 | 4308 | ||
| 4302 | /* | 4309 | /* |
| 4303 | * cur_ld_moved - load moved in current iteration | 4310 | * cur_ld_moved - load moved in current iteration |
diff --git a/kernel/sched/sched.h b/kernel/sched/sched.h index c35a1a7dd4d6..531411b1044e 100644 --- a/kernel/sched/sched.h +++ b/kernel/sched/sched.h | |||
| @@ -374,7 +374,11 @@ struct rq { | |||
| 374 | #ifdef CONFIG_FAIR_GROUP_SCHED | 374 | #ifdef CONFIG_FAIR_GROUP_SCHED |
| 375 | /* list of leaf cfs_rq on this cpu: */ | 375 | /* list of leaf cfs_rq on this cpu: */ |
| 376 | struct list_head leaf_cfs_rq_list; | 376 | struct list_head leaf_cfs_rq_list; |
| 377 | #endif | 377 | #ifdef CONFIG_SMP |
| 378 | unsigned long h_load_throttle; | ||
| 379 | #endif /* CONFIG_SMP */ | ||
| 380 | #endif /* CONFIG_FAIR_GROUP_SCHED */ | ||
| 381 | |||
| 378 | #ifdef CONFIG_RT_GROUP_SCHED | 382 | #ifdef CONFIG_RT_GROUP_SCHED |
| 379 | struct list_head leaf_rt_rq_list; | 383 | struct list_head leaf_rt_rq_list; |
| 380 | #endif | 384 | #endif |
