aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/include/asm/pci_x86.h
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2009-08-29 10:24:51 -0400
committerH. Peter Anvin <hpa@zytor.com>2010-02-19 19:12:29 -0500
commitb72d0db9dd41da1f2ec6274b03e8909583c64e41 (patch)
tree6424768067546f3aa4bd2e5d0a11d6459a6aad51 /arch/x86/include/asm/pci_x86.h
parentcf4c43dd439b90a1a876b3f836ebe745abb9a269 (diff)
x86: Move pci init function to x86_init
The PCI initialization in pci_subsys_init() is a mess. pci_numaq_init, pci_acpi_init, pci_visws_init and pci_legacy_init are called and each implementation checks and eventually modifies the global variable pcibios_scanned. x86_init functions allow us to do this more elegant. The pci.init function pointer is preset to pci_legacy_init. numaq, acpi and visws can modify the pointer in their early setup functions. The functions return 0 when they did the full initialization including bus scan. A non zero return value indicates that pci_legacy_init needs to be called either because the selected function failed or wants the generic bus scan in pci_legacy_init to happen (e.g. visws). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> LKML-Reference: <43F901BD926A4E43B106BF17856F07559FB80CFE@orsmsx508.amr.corp.intel.com> Acked-by: Jesse Barnes <jbarnes@virtuousgeek.org> Signed-off-by: Jacob Pan <jacob.jun.pan@intel.com> Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Diffstat (limited to 'arch/x86/include/asm/pci_x86.h')
-rw-r--r--arch/x86/include/asm/pci_x86.h14
1 files changed, 11 insertions, 3 deletions
diff --git a/arch/x86/include/asm/pci_x86.h b/arch/x86/include/asm/pci_x86.h
index b4bf9a942ed0..440124f1224d 100644
--- a/arch/x86/include/asm/pci_x86.h
+++ b/arch/x86/include/asm/pci_x86.h
@@ -82,7 +82,6 @@ struct irq_routing_table {
82 82
83extern unsigned int pcibios_irq_mask; 83extern unsigned int pcibios_irq_mask;
84 84
85extern int pcibios_scanned;
86extern spinlock_t pci_config_lock; 85extern spinlock_t pci_config_lock;
87 86
88extern int (*pcibios_enable_irq)(struct pci_dev *dev); 87extern int (*pcibios_enable_irq)(struct pci_dev *dev);
@@ -112,9 +111,8 @@ extern void __init dmi_check_skip_isa_align(void);
112/* some common used subsys_initcalls */ 111/* some common used subsys_initcalls */
113extern int __init pci_acpi_init(void); 112extern int __init pci_acpi_init(void);
114extern int __init pcibios_irq_init(void); 113extern int __init pcibios_irq_init(void);
115extern int __init pci_visws_init(void);
116extern int __init pci_numaq_init(void);
117extern int __init pcibios_init(void); 114extern int __init pcibios_init(void);
115extern int pci_legacy_init(void);
118 116
119/* pci-mmconfig.c */ 117/* pci-mmconfig.c */
120 118
@@ -182,3 +180,13 @@ static inline void mmio_config_writel(void __iomem *pos, u32 val)
182{ 180{
183 asm volatile("movl %%eax,(%1)" : : "a" (val), "r" (pos) : "memory"); 181 asm volatile("movl %%eax,(%1)" : : "a" (val), "r" (pos) : "memory");
184} 182}
183
184#ifdef CONFIG_PCI
185# ifdef CONFIG_ACPI
186# define x86_default_pci_init pci_acpi_init
187# else
188# define x86_default_pci_init pci_legacy_init
189# endif
190#else
191# define x86_default_pci_init NULL
192#endif