[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.LFD.2.02.1202152114510.2794@ionos>
Date: Wed, 15 Feb 2012 21:22:01 +0100 (CET)
From: Thomas Gleixner <tglx@...utronix.de>
To: Matthew Garrett <mjg59@...f.ucam.org>
cc: Peter Zijlstra <peterz@...radead.org>,
LKML <linux-kernel@...r.kernel.org>,
Arjan van de Ven <arjan@...radead.org>
Subject: Re: [PATCH] hrtimers: Special-case zero length sleeps
On Wed, 15 Feb 2012, Matthew Garrett wrote:
> Regardless of whether userspace should be concerning itself about this
> kind of thing or not, there's plenty of userspace that calls sleep(0) on
> the assumption that it'll get rescheduled. This makes using whole-system
Right. And it got always rescheduled because the old pre hrtimer
implementation put it to sleep unconditionally. The hrtimer code
before we introduced the slack stuff returned right away when the
relative delta was 0. Slack changed that back to the pre hrtimer
behaviour. Also if you disable high res timers (compile or runtime)
you go to sleep unconditionally until the next jiffies boundary.
> timer slack difficult, because there are some applications that do this
> even if they're event-driven and sleeping for significant lengths of
> time here breaks them. I'd certainly understand the argument for fixing
What is significant? If the app relies on sleep(0) returning
instantly, then it's going to malfunction on a highres=n kernel with
HZ=100 as well. Also when there are actually other runnable tasks and
it gets scheduled away, then there is no guarantee that it comes back
to the cpu within a defined boundary.
> userspace instead, but that's a massive task for something that's easily
> special-cased in the kernel.
So what's the correct special case solution? Return right away, call
schedule() with state RUNNING or some other magic crap?
Again, if a SCHED_OTHER task cannot cope with the fact that it gets
scheduled away for unbound amount of time, then changing the behaviour
of sleep(0) to some magic yield() variant does not help at all. It's
still broken and no special case in the kernel can fix that.
Thanks,
tglx
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists