Julien Grall
2013-Jul-25 15:29 UTC
[PATCH] xen/arm: Clean up identify processor call for secondary cpus
The smp_processor_id() is set at the beginning of start_secondary. We
don''t
need to compute ourself the offset of the cpu data.
---
xen/arch/arm/smpboot.c | 5 +----
1 file changed, 1 insertion(+), 4 deletions(-)
diff --git a/xen/arch/arm/smpboot.c b/xen/arch/arm/smpboot.c
index 5895178..872cc25 100644
--- a/xen/arch/arm/smpboot.c
+++ b/xen/arch/arm/smpboot.c
@@ -137,15 +137,12 @@ void __cpuinit start_secondary(unsigned long
boot_phys_offset,
unsigned long fdt_paddr,
unsigned long cpuid)
{
- struct cpuinfo_arm *c = cpu_data + cpuid;
-
memset(get_cpu_info(), 0, sizeof (struct cpu_info));
/* TODO: handle boards where CPUIDs are not contiguous */
set_processor_id(cpuid);
- *c = boot_cpu_data;
- identify_cpu(c);
+ identify_cpu(¤t_cpu_data);
init_traps();
--
1.7.10.4
Julien Grall
2013-Jul-25 15:36 UTC
Re: [PATCH] xen/arm: Clean up identify processor call for secondary cpus
On 07/25/2013 04:29 PM, Julien Grall wrote:> The smp_processor_id() is set at the beginning of start_secondary. We don''t > need to compute ourself the offset of the cpu data.I forgot the signed-off-by. Signed-off-by: Julien Grall <julien.grall@linaro.org>> --- > xen/arch/arm/smpboot.c | 5 +---- > 1 file changed, 1 insertion(+), 4 deletions(-) > > diff --git a/xen/arch/arm/smpboot.c b/xen/arch/arm/smpboot.c > index 5895178..872cc25 100644 > --- a/xen/arch/arm/smpboot.c > +++ b/xen/arch/arm/smpboot.c > @@ -137,15 +137,12 @@ void __cpuinit start_secondary(unsigned long boot_phys_offset, > unsigned long fdt_paddr, > unsigned long cpuid) > { > - struct cpuinfo_arm *c = cpu_data + cpuid; > - > memset(get_cpu_info(), 0, sizeof (struct cpu_info)); > > /* TODO: handle boards where CPUIDs are not contiguous */ > set_processor_id(cpuid); > > - *c = boot_cpu_data; > - identify_cpu(c); > + identify_cpu(¤t_cpu_data); > > init_traps(); > >
Ian Campbell
2013-Jul-29 08:57 UTC
Re: [PATCH] xen/arm: Clean up identify processor call for secondary cpus
On Thu, 2013-07-25 at 16:29 +0100, Julien Grall wrote:> The smp_processor_id() is set at the beginning of start_secondary. We don''t > need to compute ourself the offset of the cpu data. > --- > xen/arch/arm/smpboot.c | 5 +---- > 1 file changed, 1 insertion(+), 4 deletions(-) > > diff --git a/xen/arch/arm/smpboot.c b/xen/arch/arm/smpboot.c > index 5895178..872cc25 100644 > --- a/xen/arch/arm/smpboot.c > +++ b/xen/arch/arm/smpboot.c > @@ -137,15 +137,12 @@ void __cpuinit start_secondary(unsigned long boot_phys_offset, > unsigned long fdt_paddr, > unsigned long cpuid) > { > - struct cpuinfo_arm *c = cpu_data + cpuid; > - > memset(get_cpu_info(), 0, sizeof (struct cpu_info)); > > /* TODO: handle boards where CPUIDs are not contiguous */ > set_processor_id(cpuid); > > - *c = boot_cpu_data;This step defaults everything to the boot cpu''s settings. You could argue that this isn''t necessary iff identify_cpu always reinitialises everything but it doesn''t belong in this change IMHO. I think the defaulting behaviour is fine BTW, even if we don''t currently make use of it today. Ian.> - identify_cpu(c); > + identify_cpu(¤t_cpu_data); > > init_traps(); >
Julien Grall
2013-Jul-29 11:05 UTC
Re: [PATCH] xen/arm: Clean up identify processor call for secondary cpus
On 07/29/2013 09:57 AM, Ian Campbell wrote:> On Thu, 2013-07-25 at 16:29 +0100, Julien Grall wrote: >> The smp_processor_id() is set at the beginning of start_secondary. We don''t >> need to compute ourself the offset of the cpu data. >> --- >> xen/arch/arm/smpboot.c | 5 +---- >> 1 file changed, 1 insertion(+), 4 deletions(-) >> >> diff --git a/xen/arch/arm/smpboot.c b/xen/arch/arm/smpboot.c >> index 5895178..872cc25 100644 >> --- a/xen/arch/arm/smpboot.c >> +++ b/xen/arch/arm/smpboot.c >> @@ -137,15 +137,12 @@ void __cpuinit start_secondary(unsigned long boot_phys_offset, >> unsigned long fdt_paddr, >> unsigned long cpuid) >> { >> - struct cpuinfo_arm *c = cpu_data + cpuid; >> - >> memset(get_cpu_info(), 0, sizeof (struct cpu_info)); >> >> /* TODO: handle boards where CPUIDs are not contiguous */ >> set_processor_id(cpuid); >> >> - *c = boot_cpu_data; > > This step defaults everything to the boot cpu''s settings. You could > argue that this isn''t necessary iff identify_cpu always reinitialises > everything but it doesn''t belong in this change IMHO. > > I think the defaulting behaviour is fine BTW, even if we don''t currently > make use of it today.I will remove this line from the patch. -- Julien