Message ID | alpine.LFD.2.03.1304090135590.1171@syhkavp.arg (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Tue, 2013-04-09 at 01:41 -0400, Nicolas Pitre wrote: > > Do the changes to the above mcpm files want to be in a separate patch as > > it's generic ARM code, not vexpress specific? > > Well, since it was so trivial I didn't do it, but the split might be a > good idea nevertheless. So I inserted the following patch in the > series, and corresponding changes are now removed from the patch above. > What do you think? Looks fine. Did you miss my other comment about smp_ops not looking like they were getting set in the case of mcpm_smp_set_ops not getting called? > Author: Nicolas Pitre <nicolas.pitre@linaro.org> > Date: Tue Apr 9 01:29:17 2013 -0400 > > ARM: mcpm: provide an interface to set the SMP ops at run time > > This is cleaner than exporting the mcpm_smp_ops structure. > > Signed-off-by: Nicolas Pitre <nico@linaro.org> > > diff --git a/arch/arm/common/mcpm_platsmp.c b/arch/arm/common/mcpm_platsmp.c > index 34f236af09..79ed70d846 100644 > --- a/arch/arm/common/mcpm_platsmp.c > +++ b/arch/arm/common/mcpm_platsmp.c > @@ -76,7 +76,7 @@ static void mcpm_cpu_die(unsigned int cpu) > > #endif > > -struct smp_operations __initdata mcpm_smp_ops = { > +static struct smp_operations __initdata mcpm_smp_ops = { > .smp_init_cpus = simple_smp_init_cpus, > .smp_boot_secondary = mcpm_boot_secondary, > .smp_secondary_init = mcpm_secondary_init, > @@ -85,3 +85,8 @@ struct smp_operations __initdata mcpm_smp_ops = { > .cpu_die = mcpm_cpu_die, > #endif > }; > + > +void __init mcpm_smp_set_ops(void) > +{ > + smp_set_ops(&mcpm_smp_ops); > +} > diff --git a/arch/arm/include/asm/mcpm_entry.h b/arch/arm/include/asm/mcpm_entry.h > index 814623e6a1..34dfb86ff5 100644 > --- a/arch/arm/include/asm/mcpm_entry.h > +++ b/arch/arm/include/asm/mcpm_entry.h > @@ -190,5 +190,7 @@ int __mcpm_cluster_state(unsigned int cluster); > int __init mcpm_sync_init( > void (*power_up_setup)(unsigned int affinity_level)); > > +void __init mcpm_smp_set_ops(void); > + > #endif /* ! __ASSEMBLY__ */ > #endif >
diff --git a/arch/arm/common/mcpm_platsmp.c b/arch/arm/common/mcpm_platsmp.c index 34f236af09..79ed70d846 100644 --- a/arch/arm/common/mcpm_platsmp.c +++ b/arch/arm/common/mcpm_platsmp.c @@ -76,7 +76,7 @@ static void mcpm_cpu_die(unsigned int cpu) #endif -struct smp_operations __initdata mcpm_smp_ops = { +static struct smp_operations __initdata mcpm_smp_ops = { .smp_init_cpus = simple_smp_init_cpus, .smp_boot_secondary = mcpm_boot_secondary, .smp_secondary_init = mcpm_secondary_init, @@ -85,3 +85,8 @@ struct smp_operations __initdata mcpm_smp_ops = { .cpu_die = mcpm_cpu_die, #endif }; + +void __init mcpm_smp_set_ops(void) +{ + smp_set_ops(&mcpm_smp_ops); +} diff --git a/arch/arm/include/asm/mcpm_entry.h b/arch/arm/include/asm/mcpm_entry.h index 814623e6a1..34dfb86ff5 100644 --- a/arch/arm/include/asm/mcpm_entry.h +++ b/arch/arm/include/asm/mcpm_entry.h @@ -190,5 +190,7 @@ int __mcpm_cluster_state(unsigned int cluster); int __init mcpm_sync_init( void (*power_up_setup)(unsigned int affinity_level)); +void __init mcpm_smp_set_ops(void); + #endif /* ! __ASSEMBLY__ */ #endif