kdumpctl: make do_estimate more robust

At the beginning of do_estimate it currently checks whether the
TARGET_INITRD exists and if not fails with an error message. This not
only requires the user to manually trigger the build of the initrd but
also ignores all cases where the TARGET_INITRD exists but need to be
rebuild. For example when there were changes to kdump.conf or when the
system switches from kdump to fadump. All these changes will impact the
outcome of do_estimate. Thus properly check whether the initrd needs to
be rebuild and if it does trigger the rebuild automatically.

To do so move the check whether the TARGET_INITRD has fadump enabled to
is_system_modified and call this function. With this force_(no_)rebuild
options in kdump.conf are ignored to avoid unnecessary rebuilds.

While at it cleanup check_system_modified and rename it to
is_system_modified. Furthermore move printing the info that the initrd
gets rebuild to rebuild_initrd to avoid every caller has the same line.

Signed-off-by: Philipp Rudo <prudo@redhat.com>
Reviewed-by: Coiby Xu <coxu@redhat.com>
This commit is contained in:
Philipp Rudo 2023-01-12 16:31:11 +01:00 committed by Coiby Xu
parent 37577b93ed
commit d4e877214c

View File

@ -16,7 +16,6 @@ KDUMP_INITRD=""
TARGET_INITRD="" TARGET_INITRD=""
#kdump shall be the default dump mode #kdump shall be the default dump mode
DEFAULT_DUMP_MODE="kdump" DEFAULT_DUMP_MODE="kdump"
image_time=0
standard_kexec_args="-d -p" standard_kexec_args="-d -p"
@ -117,6 +116,8 @@ rebuild_kdump_initrd()
rebuild_initrd() rebuild_initrd()
{ {
dinfo "Rebuilding $TARGET_INITRD"
if [[ ! -w $(dirname "$TARGET_INITRD") ]]; then if [[ ! -w $(dirname "$TARGET_INITRD") ]]; then
derror "$(dirname "$TARGET_INITRD") does not have write permission. Cannot rebuild $TARGET_INITRD" derror "$(dirname "$TARGET_INITRD") does not have write permission. Cannot rebuild $TARGET_INITRD"
return 1 return 1
@ -294,10 +295,12 @@ get_pcs_cluster_modified_files()
{ {
local time_stamp local time_stamp
local modified_files local modified_files
local image_time
is_generic_fence_kdump && return 1 is_generic_fence_kdump && return 1
is_pcs_fence_kdump || return 1 is_pcs_fence_kdump || return 1
image_time=$1
time_stamp=$(pcs cluster cib | xmllint --xpath 'string(/cib/@cib-last-written)' - | xargs -0 date +%s --date) time_stamp=$(pcs cluster cib | xmllint --xpath 'string(/cib/@cib-last-written)' - | xargs -0 date +%s --date)
if [[ -n $time_stamp ]] && [[ $time_stamp -gt $image_time ]]; then if [[ -n $time_stamp ]] && [[ $time_stamp -gt $image_time ]]; then
@ -341,10 +344,14 @@ setup_initrd()
check_files_modified() check_files_modified()
{ {
local modified_files="" local modified_files=""
local image_time
image_time=$(stat -c "%Y" "$TARGET_INITRD" 2> /dev/null)
#also rebuild when Pacemaker cluster conf is changed and fence kdump is enabled. #also rebuild when Pacemaker cluster conf is changed and fence kdump is enabled.
modified_files=$(get_pcs_cluster_modified_files) modified_files=$(get_pcs_cluster_modified_files "$image_time")
EXTRA_BINS=${OPT[kdump_post]} EXTRA_BINS=${OPT[kdump_post]}
CHECK_FILES=${OPT[kdump_pre]} CHECK_FILES=${OPT[kdump_pre]}
@ -532,32 +539,25 @@ check_fs_modified()
# returns 0 if system is not modified # returns 0 if system is not modified
# returns 1 if system is modified # returns 1 if system is modified
# returns 2 if system modification is invalid # returns 2 if an error occurred
check_system_modified() is_system_modified()
{ {
local ret local ret
[[ -f $TARGET_INITRD ]] || return 1 [[ -f $TARGET_INITRD ]] || return 1
check_files_modified # in case of fadump mode, check whether the default/target initrd is
ret=$? # already built with dump capture capability
if [[ $ret -ne 0 ]]; then if [[ $DEFAULT_DUMP_MODE == "fadump" ]]; then
return $ret if ! lsinitrd -f $DRACUT_MODULES_FILE "$TARGET_INITRD" | grep -q -e ^kdumpbase$ -e ^zz-fadumpinit$; then
fi dinfo "Rebuild $TARGET_INITRD with dump capture support"
return 1
check_fs_modified fi
ret=$?
if [[ $ret -ne 0 ]]; then
return $ret
fi fi
check_files_modified || return
check_fs_modified || return
check_drivers_modified check_drivers_modified
ret=$?
if [[ $ret -ne 0 ]]; then
return $ret
fi
return 0
} }
# need_initrd_rebuild - check whether the initrd needs to be rebuild # need_initrd_rebuild - check whether the initrd needs to be rebuild
@ -600,18 +600,7 @@ need_initrd_rebuild()
return 1 return 1
fi fi
# in case of fadump mode, check whether the default/target initrd is is_system_modified
# already built with dump capture capability
if [[ $DEFAULT_DUMP_MODE == "fadump" ]]; then
if ! lsinitrd -f $DRACUT_MODULES_FILE "$TARGET_INITRD" | grep -q -e ^kdumpbase$ -e ^zz-fadumpinit$; then
dinfo "Rebuild $TARGET_INITRD with dump capture support"
return 1
fi
fi
image_time=$(stat -c "%Y" "$TARGET_INITRD" 2> /dev/null)
check_system_modified
} }
# On ppc64le LPARs, the keys trusted by firmware do not end up in # On ppc64le LPARs, the keys trusted by firmware do not end up in
@ -994,7 +983,6 @@ start()
# Nothing to do # Nothing to do
;; ;;
1) 1)
dinfo "Rebuilding $TARGET_INITRD"
rebuild_initrd || return rebuild_initrd || return
;; ;;
*) *)
@ -1105,7 +1093,6 @@ rebuild()
setup_initrd || return 1 setup_initrd || return 1
dinfo "Rebuilding $TARGET_INITRD"
rebuild_initrd rebuild_initrd
} }
@ -1118,10 +1105,18 @@ do_estimate()
local size_mb=$((1024 * 1024)) local size_mb=$((1024 * 1024))
setup_initrd setup_initrd
if [[ ! -f $TARGET_INITRD ]]; then is_system_modified
derror "kdumpctl estimate: kdump initramfs is not built yet." case "$?" in
exit 1 0)
fi # Nothing to do
;;
1)
rebuild_initrd || return
;;
*)
return
;;
esac
kdump_mods="$(lsinitrd "$TARGET_INITRD" -f /usr/lib/dracut/hostonly-kernel-modules.txt | tr '\n' ' ')" kdump_mods="$(lsinitrd "$TARGET_INITRD" -f /usr/lib/dracut/hostonly-kernel-modules.txt | tr '\n' ' ')"
baseline=$(kdump_get_arch_recommend_size) baseline=$(kdump_get_arch_recommend_size)