|
@@ -6358,7 +6358,7 @@ static int handle_ept_violation(struct kvm_vcpu *vcpu)
|
|
{
|
|
{
|
|
unsigned long exit_qualification;
|
|
unsigned long exit_qualification;
|
|
gpa_t gpa;
|
|
gpa_t gpa;
|
|
- u32 error_code;
|
|
|
|
|
|
+ u64 error_code;
|
|
|
|
|
|
exit_qualification = vmcs_readl(EXIT_QUALIFICATION);
|
|
exit_qualification = vmcs_readl(EXIT_QUALIFICATION);
|
|
|
|
|
|
@@ -6390,6 +6390,9 @@ static int handle_ept_violation(struct kvm_vcpu *vcpu)
|
|
EPT_VIOLATION_EXECUTABLE))
|
|
EPT_VIOLATION_EXECUTABLE))
|
|
? PFERR_PRESENT_MASK : 0;
|
|
? PFERR_PRESENT_MASK : 0;
|
|
|
|
|
|
|
|
+ error_code |= (exit_qualification & 0x100) != 0 ?
|
|
|
|
+ PFERR_GUEST_FINAL_MASK : PFERR_GUEST_PAGE_MASK;
|
|
|
|
+
|
|
vcpu->arch.gpa_available = true;
|
|
vcpu->arch.gpa_available = true;
|
|
vcpu->arch.exit_qualification = exit_qualification;
|
|
vcpu->arch.exit_qualification = exit_qualification;
|
|
|
|
|