diff options
Diffstat (limited to 'arch/sh/drivers/pci/pci.c')
-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 | } |