win32 get real implemented (timings that is).
authorAdam Dickmeiss <adam@indexdata.dk>
Fri, 5 Jan 2007 12:40:05 +0000 (12:40 +0000)
committerAdam Dickmeiss <adam@indexdata.dk>
Fri, 5 Jan 2007 12:40:05 +0000 (12:40 +0000)
src/timing.c
test/tst_timing.c

index 31f1095..0276d07 100644 (file)
@@ -2,7 +2,7 @@
  * Copyright (C) 1995-2007, Index Data ApS
  * See the file LICENSE for details.
  *
- * $Id: timing.c,v 1.2 2007-01-05 11:44:49 adam Exp $
+ * $Id: timing.c,v 1.3 2007-01-05 12:40:05 adam Exp $
  */
 
 /**
@@ -14,6 +14,9 @@
 #include <config.h>
 #endif
 
+#ifdef WIN32
+#include <windows.h>
+#endif
 #include <stdlib.h>
 
 #if HAVE_SYS_TIMES_H
@@ -34,6 +37,9 @@ struct yaz_timing {
 #if HAVE_SYS_TIME_H
     struct timeval start_time, end_time;
 #endif
+#ifdef WIN32
+    ULONGLONG start_time, end_time;
+#endif
     double real_sec, user_sec, sys_sec;
 };
 
@@ -44,6 +50,19 @@ yaz_timing_t yaz_timing_create(void)
     return t;
 }
 
+#ifdef WIN32
+static void get_date_as_largeinteger(ULONGLONG *lp)
+{
+    FILETIME f;
+    ULARGE_INTEGER li;
+    GetSystemTimeAsFileTime(&f);
+    li.LowPart = f.dwLowDateTime;
+    li.HighPart = f.dwHighDateTime;
+
+    *lp = li.QuadPart;
+}
+#endif
+
 void yaz_timing_start(yaz_timing_t t)
 {
 #if HAVE_SYS_TIMES_H
@@ -54,11 +73,14 @@ void yaz_timing_start(yaz_timing_t t)
     t->user_sec = -1.0;
     t->sys_sec = -1.0;
 #endif
+    t->real_sec = -1.0;
 #if HAVE_SYS_TIME_H
     gettimeofday(&t->start_time, 0);
     t->real_sec = 0.0;
-#else
-    t->real_sec = -1.0;
+#endif
+#ifdef WIN32
+    get_date_as_largeinteger(&t->start_time);
+    t->real_sec = 0.0;
 #endif
 }
 
@@ -76,6 +98,10 @@ void yaz_timing_stop(yaz_timing_t t)
                    t->end_time.tv_usec - t->start_time.tv_usec) / 1000000;
     
 #endif
+#ifdef WIN32
+    get_date_as_largeinteger(&t->end_time);
+    t->real_sec = (double) (t->end_time - t->start_time) / 10000000.0;
+#endif
 }
 
 double yaz_timing_get_real(yaz_timing_t t)
index c02f03c..43e62ff 100644 (file)
@@ -2,7 +2,7 @@
  * Copyright (C) 1995-2007, Index Data ApS
  * See the file LICENSE for details.
  *
- * $Id: tst_timing.c,v 1.1 2007-01-05 11:45:11 adam Exp $
+ * $Id: tst_timing.c,v 1.2 2007-01-05 12:40:05 adam Exp $
  */
 
 #include <stdlib.h>
@@ -11,6 +11,9 @@
 #include <yaz/timing.h>
 #include <yaz/test.h>
 #include <yaz/log.h>
+#ifdef WIN32
+#include <windows.h>
+#endif
 
 static void tst(void)
 {
@@ -22,6 +25,9 @@ static void tst(void)
     if (!t)
         return;
 
+#ifdef WIN32
+    Sleep(100);
+#endif
     for (i = 0; i<100000; i++)
         ;