diff options
author | Paul Burton <paul.burton@imgtec.com> | 2016-10-05 13:18:13 -0400 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2016-10-06 12:00:52 -0400 |
commit | 87dd9a4de421f052fd9be58c7da08a453f340d5e (patch) | |
tree | d59e67442805343710c679a14f7883759564912d | |
parent | c5611df968047fb0b38156497b4242730ef66108 (diff) |
MIPS: PCI: Support generic drivers
Introduce support for PCI drivers using only functionality provided
generically by the PCI subsystem, by adding the minimum arch-provided
functions required.
The driver this has been developed for & tested with the xilinx-pcie on
a MIPS Boston development board.
Signed-off-by: Paul Burton <paul.burton@imgtec.com>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/14346/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
-rw-r--r-- | arch/mips/Kconfig | 1 | ||||
-rw-r--r-- | arch/mips/pci/Makefile | 1 | ||||
-rw-r--r-- | arch/mips/pci/pci-generic.c | 52 |
3 files changed, 54 insertions, 0 deletions
diff --git a/arch/mips/Kconfig b/arch/mips/Kconfig index d31f839c6e77..86d5b3930531 100644 --- a/arch/mips/Kconfig +++ b/arch/mips/Kconfig | |||
@@ -2998,6 +2998,7 @@ config PCI_DOMAINS_GENERIC | |||
2998 | bool | 2998 | bool |
2999 | 2999 | ||
3000 | config PCI_DRIVERS_GENERIC | 3000 | config PCI_DRIVERS_GENERIC |
3001 | select PCI_DOMAINS_GENERIC if PCI_DOMAINS | ||
3001 | bool | 3002 | bool |
3002 | 3003 | ||
3003 | config PCI_DRIVERS_LEGACY | 3004 | config PCI_DRIVERS_LEGACY |
diff --git a/arch/mips/pci/Makefile b/arch/mips/pci/Makefile index 847821040cd9..4b821481dd44 100644 --- a/arch/mips/pci/Makefile +++ b/arch/mips/pci/Makefile | |||
@@ -4,6 +4,7 @@ | |||
4 | 4 | ||
5 | obj-y += pci.o | 5 | obj-y += pci.o |
6 | obj-$(CONFIG_PCI_DRIVERS_LEGACY)+= pci-legacy.o | 6 | obj-$(CONFIG_PCI_DRIVERS_LEGACY)+= pci-legacy.o |
7 | obj-$(CONFIG_PCI_DRIVERS_GENERIC)+= pci-generic.o | ||
7 | 8 | ||
8 | # | 9 | # |
9 | # PCI bus host bridge specific code | 10 | # PCI bus host bridge specific code |
diff --git a/arch/mips/pci/pci-generic.c b/arch/mips/pci/pci-generic.c new file mode 100644 index 000000000000..dce304dc3d62 --- /dev/null +++ b/arch/mips/pci/pci-generic.c | |||
@@ -0,0 +1,52 @@ | |||
1 | /* | ||
2 | * Copyright (C) 2016 Imagination Technologies | ||
3 | * Author: Paul Burton <paul.burton@imgtec.com> | ||
4 | * | ||
5 | * pcibios_align_resource taken from arch/arm/kernel/bios32.c. | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify it | ||
8 | * under the terms of the GNU General Public License as published by the | ||
9 | * Free Software Foundation; either version 2 of the License, or (at your | ||
10 | * option) any later version. | ||
11 | */ | ||
12 | |||
13 | #include <linux/pci.h> | ||
14 | |||
15 | /* | ||
16 | * We need to avoid collisions with `mirrored' VGA ports | ||
17 | * and other strange ISA hardware, so we always want the | ||
18 | * addresses to be allocated in the 0x000-0x0ff region | ||
19 | * modulo 0x400. | ||
20 | * | ||
21 | * Why? Because some silly external IO cards only decode | ||
22 | * the low 10 bits of the IO address. The 0x00-0xff region | ||
23 | * is reserved for motherboard devices that decode all 16 | ||
24 | * bits, so it's ok to allocate at, say, 0x2800-0x28ff, | ||
25 | * but we want to try to avoid allocating at 0x2900-0x2bff | ||
26 | * which might have be mirrored at 0x0100-0x03ff.. | ||
27 | */ | ||
28 | resource_size_t pcibios_align_resource(void *data, const struct resource *res, | ||
29 | resource_size_t size, resource_size_t align) | ||
30 | { | ||
31 | struct pci_dev *dev = data; | ||
32 | resource_size_t start = res->start; | ||
33 | struct pci_host_bridge *host_bridge; | ||
34 | |||
35 | if (res->flags & IORESOURCE_IO && start & 0x300) | ||
36 | start = (start + 0x3ff) & ~0x3ff; | ||
37 | |||
38 | start = (start + align - 1) & ~(align - 1); | ||
39 | |||
40 | host_bridge = pci_find_host_bridge(dev->bus); | ||
41 | |||
42 | if (host_bridge->align_resource) | ||
43 | return host_bridge->align_resource(dev, res, | ||
44 | start, size, align); | ||
45 | |||
46 | return start; | ||
47 | } | ||
48 | |||
49 | void pcibios_fixup_bus(struct pci_bus *bus) | ||
50 | { | ||
51 | pci_read_bridge_bases(bus); | ||
52 | } | ||