public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Mark Hounschell <markh@compro.net>
To: unlisted-recipients:; (no To-header on input)
Cc: linux-kernel@vger.kernel.org
Subject: Re: HZ question
Date: Tue, 13 Sep 2005 10:00:42 -0400	[thread overview]
Message-ID: <4326DB8A.7040109@compro.net> (raw)
In-Reply-To: <Pine.LNX.4.61.0509130919390.29445@chaos.analogic.com>

linux-os (Dick Johnson) wrote:
> On Tue, 13 Sep 2005, Mark Hounschell wrote:
> 
>>I need to know the kernels value of HZ in a userland app.
>>
>>getconf CLK_TCK
>>     and
>>hz = sysconf (_SC_CLK_TCK)
>>
>>both seem to return CLOCKS_PER_SEC which is defined as USER_HZ which is
>>defined as 100.
>>
>>include/asm/param.h:
>>
>>#ifdef __KERNEL__
>># define HZ       1000   /* Internal kernel timer frequency */
>># define USER_HZ  100    /* .. some user interfaces are in "ticks" */
>># define CLOCKS_PER_SEC  (USER_HZ)       /* like times() */
>>#endif
>>
>>Thanks in advance for any help
>>Mark
> 
> You are not supposed to 'tear apart' user-mode headers. In particular
> you are not supposed to use anything in /usr/include/bits, /usr/include/asm,
> or /usr/include/linux in user-mode programs. These are not POSIX headers.
>

This was a kernel header used for reference. I'm not including them.


> If a user-mode program needs to know HZ, it is very, very, broken.
> HZ is some kernel timeout tick which doesn't relate to anything
> a user program needs to know.
> 

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. So to say my program is broken because it wants to 
know the limitations of my OS/kernel is kind of far fetched.


> This is a problem and is why we should have a kernel system-call
> that returns the HZ value. I asked about this several years ago
> and its inclusion was flatly refused because of what I quoted
> above. Perhaps now that HZ are dynamic, it would be posasible to
> add that system call.
> 

I'll second that. I thought sysconf(_SC_CLK_TCK) was supposed to be that 
call.

> Note, that on this particular kernel, at this phase of the moon...
> This program returns the HZ value.
> 
> #include <stdio.h>
> #include <unistd.h>
> 
> int main()
> {
>      printf("%d\n", sysconf(_SC_CLK_TCK));
>      return 0;
> }
> 
> 
> 

No it does not. It returns USER_HZ. At least on any 2.6.12 and <.

Mark

  reply	other threads:[~2005-09-13 14:00 UTC|newest]

Thread overview: 23+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-09-13 12:48 HZ question Mark Hounschell
2005-09-13 13:46 ` linux-os (Dick Johnson)
2005-09-13 14:00   ` Mark Hounschell [this message]
2005-09-13 14:20     ` Tim Schmielau
2005-09-13 15:05       ` Mark Hounschell
2005-09-13 16:01         ` Tim Schmielau
2005-09-13 16:41           ` Mark Hounschell
2005-09-13 16:47           ` Mark Hounschell
2005-09-13 18:38             ` Stefan Smietanowski
2005-09-13 19:17               ` Mark Hounschell
2005-09-13 23:19                 ` Daniel Barkalow
2005-09-13 17:34         ` john stultz
2005-09-13 19:15           ` Mark Hounschell
2005-09-14  4:15           ` George Anzinger
2005-09-13 20:13   ` jdow
2005-09-13 20:38     ` linux-os (Dick Johnson)
2005-09-15  1:29       ` Lee Revell
2005-09-13 14:07 ` Tim Schmielau
2005-09-14  4:00 ` Coywolf Qi Hunt
2005-09-15  1:20   ` Lee Revell
2005-09-15 16:16     ` Joe Bob Spamtest
2005-09-15 20:19       ` Valdis.Kletnieks
2005-09-15 20:34         ` Jesper Juhl

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=4326DB8A.7040109@compro.net \
    --to=markh@compro.net \
    --cc=linux-kernel@vger.kernel.org \
    /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
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox