]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
arm64: KVM: Use lm_alias() for kvm_ksym_ref()
authorMark Rutland <mark.rutland@arm.com>
Thu, 10 May 2018 11:13:47 +0000 (12:13 +0100)
committerMarc Zyngier <marc.zyngier@arm.com>
Sun, 20 May 2018 10:44:01 +0000 (11:44 +0100)
For historical reasons, we open-code lm_alias() in kvm_ksym_ref().

Let's use lm_alias() to avoid duplication and make things clearer.

As we have to pull this from <linux/mm.h> (which is not safe for
inclusion in assembly), we may as well move the kvm_ksym_ref()
definition into the existing !__ASSEMBLY__ block.

Signed-off-by: Mark Rutland <mark.rutland@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Marc Zyngier <marc.zyngier@arm.com>
Cc: kvmarm@lists.cs.columbia.edu
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
arch/arm64/include/asm/kvm_asm.h

index f6648a3e4152c3cd95652563d3003abc090795df..a9ceeec5a76fff5355a2719774b39c6566208cbf 100644 (file)
 #define KVM_ARM64_DEBUG_DIRTY_SHIFT    0
 #define KVM_ARM64_DEBUG_DIRTY          (1 << KVM_ARM64_DEBUG_DIRTY_SHIFT)
 
+#ifndef __ASSEMBLY__
+
+#include <linux/mm.h>
+
 /* Translate a kernel address of @sym into its equivalent linear mapping */
 #define kvm_ksym_ref(sym)                                              \
        ({                                                              \
                void *val = &sym;                                       \
                if (!is_kernel_in_hyp_mode())                           \
-                       val = phys_to_virt((u64)&sym - kimage_voffset); \
+                       val = lm_alias(&sym);                           \
                val;                                                    \
         })
 
-#ifndef __ASSEMBLY__
 struct kvm;
 struct kvm_vcpu;