8typedef signed char int8_t;
11typedef long long int64_t;
12typedef unsigned char uint8_t;
13typedef unsigned short uint16_t;
14typedef unsigned int uint32_t;
15typedef unsigned long long uint64_t;
19#define UINT32_MAX ((uint32_t)0xFFFFFFFF)
32#define UBPF_STACK_SIZE 512
34#define IMMEDIATE(X) (int32_t)X
35#define OFFSET(X) (int16_t)X
36#define POINTER(X) (uint64_t)(X)
38#define READ_ONCE_64(destination, source, offset) \
39 destination = (uint64_t)ReadNoFence64((volatile const long long*)(source + offset))
40#define READ_ONCE_32(destination, source, offset) \
41 destination = (uint32_t)ReadNoFence((volatile const long*)(source + offset))
42#define READ_ONCE_16(destination, source, offset) \
43 destination = (uint16_t)ReadNoFence16((volatile const short*)(source + offset))
44#define READ_ONCE_8(destination, source, offset) \
45 destination = (uint8_t)ReadNoFence8((volatile const char*)(source + offset))
48#define READ_ONCE_S32(destination, source, offset) \
49 destination = (uint64_t)(int64_t)(int32_t)ReadNoFence((volatile const long*)(source + offset))
50#define READ_ONCE_S16(destination, source, offset) \
51 destination = (uint64_t)(int64_t)(int16_t)ReadNoFence16((volatile const short*)(source + offset))
52#define READ_ONCE_S8(destination, source, offset) \
53 destination = (uint64_t)(int64_t)(int8_t)ReadNoFence8((volatile const char*)(source + offset))
55#define WRITE_ONCE_64(destination, source, offset) \
56 WriteNoFence64((volatile long long*)(destination + offset), (long long)source)
57#define WRITE_ONCE_32(destination, source, offset) WriteNoFence((volatile long*)(destination + offset), (long)source)
58#define WRITE_ONCE_16(destination, source, offset) \
59 WriteNoFence16((volatile short*)(destination + offset), (short)source)
60#define WRITE_ONCE_8(destination, source, offset) WriteNoFence8((volatile char*)(destination + offset), (char)source)
63#define htobe16(X) swap16(X)
64#define htobe32(X) swap32(X)
65#define htobe64(X) swap64(X)
72#if !defined(UNREFERENCED_PARAMETER)
73#define UNREFERENCED_PARAMETER(P) (P)
76 typedef uint64_t (*
helper_function_t)(uint64_t, uint64_t, uint64_t, uint64_t, uint64_t,
void*);
207 _Out_
size_t* count);
210 _Out_
size_t* count);
212 _Outptr_result_buffer_maybenull_(*
size)
const uint8_t**
hash,
217 _Out_
size_t* count);
220 _Out_
size_t* count);
232 return value << 8 | value >> 8;
244 return swap16(value >> 16) | ((uint32_t)
swap16(value & ((1 << 16) - 1))) << 16;
256 return swap32(value >> 32) | ((uint64_t)
swap32(value & ((1ull << 32ull) - 1))) << 32;
259#define EBPF_NATIVE_HELPER_FUNCTION_ENTRY_CURRENT_VERSION 1
260#define EBPF_NATIVE_HELPER_FUNCTION_ENTRY_CURRENT_VERSION_SIZE EBPF_SIZE_INCLUDING_FIELD(helper_function_entry_t, name)
261#define EBPF_NATIVE_HELPER_FUNCTION_ENTRY_CURRENT_VERSION_TOTAL_SIZE sizeof(helper_function_entry_t)
262#define EBPF_NATIVE_HELPER_FUNCTION_ENTRY_HEADER \
263 {EBPF_NATIVE_HELPER_FUNCTION_ENTRY_CURRENT_VERSION, \
264 EBPF_NATIVE_HELPER_FUNCTION_ENTRY_CURRENT_VERSION_SIZE, \
265 EBPF_NATIVE_HELPER_FUNCTION_ENTRY_CURRENT_VERSION_TOTAL_SIZE}
267#define EBPF_NATIVE_HELPER_FUNCTION_DATA_CURRENT_VERSION 1
268#define EBPF_NATIVE_HELPER_FUNCTION_DATA_CURRENT_VERSION_SIZE \
269 EBPF_SIZE_INCLUDING_FIELD(helper_function_data_t, tail_call)
270#define EBPF_NATIVE_HELPER_FUNCTION_DATA_CURRENT_VERSION_TOTAL_SIZE sizeof(helper_function_data_t)
271#define EBPF_NATIVE_HELPER_FUNCTION_DATA_HEADER \
272 {EBPF_NATIVE_HELPER_FUNCTION_DATA_CURRENT_VERSION, \
273 EBPF_NATIVE_HELPER_FUNCTION_DATA_CURRENT_VERSION_SIZE, \
274 EBPF_NATIVE_HELPER_FUNCTION_DATA_CURRENT_VERSION_TOTAL_SIZE}
276#define EBPF_NATIVE_MAP_ENTRY_CURRENT_VERSION 1
277#define EBPF_NATIVE_MAP_ENTRY_CURRENT_VERSION_SIZE EBPF_SIZE_INCLUDING_FIELD(map_entry_t, name)
278#define EBPF_NATIVE_MAP_ENTRY_CURRENT_VERSION_TOTAL_SIZE sizeof(map_entry_t)
279#define EBPF_NATIVE_MAP_ENTRY_HEADER \
280 {EBPF_NATIVE_MAP_ENTRY_CURRENT_VERSION, \
281 EBPF_NATIVE_MAP_ENTRY_CURRENT_VERSION_SIZE, \
282 EBPF_NATIVE_MAP_ENTRY_CURRENT_VERSION_TOTAL_SIZE}
284#define EBPF_NATIVE_MAP_DATA_CURRENT_VERSION 1
285#define EBPF_NATIVE_MAP_DATA_CURRENT_VERSION_SIZE EBPF_SIZE_INCLUDING_FIELD(map_data_t, address)
286#define EBPF_NATIVE_MAP_DATA_CURRENT_VERSION_TOTAL_SIZE sizeof(map_data_t)
287#define EBPF_NATIVE_MAP_DATA_HEADER \
288 {EBPF_NATIVE_MAP_DATA_CURRENT_VERSION, \
289 EBPF_NATIVE_MAP_DATA_CURRENT_VERSION_SIZE, \
290 EBPF_NATIVE_MAP_DATA_CURRENT_VERSION_TOTAL_SIZE}
292#define EBPF_NATIVE_PROGRAM_ENTRY_CURRENT_VERSION 1
293#define EBPF_NATIVE_PROGRAM_ENTRY_CURRENT_VERSION_SIZE \
294 EBPF_SIZE_INCLUDING_FIELD(program_entry_t, program_info_hash_type)
295#define EBPF_NATIVE_PROGRAM_ENTRY_CURRENT_VERSION_TOTAL_SIZE sizeof(program_entry_t)
296#define EBPF_NATIVE_PROGRAM_ENTRY_HEADER \
297 {EBPF_NATIVE_PROGRAM_ENTRY_CURRENT_VERSION, \
298 EBPF_NATIVE_PROGRAM_ENTRY_CURRENT_VERSION_SIZE, \
299 EBPF_NATIVE_PROGRAM_ENTRY_CURRENT_VERSION_TOTAL_SIZE}
301#define EBPF_NATIVE_PROGRAM_RUNTIME_CONTEXT_CURRENT_VERSION 1
302#define EBPF_NATIVE_PROGRAM_RUNTIME_CONTEXT_CURRENT_VERSION_SIZE \
303 EBPF_SIZE_INCLUDING_FIELD(program_runtime_context_t, map_data)
304#define EBPF_NATIVE_PROGRAM_RUNTIME_CONTEXT_CURRENT_VERSION_TOTAL_SIZE sizeof(program_runtime_context_t)
305#define EBPF_NATIVE_PROGRAM_RUNTIME_CONTEXT_HEADER \
306 {EBPF_NATIVE_PROGRAM_RUNTIME_CONTEXT_CURRENT_VERSION, \
307 EBPF_NATIVE_PROGRAM_RUNTIME_CONTEXT_CURRENT_VERSION_SIZE, \
308 EBPF_NATIVE_PROGRAM_RUNTIME_CONTEXT_CURRENT_VERSION_TOTAL_SIZE}
310#define EBPF_NATIVE_MAP_INITIAL_VALUES_CURRENT_VERSION 1
311#define EBPF_NATIVE_MAP_INITIAL_VALUES_CURRENT_VERSION_SIZE EBPF_SIZE_INCLUDING_FIELD(map_initial_values_t, values)
312#define EBPF_NATIVE_MAP_INITIAL_VALUES_CURRENT_VERSION_TOTAL_SIZE sizeof(map_initial_values_t)
313#define EBPF_NATIVE_MAP_INITIAL_VALUES_HEADER \
314 {EBPF_NATIVE_MAP_INITIAL_VALUES_CURRENT_VERSION, \
315 EBPF_NATIVE_MAP_INITIAL_VALUES_CURRENT_VERSION_SIZE, \
316 EBPF_NATIVE_MAP_INITIAL_VALUES_CURRENT_VERSION_TOTAL_SIZE}
318#define EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_INFO_CURRENT_VERSION 1
319#define EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_INFO_CURRENT_VERSION_SIZE \
320 EBPF_SIZE_INCLUDING_FIELD(global_variable_section_info_t, initial_data)
321#define EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_INFO_CURRENT_VERSION_TOTAL_SIZE sizeof(global_variable_section_info_t)
322#define EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_INFO_HEADER \
323 {EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_INFO_CURRENT_VERSION, \
324 EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_INFO_CURRENT_VERSION_SIZE, \
325 EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_INFO_CURRENT_VERSION_TOTAL_SIZE}
327#define EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_DATA_CURRENT_VERSION 1
328#define EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_DATA_CURRENT_VERSION_SIZE \
329 EBPF_SIZE_INCLUDING_FIELD(global_variable_section_data_t, address_of_map_value)
330#define EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_DATA_CURRENT_VERSION_TOTAL_SIZE sizeof(global_variable_section_data_t)
331#define EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_DATA_HEADER \
332 {EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_DATA_CURRENT_VERSION, \
333 EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_DATA_CURRENT_VERSION_SIZE, \
334 EBPF_NATIVE_GLOBAL_VARIABLE_SECTION_DATA_CURRENT_VERSION_TOTAL_SIZE}
336#define EBPF_NATIVE_METADATA_TABLE_CURRENT_VERSION 1
337#define EBPF_NATIVE_METADATA_TABLE_CURRENT_VERSION_SIZE EBPF_SIZE_INCLUDING_FIELD(metadata_table_t, map_initial_values)
338#define EBPF_NATIVE_METADATA_TABLE_CURRENT_VERSION_TOTAL_SIZE sizeof(metadata_table_t)
339#define EBPF_NATIVE_METADATA_TABLE_HEADER \
340 {EBPF_NATIVE_METADATA_TABLE_CURRENT_VERSION, \
341 EBPF_NATIVE_METADATA_TABLE_CURRENT_VERSION_SIZE, \
342 EBPF_NATIVE_METADATA_TABLE_CURRENT_VERSION_TOTAL_SIZE}
struct _program_runtime_context program_runtime_context_t
struct _global_variable_section_info global_variable_section_info_t
struct _helper_function_data helper_function_data_t
uint64_t swap64(uint64_t value)
Inline function used to implement the 64 bit EBPF_OP_LE/EBPF_OP_BE instruction.
Definition bpf2c.h:254
uint64_t(* helper_function_t)(uint64_t, uint64_t, uint64_t, uint64_t, uint64_t, void *)
Definition bpf2c.h:76
struct _map_initial_values map_initial_values_t
Map initial values. This structure contains the initial values for a map. The values are used to init...
struct _map_entry map_entry_t
Map entry. This structure contains the address of the map and the map definition. The address is writ...
struct _helper_function_entry helper_function_entry_t
Helper function entry. This structure defines a helper function entry in the metadata table....
uint32_t swap32(uint32_t value)
Inline function used to implement the 32 bit EBPF_OP_LE/EBPF_OP_BE instruction.
Definition bpf2c.h:242
struct _global_variable_section_data global_variable_section_data_t
uint16_t swap16(uint16_t value)
Inline function used to implement the 16 bit EBPF_OP_LE/EBPF_OP_BE instruction.
Definition bpf2c.h:230
struct _program_entry program_entry_t
Program entry. This structure contains the address of the program and additional information about th...
struct _bpf2c_version bpf2c_version_t
Version information for the bpf2c compiler. This structure contains the version information for the b...
struct _metadata_table metadata_table_t
Metadata table for a module. This structure is returned by the module's metadata function,...
struct _map_data map_data_t
This file contains eBPF definitions common to eBPF programs, core execution engine as well as eBPF AP...
GUID ebpf_attach_type_t
Definition ebpf_windows.h:62
GUID ebpf_program_type_t
Definition ebpf_windows.h:61
Version information for the bpf2c compiler. This structure contains the version information for the b...
Definition bpf2c.h:191
uint32_t major
Definition bpf2c.h:192
uint32_t revision
Definition bpf2c.h:194
uint32_t minor
Definition bpf2c.h:193
eBPF Map Definition as it appears in the maps section of an ELF file.
Definition ebpf_structs.h:119
unsigned char * address_of_map_value
Definition bpf2c.h:146
ebpf_native_module_header_t header
Definition bpf2c.h:145
size_t size
Definition bpf2c.h:139
const void * initial_data
Definition bpf2c.h:140
const char * name
Definition bpf2c.h:138
ebpf_native_module_header_t header
Definition bpf2c.h:137
bool tail_call
Definition bpf2c.h:95
helper_function_t address
Definition bpf2c.h:94
ebpf_native_module_header_t header
Definition bpf2c.h:93
Helper function entry. This structure defines a helper function entry in the metadata table....
Definition bpf2c.h:85
const char * name
Definition bpf2c.h:88
uint32_t helper_id
Definition bpf2c.h:87
ebpf_native_module_header_t header
Definition bpf2c.h:86
uintptr_t address
Definition bpf2c.h:118
ebpf_native_module_header_t header
Definition bpf2c.h:117
Map entry. This structure contains the address of the map and the map definition. The address is writ...
Definition bpf2c.h:104
ebpf_map_definition_in_file_t definition
Definition bpf2c.h:111
uint64_t zero_marker[2]
Definition bpf2c.h:108
ebpf_native_module_header_t header
Definition bpf2c.h:110
const char * name
Definition bpf2c.h:112
Map initial values. This structure contains the initial values for a map. The values are used to init...
Definition bpf2c.h:128
const char ** values
Definition bpf2c.h:132
size_t count
Definition bpf2c.h:131
ebpf_native_module_header_t header
Definition bpf2c.h:129
const char * name
Definition bpf2c.h:130
Program entry. This structure contains the address of the program and additional information about th...
Definition bpf2c.h:162
uint16_t helper_count
Number of helper functions used by the program.
Definition bpf2c.h:176
uint64_t zero
Definition bpf2c.h:166
const char * program_info_hash_type
Type of the program info hash.
Definition bpf2c.h:182
uint16_t referenced_map_count
Number of maps referenced by the program.
Definition bpf2c.h:174
const char * program_name
Name of the program.
Definition bpf2c.h:172
size_t bpf_instruction_count
Number of BPF instructions in the program.
Definition bpf2c.h:177
uint64_t(* function)(void *, const program_runtime_context_t *)
Address of the program.
Definition bpf2c.h:169
ebpf_native_module_header_t header
Definition bpf2c.h:168
size_t program_info_hash_length
Length of the program info hash.
Definition bpf2c.h:181
uint16_t * referenced_map_indices
List of map indices referenced by the program.
Definition bpf2c.h:173
ebpf_attach_type_t * expected_attach_type
Expected attach type of the program.
Definition bpf2c.h:179
const char * pe_section_name
Name of the PE section containing the program.
Definition bpf2c.h:170
const uint8_t * program_info_hash
Hash of the program info.
Definition bpf2c.h:180
const char * section_name
Name of the section containing the program.
Definition bpf2c.h:171
ebpf_program_type_t * program_type
Type of the program.
Definition bpf2c.h:178
helper_function_entry_t * helpers
List of helper functions used by the program.
Definition bpf2c.h:175
map_data_t * map_data
Definition bpf2c.h:153
global_variable_section_data_t * global_variable_section_data
Definition bpf2c.h:154
helper_function_data_t * helper_data
Definition bpf2c.h:152
ebpf_native_module_header_t header
Definition bpf2c.h:151