X-Git-Url: https://git.grml.org/?p=grml-rescueboot.git;a=blobdiff_plain;f=42_grml;h=4a7643225bd576033364a78ca4d7ba3823ec0a36;hp=69133467ae3f6c6dfd5111bca830a7faa9e487c0;hb=f4f470fc86fa06a8fc57d406cf1156f60f171a9f;hpb=6323d69dad19996387c086b288c1810c347abb64 diff --git a/42_grml b/42_grml index 6913346..4a76432 100755 --- a/42_grml +++ b/42_grml @@ -1,8 +1,7 @@ #!/bin/sh # Filename: 42_grml # Purpose: grub-mkconfig helper script for Grml rescue systems -# Authors: grml-team (grml.org), (c) Andreas Gredler , Michael Prokop -# Bug-Reports: see http://grml.org/bugs/ +# Authors: Grml team (grml.org), (c) Andreas Gredler , Michael Prokop # License: This file is licensed under the GPL v2+. ################################################################################ @@ -12,7 +11,14 @@ prefix=/usr exec_prefix=${prefix} bindir=${exec_prefix}/bin libdir=${exec_prefix}/lib -. ${libdir}/grub/grub-mkconfig_lib + +if [ -r ${libdir}/grub/grub-mkconfig_lib ] ; then + . ${libdir}/grub/grub-mkconfig_lib +elif [ -r /usr/share/grub/grub-mkconfig_lib ] ; then # fallback for e.g. Fedora + . /usr/share/grub/grub-mkconfig_lib +else + echo "Could not locate file grub-mkconfig_lib, please report a bug." >&2 +fi # default unless configured otherwise: ISO_LOCATION="/boot/grml" @@ -21,25 +27,98 @@ if [ -r /etc/default/grml-rescueboot ] ; then . /etc/default/grml-rescueboot fi -list=$(for i in "${ISO_LOCATION}"/*.iso ; do - if grub_file_is_not_garbage "$i" ; then echo -n "$i " ; fi - done) +resolve_dm_name() { + retval="$1" + base=${1##*/} + for block in /sys/block /sys/class/block ; do + [ ! -d ${block}/${base}/dm ] && continue + retval="/dev/mapper/$(cat ${block}/${base}/dm/name)" + break + done + case "$retval" in + /dev/dm-*) + minor=${retval##*-} + retval="/dev/mapper/$(dmsetup info -C --noheadings -o name -j 253 -m $minor)" + ;; + esac + + echo "$retval" +} + +get_dependencies() { + device=${1} + if [ -z ${device} ] ; then + return + fi + device=$(readlink -f ${device}) + case "$device" in + /dev/mapper/*) + device="/dev/dm-$(dmsetup info -C --noheadings -o minor "$device")" + ;; + esac + + base=${device##*/} + dependencies="" + additional_dependencies="" + for block in /sys/block /sys/class/block ; do + [ ! -d ${block}/${base}/slaves ] && continue + for file in ${block}/${base}/slaves/* ; do + dep_name="/dev/${file##*/}" + dep_name=$(resolve_dm_name ${dep_name}) + + # resolve recursively all dependencies + additional_dependencies=$(get_dependencies ${dep_name}) + + dependencies="$dependencies $additional_dependencies $dep_name" + done + break + done + echo $dependencies -for grmliso in $list ; do - rel_dirname="$(make_system_path_relative_to_its_root $(dirname $grmliso))" +} + + + +iso_list="" +for file in "${ISO_LOCATION}"/*.iso ; do + if grub_file_is_not_garbage "$file" ; then + iso_list="$iso_list $file " + fi +done + +for grmliso in $iso_list ; do + rel_dirname="$(dirname $(make_system_path_relative_to_its_root $grmliso))" grml="$(basename $grmliso)" + device="$(${grub_probe} -t device ${grmliso})" + + additional_param="" + + case "$device" in + /dev/mapper*|/dev/md*) + dependencies=$(get_dependencies ${device}) + dep_string="" + for dep in $dependencies $device ; do + dep_string="$dep_string,$dep" + done + dep_string=${dep_string#,} + additional_param="live-media=$dep_string" + ;; + esac echo "Found Grml ISO image: $grmliso" >&2 title="Grml Rescue System ($grml)" + grub_prep=$(prepare_grub_to_access_device "$device" | sed -e "s/^/ /") cat << EOF menuentry "${title}" { -$(prepare_grub_to_access_device $(${grub_probe} -t device ${grmliso}) | sed -e "s/^/ /") - iso_path="${rel_dirname}/${grml}" +${grub_prep} + iso_path="${rel_dirname%/}/${grml}" export iso_path - kernelopts="$CUSTOM_BOOTOPTIONS" + kernelopts=" $CUSTOM_BOOTOPTIONS $additional_param " export kernelopts - loopback loop "${rel_dirname}/$grml" + # support booting recent GRUB versions on UEFI systems + rmmod tpm + loopback loop "${rel_dirname%/}/$grml" set root=(loop) configfile /boot/grub/loopback.cfg }