arm64: KVM: Move vector offsetting from hyp-init.S to kvm_get_hyp_vector
authorMarc Zyngier <marc.zyngier@arm.com>
Mon, 12 Feb 2018 16:50:19 +0000 (16:50 +0000)
committerMarc Zyngier <marc.zyngier@arm.com>
Mon, 19 Mar 2018 13:05:37 +0000 (13:05 +0000)
We currently provide the hyp-init code with a kernel VA, and expect
it to turn it into a HYP va by itself. As we're about to provide
the hypervisor with mappings that are not necessarily in the memory
range, let's move the kern_hyp_va macro to kvm_get_hyp_vector.

No functionnal change.

Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
arch/arm64/include/asm/kvm_mmu.h
arch/arm64/kvm/hyp-init.S

index a84e2dd14ebe82dfd1e94ec30257889d3c3e0636..8cd37eac6292dccb0c9f945f42cfa32b8a8745c2 100644 (file)
@@ -374,6 +374,7 @@ static inline void *kvm_get_hyp_vector(void)
                        vect = lm_alias(vect);
        }
 
+       vect = kern_hyp_va(vect);
        return vect;
 }
 
@@ -387,7 +388,7 @@ static inline int kvm_map_vectors(void)
 #else
 static inline void *kvm_get_hyp_vector(void)
 {
-       return kvm_ksym_ref(__kvm_hyp_vector);
+       return kern_hyp_va(kvm_ksym_ref(__kvm_hyp_vector));
 }
 
 static inline int kvm_map_vectors(void)
index 5aa9ccf6db99308d40ff903721f08091facd302d..6fd91b31a131857c9dd70002245f99220adc5a31 100644 (file)
@@ -117,7 +117,6 @@ CPU_BE(     orr     x4, x4, #SCTLR_ELx_EE)
        /* Set the stack and new vectors */
        kern_hyp_va     x1
        mov     sp, x1
-       kern_hyp_va     x2
        msr     vbar_el2, x2
 
        /* copy tpidr_el1 into tpidr_el2 for use by HYP */