Check module dependencies of mount points

Like -H, we need to poll every module to check if it is needed
to mount a specific device in '--mount'.

Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>
master
Cong Wang 2011-12-20 14:09:57 +08:00 committed by Harald Hoyer
parent cd7ff122a4
commit 1b7fd0fa3e
15 changed files with 82 additions and 11 deletions

5
dracut
View File

@ -633,9 +633,12 @@ else
done
fi

mods_to_load=""
# check all our modules to see if they should be sourced.
# This builds a list of modules that we will install next.
check_module_dir
for_each_module_dir check_module
for_each_module_dir check_mount

modules_loaded=" "
# source our modules.
for moddir in "$dracutbasedir/modules.d"/[0-9][0-9]*; do

View File

@ -783,6 +783,67 @@ module_installkernel() {
fi
}

module_check_mount() {
local _moddir=$(echo ${dracutbasedir}/modules.d/??${1})
local _ret
mount_needs=1
[[ -d $_moddir ]] || return 1
if [[ ! -f $_moddir/module-setup.sh ]]; then
# if we do not have a check script, we are unconditionally included
[[ -x $_moddir/check ]] || return 0
mount_needs=1 $_moddir/check 0
_ret=$?
else
unset check depends install installkernel
. $_moddir/module-setup.sh
is_func check || return 1
check 0
_ret=$?
unset check depends install installkernel
fi
unset mount_needs
return $_ret
}

check_mount() {
local _mod=$1
local _moddir=$(echo ${dracutbasedir}/modules.d/??${1})
local _ret
local _moddep
# If we are already scheduled to be loaded, no need to check again.
strstr " $mods_to_load " " $_mod " && return 0
strstr " $mods_checked_as_dep " " $_mod " && return 1

# This should never happen, but...
[[ -d $_moddir ]] || return 1

[[ $2 ]] || mods_checked_as_dep+=" $_mod "

strstr " $omit_dracutmodules " " $_mod " && return 1

if [ "${#host_fs_types[*]}" -gt 0 ]; then
module_check_mount $_mod || return 1
else
# skip this module
return 1
fi

for _moddep in $(module_depends $_mod); do
# handle deps as if they were manually added
strstr " $add_dracutmodules " " $_moddep " || \
add_dracutmodules+=" $_moddep "
strstr " $force_add_dracutmodules " " $_moddep " || \
force_add_dracutmodules+=" $_moddep "
# if a module we depend on fail, fail also
check_module $_moddep || return 1
done

strstr " $mods_to_load " " $_mod " || \
mods_to_load+=" $_mod "

return 0
}

