Prevent op_addr access during queue_stop operation, as this memory may
have been deallocated.

Fixes: e640f6cdfa84 ("baseband/acc200: add LDPC processing")
Cc: sta...@dpdk.org

Signed-off-by: Hernan Vargas <hernan.var...@intel.com>
---
 drivers/baseband/acc/rte_acc100_pmd.c | 36 ----------------------
 drivers/baseband/acc/rte_vrb_pmd.c    | 44 +--------------------------
 2 files changed, 1 insertion(+), 79 deletions(-)

diff --git a/drivers/baseband/acc/rte_acc100_pmd.c 
b/drivers/baseband/acc/rte_acc100_pmd.c
index ccf2003c3da1..3501af2710fd 100644
--- a/drivers/baseband/acc/rte_acc100_pmd.c
+++ b/drivers/baseband/acc/rte_acc100_pmd.c
@@ -837,51 +837,15 @@ acc100_queue_setup(struct rte_bbdev *dev, uint16_t 
queue_id,
        return ret;
 }
 
-static inline void
-acc100_print_op(struct rte_bbdev_dec_op *op, enum rte_bbdev_op_type op_type,
-               uint16_t index)
-{
-       if (op == NULL)
-               return;
-       if (op_type == RTE_BBDEV_OP_LDPC_DEC)
-               rte_bbdev_log(DEBUG,
-                       "  Op 5GUL %d %d %d %d %d %d %d %d %d %d %d %d",
-                       index,
-                       op->ldpc_dec.basegraph, op->ldpc_dec.z_c,
-                       op->ldpc_dec.n_cb, op->ldpc_dec.q_m,
-                       op->ldpc_dec.n_filler, op->ldpc_dec.cb_params.e,
-                       op->ldpc_dec.op_flags, op->ldpc_dec.rv_index,
-                       op->ldpc_dec.iter_max, op->ldpc_dec.iter_count,
-                       op->ldpc_dec.harq_combined_input.length
-                       );
-       else if (op_type == RTE_BBDEV_OP_LDPC_ENC) {
-               struct rte_bbdev_enc_op *op_dl = (struct rte_bbdev_enc_op *) op;
-               rte_bbdev_log(DEBUG,
-                       "  Op 5GDL %d %d %d %d %d %d %d %d %d",
-                       index,
-                       op_dl->ldpc_enc.basegraph, op_dl->ldpc_enc.z_c,
-                       op_dl->ldpc_enc.n_cb, op_dl->ldpc_enc.q_m,
-                       op_dl->ldpc_enc.n_filler, op_dl->ldpc_enc.cb_params.e,
-                       op_dl->ldpc_enc.op_flags, op_dl->ldpc_enc.rv_index
-                       );
-       }
-}
-
 static int
 acc100_queue_stop(struct rte_bbdev *dev, uint16_t queue_id)
 {
        struct acc_queue *q;
-       struct rte_bbdev_dec_op *op;
-       uint16_t i;
 
        q = dev->data->queues[queue_id].queue_private;
        rte_bbdev_log(INFO, "Queue Stop %d H/T/D %d %d %x OpType %d",
                        queue_id, q->sw_ring_head, q->sw_ring_tail,
                        q->sw_ring_depth, q->op_type);
-       for (i = 0; i < q->sw_ring_depth; ++i) {
-               op = (q->ring_addr + i)->req.op_addr;
-               acc100_print_op(op, q->op_type, i);
-       }
        /* ignore all operations in flight and clear counters */
        q->sw_ring_tail = q->sw_ring_head;
        q->aq_enqueued = 0;
diff --git a/drivers/baseband/acc/rte_vrb_pmd.c 
b/drivers/baseband/acc/rte_vrb_pmd.c
index 5fb008001101..8dd9b9971142 100644
--- a/drivers/baseband/acc/rte_vrb_pmd.c
+++ b/drivers/baseband/acc/rte_vrb_pmd.c
@@ -1051,58 +1051,16 @@ vrb_queue_setup(struct rte_bbdev *dev, uint16_t 
queue_id,
        return ret;
 }
 
-static inline void
-vrb_print_op(struct rte_bbdev_dec_op *op, enum rte_bbdev_op_type op_type,
-               uint16_t index)
-{
-       if (op == NULL)
-               return;
-       if (op_type == RTE_BBDEV_OP_LDPC_DEC)
-               rte_bbdev_log(INFO,
-                       "  Op 5GUL %d %d %d %d %d %d %d %d %d %d %d %d",
-                       index,
-                       op->ldpc_dec.basegraph, op->ldpc_dec.z_c,
-                       op->ldpc_dec.n_cb, op->ldpc_dec.q_m,
-                       op->ldpc_dec.n_filler, op->ldpc_dec.cb_params.e,
-                       op->ldpc_dec.op_flags, op->ldpc_dec.rv_index,
-                       op->ldpc_dec.iter_max, op->ldpc_dec.iter_count,
-                       op->ldpc_dec.harq_combined_input.length
-                       );
-       else if (op_type == RTE_BBDEV_OP_LDPC_ENC) {
-               struct rte_bbdev_enc_op *op_dl = (struct rte_bbdev_enc_op *) op;
-               rte_bbdev_log(INFO,
-                       "  Op 5GDL %d %d %d %d %d %d %d %d %d",
-                       index,
-                       op_dl->ldpc_enc.basegraph, op_dl->ldpc_enc.z_c,
-                       op_dl->ldpc_enc.n_cb, op_dl->ldpc_enc.q_m,
-                       op_dl->ldpc_enc.n_filler, op_dl->ldpc_enc.cb_params.e,
-                       op_dl->ldpc_enc.op_flags, op_dl->ldpc_enc.rv_index
-                       );
-       } else if (op_type == RTE_BBDEV_OP_MLDTS) {
-               struct rte_bbdev_mldts_op *op_mldts = (struct 
rte_bbdev_mldts_op *) op;
-               rte_bbdev_log(INFO, "  Op MLD %d RBs %d NL %d Rp %d %d %x\n",
-                               index,
-                               op_mldts->mldts.num_rbs, 
op_mldts->mldts.num_layers,
-                               op_mldts->mldts.r_rep,
-                               op_mldts->mldts.c_rep, 
op_mldts->mldts.op_flags);
-       }
-}
-
 /* Stop queue and clear counters. */
 static int
 vrb_queue_stop(struct rte_bbdev *dev, uint16_t queue_id)
 {
        struct acc_queue *q;
-       struct rte_bbdev_dec_op *op;
-       uint16_t i;
+
        q = dev->data->queues[queue_id].queue_private;
        rte_bbdev_log(INFO, "Queue Stop %d H/T/D %d %d %x OpType %d",
                        queue_id, q->sw_ring_head, q->sw_ring_tail,
                        q->sw_ring_depth, q->op_type);
-       for (i = 0; i < q->sw_ring_depth; ++i) {
-               op = (q->ring_addr + i)->req.op_addr;
-               vrb_print_op(op, q->op_type, i);
-       }
        /* ignore all operations in flight and clear counters */
        q->sw_ring_tail = q->sw_ring_head;
        q->aq_enqueued = 0;
-- 
2.37.1

Reply via email to