|
@@ -835,6 +835,11 @@ static bool kvm_is_write_fault(struct kvm_vcpu *vcpu)
|
|
|
return kvm_vcpu_dabt_iswrite(vcpu);
|
|
|
}
|
|
|
|
|
|
+static bool kvm_is_device_pfn(unsigned long pfn)
|
|
|
+{
|
|
|
+ return !pfn_valid(pfn);
|
|
|
+}
|
|
|
+
|
|
|
static int user_mem_abort(struct kvm_vcpu *vcpu, phys_addr_t fault_ipa,
|
|
|
struct kvm_memory_slot *memslot, unsigned long hva,
|
|
|
unsigned long fault_status)
|
|
@@ -905,7 +910,7 @@ static int user_mem_abort(struct kvm_vcpu *vcpu, phys_addr_t fault_ipa,
|
|
|
if (is_error_pfn(pfn))
|
|
|
return -EFAULT;
|
|
|
|
|
|
- if (kvm_is_mmio_pfn(pfn))
|
|
|
+ if (kvm_is_device_pfn(pfn))
|
|
|
mem_type = PAGE_S2_DEVICE;
|
|
|
|
|
|
spin_lock(&kvm->mmu_lock);
|