diff options
Diffstat (limited to 'arch/blackfin/include')
-rw-r--r-- | arch/blackfin/include/asm/Kbuild | 1 | ||||
-rw-r--r-- | arch/blackfin/include/asm/byteorder.h | 43 | ||||
-rw-r--r-- | arch/blackfin/include/asm/swab.h | 48 |
3 files changed, 50 insertions, 42 deletions
diff --git a/arch/blackfin/include/asm/Kbuild b/arch/blackfin/include/asm/Kbuild index 606ecfdcc962..d0d1ac435544 100644 --- a/arch/blackfin/include/asm/Kbuild +++ b/arch/blackfin/include/asm/Kbuild | |||
@@ -1,3 +1,4 @@ | |||
1 | include include/asm-generic/Kbuild.asm | 1 | include include/asm-generic/Kbuild.asm |
2 | 2 | ||
3 | unifdef-y += fixed_code.h | 3 | unifdef-y += fixed_code.h |
4 | unifdef-y += swab.h | ||
diff --git a/arch/blackfin/include/asm/byteorder.h b/arch/blackfin/include/asm/byteorder.h index 6a673d42da18..b9e797a497b4 100644 --- a/arch/blackfin/include/asm/byteorder.h +++ b/arch/blackfin/include/asm/byteorder.h | |||
@@ -1,48 +1,7 @@ | |||
1 | #ifndef _BLACKFIN_BYTEORDER_H | 1 | #ifndef _BLACKFIN_BYTEORDER_H |
2 | #define _BLACKFIN_BYTEORDER_H | 2 | #define _BLACKFIN_BYTEORDER_H |
3 | 3 | ||
4 | #include <asm/types.h> | 4 | #include <asm/swab.h> |
5 | #include <linux/compiler.h> | ||
6 | |||
7 | #ifdef __GNUC__ | ||
8 | |||
9 | static __inline__ __attribute_const__ __u32 ___arch__swahb32(__u32 xx) | ||
10 | { | ||
11 | __u32 tmp; | ||
12 | __asm__("%1 = %0 >> 8 (V);\n\t" | ||
13 | "%0 = %0 << 8 (V);\n\t" | ||
14 | "%0 = %0 | %1;\n\t" | ||
15 | : "+d"(xx), "=&d"(tmp)); | ||
16 | return xx; | ||
17 | } | ||
18 | |||
19 | static __inline__ __attribute_const__ __u32 ___arch__swahw32(__u32 xx) | ||
20 | { | ||
21 | __u32 rv; | ||
22 | __asm__("%0 = PACK(%1.L, %1.H);\n\t": "=d"(rv): "d"(xx)); | ||
23 | return rv; | ||
24 | } | ||
25 | |||
26 | #define __arch__swahb32(x) ___arch__swahb32(x) | ||
27 | #define __arch__swahw32(x) ___arch__swahw32(x) | ||
28 | #define __arch__swab32(x) ___arch__swahb32(___arch__swahw32(x)) | ||
29 | |||
30 | static __inline__ __attribute_const__ __u16 ___arch__swab16(__u16 xx) | ||
31 | { | ||
32 | __u32 xw = xx; | ||
33 | __asm__("%0 <<= 8;\n %0.L = %0.L + %0.H (NS);\n": "+d"(xw)); | ||
34 | return (__u16)xw; | ||
35 | } | ||
36 | |||
37 | #define __arch__swab16(x) ___arch__swab16(x) | ||
38 | |||
39 | #endif | ||
40 | |||
41 | #if defined(__GNUC__) && !defined(__STRICT_ANSI__) || defined(__KERNEL__) | ||
42 | # define __BYTEORDER_HAS_U64__ | ||
43 | # define __SWAB_64_THRU_32__ | ||
44 | #endif | ||
45 | |||
46 | #include <linux/byteorder/little_endian.h> | 5 | #include <linux/byteorder/little_endian.h> |
47 | 6 | ||
48 | #endif /* _BLACKFIN_BYTEORDER_H */ | 7 | #endif /* _BLACKFIN_BYTEORDER_H */ |
diff --git a/arch/blackfin/include/asm/swab.h b/arch/blackfin/include/asm/swab.h new file mode 100644 index 000000000000..69a051b612bd --- /dev/null +++ b/arch/blackfin/include/asm/swab.h | |||
@@ -0,0 +1,48 @@ | |||
1 | #ifndef _BLACKFIN_SWAB_H | ||
2 | #define _BLACKFIN_SWAB_H | ||
3 | |||
4 | #include <asm/types.h> | ||
5 | #include <linux/compiler.h> | ||
6 | |||
7 | #if defined(__GNUC__) && !defined(__STRICT_ANSI__) || defined(__KERNEL__) | ||
8 | # define __SWAB_64_THRU_32__ | ||
9 | #endif | ||
10 | |||
11 | #ifdef __GNUC__ | ||
12 | |||
13 | static __inline__ __attribute_const__ __u32 __arch_swahb32(__u32 xx) | ||
14 | { | ||
15 | __u32 tmp; | ||
16 | __asm__("%1 = %0 >> 8 (V);\n\t" | ||
17 | "%0 = %0 << 8 (V);\n\t" | ||
18 | "%0 = %0 | %1;\n\t" | ||
19 | : "+d"(xx), "=&d"(tmp)); | ||
20 | return xx; | ||
21 | } | ||
22 | #define __arch_swahb32 __arch_swahb32 | ||
23 | |||
24 | static __inline__ __attribute_const__ __u32 __arch_swahw32(__u32 xx) | ||
25 | { | ||
26 | __u32 rv; | ||
27 | __asm__("%0 = PACK(%1.L, %1.H);\n\t": "=d"(rv): "d"(xx)); | ||
28 | return rv; | ||
29 | } | ||
30 | #define __arch_swahw32 __arch_swahw32 | ||
31 | |||
32 | static __inline__ __attribute_const__ __u32 __arch_swab32(__u32 xx) | ||
33 | { | ||
34 | return __arch_swahb32(__arch_swahw32(xx)); | ||
35 | } | ||
36 | #define __arch_swab32 __arch_swab32 | ||
37 | |||
38 | static __inline__ __attribute_const__ __u16 __arch_swab16(__u16 xx) | ||
39 | { | ||
40 | __u32 xw = xx; | ||
41 | __asm__("%0 <<= 8;\n %0.L = %0.L + %0.H (NS);\n": "+d"(xw)); | ||
42 | return (__u16)xw; | ||
43 | } | ||
44 | #define __arch_swab16 __arch_swab16 | ||
45 | |||
46 | #endif /* __GNUC__ */ | ||
47 | |||
48 | #endif /* _BLACKFIN_SWAB_H */ | ||