5 #ifndef _RTE_GRAPH_MODEL_MCORE_DISPATCH_H_ 6 #define _RTE_GRAPH_MODEL_MCORE_DISPATCH_H_ 30 #define RTE_GRAPH_SCHED_WQ_SIZE_MULTIPLIER 8 31 #define RTE_GRAPH_SCHED_WQ_SIZE(nb_nodes) \ 32 ((typeof(nb_nodes))((nb_nodes) * RTE_GRAPH_SCHED_WQ_SIZE_MULTIPLIER)) 52 bool __rte_noinline __rte_graph_mcore_dispatch_sched_node_enqueue(
struct rte_node *node,
53 struct rte_graph_rq_head *rq);
68 void __rte_graph_mcore_dispatch_sched_wq_process(
struct rte_graph *graph);
84 unsigned int lcore_id);
101 uint32_t head = graph->head;
102 struct rte_node *node;
104 if (graph->dispatch.wq != NULL)
105 __rte_graph_mcore_dispatch_sched_wq_process(graph);
107 while (
likely(head != graph->tail)) {
108 node = (
struct rte_node *)
RTE_PTR_ADD(graph, cir_start[(int32_t)head++]);
111 if ((int32_t)head < 0 && node->dispatch.lcore_id != graph->dispatch.lcore_id)
115 if (node->dispatch.lcore_id != RTE_MAX_LCORE &&
116 graph->dispatch.lcore_id != node->dispatch.lcore_id &&
117 graph->dispatch.rq != NULL &&
118 __rte_graph_mcore_dispatch_sched_node_enqueue(node, graph->dispatch.rq))
121 __rte_node_process(graph, node);
123 head =
likely((int32_t)head > 0) ? head & mask : head;
#define RTE_PTR_ADD(ptr, x)
__rte_experimental int rte_graph_model_mcore_dispatch_node_lcore_affinity_set(const char *name, unsigned int lcore_id)
static __rte_experimental void rte_graph_walk_mcore_dispatch(struct rte_graph *graph)