123456789101112131415161718192021222324252627282930313233343536 |
- // SPDX-License-Identifier: GPL-2.0
- // Copyright (C) 2005-2017 Andes Technology Corporation
- #ifndef __NDS32_SWAB_H__
- #define __NDS32_SWAB_H__
- #include <linux/types.h>
- #include <linux/compiler.h>
- static __inline__ __attribute_const__ __u32 ___arch__swab32(__u32 x)
- {
- __asm__("wsbh %0, %0\n\t" /* word swap byte within halfword */
- "rotri %0, %0, #16\n"
- :"=r"(x)
- :"0"(x));
- return x;
- }
- static __inline__ __attribute_const__ __u16 ___arch__swab16(__u16 x)
- {
- __asm__("wsbh %0, %0\n" /* word swap byte within halfword */
- :"=r"(x)
- :"0"(x));
- return x;
- }
- #define __arch_swab32(x) ___arch__swab32(x)
- #define __arch_swab16(x) ___arch__swab16(x)
- #if !defined(__STRICT_ANSI__) || defined(__KERNEL__)
- #define __BYTEORDER_HAS_U64__
- #define __SWAB_64_THRU_32__
- #endif
- #endif /* __NDS32_SWAB_H__ */
|