@@ -1601,6 +1601,28 @@ netdev_offload_dpdk_flow_flush(struct netdev *netdev)
return 0;
}
+static int
+netdev_offload_dpdk_flow_dump_create(struct netdev *netdev,
+ struct netdev_flow_dump **dump_out,
+ bool terse OVS_UNUSED)
+{
+ struct netdev_flow_dump *dump;
+
+ dump = xzalloc(sizeof *dump);
+ dump->netdev = netdev_ref(netdev);
+
+ *dump_out = dump;
+ return 0;
+}
+
+static int
+netdev_offload_dpdk_flow_dump_destroy(struct netdev_flow_dump *dump)
+{
+ netdev_close(dump->netdev);
+ free(dump);
+ return 0;
+}
+
const struct netdev_flow_api netdev_offload_dpdk = {
.type = "dpdk_flow_api",
.flow_put = netdev_offload_dpdk_flow_put,
@@ -1608,4 +1630,6 @@ const struct netdev_flow_api netdev_offload_dpdk = {
.init_flow_api = netdev_offload_dpdk_init_flow_api,
.flow_get = netdev_offload_dpdk_flow_get,
.flow_flush = netdev_offload_dpdk_flow_flush,
+ .flow_dump_create = netdev_offload_dpdk_flow_dump_create,
+ .flow_dump_destroy = netdev_offload_dpdk_flow_dump_destroy,
};
When offloading vports, we don't configure rte_flow on the vport itself, as it is not a physical dpdk port, but rather on uplinks. Implement those APIs as a pre-step to enable iterate over the ports. Signed-off-by: Eli Britstein <elibr@nvidia.com> --- lib/netdev-offload-dpdk.c | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+)