From: tip-bot for Peter Zijlstra <tipbot@zytor.com> To: linux-tip-commits@vger.kernel.org Cc: linux-kernel@vger.kernel.org, hpa@zytor.com, mingo@kernel.org, peterz@infradead.org, dsahern@gmail.com, tglx@linutronix.de Subject: [tip:sched/core] sched: Fix HRTICK Date: Fri, 12 Jul 2013 06:29:39 -0700 [thread overview] Message-ID: <tip-971ee28cbd1ccd87b3164facd9359a534c1d2892@git.kernel.org> (raw) In-Reply-To: <20130628091853.GE29209@dyad.programming.kicks-ass.net> Commit-ID: 971ee28cbd1ccd87b3164facd9359a534c1d2892 Gitweb: http://git.kernel.org/tip/971ee28cbd1ccd87b3164facd9359a534c1d2892 Author: Peter Zijlstra <peterz@infradead.org> AuthorDate: Fri, 28 Jun 2013 11:18:53 +0200 Committer: Ingo Molnar <mingo@kernel.org> CommitDate: Fri, 12 Jul 2013 13:52:58 +0200 sched: Fix HRTICK David reported that the HRTICK sched feature was borken; which was enough motivation for me to finally fix it ;-) We should not allow hrtimer code to do softirq wakeups while holding scheduler locks. The hrtimer code only needs this when we accidentally try to program an expired time. We don't much care about those anyway since we have the regular tick to fall back to. Reported-by: David Ahern <dsahern@gmail.com> Tested-by: David Ahern <dsahern@gmail.com> Signed-off-by: Peter Zijlstra <peterz@infradead.org> Link: http://lkml.kernel.org/r/20130628091853.GE29209@dyad.programming.kicks-ass.net Signed-off-by: Ingo Molnar <mingo@kernel.org> --- kernel/sched/core.c | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/kernel/sched/core.c b/kernel/sched/core.c index 9b1f2e5..0d8eb45 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -370,13 +370,6 @@ static struct rq *this_rq_lock(void) #ifdef CONFIG_SCHED_HRTICK /* * Use HR-timers to deliver accurate preemption points. - * - * Its all a bit involved since we cannot program an hrt while holding the - * rq->lock. So what we do is store a state in in rq->hrtick_* and ask for a - * reschedule event. - * - * When we get rescheduled we reprogram the hrtick_timer outside of the - * rq->lock. */ static void hrtick_clear(struct rq *rq) @@ -404,6 +397,15 @@ static enum hrtimer_restart hrtick(struct hrtimer *timer) } #ifdef CONFIG_SMP + +static int __hrtick_restart(struct rq *rq) +{ + struct hrtimer *timer = &rq->hrtick_timer; + ktime_t time = hrtimer_get_softexpires(timer); + + return __hrtimer_start_range_ns(timer, time, 0, HRTIMER_MODE_ABS_PINNED, 0); +} + /* * called from hardirq (IPI) context */ @@ -412,7 +414,7 @@ static void __hrtick_start(void *arg) struct rq *rq = arg; raw_spin_lock(&rq->lock); - hrtimer_restart(&rq->hrtick_timer); + __hrtick_restart(rq); rq->hrtick_csd_pending = 0; raw_spin_unlock(&rq->lock); } @@ -430,7 +432,7 @@ void hrtick_start(struct rq *rq, u64 delay) hrtimer_set_expires(timer, time); if (rq == this_rq()) { - hrtimer_restart(timer); + __hrtick_restart(rq); } else if (!rq->hrtick_csd_pending) { __smp_call_function_single(cpu_of(rq), &rq->hrtick_csd, 0); rq->hrtick_csd_pending = 1;
next prev parent reply other threads:[~2013-07-12 13:30 UTC|newest] Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top 2013-06-25 21:05 deadlock in scheduler enabling HRTICK feature David Ahern 2013-06-25 21:17 ` Peter Zijlstra 2013-06-25 21:20 ` David Ahern 2013-06-26 7:05 ` Peter Zijlstra 2013-06-26 16:46 ` David Ahern 2013-06-27 10:43 ` Peter Zijlstra 2013-06-27 10:53 ` Peter Zijlstra 2013-06-27 12:28 ` Mike Galbraith 2013-06-27 13:06 ` Ingo Molnar 2013-06-27 19:18 ` Andy Lutomirski 2013-06-27 20:37 ` Peter Zijlstra 2013-06-27 22:28 ` David Ahern 2013-06-28 9:00 ` Ingo Molnar 2013-06-28 9:18 ` Peter Zijlstra 2013-07-12 13:29 ` tip-bot for Peter Zijlstra [this message] 2013-06-28 9:09 ` Peter Zijlstra 2013-06-28 17:28 ` David Ahern
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=tip-971ee28cbd1ccd87b3164facd9359a534c1d2892@git.kernel.org \ --to=tipbot@zytor.com \ --cc=dsahern@gmail.com \ --cc=hpa@zytor.com \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-tip-commits@vger.kernel.org \ --cc=mingo@kernel.org \ --cc=peterz@infradead.org \ --cc=tglx@linutronix.de \ --subject='Re: [tip:sched/core] sched: Fix HRTICK' \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.