1c126512bSOri Kam /* SPDX-License-Identifier: BSD-3-Clause 2c126512bSOri Kam * Copyright 2020 Mellanox Technologies, Ltd 3c126512bSOri Kam */ 4c126512bSOri Kam 5c126512bSOri Kam #include <rte_log.h> 6c126512bSOri Kam #include <rte_errno.h> 7e3dbbf71SOri Kam #include <rte_malloc.h> 8c126512bSOri Kam #include <rte_regexdev.h> 9c126512bSOri Kam #include <rte_regexdev_core.h> 10c126512bSOri Kam #include <rte_regexdev_driver.h> 11f324162eSOri Kam #include <sys/mman.h> 12c126512bSOri Kam 13e3dbbf71SOri Kam #include <mlx5_glue.h> 14e3dbbf71SOri Kam #include <mlx5_devx_cmds.h> 15e3dbbf71SOri Kam #include <mlx5_prm.h> 16b34d8163SFrancis Kelly #include <mlx5_common_os.h> 17e3dbbf71SOri Kam 18c126512bSOri Kam #include "mlx5_regex.h" 19e3dbbf71SOri Kam #include "mlx5_regex_utils.h" 20b34d8163SFrancis Kelly #include "mlx5_rxp.h" 21c126512bSOri Kam 22b34d8163SFrancis Kelly #define MLX5_REGEX_MAX_MATCHES MLX5_RXP_MAX_MATCHES 23b34d8163SFrancis Kelly #define MLX5_REGEX_MAX_PAYLOAD_SIZE MLX5_RXP_MAX_JOB_LENGTH 24b34d8163SFrancis Kelly #define MLX5_REGEX_MAX_RULES_PER_GROUP UINT32_MAX 25b34d8163SFrancis Kelly #define MLX5_REGEX_MAX_GROUPS MLX5_RXP_MAX_SUBSETS 26b34d8163SFrancis Kelly 27f324162eSOri Kam #define MLX5_REGEX_RXP_ROF2_LINE_LEN 34 28f324162eSOri Kam 29b34d8163SFrancis Kelly /* Private Declarations */ 309fa82d28SAdy Agbarih static int 319fa82d28SAdy Agbarih rxp_create_mkey(struct mlx5_regex_priv *priv, void *ptr, size_t size, 329fa82d28SAdy Agbarih uint32_t access, struct mlx5_regex_mkey *mkey); 339fa82d28SAdy Agbarih static inline void 349fa82d28SAdy Agbarih rxp_destroy_mkey(struct mlx5_regex_mkey *mkey); 359fa82d28SAdy Agbarih 36c126512bSOri Kam int 37c126512bSOri Kam mlx5_regex_info_get(struct rte_regexdev *dev __rte_unused, 38c126512bSOri Kam struct rte_regexdev_info *info) 39c126512bSOri Kam { 40c126512bSOri Kam info->max_matches = MLX5_REGEX_MAX_MATCHES; 41c126512bSOri Kam info->max_payload_size = MLX5_REGEX_MAX_PAYLOAD_SIZE; 42c126512bSOri Kam info->max_rules_per_group = MLX5_REGEX_MAX_RULES_PER_GROUP; 43c126512bSOri Kam info->max_groups = MLX5_REGEX_MAX_GROUPS; 44c8452005SOphir Munk info->regexdev_capa = RTE_REGEXDEV_SUPP_PCRE_GREEDY_F | 45c8452005SOphir Munk RTE_REGEXDEV_CAPA_QUEUE_PAIR_OOS_F; 46c126512bSOri Kam info->rule_flags = 0; 477a7a9907SOri Kam info->max_queue_pairs = UINT16_MAX; 48c126512bSOri Kam return 0; 49c126512bSOri Kam } 50e3dbbf71SOri Kam 51e3dbbf71SOri Kam static int 529fa82d28SAdy Agbarih rxp_create_mkey(struct mlx5_regex_priv *priv, void *ptr, size_t size, 539fa82d28SAdy Agbarih uint32_t access, struct mlx5_regex_mkey *mkey) 54b34d8163SFrancis Kelly { 559fa82d28SAdy Agbarih struct mlx5_devx_mkey_attr mkey_attr; 56b34d8163SFrancis Kelly 57b34d8163SFrancis Kelly /* Register the memory. */ 589fa82d28SAdy Agbarih mkey->umem = mlx5_glue->devx_umem_reg(priv->cdev->ctx, ptr, size, access); 599fa82d28SAdy Agbarih if (!mkey->umem) { 60b34d8163SFrancis Kelly DRV_LOG(ERR, "Failed to register memory!"); 619fa82d28SAdy Agbarih return -ENODEV; 62b34d8163SFrancis Kelly } 639fa82d28SAdy Agbarih /* Create mkey */ 649fa82d28SAdy Agbarih mkey_attr = (struct mlx5_devx_mkey_attr) { 659fa82d28SAdy Agbarih .addr = (uintptr_t)ptr, 669fa82d28SAdy Agbarih .size = (uint32_t)size, 679fa82d28SAdy Agbarih .umem_id = mlx5_os_get_umem_id(mkey->umem), 689fa82d28SAdy Agbarih .pg_access = 1, 699fa82d28SAdy Agbarih .umr_en = 0, 709fa82d28SAdy Agbarih }; 719fa82d28SAdy Agbarih #ifdef HAVE_IBV_FLOW_DV_SUPPORT 729fa82d28SAdy Agbarih mkey_attr.pd = priv->cdev->pdn; 739fa82d28SAdy Agbarih #endif 749fa82d28SAdy Agbarih mkey->mkey = mlx5_devx_cmd_mkey_create(priv->cdev->ctx, &mkey_attr); 759fa82d28SAdy Agbarih if (!mkey->mkey) { 769fa82d28SAdy Agbarih DRV_LOG(ERR, "Failed to create direct mkey!"); 779fa82d28SAdy Agbarih return -ENODEV; 78b34d8163SFrancis Kelly } 79b34d8163SFrancis Kelly return 0; 80b34d8163SFrancis Kelly } 819fa82d28SAdy Agbarih 829fa82d28SAdy Agbarih static inline void 839fa82d28SAdy Agbarih rxp_destroy_mkey(struct mlx5_regex_mkey *mkey) 849fa82d28SAdy Agbarih { 859fa82d28SAdy Agbarih if (mkey->mkey) 869fa82d28SAdy Agbarih claim_zero(mlx5_devx_cmd_destroy(mkey->mkey)); 879fa82d28SAdy Agbarih if (mkey->umem) 889fa82d28SAdy Agbarih claim_zero(mlx5_glue->devx_umem_dereg(mkey->umem)); 89b34d8163SFrancis Kelly } 90b34d8163SFrancis Kelly 91b34d8163SFrancis Kelly int 92b34d8163SFrancis Kelly mlx5_regex_rules_db_import(struct rte_regexdev *dev, 93b34d8163SFrancis Kelly const char *rule_db, uint32_t rule_db_len) 94b34d8163SFrancis Kelly { 95b34d8163SFrancis Kelly struct mlx5_regex_priv *priv = dev->data->dev_private; 969fa82d28SAdy Agbarih struct mlx5_regex_mkey mkey; 979fa82d28SAdy Agbarih uint32_t id; 989fa82d28SAdy Agbarih int ret; 999fa82d28SAdy Agbarih void *ptr; 100b34d8163SFrancis Kelly 101b34d8163SFrancis Kelly if (priv->prog_mode == MLX5_RXP_MODE_NOT_DEFINED) { 102b34d8163SFrancis Kelly DRV_LOG(ERR, "RXP programming mode not set!"); 103b34d8163SFrancis Kelly return -1; 104b34d8163SFrancis Kelly } 105b34d8163SFrancis Kelly if (rule_db == NULL) { 106b34d8163SFrancis Kelly DRV_LOG(ERR, "Database empty!"); 107b34d8163SFrancis Kelly return -ENODEV; 108b34d8163SFrancis Kelly } 109b34d8163SFrancis Kelly if (rule_db_len == 0) 110b34d8163SFrancis Kelly return -EINVAL; 1119fa82d28SAdy Agbarih /* copy rules - rules have to be 4KB aligned. */ 1129fa82d28SAdy Agbarih ptr = rte_malloc("", rule_db_len, 1 << 12); 1139fa82d28SAdy Agbarih if (!ptr) { 1149fa82d28SAdy Agbarih DRV_LOG(ERR, "Failed to allocate rules file memory."); 1159fa82d28SAdy Agbarih return -ENOMEM; 1169fa82d28SAdy Agbarih } 1179fa82d28SAdy Agbarih rte_memcpy(ptr, rule_db, rule_db_len); 1189fa82d28SAdy Agbarih /* Register umem and create rof mkey. */ 1199fa82d28SAdy Agbarih ret = rxp_create_mkey(priv, ptr, rule_db_len, /*access=*/7, &mkey); 1209fa82d28SAdy Agbarih if (ret < 0) 1219fa82d28SAdy Agbarih return ret; 122ab2e0b0dSAdy Agbarih 1239fa82d28SAdy Agbarih for (id = 0; id < priv->nb_engines; id++) { 1249fa82d28SAdy Agbarih ret = mlx5_devx_regex_rules_program(priv->cdev->ctx, id, 1259fa82d28SAdy Agbarih mkey.mkey->id, rule_db_len, (uintptr_t)ptr); 1269fa82d28SAdy Agbarih if (ret < 0) { 1279fa82d28SAdy Agbarih DRV_LOG(ERR, "Failed to program rxp rules."); 1289fa82d28SAdy Agbarih ret = -ENODEV; 1299fa82d28SAdy Agbarih break; 1309fa82d28SAdy Agbarih } 1319fa82d28SAdy Agbarih ret = 0; 1329fa82d28SAdy Agbarih } 1339fa82d28SAdy Agbarih rxp_destroy_mkey(&mkey); 1349fa82d28SAdy Agbarih rte_free(ptr); 1359fa82d28SAdy Agbarih return ret; 136b34d8163SFrancis Kelly } 137b34d8163SFrancis Kelly 138e3dbbf71SOri Kam int 139e3dbbf71SOri Kam mlx5_regex_configure(struct rte_regexdev *dev, 140e3dbbf71SOri Kam const struct rte_regexdev_config *cfg) 141e3dbbf71SOri Kam { 142e3dbbf71SOri Kam struct mlx5_regex_priv *priv = dev->data->dev_private; 143e3dbbf71SOri Kam int ret; 144e3dbbf71SOri Kam 145b34d8163SFrancis Kelly if (priv->prog_mode == MLX5_RXP_MODE_NOT_DEFINED) 146b34d8163SFrancis Kelly return -1; 147e3dbbf71SOri Kam priv->nb_queues = cfg->nb_queue_pairs; 148b34d8163SFrancis Kelly dev->data->dev_conf.nb_queue_pairs = priv->nb_queues; 149e3dbbf71SOri Kam priv->qps = rte_zmalloc(NULL, sizeof(struct mlx5_regex_qp) * 150e3dbbf71SOri Kam priv->nb_queues, 0); 151*60e9028aSWeiguo Li if (!priv->qps) { 152e3dbbf71SOri Kam DRV_LOG(ERR, "can't allocate qps memory"); 153e3dbbf71SOri Kam rte_errno = ENOMEM; 154e3dbbf71SOri Kam return -rte_errno; 155e3dbbf71SOri Kam } 156e3dbbf71SOri Kam priv->nb_max_matches = cfg->nb_max_matches; 157b34d8163SFrancis Kelly if (cfg->rule_db != NULL) { 158b34d8163SFrancis Kelly ret = mlx5_regex_rules_db_import(dev, cfg->rule_db, 159b34d8163SFrancis Kelly cfg->rule_db_len); 160b34d8163SFrancis Kelly if (ret < 0) { 161b34d8163SFrancis Kelly DRV_LOG(ERR, "Failed to program rxp rules."); 162e3dbbf71SOri Kam rte_errno = ENODEV; 163e3dbbf71SOri Kam goto configure_error; 164e3dbbf71SOri Kam } 165b34d8163SFrancis Kelly } else 166b34d8163SFrancis Kelly DRV_LOG(DEBUG, "Regex config without rules programming!"); 167e3dbbf71SOri Kam return 0; 168e3dbbf71SOri Kam configure_error: 169e3dbbf71SOri Kam if (priv->qps) 170e3dbbf71SOri Kam rte_free(priv->qps); 171e3dbbf71SOri Kam return -rte_errno; 172e3dbbf71SOri Kam } 173