31 #include "rdma_common.h"
50 DOCA_LOG_ERR(
"Entered IB device name exceeding the maximum size of %d",
72 DOCA_LOG_ERR(
"GID index for DOCA RDMA must be non-negative");
92 char *pci_address = (
char *)param;
121 DOCA_LOG_ERR(
"Entered IB device name exceeding the maximum size of %d",
158 const int cm_port = *(uint32_t *)param;
161 DOCA_LOG_ERR(
"Server listening port number for DOCA RDMA-CM must be non-negative");
180 const char *
addr = (
char *)param;
204 const char *
type = (
char *)param;
212 if (strcasecmp(
type,
"ip4") == 0 || strcasecmp(
type,
"ipv4") == 0)
214 else if (strcasecmp(
type,
"ip6") == 0 || strcasecmp(
type,
"ipv6") == 0)
216 else if (strcasecmp(
type,
"gid") == 0)
219 DOCA_LOG_ERR(
"Entered wrong server address type, the accepted server address type are: "
220 "ip4, ipv4, IP4, IPv4, IPV4, "
221 "ip6, ipv6, IP6, IPv6, IPV6, "
237 struct doca_argp_param *client_param;
238 struct doca_argp_param *device_param;
239 struct doca_argp_param *gid_index_param;
240 struct doca_argp_param *gpu_param;
241 struct doca_argp_param *use_rdma_cm_param;
242 struct doca_argp_param *cm_port_param;
243 struct doca_argp_param *cm_addr_param;
244 struct doca_argp_param *cm_addr_type_param;
364 "RDMA cm server device address, required only when using rdma_cm");
384 "RDMA cm server device address type: IPv4, IPv6 or GID, required only when using rdma_cm");
404 if (
cfg->use_rdma_cm) {
405 if (
cfg->is_server) {
406 if (
cfg->cm_addr[0] !=
'\0') {
408 "Invalid input: when using CM, only client needs to provide the server cm_addr");
412 if (
cfg->cm_addr[0] ==
'\0') {
413 DOCA_LOG_ERR(
"Invalid input: when using CM, client must provide the server cm_addr");
418 if (
cfg->cm_addr[0] !=
'\0') {
419 DOCA_LOG_ERR(
"Invalid input: server cm_addr is needed only in case of RDMA CM");
434 int main(
int argc,
char **argv)
438 struct doca_log_backend *sdk_log;
439 int exit_status = EXIT_FAILURE;
442 cfg.is_server =
true;
446 cfg.use_rdma_cm =
false;
506 exit_status = EXIT_SUCCESS;
511 if (exit_status == EXIT_SUCCESS)
#define SERVER_ADDR_TYPE_LEN
static doca_error_t client_param_callback(void *param, void *config)
DOCA_LOG_REGISTER(GPURDMA_WRITE_REQUESTER::MAIN)
int main(int argc, char **argv)
static doca_error_t register_rdma_params(void)
static doca_error_t cm_addr_type_param_callback(void *param, void *config)
static doca_error_t device_address_callback(void *param, void *config)
static doca_error_t verify_cm_params(struct rdma_config *cfg)
static doca_error_t gid_index_callback(void *param, void *config)
static doca_error_t use_rdma_cm_param_callback(void *param, void *config)
static doca_error_t cm_addr_param_callback(void *param, void *config)
static doca_error_t cm_port_param_callback(void *param, void *config)
static doca_error_t gpu_pci_address_callback(void *param, void *config)
doca_error_t rdma_write_client(struct rdma_config *cfg)
doca_error_t rdma_write_server(struct rdma_config *cfg)
#define MAX_PCI_ADDRESS_LEN
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.
@ DOCA_RDMA_ADDR_TYPE_IPv6
@ DOCA_RDMA_ADDR_TYPE_IPv4
@ DOCA_RDMA_ADDR_TYPE_GID
const struct ip_frag_config * cfg
enum doca_rdma_addr_type cm_addr_type
char device_name[DOCA_DEVINFO_IBDEV_NAME_SIZE]
char cm_addr[SERVER_ADDR_LEN+1]
char gpu_pcie_addr[MAX_PCI_ADDRESS_LEN]
char server_ip_addr[MAX_IP_ADDRESS_LEN]