diff options
author | Tim Riker | 2002-12-14 01:58:59 +0000 |
---|---|---|
committer | Tim Riker | 2002-12-14 01:58:59 +0000 |
commit | cf93274663877cb4d722a23d8c418470eb90332a (patch) | |
tree | a056983d1162502b58e2aca4c2ebf3c9c7b9c6be /modutils/rmmod.c | |
parent | 6fe1960ff5e4c7c993a8bc3add5361ee55323afe (diff) | |
download | busybox-cf93274663877cb4d722a23d8c418470eb90332a.zip busybox-cf93274663877cb4d722a23d8c418470eb90332a.tar.gz |
rmmod -a removed modules recursively
Diffstat (limited to 'modutils/rmmod.c')
-rw-r--r-- | modutils/rmmod.c | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/modutils/rmmod.c b/modutils/rmmod.c index affe975..0103d91 100644 --- a/modutils/rmmod.c +++ b/modutils/rmmod.c @@ -34,14 +34,30 @@ extern int delete_module(const char * name); extern int rmmod_main(int argc, char **argv) { int n, ret = EXIT_SUCCESS; + size_t nmod = 0; /* number of modules */ + size_t pnmod = -1; /* previous number of modules */ + void *buf; /* hold the module names which we ignore but must get */ + size_t bufsize = 0; /* Parse command line. */ while ((n = getopt(argc, argv, "a")) != EOF) { switch (n) { case 'a': /* Unload _all_ unused modules via NULL delete_module() call */ - if (delete_module(NULL)) - perror_msg_and_die("rmmod"); + /* until the number of modules does not change */ + buf = xmalloc(bufsize = 256); + while (nmod != pnmod) { + if (delete_module(NULL)) + perror_msg_and_die("rmmod"); + pnmod = nmod; + /* 1 == QM_MODULES */ + if (my_query_module(NULL, 1, &buf, &bufsize, &nmod)) { + perror_msg_and_die("QM_MODULES"); + } + } +#ifdef CONFIG_FEATURE_CLEAN_UP + free(buf); +#endif return EXIT_SUCCESS; default: show_usage(); |