Merge pull request #557 from heads105/fc30kexec

kexec-select-boot not compatible with Fedora 30
This commit is contained in:
tlaurion 2019-05-01 09:06:52 -04:00 committed by GitHub
commit fe9807cb1f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 100 additions and 1 deletions

View File

@ -361,7 +361,7 @@ CONFIG_FEATURE_HUMAN_READABLE=y
CONFIG_DEFAULT_SETFONT_DIR=""
# CONFIG_FEATURE_LOADFONT_PSF2 is not set
# CONFIG_FEATURE_LOADFONT_RAW is not set
# CONFIG_LOADKMAP is not set
CONFIG_LOADKMAP=y
# CONFIG_OPENVT is not set
# CONFIG_RESET is not set
# CONFIG_RESIZE is not set

94
initrd/bin/kexec-parse-bls Executable file
View File

@ -0,0 +1,94 @@
#!/bin/sh
set -e -o pipefail
bootdir="$1"
file="$2"
blsdir="$3"
if [ -z "$bootdir" -o -z "$file" ]; then
die "Usage: $0 /boot /boot/grub/grub.cfg blsdir"
fi
reset_entry() {
name=""
kexectype="elf"
kernel=""
initrd=""
modules=""
append="$dfltappend"
}
filedir=`dirname $file`
bootdir="${bootdir%%/}"
bootlen="${#bootdir}"
appenddir="${filedir:$bootlen}"
# assumption. grubenv is in same location as config file
# ignored if doesn't exist
grubenv="$filedir/grubenv"
fix_path() {
path="$@"
if [ "${path:0:1}" != "/" ]; then
path="$appenddir/$path"
fi
}
echo_entry() {
if [ "$kexectype" = "elf" ]; then
if [ -z "$kernel" ]; then return; fi
fix_path $kernel
entry="$name|$kexectype|kernel $path"
if [ -n "$initrd" ]; then
fix_path $initrd
entry="$entry|initrd $path"
fi
if [ -n "$append" ]; then
entry="$entry|append $append"
fi
echo $(eval "echo \"$entry\"")
fi
if [ "$kexectype" = "multiboot" -o "$kexectype" = "xen" ]; then
if [ -z "$kernel" ]; then return; fi
fix_path $kernel
echo $(eval "echo \"$name|$kexectype|kernel $path$modules\"")
fi
}
bls_entry() {
# add info to menuentry
trimcmd=`echo $line | tr '\t ' ' ' | tr -s ' '`
cmd=`echo $trimcmd | cut -d\ -f1`
val=`echo $trimcmd | cut -d\ -f2-`
case $cmd in
title)
name=$val
;;
linux*)
kernel=$val
;;
initrd*)
initrd=$val
;;
options)
# default is "options $kernelopts", so need to substitute that variable set from grubenv
append=`echo "$val" | sed "s@\$kernelopts@$kernelopts@"`
;;
esac
}
# This is the default append value if no options field in bls entry
kernelopts=`grep "set default_kernelopts" "$file" | tr "'" "\"" | cut -d\" -f 2`
[ -f "$grubenv" ] && kernelopts=`grep "^kernelopts" "$grubenv" | tr '@' '_' | cut -d= -f 2-`
reset_entry
find $blsdir -type f -name \*.conf |
while read f
do
while read line
do
bls_entry
done < "$f"
echo_entry
reset_entry
done

View File

@ -162,6 +162,11 @@ scan_options() {
if [ -r $option_file ]; then rm $option_file; fi
for i in `find $bootdir -name "$config"`; do
kexec-parse-boot "$bootdir" "$i" >> $option_file
# FC29/30+ may use BLS format grub config files
# https://fedoraproject.org/wiki/Changes/BootLoaderSpecByDefault
if [ -d "$bootdir/loader/entries" ]; then
kexec-parse-bls "$bootdir" "$i" "$bootdir/loader/entries" >> $option_file
fi
done
if [ ! -r $option_file ]; then
die "Failed to parse any boot options"