[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <1240358525.6080.40.camel@localhost>
Date: Tue, 21 Apr 2009 17:02:05 -0700
From: john stultz <johnstul@...ibm.com>
To: Jon Hunter <jon-hunter@...com>
Cc: Ingo Molnar <mingo@...e.hu>, Thomas Gleixner <tglx@...utronix.de>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>
Subject: Re: [RFC][PATCH] Dynamic Tick: Allow 32-bit machines to sleep for
more than 2.15 seconds
On Tue, 2009-04-21 at 18:20 -0500, Jon Hunter wrote:
> john stultz wrote:
> > The concern is many clocksources wrap after a handful of seconds. The
> > acpi_pm is the best example (its only 24 bits wide).
> >
> > I brought this issue up earlier, and provided some example code that
> > could be used to limit the idle time appropriately for the current
> > clocksource here:
> >
> > http://lkml.indiana.edu/hypermail/linux/kernel/0901.3/02693.html
> >
> > Jon: Did you see that mail, or is there a reason you didn't adapt this
> > code into your patch?
>
> Hi John, yes I did read this email and thanks for bringing this up.
>
> As I looked at this more I noticed that for 64-bit machines that the
> max_delta_ns would be a 64-bit integer already and so this change would
> only have an impact for 32-bit machines. I understand that there are
> more 32-bit machines that 64-bit. However, I was trying to understand
> how the wrapping of clocksources, such as the one you mention above, is
> handled today for 64-bit machines that could theoretically sleep for
> longer periods.
As the actual max_delta_ns currently comes from the clockevent driver,
that is our current limitation. For instance, on a box I'm using, the
lapic's max_delta_ns is a little more then 600ms. The HPET's does allow
for ~149sec timers, which would break with acpi_pm, but I suspect boxes
using the HPET for tick interrupts are currently using HPET for the
clocksource as well, which keeps it safe.
So I suspect its mostly luck that system configs don't hit the issue
that's saved us so far on 64bit boxes.
So yes, while your patch in of itself doesn't create the issue, it does
open the window a bit more. I'm just saying we need to add the
clocksource limiting factor in before more odd configs trip over it. :)
> In addition to this as I was reviewing the "tick_nohz_stop_sched_tick()"
> function that is configuring the dynamic tick and I noticed that this
> code would actually stop the timer altogether if the time for the next
> timer event is greater than NEXT_TIMER_MAX_DELTA jiffies. See code
> snippet below. This is very unlikely, however, if this scenario was to
> occur what would be the impact on the clocksource?
>
> /*
> * delta_jiffies >= NEXT_TIMER_MAX_DELTA signals that
> * there is no timer pending or at least extremly far
>
> * into the future (12 days for HZ=1000). In this case
> * we simply stop the tick timer:
> */
> if (unlikely(delta_jiffies >= NEXT_TIMER_MAX_DELTA)) {
> ts->idle_expires.tv64 = KTIME_MAX;
> if (ts->nohz_mode == NOHZ_MODE_HIGHRES)
> hrtimer_cancel(&ts->sched_timer);
> goto out;
> }
Fair point. Thomas? Why do we kill the timer in the above case? Can that
catch us on an UP box? If so what would ever wake us up if there were no
other system interrupts?
thanks
-john
--
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