OSDN Git Service

MIPS: split out the 64-bit ioremap implementation
authorChristoph Hellwig <hch@lst.de>
Thu, 16 Apr 2020 15:00:09 +0000 (17:00 +0200)
committerThomas Bogendoerfer <tsbogend@alpha.franken.de>
Sun, 19 Apr 2020 14:11:08 +0000 (16:11 +0200)
Split out the mips64 ioremap implementation entirely, as it will never use
page table based remapping.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
arch/mips/include/asm/io.h

index 6051325..f007571 100644 (file)
@@ -153,6 +153,25 @@ static inline void *isa_bus_to_virt(unsigned long address)
  */
 #define page_to_phys(page)     ((dma_addr_t)page_to_pfn(page) << PAGE_SHIFT)
 
+#ifdef CONFIG_64BIT
+static inline void __iomem *ioremap_prot(phys_addr_t offset,
+               unsigned long size, unsigned long prot_val)
+{
+       unsigned long flags = prot_val & _CACHE_MASK;
+       u64 base = (flags == _CACHE_UNCACHED ? IO_BASE : UNCAC_BASE);
+       void __iomem *addr;
+
+       addr = plat_ioremap(offset, size, flags);
+       if (!addr)
+               addr = (void __iomem *)(unsigned long)(base + offset);
+       return addr;
+}
+
+static inline void iounmap(const volatile void __iomem *addr)
+{
+       plat_iounmap(addr);
+}
+#else /* CONFIG_64BIT */
 extern void __iomem * __ioremap(phys_addr_t offset, phys_addr_t size, unsigned long flags);
 extern void __iounmap(const volatile void __iomem *addr);
 
@@ -174,18 +193,8 @@ static inline void __iomem *ioremap_prot(phys_addr_t offset,
 
 #define __IS_LOW512(addr) (!((phys_addr_t)(addr) & (phys_addr_t) ~0x1fffffffULL))
 
-       if (IS_ENABLED(CONFIG_64BIT)) {
-               u64 base = UNCAC_BASE;
-
-               /*
-                * R10000 supports a 2 bit uncached attribute therefore
-                * UNCAC_BASE may not equal IO_BASE.
-                */
-               if (flags == _CACHE_UNCACHED)
-                       base = (u64) IO_BASE;
-               return (void __iomem *) (unsigned long) (base + offset);
-       } else if (__builtin_constant_p(offset) &&
-                  __builtin_constant_p(size) && __builtin_constant_p(flags)) {
+       if (__builtin_constant_p(offset) &&
+           __builtin_constant_p(size) && __builtin_constant_p(flags)) {
                phys_addr_t phys_addr, last_addr;
 
                phys_addr = fixup_bigphys_addr(offset, size);
@@ -210,6 +219,22 @@ static inline void __iomem *ioremap_prot(phys_addr_t offset,
 #undef __IS_LOW512
 }
 
+static inline void iounmap(const volatile void __iomem *addr)
+{
+       if (plat_iounmap(addr))
+               return;
+
+#define __IS_KSEG1(addr) (((unsigned long)(addr) & ~0x1fffffffUL) == CKSEG1)
+
+       if (__builtin_constant_p(addr) && __IS_KSEG1(addr))
+               return;
+
+       __iounmap(addr);
+
+#undef __IS_KSEG1
+}
+#endif /* !CONFIG_64BIT */
+
 /*
  * ioremap     -   map bus memory into CPU space
  * @offset:    bus address of the memory
@@ -264,22 +289,6 @@ static inline void __iomem *ioremap_prot(phys_addr_t offset,
 #define ioremap_wc(offset, size)                                       \
        ioremap_prot((offset), (size), boot_cpu_data.writecombine)
 
-static inline void iounmap(const volatile void __iomem *addr)
-{
-       if (plat_iounmap(addr))
-               return;
-
-#define __IS_KSEG1(addr) (((unsigned long)(addr) & ~0x1fffffffUL) == CKSEG1)
-
-       if (IS_ENABLED(CONFIG_64BIT) ||
-           (__builtin_constant_p(addr) && __IS_KSEG1(addr)))
-               return;
-
-       __iounmap(addr);
-
-#undef __IS_KSEG1
-}
-
 #if defined(CONFIG_CPU_CAVIUM_OCTEON) || defined(CONFIG_CPU_LOONGSON64)
 #define war_io_reorder_wmb()           wmb()
 #else