-
Notifications
You must be signed in to change notification settings - Fork 87
/
Copy pathrdtsc.h
47 lines (35 loc) · 1.38 KB
/
rdtsc.h
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
/*
---------------------------------------------------------------------------
Copyright (c) 1998-2013, Brian Gladman, Worcester, UK. All rights reserved.
The redistribution and use of this software (with or without changes)
is allowed without the payment of fees or royalties provided that:
source code distributions include the above copyright notice, this
list of conditions and the following disclaimer;
binary distributions include the above copyright notice, this list
of conditions and the following disclaimer in their documentation.
This software is provided 'as is' with no explicit or implied warranties
in respect of its operation, including, but not limited to, correctness
and fitness for purpose.
---------------------------------------------------------------------------
Issue Date: 20/12/2007
*/
#ifndef RDTSC_H
#define RDTSC_H
#if defined( __GNUC__ )
static inline volatile unsigned long long read_tsc(void)
{
unsigned int cyl, cyh;
__asm__ __volatile__("movl $0, %%eax; cpuid; rdtsc":"=a"(cyl),"=d"(cyh)::"ebx","ecx");
return ((unsigned long long)cyh << 32) | cyl;
}
#elif defined( _WIN32 ) || defined( _WIN64 )
# include <intrin.h>
# pragma intrinsic( __rdtsc )
__inline volatile unsigned long long read_tsc(void)
{
return __rdtsc();
}
#else
# error A high resolution timer is not available
#endif
#endif