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 | ||
