diff options
author | Paul Mundt <lethal@linux-sh.org> | 2006-09-27 03:45:22 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2006-09-27 03:45:22 -0400 |
commit | a3e61d50dc82475ebca3ff8b18c174c02c5ff511 (patch) | |
tree | d7a39867983b0bca5619cfe7493358e6bde6f3ba /arch/sh/drivers/pci | |
parent | 959f85f8a3223c116bbe95dd8a9b207790b5d4d3 (diff) |
sh: Inhibit mapping PCI apertures through page tables.
Inhibit mapping through page tables in __ioremap() for PCI memory
apertures on SH7751 and SH7780-style PCI controllers, translation is
not possible for these areas. For other users that map a small window
in P1/P2 space, ioremap() traps that already, and should never make
it to __ioremap().
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/drivers/pci')
-rw-r--r-- | arch/sh/drivers/pci/pci.c | 20 |
1 files changed, 9 insertions, 11 deletions
diff --git a/arch/sh/drivers/pci/pci.c b/arch/sh/drivers/pci/pci.c index 7377a8a8e161..d439336d2e18 100644 --- a/arch/sh/drivers/pci/pci.c +++ b/arch/sh/drivers/pci/pci.c | |||
@@ -195,7 +195,7 @@ void __iomem *pci_iomap(struct pci_dev *dev, int bar, unsigned long maxlen) | |||
195 | unsigned long len = pci_resource_len(dev, bar); | 195 | unsigned long len = pci_resource_len(dev, bar); |
196 | unsigned long flags = pci_resource_flags(dev, bar); | 196 | unsigned long flags = pci_resource_flags(dev, bar); |
197 | 197 | ||
198 | if (!len || !start) | 198 | if (unlikely(!len || !start)) |
199 | return NULL; | 199 | return NULL; |
200 | if (maxlen && len > maxlen) | 200 | if (maxlen && len > maxlen) |
201 | len = maxlen; | 201 | len = maxlen; |
@@ -204,18 +204,16 @@ void __iomem *pci_iomap(struct pci_dev *dev, int bar, unsigned long maxlen) | |||
204 | * Presently the IORESOURCE_MEM case is a bit special, most | 204 | * Presently the IORESOURCE_MEM case is a bit special, most |
205 | * SH7751 style PCI controllers have PCI memory at a fixed | 205 | * SH7751 style PCI controllers have PCI memory at a fixed |
206 | * location in the address space where no remapping is desired | 206 | * location in the address space where no remapping is desired |
207 | * (traditionally at 0xfd000000). Once this changes, the | 207 | * (typically at 0xfd000000, but is_pci_memaddr() will know |
208 | * IORESOURCE_MEM case will have to switch to using ioremap() and | 208 | * best). With the IORESOURCE_MEM case more care has to be taken |
209 | * more care will have to be taken to inhibit page table mapping | 209 | * to inhibit page table mapping for legacy cores, but this is |
210 | * for legacy cores. | 210 | * punted off to __ioremap(). |
211 | * | 211 | * -- PFM. |
212 | * For now everything wraps to ioport_map(), since boards that | ||
213 | * have PCI will be able to check the address range properly on | ||
214 | * their own. | ||
215 | * -- PFM. | ||
216 | */ | 212 | */ |
217 | if (flags & (IORESOURCE_IO | IORESOURCE_MEM)) | 213 | if (flags & IORESOURCE_IO) |
218 | return ioport_map(start, len); | 214 | return ioport_map(start, len); |
215 | if (flags & IORESOURCE_MEM) | ||
216 | return ioremap(start, len); | ||
219 | 217 | ||
220 | return NULL; | 218 | return NULL; |
221 | } | 219 | } |