Commit 20183ccd authored by Srinivas Pandruvada's avatar Srinivas Pandruvada Committed by Andy Shevchenko

tools/power/x86/intel-speed-select: Ignore missing config level

It is possible that certain config levels are not available, even
if the max level includes the level. There can be missing levels in
some platforms. So ignore the level when called for information dump
for all levels and fail if specifically ask for the missing level.

Here the changes is to continue reading information about other levels
even if we fail to get information for the current level. But use the
"processed" flag to indicate the failure. When the "processed" flag is
not set, don't dump information about that level.
Signed-off-by: default avatarSrinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
Signed-off-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
parent ee7b0d31
...@@ -646,7 +646,6 @@ int isst_get_process_ctdp(int cpu, int tdp_level, struct isst_pkg_ctdp *pkg_dev) ...@@ -646,7 +646,6 @@ int isst_get_process_ctdp(int cpu, int tdp_level, struct isst_pkg_ctdp *pkg_dev)
i); i);
ctdp_level = &pkg_dev->ctdp_level[i]; ctdp_level = &pkg_dev->ctdp_level[i];
ctdp_level->processed = 1;
ctdp_level->level = i; ctdp_level->level = i;
ctdp_level->control_cpu = cpu; ctdp_level->control_cpu = cpu;
ctdp_level->pkg_id = get_physical_package_id(cpu); ctdp_level->pkg_id = get_physical_package_id(cpu);
...@@ -654,7 +653,10 @@ int isst_get_process_ctdp(int cpu, int tdp_level, struct isst_pkg_ctdp *pkg_dev) ...@@ -654,7 +653,10 @@ int isst_get_process_ctdp(int cpu, int tdp_level, struct isst_pkg_ctdp *pkg_dev)
ret = isst_get_ctdp_control(cpu, i, ctdp_level); ret = isst_get_ctdp_control(cpu, i, ctdp_level);
if (ret) if (ret)
return ret; continue;
pkg_dev->processed = 1;
ctdp_level->processed = 1;
if (ctdp_level->pbf_support) { if (ctdp_level->pbf_support) {
ret = isst_get_pbf_info(cpu, i, &ctdp_level->pbf_info); ret = isst_get_pbf_info(cpu, i, &ctdp_level->pbf_info);
...@@ -724,8 +726,6 @@ int isst_get_process_ctdp(int cpu, int tdp_level, struct isst_pkg_ctdp *pkg_dev) ...@@ -724,8 +726,6 @@ int isst_get_process_ctdp(int cpu, int tdp_level, struct isst_pkg_ctdp *pkg_dev)
isst_get_uncore_mem_freq(cpu, i, ctdp_level); isst_get_uncore_mem_freq(cpu, i, ctdp_level);
} }
pkg_dev->processed = 1;
return 0; return 0;
} }
......
...@@ -315,6 +315,7 @@ void isst_ctdp_display_information(int cpu, FILE *outf, int tdp_level, ...@@ -315,6 +315,7 @@ void isst_ctdp_display_information(int cpu, FILE *outf, int tdp_level,
char value[256]; char value[256];
int i, base_level = 1; int i, base_level = 1;
if (pkg_dev->processed)
print_package_info(cpu, outf); print_package_info(cpu, outf);
for (i = 0; i <= pkg_dev->levels; ++i) { for (i = 0; i <= pkg_dev->levels; ++i) {
......
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