|
@@ -1840,22 +1840,29 @@ mmio:
|
|
|
return X86EMUL_UNHANDLEABLE;
|
|
|
}
|
|
|
|
|
|
-static int emulator_write_phys(struct kvm_vcpu *vcpu, gpa_t gpa,
|
|
|
- const void *val, int bytes)
|
|
|
+int __emulator_write_phys(struct kvm_vcpu *vcpu, gpa_t gpa,
|
|
|
+ const void *val, int bytes)
|
|
|
{
|
|
|
int ret;
|
|
|
|
|
|
- down_read(&vcpu->kvm->slots_lock);
|
|
|
ret = kvm_write_guest(vcpu->kvm, gpa, val, bytes);
|
|
|
- if (ret < 0) {
|
|
|
- up_read(&vcpu->kvm->slots_lock);
|
|
|
+ if (ret < 0)
|
|
|
return 0;
|
|
|
- }
|
|
|
kvm_mmu_pte_write(vcpu, gpa, val, bytes);
|
|
|
- up_read(&vcpu->kvm->slots_lock);
|
|
|
return 1;
|
|
|
}
|
|
|
|
|
|
+static int emulator_write_phys(struct kvm_vcpu *vcpu, gpa_t gpa,
|
|
|
+ const void *val, int bytes)
|
|
|
+{
|
|
|
+ int ret;
|
|
|
+
|
|
|
+ down_read(&vcpu->kvm->slots_lock);
|
|
|
+ ret =__emulator_write_phys(vcpu, gpa, val, bytes);
|
|
|
+ up_read(&vcpu->kvm->slots_lock);
|
|
|
+ return ret;
|
|
|
+}
|
|
|
+
|
|
|
static int emulator_write_emulated_onepage(unsigned long addr,
|
|
|
const void *val,
|
|
|
unsigned int bytes,
|