From: James Bottomley <James.Bottomley@HansenPartnership.com>
To: Ingo Molnar <mingo@elte.hu>
Cc: Adrian Bunk <bunk@kernel.org>,
Alexey Starikovskiy <astarikovskiy@suse.de>,
tglx@linutronix.de, hpa@zytor.com, linux-kernel@vger.kernel.org
Subject: Re: Voyager phys_cpu_present_map compile error
Date: Mon, 28 Apr 2008 15:09:10 -0400 [thread overview]
Message-ID: <1209409750.3367.41.camel@localhost.localdomain> (raw)
In-Reply-To: <20080428175913.GA31911@elte.hu>
On Mon, 2008-04-28 at 19:59 +0200, Ingo Molnar wrote:
> * James Bottomley <James.Bottomley@HansenPartnership.com> wrote:
>
> > Oh ... oops ... unfortunately one I wouldn't spot in a voyager build.
> >
> > This should be the corrected patch; thanks.
>
> randconfig testing on x86.git found the build breakage below, i bisected
> it down to your patch. The config is:
>
> http://redhat.com/~mingo/misc/config-Mon_Apr_28_19_39_30_CEST_2008.bad
>
> reverted the patch for now.
>
> Ingo
>
> ------------>
> arch/x86/kernel/built-in.o: In function `physflat_cpu_mask_to_apicid':
> genapic_flat_64.c:(.text+0x14373): undefined reference to `per_cpu__x86_cpu_to_apicid'
> arch/x86/kernel/built-in.o: In function `physflat_send_IPI_mask':
> genapic_flat_64.c:(.text+0x1447f): undefined reference to `per_cpu__x86_cpu_to_apicid'
> arch/x86/kernel/built-in.o: In function `flat_apic_id_registered':
> genapic_flat_64.c:(.text+0x14558): undefined reference to `phys_cpu_present_map'
> genapic_flat_64.c:(.text+0x1455f): undefined reference to `phys_cpu_present_map'
> arch/x86/kernel/built-in.o: In function `uv_cpu_mask_to_apicid':
> genx2apic_uv_x.c:(.text+0x14627): undefined reference to `per_cpu__x86_cpu_to_apicid'
> arch/x86/kernel/built-in.o: In function `uv_send_IPI_mask':
> genx2apic_uv_x.c:(.text+0x14658): undefined reference to `per_cpu__x86_cpu_to_apicid'
> arch/x86/kernel/built-in.o: In function `acpi_register_lapic_address':
> boot.c:(.init.text+0x3b1b): undefined reference to `boot_cpu_physical_apicid'
> boot.c:(.init.text+0x3b2c): undefined reference to `boot_cpu_physical_apicid'
> arch/x86/kernel/built-in.o: In function `__get_smp_config':
> mpparse.c:(.init.text+0x53ad): undefined reference to `num_processors'
> mpparse.c:(.init.text+0x53c4): undefined reference to `num_processors'
> mpparse.c:(.init.text+0x543c): undefined reference to `num_processors'
> arch/x86/kernel/built-in.o: In function `init_apic_mappings':
> : undefined reference to `boot_cpu_physical_apicid'
> arch/x86/kernel/built-in.o: In function `init_apic_mappings':
> : undefined reference to `boot_cpu_physical_apicid'
> arch/x86/kernel/built-in.o: In function `APIC_init_uniprocessor':
> : undefined reference to `boot_cpu_physical_apicid'
> arch/x86/kernel/built-in.o: In function `APIC_init_uniprocessor':
> : undefined reference to `phys_cpu_present_map'
> arch/x86/kernel/built-in.o: In function `APIC_init_uniprocessor':
> : undefined reference to `boot_cpu_physical_apicid'
> arch/x86/kernel/built-in.o: In function `early_init_lapic_mapping':
> : undefined reference to `boot_cpu_physical_apicid'
> arch/x86/kernel/built-in.o: In function `acpi_register_lapic':
> boot.c:(.cpuinit.text+0x177a): undefined reference to `disabled_cpus'
> arch/x86/kernel/built-in.o: In function `MP_processor_info':
> mpparse.c:(.cpuinit.text+0x179d): undefined reference to `disabled_cpus'
> mpparse.c:(.cpuinit.text+0x17b4): undefined reference to `boot_cpu_physical_apicid'
> arch/x86/kernel/built-in.o: In function `setup_secondary_APIC_clock':
> : undefined reference to `boot_cpu_physical_apicid'
> arch/x86/kernel/built-in.o: In function `generic_processor_info':
> : undefined reference to `num_processors'
> arch/x86/kernel/built-in.o: In function `generic_processor_info':
> : undefined reference to `num_processors'
> arch/x86/kernel/built-in.o: In function `generic_processor_info':
> : undefined reference to `phys_cpu_present_map'
> arch/x86/kernel/built-in.o: In function `generic_processor_info':
> : undefined reference to `per_cpu__x86_cpu_to_apicid'
> arch/x86/kernel/built-in.o: In function `uv_cpu_init':
> : undefined reference to `per_cpu__x86_cpu_to_apicid'
> arch/x86/kernel/built-in.o: In function `uv_cpu_init':
> : undefined reference to `per_cpu__x86_cpu_to_apicid'
> arch/x86/kernel/built-in.o: In function `uv_cpu_init':
> : undefined reference to `per_cpu__x86_cpu_to_apicid'
Hmm, that's nasty. What it's showing is that the non-SMP local APIC
configuration pulls in large numbers of SMP variables. This was all
working right a while ago ... as in you need mpparse and the apic files
but not the SMP ones or the SMP variables. The quickest fix is probably
this one, since in these days of multi-core I suspect optimising the
non-SMP but use APIC case for size has a lot less relevance.
James
---
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c
index c0c68c1..808daf1 100644
--- a/arch/x86/kernel/setup.c
+++ b/arch/x86/kernel/setup.c
@@ -12,6 +12,7 @@
#include <asm/mpspec.h>
#include <asm/apicdef.h>
+#ifdef CONFIG_X86_MPPARSE
unsigned int num_processors;
unsigned disabled_cpus __cpuinitdata;
/* Processor that is doing the boot up */
@@ -23,8 +24,9 @@ EXPORT_PER_CPU_SYMBOL(x86_cpu_to_apicid);
/* Bitmask of physically existing CPUs */
physid_mask_t phys_cpu_present_map;
+#endif
-#if defined(CONFIG_HAVE_SETUP_PER_CPU_AREA) && defined(CONFIG_SMP)
+#if defined(CONFIG_HAVE_SETUP_PER_CPU_AREA) && defined(CONFIG_X86_SMP)
/*
* Copy data used in early init routines from the initial arrays to the
* per cpu data areas. These arrays then become expendable and the
next prev parent reply other threads:[~2008-04-28 19:09 UTC|newest]
Thread overview: 37+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-04-21 0:02 Voyager phys_cpu_present_map compile error Adrian Bunk
2008-04-21 8:53 ` Adrian Bunk
2008-04-21 12:00 ` Ingo Molnar
2008-04-21 12:55 ` H. Peter Anvin
2008-04-21 14:10 ` Status of SGI 320/540 (Visual Workstation) support? Adrian Bunk
2008-04-22 6:19 ` Andrey Panin
2008-04-22 13:29 ` Voyager phys_cpu_present_map compile error Andrew Morton
2008-04-22 15:25 ` Andy Whitcroft
2008-04-21 13:00 ` H. Peter Anvin
2008-04-21 15:42 ` James Bottomley
2008-04-21 20:03 ` Ingo Molnar
2008-04-21 23:08 ` James Bottomley
2008-04-21 19:55 ` Ingo Molnar
2008-04-21 20:03 ` H. Peter Anvin
2008-04-21 20:11 ` Ingo Molnar
2008-04-21 20:10 ` H. Peter Anvin
2008-04-23 8:53 ` Pavel Machek
2008-04-21 13:27 ` Adrian Bunk
2008-04-21 20:14 ` Ingo Molnar
2008-04-21 21:57 ` James Bottomley
2008-04-25 14:50 ` James Bottomley
2008-04-25 16:17 ` Adrian Bunk
2008-04-25 16:33 ` James Bottomley
2008-04-28 17:59 ` Ingo Molnar
2008-04-28 19:09 ` James Bottomley [this message]
2008-04-21 15:58 ` James Bottomley
2008-04-21 19:51 ` Ingo Molnar
2008-04-21 20:09 ` Adrian Bunk
2008-04-21 20:13 ` Ingo Molnar
2008-04-21 20:26 ` Adrian Bunk
2008-04-21 20:29 ` Ingo Molnar
2008-04-21 21:02 ` Adrian Bunk
2008-04-21 22:31 ` Ingo Molnar
2008-04-26 7:43 ` Pavel Machek
2008-04-27 0:44 ` H. Peter Anvin
2008-04-27 1:06 ` Adrian Bunk
2008-04-27 1:45 ` H. Peter Anvin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1209409750.3367.41.camel@localhost.localdomain \
--to=james.bottomley@hansenpartnership.com \
--cc=astarikovskiy@suse.de \
--cc=bunk@kernel.org \
--cc=hpa@zytor.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@elte.hu \
--cc=tglx@linutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox