| 1 | /* SPDX-License-Identifier: GPL-2.0 */ | 
|---|
| 2 | #ifndef _LINUX_TYPES_H | 
|---|
| 3 | #define _LINUX_TYPES_H | 
|---|
| 4 |  | 
|---|
| 5 | #define | 
|---|
| 6 | #include <uapi/linux/types.h> | 
|---|
| 7 |  | 
|---|
| 8 | #ifndef __ASSEMBLY__ | 
|---|
| 9 |  | 
|---|
| 10 | #define DECLARE_BITMAP(name,bits) \ | 
|---|
| 11 | unsigned long name[BITS_TO_LONGS(bits)] | 
|---|
| 12 |  | 
|---|
| 13 | #ifdef __SIZEOF_INT128__ | 
|---|
| 14 | typedef __s128 s128; | 
|---|
| 15 | typedef __u128 u128; | 
|---|
| 16 | #endif | 
|---|
| 17 |  | 
|---|
| 18 | typedef u32 __kernel_dev_t; | 
|---|
| 19 |  | 
|---|
| 20 | typedef __kernel_fd_set		fd_set; | 
|---|
| 21 | typedef __kernel_dev_t		dev_t; | 
|---|
| 22 | typedef __kernel_ulong_t	ino_t; | 
|---|
| 23 | typedef __kernel_mode_t		mode_t; | 
|---|
| 24 | typedef unsigned short		umode_t; | 
|---|
| 25 | typedef u32			nlink_t; | 
|---|
| 26 | typedef __kernel_off_t		off_t; | 
|---|
| 27 | typedef __kernel_pid_t		pid_t; | 
|---|
| 28 | typedef __kernel_daddr_t	daddr_t; | 
|---|
| 29 | typedef __kernel_key_t		key_t; | 
|---|
| 30 | typedef __kernel_suseconds_t	suseconds_t; | 
|---|
| 31 | typedef __kernel_timer_t	timer_t; | 
|---|
| 32 | typedef __kernel_clockid_t	clockid_t; | 
|---|
| 33 | typedef __kernel_mqd_t		mqd_t; | 
|---|
| 34 |  | 
|---|
| 35 | typedef _Bool			bool; | 
|---|
| 36 |  | 
|---|
| 37 | typedef __kernel_uid32_t	uid_t; | 
|---|
| 38 | typedef __kernel_gid32_t	gid_t; | 
|---|
| 39 | typedef __kernel_uid16_t        uid16_t; | 
|---|
| 40 | typedef __kernel_gid16_t        gid16_t; | 
|---|
| 41 |  | 
|---|
| 42 | typedef unsigned long		uintptr_t; | 
|---|
| 43 | typedef long			intptr_t; | 
|---|
| 44 |  | 
|---|
| 45 | #ifdef CONFIG_HAVE_UID16 | 
|---|
| 46 | /* This is defined by arch/{arch}/include/asm/posix_types.h */ | 
|---|
| 47 | typedef __kernel_old_uid_t	old_uid_t; | 
|---|
| 48 | typedef __kernel_old_gid_t	old_gid_t; | 
|---|
| 49 | #endif /* CONFIG_UID16 */ | 
|---|
| 50 |  | 
|---|
| 51 | #if defined(__GNUC__) | 
|---|
| 52 | typedef __kernel_loff_t		loff_t; | 
|---|
| 53 | #endif | 
|---|
| 54 |  | 
|---|
| 55 | /* | 
|---|
| 56 | * The following typedefs are also protected by individual ifdefs for | 
|---|
| 57 | * historical reasons: | 
|---|
| 58 | */ | 
|---|
| 59 | #ifndef _SIZE_T | 
|---|
| 60 | #define _SIZE_T | 
|---|
| 61 | typedef __kernel_size_t		size_t; | 
|---|
| 62 | #endif | 
|---|
| 63 |  | 
|---|
| 64 | #ifndef _SSIZE_T | 
|---|
| 65 | #define _SSIZE_T | 
|---|
| 66 | typedef __kernel_ssize_t	ssize_t; | 
|---|
| 67 | #endif | 
|---|
| 68 |  | 
|---|
| 69 | #ifndef _PTRDIFF_T | 
|---|
| 70 | #define _PTRDIFF_T | 
|---|
| 71 | typedef __kernel_ptrdiff_t	ptrdiff_t; | 
|---|
| 72 | #endif | 
|---|
| 73 |  | 
|---|
| 74 | #ifndef _CLOCK_T | 
|---|
| 75 | #define _CLOCK_T | 
|---|
| 76 | typedef __kernel_clock_t	clock_t; | 
|---|
| 77 | #endif | 
|---|
| 78 |  | 
|---|
| 79 | #ifndef _CADDR_T | 
|---|
| 80 | #define _CADDR_T | 
|---|
| 81 | typedef __kernel_caddr_t	caddr_t; | 
|---|
| 82 | #endif | 
|---|
| 83 |  | 
|---|
| 84 | /* bsd */ | 
|---|
| 85 | typedef unsigned char		u_char; | 
|---|
| 86 | typedef unsigned short		u_short; | 
|---|
| 87 | typedef unsigned int		u_int; | 
|---|
| 88 | typedef unsigned long		u_long; | 
|---|
| 89 |  | 
|---|
| 90 | /* sysv */ | 
|---|
| 91 | typedef unsigned char		unchar; | 
|---|
| 92 | typedef unsigned short		ushort; | 
|---|
| 93 | typedef unsigned int		uint; | 
|---|
| 94 | typedef unsigned long		ulong; | 
|---|
| 95 | typedef unsigned long long	ullong; | 
|---|
| 96 |  | 
|---|
| 97 | #ifndef __BIT_TYPES_DEFINED__ | 
|---|
| 98 | #define __BIT_TYPES_DEFINED__ | 
|---|
| 99 |  | 
|---|
| 100 | typedef u8			u_int8_t; | 
|---|
| 101 | typedef s8			int8_t; | 
|---|
| 102 | typedef u16			u_int16_t; | 
|---|
| 103 | typedef s16			int16_t; | 
|---|
| 104 | typedef u32			u_int32_t; | 
|---|
| 105 | typedef s32			int32_t; | 
|---|
| 106 |  | 
|---|
| 107 | #endif /* !(__BIT_TYPES_DEFINED__) */ | 
|---|
| 108 |  | 
|---|
| 109 | typedef u8			uint8_t; | 
|---|
| 110 | typedef u16			uint16_t; | 
|---|
| 111 | typedef u32			uint32_t; | 
|---|
| 112 |  | 
|---|
| 113 | #if defined(__GNUC__) | 
|---|
| 114 | typedef u64			uint64_t; | 
|---|
| 115 | typedef u64			u_int64_t; | 
|---|
| 116 | typedef s64			int64_t; | 
|---|
| 117 | #endif | 
|---|
| 118 |  | 
|---|
| 119 | /* These are the special 64-bit data types that are 8-byte aligned */ | 
|---|
| 120 | #define aligned_u64		__aligned_u64 | 
|---|
| 121 | #define aligned_s64		__aligned_s64 | 
|---|
| 122 | #define aligned_be64		__aligned_be64 | 
|---|
| 123 | #define aligned_le64		__aligned_le64 | 
|---|
| 124 |  | 
|---|
| 125 | /* Nanosecond scalar representation for kernel time values */ | 
|---|
| 126 | typedef s64	ktime_t; | 
|---|
| 127 |  | 
|---|
| 128 | /** | 
|---|
| 129 | * The type used for indexing onto a disc or disc partition. | 
|---|
| 130 | * | 
|---|
| 131 | * Linux always considers sectors to be 512 bytes long independently | 
|---|
| 132 | * of the devices real block size. | 
|---|
| 133 | * | 
|---|
| 134 | * blkcnt_t is the type of the inode's block count. | 
|---|
| 135 | */ | 
|---|
| 136 | typedef u64 sector_t; | 
|---|
| 137 | typedef u64 blkcnt_t; | 
|---|
| 138 |  | 
|---|
| 139 | /* generic data direction definitions */ | 
|---|
| 140 | #define READ			0 | 
|---|
| 141 | #define WRITE			1 | 
|---|
| 142 |  | 
|---|
| 143 | /* | 
|---|
| 144 | * The type of an index into the pagecache. | 
|---|
| 145 | */ | 
|---|
| 146 | #define pgoff_t unsigned long | 
|---|
| 147 |  | 
|---|
| 148 | /* | 
|---|
| 149 | * A dma_addr_t can hold any valid DMA address, i.e., any address returned | 
|---|
| 150 | * by the DMA API. | 
|---|
| 151 | * | 
|---|
| 152 | * If the DMA API only uses 32-bit addresses, dma_addr_t need only be 32 | 
|---|
| 153 | * bits wide.  Bus addresses, e.g., PCI BARs, may be wider than 32 bits, | 
|---|
| 154 | * but drivers do memory-mapped I/O to ioremapped kernel virtual addresses, | 
|---|
| 155 | * so they don't care about the size of the actual bus addresses. | 
|---|
| 156 | */ | 
|---|
| 157 | #ifdef CONFIG_ARCH_DMA_ADDR_T_64BIT | 
|---|
| 158 | typedef u64 dma_addr_t; | 
|---|
| 159 | #else | 
|---|
| 160 | typedef u32 dma_addr_t; | 
|---|
| 161 | #endif | 
|---|
| 162 |  | 
|---|
| 163 | typedef unsigned int __bitwise gfp_t; | 
|---|
| 164 | typedef unsigned int __bitwise slab_flags_t; | 
|---|
| 165 | typedef unsigned int __bitwise fmode_t; | 
|---|
| 166 |  | 
|---|
| 167 | #ifdef CONFIG_PHYS_ADDR_T_64BIT | 
|---|
| 168 | typedef u64 phys_addr_t; | 
|---|
| 169 | #else | 
|---|
| 170 | typedef u32 phys_addr_t; | 
|---|
| 171 | #endif | 
|---|
| 172 |  | 
|---|
| 173 | typedef phys_addr_t resource_size_t; | 
|---|
| 174 |  | 
|---|
| 175 | /* | 
|---|
| 176 | * This type is the placeholder for a hardware interrupt number. It has to be | 
|---|
| 177 | * big enough to enclose whatever representation is used by a given platform. | 
|---|
| 178 | */ | 
|---|
| 179 | typedef unsigned long irq_hw_number_t; | 
|---|
| 180 |  | 
|---|
| 181 | typedef struct { | 
|---|
| 182 | int counter; | 
|---|
| 183 | } atomic_t; | 
|---|
| 184 |  | 
|---|
| 185 | #define ATOMIC_INIT(i) { (i) } | 
|---|
| 186 |  | 
|---|
| 187 | #ifdef CONFIG_64BIT | 
|---|
| 188 | typedef struct { | 
|---|
| 189 | s64 counter; | 
|---|
| 190 | } atomic64_t; | 
|---|
| 191 | #endif | 
|---|
| 192 |  | 
|---|
| 193 | typedef struct { | 
|---|
| 194 | atomic_t refcnt; | 
|---|
| 195 | } rcuref_t; | 
|---|
| 196 |  | 
|---|
| 197 | #define RCUREF_INIT(i)	{ .refcnt = ATOMIC_INIT(i - 1) } | 
|---|
| 198 |  | 
|---|
| 199 | struct list_head { | 
|---|
| 200 | struct list_head *next, *prev; | 
|---|
| 201 | }; | 
|---|
| 202 |  | 
|---|
| 203 | struct hlist_head { | 
|---|
| 204 | struct hlist_node *first; | 
|---|
| 205 | }; | 
|---|
| 206 |  | 
|---|
| 207 | struct hlist_node { | 
|---|
| 208 | struct hlist_node *next, **pprev; | 
|---|
| 209 | }; | 
|---|
| 210 |  | 
|---|
| 211 | struct ustat { | 
|---|
| 212 | __kernel_daddr_t	f_tfree; | 
|---|
| 213 | #ifdef CONFIG_ARCH_32BIT_USTAT_F_TINODE | 
|---|
| 214 | unsigned int		f_tinode; | 
|---|
| 215 | #else | 
|---|
| 216 | unsigned long		f_tinode; | 
|---|
| 217 | #endif | 
|---|
| 218 | char			f_fname[6]; | 
|---|
| 219 | char			f_fpack[6]; | 
|---|
| 220 | }; | 
|---|
| 221 |  | 
|---|
| 222 | /** | 
|---|
| 223 | * struct callback_head - callback structure for use with RCU and task_work | 
|---|
| 224 | * @next: next update requests in a list | 
|---|
| 225 | * @func: actual update function to call after the grace period. | 
|---|
| 226 | * | 
|---|
| 227 | * The struct is aligned to size of pointer. On most architectures it happens | 
|---|
| 228 | * naturally due ABI requirements, but some architectures (like CRIS) have | 
|---|
| 229 | * weird ABI and we need to ask it explicitly. | 
|---|
| 230 | * | 
|---|
| 231 | * The alignment is required to guarantee that bit 0 of @next will be | 
|---|
| 232 | * clear under normal conditions -- as long as we use call_rcu() or | 
|---|
| 233 | * call_srcu() to queue the callback. | 
|---|
| 234 | * | 
|---|
| 235 | * This guarantee is important for few reasons: | 
|---|
| 236 | *  - future call_rcu_lazy() will make use of lower bits in the pointer; | 
|---|
| 237 | *  - the structure shares storage space in struct page with @compound_head, | 
|---|
| 238 | *    which encode PageTail() in bit 0. The guarantee is needed to avoid | 
|---|
| 239 | *    false-positive PageTail(). | 
|---|
| 240 | */ | 
|---|
| 241 | struct callback_head { | 
|---|
| 242 | struct callback_head *next; | 
|---|
| 243 | void (*func)(struct callback_head *head); | 
|---|
| 244 | } __attribute__((aligned(sizeof(void *)))); | 
|---|
| 245 | #define rcu_head callback_head | 
|---|
| 246 |  | 
|---|
| 247 | typedef void (*rcu_callback_t)(struct rcu_head *head); | 
|---|
| 248 | typedef void (*call_rcu_func_t)(struct rcu_head *head, rcu_callback_t func); | 
|---|
| 249 |  | 
|---|
| 250 | typedef void (*swap_r_func_t)(void *a, void *b, int size, const void *priv); | 
|---|
| 251 | typedef void (*swap_func_t)(void *a, void *b, int size); | 
|---|
| 252 |  | 
|---|
| 253 | typedef int (*cmp_r_func_t)(const void *a, const void *b, const void *priv); | 
|---|
| 254 | typedef int (*cmp_func_t)(const void *a, const void *b); | 
|---|
| 255 |  | 
|---|
| 256 | /* | 
|---|
| 257 | * rcuwait provides a way of blocking and waking up a single | 
|---|
| 258 | * task in an rcu-safe manner. | 
|---|
| 259 | * | 
|---|
| 260 | * The only time @task is non-nil is when a user is blocked (or | 
|---|
| 261 | * checking if it needs to) on a condition, and reset as soon as we | 
|---|
| 262 | * know that the condition has succeeded and are awoken. | 
|---|
| 263 | */ | 
|---|
| 264 | struct rcuwait { | 
|---|
| 265 | struct task_struct __rcu *task; | 
|---|
| 266 | }; | 
|---|
| 267 |  | 
|---|
| 268 | #endif /*  __ASSEMBLY__ */ | 
|---|
| 269 | #endif /* _LINUX_TYPES_H */ | 
|---|
| 270 |  | 
|---|