Commit 8173c336 authored by Ben Hutchings's avatar Ben Hutchings Committed by Len Brown

tools/power turbostat: Add checks for failure of fgets() and fscanf()

Most calls to fgets() and fscanf() are followed by error checks.
Add an exit-on-error in the remaining cases.
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
Signed-off-by: default avatarLen Brown <len.brown@intel.com>
parent 3316f99a
...@@ -2643,7 +2643,8 @@ int get_thread_siblings(struct cpu_topology *thiscpu) ...@@ -2643,7 +2643,8 @@ int get_thread_siblings(struct cpu_topology *thiscpu)
filep = fopen_or_die(path, "r"); filep = fopen_or_die(path, "r");
do { do {
offset -= BITMASK_SIZE; offset -= BITMASK_SIZE;
fscanf(filep, "%lx%c", &map, &character); if (fscanf(filep, "%lx%c", &map, &character) != 2)
err(1, "%s: failed to parse file", path);
for (shift = 0; shift < BITMASK_SIZE; shift++) { for (shift = 0; shift < BITMASK_SIZE; shift++) {
if ((map >> shift) & 0x1) { if ((map >> shift) & 0x1) {
so = shift + offset; so = shift + offset;
...@@ -3475,14 +3476,14 @@ dump_sysfs_cstate_config(void) ...@@ -3475,14 +3476,14 @@ dump_sysfs_cstate_config(void)
input = fopen(path, "r"); input = fopen(path, "r");
if (input == NULL) if (input == NULL)
continue; continue;
fgets(name_buf, sizeof(name_buf), input); if (!fgets(name_buf, sizeof(name_buf), input))
err(1, "%s: failed to read file", path);
/* truncate "C1-HSW\n" to "C1", or truncate "C1\n" to "C1" */ /* truncate "C1-HSW\n" to "C1", or truncate "C1\n" to "C1" */
sp = strchr(name_buf, '-'); sp = strchr(name_buf, '-');
if (!sp) if (!sp)
sp = strchrnul(name_buf, '\n'); sp = strchrnul(name_buf, '\n');
*sp = '\0'; *sp = '\0';
fclose(input); fclose(input);
sprintf(path, "/sys/devices/system/cpu/cpu%d/cpuidle/state%d/desc", sprintf(path, "/sys/devices/system/cpu/cpu%d/cpuidle/state%d/desc",
...@@ -3490,7 +3491,8 @@ dump_sysfs_cstate_config(void) ...@@ -3490,7 +3491,8 @@ dump_sysfs_cstate_config(void)
input = fopen(path, "r"); input = fopen(path, "r");
if (input == NULL) if (input == NULL)
continue; continue;
fgets(desc, sizeof(desc), input); if (!fgets(desc, sizeof(desc), input))
err(1, "%s: failed to read file", path);
fprintf(outf, "cpu%d: %s: %s", base_cpu, name_buf, desc); fprintf(outf, "cpu%d: %s: %s", base_cpu, name_buf, desc);
fclose(input); fclose(input);
...@@ -3512,7 +3514,8 @@ dump_sysfs_pstate_config(void) ...@@ -3512,7 +3514,8 @@ dump_sysfs_pstate_config(void)
fprintf(outf, "NSFOD %s\n", path); fprintf(outf, "NSFOD %s\n", path);
return; return;
} }
fgets(driver_buf, sizeof(driver_buf), input); if (!fgets(driver_buf, sizeof(driver_buf), input))
err(1, "%s: failed to read file", path);
fclose(input); fclose(input);
sprintf(path, "/sys/devices/system/cpu/cpu%d/cpufreq/scaling_governor", sprintf(path, "/sys/devices/system/cpu/cpu%d/cpufreq/scaling_governor",
...@@ -3522,7 +3525,8 @@ dump_sysfs_pstate_config(void) ...@@ -3522,7 +3525,8 @@ dump_sysfs_pstate_config(void)
fprintf(outf, "NSFOD %s\n", path); fprintf(outf, "NSFOD %s\n", path);
return; return;
} }
fgets(governor_buf, sizeof(governor_buf), input); if (!fgets(governor_buf, sizeof(governor_buf), input))
err(1, "%s: failed to read file", path);
fclose(input); fclose(input);
fprintf(outf, "cpu%d: cpufreq driver: %s", base_cpu, driver_buf); fprintf(outf, "cpu%d: cpufreq driver: %s", base_cpu, driver_buf);
...@@ -3531,7 +3535,8 @@ dump_sysfs_pstate_config(void) ...@@ -3531,7 +3535,8 @@ dump_sysfs_pstate_config(void)
sprintf(path, "/sys/devices/system/cpu/cpufreq/boost"); sprintf(path, "/sys/devices/system/cpu/cpufreq/boost");
input = fopen(path, "r"); input = fopen(path, "r");
if (input != NULL) { if (input != NULL) {
fscanf(input, "%d", &turbo); if (fscanf(input, "%d", &turbo) != 1)
err(1, "%s: failed to parse number from file", path);
fprintf(outf, "cpufreq boost: %d\n", turbo); fprintf(outf, "cpufreq boost: %d\n", turbo);
fclose(input); fclose(input);
} }
...@@ -3539,7 +3544,8 @@ dump_sysfs_pstate_config(void) ...@@ -3539,7 +3544,8 @@ dump_sysfs_pstate_config(void)
sprintf(path, "/sys/devices/system/cpu/intel_pstate/no_turbo"); sprintf(path, "/sys/devices/system/cpu/intel_pstate/no_turbo");
input = fopen(path, "r"); input = fopen(path, "r");
if (input != NULL) { if (input != NULL) {
fscanf(input, "%d", &turbo); if (fscanf(input, "%d", &turbo) != 1)
err(1, "%s: failed to parse number from file", path);
fprintf(outf, "cpufreq intel_pstate no_turbo: %d\n", turbo); fprintf(outf, "cpufreq intel_pstate no_turbo: %d\n", turbo);
fclose(input); fclose(input);
} }
...@@ -5464,7 +5470,8 @@ void probe_sysfs(void) ...@@ -5464,7 +5470,8 @@ void probe_sysfs(void)
input = fopen(path, "r"); input = fopen(path, "r");
if (input == NULL) if (input == NULL)
continue; continue;
fgets(name_buf, sizeof(name_buf), input); if (!fgets(name_buf, sizeof(name_buf), input))
err(1, "%s: failed to read file", path);
/* truncate "C1-HSW\n" to "C1", or truncate "C1\n" to "C1" */ /* truncate "C1-HSW\n" to "C1", or truncate "C1\n" to "C1" */
sp = strchr(name_buf, '-'); sp = strchr(name_buf, '-');
...@@ -5491,7 +5498,8 @@ void probe_sysfs(void) ...@@ -5491,7 +5498,8 @@ void probe_sysfs(void)
input = fopen(path, "r"); input = fopen(path, "r");
if (input == NULL) if (input == NULL)
continue; continue;
fgets(name_buf, sizeof(name_buf), input); if (!fgets(name_buf, sizeof(name_buf), input))
err(1, "%s: failed to read file", path);
/* truncate "C1-HSW\n" to "C1", or truncate "C1\n" to "C1" */ /* truncate "C1-HSW\n" to "C1", or truncate "C1\n" to "C1" */
sp = strchr(name_buf, '-'); sp = strchr(name_buf, '-');
if (!sp) if (!sp)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment