crypto/octeontx2: check cpt kernel driver version
[dpdk.git] / drivers / crypto / scheduler / scheduler_pmd.c
index ac9185e..6321978 100644 (file)
 #include "rte_cryptodev_scheduler.h"
 #include "scheduler_pmd_private.h"
 
-uint8_t cryptodev_driver_id;
+uint8_t cryptodev_scheduler_driver_id;
 
 struct scheduler_init_params {
        struct rte_cryptodev_pmd_init_params def_p;
-       uint32_t nb_slaves;
+       uint32_t nb_workers;
        enum rte_cryptodev_scheduler_mode mode;
        char mode_param_str[RTE_CRYPTODEV_SCHEDULER_NAME_MAX_LEN];
        uint32_t enable_ordering;
        uint16_t wc_pool[RTE_MAX_LCORE];
        uint16_t nb_wc;
-       char slave_names[RTE_CRYPTODEV_SCHEDULER_MAX_NB_SLAVES]
+       char worker_names[RTE_CRYPTODEV_SCHEDULER_MAX_NB_WORKERS]
                        [RTE_CRYPTODEV_SCHEDULER_NAME_MAX_LEN];
 };
 
 #define RTE_CRYPTODEV_VDEV_NAME                        ("name")
-#define RTE_CRYPTODEV_VDEV_SLAVE               ("slave")
+#define RTE_CRYPTODEV_VDEV_WORKER              ("worker")
 #define RTE_CRYPTODEV_VDEV_MODE                        ("mode")
 #define RTE_CRYPTODEV_VDEV_MODE_PARAM          ("mode_param")
 #define RTE_CRYPTODEV_VDEV_ORDERING            ("ordering")
