mirror of
https://github.com/dynup/kpatch
synced 2025-01-23 21:32:51 +00:00
b6692c14d7
Kernel version: 4.4.0-53-generic
25 lines
926 B
Diff
25 lines
926 B
Diff
diff -Nupr src.orig/arch/x86/kvm/vmx.c src/arch/x86/kvm/vmx.c
|
|
--- src.orig/arch/x86/kvm/vmx.c 2016-12-15 19:55:57.436000000 +0000
|
|
+++ src/arch/x86/kvm/vmx.c 2016-12-15 19:57:39.592000000 +0000
|
|
@@ -10558,10 +10558,20 @@ static void vmx_leave_nested(struct kvm_
|
|
* It should only be called before L2 actually succeeded to run, and when
|
|
* vmcs01 is current (it doesn't leave_guest_mode() or switch vmcss).
|
|
*/
|
|
+#include "kpatch.h"
|
|
static void nested_vmx_entry_failure(struct kvm_vcpu *vcpu,
|
|
struct vmcs12 *vmcs12,
|
|
u32 reason, unsigned long qualification)
|
|
{
|
|
+ int *kpatch;
|
|
+
|
|
+ kpatch = kpatch_shadow_alloc(vcpu, "kpatch", sizeof(*kpatch),
|
|
+ GFP_KERNEL);
|
|
+ if (kpatch) {
|
|
+ kpatch_shadow_get(vcpu, "kpatch");
|
|
+ kpatch_shadow_free(vcpu, "kpatch");
|
|
+ }
|
|
+
|
|
load_vmcs12_host_state(vcpu, vmcs12);
|
|
vmcs12->vm_exit_reason = reason | VMX_EXIT_REASONS_FAILED_VMENTRY;
|
|
vmcs12->exit_qualification = qualification;
|