Commit d80a4ac2 authored by Abhishek Goel's avatar Abhishek Goel Committed by Shuah Khan

cpupower : Handle set and info subcommands correctly

Cpupower tool has set and info options which are being used only by
x86 machines. This patch removes support for these two subcommands
from cpupower utility for POWER. Thus, these two subcommands will now be
available only for intel.
This removes the ambiguous error message while using set option in case
of using non-intel systems.

Without this patch on a POWER system:

root@ubuntu:~# cpupower info
System does not support Intel's performance bias setting

root@ubuntu:~# cpupower set -b 10
Error setting perf-bias value on CPU

With this patch on a POWER box:

root@ubuntu:~# cpupower info
Subcommand not supported on POWER

Same result for set subcommand.
This patch does not affect results on a intel box.
Signed-off-by: default avatarAbhishek Goel <huntbag@linux.vnet.ibm.com>
Acked-by: default avatarThomas Renninger <trenn@suse.de>
Reviewed-by: default avatarShuah Khan <skhan@linuxfoundation.org>
Signed-off-by: default avatarShuah Khan <skhan@linuxfoundation.org>
parent 7e5705c6
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include <errno.h> #include <errno.h>
#include <string.h> #include <string.h>
#include <getopt.h> #include <getopt.h>
#include <sys/utsname.h>
#include "helpers/helpers.h" #include "helpers/helpers.h"
#include "helpers/sysfs.h" #include "helpers/sysfs.h"
...@@ -30,6 +31,7 @@ int cmd_info(int argc, char **argv) ...@@ -30,6 +31,7 @@ int cmd_info(int argc, char **argv)
extern char *optarg; extern char *optarg;
extern int optind, opterr, optopt; extern int optind, opterr, optopt;
unsigned int cpu; unsigned int cpu;
struct utsname uts;
union { union {
struct { struct {
...@@ -39,6 +41,13 @@ int cmd_info(int argc, char **argv) ...@@ -39,6 +41,13 @@ int cmd_info(int argc, char **argv)
} params = {}; } params = {};
int ret = 0; int ret = 0;
ret = uname(&uts);
if (!ret && (!strcmp(uts.machine, "ppc64le") ||
!strcmp(uts.machine, "ppc64"))) {
fprintf(stderr, _("Subcommand not supported on POWER.\n"));
return ret;
}
setlocale(LC_ALL, ""); setlocale(LC_ALL, "");
textdomain(PACKAGE); textdomain(PACKAGE);
......
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include <errno.h> #include <errno.h>
#include <string.h> #include <string.h>
#include <getopt.h> #include <getopt.h>
#include <sys/utsname.h>
#include "helpers/helpers.h" #include "helpers/helpers.h"
#include "helpers/sysfs.h" #include "helpers/sysfs.h"
...@@ -31,6 +32,7 @@ int cmd_set(int argc, char **argv) ...@@ -31,6 +32,7 @@ int cmd_set(int argc, char **argv)
extern char *optarg; extern char *optarg;
extern int optind, opterr, optopt; extern int optind, opterr, optopt;
unsigned int cpu; unsigned int cpu;
struct utsname uts;
union { union {
struct { struct {
...@@ -41,6 +43,13 @@ int cmd_set(int argc, char **argv) ...@@ -41,6 +43,13 @@ int cmd_set(int argc, char **argv)
int perf_bias = 0; int perf_bias = 0;
int ret = 0; int ret = 0;
ret = uname(&uts);
if (!ret && (!strcmp(uts.machine, "ppc64le") ||
!strcmp(uts.machine, "ppc64"))) {
fprintf(stderr, _("Subcommand not supported on POWER.\n"));
return ret;
}
setlocale(LC_ALL, ""); setlocale(LC_ALL, "");
textdomain(PACKAGE); textdomain(PACKAGE);
......
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