blob: f5fa0653ebc631f1f7145021323e26585d5cd93d [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __ASM_SH_BYTEORDER_H
2#define __ASM_SH_BYTEORDER_H
3
4/*
5 * Copyright (C) 1999 Niibe Yutaka
Paul Mundt7a65eaf2007-11-09 13:58:44 +09006 * Copyright (C) 2000, 2001 Paolo Alberelli
Linus Torvalds1da177e2005-04-16 15:20:36 -07007 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07008#include <linux/compiler.h>
Paul Mundt7a65eaf2007-11-09 13:58:44 +09009#include <linux/types.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070010
Harvey Harrison14062662008-10-31 16:01:22 +090011#ifdef __LITTLE_ENDIAN__
12# define __LITTLE_ENDIAN
13#else
14# define __BIG_ENDIAN
15#endif
16
17#define __SWAB_64_THRU_32__
18
19static inline __attribute_const__ __u32 __arch_swab32(__u32 x)
Linus Torvalds1da177e2005-04-16 15:20:36 -070020{
Paul Mundt7a65eaf2007-11-09 13:58:44 +090021 __asm__(
Paul Mundt6dba1b62008-03-14 17:21:09 +090022#ifdef __SH5__
23 "byterev %0, %0\n\t"
24 "shari %0, 32, %0"
25#else
Paul Mundt7a65eaf2007-11-09 13:58:44 +090026 "swap.b %0, %0\n\t"
27 "swap.w %0, %0\n\t"
28 "swap.b %0, %0"
Paul Mundt7a65eaf2007-11-09 13:58:44 +090029#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070030 : "=r" (x)
31 : "0" (x));
Paul Mundt7a65eaf2007-11-09 13:58:44 +090032
Linus Torvalds1da177e2005-04-16 15:20:36 -070033 return x;
34}
Harvey Harrison14062662008-10-31 16:01:22 +090035#define __arch_swab32 __arch_swab32
Linus Torvalds1da177e2005-04-16 15:20:36 -070036
Harvey Harrison14062662008-10-31 16:01:22 +090037static inline __attribute_const__ __u16 __arch_swab16(__u16 x)
Linus Torvalds1da177e2005-04-16 15:20:36 -070038{
Paul Mundt7a65eaf2007-11-09 13:58:44 +090039 __asm__(
Paul Mundt6dba1b62008-03-14 17:21:09 +090040#ifdef __SH5__
Paul Mundt7a65eaf2007-11-09 13:58:44 +090041 "byterev %0, %0\n\t"
42 "shari %0, 32, %0"
Paul Mundt6dba1b62008-03-14 17:21:09 +090043#else
44 "swap.b %0, %0"
Paul Mundt7a65eaf2007-11-09 13:58:44 +090045#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070046 : "=r" (x)
47 : "0" (x));
Paul Mundt7a65eaf2007-11-09 13:58:44 +090048
Linus Torvalds1da177e2005-04-16 15:20:36 -070049 return x;
50}
Harvey Harrison14062662008-10-31 16:01:22 +090051#define __arch_swab16 __arch_swab16
Linus Torvalds1da177e2005-04-16 15:20:36 -070052
Harvey Harrison14062662008-10-31 16:01:22 +090053static inline __u64 __arch_swab64(__u64 val)
Paul Mundt7a65eaf2007-11-09 13:58:44 +090054{
55 union {
Linus Torvalds1da177e2005-04-16 15:20:36 -070056 struct { __u32 a,b; } s;
57 __u64 u;
58 } v, w;
59 v.u = val;
Harvey Harrison14062662008-10-31 16:01:22 +090060 w.s.b = __arch_swab32(v.s.a);
61 w.s.a = __arch_swab32(v.s.b);
Paul Mundt7a65eaf2007-11-09 13:58:44 +090062 return w.u;
63}
Harvey Harrison14062662008-10-31 16:01:22 +090064#define __arch_swab64 __arch_swab64
Linus Torvalds1da177e2005-04-16 15:20:36 -070065
Harvey Harrison14062662008-10-31 16:01:22 +090066#include <linux/byteorder.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070067
68#endif /* __ASM_SH_BYTEORDER_H */