On Fri, May 02, 2008 at 12:34:54AM +0100, Nix wrote:
> loki:/tmp# /usr/bin/ntpdate -bv hades
> 30 Apr 22:45:52 ntpdate[8833]: ntpdate [EMAIL PROTECTED] Fri Feb 22 18:37:11 
> UTC 2008 (1)
> 30 Apr 22:45:52 ntpdate[8833]: step time server 192.168.14.18 offset 
> -5.728539 sec
> 
> so in effect yes :)
> 
> Hm. A five-second skip forwards via date --set works fine. A five-second
> skip *backwards*, and instant boom.

I tried both directions for the hell of it.

With your config, I'm seeing a hang until the system time catches up
to what UML thought it should have been in the first place.  But it's
only a few seconds, not forever.

However, stracing it did reveal a bogus interval trying to be set,
which the patch below fixes.  It doesn't cause any behavior change
here, so YMMV.

This includes the previous patch, which I think is a good idea anyway,
so back that out and drop this in its place.

                        Jeff

Index: linux-2.6.22/arch/um/os-Linux/time.c
===================================================================
--- linux-2.6.22.orig/arch/um/os-Linux/time.c   2008-04-24 13:21:28.000000000 
-0400
+++ linux-2.6.22/arch/um/os-Linux/time.c        2008-05-02 12:21:01.000000000 
-0400
@@ -107,6 +107,10 @@ static void deliver_alarm(void)
        unsigned long long this_tick = os_nsecs();
        int one_tick = UM_NSEC_PER_SEC / UM_HZ;
 
+       /* Protection against the host's time going backwards */
+       if ((last_tick != 0) && (this_tick < last_tick))
+               this_tick = last_tick;
+
        if (last_tick == 0)
                last_tick = this_tick - one_tick;
 
@@ -149,6 +153,9 @@ static int after_sleep_interval(struct t
                start_usecs = usec;
 
        start_usecs -= skew / UM_NSEC_PER_USEC;
+       if (start_usecs < 0)
+               start_usecs = 0;
+
        tv = ((struct timeval) { .tv_sec  = start_usecs / UM_USEC_PER_SEC,
                                 .tv_usec = start_usecs % UM_USEC_PER_SEC });
        interval = ((struct itimerval) { { 0, usec }, tv });

-- 
Work email - jdike at linux dot intel dot com

-------------------------------------------------------------------------
This SF.net email is sponsored by the 2008 JavaOne(SM) Conference 
Don't miss this year's exciting event. There's still time to save $100. 
Use priority code J8TL2D2. 
http://ad.doubleclick.net/clk;198757673;13503038;p?http://java.sun.com/javaone
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

Reply via email to