Blackfin: new dynamic bfin read/write mmr helpers
authorMike Frysinger <vapier@gentoo.org>
Sat, 26 Dec 2009 15:25:56 +0000 (15:25 +0000)
committerMike Frysinger <vapier@gentoo.org>
Fri, 6 Aug 2010 16:55:44 +0000 (12:55 -0400)
These are useful when working with C structs of MMRs as the appropriate
size is selected based on the given argument.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
arch/blackfin/include/asm/def_LPBlackfin.h

index f342ff0319df8f86d47aed829d5cd2543828826e..4e562850021c849b1362fafd24ef4a55cc5736b6 100644 (file)
 #define bfin_write16(addr, val) _bfin_writeX(addr, val, 16, w)
 #define bfin_write32(addr, val) _bfin_writeX(addr, val, 32,  )
 
+#define bfin_read(addr) \
+({ \
+    sizeof(*(addr)) == 1 ? bfin_read8(addr)  : \
+    sizeof(*(addr)) == 2 ? bfin_read16(addr) : \
+    sizeof(*(addr)) == 4 ? bfin_read32(addr) : \
+    ({ BUG(); 0; }); \
+})
+#define bfin_write(addr, val) \
+({ \
+       switch (sizeof(*(addr))) { \
+       case 1: bfin_write8(addr, val);  break; \
+       case 2: bfin_write16(addr, val); break; \
+       case 4: bfin_write32(addr, val); break; \
+       default: BUG(); \
+       } \
+})
+
 #endif /* __ASSEMBLY__ */
 
 /**************************************************