@@ -38,9 +38,9 @@ struct scheduler_init_params {
 #define RTE_CRYPTODEV_VDEV_COREMASK            ("coremask")
 #define RTE_CRYPTODEV_VDEV_CORELIST            ("corelist")
 
-const char *scheduler_valid_params[] = {
+static const char * const scheduler_valid_params[] = {
        RTE_CRYPTODEV_VDEV_NAME,
-       RTE_CRYPTODEV_VDEV_SLAVE,
+       RTE_CRYPTODEV_VDEV_WORKER,
        RTE_CRYPTODEV_VDEV_MODE,
        RTE_CRYPTODEV_VDEV_MODE_PARAM,
        RTE_CRYPTODEV_VDEV_ORDERING,
@@ -71,6 +71,8 @@ const struct scheduler_parse_map scheduler_ordering_map[] = {
                {"disable", 0}
 };
 
+#define CDEV_SCHED_MODE_PARAM_SEP_CHAR         ':'
+
 static int
 cryptodev_scheduler_create(const char *name,
                struct rte_vdev_device *vdev,
@@ -89,7 +91,7 @@ cryptodev_scheduler_create(const char *name,
                return -EFAULT;
        }
 
-       dev->driver_id = cryptodev_driver_id;
+       dev->driver_id = cryptodev_scheduler_driver_id;
        dev->dev_ops = rte_crypto_scheduler_pmd_ops;
 
        sched_ctx = dev->data->dev_private;
@@ -110,6 +112,15 @@ cryptodev_scheduler_create(const char *name,
 
        if (init_params->mode > CDEV_SCHED_MODE_USERDEFINED &&
                        init_params->mode < CDEV_SCHED_MODE_COUNT) {
+               union {
+                       struct rte_cryptodev_scheduler_threshold_option
+                                       threshold_option;
+               } option;
+               enum rte_cryptodev_schedule_option_type option_type;
+               char param_name[RTE_CRYPTODEV_SCHEDULER_NAME_MAX_LEN] = {0};
+               char param_val[RTE_CRYPTODEV_SCHEDULER_NAME_MAX_LEN] = {0};
+               char *s, *end;
+
                ret = rte_cryptodev_scheduler_mode_set(dev->data->dev_id,
                        init_params->mode);
                if (ret < 0) {
@@ -125,6 +136,48 @@ cryptodev_scheduler_create(const char *name,
                                        scheduler_mode_map[i].name);
                        break;
                }
+
+               if (strlen(init_params->mode_param_str) > 0) {
+                       s = strchr(init_params->mode_param_str,
+                                       CDEV_SCHED_MODE_PARAM_SEP_CHAR);
+                       if (s == NULL) {
+                               CR_SCHED_LOG(ERR, "Invalid mode param");
+                               return -EINVAL;
+                       }
+
+                       strlcpy(param_name, init_params->mode_param_str,
+                                       s - init_params->mode_param_str + 1);
+                       s++;
+                       strlcpy(param_val, s,
+                                       RTE_CRYPTODEV_SCHEDULER_NAME_MAX_LEN);
+
+                       switch (init_params->mode) {
+                       case CDEV_SCHED_MODE_PKT_SIZE_DISTR:
+                               if (strcmp(param_name,
+                                       RTE_CRYPTODEV_SCHEDULER_PARAM_THRES)
+                                               != 0) {
+                                       CR_SCHED_LOG(ERR, "Invalid mode param");
+                                       return -EINVAL;
+                               }
+                               option_type = CDEV_SCHED_OPTION_THRESHOLD;
+
+                               option.threshold_option.threshold =
+                                               strtoul(param_val, &end, 0);
+                               break;
+                       default:
+                               CR_SCHED_LOG(ERR, "Invalid mode param");
+                               return -EINVAL;
+                       }
+
+                       if (sched_ctx->ops.option_set(dev, option_type,
+                                       (void *)&option) < 0) {
+                               CR_SCHED_LOG(ERR, "Invalid mode param");
+                               return -EINVAL;
+                       }
+
+                       RTE_LOG(INFO, PMD, "  Sched mode param (%s = %s)\n",
+                                       param_name, param_val);
+               }
        }
 
        sched_ctx->reordering_enabled = init_params->enable_ordering;
@@ -140,31 +193,31 @@ cryptodev_scheduler_create(const char *name,
                break;
        }
 
-       for (i = 0; i < init_params->nb_slaves; i++) {
-               sched_ctx->init_slave_names[sched_ctx->nb_init_slaves] =
+       for (i = 0; i < init_params->nb_workers; i++) {
+               sched_ctx->init_worker_names[sched_ctx->nb_init_workers] =
                        rte_zmalloc_socket(
                                NULL,
                                RTE_CRYPTODEV_SCHEDULER_NAME_MAX_LEN, 0,
                                SOCKET_ID_ANY);
 
-               if (!sched_ctx->init_slave_names[
-                               sched_ctx->nb_init_slaves]) {
+               if (!sched_ctx->init_worker_names[
+                               sched_ctx->nb_init_workers]) {
                        CR_SCHED_LOG(ERR, "driver %s: Insufficient memory",
                                        name);
                        return -ENOMEM;
                }
 
-               strncpy(sched_ctx->init_slave_names[
-                                       sched_ctx->nb_init_slaves],
-                               init_params->slave_names[i],
+               strncpy(sched_ctx->init_worker_names[
+                                       sched_ctx->nb_init_workers],
+                               init_params->worker_names[i],
                                RTE_CRYPTODEV_SCHEDULER_NAME_MAX_LEN - 1);
 
-               sched_ctx->nb_init_slaves++;
+               sched_ctx->nb_init_workers++;
        }
 
        /*
         * Initialize capabilities structure as an empty structure,
-        * in case device information is requested when no slaves are attached
+        * in case device information is requested when no workers are attached
         */
        sched_ctx->capabilities = rte_zmalloc_socket(NULL,
                        sizeof(struct rte_cryptodev_capabilities),
@@ -196,12 +249,12 @@ cryptodev_scheduler_remove(struct rte_vdev_device *vdev)
 
        sched_ctx = dev->data->dev_private;
 
-       if (sched_ctx->nb_slaves) {
+       if (sched_ctx->nb_workers) {
                uint32_t i;
 
-               for (i = 0; i < sched_ctx->nb_slaves; i++)
-                       rte_cryptodev_scheduler_slave_detach(dev->data->dev_id,
-                                       sched_ctx->slaves[i].dev_id);
+               for (i = 0; i < sched_ctx->nb_workers; i++)
+                       rte_cryptodev_scheduler_worker_detach(dev->data->dev_id,
+                                       sched_ctx->workers[i].dev_id);
        }
 
        return rte_cryptodev_pmd_destroy(dev);
@@ -316,24 +369,24 @@ parse_name_arg(const char *key __rte_unused,
                return -EINVAL;
        }
 
-       strncpy(params->name, value, RTE_CRYPTODEV_NAME_MAX_LEN);
+       strlcpy(params->name, value, RTE_CRYPTODEV_NAME_MAX_LEN);
 
        return 0;
 }
 
-/** Parse slave */
+/** Parse worker */
 static int
-parse_slave_arg(const char *key __rte_unused,
+parse_worker_arg(const char *key __rte_unused,
                const char *value, void *extra_args)
 {
        struct scheduler_init_params *param = extra_args;
 
-       if (param->nb_slaves >= RTE_CRYPTODEV_SCHEDULER_MAX_NB_SLAVES) {
-               CR_SCHED_LOG(ERR, "Too many slaves.");
+       if (param->nb_workers >= RTE_CRYPTODEV_SCHEDULER_MAX_NB_WORKERS) {
+               CR_SCHED_LOG(ERR, "Too many workers.");
                return -ENOMEM;
        }
 
-       strncpy(param->slave_names[param->nb_slaves++], value,
+       strncpy(param->worker_names[param->nb_workers++], value,
                        RTE_CRYPTODEV_SCHEDULER_NAME_MAX_LEN - 1);
 
        return 0;
@@ -445,8 +498,8 @@ scheduler_parse_init_params(struct scheduler_init_params *params,
                if (ret < 0)
                        goto free_kvlist;
 
-               ret = rte_kvargs_process(kvlist, RTE_CRYPTODEV_VDEV_SLAVE,
-                               &parse_slave_arg, params);
+               ret = rte_kvargs_process(kvlist, RTE_CRYPTODEV_VDEV_WORKER,
+                               &parse_worker_arg, params);
                if (ret < 0)
                        goto free_kvlist;
 
@@ -481,10 +534,10 @@ cryptodev_scheduler_probe(struct rte_vdev_device *vdev)
                        rte_socket_id(),
                        RTE_CRYPTODEV_PMD_DEFAULT_MAX_NB_QUEUE_PAIRS
                },
-               .nb_slaves = 0,
+               .nb_workers = 0,
                .mode = CDEV_SCHED_MODE_NOT_SET,
                .enable_ordering = 0,
-               .slave_names = { {0} }
+               .worker_names = { {0} }
        };
        const char *name;
 
@@ -513,7 +566,7 @@ RTE_PMD_REGISTER_VDEV(CRYPTODEV_NAME_SCHEDULER_PMD,
 RTE_PMD_REGISTER_PARAM_STRING(CRYPTODEV_NAME_SCHEDULER_PMD,
        "max_nb_queue_pairs=<int> "
        "socket_id=<int> "
-       "slave=<name>");
+       "worker=<name>");
 RTE_PMD_REGISTER_CRYPTO_DRIVER(scheduler_crypto_drv,
                cryptodev_scheduler_pmd_drv.driver,
-               cryptodev_driver_id);
+               cryptodev_scheduler_driver_id);