forked from ajaiantilal/i7z
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathi7z.h
183 lines (148 loc) · 5.47 KB
/
i7z.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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
//i7z.h
/* ----------------------------------------------------------------------- *
*
* Copyright 2009 Abhishek Jaiantilal
*
* Under GPL v2
*
* modified for ivy bridge May 2013
* Daniel McLellan <[email protected]>
*
* ----------------------------------------------------------------------- */
#include <sys/time.h>
#define i7z_VERSION_INFO "svn-r93-(27-MAY-2013)"
//structure to store the information about the processor
#define proccpuinfo "/proc/cpuinfo"
#ifndef bool
#define bool int
#endif
#define false 0
#define true 1
#define MAX_PROCESSORS 128
#define MAX_HI_PROCESSORS MAX_PROCESSORS
#define MAX_SK_PROCESSORS (MAX_PROCESSORS/4)
//add newer version of core processors here, this is basically to change any things that are done to the register
//seems like sandybridge doesnot use the IA32_TEMPERATURE_TARGET in Read_Thermal_Status_CPU
struct core_i7_version{
bool nehalem;
bool sandy_bridge;
bool ivy_bridge;
bool haswell;
};
struct program_options{
int logging; //0=no logging, 1=logging, 2=appending
int templogging;
int cstatelogging;
//always put variables before the below structure, something fishy going on and the variable is reset
struct core_i7_version i7_version;
};
/// Logging Functions
void logOpenFile_single();
void logCloseFile_single();
void logCpuFreq_single(float value);
void logOpenFile_dual(int);
void logCloseFile_dual(int);
void logCpuFreq_dual(float,int);
void logCpuFreq_dual_d(int, int);
void logCpuFreq_dual_ts(struct timespec *value, int) ;
void logCpuCstates_single(float value);
void logCpuCstates_single_c(char* value);
//void logCpuCstates_single_d(int value);
void logCpuCstates_single_ts(struct timespec *value) ;
void logCpuCstates_dual(float value, int);
void logCpuCstates_dual_c(char* value, int);
void logCpuCstates_dual_ts(struct timespec *value, int) ;
struct cpu_heirarchy_info {
int max_online_cpu;
int num_sockets;
int sibling_num[MAX_HI_PROCESSORS];
int processor_num[MAX_HI_PROCESSORS];
int package_num[MAX_HI_PROCESSORS];
int coreid_num[MAX_HI_PROCESSORS];
int display_cores[MAX_HI_PROCESSORS];
bool HT;
};
struct cpu_socket_info {
int max_cpu;
int socket_num;
int processor_num[MAX_SK_PROCESSORS];
int num_physical_cores;
int num_logical_cores;
};
struct family_info
{
char stepping;
char model;
char family;
char processor_type;
char extended_model;
int extended_family;
};
//read TSC() code for 32 and 64-bit
//http://www.mcs.anl.gov/~kazutomo/rdtsc.html
#ifndef x64_BIT
//code for 32 bit
static __inline__ unsigned long long int
rdtsc ()
{
unsigned long long int x;
__asm__ volatile (".byte 0x0f, 0x31":"=A" (x));
return x;
}
#endif
#ifdef x64_BIT
//code for 32 bit
static __inline__ unsigned long long
rdtsc (void)
{
unsigned hi, lo;
__asm__ __volatile__ ("rdtsc":"=a" (lo), "=d" (hi));
return ((unsigned long long) lo) | (((unsigned long long) hi) << 32);
}
#endif
void print_family_info (struct family_info *proc_info);
//void get_vendor (char *vendor_string);
int turbo_status ();
double cpufreq_info();
//void get_familyinformation (struct family_info *proc_info);
double estimate_MHz ();
uint64_t get_msr_value (int cpu, uint32_t reg, unsigned int highbit,
unsigned int lowbit, int* error_indx);
uint64_t set_msr_value (int cpu, uint32_t reg, uint64_t data);
#ifdef USE_INTEL_CPUID
void get_CPUs_info (unsigned int *num_Logical_OS,
unsigned int *num_Logical_process,
unsigned int *num_Processor_Core,
unsigned int *num_Physical_Socket);
#endif
int get_number_of_present_cpu();
void get_candidate_cores(struct cpu_heirarchy_info* chi);
void get_online_cpus(struct cpu_heirarchy_info* chi);
void get_siblings_list(struct cpu_heirarchy_info* chi);
void get_package_ids(struct cpu_heirarchy_info* chi);
void print_cpu_list(struct cpu_heirarchy_info chi);
void construct_cpu_hierarchy(struct cpu_heirarchy_info *chi);
void Print_Information_Processor(bool*, bool*, bool*, bool*);
void Test_Or_Make_MSR_DEVICE_FILES();
int check_and_return_processor(char*strinfo);
int check_and_return_physical_id(char*strinfo);
void construct_sibling_list(struct cpu_heirarchy_info* chi);
void construct_socket_information(struct cpu_heirarchy_info* chi,
struct cpu_socket_info* socket_0,struct cpu_socket_info* socket_1,
int, int);
void print_socket_information(struct cpu_socket_info* socket);
void construct_CPU_Heirarchy_info(struct cpu_heirarchy_info* chi);
void print_CPU_Heirarchy(struct cpu_heirarchy_info chi);
int in_core_list(int ii,int* core_list);
void Print_Version_Information();
bool file_exists(char*);
#define SET_ONLINE_ARRAY_MINUS1(online_cpus) {int iii;for(iii=0;iii<MAX_PROCESSORS;iii++) online_cpus[iii]=-1;}
#define SET_ONLINE_ARRAY_PLUS1(online_cpus) {int iii;for(iii=0;iii<MAX_PROCESSORS;iii++) online_cpus[iii]=1;}
#define SET_IF_TRUE(error_indx,a,b) if(error_indx) a=b;
#define CONTINUE_IF_TRUE(cond) if(cond) continue;
#define RETURN_IF_TRUE(cond) if(cond) return;
//due to the fact that sometimes 100.0>100, the below macro checks till 101
#define THRESHOLD_BETWEEN_0_100(cond) (cond>=-1 && cond <=125 && !isinf(cond) && !isnan(cond))? cond: __builtin_inf()
//due to the fact that sometimes 100.0>100, the below macro checks till 101
#define IS_THIS_BETWEEN_0_100(cond) (cond>=-1 && cond <=125 && !isinf(cond) && !isnan(cond))? 0: 1
#define THRESHOLD_BETWEEN_0_6000(cond) (cond>=0 && cond <=10000)? cond: __builtin_inf()