{"id":2220984,"url":"http://patchwork.ozlabs.org/api/1.1/patches/2220984/?format=json","web_url":"http://patchwork.ozlabs.org/project/openvswitch/patch/25cd8b136f66aa00c9f0dd478b52d1924cd3c019.1775660838.git.echaudro@redhat.com/","project":{"id":47,"url":"http://patchwork.ozlabs.org/api/1.1/projects/47/?format=json","name":"Open vSwitch","link_name":"openvswitch","list_id":"ovs-dev.openvswitch.org","list_email":"ovs-dev@openvswitch.org","web_url":"http://openvswitch.org/","scm_url":"git@github.com:openvswitch/ovs.git","webscm_url":"https://github.com/openvswitch/ovs"},"msgid":"<25cd8b136f66aa00c9f0dd478b52d1924cd3c019.1775660838.git.echaudro@redhat.com>","date":"2026-04-08T15:07:18","name":"[ovs-dev,RFC,v2] tests: Add a simple DOCA test framework.","commit_ref":null,"pull_url":null,"state":"rfc","archived":false,"hash":"d26eec363b37eb87c72ed11359748f827ad24ca2","submitter":{"id":70613,"url":"http://patchwork.ozlabs.org/api/1.1/people/70613/?format=json","name":"Eelco Chaudron","email":"echaudro@redhat.com"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/openvswitch/patch/25cd8b136f66aa00c9f0dd478b52d1924cd3c019.1775660838.git.echaudro@redhat.com/mbox/","series":[{"id":499154,"url":"http://patchwork.ozlabs.org/api/1.1/series/499154/?format=json","web_url":"http://patchwork.ozlabs.org/project/openvswitch/list/?series=499154","date":"2026-04-08T15:07:18","name":"[ovs-dev,RFC,v2] tests: Add a simple DOCA test framework.","version":2,"mbox":"http://patchwork.ozlabs.org/series/499154/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/patches/2220984/comments/","check":"fail","checks":"http://patchwork.ozlabs.org/api/patches/2220984/checks/","tags":{},"headers":{"Return-Path":"<ovs-dev-bounces@openvswitch.org>","X-Original-To":["incoming@patchwork.ozlabs.org","dev@openvswitch.org"],"Delivered-To":["patchwork-incoming@legolas.ozlabs.org","ovs-dev@lists.linuxfoundation.org"],"Authentication-Results":["legolas.ozlabs.org;\n\tdkim=fail reason=\"signature verification failed\" (1024-bit key;\n unprotected) header.d=redhat.com header.i=@redhat.com header.a=rsa-sha256\n header.s=mimecast20190719 header.b=W69cF6Wh;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=openvswitch.org\n (client-ip=140.211.166.136; helo=smtp3.osuosl.org;\n envelope-from=ovs-dev-bounces@openvswitch.org; receiver=patchwork.ozlabs.org)","smtp3.osuosl.org;\n\tdkim=fail reason=\"signature verification failed\" (1024-bit key)\n header.d=redhat.com header.i=@redhat.com header.a=rsa-sha256\n header.s=mimecast20190719 header.b=W69cF6Wh","smtp2.osuosl.org; dmarc=pass (p=quarantine dis=none)\n header.from=redhat.com","smtp2.osuosl.org;\n dkim=pass (1024-bit key) header.d=redhat.com header.i=@redhat.com\n header.a=rsa-sha256 header.s=mimecast20190719 header.b=W69cF6Wh"],"Received":["from smtp3.osuosl.org (smtp3.osuosl.org [140.211.166.136])\n\t(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n\t key-exchange x25519 server-signature ECDSA (secp384r1) server-digest SHA384)\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4frRJG41KNz1xy1\n\tfor <incoming@patchwork.ozlabs.org>; Thu, 09 Apr 2026 01:07:42 +1000 (AEST)","from localhost (localhost [127.0.0.1])\n\tby smtp3.osuosl.org (Postfix) with ESMTP id 2511160E2A;\n\tWed,  8 Apr 2026 15:07:40 +0000 (UTC)","from smtp3.osuosl.org ([127.0.0.1])\n by localhost (smtp3.osuosl.org [127.0.0.1]) (amavis, port 10024) with ESMTP\n id HUMxg5bbnfXv; Wed,  8 Apr 2026 15:07:37 +0000 (UTC)","from lists.linuxfoundation.org (lf-lists.osuosl.org [140.211.9.56])\n\tby smtp3.osuosl.org (Postfix) with ESMTPS id 6D03D60B71;\n\tWed,  8 Apr 2026 15:07:37 +0000 (UTC)","from lf-lists.osuosl.org (localhost [127.0.0.1])\n\tby lists.linuxfoundation.org (Postfix) with ESMTP id 54A1AC054A;\n\tWed,  8 Apr 2026 15:07:37 +0000 (UTC)","from smtp2.osuosl.org (smtp2.osuosl.org [IPv6:2605:bc80:3010::133])\n by lists.linuxfoundation.org (Postfix) with ESMTP id 0755EC0549\n for <dev@openvswitch.org>; Wed,  8 Apr 2026 15:07:36 +0000 (UTC)","from localhost (localhost [127.0.0.1])\n by smtp2.osuosl.org (Postfix) with ESMTP id E1AD340316\n for <dev@openvswitch.org>; Wed,  8 Apr 2026 15:07:35 +0000 (UTC)","from smtp2.osuosl.org ([127.0.0.1])\n by localhost (smtp2.osuosl.org [127.0.0.1]) (amavis, port 10024) with ESMTP\n id Gmmhv7xUdSMP for <dev@openvswitch.org>;\n Wed,  8 Apr 2026 15:07:34 +0000 (UTC)","from us-smtp-delivery-124.mimecast.com\n (us-smtp-delivery-124.mimecast.com [170.10.133.124])\n by smtp2.osuosl.org (Postfix) with ESMTPS id 2108B40315\n for <dev@openvswitch.org>; Wed,  8 Apr 2026 15:07:33 +0000 (UTC)","from mx-prod-mc-06.mail-002.prod.us-west-2.aws.redhat.com\n (ec2-35-165-154-97.us-west-2.compute.amazonaws.com [35.165.154.97]) by\n relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3,\n cipher=TLS_AES_256_GCM_SHA384) id us-mta-166-0j7yM5IRMDGnA-y1I2l0KQ-1; Wed,\n 08 Apr 2026 11:07:31 -0400","from mx-prod-int-03.mail-002.prod.us-west-2.aws.redhat.com\n (mx-prod-int-03.mail-002.prod.us-west-2.aws.redhat.com [10.30.177.12])\n (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest\n SHA256)\n (No client certificate requested)\n by mx-prod-mc-06.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTPS\n id 2D00418005B4; Wed,  8 Apr 2026 15:07:30 +0000 (UTC)","from wsfd-advnetlab224.anl.eng.rdu2.dc.redhat.com\n (wsfd-advnetlab224.anl.eng.rdu2.dc.redhat.com [10.6.42.15])\n by mx-prod-int-03.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTP\n id A9DE919560A6; Wed,  8 Apr 2026 15:07:29 +0000 (UTC)"],"X-Virus-Scanned":["amavis at osuosl.org","amavis at osuosl.org"],"X-Comment":"SPF check N/A for local connections - client-ip=140.211.9.56;\n helo=lists.linuxfoundation.org;\n envelope-from=ovs-dev-bounces@openvswitch.org; receiver=<UNKNOWN> ","DKIM-Filter":["OpenDKIM Filter v2.11.0 smtp3.osuosl.org 6D03D60B71","OpenDKIM Filter v2.11.0 smtp2.osuosl.org 2108B40315"],"Received-SPF":"Pass (mailfrom) identity=mailfrom; client-ip=170.10.133.124;\n helo=us-smtp-delivery-124.mimecast.com; envelope-from=echaudro@redhat.com;\n receiver=<UNKNOWN>","DMARC-Filter":"OpenDMARC Filter v1.4.2 smtp2.osuosl.org 2108B40315","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com;\n s=mimecast20190719; t=1775660852;\n h=from:from:reply-to:subject:subject:date:date:message-id:message-id:\n to:to:cc:cc:mime-version:mime-version:content-type:content-type:\n content-transfer-encoding:content-transfer-encoding;\n bh=4nCCy6tvM3tU5o2rqSikVsHdMTJ5879X5uHcCBydEKs=;\n b=W69cF6WhXNHrUF60r7aeQvCuONS0YJE52wzIrZHo7QWI4CNfG3T/x5REQVlsgAJay/KWG1\n j1ldIm72TqnTSPdi3ahL8fRD7EChj4K3Yf3u1pF8JWHvNaAmwAK1guE0gJNlU0WnxY4Yrb\n vPnio93AFmIV6S615nYB4yFmJtJj7Ks=","X-MC-Unique":"0j7yM5IRMDGnA-y1I2l0KQ-1","X-Mimecast-MFC-AGG-ID":"0j7yM5IRMDGnA-y1I2l0KQ_1775660850","To":"dev@openvswitch.org","Cc":"elibr@nvidia.com","Date":"Wed,  8 Apr 2026 17:07:18 +0200","Message-ID":"\n <25cd8b136f66aa00c9f0dd478b52d1924cd3c019.1775660838.git.echaudro@redhat.com>","MIME-Version":"1.0","X-Scanned-By":"MIMEDefang 3.0 on 10.30.177.12","X-Mimecast-Spam-Score":"0","X-Mimecast-MFC-PROC-ID":"bblC68ZyUfAl43VzMgBcrE13KrR7PGOsuhSebv0OFUw_1775660850","X-Mimecast-Originator":"redhat.com","Subject":"[ovs-dev] [RFC PATCH v2] tests: Add a simple DOCA test framework.","X-BeenThere":"ovs-dev@openvswitch.org","X-Mailman-Version":"2.1.30","Precedence":"list","List-Id":"<ovs-dev.openvswitch.org>","List-Unsubscribe":"<https://mail.openvswitch.org/mailman/options/ovs-dev>,\n <mailto:ovs-dev-request@openvswitch.org?subject=unsubscribe>","List-Archive":"<http://mail.openvswitch.org/pipermail/ovs-dev/>","List-Post":"<mailto:ovs-dev@openvswitch.org>","List-Help":"<mailto:ovs-dev-request@openvswitch.org?subject=help>","List-Subscribe":"<https://mail.openvswitch.org/mailman/listinfo/ovs-dev>,\n <mailto:ovs-dev-request@openvswitch.org?subject=subscribe>","From":"Eelco Chaudron via dev <ovs-dev@openvswitch.org>","Reply-To":"Eelco Chaudron <echaudro@redhat.com>","Content-Type":"text/plain; charset=\"us-ascii\"","Content-Transfer-Encoding":"7bit","Errors-To":"ovs-dev-bounces@openvswitch.org","Sender":"\"dev\" <ovs-dev-bounces@openvswitch.org>"},"content":"This patch adds userspace DOCA offload unit tests. They can be run\nwith the 'make check-doca-offloads' command. More details on how to\nset this up can be found in the testing.rst file.\n\nSigned-off-by: Eelco Chaudron <echaudro@redhat.com>\n---\n\nNOTE: This patch requires the netdev-doca series patch sent out\n      earlier by Eli Britstein, and my 'tests: Rework DPDK offload\n      tests to use a simpler interface argument' patch.\n\nChanges to v2:\n  - Use PCI address rather than port name, to be inline with the\n    rte_flow tests.\n---\n Documentation/topics/testing.rst        |  24 +++++\n tests/.gitignore                        |   3 +\n tests/automake.mk                       |  23 +++++\n tests/ofproto-macros.at                 |   1 +\n tests/system-doca-offloads-macros.at    | 118 ++++++++++++++++++++++++\n tests/system-doca-offloads-testsuite.at |  28 ++++++\n tests/system-doca-offloads.at           | 104 +++++++++++++++++++++\n tests/system-dpdk-macros.at             |  10 ++\n tests/system-dpdk-offloads-macros.at    |   9 --\n tests/system-traffic.at                 |  24 ++---\n 10 files changed, 323 insertions(+), 21 deletions(-)\n create mode 100644 tests/system-doca-offloads-macros.at\n create mode 100644 tests/system-doca-offloads-testsuite.at\n create mode 100644 tests/system-doca-offloads.at","diff":"diff --git a/Documentation/topics/testing.rst b/Documentation/topics/testing.rst\nindex 9cb9e0b5b..65e80f3d1 100644\n--- a/Documentation/topics/testing.rst\n+++ b/Documentation/topics/testing.rst\n@@ -262,6 +262,8 @@ The results of the testsuite are in ``tests/system-userspace-testsuite.dir``.\n All the features documented under `Unit Tests`_ are available for the userspace\n datapath testsuite.\n \n+.. _userspace-datapath-dpdk:\n+\n Userspace datapath with DPDK\n ++++++++++++++++++++++++++++\n \n@@ -327,6 +329,28 @@ To invoke the DPDK offloads testsuite with the userspace datapath, run::\n    This has only been tested on NVIDIA blades due to the limited availability\n    of other blades that support rte_flow.\n \n+Userspace datapath with DOCA offload\n+++++++++++++++++++++++++++++++++++++\n+\n+To invoke the userspace datapath tests with DOCA offload,\n+the same prerequisites apply as for :ref:`userspace-datapath-dpdk`.\n+In addition, six Virtual Function (VF) interfaces must be preconfigured on a\n+single Physical Function (PF) that supports DOCA hardware offload.\n+\n+This is an example on how to set this up for an NVIDIA blade on port\n+``ens2f0np0``::\n+\n+   OVS_DOCA_PF_PORT=ens2f0np0\n+   OVS_PF_PCI=$(basename $(readlink /sys/class/net/$OVS_DOCA_PF_PORT/device))\n+   echo 0 > /sys/bus/pci/devices/$OVS_PF_PCI/sriov_numvfs\n+   devlink dev eswitch set pci/$OVS_PF_PCI mode switchdev\n+   echo 6 > /sys/bus/pci/devices/$OVS_PF_PCI/sriov_numvfs\n+\n+This PF's PCI ID needs to be passed with the OVS_PF_PORT variable.\n+To invoke the DOCA offloads testsuite with the userspace datapath, run::\n+\n+    make check-doca-offloads OVS_PF_PCI=0000:17:00.0\n+\n Userspace datapath: Testing and Validation of CPU-specific Optimizations\n ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++\n \ndiff --git a/tests/.gitignore b/tests/.gitignore\nindex b76025d9a..597c83a7f 100644\n--- a/tests/.gitignore\n+++ b/tests/.gitignore\n@@ -32,6 +32,9 @@\n /system-offloads-testsuite\n /system-offloads-testsuite.dir/\n /system-offloads-testsuite.log\n+/system-doca-offloads-testsuite\n+/system-doca-offloads-testsuite.dir/\n+/system-doca-offloads-testsuite.log\n /system-dpdk-offloads-testsuite\n /system-dpdk-offloads-testsuite.dir/\n /system-dpdk-offloads-testsuite.log\ndiff --git a/tests/automake.mk b/tests/automake.mk\nindex f61e66866..74115b8d9 100644\n--- a/tests/automake.mk\n+++ b/tests/automake.mk\n@@ -7,6 +7,7 @@ EXTRA_DIST += \\\n \t$(SYSTEM_TSO_TESTSUITE_AT) \\\n \t$(SYSTEM_AFXDP_TESTSUITE_AT) \\\n \t$(SYSTEM_OFFLOADS_TESTSUITE_AT) \\\n+\t$(SYSTEM_DOCA_OFFLOADS_TESTSUITE_AT) \\\n \t$(SYSTEM_DPDK_OFFLOADS_TESTSUITE_AT) \\\n \t$(SYSTEM_DPDK_TESTSUITE_AT) \\\n \t$(OVSDB_CLUSTER_TESTSUITE_AT) \\\n@@ -16,6 +17,7 @@ EXTRA_DIST += \\\n \t$(SYSTEM_TSO_TESTSUITE) \\\n \t$(SYSTEM_AFXDP_TESTSUITE) \\\n \t$(SYSTEM_OFFLOADS_TESTSUITE) \\\n+\t$(SYSTEM_DOCA_OFFLOADS_TESTSUITE) \\\n \t$(SYSTEM_DPDK_OFFLOADS_TESTSUITE) \\\n \t$(SYSTEM_DPDK_TESTSUITE) \\\n \t$(OVSDB_CLUSTER_TESTSUITE) \\\n@@ -188,6 +190,12 @@ SYSTEM_OFFLOADS_TESTSUITE_AT = \\\n \ttests/system-offloads-testsuite.at \\\n \ttests/system-offloads-testsuite-macros.at\n \n+SYSTEM_DOCA_OFFLOADS_TESTSUITE_AT = \\\n+\ttests/system-common-macros.at \\\n+\ttests/system-doca-offloads.at \\\n+\ttests/system-doca-offloads-macros.at \\\n+\ttests/system-doca-offloads-testsuite.at\n+\n SYSTEM_DPDK_OFFLOADS_TESTSUITE_AT = \\\n \ttests/system-common-macros.at \\\n \ttests/system-dpdk-macros.at \\\n@@ -211,6 +219,7 @@ SYSTEM_USERSPACE_TESTSUITE = $(srcdir)/tests/system-userspace-testsuite\n SYSTEM_TSO_TESTSUITE = $(srcdir)/tests/system-tso-testsuite\n SYSTEM_AFXDP_TESTSUITE = $(srcdir)/tests/system-afxdp-testsuite\n SYSTEM_OFFLOADS_TESTSUITE = $(srcdir)/tests/system-offloads-testsuite\n+SYSTEM_DOCA_OFFLOADS_TESTSUITE = $(srcdir)/tests/system-doca-offloads-testsuite\n SYSTEM_DPDK_OFFLOADS_TESTSUITE = $(srcdir)/tests/system-dpdk-offloads-testsuite\n SYSTEM_DPDK_TESTSUITE = $(srcdir)/tests/system-dpdk-testsuite\n OVSDB_CLUSTER_TESTSUITE = $(srcdir)/tests/ovsdb-cluster-testsuite\n@@ -325,6 +334,12 @@ check-offloads-valgrind: all $(valgrind_wrappers) $(check_DATA)\n \t@echo '----------------------------------------------------------------------'\n \t@echo 'Valgrind output can be found in tests/system-offloads-testsuite.dir/*/valgrind.*'\n \t@echo '----------------------------------------------------------------------'\n+check-doca-offloads-valgrind: all $(valgrind_wrappers) $(check_DATA)\n+\t$(SHELL) '$(SYSTEM_DOCA_OFFLOADS_TESTSUITE)' -C tests VALGRIND='$(VALGRIND)' AUTOTEST_PATH='tests/valgrind:$(AUTOTEST_PATH)' -d $(TESTSUITEFLAGS) -j1\n+\t@echo\n+\t@echo '----------------------------------------------------------------------'\n+\t@echo 'Valgrind output can be found in tests/system-doca-offloads-testsuite.dir/*/valgrind.*'\n+\t@echo '----------------------------------------------------------------------'\n check-dpdk-offloads-valgrind: all $(valgrind_wrappers) $(check_DATA)\n \t$(SHELL) '$(SYSTEM_DPDK_OFFLOADS_TESTSUITE)' -C tests VALGRIND='$(VALGRIND)' AUTOTEST_PATH='tests/valgrind:$(AUTOTEST_PATH)' -d $(TESTSUITEFLAGS) -j1\n \t@echo\n@@ -373,6 +388,10 @@ check-offloads: all\n \tset $(SHELL) '$(SYSTEM_OFFLOADS_TESTSUITE)' -C tests  AUTOTEST_PATH='$(AUTOTEST_PATH)'; \\\n \t\"$$@\" $(TESTSUITEFLAGS) -j1 || (test X'$(RECHECK)' = Xyes && \"$$@\" --recheck)\n \n+check-doca-offloads: all\n+\tset $(SHELL) '$(SYSTEM_DOCA_OFFLOADS_TESTSUITE)' -C tests  AUTOTEST_PATH='$(AUTOTEST_PATH)'; \\\n+\t\"$$@\" $(TESTSUITEFLAGS) -j1 || (test X'$(RECHECK)' = Xyes && \"$$@\" --recheck)\n+\n check-dpdk-offloads: all\n \tset $(SHELL) '$(SYSTEM_DPDK_OFFLOADS_TESTSUITE)' -C tests  AUTOTEST_PATH='$(AUTOTEST_PATH)'; \\\n \t\"$$@\" $(TESTSUITEFLAGS) -j1 || (test X'$(RECHECK)' = Xyes && \"$$@\" --recheck)\n@@ -422,6 +441,10 @@ $(SYSTEM_OFFLOADS_TESTSUITE): package.m4 $(SYSTEM_TESTSUITE_AT) $(SYSTEM_OFFLOAD\n \t$(AM_V_GEN)$(AUTOTEST) -I '$(srcdir)' -o $@.tmp $@.at\n \t$(AM_V_at)mv $@.tmp $@\n \n+$(SYSTEM_DOCA_OFFLOADS_TESTSUITE): package.m4 $(SYSTEM_TESTSUITE_AT) $(SYSTEM_DOCA_OFFLOADS_TESTSUITE_AT) $(COMMON_MACROS_AT)\n+\t$(AM_V_GEN)$(AUTOTEST) -I '$(srcdir)' -o $@.tmp $@.at\n+\t$(AM_V_at)mv $@.tmp $@\n+\n $(SYSTEM_DPDK_OFFLOADS_TESTSUITE): package.m4 $(SYSTEM_TESTSUITE_AT) $(SYSTEM_DPDK_OFFLOADS_TESTSUITE_AT) $(COMMON_MACROS_AT)\n \t$(AM_V_GEN)$(AUTOTEST) -I '$(srcdir)' -o $@.tmp $@.at\n \t$(AM_V_at)mv $@.tmp $@\ndiff --git a/tests/ofproto-macros.at b/tests/ofproto-macros.at\nindex 7f6ab8904..874020071 100644\n--- a/tests/ofproto-macros.at\n+++ b/tests/ofproto-macros.at\n@@ -228,6 +228,7 @@ m4_define([_OVS_VSWITCHD_START],\n /probe tc:/d\n /setting extended ack support failed/d\n /tc: Using policy/d\n+/DOCA Disabled - Use other_config:doca-init to enable/d\n /hw-offload-priority configuration has an unknown type;/d']])\n ])\n \ndiff --git a/tests/system-doca-offloads-macros.at b/tests/system-doca-offloads-macros.at\nnew file mode 100644\nindex 000000000..56da421af\n--- /dev/null\n+++ b/tests/system-doca-offloads-macros.at\n@@ -0,0 +1,118 @@\n+AT_COPYRIGHT([Copyright (c) 2026 Red Hat, Inc.\n+\n+Licensed under the Apache License, Version 2.0 (the \"License\");\n+you may not use this file except in compliance with the License.\n+You may obtain a copy of the License at:\n+\n+    http://www.apache.org/licenses/LICENSE-2.0\n+\n+Unless required by applicable law or agreed to in writing, software\n+distributed under the License is distributed on an \"AS IS\" BASIS,\n+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n+See the License for the specific language governing permissions and\n+limitations under the License.])\n+\n+# We also skip any DPDK_OFFLOAD-skipped tests for the same reasons.\n+# For details, see the macro definition in the system-dpdk-offload.at file.\n+m4_define([CHECK_NO_DPDK_OFFLOAD],\n+[\n+     AT_SKIP_IF([:])\n+])\n+\n+# OVS_DOCA_OFFLOAD_PRE_CHECK()\n+#\n+# Check prerequisites for DOCA tests, i.e. make sure PF exists with the\n+# corresponding VFs.\n+#\n+m4_define([OVS_DOCA_OFFLOAD_PRE_CHECK], [\n+  OVS_DPDK_PRE_CHECK()\n+  AT_SKIP_IF([test -z \"$OVS_PF_PCI\"])\n+  AT_SKIP_IF([! ovs_verify_pf_cfg \"$OVS_PF_PCI\"])\n+])\n+\n+# OVS_TRAFFIC_VSWITCHD_START([vsctl-args], [vsctl-output], [dbinit-aux-args])\n+#\n+# This is a copy from system-dpdk-macro.at with the following changes:\n+#  1) Use OVS_DOCA_OFFLOAD_PRE_CHECK() instead of OVS_DPDK_PRE_CHECK().\n+#  2) Start with minimal PCI allowlist (only allows dummy device 0000:00:00.0).\n+#  3) Enable DOCA and hardware offload.\n+#\n+m4_define([OVS_TRAFFIC_VSWITCHD_START],\n+  [\n+   OVS_DOCA_OFFLOAD_PRE_CHECK()\n+   OVS_DOCA_PF_PORT=$(basename $(ls -d /sys/bus/pci/devices/$OVS_PF_PCI/net/* \\\n+                                 2>/dev/null | head -n 1))\n+   OVS_WAIT_WHILE([ip link show ovs-netdev])\n+   OVS_DPDK_START([-a 0000:00:00.0], [--disable-system],\n+                  [-- set Open_vSwitch . other_config:doca-init=true dnl\n+                   -- set Open_vSwitch . other_config:hw-offload=true $3])\n+   dnl Add bridges, ports, etc.\n+   OVS_WAIT_WHILE([ip link show br0])\n+   AT_CHECK([ovs-vsctl -- _ADD_BR([br0]) -- $1 m4_if([$2], [], [],\n+            [| uuidfilt])], [0], [$2])\n+   AT_CHECK([ovs-vsctl -- _ADD_BR([brPF])])\n+   AT_CHECK([ovs-vsctl add-port brPF $OVS_DOCA_PF_PORT -- dnl\n+             set interface $OVS_DOCA_PF_PORT type=doca])\n+])\n+\n+# OVS_TRAFFIC_VSWITCHD_STOP([ALLOWLIST], [extra_cmds])\n+#\n+# This is a copy from system-dpdk-macro.at adding some doca offload specific\n+# error message exclusion.\n+#\n+m4_define([OVS_TRAFFIC_VSWITCHD_STOP],\n+  [OVS_DPDK_STOP_VSWITCHD([dnl\n+$1\";/mlx5_net: Failed to update link status: /d\"])\n+   AT_CHECK([:; $2])\n+])\n+\n+# ADD_{VF|VETH}([port], [namespace], [ovs-br], [ip_addr] [mac_addr], [gateway],\n+#               [ip_addr_flags])\n+#\n+# Simulate the ADD_VETH() macro defined in system-common-macros.at, allowing\n+# us to run the existing system-traffic unit tests without any test-specific\n+# changes.  This is consistent with how DPDK and AF_XDP run the system tests,\n+# except that we are not using actual veth devices, but VF representor ports.\n+#\n+m4_define([ADD_VF],\n+    [ USER_PORT=$1\n+      case \"$USER_PORT\" in\n+        client) PORT_NO=0 ;;\n+        server) PORT_NO=1 ;;\n+        *) PORT_NO=${USER_PORT##*[!0-9]} ;;\n+      esac\n+\n+      AT_CHECK([[[ \"$PORT_NO\" -ge 0 ]] && [[ \"$PORT_NO\" -le 5 ]] || return 66])\n+\n+      VF=$(ovs_get_vf_netdev $OVS_PF_PCI $PORT_NO)\n+      REP=$(ovs_get_representor_netdev $OVS_PF_PCI $PORT_NO)\n+      AT_CHECK([test -n \"$VF\"])\n+      AT_CHECK([test -n \"$REP\"])\n+\n+      AT_CHECK([ip link set $REP name ovs-$1])\n+      AT_CHECK([ip link set $VF down])\n+      AT_CHECK([ip link set $VF name $1])\n+      AT_CHECK([ip link set $1 netns $2])\n+      AT_CHECK([ovs-vsctl add-port $3 ovs-$1 -- \\\n+                set interface ovs-$1 external-ids:iface-id=\"$1\" -- \\\n+                set interface ovs-$1 type=doca])\n+\n+      NS_CHECK_EXEC([$2], [ip addr add $4 dev $1 $7])\n+      NS_CHECK_EXEC([$2], [ip link set dev $1 up])\n+      if test -n \"$5\"; then\n+        NS_CHECK_EXEC([$2], [ip link set dev $1 address $5])\n+      else\n+        NS_CHECK_EXEC([$2],\n+                      [ip link set dev $1 address 02:00:00:00:EC:0$PORT_NO])\n+      fi\n+      if test -n \"$6\"; then\n+        NS_CHECK_EXEC([$2], [ip route add default via $6])\n+      fi\n+      on_exit \"ip netns exec $2 ip link set $1 netns 1; \\\n+               ip link property del dev $1 altname $VF; \\\n+               ip link property del dev ovs-$1 altname $REP; \\\n+               ip link set $1 name $VF; \\\n+               ip link set ovs-$1 name $REP\"\n+    ]\n+)\n+m4_define([ADD_VETH], [ADD_VF($@)])\ndiff --git a/tests/system-doca-offloads-testsuite.at b/tests/system-doca-offloads-testsuite.at\nnew file mode 100644\nindex 000000000..f69d872bf\n--- /dev/null\n+++ b/tests/system-doca-offloads-testsuite.at\n@@ -0,0 +1,28 @@\n+AT_INIT\n+\n+AT_COPYRIGHT([Copyright (c) 2026 Red Hat, Inc.\n+\n+Licensed under the Apache License, Version 2.0 (the \"License\");\n+you may not use this file except in compliance with the License.\n+You may obtain a copy of the License at:\n+\n+    http://www.apache.org/licenses/LICENSE-2.0\n+\n+Unless required by applicable law or agreed to in writing, software\n+distributed under the License is distributed on an \"AS IS\" BASIS,\n+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n+See the License for the specific language governing permissions and\n+limitations under the License.])\n+\n+m4_ifdef([AT_COLOR_TESTS], [AT_COLOR_TESTS])\n+\n+m4_include([tests/ovs-macros.at])\n+m4_include([tests/ovsdb-macros.at])\n+m4_include([tests/ofproto-macros.at])\n+m4_include([tests/system-common-macros.at])\n+m4_include([tests/system-userspace-macros.at])\n+m4_include([tests/system-dpdk-macros.at])\n+m4_include([tests/system-doca-offloads-macros.at])\n+\n+m4_include([tests/system-doca-offloads.at])\n+m4_include([tests/system-traffic.at])\ndiff --git a/tests/system-doca-offloads.at b/tests/system-doca-offloads.at\nnew file mode 100644\nindex 000000000..0b579a58c\n--- /dev/null\n+++ b/tests/system-doca-offloads.at\n@@ -0,0 +1,104 @@\n+AT_COPYRIGHT([Copyright (c) 2026 Red Hat, Inc.\n+\n+Licensed under the Apache License, Version 2.0 (the \"License\");\n+you may not use this file except in compliance with the License.\n+You may obtain a copy of the License at:\n+\n+    http://www.apache.org/licenses/LICENSE-2.0\n+\n+Unless required by applicable law or agreed to in writing, software\n+distributed under the License is distributed on an \"AS IS\" BASIS,\n+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n+See the License for the specific language governing permissions and\n+limitations under the License.])\n+\n+AT_BANNER([DOCA offload unit tests])\n+\n+AT_SETUP([doca offload - ping between two hardware offloaded ports])\n+OVS_DOCA_OFFLOAD_PRE_CHECK()\n+OVS_TRAFFIC_VSWITCHD_START()\n+AT_CHECK([ovs-appctl vlog/set netdev_doca:dbg])\n+\n+AT_CHECK([ovs-ofctl add-flow br0 \"actions=normal\"])\n+ADD_NAMESPACES(at_ns0, at_ns1)\n+ADD_VF(p0, at_ns0, br0, \"10.1.1.1/24\")\n+ADD_VF(p1, at_ns1, br0, \"10.1.1.2/24\")\n+\n+NS_CHECK_EXEC([at_ns0], [ping -q -c 3 -i 0.3 -W 2 10.1.1.2 \\\n+                         | FORMAT_PING], [0], [dnl\n+3 packets transmitted, 3 received, 0% packet loss, time 0ms\n+])\n+\n+# Once actual hardware offload is supported, type should be changed from 'ovs'\n+# to 'doca,offloaded'.\n+OVS_WAIT_UNTIL_EQUAL(\n+  [ovs-appctl dpctl/dump-flows --names type=ovs \\\n+   | DUMP_DP_IP_CLEAN_SORTED], [dnl\n+in_port(ovs-p0),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p1\n+in_port(ovs-p1),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p0])\n+\n+OVS_TRAFFIC_VSWITCHD_STOP\n+AT_CLEANUP\n+\n+AT_SETUP([doca offload - ping between six hardware offloaded ports])\n+OVS_DOCA_OFFLOAD_PRE_CHECK()\n+OVS_TRAFFIC_VSWITCHD_START()\n+\n+AT_CHECK([ovs-ofctl add-flow br0 \"actions=normal\"])\n+AT_CHECK([ovs-vsctl set Open_vSwitch . other_config:max-idle=20000])\n+ADD_NAMESPACES(at_ns0, at_ns1, at_ns2, at_ns3, at_ns4, at_ns5)\n+ADD_VF(p0, at_ns0, br0, \"10.1.1.1/24\")\n+ADD_VF(p1, at_ns1, br0, \"10.1.1.2/24\")\n+ADD_VF(p2, at_ns2, br0, \"10.1.1.3/24\")\n+ADD_VF(p3, at_ns3, br0, \"10.1.1.4/24\")\n+ADD_VF(p4, at_ns4, br0, \"10.1.1.5/24\")\n+ADD_VF(p5, at_ns5, br0, \"10.1.1.6/24\")\n+\n+for NS in $(seq 0 5); do\n+    START=$((NS + 2))\n+    for IP in $(seq \"$START\" 6); do\n+        NS_CHECK_EXEC([at_ns$NS], [ping -q -c 3 -i 0.3 -W 2 10.1.1.$IP \\\n+                                   | FORMAT_PING], [0], [dnl\n+3 packets transmitted, 3 received, 0% packet loss, time 0ms\n+])\n+    done\n+done\n+\n+# Once actual hardware offload is supported, type should be changed from 'ovs'\n+# to 'doca,offloaded'.\n+OVS_WAIT_UNTIL_EQUAL(\n+  [ovs-appctl dpctl/dump-flows --names type=ovs \\\n+   | DUMP_DP_IP_CLEAN_SORTED], [dnl\n+in_port(ovs-p0),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p1\n+in_port(ovs-p0),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p2\n+in_port(ovs-p0),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p3\n+in_port(ovs-p0),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p4\n+in_port(ovs-p0),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p5\n+in_port(ovs-p1),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p0\n+in_port(ovs-p1),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p2\n+in_port(ovs-p1),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p3\n+in_port(ovs-p1),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p4\n+in_port(ovs-p1),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p5\n+in_port(ovs-p2),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p0\n+in_port(ovs-p2),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p1\n+in_port(ovs-p2),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p3\n+in_port(ovs-p2),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p4\n+in_port(ovs-p2),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p5\n+in_port(ovs-p3),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p0\n+in_port(ovs-p3),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p1\n+in_port(ovs-p3),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p2\n+in_port(ovs-p3),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p4\n+in_port(ovs-p3),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p5\n+in_port(ovs-p4),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p0\n+in_port(ovs-p4),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p1\n+in_port(ovs-p4),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p2\n+in_port(ovs-p4),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p3\n+in_port(ovs-p4),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p5\n+in_port(ovs-p5),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p0\n+in_port(ovs-p5),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p1\n+in_port(ovs-p5),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p2\n+in_port(ovs-p5),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p3\n+in_port(ovs-p5),eth(macs),eth_type(0x0800),ipv4(frag=no), packets:2, bytes:196, used:0.0s, actions:ovs-p4])\n+\n+OVS_TRAFFIC_VSWITCHD_STOP\n+AT_CLEANUP\ndiff --git a/tests/system-dpdk-macros.at b/tests/system-dpdk-macros.at\nindex f8ba76673..8f669eebc 100644\n--- a/tests/system-dpdk-macros.at\n+++ b/tests/system-dpdk-macros.at\n@@ -199,3 +199,13 @@ m4_define([CONFIGURE_VETH_OFFLOADS],\n     [AT_CHECK([ethtool -K $1 tx off], [0], [ignore], [ignore])\n      AT_CHECK([ethtool -K $1 txvlan off], [0], [ignore], [ignore])]\n )\n+\n+\n+# DUMP_DP_IP_CLEAN_SORTED()\n+#\n+# Clean up and sort the ovs-appctl dpctl/dump-flows output for comparing.\n+#\n+m4_define([DUMP_DP_IP_CLEAN_SORTED], [dnl\n+  grep 'eth_type(0x0800)' \\\n+    | sed -e 's/eth(src=[[a-z0-9:]]*,dst=[[a-z0-9:]]*)/eth(macs)/;s/recirc_id(0),//' \\\n+    | strip_used | strip_ptype | sort])\n\\ No newline at end of file\ndiff --git a/tests/system-dpdk-offloads-macros.at b/tests/system-dpdk-offloads-macros.at\nindex 1ea089290..8eb108613 100644\n--- a/tests/system-dpdk-offloads-macros.at\n+++ b/tests/system-dpdk-offloads-macros.at\n@@ -147,12 +147,3 @@ m4_define([ADD_VF],\n     ]\n )\n m4_define([ADD_VETH], [ADD_VF($@)])\n-\n-# DUMP_DP_IP_CLEAN_SORTED()\n-#\n-# Clean up and sort the ovs-dpctl dump-flow output for comparing.\n-#\n-m4_define([DUMP_DP_IP_CLEAN_SORTED], [dnl\n-  grep 'eth_type(0x0800)' \\\n-    | sed -e 's/eth(src=[[a-z0-9:]]*,dst=[[a-z0-9:]]*)/eth(macs)/;s/recirc_id(0),//' \\\n-    | strip_used | strip_ptype | sort])\ndiff --git a/tests/system-traffic.at b/tests/system-traffic.at\nindex 8f4fdf8b1..4faa63aef 100644\n--- a/tests/system-traffic.at\n+++ b/tests/system-traffic.at\n@@ -2207,9 +2207,9 @@ dnl SLOW_ACTION test1: check datapatch actions\n AT_CHECK([ovs-ofctl del-flows br0])\n AT_CHECK([ovs-ofctl add-flows br0 flows.txt])\n \n-AT_CHECK([ovs-appctl ofproto/trace br0 \"in_port=1,dl_type=0x800,dl_src=e6:66:c1:11:11:11,dl_dst=e6:66:c1:22:22:22,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=6,tp_src=8,tp_dst=9\"], [0], [stdout])\n+AT_CHECK([ovs-appctl ofproto/trace --names br0 \"in_port=1,dl_type=0x800,dl_src=e6:66:c1:11:11:11,dl_dst=e6:66:c1:22:22:22,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=6,tp_src=8,tp_dst=9\"], [0], [stdout])\n AT_CHECK([tail -3 stdout], [0],\n-[Datapath actions: trunc(100),3,5,trunc(100),3,trunc(100),5,3,trunc(200),5,trunc(65535),3\n+[Datapath actions: trunc(100),ovs-p1,ovs-p2,trunc(100),ovs-p1,trunc(100),ovs-p2,ovs-p1,trunc(200),ovs-p2,trunc(65535),ovs-p1\n This flow is handled by the userspace slow path because it:\n   - Uses action(s) not supported by datapath.\n ])\n@@ -2548,10 +2548,10 @@ AT_CHECK([ovs-ofctl add-flows br0 flows.txt])\n dnl Generate some traffic.\n NS_CHECK_EXEC([at_ns0], [ping -q -c 10 -i 0.1 -w 2 10.1.1.2], [1], [ignore])\n \n-OVS_WAIT_UNTIL_EQUAL([ovs-appctl dpctl/dump-flows | grep \"eth_type(0x0800)\" | dnl\n-                      strip_ptype | strip_eth | strip_recirc | strip_stats | dnl\n-                      strip_used | sort], [dnl\n-recirc_id(<recirc>),in_port(2),eth_type(0x0800),ipv4(frag=no), packets:0, bytes:0, used:0.0s, actions:drop])\n+OVS_WAIT_UNTIL_EQUAL([ovs-appctl dpctl/dump-flows --names | dnl\n+                      grep \"eth_type(0x0800)\" | strip_ptype | strip_eth | dnl\n+                      strip_recirc | strip_stats | strip_used | sort], [dnl\n+recirc_id(<recirc>),in_port(ovs-p0),eth_type(0x0800),ipv4(frag=no), packets:0, bytes:0, used:0.0s, actions:drop])\n \n OVS_TRAFFIC_VSWITCHD_STOP([\"/WARN/d\"])\n AT_CLEANUP\n@@ -2703,11 +2703,11 @@ NS_CHECK_EXEC([at_ns0], [$PYTHON3 $srcdir/sendpkt.py p0 \\\n     $(ovs-ofctl compose-packet --bare 'ND_NS_PKT,nd_target=2001::1:0:392')],\n   [0], [ignore])\n \n-AT_CHECK([ovs-appctl dpctl/dump-flows | strip_stats | strip_used | dnl\n+AT_CHECK([ovs-appctl dpctl/dump-flows --names | strip_stats | strip_used | dnl\n           strip_key32 | strip_ptype | strip_eth | strip_recirc | dnl\n           grep \",nd\" | sort], [0], [dnl\n-recirc_id(<recirc>),in_port(2),eth(src=36:b1:ee:7c:01:03,dst=36:b1:ee:7c:01:02),eth_type(0x86dd),ipv6(proto=58,frag=no),icmpv6(type=136),nd(target=2001::1:0:392), packets:0, bytes:0, used:never, actions:1,3\n-recirc_id(<recirc>),in_port(2),eth_type(0x86dd),ipv6(proto=58,frag=no),icmpv6(type=136),nd(target=3000::1), packets:0, bytes:0, used:never, actions:drop\n+recirc_id(<recirc>),in_port(ovs-p0),eth(src=36:b1:ee:7c:01:03,dst=36:b1:ee:7c:01:02),eth_type(0x86dd),ipv6(proto=58,frag=no),icmpv6(type=136),nd(target=2001::1:0:392), packets:0, bytes:0, used:never, actions:br0,ovs-p1\n+recirc_id(<recirc>),in_port(ovs-p0),eth_type(0x86dd),ipv6(proto=58,frag=no),icmpv6(type=136),nd(target=3000::1), packets:0, bytes:0, used:never, actions:drop\n ])\n \n OVS_WAIT_UNTIL([ovs-appctl dpctl/dump-flows | grep \",nd\" | wc -l | grep -E ^0])\n@@ -2722,11 +2722,11 @@ NS_CHECK_EXEC([at_ns0], [$PYTHON3 $srcdir/sendpkt.py p0 \\\n     $(ovs-ofctl compose-packet --bare 'ND_NS_PKT,nd_target=3000::1')],\n   [0], [ignore])\n \n-AT_CHECK([ovs-appctl dpctl/dump-flows | strip_stats | strip_used | dnl\n+AT_CHECK([ovs-appctl dpctl/dump-flows --names | strip_stats | strip_used | dnl\n           strip_key32 | strip_ptype | strip_eth | strip_recirc | dnl\n           grep \",nd\" | sort], [0], [dnl\n-recirc_id(<recirc>),in_port(2),eth(src=36:b1:ee:7c:01:03,dst=36:b1:ee:7c:01:02),eth_type(0x86dd),ipv6(proto=58,frag=no),icmpv6(type=136),nd(target=2001::1:0:392), packets:0, bytes:0, used:never, actions:1,3\n-recirc_id(<recirc>),in_port(2),eth_type(0x86dd),ipv6(proto=58,frag=no),icmpv6(type=136),nd(target=3000::1), packets:0, bytes:0, used:never, actions:drop\n+recirc_id(<recirc>),in_port(ovs-p0),eth(src=36:b1:ee:7c:01:03,dst=36:b1:ee:7c:01:02),eth_type(0x86dd),ipv6(proto=58,frag=no),icmpv6(type=136),nd(target=2001::1:0:392), packets:0, bytes:0, used:never, actions:br0,ovs-p1\n+recirc_id(<recirc>),in_port(ovs-p0),eth_type(0x86dd),ipv6(proto=58,frag=no),icmpv6(type=136),nd(target=3000::1), packets:0, bytes:0, used:never, actions:drop\n ])\n \n OVS_TRAFFIC_VSWITCHD_STOP\n","prefixes":["ovs-dev","RFC","v2"]}