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"
|
conf_file="/etc/kdump.conf"
|
||||||
extra_modules=""
|
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() {
|
add_dracut_arg() {
|
||||||
dracut_args="$dracut_args $*"
|
dracut_args="$dracut_args $*"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
add_dracut_module() {
|
||||||
|
add_dracut_arg "--add $1"
|
||||||
|
}
|
||||||
|
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
case $1 in
|
case $1 in
|
||||||
-d)
|
-d)
|
||||||
@ -61,8 +65,8 @@ if [ -n "$conf_file" ]; then
|
|||||||
check_local "$config_val" 1
|
check_local "$config_val" 1
|
||||||
;;
|
;;
|
||||||
net)
|
net)
|
||||||
add_dracut_arg "--add network"
|
|
||||||
check_remote "$config_val"
|
check_remote "$config_val"
|
||||||
|
add_dracut_module "nfs"
|
||||||
;;
|
;;
|
||||||
core_collector)
|
core_collector)
|
||||||
add_dracut_arg "-I ${config_val% *}"
|
add_dracut_arg "-I ${config_val% *}"
|
||||||
@ -85,6 +89,6 @@ then
|
|||||||
add_dracut_arg "--add-drivers $extra_modules"
|
add_dracut_arg "--add-drivers $extra_modules"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
dracut $dracut_args "$@"
|
dracut $dracut_args -M "$@"
|
||||||
exit $?
|
exit $?
|
||||||
|
|
||||||
|
1
sources
1
sources
@ -12,3 +12,4 @@ d220ff5e4b07c34701d9a1fe991ef2e4 dracut-files.tbz2
|
|||||||
1548d83e2713660c4cbd2c284fdad25b dracut-files.tbz2
|
1548d83e2713660c4cbd2c284fdad25b dracut-files.tbz2
|
||||||
adea715e719a4c460c41d8134aafa95b dracut-files.tbz2
|
adea715e719a4c460c41d8134aafa95b dracut-files.tbz2
|
||||||
c7e9dd35476cb33f09f22037f6c16982 dracut-files.tbz2
|
c7e9dd35476cb33f09f22037f6c16982 dracut-files.tbz2
|
||||||
|
2cda75991642bd2ad58e93e89297748b dracut-files.tbz2
|
||||||
|
Loading…
Reference in New Issue
Block a user