1 /**************************************************************************
2 * fg_timer.c -- time handling routines
4 * Written by Curtis Olson, started June 1997.
6 * Copyright (C) 1997 Curtis L. Olson - curt@infoplane.com
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as
10 * published by the Free Software Foundation; either version 2 of the
11 * License, or (at your option) any later version.
13 * This program is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23 * (Log is kept at end of this file)
24 **************************************************************************/
27 #include <signal.h> /* for timer routines */
28 #include <stdio.h> /* for printf() */
31 # include <sys/timeb.h> /* for ftime() and struct timeb */
33 # include <sys/time.h> /* for get/setitimer, gettimeofday, struct timeval */
39 unsigned long int fgSimTime;
42 static struct itimerval t, ot;
43 static void (*callbackfunc)(int multi_loop);
46 /* This routine catches the SIGALRM */
48 /* ignore any SIGALRM's until we come back from our EOM iteration */
49 signal(SIGALRM, SIG_IGN);
51 /* printf("In fgTimerCatch()\n"); */
53 /* -1 tells the routine to use default interval rather than something
54 dynamically calculated based on frame rate */
57 signal(SIGALRM, fgTimerCatch);
61 /* this routine initializes the interval timer to generate a SIGALRM after
62 * the specified interval (dt) */
63 void fgTimerInit(float dt, void (*f)()) {
71 usec = 1000000* (dt - (float) isec);
73 t.it_interval.tv_sec = isec;
74 t.it_interval.tv_usec = usec;
75 t.it_value.tv_sec = isec;
76 t.it_value.tv_usec = usec;
77 /* printf("fgTimerInit() called\n"); */
78 fgTimerCatch(); /* set up for SIGALRM signal catch */
79 terr = setitimer( ITIMER_REAL, &t, &ot );
81 printf("Error returned from setitimer");
88 /* This function returns the number of milleseconds since the last
89 time it was called. */
90 int fgGetTimeInterval() {
92 static int inited = 0;
95 static struct timeb last;
96 static struct timeb current;
98 static struct timeval last;
99 static struct timeval current;
100 static struct timezone tz;
109 gettimeofday(&last, &tz);
117 interval = 1000 * (current.time - last.time) +
118 (current.millitm - last.millitm);
120 gettimeofday(¤t, &tz);
121 interval = 1000000 * (current.tv_sec - last.tv_sec) +
122 (current.tv_usec - last.tv_usec);
123 interval /= 1000; /* convert back to milleseconds */
134 /* Revision 1.6 1997/07/12 02:13:04 curt
135 /* Add ftime() support for those that don't have gettimeofday()
137 * Revision 1.5 1997/06/26 19:08:38 curt
138 * Restructuring make, adding automatic "make dep" support.
140 * Revision 1.4 1997/06/25 15:39:49 curt
141 * Minor changes to compile with rsxnt/win32.
143 * Revision 1.3 1997/06/17 16:52:04 curt
144 * Timer interval stuff now uses gettimeofday() instead of ftime()
146 * Revision 1.2 1997/06/17 03:41:10 curt
147 * Nonsignal based interval timing is now working.
148 * This would be a good time to look at cleaning up the code structure a bit.
150 * Revision 1.1 1997/06/16 19:24:20 curt