Browse Source

fixed UUID= and LABEL= handling

master
Harald Hoyer 16 years ago
parent
commit
2521f714f9
  1. 62
      dracut-gencmdline

62
dracut-gencmdline

@ -152,15 +152,23 @@ qpopd() {
popd >/dev/null 2>&1 popd >/dev/null 2>&1
} }


resolve_device_name() {
echo "$1"
# echo "resolve_device_name $1" 1>&2
}


freadlink() { freadlink() {
/usr/bin/readlink -f "$1" /usr/bin/readlink -f "$1"
} }


resolve_device_name() {
if [ -z "${1##UUID=*}" ]; then
real=$(freadlink /dev/disk/by-uuid/${1##UUID=})
[ -b $real ] && { echo $real; return; }
fi
if [ -z "${1##LABEL=*}" ]; then
real=$(freadlink /dev/disk/by-label/${1##LABEL=})
[ -b $real ] && { echo $real; return; }
fi
echo "$1"
}

finddevnoinsys() { finddevnoinsys() {
majmin="$1" majmin="$1"
if [ -n "$majmin" ]; then if [ -n "$majmin" ]; then
@ -604,9 +612,7 @@ done
else else
# check if it's root by label # check if it's root by label
rdev=$rootdev rdev=$rootdev
if [[ "$rdev" =~ ^(UUID=|LABEL=) ]]; then rdev=$(resolve_device_name "$rdev")
rdev=$(resolve_device_name "$rdev")
fi
rootopts=$(echo $rootopts | sed -e 's/^r[ow],//' -e 's/,_netdev//' -e 's/_netdev//' -e 's/,r[ow],$//' -e 's/,r[ow],/,/' -e 's/^r[ow]$/defaults/' -e 's/$/,ro/') rootopts=$(echo $rootopts | sed -e 's/^r[ow],//' -e 's/,_netdev//' -e 's/_netdev//' -e 's/,r[ow],$//' -e 's/,r[ow],/,/' -e 's/^r[ow]$/defaults/' -e 's/$/,ro/')
findstoragedriver "$rdev" findstoragedriver "$rdev"
fi fi
@ -615,9 +621,7 @@ done
[ -z "$thawdev" ] && thawdev=$(awk '/^[ \t]*[^#]/ { if ($3 == "swap") { print $1; exit }}' $fstab) [ -z "$thawdev" ] && thawdev=$(awk '/^[ \t]*[^#]/ { if ($3 == "swap") { print $1; exit }}' $fstab)
swsuspdev="$thawdev" swsuspdev="$thawdev"
if [ -n "$swsuspdev" ]; then if [ -n "$swsuspdev" ]; then
if [[ "$swsuspdev" =~ ^(UUID=|LABEL=) ]]; then swsuspdev=$(resolve_device_name "$swsuspdev")
swsuspdev=$(resolve_device_name "$swsuspdev")
fi
findstoragedriver "$swsuspdev" findstoragedriver "$swsuspdev"
fi fi


@ -662,31 +666,33 @@ emitcrypto()
echo -n "rd_LUKS_UUID=$luksuuid " echo -n "rd_LUKS_UUID=$luksuuid "
} }


for cryptdev in ${!cryptopart@} ; do
emitcrypto `eval echo '$'$cryptdev`
done

if [ -n "$raiddevices" ]; then if [ -n "$raiddevices" ]; then
for dev in $raiddevices; do for dev in $raiddevices; do
uid=$(udevadm info --query=all --name=/dev/${dev}|grep MD_UUID) uid=$(udevadm info --query=env --name /dev/${dev}|grep MD_UUID)
uid=$(IFS="=";set $uid;echo $2) uid=${uid##MD_UUID=}
echo -n "rd_MD_UUID=$uid " [ -n "$uid" ] && echo -n "rd_MD_UUID=$uid "
done done
else
echo -n "rd_NO_MD "
fi fi


for cryptdev in ${!cryptoraid@} ; do
emitcrypto `eval echo '$'$cryptdev`
done

if [ -z "$nolvm" -a -n "$vg_list" ]; then if [ -z "$nolvm" -a -n "$vg_list" ]; then
for vg in $vg_list; do for vg in $vg_list; do
echo -n "rd_LVM_VG=$vg " echo -n "rd_LVM_VG=$vg "
done done
else
echo -n "rd_NO_LVM "
fi fi


for cryptdev in ${!cryptolv@} ; do cryptdevs="${!cryptoraid@} ${!cryptopart@} ${!cryptolv@}"
emitcrypto `eval echo '$'$cryptdev`
done if [ -z "$cryptdevs" ]; then
echo -n "rd_NO_LUKS "
else
for cryptdev in ${!cryptoraid@} ${!cryptopart@} ${!cryptolv@} ; do
emitcrypto `eval echo '$'$cryptdev`
done
fi


# output local keyboard/18n settings # output local keyboard/18n settings
[ -e /etc/sysconfig/keyboard ] && . /etc/sysconfig/keyboard [ -e /etc/sysconfig/keyboard ] && . /etc/sysconfig/keyboard
@ -705,13 +711,5 @@ if [ -n "$rootdev" ]; then
echo -n "root=$rootdev " echo -n "root=$rootdev "
fi fi


if [ -L /usr/share/plymouth/themes/default.plymouth ]; then
theme=$(basename \
$(dirname \
$(readlink -f \
/usr/share/plymouth/themes/default.plymouth)))
[ -n "$theme" ] && echo -n "rd_plytheme=$theme "
fi

echo echo
# vim:ts=8:sw=4:sts=4:et # vim:ts=8:sw=4:sts=4:et

Loading…
Cancel
Save