Hi Arek,

> -----Original Message-----
> From: Kusztal, ArkadiuszX <arkadiuszx.kusz...@intel.com>
> Sent: Sunday, September 17, 2023 4:43 PM
> To: dev@dpdk.org
> Cc: gak...@marvell.com; Ji, Kai <kai...@intel.com>; Power, Ciara
> <ciara.po...@intel.com>; Kusztal, ArkadiuszX
> <arkadiuszx.kusz...@intel.com>
> Subject: [PATCH 1/3] common/qat: limit configuration to the primary process
> 
> This change prevents certain configuration functions from being called by the
> secondary process.
> 
> Signed-off-by: Arkadiusz Kusztal <arkadiuszx.kusz...@intel.com>
> ---
>  drivers/common/qat/qat_device.c | 113 +++++++++++++++++++++++-------
> ----------
>  drivers/common/qat/qat_device.h |   2 +
>  2 files changed, 66 insertions(+), 49 deletions(-)
> 
<snip>
> +static enum qat_device_gen
> +pick_gen(struct rte_pci_device *pci_dev) {
> +     switch (pci_dev->id.device_id) {
> +     case 0x0443:
> +             return QAT_GEN1;
> +     case 0x37c9:
> +     case 0x19e3:
> +     case 0x6f55:
> +     case 0x18ef:
> +             return QAT_GEN2;
> +     case 0x18a1:
> +             return QAT_GEN3;
> +     case 0x4941:
> +     case 0x4943:
> +             return QAT_GEN4;
> +     default:
> +             QAT_LOG(ERR, "Invalid dev_id, can't determine generation");
> +             return QAT_N_GENS;
> +     }
> +}
> +
>  struct qat_pci_device *
>  qat_pci_device_allocate(struct rte_pci_device *pci_dev,
>               struct qat_dev_cmd_param *qat_dev_cmd_param) @@ -
> 187,24 +218,8 @@ qat_pci_device_allocate(struct rte_pci_device *pci_dev,
>       rte_pci_device_name(&pci_dev->addr, name, sizeof(name));
>       snprintf(name+strlen(name), QAT_DEV_NAME_MAX_LEN-
> strlen(name), "_qat");
> 
> -     switch (pci_dev->id.device_id) {
> -     case 0x0443:
> -             qat_dev_gen = QAT_GEN1;
> -             break;
> -     case 0x37c9:
> -     case 0x19e3:
> -     case 0x6f55:
> -     case 0x18ef:
> -             qat_dev_gen = QAT_GEN2;
> -             break;
> -     case 0x18a1:
> -             qat_dev_gen = QAT_GEN3;
> -             break;
> -     case 0x4941:
> -     case 0x4943:
> -             qat_dev_gen = QAT_GEN4;
> -             break;
> -     default:
> +     qat_dev_gen = pick_gen(pci_dev);
> +     if (qat_dev_gen == QAT_N_GENS) {
>               QAT_LOG(ERR, "Invalid dev_id, can't determine generation");
>               return NULL;
>       }

The above log is duplicated, once in pick_gen() and once here.

> @@ -261,20 +276,15 @@ qat_pci_device_allocate(struct rte_pci_device
> *pci_dev,
>       qat_dev->dev_private = qat_dev + 1;
>       strlcpy(qat_dev->name, name, QAT_DEV_NAME_MAX_LEN);
>       qat_dev->qat_dev_id = qat_dev_id;
> -     qat_pci_devs[qat_dev_id].pci_dev = pci_dev;
>       qat_dev->qat_dev_gen = qat_dev_gen;
> 
>       ops_hw = qat_dev_hw_spec[qat_dev->qat_dev_gen];
> -     if (ops_hw->qat_dev_get_misc_bar == NULL) {
> -             QAT_LOG(ERR, "qat_dev_get_misc_bar function pointer not
> set");
> -             rte_memzone_free(qat_dev_mz);
> -             return NULL;
> -     }
> +     NOT_NULL(ops_hw->qat_dev_reset_ring_pairs, goto error,
> +             "QAT internal error! qat_dev_get_misc_bar function not set");

This check should be for ops_hw->qat_dev_get_misc_bar as mentioned in log.

Thanks,
Ciara

Reply via email to