]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
ARM: KVM: abstract HSR_EC_IABT away
authorMarc Zyngier <marc.zyngier@arm.com>
Mon, 15 Oct 2012 09:33:38 +0000 (10:33 +0100)
committerChristoffer Dall <cdall@cs.columbia.edu>
Wed, 6 Mar 2013 23:48:43 +0000 (15:48 -0800)
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
arch/arm/include/asm/kvm_emulate.h
arch/arm/kvm/mmu.c

index 021a59c46ddae731c39b1b0894d24505b558aa44..e59f8c0494f3fd1a9eb7ee25791bb2f067071a9d 100644 (file)
@@ -147,6 +147,11 @@ static inline u8 kvm_vcpu_trap_get_class(struct kvm_vcpu *vcpu)
        return kvm_vcpu_get_hsr(vcpu) >> HSR_EC_SHIFT;
 }
 
+static inline bool kvm_vcpu_trap_is_iabt(struct kvm_vcpu *vcpu)
+{
+       return kvm_vcpu_trap_get_class(vcpu) == HSR_EC_IABT;
+}
+
 static inline u8 kvm_vcpu_trap_get_fault(struct kvm_vcpu *vcpu)
 {
        return kvm_vcpu_get_hsr(vcpu) & HSR_FSC_TYPE;
index e00f28d2670c49f967f3cbec0de13b36cec0a3c8..8e9047a4b3b727fd3acdd2d707eccc1e7277acf8 100644 (file)
@@ -585,7 +585,6 @@ out_unlock:
  */
 int kvm_handle_guest_abort(struct kvm_vcpu *vcpu, struct kvm_run *run)
 {
-       unsigned long hsr_ec;
        unsigned long fault_status;
        phys_addr_t fault_ipa;
        struct kvm_memory_slot *memslot;
@@ -593,8 +592,7 @@ int kvm_handle_guest_abort(struct kvm_vcpu *vcpu, struct kvm_run *run)
        gfn_t gfn;
        int ret, idx;
 
-       hsr_ec = kvm_vcpu_trap_get_class(vcpu);
-       is_iabt = (hsr_ec == HSR_EC_IABT);
+       is_iabt = kvm_vcpu_trap_is_iabt(vcpu);
        fault_ipa = kvm_vcpu_get_fault_ipa(vcpu);
 
        trace_kvm_guest_fault(*vcpu_pc(vcpu), kvm_vcpu_get_hsr(vcpu),
@@ -603,8 +601,8 @@ int kvm_handle_guest_abort(struct kvm_vcpu *vcpu, struct kvm_run *run)
        /* Check the stage-2 fault is trans. fault or write fault */
        fault_status = kvm_vcpu_trap_get_fault(vcpu);
        if (fault_status != FSC_FAULT && fault_status != FSC_PERM) {
-               kvm_err("Unsupported fault status: EC=%#lx DFCS=%#lx\n",
-                       hsr_ec, fault_status);
+               kvm_err("Unsupported fault status: EC=%#x DFCS=%#lx\n",
+                       kvm_vcpu_trap_get_class(vcpu), fault_status);
                return -EFAULT;
        }