5#define EBPF_OFFSET_OF(s, m) (((size_t) & ((s*)0)->m))
6#define EBPF_FIELD_SIZE(s, m) (sizeof(((s*)0)->m))
7#define EBPF_SIZE_INCLUDING_FIELD(s, m) (EBPF_OFFSET_OF(s, m) + EBPF_FIELD_SIZE(s, m))
15#if !defined(NO_CRT) && !defined(_NO_CRT_STDIO_INLINE)
20typedef unsigned char uint8_t;
21typedef unsigned short uint16_t;
22typedef unsigned short wchar_t;
23typedef unsigned int uint32_t;
24typedef unsigned long long uint64_t;
25typedef unsigned long long size_t;
32#define EBPF_ROOT_REGISTRY_PATH L"\\Registry\\Machine\\Software\\eBPF"
33#define EBPF_ROOT_RELATIVE_PATH L"Software\\eBPF"
34#define EBPF_STORE_REGISTRY_PATH L"Software\\eBPF\\Providers"
36#define EBPF_PROVIDERS_REGISTRY_KEY L"Providers"
37#define EBPF_SECTIONS_REGISTRY_KEY L"SectionData"
38#define EBPF_PROGRAM_DATA_REGISTRY_KEY L"ProgramData"
39#define EBPF_PROGRAM_TYPE_DESCRIPTOR_REGISTRY_KEY L"TypeDescriptor"
40#define EBPF_PROGRAM_DATA_HELPERS_REGISTRY_KEY L"Helpers"
41#define EBPF_GLOBAL_HELPERS_REGISTRY_KEY L"GlobalHelpers"
43#define EBPF_EXTENSION_HEADER_VERSION L"Version"
44#define EBPF_EXTENSION_HEADER_SIZE L"Size"
46#define EBPF_SECTION_DATA_PROGRAM_TYPE L"ProgramType"
47#define EBPF_SECTION_DATA_ATTACH_TYPE L"AttachType"
49#define EBPF_PROGRAM_DATA_NAME L"Name"
50#define EBPF_PROGRAM_DATA_CONTEXT_DESCRIPTOR L"ContextDescriptor"
51#define EBPF_PROGRAM_DATA_PLATFORM_SPECIFIC_DATA L"PlatformSpecificData"
52#define EBPF_PROGRAM_DATA_PRIVILEGED L"IsPrivileged"
53#define EBPF_PROGRAM_DATA_HELPER_COUNT L"HelperCount"
55#define EBPF_HELPER_DATA_PROTOTYPE L"Prototype"
56#define EBPF_HELPER_DATA_REALLOCATE_PACKET L"ReallocatePacket"
58#define EBPF_DATA_BPF_PROG_TYPE L"BpfProgType"
59#define EBPF_DATA_BPF_ATTACH_TYPE L"BpfAttachType"
71#define EBPF_MAX_GENERAL_HELPER_FUNCTION 0xFFFF
73#define EBPF_ATTACH_CLIENT_DATA_CURRENT_VERSION 1
75#define EBPF_ATTACH_CLIENT_DATA_VERSION_SIZE EBPF_SIZE_INCLUDING_FIELD(ebpf_extension_data_t, prog_attach_flags)
76#define EBPF_ATTACH_CLIENT_DATA_VERSION_TOTAL_SIZE sizeof(ebpf_extension_data_t)
77#define EBPF_ATTACH_CLIENT_DATA_HEADER_VERSION \
78 {EBPF_ATTACH_CLIENT_DATA_CURRENT_VERSION, \
79 EBPF_ATTACH_CLIENT_DATA_VERSION_SIZE, \
80 EBPF_ATTACH_CLIENT_DATA_VERSION_TOTAL_SIZE}
83#define EBPF_ATTACH_PROVIDER_DATA_CURRENT_VERSION 1
84#define EBPF_ATTACH_PROVIDER_DATA_CURRENT_VERSION_SIZE EBPF_SIZE_INCLUDING_FIELD(ebpf_attach_provider_data_t, link_type)
85#define EBPF_ATTACH_PROVIDER_DATA_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_attach_provider_data_t)
86#define EBPF_ATTACH_PROVIDER_DATA_HEADER \
87 {EBPF_ATTACH_PROVIDER_DATA_CURRENT_VERSION, \
88 EBPF_ATTACH_PROVIDER_DATA_CURRENT_VERSION_SIZE, \
89 EBPF_ATTACH_PROVIDER_DATA_CURRENT_VERSION_TOTAL_SIZE}
91#define EBPF_PROGRAM_TYPE_DESCRIPTOR_CURRENT_VERSION 1
92#define EBPF_PROGRAM_TYPE_DESCRIPTOR_CURRENT_VERSION_SIZE \
93 EBPF_SIZE_INCLUDING_FIELD(ebpf_program_type_descriptor_t, is_privileged)
94#define EBPF_PROGRAM_TYPE_DESCRIPTOR_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_program_type_descriptor_t)
95#define EBPF_PROGRAM_TYPE_DESCRIPTOR_HEADER \
96 {EBPF_PROGRAM_TYPE_DESCRIPTOR_CURRENT_VERSION, \
97 EBPF_PROGRAM_TYPE_DESCRIPTOR_CURRENT_VERSION_SIZE, \
98 EBPF_PROGRAM_TYPE_DESCRIPTOR_CURRENT_VERSION_TOTAL_SIZE}
100#define EBPF_HELPER_FUNCTION_PROTOTYPE_CURRENT_VERSION 1
101#define EBPF_HELPER_FUNCTION_PROTOTYPE_CURRENT_VERSION_SIZE \
102 EBPF_SIZE_INCLUDING_FIELD(ebpf_helper_function_prototype_t, implicit_context)
103#define EBPF_HELPER_FUNCTION_PROTOTYPE_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_helper_function_prototype_t)
104#define EBPF_HELPER_FUNCTION_PROTOTYPE_HEADER \
105 {EBPF_HELPER_FUNCTION_PROTOTYPE_CURRENT_VERSION, \
106 EBPF_HELPER_FUNCTION_PROTOTYPE_CURRENT_VERSION_SIZE, \
107 EBPF_HELPER_FUNCTION_PROTOTYPE_CURRENT_VERSION_TOTAL_SIZE}
109#define EBPF_PROGRAM_INFORMATION_CURRENT_VERSION 1
110#define EBPF_PROGRAM_INFORMATION_CURRENT_VERSION_SIZE \
111 EBPF_SIZE_INCLUDING_FIELD(ebpf_program_info_t, global_helper_prototype)
112#define EBPF_PROGRAM_INFORMATION_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_program_info_t)
113#define EBPF_PROGRAM_INFORMATION_HEADER \
114 {EBPF_PROGRAM_INFORMATION_CURRENT_VERSION, \
115 EBPF_PROGRAM_INFORMATION_CURRENT_VERSION_SIZE, \
116 EBPF_PROGRAM_INFORMATION_CURRENT_VERSION_TOTAL_SIZE}
118#define EBPF_HELPER_FUNCTION_ADDRESSES_CURRENT_VERSION 1
119#define EBPF_HELPER_FUNCTION_ADDRESSES_CURRENT_VERSION_SIZE \
120 EBPF_SIZE_INCLUDING_FIELD(ebpf_helper_function_addresses_t, helper_function_address)
121#define EBPF_HELPER_FUNCTION_ADDRESSES_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_helper_function_addresses_t)
122#define EBPF_HELPER_FUNCTION_ADDRESSES_HEADER \
123 {EBPF_HELPER_FUNCTION_ADDRESSES_CURRENT_VERSION, \
124 EBPF_HELPER_FUNCTION_ADDRESSES_CURRENT_VERSION_SIZE, \
125 EBPF_HELPER_FUNCTION_ADDRESSES_CURRENT_VERSION_TOTAL_SIZE}
127#define EBPF_PROGRAM_DATA_CURRENT_VERSION 1
128#define EBPF_PROGRAM_DATA_CURRENT_VERSION_SIZE EBPF_SIZE_INCLUDING_FIELD(ebpf_program_data_t, capabilities)
129#define EBPF_PROGRAM_DATA_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_program_data_t)
130#define EBPF_PROGRAM_DATA_HEADER \
131 {EBPF_PROGRAM_DATA_CURRENT_VERSION, \
132 EBPF_PROGRAM_DATA_CURRENT_VERSION_SIZE, \
133 EBPF_PROGRAM_DATA_CURRENT_VERSION_TOTAL_SIZE}
135#define EBPF_PROGRAM_SECTION_INFORMATION_CURRENT_VERSION 1
136#define EBPF_PROGRAM_SECTION_INFORMATION_CURRENT_VERSION_SIZE \
137 EBPF_SIZE_INCLUDING_FIELD(ebpf_program_section_info_t, bpf_attach_type)
138#define EBPF_PROGRAM_SECTION_INFORMATION_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_program_section_info_t)
139#define EBPF_PROGRAM_SECTION_INFORMATION_HEADER \
140 {EBPF_PROGRAM_SECTION_INFORMATION_CURRENT_VERSION, \
141 EBPF_PROGRAM_SECTION_INFORMATION_CURRENT_VERSION_SIZE, \
142 EBPF_PROGRAM_SECTION_INFORMATION_CURRENT_VERSION_TOTAL_SIZE}
144#define EBPF_MAP_PROVIDER_DATA_CURRENT_VERSION 1
145#define EBPF_MAP_PROVIDER_DATA_CURRENT_VERSION_SIZE \
146 EBPF_SIZE_INCLUDING_FIELD(ebpf_map_provider_data_t, base_provider_table)
147#define EBPF_MAP_PROVIDER_DATA_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_map_provider_data_t)
148#define EBPF_MAP_PROVIDER_DATA_HEADER \
149 {EBPF_MAP_PROVIDER_DATA_CURRENT_VERSION, \
150 EBPF_MAP_PROVIDER_DATA_CURRENT_VERSION_SIZE, \
151 EBPF_MAP_PROVIDER_DATA_CURRENT_VERSION_TOTAL_SIZE}
153#define EBPF_MAP_CLIENT_DATA_CURRENT_VERSION 1
154#define EBPF_MAP_CLIENT_DATA_CURRENT_VERSION_SIZE EBPF_SIZE_INCLUDING_FIELD(ebpf_map_client_data_t, base_client_table)
155#define EBPF_MAP_CLIENT_DATA_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_map_client_data_t)
156#define EBPF_MAP_CLIENT_DATA_HEADER \
157 {EBPF_MAP_CLIENT_DATA_CURRENT_VERSION, \
158 EBPF_MAP_CLIENT_DATA_CURRENT_VERSION_SIZE, \
159 EBPF_MAP_CLIENT_DATA_CURRENT_VERSION_TOTAL_SIZE}
161#define EBPF_BASE_MAP_PROVIDER_DISPATCH_TABLE_CURRENT_VERSION 1
162#define EBPF_BASE_MAP_PROVIDER_DISPATCH_TABLE_CURRENT_VERSION_SIZE \
163 EBPF_SIZE_INCLUDING_FIELD(ebpf_base_map_provider_dispatch_table_t, process_map_delete_element)
164#define EBPF_BASE_MAP_PROVIDER_DISPATCH_TABLE_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_base_map_provider_dispatch_table_t)
165#define EBPF_BASE_MAP_PROVIDER_DISPATCH_TABLE_HEADER \
166 {EBPF_BASE_MAP_PROVIDER_DISPATCH_TABLE_CURRENT_VERSION, \
167 EBPF_BASE_MAP_PROVIDER_DISPATCH_TABLE_CURRENT_VERSION_SIZE, \
168 EBPF_BASE_MAP_PROVIDER_DISPATCH_TABLE_CURRENT_VERSION_TOTAL_SIZE}
170#define EBPF_BASE_MAP_PROVIDER_PROPERTIES_CURRENT_VERSION 1
171#define EBPF_BASE_MAP_PROVIDER_PROPERTIES_CURRENT_VERSION_SIZE \
172 EBPF_SIZE_INCLUDING_FIELD(ebpf_base_map_provider_properties_t, updates_original_value)
173#define EBPF_BASE_MAP_PROVIDER_PROPERTIES_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_base_map_provider_properties_t)
174#define EBPF_BASE_MAP_PROVIDER_PROPERTIES_HEADER \
175 {EBPF_BASE_MAP_PROVIDER_PROPERTIES_CURRENT_VERSION, \
176 EBPF_BASE_MAP_PROVIDER_PROPERTIES_CURRENT_VERSION_SIZE, \
177 EBPF_BASE_MAP_PROVIDER_PROPERTIES_CURRENT_VERSION_TOTAL_SIZE}
179#define EBPF_BASE_MAP_CLIENT_DISPATCH_TABLE_CURRENT_VERSION 1
180#define EBPF_BASE_MAP_CLIENT_DISPATCH_TABLE_CURRENT_VERSION_SIZE \
181 EBPF_SIZE_INCLUDING_FIELD(ebpf_base_map_client_dispatch_table_t, epoch_free_cache_aligned)
182#define EBPF_BASE_MAP_CLIENT_DISPATCH_TABLE_CURRENT_VERSION_TOTAL_SIZE sizeof(ebpf_base_map_client_dispatch_table_t)
183#define EBPF_BASE_MAP_CLIENT_DISPATCH_TABLE_HEADER \
184 {EBPF_BASE_MAP_CLIENT_DISPATCH_TABLE_CURRENT_VERSION, \
185 EBPF_BASE_MAP_CLIENT_DISPATCH_TABLE_CURRENT_VERSION_SIZE, \
186 EBPF_BASE_MAP_CLIENT_DISPATCH_TABLE_CURRENT_VERSION_TOTAL_SIZE}
GUID ebpf_attach_type_t
Definition ebpf_windows.h:62
_ebpf_helper_function
Definition ebpf_windows.h:65
@ EBPF_LOOKUP_ELEMENT
Look up a map element.
Definition ebpf_windows.h:66
@ EBPF_DELETE_ELEMENT
Delete a map element.
Definition ebpf_windows.h:68
@ EBPF_UPDATE_ELEMENT
Update map element.
Definition ebpf_windows.h:67
struct _ebpf_extension_header ebpf_extension_header_t
Header of an eBPF extension data structure. Every eBPF extension data structure must start with this ...
GUID ebpf_program_type_t
Definition ebpf_windows.h:61
uint8_t GUID[16]
Definition ebpf_windows.h:12
enum _ebpf_helper_function ebpf_helper_function_t