blob: 0f5f7dd2a620d5bc188382351391eb8100fd7e24 [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
Andres Salomon3ef0e1f2008-04-29 00:59:53 -070017#ifdef CONFIG_PCI_OLPC
18 pci_olpc_init();
19#endif
Andi Kleen92c05fc2006-03-23 14:35:12 -080020 if (raw_pci_ops)
21 return 0;
22#ifdef CONFIG_PCI_BIOS
23 pci_pcbios_init();
24#endif
Daniel Ritz954c0b72006-08-22 07:29:08 -070025 /*
26 * don't check for raw_pci_ops here because we want pcbios as last
27 * fallback, yet it's needed to run first to set pcibios_last_bus
28 * in case legacy PCI probing is used. otherwise detecting peer busses
29 * fails.
30 */
Andi Kleen92c05fc2006-03-23 14:35:12 -080031#ifdef CONFIG_PCI_DIRECT
Andi Kleen5e544d62006-09-26 10:52:40 +020032 pci_direct_init(type);
Andi Kleen92c05fc2006-03-23 14:35:12 -080033#endif
Andi Kleenf015c6c2006-10-05 18:47:22 +020034 if (!raw_pci_ops)
35 printk(KERN_ERR
36 "PCI: Fatal: No config space access function found\n");
37
Andi Kleen92c05fc2006-03-23 14:35:12 -080038 return 0;
39}
40arch_initcall(pci_access_init);