Enable unloading model using external tvmdp library. Updated
layer unload callback to support multiple layers.

Signed-off-by: Srikanth Yalavarthi <syalavar...@marvell.com>
Signed-off-by: Anup Prabhu <apra...@marvell.com>
---
 drivers/ml/cnxk/cn10k_ml_ops.c   |  8 +++++---
 drivers/ml/cnxk/cnxk_ml_ops.c    |  7 +++++--
 drivers/ml/cnxk/mvtvm_ml_ops.c   | 28 ++++++++++++++++++++++++++++
 drivers/ml/cnxk/mvtvm_ml_ops.h   |  1 +
 drivers/ml/cnxk/mvtvm_ml_stubs.c |  9 +++++++++
 drivers/ml/cnxk/mvtvm_ml_stubs.h |  1 +
 6 files changed, 49 insertions(+), 5 deletions(-)

diff --git a/drivers/ml/cnxk/cn10k_ml_ops.c b/drivers/ml/cnxk/cn10k_ml_ops.c
index 4191ccc840..e7208391fd 100644
--- a/drivers/ml/cnxk/cn10k_ml_ops.c
+++ b/drivers/ml/cnxk/cn10k_ml_ops.c
@@ -780,11 +780,9 @@ cn10k_ml_layer_unload(void *device, uint16_t model_id, 
const char *layer_name)
        struct cnxk_ml_layer *layer;
 
        char str[RTE_MEMZONE_NAMESIZE];
-       uint16_t layer_id = 0;
+       uint16_t layer_id;
        int ret;
 
-       PLT_SET_USED(layer_name);
-
        cnxk_mldev = (struct cnxk_ml_dev *)device;
        if (cnxk_mldev == NULL) {
                plt_err("Invalid device = %p", device);
@@ -797,6 +795,10 @@ cn10k_ml_layer_unload(void *device, uint16_t model_id, 
const char *layer_name)
                return -EINVAL;
        }
 
+       ret = cn10k_ml_model_get_layer_id(model, layer_name, &layer_id);
+       if (ret != 0)
+               return ret;
+
        layer = &model->layer[layer_id];
 
        snprintf(str, RTE_MEMZONE_NAMESIZE, "%s_%u_%u", 
CN10K_ML_LAYER_MEMZONE_NAME,
diff --git a/drivers/ml/cnxk/cnxk_ml_ops.c b/drivers/ml/cnxk/cnxk_ml_ops.c
index 1565e521fd..ce668e1eb6 100644
--- a/drivers/ml/cnxk/cnxk_ml_ops.c
+++ b/drivers/ml/cnxk/cnxk_ml_ops.c
@@ -1107,7 +1107,7 @@ cnxk_ml_model_unload(struct rte_ml_dev *dev, uint16_t 
model_id)
        struct cnxk_ml_model *model;
 
        char str[RTE_MEMZONE_NAMESIZE];
-       int ret;
+       int ret = 0;
 
        if (dev == NULL)
                return -EINVAL;
@@ -1125,7 +1125,10 @@ cnxk_ml_model_unload(struct rte_ml_dev *dev, uint16_t 
model_id)
                return -EBUSY;
        }
 
-       ret = cn10k_ml_model_unload(cnxk_mldev, model);
+       if (model->type == ML_CNXK_MODEL_TYPE_GLOW)
+               ret = cn10k_ml_model_unload(cnxk_mldev, model);
+       else
+               ret = mvtvm_ml_model_unload(cnxk_mldev, model);
        if (ret != 0)
                return ret;
 
diff --git a/drivers/ml/cnxk/mvtvm_ml_ops.c b/drivers/ml/cnxk/mvtvm_ml_ops.c
index e21bf2dc07..3847f9b6b9 100644
--- a/drivers/ml/cnxk/mvtvm_ml_ops.c
+++ b/drivers/ml/cnxk/mvtvm_ml_ops.c
@@ -185,3 +185,31 @@ mvtvm_ml_model_load(struct cnxk_ml_dev *cnxk_mldev, struct 
rte_ml_model_params *
 
        return ret;
 }
