summaryrefslogtreecommitdiffstats
path: root/arch/m68k/include/uapi/asm/swab.h
diff options
context:
space:
mode:
authorGeert Uytterhoeven <geert@linux-m68k.org>2012-10-15 23:03:30 +0200
committerGeert Uytterhoeven <geert@linux-m68k.org>2012-10-15 23:03:30 +0200
commit8fccc5f9c3ad7b6f847883a2a03b539e96245e0c (patch)
tree0fa0aa09f26eb6151d89fa3a34f2b53c015ed067 /arch/m68k/include/uapi/asm/swab.h
parentddffeb8c4d0331609ef2581d84de4d763607bd37 (diff)
parent10b3a979347d4aba7de19e8d33eb8b87fe2a11dd (diff)
Merge tag 'disintegrate-m68k-20121009' of git://git.infradead.org/users/dhowells/linux-headers into for-linus
Diffstat (limited to 'arch/m68k/include/uapi/asm/swab.h')
-rw-r--r--arch/m68k/include/uapi/asm/swab.h27
1 files changed, 27 insertions, 0 deletions
diff --git a/arch/m68k/include/uapi/asm/swab.h b/arch/m68k/include/uapi/asm/swab.h
new file mode 100644
index 00000000000..b7b37a40def
--- /dev/null
+++ b/arch/m68k/include/uapi/asm/swab.h
@@ -0,0 +1,27 @@
+#ifndef _M68K_SWAB_H
+#define _M68K_SWAB_H
+
+#include <linux/types.h>
+#include <linux/compiler.h>
+
+#define __SWAB_64_THRU_32__
+
+#if defined (__mcfisaaplus__) || defined (__mcfisac__)
+static inline __attribute_const__ __u32 __arch_swab32(__u32 val)
+{
+ __asm__("byterev %0" : "=d" (val) : "0" (val));
+ return val;
+}
+
+#define __arch_swab32 __arch_swab32
+#elif !defined(__mcoldfire__)
+
+static inline __attribute_const__ __u32 __arch_swab32(__u32 val)
+{
+ __asm__("rolw #8,%0; swap %0; rolw #8,%0" : "=d" (val) : "0" (val));
+ return val;
+}
+#define __arch_swab32 __arch_swab32
+#endif
+
+#endif /* _M68K_SWAB_H */