1 /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2 #ifndef _UAPI_LINUX_TYPES_H
3 #define _UAPI_LINUX_TYPES_H
9 #ifndef __EXPORTED_HEADERS__
10 #warning "Attempt to use kernel headers from user space, see https://kernelnewbies.org/KernelHeaders"
11 #endif /* __EXPORTED_HEADERS__ */
14 #include <linux/posix_types.h>
16 #ifdef __SIZEOF_INT128__
17 typedef __signed__ __int128 __s128
__attribute__((aligned(16)));
18 typedef unsigned __int128 __u128
__attribute__((aligned(16)));
22 * Below are truly Linux-specific types that should never collide with
23 * any application/library that wants linux/types.h.
26 /* sparse defines __CHECKER__; see Documentation/dev-tools/sparse.rst */
28 #define __bitwise __attribute__((bitwise))
33 /* The kernel doesn't use this legacy form, but user space does */
34 #define __bitwise__ __bitwise
36 typedef __u16 __bitwise __le16
;
37 typedef __u16 __bitwise __be16
;
38 typedef __u32 __bitwise __le32
;
39 typedef __u32 __bitwise __be32
;
40 typedef __u64 __bitwise __le64
;
41 typedef __u64 __bitwise __be64
;
43 typedef __u16 __bitwise __sum16
;
44 typedef __u32 __bitwise __wsum
;
47 * aligned_u64 should be used in defining kernel<->userspace ABIs to avoid
48 * common 32/64-bit compat problems.
49 * 64-bit values align to 4-byte boundaries on x86_32 (and possibly other
50 * architectures) and to 8-byte boundaries on 64-bit architectures. The new
51 * aligned_64 type enforces 8-byte alignment so that structs containing
52 * aligned_64 values have the same alignment on 32-bit and 64-bit architectures.
53 * No conversions are necessary between 32-bit user-space and a 64-bit kernel.
55 #define __aligned_u64 __u64 __attribute__((aligned(8)))
56 #define __aligned_s64 __s64 __attribute__((aligned(8)))
57 #define __aligned_be64 __be64 __attribute__((aligned(8)))
58 #define __aligned_le64 __le64 __attribute__((aligned(8)))
60 typedef unsigned __bitwise __poll_t
;
62 #endif /* __ASSEMBLY__ */
63 #endif /* _UAPI_LINUX_TYPES_H */