|
@@ -3448,6 +3448,11 @@ void kvm_get_segment(struct kvm_vcpu *vcpu,
|
|
kvm_x86_ops->get_segment(vcpu, var, seg);
|
|
kvm_x86_ops->get_segment(vcpu, var, seg);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+static gpa_t translate_gpa(struct kvm_vcpu *vcpu, gpa_t gpa, u32 access)
|
|
|
|
+{
|
|
|
|
+ return gpa;
|
|
|
|
+}
|
|
|
|
+
|
|
gpa_t kvm_mmu_gva_to_gpa_read(struct kvm_vcpu *vcpu, gva_t gva, u32 *error)
|
|
gpa_t kvm_mmu_gva_to_gpa_read(struct kvm_vcpu *vcpu, gva_t gva, u32 *error)
|
|
{
|
|
{
|
|
u32 access = (kvm_x86_ops->get_cpl(vcpu) == 3) ? PFERR_USER_MASK : 0;
|
|
u32 access = (kvm_x86_ops->get_cpl(vcpu) == 3) ? PFERR_USER_MASK : 0;
|
|
@@ -5659,6 +5664,7 @@ int kvm_arch_vcpu_init(struct kvm_vcpu *vcpu)
|
|
|
|
|
|
vcpu->arch.emulate_ctxt.ops = &emulate_ops;
|
|
vcpu->arch.emulate_ctxt.ops = &emulate_ops;
|
|
vcpu->arch.mmu.root_hpa = INVALID_PAGE;
|
|
vcpu->arch.mmu.root_hpa = INVALID_PAGE;
|
|
|
|
+ vcpu->arch.mmu.translate_gpa = translate_gpa;
|
|
if (!irqchip_in_kernel(kvm) || kvm_vcpu_is_bsp(vcpu))
|
|
if (!irqchip_in_kernel(kvm) || kvm_vcpu_is_bsp(vcpu))
|
|
vcpu->arch.mp_state = KVM_MP_STATE_RUNNABLE;
|
|
vcpu->arch.mp_state = KVM_MP_STATE_RUNNABLE;
|
|
else
|
|
else
|