1 --- a/arch/arm/mach-cns3xxx/cns3420vb.c
2 +++ b/arch/arm/mach-cns3xxx/cns3420vb.c
3 @@ -261,11 +261,21 @@ static struct map_desc cns3420_io_desc[]
4 static void __init cns3420_map_io(void)
7 + cns3xxx_pcie_iotable_init();
8 iotable_init(cns3420_io_desc, ARRAY_SIZE(cns3420_io_desc));
10 cns3420_early_serial_setup();
13 +static int __init cns3420vb_pcie_init(void)
15 + if (!machine_is_cns3420vb())
18 + return cns3xxx_pcie_init();
20 +subsys_initcall(cns3420vb_pcie_init);
22 MACHINE_START(CNS3420VB, "Cavium Networks CNS3420 Validation Board")
24 .nr_irqs = NR_IRQS_CNS3XXX,
25 --- a/arch/arm/mach-cns3xxx/core.h
26 +++ b/arch/arm/mach-cns3xxx/core.h
29 extern struct smp_operations cns3xxx_smp_ops;
30 extern void cns3xxx_timer_init(void);
31 +extern void cns3xxx_pcie_iotable_init(void);
33 #ifdef CONFIG_CACHE_L2X0
34 void __init cns3xxx_l2x0_init(void);
35 @@ -24,6 +25,7 @@ static inline void cns3xxx_l2x0_init(voi
37 void __init cns3xxx_map_io(void);
38 void __init cns3xxx_init_irq(void);
39 +int __init cns3xxx_pcie_init(void);
40 void cns3xxx_power_off(void);
41 void cns3xxx_restart(enum reboot_mode, const char *);
43 --- a/arch/arm/mach-cns3xxx/pcie.c
44 +++ b/arch/arm/mach-cns3xxx/pcie.c
45 @@ -449,7 +449,18 @@ static int cns3xxx_pcie_abort_handler(un
49 -static int __init cns3xxx_pcie_init(void)
51 +void __init cns3xxx_pcie_iotable_init()
55 + for (i = 0; i < ARRAY_SIZE(cns3xxx_pcie); i++) {
56 + iotable_init(cns3xxx_pcie[i].cfg_bases,
57 + ARRAY_SIZE(cns3xxx_pcie[i].cfg_bases));
61 +int __init cns3xxx_pcie_init(void)
65 @@ -460,15 +471,14 @@ static int __init cns3xxx_pcie_init(void
66 "imprecise external abort");
68 for (i = 0; i < ARRAY_SIZE(cns3xxx_pcie); i++) {
69 - iotable_init(cns3xxx_pcie[i].cfg_bases,
70 - ARRAY_SIZE(cns3xxx_pcie[i].cfg_bases));
71 cns3xxx_pcie_check_link(&cns3xxx_pcie[i]);
72 - cns3xxx_pcie_hw_init(&cns3xxx_pcie[i]);
73 - pci_common_init(&cns3xxx_pcie[i].hw_pci);
74 + if (cns3xxx_pcie[i].linked) {
75 + cns3xxx_pcie_hw_init(&cns3xxx_pcie[i]);
76 + pci_common_init(&cns3xxx_pcie[i].hw_pci);
80 pci_assign_unassigned_resources();
84 -device_initcall(cns3xxx_pcie_init);