[ovs-dev] [PATCH V3 03/14] netdev-offload: Introduce an API to traverse ports

Eli Britstein elibr at nvidia.com
Tue Mar 2 11:25:25 UTC 2021


Introduce an API to traverse the ports added to the offload ports map,
with a generic callback for each one.

Signed-off-by: Eli Britstein <elibr at nvidia.com>
Reviewed-by: Gaetan Rivet <gaetanr at nvidia.com>
---
 lib/netdev-offload.c | 18 ++++++++++++++++++
 lib/netdev-offload.h |  8 ++++++++
 2 files changed, 26 insertions(+)

diff --git a/lib/netdev-offload.c b/lib/netdev-offload.c
index e5d24651f..10f543018 100644
--- a/lib/netdev-offload.c
+++ b/lib/netdev-offload.c
@@ -458,6 +458,24 @@ netdev_ports_flow_flush(const char *dpif_type)
     ovs_rwlock_unlock(&netdev_hmap_rwlock);
 }
 
+void
+netdev_ports_traverse(const char *dpif_type,
+                      bool (*cb)(struct netdev *, odp_port_t, void *),
+                      void *aux)
+{
+    struct port_to_netdev_data *data;
+
+    ovs_rwlock_rdlock(&netdev_hmap_rwlock);
+    HMAP_FOR_EACH (data, portno_node, &port_to_netdev) {
+        if (netdev_get_dpif_type(data->netdev) == dpif_type) {
+            if (cb(data->netdev, data->dpif_port.port_no, aux)) {
+                break;
+            }
+        }
+    }
+    ovs_rwlock_unlock(&netdev_hmap_rwlock);
+}
+
 struct netdev_flow_dump **
 netdev_ports_flow_dump_create(const char *dpif_type, int *ports, bool terse)
 {
diff --git a/lib/netdev-offload.h b/lib/netdev-offload.h
index b063c43a3..5bf89f891 100644
--- a/lib/netdev-offload.h
+++ b/lib/netdev-offload.h
@@ -113,6 +113,14 @@ struct netdev *netdev_ports_get(odp_port_t port, const char *dpif_type);
 int netdev_ports_remove(odp_port_t port, const char *dpif_type);
 odp_port_t netdev_ifindex_to_odp_port(int ifindex);
 
+/* For each of the ports with dpif_type, call cb with the netdev and port
+ * number of the port, and an opaque user argument.
+ * The returned value is used to continue traversing upon false or stop if
+ * true.
+ */
+void netdev_ports_traverse(const char *dpif_type,
+                           bool (*cb)(struct netdev *, odp_port_t, void *),
+                           void *aux);
 struct netdev_flow_dump **netdev_ports_flow_dump_create(
                                         const char *dpif_type,
                                         int *ports,
-- 
2.28.0.2311.g225365fb51



More information about the dev mailing list