x86: Increase precision of x86_platform.get/set_wallclock()
All the virtualized platforms (KVM, lguest and Xen) have persistent wallclocks that have more than one second of precision. read_persistent_wallclock() and update_persistent_wallclock() allow for nanosecond precision but their implementation on x86 with x86_platform.get/set_wallclock() only allows for one second precision. This means guests may see a wallclock time that is off by up to 1 second. Make set_wallclock() and get_wallclock() take a struct timespec parameter (which allows for nanosecond precision) so KVM and Xen guests may start with a more accurate wallclock time and a Xen dom0 can maintain a more accurate wallclock for guests. Signed-off-by:David Vrabel <david.vrabel@citrix.com> Signed-off-by:
John Stultz <john.stultz@linaro.org>
Showing
- arch/x86/include/asm/mc146818rtc.h 2 additions, 2 deletionsarch/x86/include/asm/mc146818rtc.h
- arch/x86/include/asm/x86_init.h 4 additions, 2 deletionsarch/x86/include/asm/x86_init.h
- arch/x86/kernel/kvmclock.c 3 additions, 6 deletionsarch/x86/kernel/kvmclock.c
- arch/x86/kernel/rtc.c 7 additions, 10 deletionsarch/x86/kernel/rtc.c
- arch/x86/lguest/boot.c 2 additions, 2 deletionsarch/x86/lguest/boot.c
- arch/x86/platform/efi/efi.c 6 additions, 4 deletionsarch/x86/platform/efi/efi.c
- arch/x86/xen/time.c 6 additions, 13 deletionsarch/x86/xen/time.c
- include/linux/efi.h 2 additions, 2 deletionsinclude/linux/efi.h
Please register or sign in to comment