Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 197402
b: refs/heads/master
c: e9ec360
h: refs/heads/master
v: v3
  • Loading branch information
Haiyang Zhang authored and Greg Kroah-Hartman committed May 11, 2010
1 parent 3da9236 commit b17939c
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 11 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: ce7f6389790f24e07e7e32518c798451e799a830
refs/heads/master: e9ec36030cca2549cb656d94347dafecfcf218f6
33 changes: 23 additions & 10 deletions trunk/drivers/staging/hv/hv_utils.c
Original file line number Diff line number Diff line change
Expand Up @@ -106,31 +106,44 @@ static void shutdown_onchannelcallback(void *context)
orderly_poweroff(false);
}


/*
* Synchronize time with host after reboot, restore, etc.
* Set guest time to host UTC time.
*/
static void adj_guesttime(u64 hosttime, u8 flags)
static inline void do_adj_guesttime(u64 hosttime)
{
s64 host_tns;
struct timespec host_ts;
static s32 scnt = 50;

host_tns = (hosttime - WLTIMEDELTA) * 100;
host_ts = ns_to_timespec(host_tns);

do_settimeofday(&host_ts);
}

/*
* Synchronize time with host after reboot, restore, etc.
*
* ICTIMESYNCFLAG_SYNC flag bit indicates reboot, restore events of the VM.
* After reboot the flag ICTIMESYNCFLAG_SYNC is included in the first time
* message after the timesync channel is opened. Since the hv_utils module is
* loaded after hv_vmbus, the first message is usually missed. The other
* thing is, systime is automatically set to emulated hardware clock which may
* not be UTC time or in the same time zone. So, to override these effects, we
* use the first 50 time samples for initial system time setting.
*/
static inline void adj_guesttime(u64 hosttime, u8 flags)
{
static s32 scnt = 50;

if ((flags & ICTIMESYNCFLAG_SYNC) != 0) {
do_settimeofday(&host_ts);
do_adj_guesttime(hosttime);
return;
}

if ((flags & ICTIMESYNCFLAG_SAMPLE) != 0 &&
scnt > 0) {
if ((flags & ICTIMESYNCFLAG_SAMPLE) != 0 && scnt > 0) {
scnt--;
do_settimeofday(&host_ts);
do_adj_guesttime(hosttime);
}

return;
}

/*
Expand Down

0 comments on commit b17939c

Please sign in to comment.