john stultz wrote:
On Tue, 2005-09-13 at 11:05 -0400, Mark Hounschell wrote:
Tim Schmielau wrote:
On Tue, 13 Sep 2005, Mark Hounschell wrote:
Most if not all userland delay calls rely on HZ value in some way or
another. The minimum reliable delay you can get is one (kernel)HZ. A
program that needs an acurrate delay for a time shorter that one
(kernel)HZ may have an alternative if it knows that HZ is greater the
the requested delay.
Just assume that kernel HZ are USER_HZ and see anything else as an
additional bonus that you cannot rely on.
What does 'acurrate delay' mean, anyways?
Tim
But they are not the same. Why can I get USER_HZ but not HZ?
Because USER_HZ is there only because HZ changes on various systems and
we don't want to break userland apps that assume its value.
On a 100HZ kernel ANY requested delay via udelay or
pthread_cond_timedwait of less than 10000usecs is unreliable and the the
actual results are totally unacceptable.
On a 1000HZ kernel the number is 1000 usecs.
I'm not asking the kernel running at 1000hz to actually give me 500 usec
delay if I ask. I do expect it to be at least 500 usec and within +- a
single HZ however. Oviously a 1000HZ machine is going to give me better
resulution in any requested delay. Why is it unreasonable for userland
to know the probable resolution of userland delay requests.
But you don't really want to know HZ, you want to know timer resolution.
That's a reasonable request and I believe the posix-timers
clock_getres() interface might provide what you need. Although I'd defer
to George (CC'ed) since he's more of an expert on those interfaces.
Exactly. clock_getres() on CLOCK_REALTIME will get the resolution of
timers (itimers or posix timers on CLOCK_REALTIME. You can also get the
res using the old itimer interface by programing a repeating time of 1
usec and then reading back the timer (get_timer ?). Set a longish
initial time so you can delete the timer prior to its expiring and look
at the repeat time returned. Do be aware that this will be rounded up,
however, and will likely show, e.g. 1000 usec for 999849 ns (as returned
by clock_getres()). Either of these interfaces is in the 2.6 kernel
these days.
You might also want to check out his HRT patches.
Thanks for the plug :)
--
George Anzinger [email protected]
HRT (High-res-timers): http://sourceforge.net/projects/high-res-timers/
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
|
|