Commit b9904085 authored by Sean Christopherson's avatar Sean Christopherson Committed by Paolo Bonzini

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: default avatarCornelia Huck <cohuck@redhat.com>
Tested-by: Cornelia Huck <cohuck@redhat.com> #s390
Acked-by: default avatarMarc Zyngier <maz@kernel.org>
Signed-off-by: default avatarSean Christopherson <sean.j.christopherson@intel.com>
Message-Id: <20200321202603.19355-2-sean.j.christopherson@intel.com>
Reviewed-by: default avatarVitaly Kuznetsov <vkuznets@redhat.com>
Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
parent 4f4af841
...@@ -118,12 +118,12 @@ void kvm_arch_hardware_disable(void) ...@@ -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) ...@@ -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) ...@@ -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 = { ...@@ -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) ...@@ -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) ...@@ -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); ...@@ -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) ...@@ -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) ...@@ -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, ...@@ -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;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment