2023-02-08 16:01:48 -05:00
|
|
|
#!/bin/bash
|
2017-07-12 00:17:45 -04:00
|
|
|
# Launches kexec from saved configuration entries
|
|
|
|
set -e -o pipefail
|
2018-12-06 15:24:28 -08:00
|
|
|
. /tmp/config
|
2017-04-29 13:40:34 -04:00
|
|
|
. /etc/functions
|
|
|
|
|
2023-02-20 11:01:17 -05:00
|
|
|
TRACE "Under /bin/kexec-boot"
|
2023-02-18 12:58:43 -05:00
|
|
|
|
2017-07-04 19:49:14 -04:00
|
|
|
dryrun="n"
|
2017-07-12 00:17:45 -04:00
|
|
|
printfiles="n"
|
|
|
|
printinitrd="n"
|
|
|
|
while getopts "b:e:r:a:o:fi" arg; do
|
2017-04-29 13:40:34 -04:00
|
|
|
case $arg in
|
|
|
|
b) bootdir="$OPTARG" ;;
|
|
|
|
e) entry="$OPTARG" ;;
|
|
|
|
r) cmdremove="$OPTARG" ;;
|
|
|
|
a) cmdadd="$OPTARG" ;;
|
2017-07-12 00:17:45 -04:00
|
|
|
o) override_initrd="$OPTARG" ;;
|
|
|
|
f) dryrun="y"; printfiles="y" ;;
|
|
|
|
i) dryrun="y"; printinitrd="y" ;;
|
2017-04-29 13:40:34 -04:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
2017-07-12 00:17:45 -04:00
|
|
|
if [ -z "$bootdir" -o -z "$entry" ]; then
|
2017-07-17 12:43:14 -04:00
|
|
|
die "Usage: $0 -b /boot -e 'kexec params|...|...'"
|
2017-07-12 00:17:45 -04:00
|
|
|
fi
|
|
|
|
|
2017-07-22 14:25:39 -04:00
|
|
|
bootdir="${bootdir%%/}"
|
2017-07-12 00:17:45 -04:00
|
|
|
|
2017-04-29 13:40:34 -04:00
|
|
|
kexectype=`echo $entry | cut -d\| -f2`
|
|
|
|
kexecparams=`echo $entry | cut -d\| -f3- | tr '|' '\n'`
|
|
|
|
kexeccmd="kexec"
|
|
|
|
|
2017-07-30 17:33:26 -04:00
|
|
|
cmdadd="$CONFIG_BOOT_KERNEL_ADD $cmdadd"
|
|
|
|
cmdremove="$CONFIG_BOOT_KERNEL_REMOVE $cmdremove"
|
2017-07-02 23:01:04 -04:00
|
|
|
|
2022-01-07 13:30:57 -06:00
|
|
|
if [ "$(load_config_value CONFIG_USE_BLOB_JAIL)" = "y" ]; then
|
2023-09-19 10:36:37 -04:00
|
|
|
cmdadd="$cmdadd firmware_class.path=/firmware/"
|
2022-01-07 13:30:57 -06:00
|
|
|
fi
|
|
|
|
|
2017-04-29 13:40:34 -04:00
|
|
|
fix_file_path() {
|
2017-07-12 00:17:45 -04:00
|
|
|
if [ "$printfiles" = "y" ]; then
|
|
|
|
# output file relative to local boot directory
|
|
|
|
echo ".$firstval"
|
|
|
|
fi
|
|
|
|
|
|
|
|
filepath="$bootdir$firstval"
|
2017-07-04 19:49:14 -04:00
|
|
|
|
2017-04-29 13:40:34 -04:00
|
|
|
if ! [ -r $filepath ]; then
|
2017-07-12 00:17:45 -04:00
|
|
|
die "Failed to find file $firstval"
|
2017-04-29 13:40:34 -04:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2017-07-13 00:33:49 -04:00
|
|
|
adjusted_cmd_line="n"
|
2017-04-29 13:40:34 -04:00
|
|
|
adjust_cmd_line() {
|
|
|
|
if [ -n "$cmdremove" ]; then
|
|
|
|
for i in $cmdremove; do
|
2021-10-15 13:38:24 -05:00
|
|
|
cmdline=$(echo $cmdline | sed "s/\b$i\b//g")
|
2017-04-29 13:40:34 -04:00
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -n "$cmdadd" ]; then
|
|
|
|
cmdline="$cmdline $cmdadd"
|
|
|
|
fi
|
2017-07-13 00:33:49 -04:00
|
|
|
adjusted_cmd_line="y"
|
2017-04-29 13:40:34 -04:00
|
|
|
}
|
|
|
|
|
2023-04-17 16:11:59 -04:00
|
|
|
if [ "$CONFIG_DEBUG_OUTPUT" = "y" ];then
|
|
|
|
#If expecting debug output, have kexec load (-l) output debug info
|
|
|
|
kexeccmd="$kexeccmd -d"
|
|
|
|
fi
|
|
|
|
|
2017-07-12 00:17:45 -04:00
|
|
|
module_number="1"
|
2017-04-29 13:40:34 -04:00
|
|
|
while read line
|
|
|
|
do
|
|
|
|
key=`echo $line | cut -d\ -f1`
|
|
|
|
firstval=`echo $line | cut -d\ -f2`
|
|
|
|
restval=`echo $line | cut -d\ -f3-`
|
|
|
|
if [ "$key" = "kernel" ]; then
|
2018-03-10 15:40:07 -08:00
|
|
|
fix_file_path
|
2017-07-04 19:49:14 -04:00
|
|
|
if [ "$kexectype" = "xen" ]; then
|
2018-03-10 15:40:07 -08:00
|
|
|
# always use xen with custom arguments
|
|
|
|
kexeccmd="$kexeccmd -l $filepath"
|
2019-03-17 19:33:55 -04:00
|
|
|
kexeccmd="$kexeccmd --command-line \"$restval no-real-mode reboot=no vga=current\""
|
2017-07-04 19:49:14 -04:00
|
|
|
elif [ "$kexectype" = "multiboot" ]; then
|
|
|
|
kexeccmd="$kexeccmd -l $filepath"
|
|
|
|
kexeccmd="$kexeccmd --command-line \"$restval\""
|
2023-04-17 16:11:59 -04:00
|
|
|
elif [ "$kexectype" = "elf" ]; then
|
|
|
|
DEBUG "kexectype= $kexectype"
|
|
|
|
DEBUG "restval= $restval"
|
|
|
|
DEBUG "filepath= $filepath"
|
|
|
|
kexeccmd="$kexeccmd -l $filepath"
|
|
|
|
DEBUG "kexeccmd= $kexeccmd"
|
2017-07-02 14:27:02 -04:00
|
|
|
else
|
2023-04-17 16:11:59 -04:00
|
|
|
DEBUG "unknown kexectype!!!!"
|
2017-07-02 14:27:02 -04:00
|
|
|
kexeccmd="$kexeccmd -l $filepath"
|
2017-04-29 13:40:34 -04:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
if [ "$key" = "module" ]; then
|
|
|
|
fix_file_path
|
2017-07-02 14:27:02 -04:00
|
|
|
cmdline="$restval"
|
2017-07-12 00:17:45 -04:00
|
|
|
if [ "$kexectype" = "xen" ]; then
|
|
|
|
if [ "$module_number" -eq 1 ]; then
|
|
|
|
adjust_cmd_line
|
|
|
|
elif [ "$module_number" -eq 2 ]; then
|
|
|
|
if [ "$printinitrd" = "y" ]; then
|
|
|
|
# output the current path to initrd
|
|
|
|
echo $filepath
|
|
|
|
fi
|
|
|
|
if [ -n "$override_initrd" ]; then
|
|
|
|
filepath="$override_initrd"
|
|
|
|
fi
|
|
|
|
fi
|
2017-07-02 14:27:02 -04:00
|
|
|
fi
|
2017-07-12 00:17:45 -04:00
|
|
|
module_number=`expr $module_number + 1`
|
2017-07-02 14:27:02 -04:00
|
|
|
kexeccmd="$kexeccmd --module \"$filepath $cmdline\""
|
2017-04-29 13:40:34 -04:00
|
|
|
fi
|
|
|
|
if [ "$key" = "initrd" ]; then
|
|
|
|
fix_file_path
|
2017-07-12 00:17:45 -04:00
|
|
|
if [ "$printinitrd" = "y" ]; then
|
|
|
|
# output the current path to initrd
|
|
|
|
echo $filepath
|
|
|
|
fi
|
|
|
|
if [ -n "$override_initrd" ]; then
|
|
|
|
filepath="$override_initrd"
|
|
|
|
fi
|
2022-01-07 13:30:57 -06:00
|
|
|
firmware_initrd="$(inject_firmware.sh "$filepath" || true)"
|
|
|
|
if [ -n "$firmware_initrd" ]; then
|
|
|
|
filepath="$firmware_initrd"
|
|
|
|
fi
|
2017-04-29 13:40:34 -04:00
|
|
|
kexeccmd="$kexeccmd --initrd=$filepath"
|
|
|
|
fi
|
|
|
|
if [ "$key" = "append" ]; then
|
|
|
|
cmdline="$firstval $restval"
|
|
|
|
adjust_cmd_line
|
|
|
|
kexeccmd="$kexeccmd --append=\"$cmdline\""
|
|
|
|
fi
|
|
|
|
done << EOF
|
|
|
|
$kexecparams
|
|
|
|
EOF
|
|
|
|
|
2017-07-13 00:33:49 -04:00
|
|
|
if [ "$adjusted_cmd_line" = "n" ]; then
|
|
|
|
if [ "$kexectype" = "elf" ]; then
|
|
|
|
kexeccmd="$kexeccmd --append=\"$cmdadd\""
|
|
|
|
else
|
|
|
|
die "Failed to add required kernel commands: $cmdadd"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2017-07-04 19:49:14 -04:00
|
|
|
if [ "$dryrun" = "y" ]; then exit 0; fi
|
|
|
|
|
2017-04-29 13:40:34 -04:00
|
|
|
echo "Loading the new kernel:"
|
|
|
|
echo "$kexeccmd"
|
|
|
|
eval "$kexeccmd" \
|
|
|
|
|| die "Failed to load the new kernel"
|
|
|
|
|
2023-07-07 14:16:46 -04:00
|
|
|
if [ "$CONFIG_DEBUG_OUTPUT" = "y" ];then
|
|
|
|
#Repeat kexec command that will be executed since in debug
|
|
|
|
DEBUG "kexeccmd= $kexeccmd"
|
|
|
|
|
2023-08-22 14:34:29 -04:00
|
|
|
#Ask user if they want to continue booting without echoing back the input (-s)
|
|
|
|
read -s -n 1 -p "[DEBUG] Continue booting? [Y/n]: " debug_boot_confirm
|
|
|
|
echo
|
2023-07-07 14:16:46 -04:00
|
|
|
if [ "${debug_boot_confirm^^}" = N ]; then
|
|
|
|
# abort
|
|
|
|
die "Boot aborted"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2023-02-27 16:42:01 -05:00
|
|
|
if [ "$CONFIG_TPM" = "y" ]; then
|
|
|
|
tpmr kexec_finalize
|
2022-08-25 14:43:31 -04:00
|
|
|
fi
|
|
|
|
|
2023-06-20 12:40:00 -04:00
|
|
|
if [ -x /bin/io386 -a "$CONFIG_FINALIZE_PLATFORM_LOCKING_PRESKYLAKE" = "y" ]; then
|
2023-04-12 15:04:05 -04:00
|
|
|
lock_chip
|
|
|
|
fi
|
|
|
|
|
2017-04-29 13:40:34 -04:00
|
|
|
echo "Starting the new kernel"
|
|
|
|
exec kexec -e
|