Replace writeb and readb series I/O from macro to
inline function.

Signed-off-by: Macpaul Lin <[email protected]>
---
 arch/arm/include/asm/io.h |   64 +++++++++++++++++++++++++++++++--------------
 1 files changed, 44 insertions(+), 20 deletions(-)

diff --git a/arch/arm/include/asm/io.h b/arch/arm/include/asm/io.h
index 1fbc531..de3b2fd 100644
--- a/arch/arm/include/asm/io.h
+++ b/arch/arm/include/asm/io.h
@@ -133,13 +133,51 @@ extern inline void __raw_readsl(unsigned int addr, void 
*data, int longlen)
 #define __iormb()      dmb()
 #define __iowmb()      dmb()
 
-#define writeb(v,c)    ({ u8  __v = v; __iowmb(); __arch_putb(__v,c); __v; })
-#define writew(v,c)    ({ u16 __v = v; __iowmb(); __arch_putw(__v,c); __v; })
-#define writel(v,c)    ({ u32 __v = v; __iowmb(); __arch_putl(__v,c); __v; })
+static inline void writeb(unsigned char val, unsigned char *addr)
+{
+       __iowmb();
+       __arch_putb(val, addr);
+}
 
-#define readb(c)       ({ u8  __v = __arch_getb(c); __iormb(); __v; })
-#define readw(c)       ({ u16 __v = __arch_getw(c); __iormb(); __v; })
-#define readl(c)       ({ u32 __v = __arch_getl(c); __iormb(); __v; })
+static inline void writew(unsigned short val, unsigned short *addr)
+{
+       __iowmb();
+       __arch_putw(val, addr);
+
+}
+
+static inline void writel(unsigned int val, unsigned int *addr)
+{
+       __iowmb();
+       __arch_putl(val, addr);
+}
+
+static inline unsigned char readb(unsigned char *addr)
+{
+       u8      val;
+
+       val = __arch_getb(addr);
+       __iormb();
+       return val;
+}
+
+static inline unsigned short readw(unsigned short *addr)
+{
+       u16     val;
+
+       val = __arch_getw(addr);
+       __iormb();
+       return val;
+}
+
+static inline unsigned int readl(unsigned int *addr)
+{
+       u32     val;
+
+       val = __arch_getl(addr);
+       __iormb();
+       return val;
+}
 
 /*
  * The compiler seems to be incapable of optimising constants
@@ -363,20 +401,6 @@ check_signature(unsigned long io_addr, const unsigned char 
*signature,
 out:
        return retval;
 }
-
-#elif !defined(readb)
-
-#define readb(addr)                    (__readwrite_bug("readb"),0)
-#define readw(addr)                    (__readwrite_bug("readw"),0)
-#define readl(addr)                    (__readwrite_bug("readl"),0)
-#define writeb(v,addr)                 __readwrite_bug("writeb")
-#define writew(v,addr)                 __readwrite_bug("writew")
-#define writel(v,addr)                 __readwrite_bug("writel")
-
-#define eth_io_copy_and_sum(a,b,c,d)   __readwrite_bug("eth_io_copy_and_sum")
-
-#define check_signature(io,sig,len)    (0)
-
 #endif /* __mem_pci */
 
 /*
-- 
1.7.3.5

_______________________________________________
U-Boot mailing list
[email protected]
http://lists.denx.de/mailman/listinfo/u-boot

Reply via email to