In the function __rte_graph_mcore_dispatch_sched_node_enqueue,
use a slower loop to search for the graph, modify the search logic
to record the result of the first search, and use this record for
subsequent searches to improve search speed.

Due to the addition of a "graph" field in the "rte_node" structure,
update file release_24_11.rst.

Signed-off-by: Huichao Cai <chcch...@163.com>
---
 doc/guides/rel_notes/release_24_11.rst     |  1 +
 lib/graph/rte_graph_model_mcore_dispatch.c | 11 +++++++----
 lib/graph/rte_graph_worker_common.h        |  1 +
 3 files changed, 9 insertions(+), 4 deletions(-)

diff --git a/doc/guides/rel_notes/release_24_11.rst 
b/doc/guides/rel_notes/release_24_11.rst
index 9dc739c4cb..592116b979 100644
--- a/doc/guides/rel_notes/release_24_11.rst
+++ b/doc/guides/rel_notes/release_24_11.rst
@@ -423,6 +423,7 @@ ABI Changes
   added new structure ``rte_node_xstats`` to ``rte_node_register`` and
   added ``xstat_off`` to ``rte_node``.
 
+* graph: added ``graph`` field to the ``dispatch`` structure in the 
``rte_node`` structure.
 
 Known Issues
 ------------
diff --git a/lib/graph/rte_graph_model_mcore_dispatch.c 
b/lib/graph/rte_graph_model_mcore_dispatch.c
index a590fc9497..a81d338227 100644
--- a/lib/graph/rte_graph_model_mcore_dispatch.c
+++ b/lib/graph/rte_graph_model_mcore_dispatch.c
@@ -118,11 +118,14 @@ __rte_graph_mcore_dispatch_sched_node_enqueue(struct 
rte_node *node,
                                              struct rte_graph_rq_head *rq)
 {
        const unsigned int lcore_id = node->dispatch.lcore_id;
-       struct rte_graph *graph;
+       struct rte_graph *graph = node->dispatch.graph;
 
-       SLIST_FOREACH(graph, rq, next)
-               if (graph->dispatch.lcore_id == lcore_id)
-                       break;
+       if (unlikely((!graph) || (graph->dispatch.lcore_id != lcore_id))) {
+               SLIST_FOREACH(graph, rq, next)
+                       if (graph->dispatch.lcore_id == lcore_id)
+                               break;
+               node->dispatch.graph = graph;
+       }
 
        return graph != NULL ? __graph_sched_node_enqueue(node, graph) : false;
 }
diff --git a/lib/graph/rte_graph_worker_common.h 
b/lib/graph/rte_graph_worker_common.h
index a518af2b2a..4c2432b47f 100644
--- a/lib/graph/rte_graph_worker_common.h
+++ b/lib/graph/rte_graph_worker_common.h
@@ -110,6 +110,7 @@ struct __rte_cache_aligned rte_node {
                        unsigned int lcore_id;  /**< Node running lcore. */
                        uint64_t total_sched_objs; /**< Number of objects 
scheduled. */
                        uint64_t total_sched_fail; /**< Number of scheduled 
failure. */
+                       struct rte_graph *graph;  /**< Graph corresponding to 
lcore_id. */
                } dispatch;
        };
        rte_graph_off_t xstat_off; /**< Offset to xstat counters. */
-- 
2.27.0

Reply via email to