diff options
author | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-16 18:20:36 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-16 18:20:36 -0400 |
commit | 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 (patch) | |
tree | 0bba044c4ce775e45a88a51686b5d9f90697ea9d /arch/i386/mach-generic/bigsmp.c |
Linux-2.6.12-rc2v2.6.12-rc2
Initial git repository build. I'm not bothering with the full history,
even though we have it. We can create a separate "historical" git
archive of that later if we want to, and in the meantime it's about
3.2GB when imported into git - space that would just make the early
git days unnecessarily complicated, when we don't have a lot of good
infrastructure for it.
Let it rip!
Diffstat (limited to 'arch/i386/mach-generic/bigsmp.c')
-rw-r--r-- | arch/i386/mach-generic/bigsmp.c | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/arch/i386/mach-generic/bigsmp.c b/arch/i386/mach-generic/bigsmp.c new file mode 100644 index 000000000000..25883b44f625 --- /dev/null +++ b/arch/i386/mach-generic/bigsmp.c | |||
@@ -0,0 +1,54 @@ | |||
1 | /* | ||
2 | * APIC driver for "bigsmp" XAPIC machines with more than 8 virtual CPUs. | ||
3 | * Drives the local APIC in "clustered mode". | ||
4 | */ | ||
5 | #define APIC_DEFINITION 1 | ||
6 | #include <linux/config.h> | ||
7 | #include <linux/threads.h> | ||
8 | #include <linux/cpumask.h> | ||
9 | #include <asm/mpspec.h> | ||
10 | #include <asm/genapic.h> | ||
11 | #include <asm/fixmap.h> | ||
12 | #include <asm/apicdef.h> | ||
13 | #include <linux/kernel.h> | ||
14 | #include <linux/smp.h> | ||
15 | #include <linux/init.h> | ||
16 | #include <linux/dmi.h> | ||
17 | #include <asm/mach-bigsmp/mach_apic.h> | ||
18 | #include <asm/mach-bigsmp/mach_apicdef.h> | ||
19 | #include <asm/mach-bigsmp/mach_ipi.h> | ||
20 | #include <asm/mach-default/mach_mpparse.h> | ||
21 | |||
22 | static int dmi_bigsmp; /* can be set by dmi scanners */ | ||
23 | |||
24 | static __init int hp_ht_bigsmp(struct dmi_system_id *d) | ||
25 | { | ||
26 | #ifdef CONFIG_X86_GENERICARCH | ||
27 | printk(KERN_NOTICE "%s detected: force use of apic=bigsmp\n", d->ident); | ||
28 | dmi_bigsmp = 1; | ||
29 | #endif | ||
30 | return 0; | ||
31 | } | ||
32 | |||
33 | |||
34 | static struct dmi_system_id __initdata bigsmp_dmi_table[] = { | ||
35 | { hp_ht_bigsmp, "HP ProLiant DL760 G2", { | ||
36 | DMI_MATCH(DMI_BIOS_VENDOR, "HP"), | ||
37 | DMI_MATCH(DMI_BIOS_VERSION, "P44-"), | ||
38 | }}, | ||
39 | |||
40 | { hp_ht_bigsmp, "HP ProLiant DL740", { | ||
41 | DMI_MATCH(DMI_BIOS_VENDOR, "HP"), | ||
42 | DMI_MATCH(DMI_BIOS_VERSION, "P47-"), | ||
43 | }}, | ||
44 | { } | ||
45 | }; | ||
46 | |||
47 | |||
48 | static __init int probe_bigsmp(void) | ||
49 | { | ||
50 | dmi_check_system(bigsmp_dmi_table); | ||
51 | return dmi_bigsmp; | ||
52 | } | ||
53 | |||
54 | struct genapic apic_bigsmp = APIC_INIT("bigsmp", probe_bigsmp); | ||