+
+int
+mvtvm_ml_model_unload(struct cnxk_ml_dev *cnxk_mldev, struct cnxk_ml_model 
*model)
+{
+       char str[RTE_MEMZONE_NAMESIZE];
+       const struct plt_memzone *mz;
+       int ret;
+
+       RTE_SET_USED(cnxk_mldev);
+
+       /* Initialize model in TVMDP */
+       ret = tvmdp_model_unload(model->model_id);
+       if (ret != 0) {
+               plt_err("TVMDP: Model unload failed, model_id = %u, error = 
%d", model->model_id,
+                       ret);
+               return ret;
+       }
+
+       snprintf(str, RTE_MEMZONE_NAMESIZE, "%s_%u", 
MVTVM_ML_MODEL_MEMZONE_NAME, model->model_id);
+       mz = rte_memzone_lookup(str);
+       if (mz == NULL) {
+               plt_err("Memzone lookup failed for TVM model: model_id = %u, mz 
= %s",
+                       model->model_id, str);
+               return -EINVAL;
+       }
+
+       return plt_memzone_free(mz);
+}
diff --git a/drivers/ml/cnxk/mvtvm_ml_ops.h b/drivers/ml/cnxk/mvtvm_ml_ops.h
index 6607537599..770794fe7d 100644
--- a/drivers/ml/cnxk/mvtvm_ml_ops.h
+++ b/drivers/ml/cnxk/mvtvm_ml_ops.h
@@ -18,5 +18,6 @@ int mvtvm_ml_dev_configure(struct cnxk_ml_dev *cnxk_mldev, 
const struct rte_ml_d
 int mvtvm_ml_dev_close(struct cnxk_ml_dev *cnxk_mldev);
 int mvtvm_ml_model_load(struct cnxk_ml_dev *cnxk_mldev, struct 
rte_ml_model_params *params,
                        struct cnxk_ml_model *model);
+int mvtvm_ml_model_unload(struct cnxk_ml_dev *cnxk_mldev, struct cnxk_ml_model 
*model);
 
 #endif /* _MVTVM_ML_OPS_H_ */
diff --git a/drivers/ml/cnxk/mvtvm_ml_stubs.c b/drivers/ml/cnxk/mvtvm_ml_stubs.c
index 80a9a90b4e..a17a76e41f 100644
--- a/drivers/ml/cnxk/mvtvm_ml_stubs.c
+++ b/drivers/ml/cnxk/mvtvm_ml_stubs.c
@@ -63,3 +63,12 @@ mvtvm_ml_model_load(struct cnxk_ml_dev *cnxk_mldev, struct 
rte_ml_model_params *
 
        return -EINVAL;
 }
+
+int
+mvtvm_ml_model_unload(struct cnxk_ml_dev *cnxk_mldev, struct cnxk_ml_model 
*model)
+{
+       RTE_SET_USED(cnxk_mldev);
+       RTE_SET_USED(model);
+
+       return -EINVAL;
+}
diff --git a/drivers/ml/cnxk/mvtvm_ml_stubs.h b/drivers/ml/cnxk/mvtvm_ml_stubs.h
index 29f721072a..3776fb5369 100644
--- a/drivers/ml/cnxk/mvtvm_ml_stubs.h
+++ b/drivers/ml/cnxk/mvtvm_ml_stubs.h
@@ -15,6 +15,7 @@ int mvtvm_ml_dev_configure(struct cnxk_ml_dev *cnxk_mldev, 
const struct rte_ml_d
 int mvtvm_ml_dev_close(struct cnxk_ml_dev *cnxk_mldev);
 int mvtvm_ml_model_load(struct cnxk_ml_dev *cnxk_mldev, struct 
rte_ml_model_params *params,
                        struct cnxk_ml_model *model);
+int mvtvm_ml_model_unload(struct cnxk_ml_dev *cnxk_mldev, struct cnxk_ml_model 
*model);
 
 int mvtvm_ml_model_get_layer_id(struct cnxk_ml_model *model, const char 
*layer_name,
                                uint16_t *layer_id);
-- 
2.42.0

Reply via email to