X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=include%2Fasm-mips%2Fbyteorder.h;h=eee83cbdf2b08c7a22644255b153a8fcace0ec5e;hb=refs%2Fheads%2Fvserver;hp=4ce5bc37f403b37e7395e3851928e8439a52fdf6;hpb=76828883507a47dae78837ab5dec5a5b4513c667;p=linux-2.6.git diff --git a/include/asm-mips/byteorder.h b/include/asm-mips/byteorder.h index 4ce5bc37f..eee83cbdf 100644 --- a/include/asm-mips/byteorder.h +++ b/include/asm-mips/byteorder.h @@ -8,7 +8,6 @@ #ifndef _ASM_BYTEORDER_H #define _ASM_BYTEORDER_H -#include #include #include @@ -19,9 +18,7 @@ static __inline__ __attribute_const__ __u16 ___arch__swab16(__u16 x) { __asm__( - " .set mips32r2 \n" " wsbh %0, %1 \n" - " .set mips0 \n" : "=r" (x) : "r" (x)); @@ -32,10 +29,8 @@ static __inline__ __attribute_const__ __u16 ___arch__swab16(__u16 x) static __inline__ __attribute_const__ __u32 ___arch__swab32(__u32 x) { __asm__( - " .set mips32r2 \n" " wsbh %0, %1 \n" " rotr %0, %0, 16 \n" - " .set mips0 \n" : "=r" (x) : "r" (x)); @@ -43,6 +38,24 @@ static __inline__ __attribute_const__ __u32 ___arch__swab32(__u32 x) } #define __arch__swab32(x) ___arch__swab32(x) +#ifdef CONFIG_CPU_MIPS64_R2 + +static __inline__ __attribute_const__ __u64 ___arch__swab64(__u64 x) +{ + __asm__( + " dsbh %0, %1 \n" + " dshd %0, %0 \n" + " drotr %0, %0, 32 \n" + : "=r" (x) + : "r" (x)); + + return x; +} + +#define __arch__swab64(x) ___arch__swab64(x) + +#endif /* CONFIG_CPU_MIPS64_R2 */ + #endif /* CONFIG_CPU_MIPSR2 */ #if !defined(__STRICT_ANSI__) || defined(__KERNEL__)