diff options
Diffstat (limited to 'arch/x86/kernel')
-rw-r--r-- | arch/x86/kernel/mmconf-fam10h_64.c | 28 | ||||
-rw-r--r-- | arch/x86/kernel/setup_64.c | 23 |
2 files changed, 43 insertions, 8 deletions
diff --git a/arch/x86/kernel/mmconf-fam10h_64.c b/arch/x86/kernel/mmconf-fam10h_64.c index 37897920ec65..edc5fbfe85c0 100644 --- a/arch/x86/kernel/mmconf-fam10h_64.c +++ b/arch/x86/kernel/mmconf-fam10h_64.c | |||
@@ -6,12 +6,15 @@ | |||
6 | #include <linux/mm.h> | 6 | #include <linux/mm.h> |
7 | #include <linux/string.h> | 7 | #include <linux/string.h> |
8 | #include <linux/pci.h> | 8 | #include <linux/pci.h> |
9 | #include <linux/dmi.h> | ||
9 | #include <asm/pci-direct.h> | 10 | #include <asm/pci-direct.h> |
10 | #include <linux/sort.h> | 11 | #include <linux/sort.h> |
11 | #include <asm/io.h> | 12 | #include <asm/io.h> |
12 | #include <asm/msr.h> | 13 | #include <asm/msr.h> |
13 | #include <asm/acpi.h> | 14 | #include <asm/acpi.h> |
14 | 15 | ||
16 | #include "../pci/pci.h" | ||
17 | |||
15 | struct pci_hostbridge_probe { | 18 | struct pci_hostbridge_probe { |
16 | u32 bus; | 19 | u32 bus; |
17 | u32 slot; | 20 | u32 slot; |
@@ -176,6 +179,9 @@ void __cpuinit fam10h_check_enable_mmcfg(void) | |||
176 | u64 val; | 179 | u64 val; |
177 | u32 address; | 180 | u32 address; |
178 | 181 | ||
182 | if (!(pci_probe & PCI_CHECK_ENABLE_AMD_MMCONF)) | ||
183 | return; | ||
184 | |||
179 | address = MSR_FAM10H_MMIO_CONF_BASE; | 185 | address = MSR_FAM10H_MMIO_CONF_BASE; |
180 | rdmsrl(address, val); | 186 | rdmsrl(address, val); |
181 | 187 | ||
@@ -213,3 +219,25 @@ void __cpuinit fam10h_check_enable_mmcfg(void) | |||
213 | FAM10H_MMIO_CONF_ENABLE; | 219 | FAM10H_MMIO_CONF_ENABLE; |
214 | wrmsrl(address, val); | 220 | wrmsrl(address, val); |
215 | } | 221 | } |
222 | |||
223 | static int __devinit set_check_enable_amd_mmconf(const struct dmi_system_id *d) | ||
224 | { | ||
225 | pci_probe |= PCI_CHECK_ENABLE_AMD_MMCONF; | ||
226 | return 0; | ||
227 | } | ||
228 | |||
229 | static struct dmi_system_id __devinitdata mmconf_dmi_table[] = { | ||
230 | { | ||
231 | .callback = set_check_enable_amd_mmconf, | ||
232 | .ident = "Sun Microsystems Machine", | ||
233 | .matches = { | ||
234 | DMI_MATCH(DMI_SYS_VENDOR, "Sun Microsystems"), | ||
235 | }, | ||
236 | }, | ||
237 | {} | ||
238 | }; | ||
239 | |||
240 | void __init check_enable_amd_mmconf_dmi(void) | ||
241 | { | ||
242 | dmi_check_system(mmconf_dmi_table); | ||
243 | } | ||
diff --git a/arch/x86/kernel/setup_64.c b/arch/x86/kernel/setup_64.c index d8a9ee752fb3..2f5c488aad0b 100644 --- a/arch/x86/kernel/setup_64.c +++ b/arch/x86/kernel/setup_64.c | |||
@@ -289,6 +289,18 @@ static void __init parse_setup_data(void) | |||
289 | } | 289 | } |
290 | } | 290 | } |
291 | 291 | ||
292 | #ifdef CONFIG_PCI_MMCONFIG | ||
293 | extern void __cpuinit fam10h_check_enable_mmcfg(void); | ||
294 | extern void __init check_enable_amd_mmconf_dmi(void); | ||
295 | #else | ||
296 | void __cpuinit fam10h_check_enable_mmcfg(void) | ||
297 | { | ||
298 | } | ||
299 | void __init check_enable_amd_mmconf_dmi(void) | ||
300 | { | ||
301 | } | ||
302 | #endif | ||
303 | |||
292 | /* | 304 | /* |
293 | * setup_arch - architecture-specific boot-time initializations | 305 | * setup_arch - architecture-specific boot-time initializations |
294 | * | 306 | * |
@@ -510,6 +522,9 @@ void __init setup_arch(char **cmdline_p) | |||
510 | conswitchp = &dummy_con; | 522 | conswitchp = &dummy_con; |
511 | #endif | 523 | #endif |
512 | #endif | 524 | #endif |
525 | |||
526 | /* do this before identify_cpu for boot cpu */ | ||
527 | check_enable_amd_mmconf_dmi(); | ||
513 | } | 528 | } |
514 | 529 | ||
515 | static int __cpuinit get_model_name(struct cpuinfo_x86 *c) | 530 | static int __cpuinit get_model_name(struct cpuinfo_x86 *c) |
@@ -697,14 +712,6 @@ static void __cpuinit early_init_amd(struct cpuinfo_x86 *c) | |||
697 | set_cpu_cap(c, X86_FEATURE_CONSTANT_TSC); | 712 | set_cpu_cap(c, X86_FEATURE_CONSTANT_TSC); |
698 | } | 713 | } |
699 | 714 | ||
700 | #ifdef CONFIG_PCI_MMCONFIG | ||
701 | extern void __cpuinit fam10h_check_enable_mmcfg(void); | ||
702 | #else | ||
703 | void __cpuinit fam10h_check_enable_mmcfg(void) | ||
704 | { | ||
705 | } | ||
706 | #endif | ||
707 | |||
708 | static void __cpuinit init_amd(struct cpuinfo_x86 *c) | 715 | static void __cpuinit init_amd(struct cpuinfo_x86 *c) |
709 | { | 716 | { |
710 | unsigned level; | 717 | unsigned level; |