diff options
author | Geert Uytterhoeven <geert@linux-m68k.org> | 2012-10-15 23:03:30 +0200 |
---|---|---|
committer | Geert Uytterhoeven <geert@linux-m68k.org> | 2012-10-15 23:03:30 +0200 |
commit | 8fccc5f9c3ad7b6f847883a2a03b539e96245e0c (patch) | |
tree | 0fa0aa09f26eb6151d89fa3a34f2b53c015ed067 /arch/m68k/include/uapi/asm/swab.h | |
parent | ddffeb8c4d0331609ef2581d84de4d763607bd37 (diff) | |
parent | 10b3a979347d4aba7de19e8d33eb8b87fe2a11dd (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.h | 27 |
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 */ |