KVM: arm64: nv: Turn upper_attr for S2 walk into the full descriptor
authorMarc Zyngier <maz@kernel.org>
Fri, 21 Jun 2024 13:59:36 +0000 (14:59 +0100)
committerMarc Zyngier <maz@kernel.org>
Fri, 30 Aug 2024 11:04:20 +0000 (12:04 +0100)
The upper_attr attribute has been badly named, as it most of the
time carries the full "last walked descriptor".

Rename it to "desc" and make ti contain the full 64bit descriptor.
This will be used by the S1 PTW.

Signed-off-by: Marc Zyngier <maz@kernel.org>
arch/arm64/include/asm/kvm_nested.h
arch/arm64/kvm/nested.c

index 6e163501f13ea1ba48208d97a2301cc346d50513..43e531c67311cbd44a7c325dd5c614172304a528 100644 (file)
@@ -85,7 +85,7 @@ struct kvm_s2_trans {
        bool readable;
        int level;
        u32 esr;
-       u64 upper_attr;
+       u64 desc;
 };
 
 static inline phys_addr_t kvm_s2_trans_output(struct kvm_s2_trans *trans)
@@ -115,7 +115,7 @@ static inline bool kvm_s2_trans_writable(struct kvm_s2_trans *trans)
 
 static inline bool kvm_s2_trans_executable(struct kvm_s2_trans *trans)
 {
-       return !(trans->upper_attr & BIT(54));
+       return !(trans->desc & BIT(54));
 }
 
 extern int kvm_walk_nested_s2(struct kvm_vcpu *vcpu, phys_addr_t gipa,
index 49a7832a3fb1d8c293405757fed7b624d652dd46..234d0f6006c61a89b88e0e1ffbcbc04c9c44b03c 100644 (file)
@@ -256,7 +256,7 @@ static int walk_nested_s2_pgd(phys_addr_t ipa,
                /* Check for valid descriptor at this point */
                if (!(desc & 1) || ((desc & 3) == 1 && level == 3)) {
                        out->esr = compute_fsc(level, ESR_ELx_FSC_FAULT);
-                       out->upper_attr = desc;
+                       out->desc = desc;
                        return 1;
                }
 
@@ -266,7 +266,7 @@ static int walk_nested_s2_pgd(phys_addr_t ipa,
 
                if (check_output_size(wi, desc)) {
                        out->esr = compute_fsc(level, ESR_ELx_FSC_ADDRSZ);
-                       out->upper_attr = desc;
+                       out->desc = desc;
                        return 1;
                }
 
@@ -278,19 +278,19 @@ static int walk_nested_s2_pgd(phys_addr_t ipa,
 
        if (level < first_block_level) {
                out->esr = compute_fsc(level, ESR_ELx_FSC_FAULT);
-               out->upper_attr = desc;
+               out->desc = desc;
                return 1;
        }
 
        if (check_output_size(wi, desc)) {
                out->esr = compute_fsc(level, ESR_ELx_FSC_ADDRSZ);
-               out->upper_attr = desc;
+               out->desc = desc;
                return 1;
        }
 
        if (!(desc & BIT(10))) {
                out->esr = compute_fsc(level, ESR_ELx_FSC_ACCESS);
-               out->upper_attr = desc;
+               out->desc = desc;
                return 1;
        }
 
@@ -304,7 +304,7 @@ static int walk_nested_s2_pgd(phys_addr_t ipa,
        out->readable = desc & (0b01 << 6);
        out->writable = desc & (0b10 << 6);
        out->level = level;
-       out->upper_attr = desc & GENMASK_ULL(63, 52);
+       out->desc = desc;
        return 0;
 }