check_module() {
local _mod=$1
local _moddir=$(echo ${dracutbasedir}/modules.d/??${1})
@ -834,14 +895,15 @@ check_module() {
return 0
}

check_module_dir() {
for_each_module_dir() {
local _modcheck
local _mod
local _moddir
mods_to_load=""
local _func
_func=$1
for _moddir in "$dracutbasedir/modules.d"/[0-9][0-9]*; do
_mod=${_moddir##*/}; _mod=${_mod#[0-9][0-9]}
check_module $_mod 1
$_func $_mod 1
done

# Report any missing dracut modules, the user has specified

View File

@ -3,6 +3,7 @@
# ex: ts=8 sw=4 sts=4 et filetype=sh

check() {
[[ "$mount_needs" ]] && return 1
[ -x /sbin/bootchartd ] || return 1
return 255
}

View File

@ -3,6 +3,7 @@
# ex: ts=8 sw=4 sts=4 et filetype=sh

check() {
[[ "$mount_needs" ]] && return 1
return 0
}


View File

@ -3,6 +3,7 @@
# ex: ts=8 sw=4 sts=4 et filetype=sh

check() {
[[ "$mount_needs" ]] && return 1
[ -f /etc/redhat-release ]
}


View File

@ -3,6 +3,7 @@
# ex: ts=8 sw=4 sts=4 et filetype=sh

check() {
[[ "$mount_needs" ]] && return 1
[[ -x /sbin/plymouthd && -x /bin/plymouth && -x /usr/sbin/plymouth-set-default-theme ]]
}


View File

@ -11,7 +11,7 @@ check() {
. $dracutfunctions
[[ $debug ]] && set -x

[[ $hostonly ]] && {
[[ $hostonly ]] || [[ $mount_needs ]] && {
local _found
for fs in $host_fs_types; do
[[ "$fs" = "|btrfs" ]] && _found="1"

View File

@ -23,7 +23,7 @@ check() {
echo " rd.luks.uuid=${ID_FS_UUID} " >> "${initdir}/etc/cmdline.d/90crypt.conf"
}

[[ $hostonly ]] && {
[[ $hostonly ]] || [[ $mount_needs ]] && {
[[ -d "${initdir}/etc/cmdline.d" ]] || mkdir -p "${initdir}/etc/cmdline.d"
for_each_host_dev_fs check_crypt
[ -f "${initdir}/etc/cmdline.d/90crypt.conf" ] || return 1

View File

@ -38,7 +38,7 @@ check() {
echo " rd.dm.uuid=${DM_NAME} " >> "${initdir}/etc/cmdline.d/90dmraid.conf"
}

[[ $hostonly ]] && {
[[ $hostonly ]] || [[ $mount_needs ]] && {
[[ -d "${initdir}/etc/cmdline.d" ]] || mkdir -p "${initdir}/etc/cmdline.d"
for_each_host_dev_fs check_dmraid
[ -f "${initdir}/etc/cmdline.d/90dmraid.conf" ] || return 1

View File

@ -23,7 +23,7 @@ check() {
echo " rd.lvm.lv=${DM_LV_NAME} " >> "${initdir}/etc/cmdline.d/90lvm.conf"
}

[[ $hostonly ]] && {
[[ $hostonly ]] || [[ $mount_needs ]] && {
[[ -d "${initdir}/etc/cmdline.d" ]] || mkdir -p "${initdir}/etc/cmdline.d"
for_each_host_dev_fs check_lvm
[ -f "${initdir}/etc/cmdline.d/90lvm.conf" ] || return 1

View File

@ -38,7 +38,7 @@ check() {
echo " rd.md.uuid=${MD_UUID} " >> "${initdir}/etc/cmdline.d/90mdraid.conf"
}

[[ $hostonly ]] && {
[[ $hostonly ]] || [[ $mount_needs ]] && {
[[ -d "${initdir}/etc/cmdline.d" ]] || mkdir -p "${initdir}/etc/cmdline.d"
for_each_host_dev_fs check_mdraid
[[ -f "${initdir}/etc/cmdline.d/90mdraid.conf" ]] || return 1

View File

@ -6,7 +6,7 @@ check() {
# FIXME
# If hostonly was requested, fail the check until we have some way of
# knowing we are booting from FCoE
[[ $hostonly ]] && return 1
[[ $hostonly ]] || [[ $mount_needs ]] && return 1

return 0
}

View File

@ -7,7 +7,7 @@ check() {
type -P rpcbind >/dev/null || type -P portmap >/dev/null || return 1
type -P rpc.statd mount.nfs mount.nfs4 umount >/dev/null || return 1

[[ $hostonly ]] && {
[[ $hostonly ]] || [[ $mount_needs ]] && {
for fs in ${host_fs_types[@]}; do
strstr "$fs" "|nfs" && return 0
strstr "$fs" "|nfs3" && return 0

View File

@ -3,6 +3,7 @@
# ex: ts=8 sw=4 sts=4 et filetype=sh

check() {
[[ "$mount_needs" ]] && return 1
type -P biosdevname >/dev/null || return 1
return 0
}

View File

@ -3,6 +3,7 @@
# ex: ts=8 sw=4 sts=4 et filetype=sh

check() {
[[ $mount_needs ]] && return 1
return 0
}