mkdumprd: move module inclusion code to module-setup.sh
This commit is contained in:
parent
108f6ac2cc
commit
c5ebc6337d
@ -1,9 +0,0 @@
|
||||
#!/bin/bash
|
||||
|
||||
#kdumpctl sets this explicitly
|
||||
if [ -z "$IN_KDUMP" ]
|
||||
then
|
||||
exit 1
|
||||
fi
|
||||
exit 0
|
||||
|
@ -1,9 +0,0 @@
|
||||
#!/bin/bash
|
||||
|
||||
inst "/bin/date" "/bin/date"
|
||||
inst "/bin/sync" "/bin/sync"
|
||||
inst "/usr/bin/reboot" "/bin/reboot"
|
||||
inst "/sbin/makedumpfile" "/sbin/makedumpfile"
|
||||
inst "/etc/kdump.conf" "/etc/kdump.conf"
|
||||
inst_hook pre-pivot 01 "$moddir/kdump.sh"
|
||||
|
77
kdump_dracut_modules/99kdumpbase/module-setup.sh
Executable file
77
kdump_dracut_modules/99kdumpbase/module-setup.sh
Executable file
@ -0,0 +1,77 @@
|
||||
#!/bin/bash
|
||||
|
||||
check() {
|
||||
[[ $debug ]] && set -x
|
||||
#kdumpctl sets this explicitly
|
||||
if [ -z "$IN_KDUMP" ] || [ ! -f /etc/kdump.conf ]
|
||||
then
|
||||
return 1
|
||||
fi
|
||||
return 0
|
||||
}
|
||||
|
||||
is_lvm() { [[ $(get_fs_type /dev/block/$1) = LVM2_member ]]; }
|
||||
is_mdraid() { [[ -d "/sys/dev/block/$1/md" ]]; }
|
||||
is_btrfs() { get_fs_type /dev/block/$1 | grep -q btrfs; }
|
||||
is_mpath() {
|
||||
[ -e /sys/dev/block/$1/dm/uuid ] || return 1
|
||||
[[ $(cat /sys/dev/block/$1/dm/uuid) =~ ^mpath- ]] && return 0
|
||||
return 1
|
||||
}
|
||||
is_dmraid() { get_fs_type /dev/block/$1 |grep -v linux_raid_member | \
|
||||
grep -q _raid_member; }
|
||||
|
||||
is_iscsi() (
|
||||
[[ -L /sys/dev/block/$1 ]] || return
|
||||
cd "$(readlink -f /sys/dev/block/$1)"
|
||||
until [[ -d sys || -d iscsi_session ]]; do
|
||||
cd ..
|
||||
done
|
||||
[[ -d iscsi_session ]]
|
||||
)
|
||||
|
||||
pull_dracut_modules() {
|
||||
local _dev=$1
|
||||
local _is_uuid=`echo $1 | grep UUID`
|
||||
local _is_label=`echo $1 | grep LABEL`
|
||||
|
||||
if [ -n "$_is_uuid" -o -n "$_is_label" ]
|
||||
then
|
||||
_dev=`findfs $1`
|
||||
fi
|
||||
|
||||
. $dracutfunctions
|
||||
unset MAJOR MINOR
|
||||
eval $(udevadm info --query=env --name="$_dev" | egrep '^(MAJOR|MINOR)')
|
||||
check_block_and_slaves is_btrfs "$MAJOR:$MINOR" && echo -n "btrfs "
|
||||
check_block_and_slaves is_lvm "$MAJOR:$MINOR" && echo -n "lvm "
|
||||
check_block_and_slaves is_mdraid "$MAJOR:$MINOR" && echo -n "mdraid "
|
||||
check_block_and_slaves is_mpath "$MAJOR:$MINOR" && echo -n "multipath "
|
||||
check_block_and_slaves is_iscsi "$MAJOR:$MINOR" && echo -n "iscsi "
|
||||
check_block_and_slaves is_dmraid "$MAJOR:$MINOR" && echo -n "dmraid "
|
||||
unset MAJOR MINOR
|
||||
}
|
||||
|
||||
depends() {
|
||||
local _deps="base shutdown"
|
||||
while read config_opt config_val;
|
||||
do
|
||||
case "$config_opt" in
|
||||
ext[234]|xfs|btrfs|minix|raw)
|
||||
_deps="$_deps `pull_dracut_modules "$config_val"`"
|
||||
;;
|
||||
esac
|
||||
done < /etc/kdump.conf
|
||||
echo $_deps
|
||||
return 0
|
||||
}
|
||||
|
||||
install() {
|
||||
inst "/bin/date" "/bin/date"
|
||||
inst "/bin/sync" "/bin/sync"
|
||||
inst "/usr/bin/reboot" "/bin/reboot"
|
||||
inst "/sbin/makedumpfile" "/sbin/makedumpfile"
|
||||
inst "/etc/kdump.conf" "/etc/kdump.conf"
|
||||
inst_hook pre-pivot 01 "$moddir/kdump.sh"
|
||||
}
|
||||
|
10
mkdumprd
10
mkdumprd
@ -10,12 +10,16 @@ export IN_KDUMP=1
|
||||
|
||||
conf_file="/etc/kdump.conf"
|
||||
extra_modules=""
|
||||
dracut_args="-H -o i18n -o plymouth --add shutdown -c /dev/null"
|
||||
dracut_args="-m kdumpbase --add dash -c /dev/null"
|
||||
|
||||
add_dracut_arg() {
|
||||
dracut_args="$dracut_args $*"
|
||||
}
|
||||
|
||||
add_dracut_module() {
|
||||
add_dracut_arg "--add $1"
|
||||
}
|
||||
|
||||
while [ $# -gt 0 ]; do
|
||||
case $1 in
|
||||
-d)
|
||||
@ -61,8 +65,8 @@ if [ -n "$conf_file" ]; then
|
||||
check_local "$config_val" 1
|
||||
;;
|
||||
net)
|
||||
add_dracut_arg "--add network"
|
||||
check_remote "$config_val"
|
||||
add_dracut_module "nfs"
|
||||
;;
|
||||
core_collector)
|
||||
add_dracut_arg "-I ${config_val% *}"
|
||||
@ -85,6 +89,6 @@ then
|
||||
add_dracut_arg "--add-drivers $extra_modules"
|
||||
fi
|
||||
|
||||
dracut $dracut_args "$@"
|
||||
dracut $dracut_args -M "$@"
|
||||
exit $?
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user