diff options
-rw-r--r-- | Documentation/devicetree/bindings/pci/v3-v360epc-pci.txt | 15 | ||||
-rw-r--r-- | Documentation/devicetree/bindings/vendor-prefixes.txt | 1 | ||||
-rw-r--r-- | arch/arm/boot/dts/integratorap.dts | 41 | ||||
-rw-r--r-- | arch/arm/mach-integrator/integrator_ap.c | 11 | ||||
-rw-r--r-- | arch/arm/mach-integrator/pci_v3.c | 177 |
5 files changed, 209 insertions, 36 deletions
diff --git a/Documentation/devicetree/bindings/pci/v3-v360epc-pci.txt b/Documentation/devicetree/bindings/pci/v3-v360epc-pci.txt new file mode 100644 index 000000000000..30b364e504ba --- /dev/null +++ b/Documentation/devicetree/bindings/pci/v3-v360epc-pci.txt | |||
@@ -0,0 +1,15 @@ | |||
1 | V3 Semiconductor V360 EPC PCI bridge | ||
2 | |||
3 | This bridge is found in the ARM Integrator/AP (Application Platform) | ||
4 | |||
5 | Integrator-specific notes: | ||
6 | |||
7 | - syscon: should contain a link to the syscon device node (since | ||
8 | on the Integrator, some registers in the syscon are required to | ||
9 | operate the V3). | ||
10 | |||
11 | V360 EPC specific notes: | ||
12 | |||
13 | - reg: should contain the base address of the V3 adapter. | ||
14 | - interrupts: should contain a reference to the V3 error interrupt | ||
15 | as routed on the system. | ||
diff --git a/Documentation/devicetree/bindings/vendor-prefixes.txt b/Documentation/devicetree/bindings/vendor-prefixes.txt index 6931c4348d24..d247d1003987 100644 --- a/Documentation/devicetree/bindings/vendor-prefixes.txt +++ b/Documentation/devicetree/bindings/vendor-prefixes.txt | |||
@@ -59,6 +59,7 @@ ste ST-Ericsson | |||
59 | stericsson ST-Ericsson | 59 | stericsson ST-Ericsson |
60 | ti Texas Instruments | 60 | ti Texas Instruments |
61 | toshiba Toshiba Corporation | 61 | toshiba Toshiba Corporation |
62 | v3 V3 Semiconductor | ||
62 | via VIA Technologies, Inc. | 63 | via VIA Technologies, Inc. |
63 | wlf Wolfson Microelectronics | 64 | wlf Wolfson Microelectronics |
64 | wm Wondermedia Technologies, Inc. | 65 | wm Wondermedia Technologies, Inc. |
diff --git a/arch/arm/boot/dts/integratorap.dts b/arch/arm/boot/dts/integratorap.dts index c9c3fa344647..03f23b7a0ab5 100644 --- a/arch/arm/boot/dts/integratorap.dts +++ b/arch/arm/boot/dts/integratorap.dts | |||
@@ -39,6 +39,47 @@ | |||
39 | valid-mask = <0x003fffff>; | 39 | valid-mask = <0x003fffff>; |
40 | }; | 40 | }; |
41 | 41 | ||
42 | pci: pciv3@62000000 { | ||
43 | compatible = "v3,v360epc-pci"; | ||
44 | #interrupt-cells = <1>; | ||
45 | #size-cells = <2>; | ||
46 | #address-cells = <3>; | ||
47 | reg = <0x62000000 0x10000>; | ||
48 | interrupt-parent = <&pic>; | ||
49 | interrupts = <17>; /* Bus error IRQ */ | ||
50 | ranges = <0x00000000 0 0x61000000 /* config space */ | ||
51 | 0x61000000 0 0x00100000 /* 16 MiB @ 61000000 */ | ||
52 | 0x01000000 0 0x60000000 /* I/O space */ | ||
53 | 0x60000000 0 0x00100000 /* 16 MiB @ 60000000 */ | ||
54 | 0x02000000 0 0x40000000 /* non-prefectable memory */ | ||
55 | 0x40000000 0 0x10000000 /* 256 MiB @ 40000000 */ | ||
56 | 0x42000000 0 0x50000000 /* prefetchable memory */ | ||
57 | 0x50000000 0 0x10000000>; /* 256 MiB @ 50000000 */ | ||
58 | interrupt-map-mask = <0xf800 0 0 0x7>; | ||
59 | interrupt-map = < | ||
60 | /* IDSEL 9 */ | ||
61 | 0x4800 0 0 1 &pic 13 /* INT A on slot 9 is irq 13 */ | ||
62 | 0x4800 0 0 2 &pic 14 /* INT B on slot 9 is irq 14 */ | ||
63 | 0x4800 0 0 3 &pic 15 /* INT C on slot 9 is irq 15 */ | ||
64 | 0x4800 0 0 4 &pic 16 /* INT D on slot 9 is irq 16 */ | ||
65 | /* IDSEL 10 */ | ||
66 | 0x5000 0 0 1 &pic 14 /* INT A on slot 10 is irq 14 */ | ||
67 | 0x5000 0 0 2 &pic 15 /* INT B on slot 10 is irq 15 */ | ||
68 | 0x5000 0 0 3 &pic 16 /* INT C on slot 10 is irq 16 */ | ||
69 | 0x5000 0 0 4 &pic 13 /* INT D on slot 10 is irq 13 */ | ||
70 | /* IDSEL 11 */ | ||
71 | 0x5800 0 0 1 &pic 15 /* INT A on slot 11 is irq 15 */ | ||
72 | 0x5800 0 0 2 &pic 16 /* INT B on slot 11 is irq 16 */ | ||
73 | 0x5800 0 0 3 &pic 13 /* INT C on slot 11 is irq 13 */ | ||
74 | 0x5800 0 0 4 &pic 14 /* INT D on slot 11 is irq 14 */ | ||
75 | /* IDSEL 12 */ | ||
76 | 0x6000 0 0 1 &pic 16 /* INT A on slot 12 is irq 16 */ | ||
77 | 0x6000 0 0 2 &pic 13 /* INT B on slot 12 is irq 13 */ | ||
78 | 0x6000 0 0 3 &pic 14 /* INT C on slot 12 is irq 14 */ | ||
79 | 0x6000 0 0 4 &pic 15 /* INT D on slot 12 is irq 15 */ | ||
80 | >; | ||
81 | }; | ||
82 | |||
42 | fpga { | 83 | fpga { |
43 | /* | 84 | /* |
44 | * The Integator/AP predates the idea to have magic numbers | 85 | * The Integator/AP predates the idea to have magic numbers |
diff --git a/arch/arm/mach-integrator/integrator_ap.c b/arch/arm/mach-integrator/integrator_ap.c index 16f3196efdb4..a5b15c4e8def 100644 --- a/arch/arm/mach-integrator/integrator_ap.c +++ b/arch/arm/mach-integrator/integrator_ap.c | |||
@@ -473,15 +473,6 @@ static struct of_dev_auxdata ap_auxdata_lookup[] __initdata = { | |||
473 | { /* sentinel */ }, | 473 | { /* sentinel */ }, |
474 | }; | 474 | }; |
475 | 475 | ||
476 | /* | ||
477 | * This is a placeholder that will get deleted when we move the PCI | ||
478 | * device over to the device tree. | ||
479 | */ | ||
480 | static struct platform_device pci_v3_device_of = { | ||
481 | .name = "pci-v3", | ||
482 | .id = 0, | ||
483 | }; | ||
484 | |||
485 | static void __init ap_init_of(void) | 476 | static void __init ap_init_of(void) |
486 | { | 477 | { |
487 | unsigned long sc_dec; | 478 | unsigned long sc_dec; |
@@ -536,8 +527,6 @@ static void __init ap_init_of(void) | |||
536 | of_platform_populate(root, of_default_bus_match_table, | 527 | of_platform_populate(root, of_default_bus_match_table, |
537 | ap_auxdata_lookup, parent); | 528 | ap_auxdata_lookup, parent); |
538 | 529 | ||
539 | platform_device_register(&pci_v3_device_of); | ||
540 | |||
541 | sc_dec = readl(ap_syscon_base + INTEGRATOR_SC_DEC_OFFSET); | 530 | sc_dec = readl(ap_syscon_base + INTEGRATOR_SC_DEC_OFFSET); |
542 | for (i = 0; i < 4; i++) { | 531 | for (i = 0; i < 4; i++) { |
543 | struct lm_device *lmdev; | 532 | struct lm_device *lmdev; |
diff --git a/arch/arm/mach-integrator/pci_v3.c b/arch/arm/mach-integrator/pci_v3.c index a3cefdebd136..a0e069d37e14 100644 --- a/arch/arm/mach-integrator/pci_v3.c +++ b/arch/arm/mach-integrator/pci_v3.c | |||
@@ -28,6 +28,10 @@ | |||
28 | #include <linux/init.h> | 28 | #include <linux/init.h> |
29 | #include <linux/io.h> | 29 | #include <linux/io.h> |
30 | #include <linux/platform_device.h> | 30 | #include <linux/platform_device.h> |
31 | #include <linux/of.h> | ||
32 | #include <linux/of_address.h> | ||
33 | #include <linux/of_irq.h> | ||
34 | #include <linux/of_pci.h> | ||
31 | #include <video/vga.h> | 35 | #include <video/vga.h> |
32 | 36 | ||
33 | #include <mach/hardware.h> | 37 | #include <mach/hardware.h> |
@@ -279,7 +283,12 @@ | |||
279 | * the mappings into PCI memory. | 283 | * the mappings into PCI memory. |
280 | */ | 284 | */ |
281 | 285 | ||
286 | /* Filled in by probe */ | ||
282 | static void __iomem *pci_v3_base; | 287 | static void __iomem *pci_v3_base; |
288 | static struct resource conf_mem; /* FIXME: remap this instead of static map */ | ||
289 | static struct resource io_mem; | ||
290 | static struct resource non_mem; | ||
291 | static struct resource pre_mem; | ||
283 | 292 | ||
284 | // V3 access routines | 293 | // V3 access routines |
285 | #define v3_writeb(o,v) __raw_writeb(v, pci_v3_base + (unsigned int)(o)) | 294 | #define v3_writeb(o,v) __raw_writeb(v, pci_v3_base + (unsigned int)(o)) |
@@ -423,13 +432,13 @@ static void __iomem *v3_open_config_window(struct pci_bus *bus, | |||
423 | * prefetchable), this frees up base1 for re-use by | 432 | * prefetchable), this frees up base1 for re-use by |
424 | * configuration memory | 433 | * configuration memory |
425 | */ | 434 | */ |
426 | v3_writel(V3_LB_BASE0, v3_addr_to_lb_base(PHYS_PCI_MEM_BASE) | | 435 | v3_writel(V3_LB_BASE0, v3_addr_to_lb_base(non_mem.start) | |
427 | V3_LB_BASE_ADR_SIZE_512MB | V3_LB_BASE_ENABLE); | 436 | V3_LB_BASE_ADR_SIZE_512MB | V3_LB_BASE_ENABLE); |
428 | 437 | ||
429 | /* | 438 | /* |
430 | * Set up base1/map1 to point into configuration space. | 439 | * Set up base1/map1 to point into configuration space. |
431 | */ | 440 | */ |
432 | v3_writel(V3_LB_BASE1, v3_addr_to_lb_base(PHYS_PCI_CONFIG_BASE) | | 441 | v3_writel(V3_LB_BASE1, v3_addr_to_lb_base(conf_mem.start) | |
433 | V3_LB_BASE_ADR_SIZE_16MB | V3_LB_BASE_ENABLE); | 442 | V3_LB_BASE_ADR_SIZE_16MB | V3_LB_BASE_ENABLE); |
434 | v3_writew(V3_LB_MAP1, mapaddress); | 443 | v3_writew(V3_LB_MAP1, mapaddress); |
435 | 444 | ||
@@ -441,7 +450,7 @@ static void v3_close_config_window(void) | |||
441 | /* | 450 | /* |
442 | * Reassign base1 for use by prefetchable PCI memory | 451 | * Reassign base1 for use by prefetchable PCI memory |
443 | */ | 452 | */ |
444 | v3_writel(V3_LB_BASE1, v3_addr_to_lb_base(PHYS_PCI_MEM_BASE + SZ_256M) | | 453 | v3_writel(V3_LB_BASE1, v3_addr_to_lb_base(pre_mem.start) | |
445 | V3_LB_BASE_ADR_SIZE_256MB | V3_LB_BASE_PREFETCH | | 454 | V3_LB_BASE_ADR_SIZE_256MB | V3_LB_BASE_PREFETCH | |
446 | V3_LB_BASE_ENABLE); | 455 | V3_LB_BASE_ENABLE); |
447 | v3_writew(V3_LB_MAP1, v3_addr_to_lb_map(PCI_BUS_PREMEM_START) | | 456 | v3_writew(V3_LB_MAP1, v3_addr_to_lb_map(PCI_BUS_PREMEM_START) | |
@@ -450,7 +459,7 @@ static void v3_close_config_window(void) | |||
450 | /* | 459 | /* |
451 | * And shrink base0 back to a 256M window (NOTE: MAP0 already correct) | 460 | * And shrink base0 back to a 256M window (NOTE: MAP0 already correct) |
452 | */ | 461 | */ |
453 | v3_writel(V3_LB_BASE0, v3_addr_to_lb_base(PHYS_PCI_MEM_BASE) | | 462 | v3_writel(V3_LB_BASE0, v3_addr_to_lb_base(non_mem.start) | |
454 | V3_LB_BASE_ADR_SIZE_256MB | V3_LB_BASE_ENABLE); | 463 | V3_LB_BASE_ADR_SIZE_256MB | V3_LB_BASE_ENABLE); |
455 | } | 464 | } |
456 | 465 | ||
@@ -522,20 +531,6 @@ static struct pci_ops pci_v3_ops = { | |||
522 | .write = v3_write_config, | 531 | .write = v3_write_config, |
523 | }; | 532 | }; |
524 | 533 | ||
525 | static struct resource non_mem = { | ||
526 | .name = "PCI non-prefetchable", | ||
527 | .start = PHYS_PCI_MEM_BASE + PCI_BUS_NONMEM_START, | ||
528 | .end = PHYS_PCI_MEM_BASE + PCI_BUS_NONMEM_START + PCI_BUS_NONMEM_SIZE - 1, | ||
529 | .flags = IORESOURCE_MEM, | ||
530 | }; | ||
531 | |||
532 | static struct resource pre_mem = { | ||
533 | .name = "PCI prefetchable", | ||
534 | .start = PHYS_PCI_MEM_BASE + PCI_BUS_PREMEM_START, | ||
535 | .end = PHYS_PCI_MEM_BASE + PCI_BUS_PREMEM_START + PCI_BUS_PREMEM_SIZE - 1, | ||
536 | .flags = IORESOURCE_MEM | IORESOURCE_PREFETCH, | ||
537 | }; | ||
538 | |||
539 | static int __init pci_v3_setup_resources(struct pci_sys_data *sys) | 534 | static int __init pci_v3_setup_resources(struct pci_sys_data *sys) |
540 | { | 535 | { |
541 | if (request_resource(&iomem_resource, &non_mem)) { | 536 | if (request_resource(&iomem_resource, &non_mem)) { |
@@ -659,7 +654,7 @@ static int __init pci_v3_setup(int nr, struct pci_sys_data *sys) | |||
659 | return -EINVAL; | 654 | return -EINVAL; |
660 | 655 | ||
661 | if (nr == 0) { | 656 | if (nr == 0) { |
662 | sys->mem_offset = PHYS_PCI_MEM_BASE; | 657 | sys->mem_offset = non_mem.start; |
663 | ret = pci_v3_setup_resources(sys); | 658 | ret = pci_v3_setup_resources(sys); |
664 | } | 659 | } |
665 | 660 | ||
@@ -697,7 +692,7 @@ static void __init pci_v3_preinit(void) | |||
697 | * Setup window 0 - PCI non-prefetchable memory | 692 | * Setup window 0 - PCI non-prefetchable memory |
698 | * Local: 0x40000000 Bus: 0x00000000 Size: 256MB | 693 | * Local: 0x40000000 Bus: 0x00000000 Size: 256MB |
699 | */ | 694 | */ |
700 | v3_writel(V3_LB_BASE0, v3_addr_to_lb_base(PHYS_PCI_MEM_BASE) | | 695 | v3_writel(V3_LB_BASE0, v3_addr_to_lb_base(non_mem.start) | |
701 | V3_LB_BASE_ADR_SIZE_256MB | V3_LB_BASE_ENABLE); | 696 | V3_LB_BASE_ADR_SIZE_256MB | V3_LB_BASE_ENABLE); |
702 | v3_writew(V3_LB_MAP0, v3_addr_to_lb_map(PCI_BUS_NONMEM_START) | | 697 | v3_writew(V3_LB_MAP0, v3_addr_to_lb_map(PCI_BUS_NONMEM_START) | |
703 | V3_LB_MAP_TYPE_MEM); | 698 | V3_LB_MAP_TYPE_MEM); |
@@ -706,7 +701,7 @@ static void __init pci_v3_preinit(void) | |||
706 | * Setup window 1 - PCI prefetchable memory | 701 | * Setup window 1 - PCI prefetchable memory |
707 | * Local: 0x50000000 Bus: 0x10000000 Size: 256MB | 702 | * Local: 0x50000000 Bus: 0x10000000 Size: 256MB |
708 | */ | 703 | */ |
709 | v3_writel(V3_LB_BASE1, v3_addr_to_lb_base(PHYS_PCI_MEM_BASE + SZ_256M) | | 704 | v3_writel(V3_LB_BASE1, v3_addr_to_lb_base(pre_mem.start) | |
710 | V3_LB_BASE_ADR_SIZE_256MB | V3_LB_BASE_PREFETCH | | 705 | V3_LB_BASE_ADR_SIZE_256MB | V3_LB_BASE_PREFETCH | |
711 | V3_LB_BASE_ENABLE); | 706 | V3_LB_BASE_ENABLE); |
712 | v3_writew(V3_LB_MAP1, v3_addr_to_lb_map(PCI_BUS_PREMEM_START) | | 707 | v3_writew(V3_LB_MAP1, v3_addr_to_lb_map(PCI_BUS_PREMEM_START) | |
@@ -715,7 +710,7 @@ static void __init pci_v3_preinit(void) | |||
715 | /* | 710 | /* |
716 | * Setup window 2 - PCI IO | 711 | * Setup window 2 - PCI IO |
717 | */ | 712 | */ |
718 | v3_writel(V3_LB_BASE2, v3_addr_to_lb_base2(PHYS_PCI_IO_BASE) | | 713 | v3_writel(V3_LB_BASE2, v3_addr_to_lb_base2(io_mem.start) | |
719 | V3_LB_BASE_ENABLE); | 714 | V3_LB_BASE_ENABLE); |
720 | v3_writew(V3_LB_MAP2, v3_addr_to_lb_map2(0)); | 715 | v3_writew(V3_LB_MAP2, v3_addr_to_lb_map2(0)); |
721 | 716 | ||
@@ -772,7 +767,7 @@ static void __init pci_v3_postinit(void) | |||
772 | "interrupt: %d\n", ret); | 767 | "interrupt: %d\n", ret); |
773 | #endif | 768 | #endif |
774 | 769 | ||
775 | register_isa_ports(PHYS_PCI_MEM_BASE, PHYS_PCI_IO_BASE, 0); | 770 | register_isa_ports(non_mem.start, io_mem.start, 0); |
776 | } | 771 | } |
777 | 772 | ||
778 | /* | 773 | /* |
@@ -837,7 +832,6 @@ static int __init pci_v3_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) | |||
837 | 832 | ||
838 | static struct hw_pci pci_v3 __initdata = { | 833 | static struct hw_pci pci_v3 __initdata = { |
839 | .swizzle = pci_v3_swizzle, | 834 | .swizzle = pci_v3_swizzle, |
840 | .map_irq = pci_v3_map_irq, | ||
841 | .setup = pci_v3_setup, | 835 | .setup = pci_v3_setup, |
842 | .nr_controllers = 1, | 836 | .nr_controllers = 1, |
843 | .ops = &pci_v3_ops, | 837 | .ops = &pci_v3_ops, |
@@ -845,8 +839,107 @@ static struct hw_pci pci_v3 __initdata = { | |||
845 | .postinit = pci_v3_postinit, | 839 | .postinit = pci_v3_postinit, |
846 | }; | 840 | }; |
847 | 841 | ||
842 | #ifdef CONFIG_OF | ||
843 | |||
844 | static int __init pci_v3_map_irq_dt(const struct pci_dev *dev, u8 slot, u8 pin) | ||
845 | { | ||
846 | struct of_irq oirq; | ||
847 | int ret; | ||
848 | |||
849 | ret = of_irq_map_pci(dev, &oirq); | ||
850 | if (ret) { | ||
851 | dev_err(&dev->dev, "of_irq_map_pci() %d\n", ret); | ||
852 | /* Proper return code 0 == NO_IRQ */ | ||
853 | return 0; | ||
854 | } | ||
855 | |||
856 | return irq_create_of_mapping(oirq.controller, oirq.specifier, | ||
857 | oirq.size); | ||
858 | } | ||
859 | |||
860 | static int __init pci_v3_dtprobe(struct platform_device *pdev, | ||
861 | struct device_node *np) | ||
862 | { | ||
863 | struct of_pci_range_parser parser; | ||
864 | struct of_pci_range range; | ||
865 | struct resource *res; | ||
866 | int irq, ret; | ||
867 | |||
868 | if (of_pci_range_parser_init(&parser, np)) | ||
869 | return -EINVAL; | ||
870 | |||
871 | /* Get base for bridge registers */ | ||
872 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | ||
873 | if (!res) { | ||
874 | dev_err(&pdev->dev, "unable to obtain PCIv3 base\n"); | ||
875 | return -ENODEV; | ||
876 | } | ||
877 | pci_v3_base = devm_ioremap(&pdev->dev, res->start, | ||
878 | resource_size(res)); | ||
879 | if (!pci_v3_base) { | ||
880 | dev_err(&pdev->dev, "unable to remap PCIv3 base\n"); | ||
881 | return -ENODEV; | ||
882 | } | ||
883 | |||
884 | /* Get and request error IRQ resource */ | ||
885 | irq = platform_get_irq(pdev, 0); | ||
886 | if (irq <= 0) { | ||
887 | dev_err(&pdev->dev, "unable to obtain PCIv3 error IRQ\n"); | ||
888 | return -ENODEV; | ||
889 | } | ||
890 | ret = devm_request_irq(&pdev->dev, irq, v3_irq, 0, | ||
891 | "PCIv3 error", NULL); | ||
892 | if (ret < 0) { | ||
893 | dev_err(&pdev->dev, "unable to request PCIv3 error IRQ %d (%d)\n", irq, ret); | ||
894 | return ret; | ||
895 | } | ||
896 | |||
897 | for_each_of_pci_range(&parser, &range) { | ||
898 | if (!range.flags) { | ||
899 | of_pci_range_to_resource(&range, np, &conf_mem); | ||
900 | conf_mem.name = "PCIv3 config"; | ||
901 | } | ||
902 | if (range.flags & IORESOURCE_IO) { | ||
903 | of_pci_range_to_resource(&range, np, &io_mem); | ||
904 | io_mem.name = "PCIv3 I/O"; | ||
905 | } | ||
906 | if ((range.flags & IORESOURCE_MEM) && | ||
907 | !(range.flags & IORESOURCE_PREFETCH)) { | ||
908 | of_pci_range_to_resource(&range, np, &non_mem); | ||
909 | non_mem.name = "PCIv3 non-prefetched mem"; | ||
910 | } | ||
911 | if ((range.flags & IORESOURCE_MEM) && | ||
912 | (range.flags & IORESOURCE_PREFETCH)) { | ||
913 | of_pci_range_to_resource(&range, np, &pre_mem); | ||
914 | pre_mem.name = "PCIv3 prefetched mem"; | ||
915 | } | ||
916 | } | ||
917 | |||
918 | if (!conf_mem.start || !io_mem.start || | ||
919 | !non_mem.start || !pre_mem.start) { | ||
920 | dev_err(&pdev->dev, "missing ranges in device node\n"); | ||
921 | return -EINVAL; | ||
922 | } | ||
923 | |||
924 | pci_v3.map_irq = pci_v3_map_irq_dt; | ||
925 | pci_common_init_dev(&pdev->dev, &pci_v3); | ||
926 | |||
927 | return 0; | ||
928 | } | ||
929 | |||
930 | #else | ||
931 | |||
932 | static inline int pci_v3_dtprobe(struct platform_device *pdev, | ||
933 | struct device_node *np) | ||
934 | { | ||
935 | return -EINVAL; | ||
936 | } | ||
937 | |||
938 | #endif | ||
939 | |||
848 | static int __init pci_v3_probe(struct platform_device *pdev) | 940 | static int __init pci_v3_probe(struct platform_device *pdev) |
849 | { | 941 | { |
942 | struct device_node *np = pdev->dev.of_node; | ||
850 | int ret; | 943 | int ret; |
851 | 944 | ||
852 | /* Remap the Integrator system controller */ | 945 | /* Remap the Integrator system controller */ |
@@ -856,6 +949,10 @@ static int __init pci_v3_probe(struct platform_device *pdev) | |||
856 | return -ENODEV; | 949 | return -ENODEV; |
857 | } | 950 | } |
858 | 951 | ||
952 | /* Device tree probe path */ | ||
953 | if (np) | ||
954 | return pci_v3_dtprobe(pdev, np); | ||
955 | |||
859 | pci_v3_base = devm_ioremap(&pdev->dev, PHYS_PCI_V3_BASE, SZ_64K); | 956 | pci_v3_base = devm_ioremap(&pdev->dev, PHYS_PCI_V3_BASE, SZ_64K); |
860 | if (!pci_v3_base) { | 957 | if (!pci_v3_base) { |
861 | dev_err(&pdev->dev, "unable to remap PCIv3 base\n"); | 958 | dev_err(&pdev->dev, "unable to remap PCIv3 base\n"); |
@@ -869,14 +966,44 @@ static int __init pci_v3_probe(struct platform_device *pdev) | |||
869 | return -ENODEV; | 966 | return -ENODEV; |
870 | } | 967 | } |
871 | 968 | ||
872 | pci_common_init(&pci_v3); | 969 | conf_mem.name = "PCIv3 config"; |
970 | conf_mem.start = PHYS_PCI_CONFIG_BASE; | ||
971 | conf_mem.end = PHYS_PCI_CONFIG_BASE + SZ_16M - 1; | ||
972 | conf_mem.flags = IORESOURCE_MEM; | ||
973 | |||
974 | io_mem.name = "PCIv3 I/O"; | ||
975 | io_mem.start = PHYS_PCI_IO_BASE; | ||
976 | io_mem.end = PHYS_PCI_IO_BASE + SZ_16M - 1; | ||
977 | io_mem.flags = IORESOURCE_MEM; | ||
978 | |||
979 | non_mem.name = "PCIv3 non-prefetched mem"; | ||
980 | non_mem.start = PHYS_PCI_MEM_BASE + PCI_BUS_NONMEM_START; | ||
981 | non_mem.end = PHYS_PCI_MEM_BASE + PCI_BUS_NONMEM_START + | ||
982 | PCI_BUS_NONMEM_SIZE - 1; | ||
983 | non_mem.flags = IORESOURCE_MEM; | ||
984 | |||
985 | pre_mem.name = "PCIv3 prefetched mem"; | ||
986 | pre_mem.start = PHYS_PCI_MEM_BASE + PCI_BUS_PREMEM_START; | ||
987 | pre_mem.end = PHYS_PCI_MEM_BASE + PCI_BUS_PREMEM_START + | ||
988 | PCI_BUS_PREMEM_SIZE - 1; | ||
989 | pre_mem.flags = IORESOURCE_MEM | IORESOURCE_PREFETCH; | ||
990 | |||
991 | pci_v3.map_irq = pci_v3_map_irq; | ||
992 | |||
993 | pci_common_init_dev(&pdev->dev, &pci_v3); | ||
873 | 994 | ||
874 | return 0; | 995 | return 0; |
875 | } | 996 | } |
876 | 997 | ||
998 | static const struct of_device_id pci_ids[] = { | ||
999 | { .compatible = "v3,v360epc-pci", }, | ||
1000 | {}, | ||
1001 | }; | ||
1002 | |||
877 | static struct platform_driver pci_v3_driver = { | 1003 | static struct platform_driver pci_v3_driver = { |
878 | .driver = { | 1004 | .driver = { |
879 | .name = "pci-v3", | 1005 | .name = "pci-v3", |
1006 | .of_match_table = pci_ids, | ||
880 | }, | 1007 | }, |
881 | }; | 1008 | }; |
882 | 1009 | ||