KVM: arm64: Use kmemleak_free_part_phys() to unregister hyp_mem_base
authorZenghui Yu <yuzenghui@huawei.com>
Thu, 8 Sep 2022 13:06:59 +0000 (21:06 +0800)
committerMarc Zyngier <maz@kernel.org>
Mon, 19 Sep 2022 16:59:48 +0000 (17:59 +0100)
commit522c9a64c7049f50c7b1299741c13fac3f231cd4
treec8756f0c8ea83b7bc846ca71dc8928d82e5542b3
parent1c23f9e627a7b412978b4e852793c5e3c3efc555
KVM: arm64: Use kmemleak_free_part_phys() to unregister hyp_mem_base

With commit 0c24e061196c ("mm: kmemleak: add rbtree and store physical
address for objects allocated with PA"), kmemleak started to put the
objects allocated with physical address onto object_phys_tree_root tree.
The kmemleak_free_part() therefore no longer worked as expected on
physically allocated objects (hyp_mem_base in this case) as it attempted to
search and remove things in object_tree_root tree.

Fix it by using kmemleak_free_part_phys() to unregister hyp_mem_base. This
fixes an immediate crash when booting a KVM host in protected mode with
kmemleak enabled.

Signed-off-by: Zenghui Yu <yuzenghui@huawei.com>
Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Reviewed-by: Oliver Upton <oliver.upton@linux.dev>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20220908130659.2021-1-yuzenghui@huawei.com
arch/arm64/kvm/arm.c