40 #define USER_MAX_PATH_NAME 255
41 #define MAX_PATH_NAME (USER_MAX_PATH_NAME + 1)
42 #define MAX_BLOCKS (128 + 32)
61 const char *input_path,
62 const char *output_path,
65 uint32_t data_block_count,
66 uint32_t rdnc_block_count,
67 uint32_t *missing_indices,
87 DOCA_LOG_ERR(
"Entered device PCI address exceeding the maximum size of %d",
105 char *
path = (
char *)param;
113 if (access(
path, F_OK) == -1) {
131 char *file = (
char *)param;
173 char *
matrix = (
char *)param;
175 if (strcasecmp(
matrix,
"cauchy") == 0)
177 else if (strcasecmp(
matrix,
"vandermonde") == 0)
199 DOCA_LOG_ERR(
"Data block size should be bigger than 0");
218 DOCA_LOG_ERR(
"Redundancy block size should be bigger than 0");
234 char *ind = (
char *)param;
238 while (*ind !=
'\0') {
239 num = strtol(ind, &ind, 10);
245 DOCA_LOG_ERR(
"Delete block indices count is bigger then max: %d, requested: %ld",
267 const int *num = (
int *)param;
270 DOCA_LOG_ERR(
"Entered number of source doca_buf: %d, valid value must be >= 1", *num);
289 const int *num = (
int *)param;
292 DOCA_LOG_ERR(
"Entered number of destination doca_buf: %d, valid value must be >= 1", *num);
309 struct doca_argp_param *pci_param, *input_path_param, *output_path_param, *do_both_param, *matrix_param,
310 *data_block_count_param, *rdnc_block_count_param, *delete_block_indices_param, *num_src_buf_param,
433 "Indices of data blocks to delete comma separated i.e. 0,3,4 - default: 0");
486 int main(
int argc,
char **argv)
489 int exit_status = EXIT_FAILURE;
491 struct doca_log_backend *sdk_log;
560 exit_status = EXIT_SUCCESS;
565 if (exit_status == EXIT_SUCCESS)
char path[MAX_PATH_LEN+1]
if(bitoffset % 64+bitlength > 64) result|
static doca_error_t input_path_callback(void *param, void *config)
int main(int argc, char **argv)
static doca_error_t matrix_callback(void *param, void *config)
static doca_error_t output_path_callback(void *param, void *config)
static doca_error_t delete_block_indices_callback(void *param, void *config)
static doca_error_t pci_address_callback(void *param, void *config)
doca_error_t ec_recover(const char *pci_addr, const char *input_path, const char *output_path, bool do_both, enum doca_ec_matrix_type matrix_type, uint32_t data_block_count, uint32_t rdnc_block_count, uint32_t *missing_indices, size_t n_missing, int num_src_buf, int num_dst_buf)
static doca_error_t register_ec_params(void)
DOCA_LOG_REGISTER(EC_RECOVER::MAIN)
static doca_error_t rdnc_block_count_callback(void *param, void *config)
#define USER_MAX_PATH_NAME
static doca_error_t do_both_callback(void *param, void *config)
static doca_error_t num_dst_buf_callback(void *param, void *config)
static doca_error_t data_block_count_callback(void *param, void *config)
static doca_error_t num_src_buf_callback(void *param, void *config)
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_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.
#define DOCA_DEVINFO_PCI_ADDR_SIZE
Buffer size to hold PCI BDF format: "XXXX:XX:XX.X". Including a null terminator.
doca_ec_matrix_type
Types of coding matrix used for erasure codes.
@ DOCA_EC_MATRIX_TYPE_VANDERMONDE
@ DOCA_EC_MATRIX_TYPE_CAUCHY
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.
enum doca_ec_matrix_type matrix
uint32_t rdnc_block_count
char output_path[MAX_PATH_NAME]
uint32_t delete_block_indices[MAX_BLOCKS]
char pci_address[DOCA_DEVINFO_PCI_ADDR_SIZE]
char input_path[MAX_PATH_NAME]
uint32_t data_block_count