numam-dpdk/lib/librte_pipeline/rte_swx_extern.h
Cristian Dumitrescu 1e4c88caea pipeline: add SWX extern objects and funcs
Add extern objects and functions to plug into the SWX pipeline any
functionality that cannot be efficiently implemented with existing
instructions, e.g. special checksum/ECC, crypto, meters, stats arrays,
heuristics, etc. In/out arguments are passed through mailbox with
format defined by struct.

Signed-off-by: Cristian Dumitrescu <cristian.dumitrescu@intel.com>
2020-10-01 18:43:07 +02:00

99 lines
2.7 KiB
C

/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(c) 2020 Intel Corporation
*/
#ifndef __INCLUDE_RTE_SWX_EXTERN_H__
#define __INCLUDE_RTE_SWX_EXTERN_H__
#ifdef __cplusplus
extern "C" {
#endif
/**
* @file
* RTE SWX Extern objects and functions
*
* Extern object and extern function interfaces. The extern objects and extern
* functions provide the mechanisms to hook external functionality into the
* packet processing pipeline.
*/
#include <stdint.h>
/*
* Extern type
*/
/**
* Extern object constructor
*
* @param[in] args
* Extern object constructor arguments. It may be NULL.
* @return
* Extern object handle.
*/
typedef void *
(*rte_swx_extern_type_constructor_t)(const char *args);
/**
* Extern object destructor
*
* @param[in] object
* Extern object handle.
*/
typedef void
(*rte_swx_extern_type_destructor_t)(void *object);
/**
* Extern object member function
*
* The mailbox is used to pass input arguments to the member function and
* retrieve the output results. The mailbox mechanism allows for multiple
* concurrent executions of the same member function for the same extern object.
*
* Multiple invocations of the same member function may be required in order for
* the associated operation to complete. The completion is flagged by a return
* value of 1, in which case the results are available in the mailbox; in case
* of a return value of 0, the operation is not yet completed, so the member
* function must be invoked again with exactly the same object and mailbox
* arguments.
*
* @param[in] object
* Extern object handle.
* @param[in] mailbox
* Extern object mailbox.
* @return
* 0 when the operation is not yet completed, and 1 when the operation is
* completed. No other return values are allowed.
*/
typedef int
(*rte_swx_extern_type_member_func_t)(void *object, void *mailbox);
/*
* Extern function
*/
/** The mailbox is used to pass input arguments to the extern function and
* retrieve the output results. The mailbox mechanism allows for multiple
* concurrent executions of the same extern function.
*
* Multiple invocations of the same extern function may be required in order for
* the associated operation to complete. The completion is flagged by a return
* value of 1, in which case the results are available in the mailbox; in case
* of a return value of 0, the operation is not yet completed, so the extern
* function must be invoked again with exactly the same mailbox argument.
*
* @param[in] mailbox
* Extern object mailbox.
* @return
* 0 when the operation is not yet completed, and 1 when the operation is
* completed. No other return values are allowed.
*/
typedef int
(*rte_swx_extern_func_t)(void *mailbox);
#ifdef __cplusplus
}
#endif
#endif