mirror of
https://github.com/anrieff/libcpuid
synced 2025-10-13 11:10:39 +00:00
Add up to 8 entries for CPUID leaf 04; push version to 0.3.0.
This is a backwards-incompatible binary change, which increases sizeof(cpu_raw_data_t). Specifically, the cpu_raw_data_t::intel_fn4 array is increased from 4 to 8 elements, because on recent Hasells (Crystalwell) there is a Level 4 cache, which should be encoded in CPUID eax=4 ecx=4. However, we were only storing levels for eax=4 for ecx <= 3. Thus the raw data didn't have the relevant info. There will be further changes to this, specifically to store and print the level 4 cache in cpuid_tool.
This commit is contained in:
parent
3f36114b19
commit
c31b5c0ae8
4 changed files with 9 additions and 8 deletions
|
@ -373,7 +373,7 @@ int cpuid_get_raw_data(struct cpu_raw_data_t* data)
|
|||
cpu_exec_cpuid(i, data->basic_cpuid[i]);
|
||||
for (i = 0; i < 32; i++)
|
||||
cpu_exec_cpuid(0x80000000 + i, data->ext_cpuid[i]);
|
||||
for (i = 0; i < 4; i++) {
|
||||
for (i = 0; i < MAX_INTELFN4_LEVEL; i++) {
|
||||
memset(data->intel_fn4[i], 0, sizeof(data->intel_fn4[i]));
|
||||
data->intel_fn4[i][0] = 4;
|
||||
data->intel_fn4[i][2] = i;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue