diff options
author | Rob Herring <rob.herring@calxeda.com> | 2012-07-04 12:18:40 -0400 |
---|---|---|
committer | Rob Herring <rob.herring@calxeda.com> | 2012-07-26 10:10:04 -0400 |
commit | dd9bf78040fa0da4cecc228e1682b9682b8cb180 (patch) | |
tree | 9cf716530a0549fdac85b7b7b68badce122ce313 | |
parent | 0b9b18e0166d8925ed222335efbc3cfd66aa882f (diff) |
ARM: iop3xx: use fixed PCI i/o mapping
Move iop33x and iop32x PCI to fixed i/o mapping and remove io.h. This
changes the PCI bus addresses from the cpu address to 0 based. It appears
that there is translation h/w for this, but its untested.
Not sure what to do with io_offset. I think it should always be 0.
AFAICT, PCI setup is skipped if the ATU is already setup.
Signed-off-by: Rob Herring <rob.herring@calxeda.com>
Reviewed-by: Arnd Bergmann <arnd@arndb.de>
-rw-r--r-- | arch/arm/Kconfig | 2 | ||||
-rw-r--r-- | arch/arm/include/asm/hardware/iop3xx.h | 12 | ||||
-rw-r--r-- | arch/arm/mach-iop32x/include/mach/io.h | 19 | ||||
-rw-r--r-- | arch/arm/mach-iop33x/include/mach/io.h | 19 | ||||
-rw-r--r-- | arch/arm/plat-iop/pci.c | 25 | ||||
-rw-r--r-- | arch/arm/plat-iop/setup.c | 5 |
6 files changed, 10 insertions, 72 deletions
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 1b7faa5a085..58bb75efa63 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
@@ -495,7 +495,6 @@ config ARCH_IOP32X | |||
495 | bool "IOP32x-based" | 495 | bool "IOP32x-based" |
496 | depends on MMU | 496 | depends on MMU |
497 | select CPU_XSCALE | 497 | select CPU_XSCALE |
498 | select NEED_MACH_IO_H | ||
499 | select NEED_RET_TO_USER | 498 | select NEED_RET_TO_USER |
500 | select PLAT_IOP | 499 | select PLAT_IOP |
501 | select PCI | 500 | select PCI |
@@ -508,7 +507,6 @@ config ARCH_IOP33X | |||
508 | bool "IOP33x-based" | 507 | bool "IOP33x-based" |
509 | depends on MMU | 508 | depends on MMU |
510 | select CPU_XSCALE | 509 | select CPU_XSCALE |
511 | select NEED_MACH_IO_H | ||
512 | select NEED_RET_TO_USER | 510 | select NEED_RET_TO_USER |
513 | select PLAT_IOP | 511 | select PLAT_IOP |
514 | select PCI | 512 | select PCI |
diff --git a/arch/arm/include/asm/hardware/iop3xx.h b/arch/arm/include/asm/hardware/iop3xx.h index 2ff2c75a463..02fe2fbe247 100644 --- a/arch/arm/include/asm/hardware/iop3xx.h +++ b/arch/arm/include/asm/hardware/iop3xx.h | |||
@@ -217,18 +217,8 @@ extern int iop3xx_get_init_atu(void); | |||
217 | #define IOP3XX_PCI_LOWER_MEM_PA 0x80000000 | 217 | #define IOP3XX_PCI_LOWER_MEM_PA 0x80000000 |
218 | #define IOP3XX_PCI_MEM_WINDOW_SIZE 0x08000000 | 218 | #define IOP3XX_PCI_MEM_WINDOW_SIZE 0x08000000 |
219 | 219 | ||
220 | #define IOP3XX_PCI_IO_WINDOW_SIZE 0x00010000 | ||
221 | #define IOP3XX_PCI_LOWER_IO_PA 0x90000000 | 220 | #define IOP3XX_PCI_LOWER_IO_PA 0x90000000 |
222 | #define IOP3XX_PCI_LOWER_IO_VA 0xfe000000 | 221 | #define IOP3XX_PCI_LOWER_IO_BA 0x00000000 |
223 | #define IOP3XX_PCI_LOWER_IO_BA 0x90000000 | ||
224 | #define IOP3XX_PCI_UPPER_IO_PA (IOP3XX_PCI_LOWER_IO_PA +\ | ||
225 | IOP3XX_PCI_IO_WINDOW_SIZE - 1) | ||
226 | #define IOP3XX_PCI_UPPER_IO_VA (IOP3XX_PCI_LOWER_IO_VA +\ | ||
227 | IOP3XX_PCI_IO_WINDOW_SIZE - 1) | ||
228 | #define IOP3XX_PCI_IO_PHYS_TO_VIRT(addr) (((u32) (addr) -\ | ||
229 | IOP3XX_PCI_LOWER_IO_PA) +\ | ||
230 | IOP3XX_PCI_LOWER_IO_VA) | ||
231 | |||
232 | 222 | ||
233 | #ifndef __ASSEMBLY__ | 223 | #ifndef __ASSEMBLY__ |
234 | 224 | ||
diff --git a/arch/arm/mach-iop32x/include/mach/io.h b/arch/arm/mach-iop32x/include/mach/io.h deleted file mode 100644 index e2ada265bb8..00000000000 --- a/arch/arm/mach-iop32x/include/mach/io.h +++ /dev/null | |||
@@ -1,19 +0,0 @@ | |||
1 | /* | ||
2 | * arch/arm/mach-iop32x/include/mach/io.h | ||
3 | * | ||
4 | * Copyright (C) 2001 MontaVista Software, Inc. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef __IO_H | ||
12 | #define __IO_H | ||
13 | |||
14 | #include <asm/hardware/iop3xx.h> | ||
15 | |||
16 | #define IO_SPACE_LIMIT 0xffffffff | ||
17 | #define __io(p) ((void __iomem *)IOP3XX_PCI_IO_PHYS_TO_VIRT(p)) | ||
18 | |||
19 | #endif | ||
diff --git a/arch/arm/mach-iop33x/include/mach/io.h b/arch/arm/mach-iop33x/include/mach/io.h deleted file mode 100644 index f7c1b659566..00000000000 --- a/arch/arm/mach-iop33x/include/mach/io.h +++ /dev/null | |||
@@ -1,19 +0,0 @@ | |||
1 | /* | ||
2 | * arch/arm/mach-iop33x/include/mach/io.h | ||
3 | * | ||
4 | * Copyright (C) 2001 MontaVista Software, Inc. | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | |||
11 | #ifndef __IO_H | ||
12 | #define __IO_H | ||
13 | |||
14 | #include <asm/hardware/iop3xx.h> | ||
15 | |||
16 | #define IO_SPACE_LIMIT 0xffffffff | ||
17 | #define __io(p) ((void __iomem *)IOP3XX_PCI_IO_PHYS_TO_VIRT(p)) | ||
18 | |||
19 | #endif | ||
diff --git a/arch/arm/plat-iop/pci.c b/arch/arm/plat-iop/pci.c index 8daae9b230e..362474b5c40 100644 --- a/arch/arm/plat-iop/pci.c +++ b/arch/arm/plat-iop/pci.c | |||
@@ -192,30 +192,24 @@ int iop3xx_pci_setup(int nr, struct pci_sys_data *sys) | |||
192 | if (nr != 0) | 192 | if (nr != 0) |
193 | return 0; | 193 | return 0; |
194 | 194 | ||
195 | res = kzalloc(2 * sizeof(struct resource), GFP_KERNEL); | 195 | res = kzalloc(sizeof(struct resource), GFP_KERNEL); |
196 | if (!res) | 196 | if (!res) |
197 | panic("PCI: unable to alloc resources"); | 197 | panic("PCI: unable to alloc resources"); |
198 | 198 | ||
199 | res[0].start = IOP3XX_PCI_LOWER_IO_PA; | 199 | res->start = IOP3XX_PCI_LOWER_MEM_PA; |
200 | res[0].end = IOP3XX_PCI_LOWER_IO_PA + IOP3XX_PCI_IO_WINDOW_SIZE - 1; | 200 | res->end = IOP3XX_PCI_LOWER_MEM_PA + IOP3XX_PCI_MEM_WINDOW_SIZE - 1; |
201 | res[0].name = "IOP3XX PCI I/O Space"; | 201 | res->name = "IOP3XX PCI Memory Space"; |
202 | res[0].flags = IORESOURCE_IO; | 202 | res->flags = IORESOURCE_MEM; |
203 | request_resource(&ioport_resource, &res[0]); | 203 | request_resource(&iomem_resource, res); |
204 | |||
205 | res[1].start = IOP3XX_PCI_LOWER_MEM_PA; | ||
206 | res[1].end = IOP3XX_PCI_LOWER_MEM_PA + IOP3XX_PCI_MEM_WINDOW_SIZE - 1; | ||
207 | res[1].name = "IOP3XX PCI Memory Space"; | ||
208 | res[1].flags = IORESOURCE_MEM; | ||
209 | request_resource(&iomem_resource, &res[1]); | ||
210 | 204 | ||
211 | /* | 205 | /* |
212 | * Use whatever translation is already setup. | 206 | * Use whatever translation is already setup. |
213 | */ | 207 | */ |
214 | sys->mem_offset = IOP3XX_PCI_LOWER_MEM_PA - *IOP3XX_OMWTVR0; | 208 | sys->mem_offset = IOP3XX_PCI_LOWER_MEM_PA - *IOP3XX_OMWTVR0; |
215 | sys->io_offset = IOP3XX_PCI_LOWER_IO_PA - *IOP3XX_OIOWTVR; | ||
216 | 209 | ||
217 | pci_add_resource_offset(&sys->resources, &res[0], sys->io_offset); | 210 | pci_add_resource_offset(&sys->resources, res, sys->mem_offset); |
218 | pci_add_resource_offset(&sys->resources, &res[1], sys->mem_offset); | 211 | |
212 | pci_ioremap_io(0, IOP3XX_PCI_LOWER_IO_PA); | ||
219 | 213 | ||
220 | return 1; | 214 | return 1; |
221 | } | 215 | } |
@@ -367,7 +361,6 @@ void __init iop3xx_pci_preinit_cond(void) | |||
367 | 361 | ||
368 | void __init iop3xx_pci_preinit(void) | 362 | void __init iop3xx_pci_preinit(void) |
369 | { | 363 | { |
370 | pcibios_min_io = 0; | ||
371 | pcibios_min_mem = 0; | 364 | pcibios_min_mem = 0; |
372 | 365 | ||
373 | iop3xx_atu_disable(); | 366 | iop3xx_atu_disable(); |
diff --git a/arch/arm/plat-iop/setup.c b/arch/arm/plat-iop/setup.c index bade586fed0..5b217f460f1 100644 --- a/arch/arm/plat-iop/setup.c +++ b/arch/arm/plat-iop/setup.c | |||
@@ -25,11 +25,6 @@ static struct map_desc iop3xx_std_desc[] __initdata = { | |||
25 | .pfn = __phys_to_pfn(IOP3XX_PERIPHERAL_PHYS_BASE), | 25 | .pfn = __phys_to_pfn(IOP3XX_PERIPHERAL_PHYS_BASE), |
26 | .length = IOP3XX_PERIPHERAL_SIZE, | 26 | .length = IOP3XX_PERIPHERAL_SIZE, |
27 | .type = MT_UNCACHED, | 27 | .type = MT_UNCACHED, |
28 | }, { /* PCI IO space */ | ||
29 | .virtual = IOP3XX_PCI_LOWER_IO_VA, | ||
30 | .pfn = __phys_to_pfn(IOP3XX_PCI_LOWER_IO_PA), | ||
31 | .length = IOP3XX_PCI_IO_WINDOW_SIZE, | ||
32 | .type = MT_DEVICE, | ||
33 | }, | 28 | }, |
34 | }; | 29 | }; |
35 | 30 | ||