@@ -12,17 +12,22 @@ int odp_cpuinfo_parser(FILE *file, odp_system_info_t *sysinfo)
char str[1024];
char *pos;
double mhz = 0.0;
+ uint64_t hz;
int model = 0;
int count = 2;
+ int id = 0;
strcpy(sysinfo->cpu_arch_str, "powerpc");
- while (fgets(str, sizeof(str), file) != NULL && count > 0) {
+ while (fgets(str, sizeof(str), file) != NULL && id < MAX_CPU_NUMBER) {
if (!mhz) {
pos = strstr(str, "clock");
if (pos)
- if (sscanf(pos, "clock : %lf", &mhz) == 1)
+ if (sscanf(pos, "clock : %lf", &mhz) == 1) {
+ hz = (uint64_t)(mhz * 1000000.0);
+ sysinfo->cpu_hz[id] = hz;
count--;
+ }
}
if (!model) {
@@ -32,16 +37,21 @@ int odp_cpuinfo_parser(FILE *file, odp_system_info_t *sysinfo)
int len;
pos = strchr(str, ':');
- strncpy(sysinfo->model_str[0], pos + 2,
- sizeof(sysinfo->model_str[0]));
- len = strlen(sysinfo->model_str[0]);
- sysinfo->model_str[0][len - 1] = 0;
+ strncpy(sysinfo->model_str[id], pos + 2,
+ sizeof(sysinfo->model_str[id]));
+ len = strlen(sysinfo->model_str[id]);
+ sysinfo->model_str[id][len - 1] = 0;
model = 1;
count--;
}
}
- sysinfo->cpu_hz[0] = (uint64_t)(mhz * 1000000.0);
+ if (count == 0) {
+ mhz = 0.0;
+ model = 0;
+ count = 2;
+ id++;
+ }
}
return 0;