mirror of https://gitee.com/openkylin/linux.git
KVM: Pass kvm_init()'s opaque param to additional arch funcs
Pass @opaque to kvm_arch_hardware_setup() and kvm_arch_check_processor_compat() to allow architecture specific code to reference @opaque without having to stash it away in a temporary global variable. This will enable x86 to separate its vendor specific callback ops, which are passed via @opaque, into "init" and "runtime" ops without having to stash away the "init" ops. No functional change intended. Reviewed-by: Cornelia Huck <cohuck@redhat.com> Tested-by: Cornelia Huck <cohuck@redhat.com> #s390 Acked-by: Marc Zyngier <maz@kernel.org> Signed-off-by: Sean Christopherson <sean.j.christopherson@intel.com> Message-Id: <20200321202603.19355-2-sean.j.christopherson@intel.com> Reviewed-by: Vitaly Kuznetsov <vkuznets@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
4f4af841f0
commit
b990408537
|
@ -118,12 +118,12 @@ void kvm_arch_hardware_disable(void)
|
||||||
kvm_mips_callbacks->hardware_disable();
|
kvm_mips_callbacks->hardware_disable();
|
||||||
}
|
}
|
||||||
|
|
||||||
int kvm_arch_hardware_setup(void)
|
int kvm_arch_hardware_setup(void *opaque)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int kvm_arch_check_processor_compat(void)
|
int kvm_arch_check_processor_compat(void *opaque)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -415,12 +415,12 @@ int kvm_arch_hardware_enable(void)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int kvm_arch_hardware_setup(void)
|
int kvm_arch_hardware_setup(void *opaque)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int kvm_arch_check_processor_compat(void)
|
int kvm_arch_check_processor_compat(void *opaque)
|
||||||
{
|
{
|
||||||
return kvmppc_core_check_processor_compat();
|
return kvmppc_core_check_processor_compat();
|
||||||
}
|
}
|
||||||
|
|
|
@ -235,7 +235,7 @@ int kvm_arch_hardware_enable(void)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int kvm_arch_check_processor_compat(void)
|
int kvm_arch_check_processor_compat(void *opaque)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -302,7 +302,7 @@ static struct notifier_block kvm_clock_notifier = {
|
||||||
.notifier_call = kvm_clock_sync,
|
.notifier_call = kvm_clock_sync,
|
||||||
};
|
};
|
||||||
|
|
||||||
int kvm_arch_hardware_setup(void)
|
int kvm_arch_hardware_setup(void *opaque)
|
||||||
{
|
{
|
||||||
gmap_notifier.notifier_call = kvm_gmap_notifier;
|
gmap_notifier.notifier_call = kvm_gmap_notifier;
|
||||||
gmap_register_pte_notifier(&gmap_notifier);
|
gmap_register_pte_notifier(&gmap_notifier);
|
||||||
|
|
|
@ -9626,7 +9626,7 @@ void kvm_arch_hardware_disable(void)
|
||||||
drop_user_return_notifiers();
|
drop_user_return_notifiers();
|
||||||
}
|
}
|
||||||
|
|
||||||
int kvm_arch_hardware_setup(void)
|
int kvm_arch_hardware_setup(void *opaque)
|
||||||
{
|
{
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
|
@ -9667,7 +9667,7 @@ void kvm_arch_hardware_unsetup(void)
|
||||||
kvm_x86_ops->hardware_unsetup();
|
kvm_x86_ops->hardware_unsetup();
|
||||||
}
|
}
|
||||||
|
|
||||||
int kvm_arch_check_processor_compat(void)
|
int kvm_arch_check_processor_compat(void *opaque)
|
||||||
{
|
{
|
||||||
struct cpuinfo_x86 *c = &cpu_data(smp_processor_id());
|
struct cpuinfo_x86 *c = &cpu_data(smp_processor_id());
|
||||||
|
|
||||||
|
|
|
@ -886,9 +886,9 @@ void kvm_arch_create_vcpu_debugfs(struct kvm_vcpu *vcpu);
|
||||||
|
|
||||||
int kvm_arch_hardware_enable(void);
|
int kvm_arch_hardware_enable(void);
|
||||||
void kvm_arch_hardware_disable(void);
|
void kvm_arch_hardware_disable(void);
|
||||||
int kvm_arch_hardware_setup(void);
|
int kvm_arch_hardware_setup(void *opaque);
|
||||||
void kvm_arch_hardware_unsetup(void);
|
void kvm_arch_hardware_unsetup(void);
|
||||||
int kvm_arch_check_processor_compat(void);
|
int kvm_arch_check_processor_compat(void *opaque);
|
||||||
int kvm_arch_vcpu_runnable(struct kvm_vcpu *vcpu);
|
int kvm_arch_vcpu_runnable(struct kvm_vcpu *vcpu);
|
||||||
bool kvm_arch_vcpu_in_kernel(struct kvm_vcpu *vcpu);
|
bool kvm_arch_vcpu_in_kernel(struct kvm_vcpu *vcpu);
|
||||||
int kvm_arch_vcpu_should_kick(struct kvm_vcpu *vcpu);
|
int kvm_arch_vcpu_should_kick(struct kvm_vcpu *vcpu);
|
||||||
|
|
|
@ -64,12 +64,12 @@ int kvm_arch_vcpu_should_kick(struct kvm_vcpu *vcpu)
|
||||||
return kvm_vcpu_exiting_guest_mode(vcpu) == IN_GUEST_MODE;
|
return kvm_vcpu_exiting_guest_mode(vcpu) == IN_GUEST_MODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
int kvm_arch_hardware_setup(void)
|
int kvm_arch_hardware_setup(void *opaque)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int kvm_arch_check_processor_compat(void)
|
int kvm_arch_check_processor_compat(void *opaque)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -4648,14 +4648,22 @@ struct kvm_vcpu * __percpu *kvm_get_running_vcpus(void)
|
||||||
return &kvm_running_vcpu;
|
return &kvm_running_vcpu;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void check_processor_compat(void *rtn)
|
struct kvm_cpu_compat_check {
|
||||||
|
void *opaque;
|
||||||
|
int *ret;
|
||||||
|
};
|
||||||
|
|
||||||
|
static void check_processor_compat(void *data)
|
||||||
{
|
{
|
||||||
*(int *)rtn = kvm_arch_check_processor_compat();
|
struct kvm_cpu_compat_check *c = data;
|
||||||
|
|
||||||
|
*c->ret = kvm_arch_check_processor_compat(c->opaque);
|
||||||
}
|
}
|
||||||
|
|
||||||
int kvm_init(void *opaque, unsigned vcpu_size, unsigned vcpu_align,
|
int kvm_init(void *opaque, unsigned vcpu_size, unsigned vcpu_align,
|
||||||
struct module *module)
|
struct module *module)
|
||||||
{
|
{
|
||||||
|
struct kvm_cpu_compat_check c;
|
||||||
int r;
|
int r;
|
||||||
int cpu;
|
int cpu;
|
||||||
|
|
||||||
|
@ -4679,12 +4687,14 @@ int kvm_init(void *opaque, unsigned vcpu_size, unsigned vcpu_align,
|
||||||
goto out_free_0;
|
goto out_free_0;
|
||||||
}
|
}
|
||||||
|
|
||||||
r = kvm_arch_hardware_setup();
|
r = kvm_arch_hardware_setup(opaque);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
goto out_free_1;
|
goto out_free_1;
|
||||||
|
|
||||||
|
c.ret = &r;
|
||||||
|
c.opaque = opaque;
|
||||||
for_each_online_cpu(cpu) {
|
for_each_online_cpu(cpu) {
|
||||||
smp_call_function_single(cpu, check_processor_compat, &r, 1);
|
smp_call_function_single(cpu, check_processor_compat, &c, 1);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
goto out_free_2;
|
goto out_free_2;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue