Commit d9149996 authored by Tobin C. Harding's avatar Tobin C. Harding Committed by Linus Torvalds

tools/vm/slabinfo: order command line options

During recent discussion on LKML over SLAB vs SLUB it was suggested by
Jesper that it would be nice to have a tool to view the current
fragmentation of the slab allocators.  CC list for this set is taken
from that thread.

For SLUB we have all the information for this already exposed by the
kernel and also we have a userspace tool for displaying this info:

	tools/vm/slabinfo.c

Extend slabinfo to improve the fragmentation information by enabling
sorting of caches by number of partial slabs.

Also add cache list sorted in this manner to the output of `slabinfo -X`.

This patch (of 4):

get_opt() has a spurious character within the option string.  Remove it
and reorder the options in alphabetic order so that it is easier to keep
the options correct.  Use the same ordering for command help output and
long option handling code.

Link: http://lkml.kernel.org/r/20190426022622.4089-2-tobin@kernel.orgSigned-off-by: default avatarTobin C. Harding <tobin@kernel.org>
Cc: Jesper Dangaard Brouer <brouer@redhat.com>
Cc: Pekka Enberg <penberg@iki.fi>
Cc: Vlastimil Babka <vbabka@suse.cz>
Cc: Christoph Lameter <cl@linux.com>
Cc: David Rientjes <rientjes@google.com>
Cc: Joonsoo Kim <iamjoonsoo.kim@lge.com>
Cc: Tejun Heo <tj@kernel.org>
Cc: Qian Cai <cai@lca.pw>
Cc: Mel Gorman <mgorman@techsingularity.net>
Cc: Alexander Duyck <alexander.duyck@gmail.com>
Cc: Michal Hocko <mhocko@kernel.org>
Cc: Brendan Gregg <brendan.d.gregg@gmail.com>,
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 98879b3b
...@@ -110,7 +110,7 @@ static void fatal(const char *x, ...) ...@@ -110,7 +110,7 @@ static void fatal(const char *x, ...)
static void usage(void) static void usage(void)
{ {
printf("slabinfo 4/15/2011. (c) 2007 sgi/(c) 2011 Linux Foundation.\n\n" printf("slabinfo 4/15/2011. (c) 2007 sgi/(c) 2011 Linux Foundation.\n\n"
"slabinfo [-aADefhilnosrStTvz1LXBU] [N=K] [-dafzput] [slab-regexp]\n" "slabinfo [-aABDefhilLnorsStTUvXz1] [N=K] [-dafzput] [slab-regexp]\n"
"-a|--aliases Show aliases\n" "-a|--aliases Show aliases\n"
"-A|--activity Most active slabs first\n" "-A|--activity Most active slabs first\n"
"-B|--Bytes Show size in bytes\n" "-B|--Bytes Show size in bytes\n"
...@@ -131,9 +131,9 @@ static void usage(void) ...@@ -131,9 +131,9 @@ static void usage(void)
"-T|--Totals Show summary information\n" "-T|--Totals Show summary information\n"
"-U|--Unreclaim Show unreclaimable slabs only\n" "-U|--Unreclaim Show unreclaimable slabs only\n"
"-v|--validate Validate slabs\n" "-v|--validate Validate slabs\n"
"-X|--Xtotals Show extended summary information\n"
"-z|--zero Include empty slabs\n" "-z|--zero Include empty slabs\n"
"-1|--1ref Single reference\n" "-1|--1ref Single reference\n"
"-X|--Xtotals Show extended summary information\n"
"\n" "\n"
"-d | --debug Switch off all debug options\n" "-d | --debug Switch off all debug options\n"
...@@ -1334,6 +1334,7 @@ static void xtotals(void) ...@@ -1334,6 +1334,7 @@ static void xtotals(void)
struct option opts[] = { struct option opts[] = {
{ "aliases", no_argument, NULL, 'a' }, { "aliases", no_argument, NULL, 'a' },
{ "activity", no_argument, NULL, 'A' }, { "activity", no_argument, NULL, 'A' },
{ "Bytes", no_argument, NULL, 'B'},
{ "debug", optional_argument, NULL, 'd' }, { "debug", optional_argument, NULL, 'd' },
{ "display-activity", no_argument, NULL, 'D' }, { "display-activity", no_argument, NULL, 'D' },
{ "empty", no_argument, NULL, 'e' }, { "empty", no_argument, NULL, 'e' },
...@@ -1341,21 +1342,20 @@ struct option opts[] = { ...@@ -1341,21 +1342,20 @@ struct option opts[] = {
{ "help", no_argument, NULL, 'h' }, { "help", no_argument, NULL, 'h' },
{ "inverted", no_argument, NULL, 'i'}, { "inverted", no_argument, NULL, 'i'},
{ "slabs", no_argument, NULL, 'l' }, { "slabs", no_argument, NULL, 'l' },
{ "Loss", no_argument, NULL, 'L'},
{ "numa", no_argument, NULL, 'n' }, { "numa", no_argument, NULL, 'n' },
{ "lines", required_argument, NULL, 'N'},
{ "ops", no_argument, NULL, 'o' }, { "ops", no_argument, NULL, 'o' },
{ "shrink", no_argument, NULL, 's' },
{ "report", no_argument, NULL, 'r' }, { "report", no_argument, NULL, 'r' },
{ "shrink", no_argument, NULL, 's' },
{ "Size", no_argument, NULL, 'S'}, { "Size", no_argument, NULL, 'S'},
{ "tracking", no_argument, NULL, 't'}, { "tracking", no_argument, NULL, 't'},
{ "Totals", no_argument, NULL, 'T'}, { "Totals", no_argument, NULL, 'T'},
{ "Unreclaim", no_argument, NULL, 'U'},
{ "validate", no_argument, NULL, 'v' }, { "validate", no_argument, NULL, 'v' },
{ "Xtotals", no_argument, NULL, 'X'},
{ "zero", no_argument, NULL, 'z' }, { "zero", no_argument, NULL, 'z' },
{ "1ref", no_argument, NULL, '1'}, { "1ref", no_argument, NULL, '1'},
{ "lines", required_argument, NULL, 'N'},
{ "Loss", no_argument, NULL, 'L'},
{ "Xtotals", no_argument, NULL, 'X'},
{ "Bytes", no_argument, NULL, 'B'},
{ "Unreclaim", no_argument, NULL, 'U'},
{ NULL, 0, NULL, 0 } { NULL, 0, NULL, 0 }
}; };
...@@ -1367,18 +1367,18 @@ int main(int argc, char *argv[]) ...@@ -1367,18 +1367,18 @@ int main(int argc, char *argv[])
page_size = getpagesize(); page_size = getpagesize();
while ((c = getopt_long(argc, argv, "aAd::Defhil1noprstvzTSN:LXBU", while ((c = getopt_long(argc, argv, "aABd::DefhilLnN:orsStTUvXz1",
opts, NULL)) != -1) opts, NULL)) != -1)
switch (c) { switch (c) {
case '1':
show_single_ref = 1;
break;
case 'a': case 'a':
show_alias = 1; show_alias = 1;
break; break;
case 'A': case 'A':
sort_active = 1; sort_active = 1;
break; break;
case 'B':
show_bytes = 1;
break;
case 'd': case 'd':
set_debug = 1; set_debug = 1;
if (!debug_opt_scan(optarg)) if (!debug_opt_scan(optarg))
...@@ -1399,9 +1399,22 @@ int main(int argc, char *argv[]) ...@@ -1399,9 +1399,22 @@ int main(int argc, char *argv[])
case 'i': case 'i':
show_inverted = 1; show_inverted = 1;
break; break;
case 'l':
show_slab = 1;
break;
case 'L':
sort_loss = 1;
break;
case 'n': case 'n':
show_numa = 1; show_numa = 1;
break; break;
case 'N':
if (optarg) {
output_lines = atoi(optarg);
if (output_lines < 1)
output_lines = 1;
}
break;
case 'o': case 'o':
show_ops = 1; show_ops = 1;
break; break;
...@@ -1411,33 +1424,20 @@ int main(int argc, char *argv[]) ...@@ -1411,33 +1424,20 @@ int main(int argc, char *argv[])
case 's': case 's':
shrink = 1; shrink = 1;
break; break;
case 'l': case 'S':
show_slab = 1; sort_size = 1;
break; break;
case 't': case 't':
show_track = 1; show_track = 1;
break; break;
case 'v':
validate = 1;
break;
case 'z':
skip_zero = 0;
break;
case 'T': case 'T':
show_totals = 1; show_totals = 1;
break; break;
case 'S': case 'U':
sort_size = 1; unreclaim_only = 1;
break;
case 'N':
if (optarg) {
output_lines = atoi(optarg);
if (output_lines < 1)
output_lines = 1;
}
break; break;
case 'L': case 'v':
sort_loss = 1; validate = 1;
break; break;
case 'X': case 'X':
if (output_lines == -1) if (output_lines == -1)
...@@ -1445,11 +1445,11 @@ int main(int argc, char *argv[]) ...@@ -1445,11 +1445,11 @@ int main(int argc, char *argv[])
extended_totals = 1; extended_totals = 1;
show_bytes = 1; show_bytes = 1;
break; break;
case 'B': case 'z':
show_bytes = 1; skip_zero = 0;
break; break;
case 'U': case '1':
unreclaim_only = 1; show_single_ref = 1;
break; break;
default: default:
fatal("%s: Invalid option '%c'\n", argv[0], optopt); fatal("%s: Invalid option '%c'\n", argv[0], optopt);
......
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