Date: Wed, 23 May 2007 16:19:21 +0000 From: "Poul-Henning Kamp" <phk@phk.freebsd.dk> To: Takeharu KATO <takeharu1219@ybb.ne.jp> Cc: freebsd-current@freebsd.org Subject: Re: Evaluation of High Precision Event Timer Driver for userland timer facility Message-ID: <6014.1179937161@critter.freebsd.dk> In-Reply-To: Your message of "Wed, 09 May 2007 20:34:26 %2B0900." <4641B1C2.70909@ybb.ne.jp>
next in thread | previous in thread | raw e-mail | index | archive | help
In message <4641B1C2.70909@ybb.ne.jp>, Takeharu KATO writes: >Hi, > >I wrote a patch to add following features into acpi_hpet timer driver >(The patch is posted as PR kern/112544). I have briefly scanned your patch and have some comments. Basing this facility on the HPET almost guarantees that we cannot use it in FreeBSD, because the HPET is not available on more than a couple of our architectures. The underlying timecounters have datastructures that can be used to implement the mmap(2) access to user-space, but access to the necessary hardware is not readily available, as that more often than not, requires kernel privileges. Without userland access to the timekeeping hardware, it is difficult to avoid the system call overhead and once in the kernel anyway it is doubtful that splitting the code between userland and kernel really gives much of a payoff. I am aware that Linux has a userland timestamping facility, but I am also aware of its numerous shortcomings. >feature-1) Global time stamp for SMP machines. > This driver provides a common time-base on N-Way MP system via > mmap system call. > It is not affected by clock freq. drifts. This is an incredibly tall claim that has no backing in reality. >feature-2) Periodic timer facility > This driver provides periodic timer facility for userland applications to > use for appication specific process scheduling. This should under no circumstances be committed without an architecture and hardware independent API. We already have [gs]etitimer() for this purpose. If we want to do something like this, we want to do it right, and that means giving the timeout mechanism in the kernel a good workout. Poul-Henning -- Poul-Henning Kamp | UNIX since Zilog Zeus 3.20 phk@FreeBSD.ORG | TCP/IP since RFC 956 FreeBSD committer | BSD since 4.3-tahoe Never attribute to malice what can adequately be explained by incompetence.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?6014.1179937161>