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>
This commit is contained in:
Liran Alon 2019-06-19 19:21:32 +03:00 committed by Paolo Bonzini
parent 6b2341eeea
commit b1115c9991
8 changed files with 48 additions and 0 deletions

View File

@ -291,6 +291,11 @@ int kvm_destroy_vcpu(CPUState *cpu)
DPRINTF("kvm_destroy_vcpu\n"); DPRINTF("kvm_destroy_vcpu\n");
ret = kvm_arch_destroy_vcpu(cpu);
if (ret < 0) {
goto err;
}
mmap_size = kvm_ioctl(s, KVM_GET_VCPU_MMAP_SIZE, 0); mmap_size = kvm_ioctl(s, KVM_GET_VCPU_MMAP_SIZE, 0);
if (mmap_size < 0) { if (mmap_size < 0) {
ret = mmap_size; ret = mmap_size;

View File

@ -371,6 +371,7 @@ int kvm_arch_put_registers(CPUState *cpu, int level);
int kvm_arch_init(MachineState *ms, KVMState *s); int kvm_arch_init(MachineState *ms, KVMState *s);
int kvm_arch_init_vcpu(CPUState *cpu); int kvm_arch_init_vcpu(CPUState *cpu);
int kvm_arch_destroy_vcpu(CPUState *cpu);
bool kvm_vcpu_id_is_valid(int vcpu_id); bool kvm_vcpu_id_is_valid(int vcpu_id);

View File

@ -240,6 +240,11 @@ int kvm_arch_init_vcpu(CPUState *cs)
return kvm_arm_init_cpreg_list(cpu); return kvm_arm_init_cpreg_list(cpu);
} }
int kvm_arch_destroy_vcpu(CPUState *cs)
{
return 0;
}
typedef struct Reg { typedef struct Reg {
uint64_t id; uint64_t id;
int offset; int offset;

View File

@ -654,6 +654,11 @@ int kvm_arch_init_vcpu(CPUState *cs)
return kvm_arm_init_cpreg_list(cpu); return kvm_arm_init_cpreg_list(cpu);
} }
int kvm_arch_destroy_vcpu(CPUState *cs)
{
return 0;
}
bool kvm_arm_reg_syncs_via_cpreg_list(uint64_t regidx) bool kvm_arm_reg_syncs_via_cpreg_list(uint64_t regidx)
{ {
/* Return true if the regidx is a register we should synchronize /* Return true if the regidx is a register we should synchronize

View File

@ -1679,6 +1679,18 @@ int kvm_arch_init_vcpu(CPUState *cs)
return r; 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) void kvm_arch_reset_vcpu(X86CPU *cpu)
{ {
CPUX86State *env = &cpu->env; CPUX86State *env = &cpu->env;

View File

@ -91,6 +91,11 @@ int kvm_arch_init_vcpu(CPUState *cs)
return ret; return ret;
} }
int kvm_arch_destroy_vcpu(CPUState *cs)
{
return 0;
}
void kvm_mips_reset_vcpu(MIPSCPU *cpu) void kvm_mips_reset_vcpu(MIPSCPU *cpu)
{ {
CPUMIPSState *env = &cpu->env; CPUMIPSState *env = &cpu->env;

View File

@ -521,6 +521,11 @@ int kvm_arch_init_vcpu(CPUState *cs)
return ret; return ret;
} }
int kvm_arch_destroy_vcpu(CPUState *cs)
{
return 0;
}
static void kvm_sw_tlb_put(PowerPCCPU *cpu) static void kvm_sw_tlb_put(PowerPCCPU *cpu)
{ {
CPUPPCState *env = &cpu->env; CPUPPCState *env = &cpu->env;

View File

@ -368,6 +368,16 @@ int kvm_arch_init_vcpu(CPUState *cs)
return 0; return 0;
} }
int kvm_arch_destroy_vcpu(CPUState *cs)
{
S390CPU *cpu = S390_CPU(cs);
g_free(cpu->irqstate);
cpu->irqstate = NULL;
return 0;
}
void kvm_s390_reset_vcpu(S390CPU *cpu) void kvm_s390_reset_vcpu(S390CPU *cpu)
{ {
CPUState *cs = CPU(cpu); CPUState *cs = CPU(cpu);