types.h 1.6 KB

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