From: Heiko Carstens Date: Wed, 8 Aug 2012 08:52:47 +0000 (+0200) Subject: lscpu: limit options --all, --online, --offline to parsable and extended output X-Git-Tag: v2.22-rc2~22 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=7fc12cd2760f8f2858eef8bd7e170cef9932d26f;p=thirdparty%2Futil-linux.git lscpu: limit options --all, --online, --offline to parsable and extended output Passing the --all, --online or --offline options for the output summary doesn't make much sense. It should be limited to the two list output options. Signed-off-by: Heiko Carstens --- diff --git a/sys-utils/lscpu.1 b/sys-utils/lscpu.1 index 41dae83699..f7e34b95d8 100644 --- a/sys-utils/lscpu.1 +++ b/sys-utils/lscpu.1 @@ -81,13 +81,16 @@ and hypervisor support CPU polarization. .SH OPTIONS .TP .BR \-a , " \-\-all" -Include online and offline CPUs in the output (default for -e). +Include lines for online and offline CPUs in the output (default for -e). This +option may only specified together with option -e or -p. .TP .BR \-b , " \-\-online" -Limit the output to online CPUs (default for -p). +Limit the output to online CPUs (default for -p). This option may only +be specified together with option -e or -p. .TP .BR \-c , " \-\-offline" -Limit the output to offline CPUs. +Limit the output to offline CPUs. This option may only be specified together +with option -e or -p. .TP .BR \-e , " \-\-extended " \fI[=list]\fP Display the CPU information in human readable format. diff --git a/sys-utils/lscpu.c b/sys-utils/lscpu.c index b93998a5aa..25a027345a 100644 --- a/sys-utils/lscpu.c +++ b/sys-utils/lscpu.c @@ -1243,6 +1243,7 @@ int main(int argc, char *argv[]) struct lscpu_desc _desc = { .flags = 0 }, *desc = &_desc; int c, i; int columns[ARRAY_SIZE(coldescs)], ncolumns = 0; + int cpu_modifier_specified = 0; static const struct option longopts[] = { { "all", no_argument, 0, 'a' }, @@ -1276,12 +1277,15 @@ int main(int argc, char *argv[]) switch (c) { case 'a': mod->online = mod->offline = 1; + cpu_modifier_specified = 1; break; case 'b': mod->online = 1; + cpu_modifier_specified = 1; break; case 'c': mod->offline = 1; + cpu_modifier_specified = 1; break; case 'h': usage(stdout); @@ -1316,6 +1320,14 @@ int main(int argc, char *argv[]) } } + if (cpu_modifier_specified && mod->mode == OUTPUT_SUMMARY) { + fprintf(stderr, + _("%s: options --all, --online and --offline may only " + "be used with options --extended or --parsable.\n"), + program_invocation_short_name); + return EXIT_FAILURE; + } + if (argc != optind) usage(stderr);