35 #define MAC_ADDR_LEN 6
52 char *mac_addresses_param = (
char *)param;
55 if (sscanf(mac_addresses_param,
"%17s %17s", mac1, mac2) != 2) {
62 "%hhx:%hhx:%hhx:%hhx:%hhx:%hhx",
75 "%hhx:%hhx:%hhx:%hhx:%hhx:%hhx",
96 struct doca_argp_param *mac_addresses_param;
124 int main(
int argc,
char **argv)
127 struct doca_log_backend *sdk_log;
128 int exit_status = EXIT_FAILURE;
132 .port_config.nb_queues = 1,
133 .port_config.nb_hairpin_q = 1,
134 .port_config.enable_mbuf_metadata = 1,
135 .port_config.lpbk_support = 1,
183 goto dpdk_ports_queues_cleanup;
186 exit_status = EXIT_SUCCESS;
188 dpdk_ports_queues_cleanup:
195 if (exit_status == EXIT_SUCCESS)
doca_error_t dpdk_init(int argc, char **argv)
doca_error_t dpdk_queues_and_ports_init(struct application_dpdk_config *app_dpdk_config)
void dpdk_queues_and_ports_fini(struct application_dpdk_config *app_dpdk_config)
static doca_error_t mac_addresses_callback(void *param, void *opaque)
int main(int argc, char **argv)
DOCA_LOG_REGISTER(FLOW_LOOPBACK::MAIN)
doca_error_t register_flow_loopback_params(void)
doca_error_t flow_loopback(int nb_queues, uint8_t mac_addresses[2][6])
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 doca_error_t doca_argp_init(const char *program_name, void *program_config)
Initialize the parser interface.
DOCA_EXPERIMENTAL void doca_argp_set_dpdk_program(doca_argp_dpdk_cb_t callback)
Mark the program as based on DPDK API.
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 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.
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.
struct application_port_config port_config