1
0
Fork 0
mirror of https://github.com/anrieff/libcpuid synced 2025-01-23 20:06:41 +00:00

Fix cpuid_deserialize_raw_data_internal when raw starts with 'version'

This commit is contained in:
Xorg 2022-09-27 20:16:05 +02:00
parent 951c42be82
commit 9334bce205
No known key found for this signature in database
GPG key ID: 1E55EE2EFF18BC1A

View file

@ -428,6 +428,7 @@ static int cpuid_deserialize_raw_data_internal(struct cpu_raw_data_t* single_raw
int cur_line = 0; int cur_line = 0;
int assigned = 0; int assigned = 0;
int subleaf = 0; int subleaf = 0;
bool is_header = true;
bool is_libcpuid_dump = true; bool is_libcpuid_dump = true;
bool is_aida64_dump = false; bool is_aida64_dump = false;
const bool use_raw_array = (raw_array != NULL); const bool use_raw_array = (raw_array != NULL);
@ -453,34 +454,39 @@ static int cpuid_deserialize_raw_data_internal(struct cpu_raw_data_t* single_raw
line[strcspn(line, "\n")] = '\0'; line[strcspn(line, "\n")] = '\0';
if (line[0] == '\0') // Skip empty lines if (line[0] == '\0') // Skip empty lines
continue; continue;
if (!strcmp(line, "--------------------------------------------------------------------------------")) // Skip test results
break;
cur_line++; cur_line++;
if (cur_line == 1) { if (is_header) {
if ((sscanf(line, "version=%s", version) >= 1) || (sscanf(line, "basic_cpuid[%d]=%x %x %x %x", &i, &eax, &ebx, &ecx, &edx) >= 5)) { if (sscanf(line, "version=%s", version) >= 1) {
debugf(2, "Recognized version '%s' from raw dump\n", version);
is_libcpuid_dump = true; is_libcpuid_dump = true;
is_aida64_dump = false; is_aida64_dump = false;
if (version[0] != '\0') { continue;
debugf(2, "Recognized version '%s' from raw dump\n", version); }
continue; else if (sscanf(line, "basic_cpuid[%d]=%x %x %x %x", &i, &eax, &ebx, &ecx, &edx) >= 5) {
} debugf(2, "Parsing raw dump for a single CPU dump\n");
if (i >= 0) { is_header = false;
debugf(2, "Parsing raw dump for a single CPU dump\n"); is_libcpuid_dump = true;
if (use_raw_array) { is_aida64_dump = false;
cpuid_grow_raw_data_array(raw_array, 1); if (use_raw_array) {
raw_ptr = &raw_array->raw[0]; cpuid_grow_raw_data_array(raw_array, 1);
raw_array->with_affinity = false; raw_ptr = &raw_array->raw[0];
} raw_array->with_affinity = false;
} }
} }
else if (!strcmp(line, "------[ Versions ]------") || !strcmp(line, "------[ Logical CPU #0 ]------") || !strcmp(line, "------[ CPUID Registers / Logical CPU #0 ]------")) { else if (!strcmp(line, "------[ Versions ]------") || !strcmp(line, "------[ Logical CPU #0 ]------") || !strcmp(line, "------[ CPUID Registers / Logical CPU #0 ]------")) {
debugf(2, "Recognized AIDA64 raw dump\n");
is_header = false;
is_libcpuid_dump = false; is_libcpuid_dump = false;
is_aida64_dump = true; is_aida64_dump = true;
debugf(2, "Recognized AIDA64 raw dump\n");
} }
} }
if (is_libcpuid_dump) { if (is_libcpuid_dump) {
if (use_raw_array && (sscanf(line, "_________________ Logical CPU #%hi _________________", &logical_cpu) >= 1)) { if (use_raw_array && (sscanf(line, "_________________ Logical CPU #%hi _________________", &logical_cpu) >= 1)) {
debugf(2, "Parsing raw dump for logical CPU %i\n", logical_cpu); debugf(2, "Parsing raw dump for logical CPU %i\n", logical_cpu);
is_header = false;
cpuid_grow_raw_data_array(raw_array, logical_cpu + 1); cpuid_grow_raw_data_array(raw_array, logical_cpu + 1);
raw_ptr = &raw_array->raw[logical_cpu]; raw_ptr = &raw_array->raw[logical_cpu];
raw_array->with_affinity = true; raw_array->with_affinity = true;