47 if (signum == SIGINT || signum == SIGTERM) {
48 DOCA_LOG_INFO(
"Signal %d received, preparing to exit", signum);
63 char *mlxdevs_names = (
char *)param;
64 char *current_dev_name;
69 current_dev_name = strtok(mlxdevs_names,
",");
70 if (current_dev_name ==
NULL) {
71 DOCA_LOG_ERR(
"Expected two IB devices names, but none entered");
77 DOCA_LOG_ERR(
"First entered IB device name exceeding the maximum size of %d",
84 current_dev_name = strtok(
NULL,
",");
85 if (current_dev_name ==
NULL) {
86 DOCA_LOG_ERR(
"Expected two IB devices names, but only one entered");
92 DOCA_LOG_ERR(
"Second entered IB device name exceeding the maximum size of %d",
99 current_dev_name = strtok(
NULL,
",");
100 if (current_dev_name !=
NULL) {
106 DOCA_LOG_ERR(
"Identical devices names were provided, please enter different names");
126 DOCA_LOG_ERR(
"Packets receive rate parameter must be a positive value");
148 DOCA_LOG_ERR(
"Max packet size parameter must be a positive value");
170 DOCA_LOG_ERR(
"Packet max process time parameter must be a positive value");
175 DOCA_LOG_ERR(
"Packet max process time parameter can not be larger than %d", UINT16_MAX);
197 DOCA_LOG_ERR(
"Number of task batches parameter must be a positive value");
202 DOCA_LOG_ERR(
"Number of task batches parameter can not be larger than %d", UINT16_MAX);
223 if (*one_sided_fwd < 0 || *one_sided_fwd > 2) {
224 DOCA_LOG_ERR(
"One-sided forwarding parameter must be 0, 1 or 2");
243 int *max_fwds = (
int *)param;
246 DOCA_LOG_ERR(
"Max forwardings parameter must be non-negative");
264 struct doca_argp_param *mlxdevs_names, *pkts_recv_rate, *max_pkt_size, *pkt_max_process_time, *num_task_batches,
265 *one_sided_fwd, *max_fwds;
277 "Set two IB devices names separated by a comma, without spaces.");
370 "Set one-sided forwarding: 0 - two-sided forwarding, 1 - device 1 -> device 2, 2 - device 2 -> device 1. default is 0.");
390 "Set max forwarded packet batches limit after which the application run will end, default is 0, meaning no limit.");
409 int main(
int argc,
char **argv)
417 struct doca_log_backend *sdk_log;
419 int exit_status = EXIT_SUCCESS;
446 exit_status = EXIT_FAILURE;
454 exit_status = EXIT_FAILURE;
469 exit_status = EXIT_FAILURE;
475 DOCA_LOG_ERR(
"Failed to clean up Ethernet L2 Forwarding Application resources: %s",
477 exit_status = EXIT_FAILURE;
DOCA_LOG_REGISTER(ETH_L2_FWD)
static doca_error_t pkt_max_process_time_callback(void *param, void *config)
int main(int argc, char **argv)
static doca_error_t pkts_recv_rate_callback(void *param, void *config)
static doca_error_t num_task_batches_callback(void *param, void *config)
static doca_error_t max_forwardings_callback(void *param, void *config)
static doca_error_t mlxdevs_names_callback(void *param, void *config)
static doca_error_t max_pkt_size_callback(void *param, void *config)
static void signal_handler(int signum)
static doca_error_t register_eth_l2_fwd_params(void)
static doca_error_t one_sided_fwd_callback(void *param, void *config)
doca_error_t eth_l2_fwd_cleanup(struct eth_l2_fwd_resources *state)
doca_error_t eth_l2_fwd_execute(struct eth_l2_fwd_cfg *cfg, struct eth_l2_fwd_resources *state)
void eth_l2_fwd_force_stop(void)
#define ETH_L2_FWD_MAX_PKT_SIZE_DEFAULT
#define ETH_L2_FWD_PKT_MAX_PROCESS_TIME_DEFAULT
#define ETH_L2_FWD_NUM_TASK_BATCHES_DEFAULT
#define ETH_L2_FWD_NUM_TASKS_PER_BATCH
#define ETH_L2_FWD_PKTS_RECV_RATE_DEFAULT
static struct app_gpu_cfg app_cfg
DOCA_EXPERIMENTAL void doca_argp_param_set_description(struct doca_argp_param *param, const char *description)
Set the description of the program param, used during program usage.
DOCA_EXPERIMENTAL void doca_argp_param_set_long_name(struct doca_argp_param *param, const char *name)
Set the long name of the program param.
DOCA_EXPERIMENTAL doca_error_t doca_argp_start(int argc, char **argv)
Parse incoming arguments (cmd line/json).
DOCA_EXPERIMENTAL void doca_argp_param_set_arguments(struct doca_argp_param *param, const char *arguments)
Set the description of the expected arguments of the program param, used during program usage.
DOCA_EXPERIMENTAL doca_error_t doca_argp_init(const char *program_name, void *program_config)
Initialize the parser interface.
DOCA_EXPERIMENTAL void doca_argp_param_set_callback(struct doca_argp_param *param, doca_argp_param_cb_t callback)
Set the callback function of the program param.
DOCA_EXPERIMENTAL void doca_argp_param_set_mandatory(struct doca_argp_param *param)
Mark the program param as mandatory.
DOCA_EXPERIMENTAL doca_error_t doca_argp_param_create(struct doca_argp_param **param)
Create new program param.
DOCA_EXPERIMENTAL void doca_argp_param_set_type(struct doca_argp_param *param, enum doca_argp_type type)
Set the type of the param arguments.
DOCA_EXPERIMENTAL void doca_argp_param_set_short_name(struct doca_argp_param *param, const char *name)
Set the short name of the program param.
DOCA_EXPERIMENTAL doca_error_t doca_argp_destroy(void)
ARG Parser destroy.
DOCA_EXPERIMENTAL doca_error_t doca_argp_register_param(struct doca_argp_param *input_param)
Register a program flag.
#define DOCA_DEVINFO_IBDEV_NAME_SIZE
Buffer size to hold Infiniband/RoCE device name. Including a null terminator.
enum doca_error doca_error_t
DOCA API return codes.
DOCA_STABLE const char * doca_error_get_descr(doca_error_t error)
Returns the description string of an error code.
@ DOCA_ERROR_INVALID_VALUE
DOCA_EXPERIMENTAL doca_error_t doca_log_backend_create_standard(void)
Create default, non configurable backend for application messages.
#define DOCA_LOG_ERR(format,...)
Generates an ERROR application log message.
#define DOCA_LOG_INFO(format,...)
Generates an INFO application log message.
DOCA_EXPERIMENTAL doca_error_t doca_log_backend_create_with_file_sdk(FILE *fptr, struct doca_log_backend **backend)
Create a logging backend with a FILE* stream for SDK messages.
DOCA_EXPERIMENTAL doca_error_t doca_log_backend_set_sdk_level(struct doca_log_backend *backend, uint32_t level)
Set the log level limit for SDK logging backends.
uint16_t num_task_batches
uint16_t pkt_max_process_time
size_t strlcpy(char *dst, const char *src, size_t size)