]> git.rm.cloudns.org Git - xonotic/darkplaces.git/commitdiff
fix severe timing issues regarding the global variable realtime which governs many...
authorhavoc <havoc@d7cf8633-e32d-0410-b094-e92efae38249>
Thu, 5 Apr 2007 07:02:29 +0000 (07:02 +0000)
committerhavoc <havoc@d7cf8633-e32d-0410-b094-e92efae38249>
Thu, 5 Apr 2007 07:02:29 +0000 (07:02 +0000)
git-svn-id: svn://svn.icculus.org/twilight/trunk/darkplaces@7049 d7cf8633-e32d-0410-b094-e92efae38249

host.c

diff --git a/host.c b/host.c
index 13cd059127f4ef97f4f95fbae09d9c0b6259e92a..2ce7a994f3ad214e6aa2ae5a5ec6b5b01f5595d9 100644 (file)
--- a/host.c
+++ b/host.c
@@ -577,12 +577,11 @@ Runs all active servers
 static void Host_Init(void);
 void Host_Main(void)
 {
-       static double time1 = 0;
-       static double time2 = 0;
-       static double time3 = 0;
-       // these are static because of setjmp/longjmp warnings in mingw32 gcc 2.95.3
-       static double frameoldtime, framenewtime, framedeltatime, cl_timer, sv_timer;
-       double clframetime;
+       double time1 = 0;
+       double time2 = 0;
+       double time3 = 0;
+       double cl_timer, sv_timer;
+       double clframetime, deltarealtime, oldrealtime;
        double wait;
        int pass1, pass2, pass3;
 
@@ -591,20 +590,18 @@ void Host_Main(void)
        cl_timer = 0;
        sv_timer = 0;
 
-       framenewtime = Sys_DoubleTime();
+       realtime = Sys_DoubleTime();
        for (;;)
        {
                if (setjmp(host_abortframe))
                        continue;                       // something bad happened, or the server disconnected
 
-               frameoldtime = framenewtime;
-               framenewtime = Sys_DoubleTime();
-               framedeltatime = framenewtime - frameoldtime;
-               realtime += framedeltatime;
+               oldrealtime = realtime;
+               realtime = Sys_DoubleTime();
 
-               // accumulate the new frametime into the timers
-               cl_timer += framedeltatime;
-               sv_timer += framedeltatime;
+               deltarealtime = realtime - oldrealtime;
+               cl_timer += deltarealtime;
+               sv_timer += deltarealtime;
 
                if (slowmo.value < 0)
                        Cvar_SetValue("slowmo", 0);
@@ -701,7 +698,7 @@ void Host_Main(void)
                                // synchronize to the client frametime, but no less than 10ms and no more than sys_ticrate
                                advancetime = bound(0.01, cl_timer, sys_ticrate.value);
                                framelimit = 10;
-                               aborttime = Sys_DoubleTime() + 0.1;
+                               aborttime = realtime + 0.1;
                        }
                        else
                        {
@@ -710,7 +707,7 @@ void Host_Main(void)
                                if (cls.state == ca_connected)
                                {
                                        framelimit = 10;
-                                       aborttime = Sys_DoubleTime() + 0.1;
+                                       aborttime = realtime + 0.1;
                                }
                        }
                        advancetime = min(advancetime, 0.1);