> The ipsec_mb SW PMD now has multiprocess support.
> The queue-pair IMB_MGR is stored in a memzone instead of being allocated
> externally by the Intel IPSec MB library, when v1.1 is used.
> If v1.0 is used, multi process is not supported, and allocation is
> done as before.
> The secondary process needs to reconfigure the queue-pair to allow for
> IMB_MGR function pointers be updated.
> 
> Intel IPsec MB library version 1.1 is required for this support.
> 
> Signed-off-by: Ciara Power <ciara.po...@intel.com>
> ---
>  doc/guides/rel_notes/release_21_11.rst        |   7 ++
>  .../crypto/ipsec_mb/rte_ipsec_mb_pmd_ops.c    | 110 +++++++++++++++---
>  .../ipsec_mb/rte_ipsec_mb_pmd_private.h       |   5 +

Missed to comment on first patch.
rte_ may be skipped from the internal files of the PMD.
rte_ is normally added for files which are exposed to the user.

>  3 files changed, 106 insertions(+), 16 deletions(-)
> 
> diff --git a/doc/guides/rel_notes/release_21_11.rst
> b/doc/guides/rel_notes/release_21_11.rst
> index 43d367bcad..3c9d7e19cb 100644
> --- a/doc/guides/rel_notes/release_21_11.rst
> +++ b/doc/guides/rel_notes/release_21_11.rst
> @@ -62,6 +62,13 @@ New Features
>    * Added bus-level parsing of the devargs syntax.
>    * Kept compatibility with the legacy syntax as parsing fallback.
> 
> +* **Added multi-process support for IPsec-mb PMD.**
> +
> +  Added multi-process support to IPsec-mb PMD, which will add support
> +  for PMDs that are moved to use this shared framework.
> +  This feature makes use of an intel-ipsec-mb API found in v1.1,
> +  which is the minimum required version to use this multi-process support.
> +

I believe first new PMD framework should be introduced in the release note and
a sub bullet may be added to specify multi process support.

