From: Jasvinder Singh <jasvinder.si...@intel.com>

Update mbuf prefetch function of the scheduler grinder to allow configuration
flexiblity for pipe traffic classes and queues, and subport level
configuration of the pipe parameters.

Signed-off-by: Jasvinder Singh <jasvinder.si...@intel.com>
Signed-off-by: Abraham Tovar <abrahamx.to...@intel.com>
Signed-off-by: Lukasz Krakowiak <lukaszx.krakow...@intel.com>
---
 lib/librte_sched/rte_sched.c | 42 ++++++++++++++++++++++++++++--------
 1 file changed, 33 insertions(+), 9 deletions(-)

diff --git a/lib/librte_sched/rte_sched.c b/lib/librte_sched/rte_sched.c
index ba344f0a1..06d89e3fd 100644
--- a/lib/librte_sched/rte_sched.c
+++ b/lib/librte_sched/rte_sched.c
@@ -2478,19 +2478,43 @@ grinder_prefetch_tc_queue_arrays(struct rte_sched_port 
*port, uint32_t pos)
 }
 
 static inline void
-grinder_prefetch_mbuf(struct rte_sched_port *port, uint32_t pos)
+grinder_prefetch_mbuf(struct rte_sched_subport *subport, uint32_t pos)
 {
-       struct rte_sched_grinder *grinder = port->grinder + pos;
-       uint32_t qpos = grinder->qpos;
-       struct rte_mbuf **qbase = grinder->qbase[qpos];
-       uint16_t qsize = grinder->qsize;
-       uint16_t qr = grinder->queue[qpos]->qr & (qsize - 1);
+       struct rte_sched_grinder *grinder = subport->grinder + pos;
+       struct rte_mbuf **qbase;
+       uint32_t tc_index = grinder->tc_index;
+       uint32_t qpos;
+       uint16_t qsize, qr;
+
+       if (tc_index < RTE_SCHED_TRAFFIC_CLASS_BE) {
+               qbase = grinder->sp.qbase;
+               qsize = grinder->sp.qsize;
+               qr = grinder->sp.queue->qr & (qsize - 1);
+
+               grinder->pkt = qbase[qr];
+               rte_prefetch0(grinder->pkt);
+
+               if (unlikely((qr & 0x7) == 7)) {
+                       uint16_t qr_next =
+                               (grinder->sp.queue->qr + 1) & (qsize - 1);
+
+                       rte_prefetch0(qbase + qr_next);
+               }
+
+               return;
+       }
+
+       qpos = grinder->be.qpos;
+       qbase = grinder->be.qbase[qpos];
+       qsize = grinder->be.qsize[qpos];
+       qr = grinder->be.queue[qpos]->qr & (qsize - 1);
 
        grinder->pkt = qbase[qr];
        rte_prefetch0(grinder->pkt);
 
        if (unlikely((qr & 0x7) == 7)) {
-               uint16_t qr_next = (grinder->queue[qpos]->qr + 1) & (qsize - 1);
+               uint16_t qr_next =
+                       (grinder->be.queue[qpos]->qr + 1) & (qsize - 1);
 
                rte_prefetch0(qbase + qr_next);
        }
@@ -2529,7 +2553,7 @@ grinder_handle(struct rte_sched_port *port, uint32_t pos)
 
        case e_GRINDER_PREFETCH_MBUF:
        {
-               grinder_prefetch_mbuf(port, pos);
+               grinder_prefetch_mbuf(port->subport, pos);
 
                grinder->state = e_GRINDER_READ_MBUF;
                return 0;
@@ -2544,7 +2568,7 @@ grinder_handle(struct rte_sched_port *port, uint32_t pos)
                /* Look for next packet within the same TC */
                if (result && grinder->qmask) {
                        grinder_wrr(port->subport, pos);
-                       grinder_prefetch_mbuf(port, pos);
+                       grinder_prefetch_mbuf(port->subport, pos);
 
                        return 1;
                }
-- 
2.20.1

Reply via email to