aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2008-05-25 15:21:36 -0400
committerThomas Gleixner <tglx@linutronix.de>2008-05-25 15:21:36 -0400
commit85cc35fa7255d113b5383a9c8536c363274bb475 (patch)
treede41a35a212984d3f93b77177eb2e7ffabe2038d
parent136ef671df04dc157afa0d4b96c7bd23ba072c9c (diff)
x86: fix mpparse fallout
UP builds with LOCAL_APIC=y and IO_APIC=n fail with a missing reference to mp_bus_not_pci. Distangle the mpparse code some more and move the ioapic specific bus check into a separate function. This code needs sume urgent un#ifdef surgery all over the place. Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r--arch/x86/kernel/mpparse.c73
1 files changed, 41 insertions, 32 deletions
diff --git a/arch/x86/kernel/mpparse.c b/arch/x86/kernel/mpparse.c
index e8e041ed84d6..9f3792d55044 100644
--- a/arch/x86/kernel/mpparse.c
+++ b/arch/x86/kernel/mpparse.c
@@ -81,6 +81,7 @@ static void __cpuinit MP_processor_info(struct mpc_config_processor *m)
81 generic_processor_info(apicid, m->mpc_apicver); 81 generic_processor_info(apicid, m->mpc_apicver);
82} 82}
83 83
84#ifdef CONFIG_X86_IO_APIC
84static void __init MP_bus_info(struct mpc_config_bus *m) 85static void __init MP_bus_info(struct mpc_config_bus *m)
85{ 86{
86 char str[7]; 87 char str[7];
@@ -122,6 +123,7 @@ static void __init MP_bus_info(struct mpc_config_bus *m)
122 } else 123 } else
123 printk(KERN_WARNING "Unknown bustype %s - ignoring\n", str); 124 printk(KERN_WARNING "Unknown bustype %s - ignoring\n", str);
124} 125}
126#endif
125 127
126#ifdef CONFIG_X86_IO_APIC 128#ifdef CONFIG_X86_IO_APIC
127 129
@@ -336,7 +338,9 @@ static int __init smp_read_mpc(struct mp_config_table *mpc, unsigned early)
336 { 338 {
337 struct mpc_config_bus *m = 339 struct mpc_config_bus *m =
338 (struct mpc_config_bus *)mpt; 340 (struct mpc_config_bus *)mpt;
341#ifdef CONFIG_X86_IO_APIC
339 MP_bus_info(m); 342 MP_bus_info(m);
343#endif
340 mpt += sizeof(*m); 344 mpt += sizeof(*m);
341 count += sizeof(*m); 345 count += sizeof(*m);
342 break; 346 break;
@@ -472,40 +476,11 @@ static void __init construct_default_ioirq_mptable(int mpc_default_type)
472 MP_intsrc_info(&intsrc); 476 MP_intsrc_info(&intsrc);
473} 477}
474 478
475#endif
476 479
477static inline void __init construct_default_ISA_mptable(int mpc_default_type) 480static void construct_ioapic_table(int mpc_default_type)
478{ 481{
479 struct mpc_config_processor processor;
480 struct mpc_config_bus bus;
481#ifdef CONFIG_X86_IO_APIC
482 struct mpc_config_ioapic ioapic; 482 struct mpc_config_ioapic ioapic;
483#endif 483 struct mpc_config_bus bus;
484 struct mpc_config_lintsrc lintsrc;
485 int linttypes[2] = { mp_ExtINT, mp_NMI };
486 int i;
487
488 /*
489 * local APIC has default address
490 */
491 mp_lapic_addr = APIC_DEFAULT_PHYS_BASE;
492
493 /*
494 * 2 CPUs, numbered 0 & 1.
495 */
496 processor.mpc_type = MP_PROCESSOR;
497 /* Either an integrated APIC or a discrete 82489DX. */
498 processor.mpc_apicver = mpc_default_type > 4 ? 0x10 : 0x01;
499 processor.mpc_cpuflag = CPU_ENABLED;
500 processor.mpc_cpufeature = (boot_cpu_data.x86 << 8) |
501 (boot_cpu_data.x86_model << 4) | boot_cpu_data.x86_mask;
502 processor.mpc_featureflag = boot_cpu_data.x86_capability[0];
503 processor.mpc_reserved[0] = 0;
504 processor.mpc_reserved[1] = 0;
505 for (i = 0; i < 2; i++) {
506 processor.mpc_apicid = i;
507 MP_processor_info(&processor);
508 }
509 484
510 bus.mpc_type = MP_BUS; 485 bus.mpc_type = MP_BUS;
511 bus.mpc_busid = 0; 486 bus.mpc_busid = 0;
@@ -534,7 +509,6 @@ static inline void __init construct_default_ISA_mptable(int mpc_default_type)
534 MP_bus_info(&bus); 509 MP_bus_info(&bus);
535 } 510 }
536 511
537#ifdef CONFIG_X86_IO_APIC
538 ioapic.mpc_type = MP_IOAPIC; 512 ioapic.mpc_type = MP_IOAPIC;
539 ioapic.mpc_apicid = 2; 513 ioapic.mpc_apicid = 2;
540 ioapic.mpc_apicver = mpc_default_type > 4 ? 0x10 : 0x01; 514 ioapic.mpc_apicver = mpc_default_type > 4 ? 0x10 : 0x01;
@@ -546,7 +520,42 @@ static inline void __init construct_default_ISA_mptable(int mpc_default_type)
546 * We set up most of the low 16 IO-APIC pins according to MPS rules. 520 * We set up most of the low 16 IO-APIC pins according to MPS rules.
547 */ 521 */
548 construct_default_ioirq_mptable(mpc_default_type); 522 construct_default_ioirq_mptable(mpc_default_type);
523}
524#else
525static inline void construct_ioapic_table(int mpc_default_type) { }
549#endif 526#endif
527
528static inline void __init construct_default_ISA_mptable(int mpc_default_type)
529{
530 struct mpc_config_processor processor;
531 struct mpc_config_lintsrc lintsrc;
532 int linttypes[2] = { mp_ExtINT, mp_NMI };
533 int i;
534
535 /*
536 * local APIC has default address
537 */
538 mp_lapic_addr = APIC_DEFAULT_PHYS_BASE;
539
540 /*
541 * 2 CPUs, numbered 0 & 1.
542 */
543 processor.mpc_type = MP_PROCESSOR;
544 /* Either an integrated APIC or a discrete 82489DX. */
545 processor.mpc_apicver = mpc_default_type > 4 ? 0x10 : 0x01;
546 processor.mpc_cpuflag = CPU_ENABLED;
547 processor.mpc_cpufeature = (boot_cpu_data.x86 << 8) |
548 (boot_cpu_data.x86_model << 4) | boot_cpu_data.x86_mask;
549 processor.mpc_featureflag = boot_cpu_data.x86_capability[0];
550 processor.mpc_reserved[0] = 0;
551 processor.mpc_reserved[1] = 0;
552 for (i = 0; i < 2; i++) {
553 processor.mpc_apicid = i;
554 MP_processor_info(&processor);
555 }
556
557 construct_ioapic_table(mpc_default_type);
558
550 lintsrc.mpc_type = MP_LINTSRC; 559 lintsrc.mpc_type = MP_LINTSRC;
551 lintsrc.mpc_irqflag = 0; /* conforming */ 560 lintsrc.mpc_irqflag = 0; /* conforming */
552 lintsrc.mpc_srcbusid = 0; 561 lintsrc.mpc_srcbusid = 0;