Skip to content

Commit

Permalink
xen/arm: introduce xen_read_wallclock
Browse files Browse the repository at this point in the history
Read the wallclock from the shared info page at boot time.

Signed-off-by: Stefano Stabellini <[email protected]>
Acked-by: Arnd Bergmann <[email protected]>
  • Loading branch information
Stefano Stabellini authored and David Vrabel committed Dec 21, 2015
1 parent ab76078 commit e709fba
Showing 1 changed file with 27 additions and 0 deletions.
27 changes: 27 additions & 0 deletions arch/arm/xen/enlighten.c
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
#include <linux/cpufreq.h>
#include <linux/cpu.h>
#include <linux/console.h>
#include <linux/timekeeping.h>

#include <linux/mm.h>

Expand Down Expand Up @@ -93,6 +94,27 @@ static unsigned long long xen_stolen_accounting(int cpu)
return state.time[RUNSTATE_runnable] + state.time[RUNSTATE_offline];
}

static void xen_read_wallclock(struct timespec64 *ts)
{
u32 version;
struct timespec64 now, ts_monotonic;
struct shared_info *s = HYPERVISOR_shared_info;
struct pvclock_wall_clock *wall_clock = &(s->wc);

/* get wallclock at system boot */
do {
version = wall_clock->version;
rmb(); /* fetch version before time */
now.tv_sec = ((uint64_t)wall_clock->sec_hi << 32) | wall_clock->sec;
now.tv_nsec = wall_clock->nsec;
rmb(); /* fetch time before checking version */
} while ((wall_clock->version & 1) || (version != wall_clock->version));

/* time since system boot */
ktime_get_ts64(&ts_monotonic);
*ts = timespec64_add(now, ts_monotonic);
}

static void xen_percpu_init(void)
{
struct vcpu_register_vcpu_info info;
Expand Down Expand Up @@ -301,6 +323,11 @@ static int __init xen_pm_init(void)

pm_power_off = xen_power_off;
arm_pm_restart = xen_restart;
if (!xen_initial_domain()) {
struct timespec64 ts;
xen_read_wallclock(&ts);
do_settimeofday64(&ts);
}

return 0;
}
Expand Down

0 comments on commit e709fba

Please sign in to comment.