sh: Use the generic I/O port base for slowdown.
authorPaul Mundt <lethal@linux-sh.org>
Thu, 12 Nov 2009 07:36:26 +0000 (16:36 +0900)
committerPaul Mundt <lethal@linux-sh.org>
Thu, 12 Nov 2009 07:36:26 +0000 (16:36 +0900)
This fixes up the build and behaviour for various configurations. Namely
the CONFIG_32BIT cases where legacy mappings do not exist, as well as the
sh64 build.

Signed-off-by: Paul Mundt <lethal@linux-sh.org>
arch/sh/include/asm/io.h
arch/sh/kernel/io_generic.c
arch/sh/kernel/machvec.c

index 0cf2a5708e2604de03a15cdb9c203fd7bc18fd23..512cd3e9d0ca1c92c6153e1cf5a1cc7e460cb644 100644 (file)
 #define ctrl_outl              __raw_writel
 #define ctrl_outq              __raw_writeq
 
+extern unsigned long generic_io_base;
+
 static inline void ctrl_delay(void)
 {
-#ifdef CONFIG_CPU_SH4
-       __raw_readw(CCN_PVR);
-#elif defined(P2SEG)
-       __raw_readw(P2SEG);
-#else
-#error "Need a dummy address for delay"
-#endif
+       __raw_readw(generic_io_base);
 }
 
 #define __BUILD_MEMORY_STRING(bwlq, type)                              \
@@ -186,8 +182,6 @@ __BUILD_MEMORY_STRING(q, u64)
 
 #define IO_SPACE_LIMIT 0xffffffff
 
-extern unsigned long generic_io_base;
-
 /*
  * This function provides a method for the generic case where a
  * board-specific ioport_map simply needs to return the port + some
index b8fa6524760af3be77c391b1a92ffbd0ba4362ca..e1e1dbd195579e5cacc7a5437020a75bcc695757 100644 (file)
@@ -24,7 +24,7 @@
 #define dummy_read()
 #endif
 
-unsigned long generic_io_base;
+unsigned long generic_io_base = 0;
 
 u8 generic_inb(unsigned long port)
 {
@@ -147,8 +147,10 @@ void generic_outsl(unsigned long port, const void *src, unsigned long count)
 
 void __iomem *generic_ioport_map(unsigned long addr, unsigned int size)
 {
+#ifdef P1SEG
        if (PXSEG(addr) >= P1SEG)
                return (void __iomem *)addr;
+#endif
 
        return (void __iomem *)(addr + generic_io_base);
 }
index cbce639b108a6144351f39b85212eb00a48f433a..1652340ba3f2abe07ce27ca818deb76d19e282f6 100644 (file)
@@ -135,5 +135,9 @@ void __init sh_mv_setup(void)
        if (!sh_mv.mv_nr_irqs)
                sh_mv.mv_nr_irqs = NR_IRQS;
 
+#ifdef P2SEG
        __set_io_port_base(P2SEG);
+#else
+       __set_io_port_base(0);
+#endif
 }