mirror of
https://github.com/Dr-Noob/cpufetch.git
synced 2026-03-25 07:50:40 +01:00
[v1.04][X86] Fix bug (hopefully)
This commit is contained in:
@@ -21,7 +21,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ARCH_X86
|
#ifdef ARCH_X86
|
||||||
static const char* ARCH_STR = "x86_64 build";
|
static const char* ARCH_STR = "x86 / x86_64 build";
|
||||||
#include "../x86/cpuid.h"
|
#include "../x86/cpuid.h"
|
||||||
#elif ARCH_PPC
|
#elif ARCH_PPC
|
||||||
static const char* ARCH_STR = "PowerPC build";
|
static const char* ARCH_STR = "PowerPC build";
|
||||||
|
|||||||
@@ -486,8 +486,8 @@ struct cpuInfo* get_cpu_info(void) {
|
|||||||
cpu->cpu_name = get_str_cpu_name_internal();
|
cpu->cpu_name = get_str_cpu_name_internal();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
cpu->cpu_name = NULL;
|
||||||
printWarn("Can't read CPU name from cpuid (needed extended level is 0x%.8X, max is 0x%.8X)", 0x80000004, cpu->maxExtendedLevels);
|
printWarn("Can't read CPU name from cpuid (needed extended level is 0x%.8X, max is 0x%.8X)", 0x80000004, cpu->maxExtendedLevels);
|
||||||
cpu->cpu_name = infer_cpu_name_from_uarch(cpu->arch);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
cpu->topology_extensions = false;
|
cpu->topology_extensions = false;
|
||||||
@@ -537,12 +537,17 @@ struct cpuInfo* get_cpu_info(void) {
|
|||||||
ptr->first_core_id = first_core;
|
ptr->first_core_id = first_core;
|
||||||
ptr->feat = get_features_info(ptr);
|
ptr->feat = get_features_info(ptr);
|
||||||
|
|
||||||
// If any field of the struct is NULL,
|
|
||||||
// return inmideately, as further functions
|
|
||||||
// require valid fields (cach, topo, etc)
|
|
||||||
ptr->arch = get_cpu_uarch(ptr);
|
ptr->arch = get_cpu_uarch(ptr);
|
||||||
ptr->freq = get_frequency_info(ptr);
|
ptr->freq = get_frequency_info(ptr);
|
||||||
|
|
||||||
|
if (cpu->cpu_name == NULL && ptr == cpu) {
|
||||||
|
// If we couldnt read CPU name from cpuid, infer it now
|
||||||
|
cpu->cpu_name = infer_cpu_name_from_uarch(cpu->arch);
|
||||||
|
}
|
||||||
|
|
||||||
|
// If any field of the struct is NULL,
|
||||||
|
// return early, as next functions
|
||||||
|
// require non NULL fields in cach and topo
|
||||||
ptr->cach = get_cache_info(ptr);
|
ptr->cach = get_cache_info(ptr);
|
||||||
if(ptr->cach == NULL) return cpu;
|
if(ptr->cach == NULL) return cpu;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user