提交 ee24b1c2 编写于 作者: B bsegall@google.com 提交者: Joseph Qi

sched/fair: Don't push cfs_bandwith slack timers forward

commit 66567fcbaecac455caa1b13643155d686b51ce63 upstream.

When a cfs_rq sleeps and returns its quota, we delay for 5ms before
waking any throttled cfs_rqs to coalesce with other cfs_rqs going to
sleep, as this has to be done outside of the rq lock we hold.

The current code waits for 5ms without any sleeps, instead of waiting
for 5ms from the first sleep, which can delay the unthrottle more than
we want. Switch this around so that we can't push this forward forever.

This requires an extra flag rather than using hrtimer_active, since we
need to start a new timer if the current one is in the process of
finishing.
Signed-off-by: NBen Segall <bsegall@google.com>
Signed-off-by: NPeter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: NXunlei Pang <xlpang@linux.alibaba.com>
Acked-by: NPhil Auld <pauld@redhat.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Link: https://lkml.kernel.org/r/xm26a7euy6iq.fsf_-_@bsegall-linux.svl.corp.google.comSigned-off-by: NIngo Molnar <mingo@kernel.org>
Signed-off-by: NShanpei Chen <shanpeic@linux.alibaba.com>
Acked-by: NMichael Wang <yun.wang@linux.alibaba.com>
上级 da57ae3d
...@@ -4699,6 +4699,11 @@ static void start_cfs_slack_bandwidth(struct cfs_bandwidth *cfs_b) ...@@ -4699,6 +4699,11 @@ static void start_cfs_slack_bandwidth(struct cfs_bandwidth *cfs_b)
if (runtime_refresh_within(cfs_b, min_left)) if (runtime_refresh_within(cfs_b, min_left))
return; return;
/* don't push forwards an existing deferred unthrottle */
if (cfs_b->slack_started)
return;
cfs_b->slack_started = true;
hrtimer_start(&cfs_b->slack_timer, hrtimer_start(&cfs_b->slack_timer,
ns_to_ktime(cfs_bandwidth_slack_period), ns_to_ktime(cfs_bandwidth_slack_period),
HRTIMER_MODE_REL); HRTIMER_MODE_REL);
...@@ -4749,6 +4754,7 @@ static void do_sched_cfs_slack_timer(struct cfs_bandwidth *cfs_b) ...@@ -4749,6 +4754,7 @@ static void do_sched_cfs_slack_timer(struct cfs_bandwidth *cfs_b)
/* confirm we're still not at a refresh boundary */ /* confirm we're still not at a refresh boundary */
raw_spin_lock(&cfs_b->lock); raw_spin_lock(&cfs_b->lock);
cfs_b->slack_started = false;
if (cfs_b->distribute_running) { if (cfs_b->distribute_running) {
raw_spin_unlock(&cfs_b->lock); raw_spin_unlock(&cfs_b->lock);
return; return;
...@@ -4917,6 +4923,7 @@ void init_cfs_bandwidth(struct cfs_bandwidth *cfs_b) ...@@ -4917,6 +4923,7 @@ void init_cfs_bandwidth(struct cfs_bandwidth *cfs_b)
hrtimer_init(&cfs_b->slack_timer, CLOCK_MONOTONIC, HRTIMER_MODE_REL); hrtimer_init(&cfs_b->slack_timer, CLOCK_MONOTONIC, HRTIMER_MODE_REL);
cfs_b->slack_timer.function = sched_cfs_slack_timer; cfs_b->slack_timer.function = sched_cfs_slack_timer;
cfs_b->distribute_running = 0; cfs_b->distribute_running = 0;
cfs_b->slack_started = false;
} }
static void init_cfs_rq_runtime(struct cfs_rq *cfs_rq) static void init_cfs_rq_runtime(struct cfs_rq *cfs_rq)
......
...@@ -337,8 +337,10 @@ struct cfs_bandwidth { ...@@ -337,8 +337,10 @@ struct cfs_bandwidth {
u64 runtime; u64 runtime;
s64 hierarchical_quota; s64 hierarchical_quota;
short idle; u8 idle;
short period_active; u8 period_active;
u8 distribute_running;
u8 slack_started;
struct hrtimer period_timer; struct hrtimer period_timer;
struct hrtimer slack_timer; struct hrtimer slack_timer;
struct list_head throttled_cfs_rq; struct list_head throttled_cfs_rq;
...@@ -347,8 +349,6 @@ struct cfs_bandwidth { ...@@ -347,8 +349,6 @@ struct cfs_bandwidth {
int nr_periods; int nr_periods;
int nr_throttled; int nr_throttled;
u64 throttled_time; u64 throttled_time;
bool distribute_running;
#endif #endif
}; };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册