Files
mirror_zfs/scripts/zfs.sh
T

289 lines
5.5 KiB
Bash
Raw Normal View History

2017-08-15 17:26:38 -07:00
#!/bin/sh
#
# A simple script to load/unload the ZFS module stack.
2010-08-26 11:22:58 -07:00
#
2017-08-15 17:26:38 -07:00
BASE_DIR=$(dirname "$0")
2010-08-26 11:22:58 -07:00
SCRIPT_COMMON=common.sh
2017-08-15 17:26:38 -07:00
if [ -f "${BASE_DIR}/${SCRIPT_COMMON}" ]; then
. "${BASE_DIR}/${SCRIPT_COMMON}"
2010-08-26 11:22:58 -07:00
else
2017-08-15 17:26:38 -07:00
echo "Missing helper script ${SCRIPT_COMMON}" && exit 1
2010-08-26 11:22:58 -07:00
fi
PROG=zfs.sh
2017-08-15 17:26:38 -07:00
VERBOSE="no"
UNLOAD="no"
2021-08-13 16:37:46 -04:00
LOAD="yes"
STACK_TRACER="no"
2017-08-15 17:26:38 -07:00
ZED_PIDFILE=${ZED_PIDFILE:-/var/run/zed.pid}
LDMOD=${LDMOD:-/sbin/modprobe}
KMOD_ZLIB_DEFLATE=${KMOD_ZLIB_DEFLATE:-zlib_deflate}
KMOD_ZLIB_INFLATE=${KMOD_ZLIB_INFLATE:-zlib_inflate}
KMOD_SPL=${KMOD_SPL:-spl}
KMOD_ZAVL=${KMOD_ZAVL:-zavl}
KMOD_ZNVPAIR=${KMOD_ZNVPAIR:-znvpair}
KMOD_ZUNICODE=${KMOD_ZUNICODE:-zunicode}
KMOD_ZCOMMON=${KMOD_ZCOMMON:-zcommon}
2018-02-08 09:16:23 -07:00
KMOD_ZLUA=${KMOD_ZLUA:-zlua}
2017-08-15 17:26:38 -07:00
KMOD_ICP=${KMOD_ICP:-icp}
KMOD_ZFS=${KMOD_ZFS:-zfs}
2019-12-19 12:31:16 -05:00
KMOD_FREEBSD=${KMOD_FREEBSD:-openzfs}
2020-08-18 19:10:17 +02:00
KMOD_ZZSTD=${KMOD_ZZSTD:-zzstd}
2017-08-15 17:26:38 -07:00
2010-08-26 11:22:58 -07:00
usage() {
cat << EOF
USAGE:
$0 [hvudS] [module-options]
2010-08-26 11:22:58 -07:00
DESCRIPTION:
Load/unload the ZFS module stack.
OPTIONS:
-h Show this message
-v Verbose
2021-08-13 16:37:46 -04:00
-r Reload modules
2010-08-26 11:22:58 -07:00
-u Unload modules
-S Enable kernel stack tracer
2010-08-26 11:22:58 -07:00
EOF
}
2021-08-13 16:37:46 -04:00
while getopts 'hvruS' OPTION; do
2010-08-26 11:22:58 -07:00
case $OPTION in
h)
usage
exit 1
;;
v)
2017-08-15 17:26:38 -07:00
VERBOSE="yes"
2010-08-26 11:22:58 -07:00
;;
2021-08-13 16:37:46 -04:00
r)
UNLOAD="yes"
LOAD="yes"
;;
2010-08-26 11:22:58 -07:00
u)
2017-08-15 17:26:38 -07:00
UNLOAD="yes"
2021-08-13 16:37:46 -04:00
LOAD="no"
2010-08-26 11:22:58 -07:00
;;
S)
STACK_TRACER="yes"
;;
2010-08-26 11:22:58 -07:00
?)
usage
exit
;;
esac
done
2017-08-15 17:26:38 -07:00
kill_zed() {
if [ -f "$ZED_PIDFILE" ]; then
PID=$(cat "$ZED_PIDFILE")
kill "$PID"
fi
}
2019-12-19 12:31:16 -05:00
check_modules_linux() {
2017-09-18 14:23:09 -07:00
LOADED_MODULES=""
MISSING_MODULES=""
2017-08-15 17:26:38 -07:00
2020-08-18 19:10:17 +02:00
for KMOD in $KMOD_SPL $KMOD_ZAVL $KMOD_ZNVPAIR $KMOD_ZUNICODE $KMOD_ZCOMMON \
$KMOD_ZLUA $KMOD_ZZSTD $KMOD_ICP $KMOD_ZFS; do
2017-08-15 17:26:38 -07:00
NAME=$(basename "$KMOD" .ko)
2018-01-17 10:17:16 -08:00
if lsmod | grep -E -q "^${NAME}"; then
2017-08-15 17:26:38 -07:00
LOADED_MODULES="$LOADED_MODULES\t$NAME\n"
fi
if ! modinfo "$KMOD" >/dev/null 2>&1; then
MISSING_MODULES="$MISSING_MODULES\t${KMOD}\n"
fi
done
if [ -n "$LOADED_MODULES" ]; then
printf "Unload the kernel modules by running '%s -u':\n" "$PROG"
printf "%b" "$LOADED_MODULES"
exit 1
fi
if [ -n "$MISSING_MODULES" ]; then
printf "The following kernel modules can not be found:\n"
printf "%b" "$MISSING_MODULES"
exit 1
fi
return 0
}
2019-12-19 12:31:16 -05:00
load_module_linux() {
2017-09-18 14:23:09 -07:00
KMOD=$1
2017-08-15 17:26:38 -07:00
FILE=$(modinfo "$KMOD" | awk '/^filename:/ {print $2}')
VERSION=$(modinfo "$KMOD" | awk '/^version:/ {print $2}')
if [ "$VERBOSE" = "yes" ]; then
echo "Loading: $FILE ($VERSION)"
fi
2021-05-14 11:55:17 +02:00
if ! $LDMOD "$KMOD" >/dev/null 2>&1; then
2017-08-15 17:26:38 -07:00
echo "Failed to load $KMOD"
return 1
fi
return 0
}
2019-12-19 12:31:16 -05:00
load_modules_freebsd() {
kldload "$KMOD_FREEBSD" || return 1
if [ "$VERBOSE" = "yes" ]; then
echo "Successfully loaded ZFS module stack"
fi
return 0
}
load_modules_linux() {
2017-08-15 17:26:38 -07:00
mkdir -p /etc/zfs
if modinfo "$KMOD_ZLIB_DEFLATE" >/dev/null 2>&1; then
modprobe "$KMOD_ZLIB_DEFLATE" >/dev/null 2>&1
fi
if modinfo "$KMOD_ZLIB_INFLATE">/dev/null 2>&1; then
modprobe "$KMOD_ZLIB_INFLATE" >/dev/null 2>&1
fi
2017-08-15 17:26:38 -07:00
2018-02-15 17:53:18 -08:00
for KMOD in $KMOD_SPL $KMOD_ZAVL $KMOD_ZNVPAIR \
2020-08-18 19:10:17 +02:00
$KMOD_ZUNICODE $KMOD_ZCOMMON $KMOD_ZLUA $KMOD_ZZSTD \
$KMOD_ICP $KMOD_ZFS; do
2019-12-19 12:31:16 -05:00
load_module_linux "$KMOD" || return 1
2017-08-15 17:26:38 -07:00
done
if [ "$VERBOSE" = "yes" ]; then
echo "Successfully loaded ZFS module stack"
fi
return 0
}
2019-12-19 12:31:16 -05:00
unload_module_linux() {
2017-09-18 14:23:09 -07:00
KMOD=$1
2017-08-15 17:26:38 -07:00
NAME=$(basename "$KMOD" .ko)
FILE=$(modinfo "$KMOD" | awk '/^filename:/ {print $2}')
VERSION=$(modinfo "$KMOD" | awk '/^version:/ {print $2}')
if [ "$VERBOSE" = "yes" ]; then
echo "Unloading: $KMOD ($VERSION)"
fi
rmmod "$NAME" || echo "Failed to unload $NAME"
return 0
}
2019-12-19 12:31:16 -05:00
unload_modules_freebsd() {
kldunload "$KMOD_FREEBSD" || echo "Failed to unload $KMOD_FREEBSD"
if [ "$VERBOSE" = "yes" ]; then
echo "Successfully unloaded ZFS module stack"
fi
return 0
}
unload_modules_linux() {
2020-08-18 19:10:17 +02:00
for KMOD in $KMOD_ZFS $KMOD_ICP $KMOD_ZZSTD $KMOD_ZLUA $KMOD_ZCOMMON \
$KMOD_ZUNICODE $KMOD_ZNVPAIR $KMOD_ZAVL $KMOD_SPL; do
2017-08-15 17:26:38 -07:00
NAME=$(basename "$KMOD" .ko)
2018-01-17 10:17:16 -08:00
USE_COUNT=$(lsmod | grep -E "^${NAME} " | awk '{print $3}')
2017-08-15 17:26:38 -07:00
if [ "$USE_COUNT" = "0" ] ; then
2019-12-19 12:31:16 -05:00
unload_module_linux "$KMOD" || return 1
elif [ "$USE_COUNT" != "" ] ; then
2020-10-13 16:51:54 -07:00
echo "Module ${NAME} is still in use!"
return 1
2017-08-15 17:26:38 -07:00
fi
done
if modinfo "$KMOD_ZLIB_DEFLATE" >/dev/null 2>&1; then
modprobe -r "$KMOD_ZLIB_DEFLATE" >/dev/null 2>&1
fi
if modinfo "$KMOD_ZLIB_INFLATE">/dev/null 2>&1; then
modprobe -r "$KMOD_ZLIB_INFLATE" >/dev/null 2>&1
fi
2017-08-15 17:26:38 -07:00
if [ "$VERBOSE" = "yes" ]; then
echo "Successfully unloaded ZFS module stack"
fi
return 0
}
2019-12-19 12:31:16 -05:00
stack_clear_linux() {
2017-09-18 14:23:09 -07:00
STACK_MAX_SIZE=/sys/kernel/debug/tracing/stack_max_size
STACK_TRACER_ENABLED=/proc/sys/kernel/stack_tracer_enabled
2017-08-15 17:26:38 -07:00
if [ "$STACK_TRACER" = "yes" ] && [ -e "$STACK_MAX_SIZE" ]; then
2017-08-15 17:26:38 -07:00
echo 1 >"$STACK_TRACER_ENABLED"
echo 0 >"$STACK_MAX_SIZE"
fi
}
2019-12-19 12:31:16 -05:00
stack_check_linux() {
2017-09-18 14:23:09 -07:00
STACK_MAX_SIZE=/sys/kernel/debug/tracing/stack_max_size
STACK_TRACE=/sys/kernel/debug/tracing/stack_trace
STACK_LIMIT=15362
2017-08-15 17:26:38 -07:00
if [ -e "$STACK_MAX_SIZE" ]; then
STACK_SIZE=$(cat "$STACK_MAX_SIZE")
if [ "$STACK_SIZE" -ge "$STACK_LIMIT" ]; then
echo
echo "Warning: max stack size $STACK_SIZE bytes"
cat "$STACK_TRACE"
fi
fi
}
2017-03-09 10:20:15 -08:00
if [ "$(id -u)" != 0 ]; then
2017-08-15 17:26:38 -07:00
echo "Must run as root"
exit 1
2010-08-26 11:22:58 -07:00
fi
2019-12-19 12:31:16 -05:00
UNAME=$(uname -s)
2017-08-15 17:26:38 -07:00
if [ "$UNLOAD" = "yes" ]; then
kill_zed
umount -t zfs -a
2019-12-19 12:31:16 -05:00
case $UNAME in
FreeBSD)
unload_modules_freebsd
;;
Linux)
stack_check_linux
unload_modules_linux
;;
esac
2021-08-13 16:37:46 -04:00
fi
if [ "$LOAD" = "yes" ]; then
2019-12-19 12:31:16 -05:00
case $UNAME in
FreeBSD)
load_modules_freebsd
;;
Linux)
stack_clear_linux
check_modules_linux
load_modules_linux "$@"
udevadm trigger
udevadm settle
;;
esac
2010-08-26 11:22:58 -07:00
fi
exit 0