On ix86 machines, it is appropriate to read the RTC clock several times in a row until nothing changes. This protects against getting bad readings when some values wrap (like seconds). You can't stop the clock when you read it or you will lose time. I don't see anything like this in your code. Also, when setting the clock it is necessary to stop the clock so its settings don't change while you are writing a new time. I also don't see anything like this in your code either. Also ix86 machines have a spin-lock, rtc_lock, so that other procedures, even interrupts can access its registers. I see you using a semaphore that can't be used in interrupt context. Notice: the RTC clock is used for high-precision timing via interrupt in some ix86 drivers. If you modify the RTC code on all platforms as you propose, you cannot "keep" the RTC all to your self. Its interrupt must be available to drivers and access to the hardware needs to be locked with the existing spin-lock. I note that on 2.6.9 on somebody broke it so that, the interrupt is used for something only ONCE during startup and ONCE during shut-down. CPU0 0: 6225448 IO-APIC-edge timer 1: 14002 IO-APIC-edge i8042 8: 1 IO-APIC-edge rtc <--- bingo 9: 0 IO-APIC-level acpi [snipped...] I don't have a clue why anybody would grab that interrupt. Fortunately, the interrupt-grabbing code can be loaded as a module and then unloaded so that other drivers can use that device and its interrupt. Any changes to the RTC code need to consider these things. On Mon, 31 Jan 2005, Mark A. Greer wrote: > This patch adds support for the ST M41T00 RTC chip. > > You will likely notice that it implements a PPC-specific interface > (/dev/rtc->drivers/char/genrtc.h->include/asm-ppc/rtc.h->this file). This > was necessary to support a subset of ppc platforms that need to hook up the > rtc support at runtime. If I implemented /dev/rtc directly or interfaced to > genrtc.c directly, those platforms couldn't use this driver. Eventually, I > hope to work on more uniform rtc support across all the processor > architectures. > > Also, on ppc at least, the hw clock can be set from a timer interrupt if > STA_UNSYNC is not set (e.g., ntpd is running). To handle this, a tasklet is > used to set the clock if in_interrupt() is true. > > I'd appreciate an comments or to have it pushed into the kernel.org tree if > its acceptable. > > Thanks, > > Mark > > Signed-off-by: Mark A. Greer <mgreer at mvista.com> > -- > > Cheers, Dick Johnson Penguin : Linux version 2.6.9 on an i686 machine (5537.79 BogoMips). Notice : All mail here is now cached for review by Dictator Bush. 98.36% of all statistics are fiction.