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