forked from yaosj2k/dnsforwarder
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ptimer.c
executable file
·54 lines (47 loc) · 1.04 KB
/
ptimer.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include <limits.h>
#include "ptimer.h"
int PTimer_Start(PTimer *t)
{
#ifdef WIN32
#ifdef WIN64
t->c = GetTickCount64();
return 0;
#else
t->c = GetTickCount();
return 0;
#endif /* WIN64 */
#else
return clock_gettime(CLOCK_REALTIME, &(t->c));
#endif /* WIN32 */
}
unsigned long PTimer_End(PTimer *t)
{
#ifdef WIN32
#ifdef WIN64
return (unsigned long)(GetTickCount64() - t->c);
#else
return (unsigned long)(GetTickCount() - t->c);
#endif /* WIN64 */
#else
struct timespec e;
unsigned long ms;
if( clock_gettime(CLOCK_REALTIME, &e) != 0 )
{
return ULONG_MAX;
}
if( e.tv_nsec > t->c.tv_nsec )
{
ms = (e.tv_nsec - t->c.tv_nsec) / 1000000;
} else {
--e.tv_sec;
/*ms = ((1000000000 + e.tv_nsec) - t->c.tv_nsec) / 1000000;*/
ms = ((1000000000 - t->c.tv_nsec) + e.tv_nsec) / 1000000;
}
if( e.tv_sec < t->c.tv_sec )
{
return ULONG_MAX;
}
ms += (e.tv_sec - t->c.tv_sec) * 1000;
return ms;
#endif /* WIN32 */
}