blob: d028e1b05c3697e56e64631b0863cb3d90819fd3 [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{
Andi Kleen5e544d62006-09-26 10:52:40 +02009 int type = 0;
10
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
31 return 0;
32}
33arch_initcall(pci_access_init);