]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
KVM: arm64: nv: Report addrsz fault at level 0 with a bad VTTBR.BADDR
authorZenghui Yu (Huawei) <zenghui.yu@linux.dev>
Wed, 25 Feb 2026 17:35:14 +0000 (01:35 +0800)
committerMarc Zyngier <maz@kernel.org>
Thu, 5 Mar 2026 15:46:48 +0000 (15:46 +0000)
As per R_BFHQH,

" When an Address size fault is generated, the reported fault code
  indicates one of the following:

  If the fault was generated due to the TTBR_ELx used in the translation
  having nonzero address bits above the OA size, then a fault at level 0. "

Fix the reported Address size fault level as being 0 if the base address is
wrongly programmed by L1.

Fixes: 61e30b9eef7f ("KVM: arm64: nv: Implement nested Stage-2 page table walk logic")
Signed-off-by: Zenghui Yu (Huawei) <zenghui.yu@linux.dev>
Link: https://patch.msgid.link/20260225173515.20490-3-zenghui.yu@linux.dev
Signed-off-by: Marc Zyngier <maz@kernel.org>
arch/arm64/kvm/nested.c

index 9da28814b64603695ce1c5b1c91fac4c52c95981..91e4f3cb580a044da941946faf3c0ab128debf62 100644 (file)
@@ -280,7 +280,8 @@ static int walk_nested_s2_pgd(struct kvm_vcpu *vcpu, phys_addr_t ipa,
        base_addr = wi->baddr & GENMASK_ULL(47, base_lower_bound);
 
        if (check_output_size(wi, base_addr)) {
-               out->esr = compute_fsc(level, ESR_ELx_FSC_ADDRSZ);
+               /* R_BFHQH */
+               out->esr = compute_fsc(0, ESR_ELx_FSC_ADDRSZ);
                return 1;
        }