slub page alloc fallback: Enable interrupts for GFP_WAIT.
[wrt350n-kernel.git] / include / linux / byteorder / swabb.h
blob8c780c7d779e134fd9d42531b8f2e8d61b2badb4
1 #ifndef _LINUX_BYTEORDER_SWABB_H
2 #define _LINUX_BYTEORDER_SWABB_H
4 /*
5 * linux/byteorder/swabb.h
6 * SWAp Bytes Bizarrely
7 * swaHHXX[ps]?(foo)
9 * Support for obNUXIous pdp-endian and other bizarre architectures.
10 * Will Linux ever run on such ancient beasts? if not, this file
11 * will be but a programming pearl. Still, it's a reminder that we
12 * shouldn't be making too many assumptions when trying to be portable.
17 * Meaning of the names I chose (vaxlinux people feel free to correct them):
18 * swahw32 swap 16-bit half-words in a 32-bit word
19 * swahb32 swap 8-bit halves of each 16-bit half-word in a 32-bit word
21 * No 64-bit support yet. I don't know NUXI conventions for long longs.
22 * I guarantee it will be a mess when it's there, though :->
23 * It will be even worse if there are conflicting 64-bit conventions.
24 * Hopefully, no one ever used 64-bit objects on NUXI machines.
28 #include <linux/types.h>
30 #define ___swahw32(x) \
31 ({ \
32 __u32 __x = (x); \
33 ((__u32)( \
34 (((__u32)(__x) & (__u32)0x0000ffffUL) << 16) | \
35 (((__u32)(__x) & (__u32)0xffff0000UL) >> 16) )); \
37 #define ___swahb32(x) \
38 ({ \
39 __u32 __x = (x); \
40 ((__u32)( \
41 (((__u32)(__x) & (__u32)0x00ff00ffUL) << 8) | \
42 (((__u32)(__x) & (__u32)0xff00ff00UL) >> 8) )); \
45 #define ___constant_swahw32(x) \
46 ((__u32)( \
47 (((__u32)(x) & (__u32)0x0000ffffUL) << 16) | \
48 (((__u32)(x) & (__u32)0xffff0000UL) >> 16) ))
49 #define ___constant_swahb32(x) \
50 ((__u32)( \
51 (((__u32)(x) & (__u32)0x00ff00ffUL) << 8) | \
52 (((__u32)(x) & (__u32)0xff00ff00UL) >> 8) ))
55 * provide defaults when no architecture-specific optimization is detected
57 #ifndef __arch__swahw32
58 # define __arch__swahw32(x) ___swahw32(x)
59 #endif
60 #ifndef __arch__swahb32
61 # define __arch__swahb32(x) ___swahb32(x)
62 #endif
64 #ifndef __arch__swahw32p
65 # define __arch__swahw32p(x) __swahw32(*(x))
66 #endif
67 #ifndef __arch__swahb32p
68 # define __arch__swahb32p(x) __swahb32(*(x))
69 #endif
71 #ifndef __arch__swahw32s
72 # define __arch__swahw32s(x) do { *(x) = __swahw32p((x)); } while (0)
73 #endif
74 #ifndef __arch__swahb32s
75 # define __arch__swahb32s(x) do { *(x) = __swahb32p((x)); } while (0)
76 #endif
80 * Allow constant folding
82 #define __swahw32(x) \
83 (__builtin_constant_p((__u32)(x)) ? \
84 ___swahw32((x)) : \
85 __fswahw32((x)))
86 #define __swahb32(x) \
87 (__builtin_constant_p((__u32)(x)) ? \
88 ___swahb32((x)) : \
89 __fswahb32((x)))
92 static inline __u32 __fswahw32(__u32 x)
94 return __arch__swahw32(x);
97 static inline __u32 __swahw32p(__u32 *x)
99 return __arch__swahw32p(x);
102 static inline void __swahw32s(__u32 *addr)
104 __arch__swahw32s(addr);
107 static inline __u32 __fswahb32(__u32 x)
109 return __arch__swahb32(x);
112 static inline __u32 __swahb32p(__u32 *x)
114 return __arch__swahb32p(x);
117 static inline void __swahb32s(__u32 *addr)
119 __arch__swahb32s(addr);
122 #ifdef __BYTEORDER_HAS_U64__
124 * Not supported yet
126 #endif /* __BYTEORDER_HAS_U64__ */
128 #define swahw32 __swahw32
129 #define swahb32 __swahb32
130 #define swahw32p __swahw32p
131 #define swahb32p __swahb32p
132 #define swahw32s __swahw32s
133 #define swahb32s __swahb32s
135 #endif /* _LINUX_BYTEORDER_SWABB_H */