blob: 7db8f30744c9275bdb90131c391d30a73b768d26 (
plain)
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
|
/**
** Simple entropy harvester based upon the havege RNG
**
** Copyright 2018-2022 Jirka Hladky hladky DOT jiri AT gmail DOT com
** Copyright 2009-2014 Gary Wuertz gary@issiweb.com
**
** This program is free software: you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation, either version 3 of the License, or
** (at your option) any later version.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef HAVEGETUNE_H
#define HAVEGETUNE_H
#include "havegecollect.h"
/**
* Some systems supply a maximum
*/
#ifndef FILENAME_MAX
#define FILENAME_MAX 256 /* Max path length */
#endif
/**
* Limits
*/
#define MAX_BIT_IDX (256/BITS_PER_H_UINT) /* Size of resource bitmaps */
#define MAX_CACHES 8 /* Max cache types */
#define MAX_CPUS 8 /* Max cpu types */
/**
* Object used to represent a set of objects
*/
typedef struct {
H_UINT bits[MAX_BIT_IDX];
int msw;
H_UINT source;
} TOPO_MAP;
/**
* Cache instance
*/
typedef struct {
TOPO_MAP cpuMap; /* what cpus have this cache */
H_UINT type; /* 'I'nstruction, 'D'ata, 'U'nified, 'T'race */
H_UINT level; /* 0-15................ */
H_UINT size; /* size in KB */
} CACHE_INST;
/**
* Sources for CACHE_INST TOPO_MAP
*/
#define SRC_DEFAULT 0x00001
#define SRC_PARAM 0x00002
#define SRC_CPUID_AMD6 0x00004
#define SRC_CPUID_AMD5 0x00008
#define SRC_CPUID_INTEL2 0x00010
#define SRC_CPUID_INTEL4 0x00020
#define SRC_VFS_INDEX 0x00040
/**
* CPU instance
*/
typedef struct {
TOPO_MAP cpuMap; /* what cpus have this config */
H_UINT signature; /* processor signature */
H_UINT flags;
H_UINT maxFn;
H_UINT maxFnx;
char vendor[16];
} CPU_INST;
/**
* Sources for CPU_INST TOPO_MAP
*/
#define SRC_CPUID_PRESENT 0x00100
#define SRC_CPUID_HT 0x00200
#define SRC_CPUID_AMD 0x00400
#define SRC_CPUID_AMD8 0x00800
#define SRC_CPUID_LEAFB 0x01000
#define SRC_CPUID_LEAF4 0x02000
#define SRC_VFS_STATUS 0x04000
#define SRC_VFS_ONLINE 0x08000
#define SRC_VFS_CPUINFO 0x10000
#define SRC_VFS_CPUDIR 0x20000
/**
* Size of representation fields
*/
#define SZ_BUILDREP 32
#define SZ_CPUREP 64
#define SZ_CACHEREP 32
/**
* The result of tuning
*/
typedef struct {
char *procfs; /* where proc is mounted */
char *sysfs; /* where sys is mounted */
char buildOpts[SZ_BUILDREP]; /* build options */
char cpuOpts[SZ_CPUREP]; /* cpu options */
char icacheOpts[SZ_CACHEREP]; /* icache options */
char dcacheOpts[SZ_CACHEREP]; /* dcache options */
TOPO_MAP pAllowed; /* allowed processors */
TOPO_MAP pOnline; /* processors online */
TOPO_MAP pCpuInfo; /* processors with info */
TOPO_MAP pCacheInfo; /* processors with cache info */
TOPO_MAP mAllowed; /* allowed memory */
H_UINT a_cpu; /* suggested cpu */
H_UINT i_tune; /* suggested i cache value */
H_UINT d_tune; /* suggested d cache value */
int ctCpu; /* number of cpu types */
int ctCache; /* number of cache items */
CPU_INST cpus[MAX_CPUS]; /* cpu instances */
CACHE_INST caches[MAX_CACHES+2]; /* cache instances */
} HOST_CFG;
/**
* Tuning interface
*/
void havege_tune(HOST_CFG *env, H_PARAMS *params);
#endif
|