blob: 3de9f9ba2da6aed8be73921f3f416ed8af444a49 [file] [log] [blame]
Andi Kleen92c05fc2006-03-23 14:35:12 -08001#include <linux/pci.h>
2#include <linux/init.h>
3#include "pci.h"
4
5/* arch_initcall has too random ordering, so call the initializers
6 in the right sequence from here. */
7static __init int pci_access_init(void)
8{
David Rientjesf6744c02007-05-09 02:35:28 -07009 int type __maybe_unused = 0;
Andi Kleen5e544d62006-09-26 10:52:40 +020010
11#ifdef CONFIG_PCI_DIRECT
12 type = pci_direct_probe();
13#endif
Andi Kleen92c05fc2006-03-23 14:35:12 -080014#ifdef CONFIG_PCI_MMCONFIG
Andi Kleen5e544d62006-09-26 10:52:40 +020015 pci_mmcfg_init(type);
Andi Kleen92c05fc2006-03-23 14:35:12 -080016#endif
17 if (raw_pci_ops)
18 return 0;
19#ifdef CONFIG_PCI_BIOS
20 pci_pcbios_init();
21#endif
Daniel Ritz954c0b72006-08-22 07:29:08 -070022 /*
23 * don't check for raw_pci_ops here because we want pcbios as last
24 * fallback, yet it's needed to run first to set pcibios_last_bus
25 * in case legacy PCI probing is used. otherwise detecting peer busses
26 * fails.
27 */
Andi Kleen92c05fc2006-03-23 14:35:12 -080028#ifdef CONFIG_PCI_DIRECT
Andi Kleen5e544d62006-09-26 10:52:40 +020029 pci_direct_init(type);
Andi Kleen92c05fc2006-03-23 14:35:12 -080030#endif
Andi Kleenf015c6c2006-10-05 18:47:22 +020031 if (!raw_pci_ops)
32 printk(KERN_ERR
33 "PCI: Fatal: No config space access function found\n");
34
Andi Kleen92c05fc2006-03-23 14:35:12 -080035 return 0;
36}
37arch_initcall(pci_access_init);