ebpf-for-windows/libs/platform/ebpf_epoch.h

99 строки
2.5 KiB
C

// Copyright (c) Microsoft Corporation
// SPDX-License-Identifier: MIT
#pragma once
#include "ebpf_platform.h"
#ifdef __cplusplus
extern "C"
{
#endif
typedef struct _ebpf_epoch_work_item ebpf_epoch_work_item_t;
/**
* @brief Initialize the eBPF epoch tracking module.
*
* @retval EBPF_SUCCESS The operation was successful.
* @retval EBPF_NO_MEMORY Unable to allocate resources for this
* operation.
*/
ebpf_result_t
ebpf_epoch_initiate();
/**
* @brief Uninitialize the eBPF epoch tracking module.
*
*/
void
ebpf_epoch_terminate();
/**
* @brief Called prior to touching memory with lifetime under epoch control.
* @retval EBPF_SUCCESS The operation was successful.
* @retval EBPF_NO_MEMORY Unable to allocate per-thread
* tracking state.
*/
ebpf_result_t
ebpf_epoch_enter();
/**
* @brief Called after touching memory with lifetime under epoch control.
*/
void
ebpf_epoch_exit();
/**
* @brief Allocate memory under epoch control.
* @param[in] size Size of memory to allocate
* @returns Pointer to memory block allocated, or null on failure.
*/
void*
ebpf_epoch_allocate(size_t size);
/**
* @brief Free memory under epoch control.
* @param[in] memory Allocation to be freed once epoch ends.
*/
void
ebpf_epoch_free(_Frees_ptr_opt_ void* memory);
/**
* @Brief Release any memory that is associated with expired epochs.
*/
void
ebpf_epoch_flush();
/**
* @brief Allocate an epoch work item; a work item that can be scheduled to
* run when the current epoch ends.
*
* @param[in] callback_context Context to pass to the callback function.
* @param[in] callback Callback function to run on epoch end.
* @return Pointer to work item that can be scheduled.
*/
ebpf_epoch_work_item_t*
ebpf_epoch_allocate_work_item(_In_ void* callback_context, _In_ void (*callback)(void* context));
/**
* @brief Schedule a previously allocated work-item to run when the current
* epoch ends.
*
* @param[in] work_item Pointer to work item to run on epoch end.
*/
void
ebpf_epoch_schedule_work_item(_In_ ebpf_epoch_work_item_t* work_item);
/**
* @brief Free an epoch work item.
*
* @param[in] work_item Pointer to work item to free.
*/
void
ebpf_epoch_free_work_item(_Frees_ptr_opt_ ebpf_epoch_work_item_t* work_item);
#ifdef __cplusplus
}
#endif