2005-04-17 06:20:36 +08:00
|
|
|
/*
|
|
|
|
* APIC driver for "bigsmp" XAPIC machines with more than 8 virtual CPUs.
|
|
|
|
* Drives the local APIC in "clustered mode".
|
|
|
|
*/
|
|
|
|
#define APIC_DEFINITION 1
|
|
|
|
#include <linux/threads.h>
|
|
|
|
#include <linux/cpumask.h>
|
2006-09-26 16:52:26 +08:00
|
|
|
#include <asm/smp.h>
|
2005-04-17 06:20:36 +08:00
|
|
|
#include <asm/mpspec.h>
|
|
|
|
#include <asm/genapic.h>
|
|
|
|
#include <asm/fixmap.h>
|
|
|
|
#include <asm/apicdef.h>
|
|
|
|
#include <linux/kernel.h>
|
|
|
|
#include <linux/smp.h>
|
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/dmi.h>
|
|
|
|
#include <asm/mach-bigsmp/mach_apic.h>
|
|
|
|
#include <asm/mach-bigsmp/mach_apicdef.h>
|
|
|
|
#include <asm/mach-bigsmp/mach_ipi.h>
|
|
|
|
#include <asm/mach-default/mach_mpparse.h>
|
|
|
|
|
|
|
|
static int dmi_bigsmp; /* can be set by dmi scanners */
|
|
|
|
|
2007-10-04 03:15:40 +08:00
|
|
|
static int hp_ht_bigsmp(const struct dmi_system_id *d)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
|
|
|
#ifdef CONFIG_X86_GENERICARCH
|
|
|
|
printk(KERN_NOTICE "%s detected: force use of apic=bigsmp\n", d->ident);
|
|
|
|
dmi_bigsmp = 1;
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-10-04 03:15:40 +08:00
|
|
|
static const struct dmi_system_id bigsmp_dmi_table[] = {
|
2005-04-17 06:20:36 +08:00
|
|
|
{ hp_ht_bigsmp, "HP ProLiant DL760 G2", {
|
|
|
|
DMI_MATCH(DMI_BIOS_VENDOR, "HP"),
|
|
|
|
DMI_MATCH(DMI_BIOS_VERSION, "P44-"),
|
|
|
|
}},
|
|
|
|
|
|
|
|
{ hp_ht_bigsmp, "HP ProLiant DL740", {
|
|
|
|
DMI_MATCH(DMI_BIOS_VENDOR, "HP"),
|
|
|
|
DMI_MATCH(DMI_BIOS_VERSION, "P47-"),
|
|
|
|
}},
|
|
|
|
{ }
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2007-05-24 04:58:23 +08:00
|
|
|
static int probe_bigsmp(void)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2005-09-04 06:56:31 +08:00
|
|
|
if (def_to_bigsmp)
|
|
|
|
dmi_bigsmp = 1;
|
|
|
|
else
|
|
|
|
dmi_check_system(bigsmp_dmi_table);
|
2005-04-17 06:20:36 +08:00
|
|
|
return dmi_bigsmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct genapic apic_bigsmp = APIC_INIT("bigsmp", probe_bigsmp);
|