blob: b394b2a4b9129d80f6b1d3eff10b9ac346393b03 [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#ifdef CONFIG_PCI_DIRECT
Yinghai Lubb63b422008-02-28 23:56:50 -080010 int type = 0;
11
Andi Kleen5e544d62006-09-26 10:52:40 +020012 type = pci_direct_probe();
13#endif
Linus Torvalds5f78e4d2008-04-29 08:26:51 -070014
Yinghai Lubb63b422008-02-28 23:56:50 -080015 pci_mmcfg_early_init();
16
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#ifdef CONFIG_PCI_BIOS
21 pci_pcbios_init();
22#endif
Daniel Ritz954c0b72006-08-22 07:29:08 -070023 /*
24 * don't check for raw_pci_ops here because we want pcbios as last
25 * fallback, yet it's needed to run first to set pcibios_last_bus
26 * in case legacy PCI probing is used. otherwise detecting peer busses
27 * fails.
28 */
Andi Kleen92c05fc2006-03-23 14:35:12 -080029#ifdef CONFIG_PCI_DIRECT
Andi Kleen5e544d62006-09-26 10:52:40 +020030 pci_direct_init(type);
Andi Kleen92c05fc2006-03-23 14:35:12 -080031#endif
Yinghai Lubb63b422008-02-28 23:56:50 -080032 if (!raw_pci_ops && !raw_pci_ext_ops)
Andi Kleenf015c6c2006-10-05 18:47:22 +020033 printk(KERN_ERR
34 "PCI: Fatal: No config space access function found\n");
35
Yinghai Lu13a6ddb2008-03-27 01:31:18 -070036 dmi_check_skip_isa_align();
37
Andi Kleen92c05fc2006-03-23 14:35:12 -080038 return 0;
39}
40arch_initcall(pci_access_init);