diff options
author | Liran Alon | 2019-06-19 18:21:32 +0200 |
---|---|---|
committer | Paolo Bonzini | 2019-06-21 02:29:39 +0200 |
commit | b1115c99919cf158bb859865f14c3198a0e6f679 (patch) | |
tree | c1ab6421d1e577e2868bd2eaee16d64c04ceea70 /target/i386/kvm.c | |
parent | target/i386: kvm: Delete VMX migration blocker on vCPU init failure (diff) | |
download | qemu-b1115c99919cf158bb859865f14c3198a0e6f679.tar.gz qemu-b1115c99919cf158bb859865f14c3198a0e6f679.tar.xz qemu-b1115c99919cf158bb859865f14c3198a0e6f679.zip |
KVM: Introduce kvm_arch_destroy_vcpu()
Simiar to how kvm_init_vcpu() calls kvm_arch_init_vcpu() to perform
arch-dependent initialisation, introduce kvm_arch_destroy_vcpu()
to be called from kvm_destroy_vcpu() to perform arch-dependent
destruction.
This was added because some architectures (Such as i386)
currently do not free memory that it have allocated in
kvm_arch_init_vcpu().
Suggested-by: Maran Wilson <maran.wilson@oracle.com>
Reviewed-by: Maran Wilson <maran.wilson@oracle.com>
Signed-off-by: Liran Alon <liran.alon@oracle.com>
Message-Id: <20190619162140.133674-3-liran.alon@oracle.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'target/i386/kvm.c')
-rw-r--r-- | target/i386/kvm.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/target/i386/kvm.c b/target/i386/kvm.c index c5cbeaddd1..26d8c61a5f 100644 --- a/target/i386/kvm.c +++ b/target/i386/kvm.c @@ -1679,6 +1679,18 @@ int kvm_arch_init_vcpu(CPUState *cs) return r; } +int kvm_arch_destroy_vcpu(CPUState *cs) +{ + X86CPU *cpu = X86_CPU(cs); + + if (cpu->kvm_msr_buf) { + g_free(cpu->kvm_msr_buf); + cpu->kvm_msr_buf = NULL; + } + + return 0; +} + void kvm_arch_reset_vcpu(X86CPU *cpu) { CPUX86State *env = &cpu->env; |