1#ifndef _UAPI_LINUX_TYPES_H 2#define _UAPI_LINUX_TYPES_H 3 4#include <asm/types.h> 5 6#ifndef __ASSEMBLY__ 7#ifndef __KERNEL__ 8#ifndef __EXPORTED_HEADERS__ 9#warning "Attempt to use kernel headers from user space, see http://kernelnewbies.org/KernelHeaders" 10#endif /* __EXPORTED_HEADERS__ */ 11#endif 12 13#include <linux/posix_types.h> 14 15 16/* 17 * Below are truly Linux-specific types that should never collide with 18 * any application/library that wants linux/types.h. 19 */ 20 21#ifdef __CHECKER__ 22#define __bitwise__ __attribute__((bitwise)) 23#else 24#define __bitwise__ 25#endif 26#ifdef __CHECK_ENDIAN__ 27#define __bitwise __bitwise__ 28#else 29#define __bitwise 30#endif 31 32typedef __u16 __bitwise __le16; 33typedef __u16 __bitwise __be16; 34typedef __u32 __bitwise __le32; 35typedef __u32 __bitwise __be32; 36typedef __u64 __bitwise __le64; 37typedef __u64 __bitwise __be64; 38 39typedef __u16 __bitwise __sum16; 40typedef __u32 __bitwise __wsum; 41 42/* 43 * aligned_u64 should be used in defining kernel<->userspace ABIs to avoid 44 * common 32/64-bit compat problems. 45 * 64-bit values align to 4-byte boundaries on x86_32 (and possibly other 46 * architectures) and to 8-byte boundaries on 64-bit architectures. The new 47 * aligned_64 type enforces 8-byte alignment so that structs containing 48 * aligned_64 values have the same alignment on 32-bit and 64-bit architectures. 49 * No conversions are necessary between 32-bit user-space and a 64-bit kernel. 50 */ 51#define __aligned_u64 __u64 __attribute__((aligned(8))) 52#define __aligned_be64 __be64 __attribute__((aligned(8))) 53#define __aligned_le64 __le64 __attribute__((aligned(8))) 54 55#endif /* __ASSEMBLY__ */ 56#endif /* _UAPI_LINUX_TYPES_H */ 57