Merge git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core-2.6
[linux/fpc-iii.git] / arch / x86 / include / asm / swab.h
blob557cd9f006612aebbffb5bfb2976330a0fd23403
1 #ifndef _ASM_X86_SWAB_H
2 #define _ASM_X86_SWAB_H
4 #include <linux/types.h>
5 #include <linux/compiler.h>
7 static inline __attribute_const__ __u32 __arch_swab32(__u32 val)
9 #ifdef __i386__
10 # ifdef CONFIG_X86_BSWAP
11 asm("bswap %0" : "=r" (val) : "0" (val));
12 # else
13 asm("xchgb %b0,%h0\n\t" /* swap lower bytes */
14 "rorl $16,%0\n\t" /* swap words */
15 "xchgb %b0,%h0" /* swap higher bytes */
16 : "=q" (val)
17 : "0" (val));
18 # endif
20 #else /* __i386__ */
21 asm("bswapl %0"
22 : "=r" (val)
23 : "0" (val));
24 #endif
25 return val;
27 #define __arch_swab32 __arch_swab32
29 static inline __attribute_const__ __u64 __arch_swab64(__u64 val)
31 #ifdef __i386__
32 union {
33 struct {
34 __u32 a;
35 __u32 b;
36 } s;
37 __u64 u;
38 } v;
39 v.u = val;
40 # ifdef CONFIG_X86_BSWAP
41 asm("bswapl %0 ; bswapl %1 ; xchgl %0,%1"
42 : "=r" (v.s.a), "=r" (v.s.b)
43 : "0" (v.s.a), "1" (v.s.b));
44 # else
45 v.s.a = __arch_swab32(v.s.a);
46 v.s.b = __arch_swab32(v.s.b);
47 asm("xchgl %0,%1"
48 : "=r" (v.s.a), "=r" (v.s.b)
49 : "0" (v.s.a), "1" (v.s.b));
50 # endif
51 return v.u;
52 #else /* __i386__ */
53 asm("bswapq %0"
54 : "=r" (val)
55 : "0" (val));
56 return val;
57 #endif
59 #define __arch_swab64 __arch_swab64
61 #endif /* _ASM_X86_SWAB_H */