forked from Minki/linux
tools: bpftool: Update and synchronise option list in doc and help msg
All bpftool commands support the options for JSON output and debug from libbpf. In addition, some commands support additional options corresponding to specific use cases. The list of options described in the man pages for the different commands are not always accurate. The messages for interactive help are mostly limited to HELP_SPEC_OPTIONS, and are even less representative of the actual set of options supported for the commands. Let's update the lists: - HELP_SPEC_OPTIONS is modified to contain the "default" options (JSON and debug), and to be extensible (no ending curly bracket). - All commands use HELP_SPEC_OPTIONS in their help message, and then complete the list with their specific options. - The lists of options in the man pages are updated. - The formatting of the list for bpftool.rst is adjusted to match formatting for the other man pages. This is for consistency, and also because it will be helpful in a future patch to automatically check that the files are synchronised. Signed-off-by: Quentin Monnet <quentin@isovalent.com> Signed-off-by: Andrii Nakryiko <andrii@kernel.org> Link: https://lore.kernel.org/bpf/20210730215435.7095-5-quentin@isovalent.com
This commit is contained in:
parent
b544342e52
commit
c07ba629df
@ -12,7 +12,7 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **btf** *COMMAND*
|
**bpftool** [*OPTIONS*] **btf** *COMMAND*
|
||||||
|
|
||||||
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] }
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | {**-d** | **--debug** } }
|
||||||
|
|
||||||
*COMMANDS* := { **dump** | **help** }
|
*COMMANDS* := { **dump** | **help** }
|
||||||
|
|
||||||
|
@ -12,7 +12,8 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **cgroup** *COMMAND*
|
**bpftool** [*OPTIONS*] **cgroup** *COMMAND*
|
||||||
|
|
||||||
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-f** | **--bpffs** } }
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } |
|
||||||
|
{ **-f** | **--bpffs** } }
|
||||||
|
|
||||||
*COMMANDS* :=
|
*COMMANDS* :=
|
||||||
{ **show** | **list** | **tree** | **attach** | **detach** | **help** }
|
{ **show** | **list** | **tree** | **attach** | **detach** | **help** }
|
||||||
|
@ -12,7 +12,7 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **feature** *COMMAND*
|
**bpftool** [*OPTIONS*] **feature** *COMMAND*
|
||||||
|
|
||||||
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] }
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } }
|
||||||
|
|
||||||
*COMMANDS* := { **probe** | **help** }
|
*COMMANDS* := { **probe** | **help** }
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **gen** *COMMAND*
|
**bpftool** [*OPTIONS*] **gen** *COMMAND*
|
||||||
|
|
||||||
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] }
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } }
|
||||||
|
|
||||||
*COMMAND* := { **object** | **skeleton** | **help** }
|
*COMMAND* := { **object** | **skeleton** | **help** }
|
||||||
|
|
||||||
|
@ -12,6 +12,8 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **iter** *COMMAND*
|
**bpftool** [*OPTIONS*] **iter** *COMMAND*
|
||||||
|
|
||||||
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } }
|
||||||
|
|
||||||
*COMMANDS* := { **pin** | **help** }
|
*COMMANDS* := { **pin** | **help** }
|
||||||
|
|
||||||
ITER COMMANDS
|
ITER COMMANDS
|
||||||
|
@ -12,7 +12,8 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **link** *COMMAND*
|
**bpftool** [*OPTIONS*] **link** *COMMAND*
|
||||||
|
|
||||||
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-f** | **--bpffs** } }
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } |
|
||||||
|
{ **-f** | **--bpffs** } | { **-n** | **--nomount** } }
|
||||||
|
|
||||||
*COMMANDS* := { **show** | **list** | **pin** | **help** }
|
*COMMANDS* := { **show** | **list** | **pin** | **help** }
|
||||||
|
|
||||||
|
@ -12,7 +12,8 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **map** *COMMAND*
|
**bpftool** [*OPTIONS*] **map** *COMMAND*
|
||||||
|
|
||||||
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-f** | **--bpffs** } }
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } |
|
||||||
|
{ **-f** | **--bpffs** } | { **-n** | **--nomount** } }
|
||||||
|
|
||||||
*COMMANDS* :=
|
*COMMANDS* :=
|
||||||
{ **show** | **list** | **create** | **dump** | **update** | **lookup** | **getnext**
|
{ **show** | **list** | **create** | **dump** | **update** | **lookup** | **getnext**
|
||||||
|
@ -12,7 +12,7 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **net** *COMMAND*
|
**bpftool** [*OPTIONS*] **net** *COMMAND*
|
||||||
|
|
||||||
*OPTIONS* := { [{ **-j** | **--json** }] [{ **-p** | **--pretty** }] }
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } }
|
||||||
|
|
||||||
*COMMANDS* :=
|
*COMMANDS* :=
|
||||||
{ **show** | **list** | **attach** | **detach** | **help** }
|
{ **show** | **list** | **attach** | **detach** | **help** }
|
||||||
|
@ -12,7 +12,7 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **perf** *COMMAND*
|
**bpftool** [*OPTIONS*] **perf** *COMMAND*
|
||||||
|
|
||||||
*OPTIONS* := { [{ **-j** | **--json** }] [{ **-p** | **--pretty** }] }
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } }
|
||||||
|
|
||||||
*COMMANDS* :=
|
*COMMANDS* :=
|
||||||
{ **show** | **list** | **help** }
|
{ **show** | **list** | **help** }
|
||||||
|
@ -12,7 +12,8 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **prog** *COMMAND*
|
**bpftool** [*OPTIONS*] **prog** *COMMAND*
|
||||||
|
|
||||||
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-f** | **--bpffs** } }
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } |
|
||||||
|
{ **-f** | **--bpffs** } | { **-m** | **--mapcompat** } | { **-n** | **--nomount** } }
|
||||||
|
|
||||||
*COMMANDS* :=
|
*COMMANDS* :=
|
||||||
{ **show** | **list** | **dump xlated** | **dump jited** | **pin** | **load**
|
{ **show** | **list** | **dump xlated** | **dump jited** | **pin** | **load**
|
||||||
|
@ -12,7 +12,7 @@ SYNOPSIS
|
|||||||
|
|
||||||
**bpftool** [*OPTIONS*] **struct_ops** *COMMAND*
|
**bpftool** [*OPTIONS*] **struct_ops** *COMMAND*
|
||||||
|
|
||||||
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] }
|
*OPTIONS* := { { **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } }
|
||||||
|
|
||||||
*COMMANDS* :=
|
*COMMANDS* :=
|
||||||
{ **show** | **list** | **dump** | **register** | **unregister** | **help** }
|
{ **show** | **list** | **dump** | **register** | **unregister** | **help** }
|
||||||
|
@ -18,15 +18,15 @@ SYNOPSIS
|
|||||||
|
|
||||||
*OBJECT* := { **map** | **program** | **cgroup** | **perf** | **net** | **feature** }
|
*OBJECT* := { **map** | **program** | **cgroup** | **perf** | **net** | **feature** }
|
||||||
|
|
||||||
*OPTIONS* := { { **-V** | **--version** } | { **-h** | **--help** }
|
*OPTIONS* := { { **-V** | **--version** } |
|
||||||
| { **-j** | **--json** } [{ **-p** | **--pretty** }] }
|
{ **-j** | **--json** } [{ **-p** | **--pretty** }] | { **-d** | **--debug** } }
|
||||||
|
|
||||||
*MAP-COMMANDS* :=
|
*MAP-COMMANDS* :=
|
||||||
{ **show** | **list** | **create** | **dump** | **update** | **lookup** | **getnext**
|
{ **show** | **list** | **create** | **dump** | **update** | **lookup** | **getnext** |
|
||||||
| **delete** | **pin** | **event_pipe** | **help** }
|
**delete** | **pin** | **event_pipe** | **help** }
|
||||||
|
|
||||||
*PROG-COMMANDS* := { **show** | **list** | **dump jited** | **dump xlated** | **pin**
|
*PROG-COMMANDS* := { **show** | **list** | **dump jited** | **dump xlated** | **pin** |
|
||||||
| **load** | **attach** | **detach** | **help** }
|
**load** | **attach** | **detach** | **help** }
|
||||||
|
|
||||||
*CGROUP-COMMANDS* := { **show** | **list** | **attach** | **detach** | **help** }
|
*CGROUP-COMMANDS* := { **show** | **list** | **attach** | **detach** | **help** }
|
||||||
|
|
||||||
|
@ -981,7 +981,7 @@ static int do_help(int argc, char **argv)
|
|||||||
" FORMAT := { raw | c }\n"
|
" FORMAT := { raw | c }\n"
|
||||||
" " HELP_SPEC_MAP "\n"
|
" " HELP_SPEC_MAP "\n"
|
||||||
" " HELP_SPEC_PROGRAM "\n"
|
" " HELP_SPEC_PROGRAM "\n"
|
||||||
" " HELP_SPEC_OPTIONS "\n"
|
" " HELP_SPEC_OPTIONS " }\n"
|
||||||
"",
|
"",
|
||||||
bin_name, "btf");
|
bin_name, "btf");
|
||||||
|
|
||||||
|
@ -501,7 +501,8 @@ static int do_help(int argc, char **argv)
|
|||||||
HELP_SPEC_ATTACH_TYPES "\n"
|
HELP_SPEC_ATTACH_TYPES "\n"
|
||||||
" " HELP_SPEC_ATTACH_FLAGS "\n"
|
" " HELP_SPEC_ATTACH_FLAGS "\n"
|
||||||
" " HELP_SPEC_PROGRAM "\n"
|
" " HELP_SPEC_PROGRAM "\n"
|
||||||
" " HELP_SPEC_OPTIONS "\n"
|
" " HELP_SPEC_OPTIONS " |\n"
|
||||||
|
" {-f|--bpffs} }
|
||||||
"",
|
"",
|
||||||
bin_name, argv[-2]);
|
bin_name, argv[-2]);
|
||||||
|
|
||||||
|
@ -1005,6 +1005,7 @@ static int do_help(int argc, char **argv)
|
|||||||
" %1$s %2$s help\n"
|
" %1$s %2$s help\n"
|
||||||
"\n"
|
"\n"
|
||||||
" COMPONENT := { kernel | dev NAME }\n"
|
" COMPONENT := { kernel | dev NAME }\n"
|
||||||
|
" " HELP_SPEC_OPTIONS " }\n"
|
||||||
"",
|
"",
|
||||||
bin_name, argv[-2]);
|
bin_name, argv[-2]);
|
||||||
|
|
||||||
|
@ -1026,7 +1026,7 @@ static int do_help(int argc, char **argv)
|
|||||||
" %1$s %2$s skeleton FILE [name OBJECT_NAME]\n"
|
" %1$s %2$s skeleton FILE [name OBJECT_NAME]\n"
|
||||||
" %1$s %2$s help\n"
|
" %1$s %2$s help\n"
|
||||||
"\n"
|
"\n"
|
||||||
" " HELP_SPEC_OPTIONS "\n"
|
" " HELP_SPEC_OPTIONS " }\n"
|
||||||
"",
|
"",
|
||||||
bin_name, "gen");
|
bin_name, "gen");
|
||||||
|
|
||||||
|
@ -97,7 +97,9 @@ static int do_help(int argc, char **argv)
|
|||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"Usage: %1$s %2$s pin OBJ PATH [map MAP]\n"
|
"Usage: %1$s %2$s pin OBJ PATH [map MAP]\n"
|
||||||
" %1$s %2$s help\n"
|
" %1$s %2$s help\n"
|
||||||
|
"\n"
|
||||||
" " HELP_SPEC_MAP "\n"
|
" " HELP_SPEC_MAP "\n"
|
||||||
|
" " HELP_SPEC_OPTIONS " }\n"
|
||||||
"",
|
"",
|
||||||
bin_name, "iter");
|
bin_name, "iter");
|
||||||
|
|
||||||
|
@ -401,7 +401,8 @@ static int do_help(int argc, char **argv)
|
|||||||
" %1$s %2$s help\n"
|
" %1$s %2$s help\n"
|
||||||
"\n"
|
"\n"
|
||||||
" " HELP_SPEC_LINK "\n"
|
" " HELP_SPEC_LINK "\n"
|
||||||
" " HELP_SPEC_OPTIONS "\n"
|
" " HELP_SPEC_OPTIONS " |\n"
|
||||||
|
" {-f|--bpffs} | {-n|--nomount} }\n"
|
||||||
"",
|
"",
|
||||||
bin_name, argv[-2]);
|
bin_name, argv[-2]);
|
||||||
|
|
||||||
|
@ -64,7 +64,8 @@ static int do_help(int argc, char **argv)
|
|||||||
" %s version\n"
|
" %s version\n"
|
||||||
"\n"
|
"\n"
|
||||||
" OBJECT := { prog | map | link | cgroup | perf | net | feature | btf | gen | struct_ops | iter }\n"
|
" OBJECT := { prog | map | link | cgroup | perf | net | feature | btf | gen | struct_ops | iter }\n"
|
||||||
" " HELP_SPEC_OPTIONS "\n"
|
" " HELP_SPEC_OPTIONS " |\n"
|
||||||
|
" {-V|--version} }\n"
|
||||||
"",
|
"",
|
||||||
bin_name, bin_name, bin_name);
|
bin_name, bin_name, bin_name);
|
||||||
|
|
||||||
|
@ -57,8 +57,7 @@ static inline void *u64_to_ptr(__u64 ptr)
|
|||||||
#define HELP_SPEC_PROGRAM \
|
#define HELP_SPEC_PROGRAM \
|
||||||
"PROG := { id PROG_ID | pinned FILE | tag PROG_TAG | name PROG_NAME }"
|
"PROG := { id PROG_ID | pinned FILE | tag PROG_TAG | name PROG_NAME }"
|
||||||
#define HELP_SPEC_OPTIONS \
|
#define HELP_SPEC_OPTIONS \
|
||||||
"OPTIONS := { {-j|--json} [{-p|--pretty}] | {-f|--bpffs} |\n" \
|
"OPTIONS := { {-j|--json} [{-p|--pretty}] | {-d|--debug}"
|
||||||
"\t {-m|--mapcompat} | {-n|--nomount} }"
|
|
||||||
#define HELP_SPEC_MAP \
|
#define HELP_SPEC_MAP \
|
||||||
"MAP := { id MAP_ID | pinned FILE | name MAP_NAME }"
|
"MAP := { id MAP_ID | pinned FILE | name MAP_NAME }"
|
||||||
#define HELP_SPEC_LINK \
|
#define HELP_SPEC_LINK \
|
||||||
|
@ -1466,8 +1466,9 @@ static int do_help(int argc, char **argv)
|
|||||||
" devmap | devmap_hash | sockmap | cpumap | xskmap | sockhash |\n"
|
" devmap | devmap_hash | sockmap | cpumap | xskmap | sockhash |\n"
|
||||||
" cgroup_storage | reuseport_sockarray | percpu_cgroup_storage |\n"
|
" cgroup_storage | reuseport_sockarray | percpu_cgroup_storage |\n"
|
||||||
" queue | stack | sk_storage | struct_ops | ringbuf | inode_storage |\n"
|
" queue | stack | sk_storage | struct_ops | ringbuf | inode_storage |\n"
|
||||||
" task_storage }\n"
|
" task_storage }\n"
|
||||||
" " HELP_SPEC_OPTIONS "\n"
|
" " HELP_SPEC_OPTIONS " |\n"
|
||||||
|
" {-f|--bpffs} | {-n|--nomount} }\n"
|
||||||
"",
|
"",
|
||||||
bin_name, argv[-2]);
|
bin_name, argv[-2]);
|
||||||
|
|
||||||
|
@ -729,6 +729,7 @@ static int do_help(int argc, char **argv)
|
|||||||
"\n"
|
"\n"
|
||||||
" " HELP_SPEC_PROGRAM "\n"
|
" " HELP_SPEC_PROGRAM "\n"
|
||||||
" ATTACH_TYPE := { xdp | xdpgeneric | xdpdrv | xdpoffload }\n"
|
" ATTACH_TYPE := { xdp | xdpgeneric | xdpdrv | xdpoffload }\n"
|
||||||
|
" " HELP_SPEC_OPTIONS " }\n"
|
||||||
"\n"
|
"\n"
|
||||||
"Note: Only xdp and tc attachments are supported now.\n"
|
"Note: Only xdp and tc attachments are supported now.\n"
|
||||||
" For progs attached to cgroups, use \"bpftool cgroup\"\n"
|
" For progs attached to cgroups, use \"bpftool cgroup\"\n"
|
||||||
|
@ -231,7 +231,10 @@ static int do_show(int argc, char **argv)
|
|||||||
static int do_help(int argc, char **argv)
|
static int do_help(int argc, char **argv)
|
||||||
{
|
{
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"Usage: %1$s %2$s { show | list | help }\n"
|
"Usage: %1$s %2$s { show | list }\n"
|
||||||
|
" %1$s %2$s help }\n"
|
||||||
|
"\n"
|
||||||
|
" " HELP_SPEC_OPTIONS " }\n"
|
||||||
"",
|
"",
|
||||||
bin_name, argv[-2]);
|
bin_name, argv[-2]);
|
||||||
|
|
||||||
|
@ -2259,7 +2259,8 @@ static int do_help(int argc, char **argv)
|
|||||||
" ATTACH_TYPE := { msg_verdict | skb_verdict | stream_verdict |\n"
|
" ATTACH_TYPE := { msg_verdict | skb_verdict | stream_verdict |\n"
|
||||||
" stream_parser | flow_dissector }\n"
|
" stream_parser | flow_dissector }\n"
|
||||||
" METRIC := { cycles | instructions | l1d_loads | llc_misses | itlb_misses | dtlb_misses }\n"
|
" METRIC := { cycles | instructions | l1d_loads | llc_misses | itlb_misses | dtlb_misses }\n"
|
||||||
" " HELP_SPEC_OPTIONS "\n"
|
" " HELP_SPEC_OPTIONS " |\n"
|
||||||
|
" {-f|--bpffs} | {-m|--mapcompat} | {-n|--nomount} }\n"
|
||||||
"",
|
"",
|
||||||
bin_name, argv[-2]);
|
bin_name, argv[-2]);
|
||||||
|
|
||||||
|
@ -572,8 +572,8 @@ static int do_help(int argc, char **argv)
|
|||||||
" %1$s %2$s unregister STRUCT_OPS_MAP\n"
|
" %1$s %2$s unregister STRUCT_OPS_MAP\n"
|
||||||
" %1$s %2$s help\n"
|
" %1$s %2$s help\n"
|
||||||
"\n"
|
"\n"
|
||||||
" OPTIONS := { {-j|--json} [{-p|--pretty}] }\n"
|
|
||||||
" STRUCT_OPS_MAP := [ id STRUCT_OPS_MAP_ID | name STRUCT_OPS_MAP_NAME ]\n"
|
" STRUCT_OPS_MAP := [ id STRUCT_OPS_MAP_ID | name STRUCT_OPS_MAP_NAME ]\n"
|
||||||
|
" " HELP_SPEC_OPTIONS " }\n"
|
||||||
"",
|
"",
|
||||||
bin_name, argv[-2]);
|
bin_name, argv[-2]);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user