kdumpctl: force rebuild in case of dynamic system modification
There could be some dynamic system modification, which may affect kdump kernel boot process. In such situation initramfs must be rebuilt on the basis of changes. Since most of these checking methods will use information from TARGET_INITRD, therefore check its existence in common code. Signed-off-by: Pratyush Anand <panand@redhat.com> Acked-by: Xunlei Pang <xlpang@redhat.com> Acked-by: Baoquan He <xlpang@redhat.com> Acked-by: Dave Young <dyoung@redhat.com>
This commit is contained in:
parent
87964860b6
commit
e4143381b1
21
kdumpctl
21
kdumpctl
@ -327,10 +327,21 @@ setup_target_initrd()
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# returns 0 if system is not modified
|
||||||
|
# returns 1 if system is modified
|
||||||
|
# returns 2 if system modification is invalid
|
||||||
|
check_system_modified()
|
||||||
|
{
|
||||||
|
[[ -f $TARGET_INITRD ]] || return 1
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
check_rebuild()
|
check_rebuild()
|
||||||
{
|
{
|
||||||
local extra_modules modified_files=""
|
local extra_modules modified_files=""
|
||||||
local _force_rebuild force_rebuild="0"
|
local _force_rebuild force_rebuild="0"
|
||||||
|
local ret system_modified="0"
|
||||||
local initramfs_has_fadump
|
local initramfs_has_fadump
|
||||||
|
|
||||||
check_boot_dir
|
check_boot_dir
|
||||||
@ -388,6 +399,14 @@ check_rebuild()
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
|
check_system_modified
|
||||||
|
ret=$?
|
||||||
|
if [ $ret -eq 2 ]; then
|
||||||
|
return 1
|
||||||
|
elif [ $ret -eq 1 ];then
|
||||||
|
system_modified="1"
|
||||||
|
fi
|
||||||
|
|
||||||
#check if target initrd has fadump support
|
#check if target initrd has fadump support
|
||||||
if [ "$DEFAULT_DUMP_MODE" = "fadump" ] && [ -f "$TARGET_INITRD" ]; then
|
if [ "$DEFAULT_DUMP_MODE" = "fadump" ] && [ -f "$TARGET_INITRD" ]; then
|
||||||
initramfs_has_fadump=`lsinitrd -m $TARGET_INITRD | grep ^kdumpbase$ | wc -l`
|
initramfs_has_fadump=`lsinitrd -m $TARGET_INITRD | grep ^kdumpbase$ | wc -l`
|
||||||
@ -399,6 +418,8 @@ check_rebuild()
|
|||||||
echo "$TARGET_INITRD has no fadump support"
|
echo "$TARGET_INITRD has no fadump support"
|
||||||
elif [ "$force_rebuild" != "0" ]; then
|
elif [ "$force_rebuild" != "0" ]; then
|
||||||
echo -n "Force rebuild $TARGET_INITRD"; echo
|
echo -n "Force rebuild $TARGET_INITRD"; echo
|
||||||
|
elif [ "$system_modified" != "0" ]; then
|
||||||
|
:
|
||||||
elif [ -n "$modified_files" ]; then
|
elif [ -n "$modified_files" ]; then
|
||||||
echo "Detected change(s) in the following file(s):"
|
echo "Detected change(s) in the following file(s):"
|
||||||
echo -n " "; echo "$modified_files" | sed 's/\s/\n /g'
|
echo -n " "; echo "$modified_files" | sed 's/\s/\n /g'
|
||||||
|
Loading…
Reference in New Issue
Block a user