]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commit
xen/balloon: add late_initcall_sync() for initial ballooning done
authorJuergen Gross <jgross@suse.com>
Tue, 2 Nov 2021 09:19:44 +0000 (10:19 +0100)
committerAndrea Righi <andrea.righi@canonical.com>
Tue, 4 Jan 2022 08:48:11 +0000 (09:48 +0100)
commite0af2c3049e1440412354cf7a77277274e14e516
tree750ced2bd25ae2616df8df37799c4278fff32b6d
parent4a20f90d8fa9babd87d7510ad141b81aee3a1b28
xen/balloon: add late_initcall_sync() for initial ballooning done

BugLink: https://bugs.launchpad.net/bugs/1951822
commit 40fdea0284bb20814399da0484a658a96c735d90 upstream.

When running as PVH or HVM guest with actual memory < max memory the
hypervisor is using "populate on demand" in order to allow the guest
to balloon down from its maximum memory size. For this to work
correctly the guest must not touch more memory pages than its target
memory size as otherwise the PoD cache will be exhausted and the guest
is crashed as a result of that.

In extreme cases ballooning down might not be finished today before
the init process is started, which can consume lots of memory.

In order to avoid random boot crashes in such cases, add a late init
call to wait for ballooning down having finished for PVH/HVM guests.

Warn on console if initial ballooning fails, panic() after stalling
for more than 3 minutes per default. Add a module parameter for
changing this timeout.

[boris: replaced pr_info() with pr_notice()]

Cc: <stable@vger.kernel.org>
Reported-by: Marek Marczykowski-Górecki <marmarek@invisiblethingslab.com>
Signed-off-by: Juergen Gross <jgross@suse.com>
Link: https://lore.kernel.org/r/20211102091944.17487-1-jgross@suse.com
Reviewed-by: Boris Ostrovsky <boris.ostrovsky@oracle.com>
Signed-off-by: Boris Ostrovsky <boris.ostrovsky@oracle.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Paolo Pisati <paolo.pisati@canonical.com>
Documentation/admin-guide/kernel-parameters.txt
drivers/xen/balloon.c