2 * kmod - one tool to rule them all
4 * Copyright (C) 2011-2013 ProFUSION embedded systems
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
30 static const char options_s
[] = "+hV";
31 static const struct option options
[] = {
32 { "help", no_argument
, NULL
, 'h' },
33 { "version", no_argument
, NULL
, 'V' },
37 static const struct kmod_cmd kmod_cmd_help
;
39 static const struct kmod_cmd
*kmod_cmds
[] = {
42 &kmod_cmd_static_nodes
,
45 static const struct kmod_cmd
*kmod_compat_cmds
[] = {
46 &kmod_cmd_compat_lsmod
,
47 &kmod_cmd_compat_rmmod
,
48 &kmod_cmd_compat_insmod
,
49 &kmod_cmd_compat_modinfo
,
50 &kmod_cmd_compat_modprobe
,
51 &kmod_cmd_compat_depmod
,
54 static int kmod_help(int argc
, char *argv
[])
58 printf("kmod - Manage kernel modules: list, load, unload, etc\n"
60 "\t%s [options] command [command_options]\n\n"
62 "\t-V, --version show version\n"
63 "\t-h, --help show this help\n\n"
64 "Commands:\n", basename(argv
[0]));
66 for (i
= 0; i
< ARRAY_SIZE(kmod_cmds
); i
++) {
67 if (kmod_cmds
[i
]->help
!= NULL
) {
68 printf(" %-12s %s\n", kmod_cmds
[i
]->name
,
73 puts("\nkmod also handles gracefully if called from following symlinks:");
75 for (i
= 0; i
< ARRAY_SIZE(kmod_compat_cmds
); i
++) {
76 if (kmod_compat_cmds
[i
]->help
!= NULL
) {
77 printf(" %-12s %s\n", kmod_compat_cmds
[i
]->name
,
78 kmod_compat_cmds
[i
]->help
);
85 static const struct kmod_cmd kmod_cmd_help
= {
88 .help
= "Show help message",
91 static int handle_kmod_commands(int argc
, char *argv
[])
100 c
= getopt_long(argc
, argv
, options_s
, options
, NULL
);
106 kmod_help(argc
, argv
);
109 puts("kmod version " VERSION
);
114 fprintf(stderr
, "Error: unexpected getopt_long() value '%c'.\n", c
);
119 if (optind
>= argc
) {
120 fputs("missing command\n", stderr
);
126 for (i
= 0, err
= -EINVAL
; i
< ARRAY_SIZE(kmod_cmds
); i
++) {
127 if (strcmp(kmod_cmds
[i
]->name
, cmd
) != 0)
130 err
= kmod_cmds
[i
]->cmd(--argc
, ++argv
);
134 fprintf(stderr
, "invalid command '%s'\n", cmd
);
141 kmod_help(argc
, argv
);
146 static int handle_kmod_compat_commands(int argc
, char *argv
[])
151 cmd
= basename(argv
[0]);
153 for (i
= 0; i
< ARRAY_SIZE(kmod_compat_cmds
); i
++) {
154 if (strcmp(kmod_compat_cmds
[i
]->name
, cmd
) == 0)
155 return kmod_compat_cmds
[i
]->cmd(argc
, argv
);
161 int main(int argc
, char *argv
[])
165 if (strcmp(program_invocation_short_name
, "kmod") == 0)
166 err
= handle_kmod_commands(argc
, argv
);
168 err
= handle_kmod_compat_commands(argc
, argv
);