2 * Copyright 2000, International Business Machines Corporation and others.
5 * This software has been released under the terms of the IBM Public
6 * License. For details, see the LICENSE file in the top-level source
7 * directory or online at http://www.openafs.org/dl/license10.html
10 /* Elapsed time package */
11 /* See rx_clock.h for calling conventions */
13 #include <afsconfig.h>
14 #include <afs/param.h>
25 struct clock clock_now; /* The last elapsed time ready by clock_GetTimer */
27 /* This is set to 1 whenever the time is read, and reset to 0 whenever
28 * clock_NewTime is called. This is to allow the caller to control the
29 * frequency with which the actual time is re-evaluated.
31 int clock_haveCurrentTime;
33 int clock_nUpdates; /* The actual number of clock updates */
34 static int clockInitialized = 0;
36 /* Timing tests show that we can compute times at about 4uS per call. */
37 LARGE_INTEGER rxi_clock0;
38 LARGE_INTEGER rxi_clockFreq;
41 if (!QueryPerformanceFrequency(&rxi_clockFreq)) {
42 printf("No High Performance clock, exiting.\n");
47 (void) QueryPerformanceCounter(&rxi_clock0);
53 /* Make clock uninitialized. */
60 void clock_UpdateTime(void)
62 LARGE_INTEGER now, delta;
65 (void) QueryPerformanceCounter(&now);
67 delta.QuadPart = now.QuadPart - rxi_clock0.QuadPart;
69 seconds = (double)delta.QuadPart / (double)rxi_clockFreq.QuadPart;
71 clock_now.sec = (int) seconds;
72 clock_now.usec = (int) ((seconds - (double)clock_now.sec)
74 clock_haveCurrentTime = 1;
78 #endif /* AFS_NT40_ENV */