3 # Takes a list of modules and unloads them and all dependent modules.
4 # If a module cannot be unloaded (e.g. it's in use), an error is
6 ###############################################################################
8 # Unload all modules dependent on $1 (exclude removal of $1)
9 unload_dep_modules_exclusive() {
11 local DEPS="$(lsmod | awk '($1 == "'$MODULE'") { print $4 }')"
12 for SUBMOD in $(echo $DEPS | tr ',' ' '); do
13 unload_dep_modules_inclusive $SUBMOD || return 1
18 # Unload all modules dependent on $1 (include removal of $1)
19 unload_dep_modules_inclusive() {
22 # if $MODULE not loaded, return 0
23 lsmod | egrep -q "^\<$MODULE\>" || return 0
24 unload_dep_modules_exclusive $MODULE || return 1
25 rmmod $MODULE || return 1
31 # To maintain backwards compatibility, ldiskfs and libcfs must be
32 # unloaded if no parameters are given, or if only the ldiskfs parameter
33 # is given. It's ugly, but is needed to emulate the prior functionality
34 if [ -z "$modules" ] || [ "$modules" = "ldiskfs" ]; then
35 modules="ptlrpc lnet_selftest ldiskfs libcfs"
38 for mod in $modules; do
39 unload_dep_modules_inclusive $mod || exit 1