Alexandre, On Thu, Dec 03 2020 at 03:10, Alexandre Belloni wrote: > On 03/12/2020 02:14:12+0100, Thomas Gleixner wrote: >> That said, can somebody answer the one million dollar question which >> problem is solved by all of this magic nonsense? >> > The goal was to remove the 500ms offset for all the RTCs but the > MC146818 because there are RTC that will reset properly their counter > when setting the time, meaning they can be set very precisely. The MC setting is halfways precise. The write resets the divider chain and when the reset is removed then the next UIP will happen after the magic 0.5 seconds. So yes, writing it 500ms _before_ the next second is halfways correct assumed that there is no interference between ktime_get_real() and the actual write which is a silly assumption as the code is fully preemptible. > IIRC, used in conjunction with rtc_hctosys which also adds > inconditionnaly 500ms this can ends up with the system time > being one second away from the wall clock time which NTP will take quite > some time to remove. The rtc_cmos() driver has a fun comment in cmos_set_time().... The logic in sync_cmos_clock() and rtc_set_ntp_time() is different as I pointed out: sync_cmos_clock() hands -500ms to rtc_tv_nsec_ok() and rtc_set_ntp_time() uses +500ms, IOW exactly ONE second difference in behaviour. > Coincidentally, I was going to revert those patches for v5.11. Which will break the rtc_cmos() driver in a different way. We should really fix that proper and just have the 500ms offset for rtc_cmos, aka. MC146818. When other drivers want a different offset, then they still can do so. The direct /dev/rtc settime ioctl is not using that logic anyway. Thats the business of the user space application to get that straight which is scheduling lottery as well. Thanks, tglx