2020-10-15 12:45:57 +00:00
|
|
|
#! /bin/sh
|
|
|
|
|
|
|
|
KEXEC=/sbin/kexec
|
|
|
|
standard_kexec_args="-p"
|
|
|
|
|
|
|
|
EARLY_KDUMP_INITRD=""
|
|
|
|
EARLY_KDUMP_KERNEL=""
|
|
|
|
EARLY_KDUMP_CMDLINE=""
|
|
|
|
EARLY_KDUMP_KERNELVER=""
|
|
|
|
EARLY_KEXEC_ARGS=""
|
|
|
|
|
|
|
|
. /etc/sysconfig/kdump
|
|
|
|
. /lib/dracut-lib.sh
|
|
|
|
. /lib/kdump-lib.sh
|
2021-01-22 08:12:00 +00:00
|
|
|
. /lib/kdump-logger.sh
|
2020-10-15 12:45:57 +00:00
|
|
|
|
2021-11-03 11:37:33 +00:00
|
|
|
# initiate the kdump logger
|
|
|
|
if ! dlog_init; then
|
2020-11-05 05:34:29 +00:00
|
|
|
echo "failed to initiate the kdump logger."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2020-10-15 12:45:57 +00:00
|
|
|
prepare_parameters()
|
|
|
|
{
|
|
|
|
EARLY_KDUMP_CMDLINE=$(prepare_cmdline "${KDUMP_COMMANDLINE}" "${KDUMP_COMMANDLINE_REMOVE}" "${KDUMP_COMMANDLINE_APPEND}")
|
|
|
|
EARLY_KDUMP_KERNEL="/boot/kernel-earlykdump"
|
|
|
|
EARLY_KDUMP_INITRD="/boot/initramfs-earlykdump"
|
|
|
|
}
|
|
|
|
|
|
|
|
early_kdump_load()
|
|
|
|
{
|
2021-11-03 11:37:33 +00:00
|
|
|
if ! check_kdump_feasibility; then
|
2020-10-15 12:45:57 +00:00
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if is_fadump_capable; then
|
2020-11-05 05:34:29 +00:00
|
|
|
dwarn "WARNING: early kdump doesn't support fadump."
|
2020-10-15 12:45:57 +00:00
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
2023-09-21 06:54:17 +00:00
|
|
|
if is_kernel_loaded "kdump"; then
|
2020-10-15 12:45:57 +00:00
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
prepare_parameters
|
|
|
|
|
|
|
|
EARLY_KEXEC_ARGS=$(prepare_kexec_args "${KEXEC_ARGS}")
|
|
|
|
|
|
|
|
if is_secure_boot_enforced; then
|
2020-11-05 05:34:29 +00:00
|
|
|
dinfo "Secure Boot is enabled. Using kexec file based syscall."
|
2020-10-15 12:45:57 +00:00
|
|
|
EARLY_KEXEC_ARGS="$EARLY_KEXEC_ARGS -s"
|
|
|
|
fi
|
|
|
|
|
2020-11-20 12:35:49 +00:00
|
|
|
# Here, only output the messages, but do not save these messages
|
|
|
|
# to a file because the target disk may not be mounted yet, the
|
|
|
|
# earlykdump is too early.
|
2020-11-05 05:34:29 +00:00
|
|
|
ddebug "earlykdump: $KEXEC ${EARLY_KEXEC_ARGS} $standard_kexec_args \
|
|
|
|
--command-line=$EARLY_KDUMP_CMDLINE --initrd=$EARLY_KDUMP_INITRD \
|
|
|
|
$EARLY_KDUMP_KERNEL"
|
|
|
|
|
2021-11-03 11:37:33 +00:00
|
|
|
if $KEXEC $EARLY_KEXEC_ARGS $standard_kexec_args \
|
2020-10-15 12:45:57 +00:00
|
|
|
--command-line="$EARLY_KDUMP_CMDLINE" \
|
2021-11-03 11:37:33 +00:00
|
|
|
--initrd=$EARLY_KDUMP_INITRD $EARLY_KDUMP_KERNEL; then
|
2020-11-05 05:34:29 +00:00
|
|
|
dinfo "kexec: loaded early-kdump kernel"
|
2020-10-15 12:45:57 +00:00
|
|
|
return 0
|
|
|
|
else
|
2020-11-05 05:34:29 +00:00
|
|
|
derror "kexec: failed to load early-kdump kernel"
|
2020-10-15 12:45:57 +00:00
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
set_early_kdump()
|
|
|
|
{
|
|
|
|
if getargbool 0 rd.earlykdump; then
|
2020-11-05 05:34:29 +00:00
|
|
|
dinfo "early-kdump is enabled."
|
2020-10-15 12:45:57 +00:00
|
|
|
early_kdump_load
|
|
|
|
else
|
2020-11-05 05:34:29 +00:00
|
|
|
dinfo "early-kdump is disabled."
|
2020-10-15 12:45:57 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
set_early_kdump
|