>  * **Updated Marvell cnxk crypto PMD.**
> 
>    * Added AES-CBC SHA1-HMAC support in lookaside protocol (IPsec) for
> CN10K.
> diff --git a/drivers/crypto/ipsec_mb/rte_ipsec_mb_pmd_ops.c
> b/drivers/crypto/ipsec_mb/rte_ipsec_mb_pmd_ops.c
> index 1146297216..c7bcfd3dce 100644
> --- a/drivers/crypto/ipsec_mb/rte_ipsec_mb_pmd_ops.c
> +++ b/drivers/crypto/ipsec_mb/rte_ipsec_mb_pmd_ops.c
> @@ -9,6 +9,8 @@
> 
>  #include "rte_ipsec_mb_pmd_private.h"
> 
> +#define IMB_MP_REQ_VER_STR "1.1.0"
> +
>  /** Configure device */
>  int
>  ipsec_mb_pmd_config(__rte_unused struct rte_cryptodev *dev,
> @@ -98,10 +100,20 @@ ipsec_mb_pmd_qp_release(struct rte_cryptodev
> *dev, uint16_t qp_id)
>       struct ipsec_mb_qp *qp = dev->data->queue_pairs[qp_id];
>       struct rte_ring *r = NULL;
> 
> -     if (qp != NULL) {
> +     if (qp != NULL && rte_eal_process_type() == RTE_PROC_PRIMARY) {
>               r = rte_ring_lookup(qp->name);
>               if (r)
>                       rte_ring_free(r);
> +
> +#if IMB_VERSION(1, 1, 0) > IMB_VERSION_NUM
> +             if (qp->mb_mgr)
> +                     free_mb_mgr(qp->mb_mgr);
> +#else
> +             if (qp->mb_mgr_mz) {
> +                     rte_memzone_free(qp->mb_mgr_mz);
> +                     qp->mb_mgr = NULL;
> +             }
> +#endif
>               rte_free(qp);
>               dev->data->queue_pairs[qp_id] = NULL;
>       }
> @@ -154,6 +166,42 @@ static struct rte_ring
>                              RING_F_SP_ENQ | RING_F_SC_DEQ);
>  }
> 
> +#if IMB_VERSION(1, 1, 0) <= IMB_VERSION_NUM
> +static IMB_MGR *
> +ipsec_mb_pmd_alloc_mb_from_memzone(const struct rte_memzone
> **mb_mgr_mz,
> +             const char *mb_mgr_mz_name)
> +{
> +     IMB_MGR *mb_mgr;
> +
> +     if (rte_eal_process_type() ==  RTE_PROC_PRIMARY) {
> +             *mb_mgr_mz = rte_memzone_lookup(mb_mgr_mz_name);
> +             if (*mb_mgr_mz == NULL) {
> +                     *mb_mgr_mz =
> rte_memzone_reserve(mb_mgr_mz_name,
> +                     imb_get_mb_mgr_size(),
> +                     rte_socket_id(), 0);
> +             }
> +             if (*mb_mgr_mz == NULL) {
> +                     IPSEC_MB_LOG(DEBUG, "Error allocating memzone
> for %s",
> +                                     mb_mgr_mz_name);
> +                     return NULL;
> +             }
> +             mb_mgr = imb_set_pointers_mb_mgr((*mb_mgr_mz)->addr,
> 0, 1);
> +             init_mb_mgr_auto(mb_mgr, NULL);
> +     } else {
> +             *mb_mgr_mz = rte_memzone_lookup(mb_mgr_mz_name);
> +             if (*mb_mgr_mz == NULL) {
> +                     IPSEC_MB_LOG(ERR,
> +                             "Secondary can't find %s mz, did primary
> create it?",
> +                             mb_mgr_mz_name);
> +                     return NULL;
> +             }
> +             mb_mgr = imb_set_pointers_mb_mgr((*mb_mgr_mz)->addr,
> 0, 0);
> +             init_mb_mgr_auto(mb_mgr, NULL);
> +     }
> +     return mb_mgr;
> +}
> +#endif
> +
>  /** Setup a queue pair */
>  int
>  ipsec_mb_pmd_qp_setup(struct rte_cryptodev *dev, uint16_t qp_id,
> @@ -167,16 +215,44 @@ ipsec_mb_pmd_qp_setup(struct rte_cryptodev
> *dev, uint16_t qp_id,
>       uint32_t qp_size;
>       int ret = -1;
> 
> -     /* Free memory prior to re-allocation if needed. */
> -     if (dev->data->queue_pairs[qp_id] != NULL)
> -             ipsec_mb_pmd_qp_release(dev, qp_id);
> +     if (rte_eal_process_type() == RTE_PROC_SECONDARY) {
> +#if IMB_VERSION(1, 1, 0) > IMB_VERSION_NUM
> +             IPSEC_MB_LOG(ERR, "The intel-ipsec-mb version (%s) does
> not support multiprocess,"
> +                             "the minimum version required for this
> feature is %s.",
> +                             IMB_VERSION_STR, IMB_MP_REQ_VER_STR);
> +             return -EINVAL;
> +#endif
> +             if (dev->data->queue_pairs[qp_id] != NULL)
> +                     qp = dev->data->queue_pairs[qp_id];
> +     } else {
> +             /* Free memory prior to re-allocation if needed. */
> +             if (dev->data->queue_pairs[qp_id] != NULL)
> +                     ipsec_mb_pmd_qp_release(dev, qp_id);
> +
> +             qp_size = sizeof(*qp) + pmd_data->qp_priv_size;
> +             /* Allocate the queue pair data structure. */
> +             qp = rte_zmalloc_socket("IPSEC PMD Queue Pair", qp_size,
> +                                     RTE_CACHE_LINE_SIZE, socket_id);
> +             if (qp == NULL)
> +                     return -ENOMEM;
> +     }
> +
> +#if IMB_VERSION(1, 1, 0) > IMB_VERSION_NUM
> +     qp->mb_mgr = alloc_init_mb_mgr();
> +#else
> +     char mz_name[IPSEC_MB_MAX_MZ_NAME];
> +     snprintf(mz_name, sizeof(mz_name), "IMB_MGR_DEV_%d_QP_%d",
> +                     dev->data->dev_id, qp_id);
> +     qp->mb_mgr = ipsec_mb_pmd_alloc_mb_from_memzone(&(qp-
> >mb_mgr_mz),
> +                     mz_name);

_pmd_ may be skipped from the internal APIs. The function names are pretty long.

> +#endif
> +     if (qp->mb_mgr == NULL) {
> +             ret = -ENOMEM;
> +             goto qp_setup_cleanup;
> +     }
> 
> -     qp_size = sizeof(*qp) + pmd_data->qp_priv_size;
> -     /* Allocate the queue pair data structure. */
> -     qp = rte_zmalloc_socket("IPSEC PMD Queue Pair", qp_size,
> -                             RTE_CACHE_LINE_SIZE, socket_id);
> -     if (qp == NULL)
> -             return -ENOMEM;
> +     if (rte_eal_process_type() == RTE_PROC_SECONDARY)
> +             return 0;
> 
>       qp->id = qp_id;
>       dev->data->queue_pairs[qp_id] = qp;
> @@ -194,12 +270,6 @@ ipsec_mb_pmd_qp_setup(struct rte_cryptodev
> *dev, uint16_t qp_id,
>               goto qp_setup_cleanup;
>       }
> 
> -     qp->mb_mgr = alloc_init_mb_mgr();
> -     if (!qp->mb_mgr) {
> -             ret = -ENOMEM;
> -             goto qp_setup_cleanup;
> -     }
> -
>       memset(&qp->stats, 0, sizeof(qp->stats));
> 
>       if (pmd_data->queue_pair_configure) {
> @@ -211,8 +281,15 @@ ipsec_mb_pmd_qp_setup(struct rte_cryptodev
> *dev, uint16_t qp_id,
>       return 0;
> 
>  qp_setup_cleanup:
> +#if IMB_VERSION(1, 1, 0) > IMB_VERSION_NUM
>       if (qp->mb_mgr)
>               free_mb_mgr(qp->mb_mgr);
> +#else
> +     if (rte_eal_process_type() == RTE_PROC_SECONDARY)
> +             return ret;
> +     if (qp->mb_mgr_mz)
> +             rte_memzone_free(qp->mb_mgr_mz);
> +#endif
>       if (qp)
>               rte_free(qp);
>       return ret;
> @@ -269,6 +346,7 @@ ipsec_mb_pmd_sym_session_configure(
> 
>       set_sym_session_private_data(sess, dev->driver_id,
> sess_private_data);
> 
> +     free_mb_mgr(mb_mgr);
>       return 0;
>  }
> 
> diff --git a/drivers/crypto/ipsec_mb/rte_ipsec_mb_pmd_private.h
> b/drivers/crypto/ipsec_mb/rte_ipsec_mb_pmd_private.h
> index 754259aa59..35860b1b10 100644
> --- a/drivers/crypto/ipsec_mb/rte_ipsec_mb_pmd_private.h
> +++ b/drivers/crypto/ipsec_mb/rte_ipsec_mb_pmd_private.h
> @@ -18,6 +18,9 @@
>  /* Maximum length for digest */
>  #define DIGEST_LENGTH_MAX 64
> 
> +/* Maximum length for memzone name */
> +#define IPSEC_MB_MAX_MZ_NAME 32
> +
>  enum ipsec_mb_vector_mode {
>       IPSEC_MB_NOT_SUPPORTED = 0,
>       IPSEC_MB_SSE,
> @@ -95,6 +98,8 @@ struct ipsec_mb_qp {
>        */
>       IMB_MGR *mb_mgr;
>       /* Multi buffer manager */
> +     const struct rte_memzone *mb_mgr_mz;
> +     /* Shared memzone for storing mb_mgr */
>       __extension__ uint8_t additional_data[0];
>       /**< Storing PMD specific additional data */
>  };
> --
> 2.25.1

Reply via email to