xref: /aosp_15_r20/external/kernel-headers/original/uapi/linux/stddef.h (revision f80ad8b4341604f5951dab671d41019a6d7087ce)
1*f80ad8b4SAndroid Build Coastguard Worker /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2*f80ad8b4SAndroid Build Coastguard Worker #ifndef _UAPI_LINUX_STDDEF_H
3*f80ad8b4SAndroid Build Coastguard Worker #define _UAPI_LINUX_STDDEF_H
4*f80ad8b4SAndroid Build Coastguard Worker 
5*f80ad8b4SAndroid Build Coastguard Worker #include <linux/compiler_types.h>
6*f80ad8b4SAndroid Build Coastguard Worker 
7*f80ad8b4SAndroid Build Coastguard Worker #ifndef __always_inline
8*f80ad8b4SAndroid Build Coastguard Worker #define __always_inline inline
9*f80ad8b4SAndroid Build Coastguard Worker #endif
10*f80ad8b4SAndroid Build Coastguard Worker 
11*f80ad8b4SAndroid Build Coastguard Worker /**
12*f80ad8b4SAndroid Build Coastguard Worker  * __struct_group() - Create a mirrored named and anonyomous struct
13*f80ad8b4SAndroid Build Coastguard Worker  *
14*f80ad8b4SAndroid Build Coastguard Worker  * @TAG: The tag name for the named sub-struct (usually empty)
15*f80ad8b4SAndroid Build Coastguard Worker  * @NAME: The identifier name of the mirrored sub-struct
16*f80ad8b4SAndroid Build Coastguard Worker  * @ATTRS: Any struct attributes (usually empty)
17*f80ad8b4SAndroid Build Coastguard Worker  * @MEMBERS: The member declarations for the mirrored structs
18*f80ad8b4SAndroid Build Coastguard Worker  *
19*f80ad8b4SAndroid Build Coastguard Worker  * Used to create an anonymous union of two structs with identical layout
20*f80ad8b4SAndroid Build Coastguard Worker  * and size: one anonymous and one named. The former's members can be used
21*f80ad8b4SAndroid Build Coastguard Worker  * normally without sub-struct naming, and the latter can be used to
22*f80ad8b4SAndroid Build Coastguard Worker  * reason about the start, end, and size of the group of struct members.
23*f80ad8b4SAndroid Build Coastguard Worker  * The named struct can also be explicitly tagged for layer reuse, as well
24*f80ad8b4SAndroid Build Coastguard Worker  * as both having struct attributes appended.
25*f80ad8b4SAndroid Build Coastguard Worker  */
26*f80ad8b4SAndroid Build Coastguard Worker #define __struct_group(TAG, NAME, ATTRS, MEMBERS...) \
27*f80ad8b4SAndroid Build Coastguard Worker 	union { \
28*f80ad8b4SAndroid Build Coastguard Worker 		struct { MEMBERS } ATTRS; \
29*f80ad8b4SAndroid Build Coastguard Worker 		struct TAG { MEMBERS } ATTRS NAME; \
30*f80ad8b4SAndroid Build Coastguard Worker 	} ATTRS
31*f80ad8b4SAndroid Build Coastguard Worker 
32*f80ad8b4SAndroid Build Coastguard Worker #ifdef __cplusplus
33*f80ad8b4SAndroid Build Coastguard Worker /* sizeof(struct{}) is 1 in C++, not 0, can't use C version of the macro. */
34*f80ad8b4SAndroid Build Coastguard Worker #define __DECLARE_FLEX_ARRAY(T, member)	\
35*f80ad8b4SAndroid Build Coastguard Worker 	T member[0]
36*f80ad8b4SAndroid Build Coastguard Worker #else
37*f80ad8b4SAndroid Build Coastguard Worker /**
38*f80ad8b4SAndroid Build Coastguard Worker  * __DECLARE_FLEX_ARRAY() - Declare a flexible array usable in a union
39*f80ad8b4SAndroid Build Coastguard Worker  *
40*f80ad8b4SAndroid Build Coastguard Worker  * @TYPE: The type of each flexible array element
41*f80ad8b4SAndroid Build Coastguard Worker  * @NAME: The name of the flexible array member
42*f80ad8b4SAndroid Build Coastguard Worker  *
43*f80ad8b4SAndroid Build Coastguard Worker  * In order to have a flexible array member in a union or alone in a
44*f80ad8b4SAndroid Build Coastguard Worker  * struct, it needs to be wrapped in an anonymous struct with at least 1
45*f80ad8b4SAndroid Build Coastguard Worker  * named member, but that member can be empty.
46*f80ad8b4SAndroid Build Coastguard Worker  */
47*f80ad8b4SAndroid Build Coastguard Worker #define __DECLARE_FLEX_ARRAY(TYPE, NAME)	\
48*f80ad8b4SAndroid Build Coastguard Worker 	struct { \
49*f80ad8b4SAndroid Build Coastguard Worker 		struct { } __empty_ ## NAME; \
50*f80ad8b4SAndroid Build Coastguard Worker 		TYPE NAME[]; \
51*f80ad8b4SAndroid Build Coastguard Worker 	}
52*f80ad8b4SAndroid Build Coastguard Worker #endif
53*f80ad8b4SAndroid Build Coastguard Worker 
54*f80ad8b4SAndroid Build Coastguard Worker #ifndef __counted_by
55*f80ad8b4SAndroid Build Coastguard Worker #define __counted_by(m)
56*f80ad8b4SAndroid Build Coastguard Worker #endif
57*f80ad8b4SAndroid Build Coastguard Worker 
58*f80ad8b4SAndroid Build Coastguard Worker #ifndef __counted_by_le
59*f80ad8b4SAndroid Build Coastguard Worker #define __counted_by_le(m)
60*f80ad8b4SAndroid Build Coastguard Worker #endif
61*f80ad8b4SAndroid Build Coastguard Worker 
62*f80ad8b4SAndroid Build Coastguard Worker #ifndef __counted_by_be
63*f80ad8b4SAndroid Build Coastguard Worker #define __counted_by_be(m)
64*f80ad8b4SAndroid Build Coastguard Worker #endif
65*f80ad8b4SAndroid Build Coastguard Worker 
66*f80ad8b4SAndroid Build Coastguard Worker #endif /* _UAPI_LINUX_STDDEF_H */
67