diff options
author | Harvey Harrison <harvey.harrison@gmail.com> | 2009-01-06 17:56:22 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-01-06 21:10:26 -0500 |
commit | 292b4d0978e3bbb087a83ce77e389c7b462a093c (patch) | |
tree | d240d83e170696543688f9f58384c1ede986b507 /arch/avr32/include | |
parent | 991c0e6d1ae3df59f0ddfe05edecec8319e35a1b (diff) |
avr32: introduce asm/swab.h
Signed-off-by: Harvey Harrison <harvey.harrison@gmail.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/avr32/include')
-rw-r--r-- | arch/avr32/include/asm/Kbuild | 1 | ||||
-rw-r--r-- | arch/avr32/include/asm/byteorder.h | 31 | ||||
-rw-r--r-- | arch/avr32/include/asm/swab.h | 35 |
3 files changed, 38 insertions, 29 deletions
diff --git a/arch/avr32/include/asm/Kbuild b/arch/avr32/include/asm/Kbuild index 3136628ba8d2..219822c8ad18 100644 --- a/arch/avr32/include/asm/Kbuild +++ b/arch/avr32/include/asm/Kbuild | |||
@@ -1,3 +1,4 @@ | |||
1 | include include/asm-generic/Kbuild.asm | 1 | include include/asm-generic/Kbuild.asm |
2 | 2 | ||
3 | header-y += swab.h | ||
3 | header-y += cachectl.h | 4 | header-y += cachectl.h |
diff --git a/arch/avr32/include/asm/byteorder.h b/arch/avr32/include/asm/byteorder.h index 8e3af02076dd..2aba64b4e122 100644 --- a/arch/avr32/include/asm/byteorder.h +++ b/arch/avr32/include/asm/byteorder.h | |||
@@ -4,34 +4,7 @@ | |||
4 | #ifndef __ASM_AVR32_BYTEORDER_H | 4 | #ifndef __ASM_AVR32_BYTEORDER_H |
5 | #define __ASM_AVR32_BYTEORDER_H | 5 | #define __ASM_AVR32_BYTEORDER_H |
6 | 6 | ||
7 | #include <asm/types.h> | 7 | #include <asm/swab.h> |
8 | #include <linux/compiler.h> | 8 | #include <linux/byteorder/big_endian.h> |
9 | 9 | ||
10 | #define __BIG_ENDIAN | ||
11 | #define __SWAB_64_THRU_32__ | ||
12 | |||
13 | #ifdef __CHECKER__ | ||
14 | extern unsigned long __builtin_bswap_32(unsigned long x); | ||
15 | extern unsigned short __builtin_bswap_16(unsigned short x); | ||
16 | #endif | ||
17 | |||
18 | /* | ||
19 | * avr32-linux-gcc versions earlier than 4.2 improperly sign-extends | ||
20 | * the result. | ||
21 | */ | ||
22 | #if !(__GNUC__ == 4 && __GNUC_MINOR__ < 2) | ||
23 | static inline __attribute_const__ __u16 __arch_swab16(__u16 val) | ||
24 | { | ||
25 | return __builtin_bswap_16(val); | ||
26 | } | ||
27 | #define __arch_swab16 __arch_swab16 | ||
28 | |||
29 | static inline __attribute_const__ __u32 __arch_swab32(__u32 val) | ||
30 | { | ||
31 | return __builtin_bswap_32(val); | ||
32 | } | ||
33 | #define __arch_swab32 __arch_swab32 | ||
34 | #endif | ||
35 | |||
36 | #include <linux/byteorder.h> | ||
37 | #endif /* __ASM_AVR32_BYTEORDER_H */ | 10 | #endif /* __ASM_AVR32_BYTEORDER_H */ |
diff --git a/arch/avr32/include/asm/swab.h b/arch/avr32/include/asm/swab.h new file mode 100644 index 000000000000..a14aa5b46d98 --- /dev/null +++ b/arch/avr32/include/asm/swab.h | |||
@@ -0,0 +1,35 @@ | |||
1 | /* | ||
2 | * AVR32 byteswapping functions. | ||
3 | */ | ||
4 | #ifndef __ASM_AVR32_SWAB_H | ||
5 | #define __ASM_AVR32_SWAB_H | ||
6 | |||
7 | #include <asm/types.h> | ||
8 | #include <linux/compiler.h> | ||
9 | |||
10 | #define __SWAB_64_THRU_32__ | ||
11 | |||
12 | #ifdef __CHECKER__ | ||
13 | extern unsigned long __builtin_bswap_32(unsigned long x); | ||
14 | extern unsigned short __builtin_bswap_16(unsigned short x); | ||
15 | #endif | ||
16 | |||
17 | /* | ||
18 | * avr32-linux-gcc versions earlier than 4.2 improperly sign-extends | ||
19 | * the result. | ||
20 | */ | ||
21 | #if !(__GNUC__ == 4 && __GNUC_MINOR__ < 2) | ||
22 | static inline __attribute_const__ __u16 __arch_swab16(__u16 val) | ||
23 | { | ||
24 | return __builtin_bswap_16(val); | ||
25 | } | ||
26 | #define __arch_swab16 __arch_swab16 | ||
27 | |||
28 | static inline __attribute_const__ __u32 __arch_swab32(__u32 val) | ||
29 | { | ||
30 | return __builtin_bswap_32(val); | ||
31 | } | ||
32 | #define __arch_swab32 __arch_swab32 | ||
33 | #endif | ||
34 | |||
35 | #endif /* __ASM_AVR32_SWAB_H */ | ||