Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/95089/?format=api
http://patches.dpdk.org/api/patches/95089/?format=api", "web_url": "http://patches.dpdk.org/project/dts/patch/20210701135738.18513-3-zhiminx.huang@intel.com/", "project": { "id": 3, "url": "http://patches.dpdk.org/api/projects/3/?format=api", "name": "DTS", "link_name": "dts", "list_id": "dts.dpdk.org", "list_email": "dts@dpdk.org", "web_url": "", "scm_url": "git://dpdk.org/tools/dts", "webscm_url": "http://git.dpdk.org/tools/dts/", "list_archive_url": "https://inbox.dpdk.org/dts", "list_archive_url_format": "https://inbox.dpdk.org/dts/{}", "commit_url_format": "" }, "msgid": "<20210701135738.18513-3-zhiminx.huang@intel.com>", "list_archive_url": "https://inbox.dpdk.org/dts/20210701135738.18513-3-zhiminx.huang@intel.com", "date": "2021-07-01T13:57:37", "name": "[V2,2/3] tests/cvl_ip_fragment_rte_flow:add new feature test suite", "commit_ref": null, "pull_url": null, "state": "accepted", "archived": false, "hash": "82de50b7bbb68d4e7c08695f1ab00fa35e7eb30b", "submitter": { "id": 1685, "url": "http://patches.dpdk.org/api/people/1685/?format=api", "name": "Huang, ZhiminX", "email": "zhiminx.huang@intel.com" }, "delegate": null, "mbox": "http://patches.dpdk.org/project/dts/patch/20210701135738.18513-3-zhiminx.huang@intel.com/mbox/", "series": [ { "id": 17556, "url": "http://patches.dpdk.org/api/series/17556/?format=api", "web_url": "http://patches.dpdk.org/project/dts/list/?series=17556", "date": "2021-07-01T13:57:35", "name": "add new feature suite", "version": 2, "mbox": "http://patches.dpdk.org/series/17556/mbox/" } ], "comments": "http://patches.dpdk.org/api/patches/95089/comments/", "check": "pending", "checks": "http://patches.dpdk.org/api/patches/95089/checks/", "tags": {}, "related": [], "headers": { "Return-Path": "<dts-bounces@dpdk.org>", "X-Original-To": "patchwork@inbox.dpdk.org", "Delivered-To": "patchwork@inbox.dpdk.org", "Received": [ "from mails.dpdk.org (mails.dpdk.org [217.70.189.124])\n\tby inbox.dpdk.org (Postfix) with ESMTP id 50FE1A0C3F;\n\tThu, 1 Jul 2021 07:23:48 +0200 (CEST)", "from [217.70.189.124] (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 46D204129C;\n\tThu, 1 Jul 2021 07:23:48 +0200 (CEST)", "from mga14.intel.com (mga14.intel.com [192.55.52.115])\n by mails.dpdk.org (Postfix) with ESMTP id 0D7B841296\n for <dts@dpdk.org>; Thu, 1 Jul 2021 07:23:45 +0200 (CEST)", "from orsmga007.jf.intel.com ([10.7.209.58])\n by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384;\n 30 Jun 2021 22:23:45 -0700", "from unknown (HELO localhost.localdomain) ([10.240.183.103])\n by orsmga007-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384;\n 30 Jun 2021 22:23:43 -0700" ], "X-IronPort-AV": [ "E=McAfee;i=\"6200,9189,10031\"; a=\"208294850\"", "E=Sophos;i=\"5.83,313,1616482800\"; d=\"scan'208\";a=\"208294850\"", "E=Sophos;i=\"5.83,313,1616482800\"; d=\"scan'208\";a=\"447746849\"" ], "From": "Zhimin Huang <zhiminx.huang@intel.com>", "To": "dts@dpdk.org", "Cc": "qi.fu@intel.com,\n\tZhimin Huang <zhiminx.huang@intel.com>", "Date": "Thu, 1 Jul 2021 21:57:37 +0800", "Message-Id": "<20210701135738.18513-3-zhiminx.huang@intel.com>", "X-Mailer": "git-send-email 2.17.1", "In-Reply-To": "<20210701135738.18513-1-zhiminx.huang@intel.com>", "References": "<20210701135738.18513-1-zhiminx.huang@intel.com>", "MIME-Version": "1.0", "Content-Type": "text/plain; charset=UTF-8", "Content-Transfer-Encoding": "8bit", "Subject": "[dts] [PATCH V2 2/3] tests/cvl_ip_fragment_rte_flow:add new feature\n test suite", "X-BeenThere": "dts@dpdk.org", "X-Mailman-Version": "2.1.29", "Precedence": "list", "List-Id": "test suite reviews and discussions <dts.dpdk.org>", "List-Unsubscribe": "<https://mails.dpdk.org/options/dts>,\n <mailto:dts-request@dpdk.org?subject=unsubscribe>", "List-Archive": "<http://mails.dpdk.org/archives/dts/>", "List-Post": "<mailto:dts@dpdk.org>", "List-Help": "<mailto:dts-request@dpdk.org?subject=help>", "List-Subscribe": "<https://mails.dpdk.org/listinfo/dts>,\n <mailto:dts-request@dpdk.org?subject=subscribe>", "Errors-To": "dts-bounces@dpdk.org", "Sender": "\"dts\" <dts-bounces@dpdk.org>" }, "content": "*.add new feature cvl ipfragment rte flow test suite\n\nSigned-off-by: Zhimin Huang <zhiminx.huang@intel.com>\n---\n tests/TestSuite_cvl_ip_fragment_rte_flow.py | 493 ++++++++++++++++++++\n 1 file changed, 493 insertions(+)\n create mode 100644 tests/TestSuite_cvl_ip_fragment_rte_flow.py", "diff": "diff --git a/tests/TestSuite_cvl_ip_fragment_rte_flow.py b/tests/TestSuite_cvl_ip_fragment_rte_flow.py\nnew file mode 100644\nindex 00000000..acf8e78e\n--- /dev/null\n+++ b/tests/TestSuite_cvl_ip_fragment_rte_flow.py\n@@ -0,0 +1,493 @@\n+# BSD LICENSE\n+#\n+# Copyright(c) 2021 Intel Corporation. All rights reserved.\n+# All rights reserved.\n+#\n+# Redistribution and use in source and binary forms, with or without\n+# modification, are permitted provided that the following conditions\n+# are met:\n+#\n+# * Redistributions of source code must retain the above copyright\n+# notice, this list of conditions and the following disclaimer.\n+# * Redistributions in binary form must reproduce the above copyright\n+# notice, this list of conditions and the following disclaimer in\n+# the documentation and/or other materials provided with the\n+# distribution.\n+# * Neither the name of Intel Corporation nor the names of its\n+# contributors may be used to endorse or promote products derived\n+# from this software without specific prior written permission.\n+#\n+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\n+# \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\n+# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\n+# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT\n+# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\n+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,\n+# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY\n+# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n+# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n+\n+\n+from packet import Packet\n+from pmd_output import PmdOutput\n+from test_case import TestCase\n+from utils import GREEN, RED\n+import time\n+from scapy.all import *\n+import rte_flow_common as rfc\n+\n+LAUNCH_QUEUE = 16\n+\n+tv_mac_ipv4_frag_fdir_queue_index = {\n+ \"name\": \"tv_mac_ipv4_frag_fdir_queue_index\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv4 packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions queue index 1 / mark / end\",\n+ \"scapy_str\": {\"matched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"queue\": 1, \"mark_id\": 0}\n+}\n+\n+tv_mac_ipv4_frag_fdir_rss_queues = {\n+ \"name\": \"tv_mac_ipv4_frag_fdir_rss_queues\",\n+ \"rule\": [\"flow create 0 ingress pattern eth / ipv4 packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions rss queues 2 3 end / mark / end\",\n+ \"flow create 0 ingress pattern eth / ipv4 / end actions rss types ipv4-frag end key_len 0 queues end / end\"],\n+ \"scapy_str\": {\"matched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"queue\": [2, 3], \"mark_id\": 0}\n+}\n+\n+tv_mac_ipv4_frag_fdir_passthru = {\n+ \"name\": \"tv_mac_ipv4_frag_fdir_passthru\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv4 packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions passthru / mark / end\",\n+ \"scapy_str\": {\"matched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"mark_id\": 0}\n+}\n+\n+tv_mac_ipv4_frag_fdir_drop = {\n+ \"name\": \"tv_mac_ipv4_frag_fdir_drop\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv4 packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions drop / end\",\n+ \"scapy_str\": {\"matched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"drop\": True}\n+}\n+\n+tv_mac_ipv4_frag_fdir_mark_rss = {\n+ \"name\": \"tv_mac_ipv4_frag_fdir_mark_rss\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv4 packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions mark / rss / end\",\n+ \"scapy_str\": {\"matched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"mark_id\": 0, \"rss\": True}\n+}\n+\n+tv_mac_ipv4_frag_fdir_mark = {\n+ \"name\": \"tv_mac_ipv4_frag_fdir_mark\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv4 packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions mark id 1 / end\",\n+ \"scapy_str\": {\"matched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"mark_id\": 1}\n+}\n+\n+tvs_mac_ipv4_fragment_fdir = [\n+ tv_mac_ipv4_frag_fdir_queue_index,\n+ tv_mac_ipv4_frag_fdir_rss_queues,\n+ tv_mac_ipv4_frag_fdir_passthru,\n+ tv_mac_ipv4_frag_fdir_drop,\n+ tv_mac_ipv4_frag_fdir_mark_rss,\n+ tv_mac_ipv4_frag_fdir_mark,\n+]\n+\n+tvs_mac_ipv4_fragment_fdir_l2dst = [eval(str(element).replace('mac_ipv4_frag', 'mac_ipv4_frag_l2dst')\n+ .replace('eth / ipv4 packet_id', 'eth dst is 00:00:00:00:00:01 / ipv4 packet_id')\n+ .replace(\"Ether()\", \"Ether(dst='00:00:00:00:00:01')\")\n+ )\n+ for element in tvs_mac_ipv4_fragment_fdir]\n+\n+tvs_mac_ipv4_frag_fdir_with_l2 = tvs_mac_ipv4_fragment_fdir_l2dst\n+\n+tvs_mac_ipv4_fragment_fdir_l3src = [eval(str(element).replace('mac_ipv4_frag', 'mac_ipv4_frag_l3src')\n+ .replace('ipv4 packet_id', 'ipv4 src is 192.168.1.1 packet_id')\n+ .replace(\"IP(id=47750)\", \"IP(id=47750, src='192.168.1.1')\"))\n+ for element in tvs_mac_ipv4_fragment_fdir]\n+\n+tvs_mac_ipv4_fragment_fdir_l3dst = [eval(str(element).replace('mac_ipv4_frag', 'mac_ipv4_frag_l3dst')\n+ .replace('ipv4 packet_id', 'ipv4 dst is 192.168.1.2 packet_id')\n+ .replace(\"IP(id=47750)\", \"IP(id=47750, dst='192.168.1.2')\"))\n+ for element in tvs_mac_ipv4_fragment_fdir]\n+\n+tvs_mac_ipv4_frag_fdir_with_l3 = tvs_mac_ipv4_fragment_fdir_l3src + tvs_mac_ipv4_fragment_fdir_l3dst\n+\n+tv_mac_ipv6_frag_fdir_queue_index = {\n+ \"name\": \"tv_mac_ipv6_frag_fdir_queue_index\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffffffff packet_id mask 0xffffffff frag_data spec 0x0001 frag_data last 0xffff frag_data mask 0xffff / end actions queue index 1 / mark / end\",\n+ \"scapy_str\": {\"matched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"queue\": 1, \"mark_id\": 0}\n+}\n+\n+tv_mac_ipv6_frag_fdir_rss_queues = {\n+ \"name\": \"tv_mac_ipv6_frag_fdir_rss_queues\",\n+ \"rule\": [\"flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffffffff packet_id mask 0xffffffff frag_data spec 0x0001 frag_data last 0xffff frag_data mask 0xffff / end actions rss queues 2 3 end / mark / end\",\n+ \"flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext / end actions rss types ipv6-frag end key_len 0 queues end / end\"],\n+ \"scapy_str\": {\"matched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"queue\": [2, 3], \"mark_id\": 0}\n+}\n+\n+tv_mac_ipv6_frag_fdir_passthru = {\n+ \"name\": \"tv_mac_ipv6_frag_fdir_passthru\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffffffff packet_id mask 0xffffffff frag_data spec 0x0001 frag_data last 0xffff frag_data mask 0xffff / end actions passthru / mark / end\",\n+ \"scapy_str\": {\"matched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"mark_id\": 0}\n+}\n+\n+tv_mac_ipv6_frag_fdir_drop = {\n+ \"name\": \"tv_mac_ipv6_frag_fdir_drop\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffffffff packet_id mask 0xffffffff frag_data spec 0x0001 frag_data last 0xffff frag_data mask 0xffff / end actions drop / end\",\n+ \"scapy_str\": {\"matched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"drop\": True}\n+}\n+\n+tv_mac_ipv6_frag_fdir_mark_rss = {\n+ \"name\": \"tv_mac_ipv6_frag_fdir_mark_rss\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffffffff packet_id mask 0xffffffff frag_data spec 0x0001 frag_data last 0xffff frag_data mask 0xffff / end actions mark / rss / end\",\n+ \"scapy_str\": {\"matched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"mark_id\": 0, \"rss\": True}\n+}\n+\n+tv_mac_ipv6_frag_fdir_mark = {\n+ \"name\": \"tv_mac_ipv6_frag_fdir_mark\",\n+ \"rule\": \"flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffffffff packet_id mask 0xffffffff frag_data spec 0x0001 frag_data last 0xffff frag_data mask 0xffff / end actions mark id 1 / end\",\n+ \"scapy_str\": {\"matched\": [\"Ether()/IPv6()/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"],\n+ \"unmatched\": [\"Ether()/IP(id=47750)/Raw('X'*666)\"]\n+ },\n+ \"check_param\": {\"port_id\": 0, \"rxq\": LAUNCH_QUEUE, \"mark_id\": 1}\n+}\n+\n+tvs_mac_ipv6_fragment_fdir = [\n+ tv_mac_ipv6_frag_fdir_queue_index,\n+ tv_mac_ipv6_frag_fdir_rss_queues,\n+ tv_mac_ipv6_frag_fdir_passthru,\n+ tv_mac_ipv6_frag_fdir_drop,\n+ tv_mac_ipv6_frag_fdir_mark_rss,\n+ tv_mac_ipv6_frag_fdir_mark,\n+]\n+\n+tvs_mac_ipv6_fragment_fdir_l2dst = [eval(str(element).replace('mac_ipv6_frag', 'mac_ipv6_frag_l2dst')\n+ .replace('eth / ipv6 / ipv6_frag_ext packet_id', 'eth dst is 00:00:00:00:00:01 / ipv6 / ipv6_frag_ext packet_id')\n+ .replace(\"Ether()\", \"Ether(dst='00:00:00:00:00:01')\")\n+ )\n+ for element in tvs_mac_ipv6_fragment_fdir]\n+\n+tvs_mac_ipv6_frag_fdir_with_l2 = tvs_mac_ipv6_fragment_fdir_l2dst\n+\n+tvs_mac_ipv6_fragment_fdir_l3src = [eval(str(element).replace('mac_ipv6_frag', 'mac_ipv6_frag_l3src')\n+ .replace('/ ipv6 /', '/ ipv6 src is 2001::1 /')\n+ .replace(\"IPv6()\", \"IPv6(src='2001::1')\"))\n+ for element in tvs_mac_ipv6_fragment_fdir]\n+\n+tvs_mac_ipv6_fragment_fdir_l3dst = [eval(str(element).replace('mac_ipv6_frag', 'mac_ipv6_frag_l3dst')\n+ .replace('/ ipv6 /', '/ ipv6 dst is 2001::2 /')\n+ .replace(\"IPv6()\", \"IPv6(dst='2001::2')\"))\n+ for element in tvs_mac_ipv6_fragment_fdir]\n+\n+tvs_mac_ipv6_frag_fdir_with_l3 = tvs_mac_ipv6_fragment_fdir_l3src + tvs_mac_ipv6_fragment_fdir_l3dst\n+\n+tv_rss_basic_packets = {\n+ 'ipv4_rss_fragment':\n+ \"Ether(src='00:11:22:33:44:55', dst='00:11:22:33:55:66')/IP(src='192.168.6.11', dst='10.11.12.13', id=47750)/Raw('X'*666)\",\n+ 'ipv6_rss_fragment':\n+ \"Ether(src='00:11:22:33:44:55', dst='00:11:22:33:55:66')/IPv6(src='CDCD:910A:2222:5498:8475:1111:3900:1537', dst='CDCD:910A:2222:5498:8475:1111:3900:2020')/IPv6ExtHdrFragment(id=47750)/Raw('X'*666)\"\n+}\n+\n+tv_mac_ipv4_fragment_rss = {\n+ 'sub_casename': 'tv_mac_ipv4_fragment_rss',\n+ 'rule': 'flow create 0 ingress pattern eth / ipv4 / end actions rss types ipv4-frag end key_len 0 queues end / end',\n+ 'port_id': 0,\n+ 'test': [\n+ {\n+ 'send_packet': tv_rss_basic_packets['ipv4_rss_fragment'],\n+ 'action': {'save_hash': 'ipv4'},\n+ },\n+ {\n+ 'send_packet': tv_rss_basic_packets['ipv4_rss_fragment'].replace('192.168.6.11', '192.168.6.12'),\n+ 'action': {'check_hash_different': 'ipv4'},\n+ },\n+ {\n+ 'send_packet': tv_rss_basic_packets['ipv4_rss_fragment'].replace('10.11.12.13', '10.11.12.14'),\n+ 'action': {'check_hash_different': 'ipv4'},\n+ },\n+ {\n+ 'send_packet': tv_rss_basic_packets['ipv4_rss_fragment'].replace('id=47750', 'id=47751'),\n+ 'action': {'check_hash_different': 'ipv4'},\n+ },\n+ {\n+ 'send_packet': \"Ether()/IPv6()/IPv6ExtHdrFragment(id=47751)/Raw('X'*666)\",\n+ 'action': {'check_no_hash': 'ipv4'},\n+ },\n+ ],\n+ 'post-test': [\n+ {\n+ 'send_packet': tv_rss_basic_packets['ipv4_rss_fragment'],\n+ 'action': {'check_no_hash': 'ipv4'},\n+ },\n+ ]\n+}\n+\n+tv_mac_ipv6_fragment_rss = {\n+ 'sub_casename': 'tv_mac_ipv6_fragment_rss',\n+ 'rule': 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext / end actions rss types ipv6-frag end key_len 0 queues end / end',\n+ 'port_id': 0,\n+ 'test': [\n+ {\n+ 'send_packet': tv_rss_basic_packets['ipv6_rss_fragment'],\n+ 'action': {'save_hash': 'ipv6'},\n+ },\n+ {\n+ 'send_packet': tv_rss_basic_packets['ipv6_rss_fragment'].replace('3900:1537', '3900:1538'),\n+ 'action': {'check_hash_different': 'ipv6'},\n+ },\n+ {\n+ 'send_packet': tv_rss_basic_packets['ipv6_rss_fragment'].replace('3900:2020', '3900:2021'),\n+ 'action': {'check_hash_different': 'ipv6'},\n+ },\n+ {\n+ 'send_packet': tv_rss_basic_packets['ipv6_rss_fragment'].replace('id=47750', 'id=47751'),\n+ 'action': {'check_hash_different': 'ipv6'},\n+ },\n+ {\n+ 'send_packet': \"Ether()/IP(id=47750)/Raw('X'*666)\",\n+ 'action': {'check_no_hash': 'ipv6'},\n+ },\n+ ],\n+ 'post-test': [\n+ {\n+ 'send_packet': tv_rss_basic_packets['ipv6_rss_fragment'],\n+ 'action': {'check_no_hash': 'ipv6'},\n+ },\n+ ]\n+}\n+\n+\n+class TestCvlIpFragmentRteFlow(TestCase):\n+ def set_up_all(self):\n+ self.ports = self.dut.get_ports(self.nic)\n+\n+ # init pkt\n+ self.pkt = Packet()\n+ # set default app parameter\n+ self.pmd_out = PmdOutput(self.dut)\n+ self.tester_mac = self.tester.get_mac(0)\n+ self.tester_port0 = self.tester.get_local_port(self.ports[0])\n+ self.tester_iface0 = self.tester.get_interface(self.tester_port0)\n+\n+ self.tester.send_expect('ifconfig {} up'.format(self.tester_iface0), '# ')\n+ self.param = '--rxq={} --txq={} --disable-rss --txd=384 --rxd=384'.format(LAUNCH_QUEUE, LAUNCH_QUEUE)\n+ self.param_fdir = '--rxq={} --txq={}'.format(LAUNCH_QUEUE, LAUNCH_QUEUE)\n+ self.cores = self.dut.get_core_list(\"1S/4C/1T\")\n+\n+ self.ports_pci = [self.dut.ports_info[self.ports[0]]['pci']]\n+\n+ self.rssprocess = rfc.RssProcessing(self, self.pmd_out, [self.tester_iface0], LAUNCH_QUEUE, ipfrag_flag=True)\n+ self.fdirprocess = rfc.FdirProcessing(self, self.pmd_out, [self.tester_iface0], LAUNCH_QUEUE, ipfrag_flag=True)\n+\n+ def set_up(self):\n+ self.dut.bind_interfaces_linux('vfio-pci')\n+\n+ def launch_testpmd(self, param_fdir=False):\n+ \"\"\"\n+ start testpmd with fdir or rss param\n+\n+ :param param_fdir: True: Fdir param/False: rss param\n+ \"\"\"\n+ if param_fdir == True:\n+ self.pmd_out.start_testpmd(cores=self.cores, ports=self.ports_pci, param=self.param_fdir)\n+ else:\n+ self.pmd_out.start_testpmd(cores=self.cores, ports=self.ports_pci, param=self.param)\n+ self.dut.send_expect(\"set fwd rxonly\", \"testpmd> \")\n+ self.dut.send_expect(\"set verbose 1\", \"testpmd> \")\n+ self.dut.send_expect(\"start\", \"testpmd> \")\n+\n+ def tear_down(self):\n+ self.dut.send_expect(\"quit\", \"# \")\n+ self.dut.kill_all()\n+\n+ def tear_down_all(self):\n+ self.dut.kill_all()\n+\n+ def test_mac_ipv4_frag_fdir(self):\n+ self.launch_testpmd(param_fdir=True)\n+ self.fdirprocess.flow_director_validate(tvs_mac_ipv4_fragment_fdir)\n+\n+ def test_mac_ipv6_frag_fdir(self):\n+ self.launch_testpmd(param_fdir=True)\n+ self.fdirprocess.flow_director_validate(tvs_mac_ipv6_fragment_fdir)\n+\n+ def test_mac_ipv4_frag_fdir_with_l2(self):\n+ self.launch_testpmd(param_fdir=True)\n+ self.fdirprocess.flow_director_validate(tvs_mac_ipv4_frag_fdir_with_l2)\n+\n+ def test_mac_ipv4_frag_fdir_with_l3(self):\n+ self.launch_testpmd(param_fdir=True)\n+ self.fdirprocess.flow_director_validate(tvs_mac_ipv4_frag_fdir_with_l3)\n+\n+ def test_mac_ipv6_frag_fdir_with_l2(self):\n+ self.launch_testpmd(param_fdir=True)\n+ self.fdirprocess.flow_director_validate(tvs_mac_ipv6_frag_fdir_with_l2)\n+\n+ def test_mac_ipv6_frag_fdir_with_l3(self):\n+ self.launch_testpmd(param_fdir=True)\n+ self.fdirprocess.flow_director_validate(tvs_mac_ipv6_frag_fdir_with_l3)\n+\n+ def test_mac_ipv4_frag_rss(self):\n+ self.launch_testpmd(param_fdir=False)\n+ self.rssprocess.handle_rss_distribute_cases(tv_mac_ipv4_fragment_rss)\n+\n+ def test_mac_ipv6_frag_rss(self):\n+ self.launch_testpmd(param_fdir=False)\n+ self.rssprocess.handle_rss_distribute_cases(tv_mac_ipv6_fragment_rss)\n+\n+ def test_exclusive_validation(self):\n+ result = True\n+ result_list = []\n+ rule_list_fdir = [\n+ 'flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / ipv4 src is 192.168.0.20 / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions queue index 2 / end']\n+ pkt_fdir = \"Ether(dst='00:11:22:33:44:55')/IP(src='192.168.0.20', id=47750)/Raw('X'*666)\"\n+\n+ self.logger.info('Subcase 1: exclusive validation fdir rule')\n+ self.launch_testpmd(param_fdir=True)\n+ try:\n+ self.rssprocess.create_rule(rule_list_fdir)\n+ except Exception as e:\n+ self.logger.warning('Subcase 1 failed: %s' % e)\n+ result = False\n+ hashes, queues = self.rssprocess.send_pkt_get_hash_queues(pkts=pkt_fdir)\n+ for queue in queues:\n+ if '0x2' != queue:\n+ result = False\n+ self.logger.error('Error: queue index {} != 2'.format(queue))\n+ continue\n+ result_list.append(result)\n+ self.dut.send_expect(\"quit\", \"# \")\n+ self.logger.info(\"*********subcase test result %s\" % result_list)\n+\n+ self.logger.info('Subcase 2: exclusive validation fdir rule')\n+ result = True\n+ self.launch_testpmd(param_fdir=True)\n+ try:\n+ self.rssprocess.create_rule(rule_list_fdir[::-1])\n+ except Exception as e:\n+ self.logger.warning('Subcase 2 failed: %s' % e)\n+ result = False\n+ hashes, queues = self.rssprocess.send_pkt_get_hash_queues(pkts=pkt_fdir)\n+ for queue in queues:\n+ if '0x2' != queue:\n+ result = False\n+ self.logger.error('Error: queue index {} != 2'.format(queue))\n+ continue\n+ result_list.append(result)\n+ self.dut.send_expect(\"quit\", \"# \")\n+ self.logger.info(\"*********subcase test result %s\" % result_list)\n+\n+ self.logger.info('Subcase 3: exclusive validation rss rule')\n+ result = True\n+ self.launch_testpmd()\n+ rule_list_rss = [\n+ 'flow create 0 ingress pattern eth / ipv4 / end actions rss types ipv4 end key_len 0 queues end / end',\n+ 'flow create 0 ingress pattern eth / ipv4 / end actions rss types ipv4-frag end key_len 0 queues end / end']\n+ pkt_rss = [\"Ether()/IP(id=47750)/Raw('X'*666)\",\n+ \"Ether()/IP(id=47751)/Raw('X'*666)\"]\n+ try:\n+ self.rssprocess.create_rule(rule_list_rss)\n+ except Exception as e:\n+ self.logger.warning('Subcase 3 failed: %s' % e)\n+ result = False\n+ hashes1, queues1 = self.rssprocess.send_pkt_get_hash_queues(pkts=pkt_rss[0])\n+ hashes2, queues2 = self.rssprocess.send_pkt_get_hash_queues(pkts=pkt_rss[1])\n+ if hashes1[0] != hashes1[1] and hashes2[0] != hashes2[1]:\n+ result = False\n+ self.logger.error(\"hash value is incorrect\")\n+ if hashes1[0] == hashes2[0]:\n+ result = False\n+ self.logger.error(\"hash value is incorrect\")\n+ result_list.append(result)\n+ self.dut.send_expect(\"quit\", \"# \")\n+ self.logger.info(\"*********subcase test result %s\" % result_list)\n+\n+ self.logger.info('Subcase 4: exclusive validation rss rule')\n+ result = True\n+ self.launch_testpmd()\n+ try:\n+ self.rssprocess.create_rule(rule_list_rss[::-1])\n+ except Exception as e:\n+ self.logger.warning('Subcase 4 failed: %s' % e)\n+ hashes1, queues1 = self.rssprocess.send_pkt_get_hash_queues(pkts=pkt_rss[0])\n+ hashes2, queues2 = self.rssprocess.send_pkt_get_hash_queues(pkts=pkt_rss[1])\n+ if hashes1[0] != hashes1[1] and hashes2[0] != hashes2[1]:\n+ result = False\n+ self.logger.error(\"hash value is incorrect\")\n+ if hashes1[0] != hashes2[0]:\n+ result = False\n+ self.logger.error(\"hash value is incorrect\")\n+ result_list.append(result)\n+ self.dut.send_expect(\"quit\", \"# \")\n+ self.logger.info(\"*********subcase test result %s\" % result_list)\n+ self.verify(all(result_list) is True, 'sub-case failed {}'.format(result_list))\n+\n+ def test_negative_case(self):\n+ negative_rules = [\n+ 'flow create 0 ingress pattern eth / ipv6 packet_id is 47750 fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id is 47750 fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions queue index 300 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id is 0x10000 fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id is 47750 fragment_offset spec 0x2 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id is 47750 fragment_offset spec 0x2000 fragment_offset last 0x1 fragment_offset mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id is 47750 fragment_offset spec 0x2000 fragment_offset last 0x1fff fragment_offset mask 0xf / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id is 47750 fragment_offset last 0x1fff fragment_offset mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id is 47750 fragment_offset spec 0x2000 fragment_offset mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id is 47750 fragment_offset spec 0x2000 fragment_offset last 0x1fff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id is 0x10000 / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id is 47750 / end actions queue index 300 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id spec 0xfff packet_id last 0x0 packet_id mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id last 0xffff packet_id mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id spec 0 packet_id mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 packet_id spec 0 packet_id last 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 / ipv6_frag_ext packet_id is 47750 frag_data spec 0x0001 frag_data last 0xfff8 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id is 47750 frag_data spec 0xfff8 frag_data last 0x0001 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / frag_data spec 0x0001 frag_data last 0xfff8 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id is 47750 frag_data last 0xfff8 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id is 47750 frag_data spec 0x0001 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id is 47750 frag_data spec 0x0001 frag_data last 0xfff8 / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id is 47750 frag_data spec 0x0001 frag_data last 0xfff8 frag_data mask 0xffff / end actions queue index 300 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff frag_data spec 0x0001 frag_data last 0xfff8 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0xffff packet_id last 0x0 packet_id mask 0xffff frag_data spec 0x0001 frag_data last 0xfff8 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff frag_data spec 0xfff8 frag_data last 0x0001 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / packet_id last 0xffff packet_id mask 0xffff frag_data spec 0x0001 frag_data last 0xfff8 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id mask 0xffff frag_data spec 0x0001 frag_data last 0xfff8 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffff frag_data spec 0x0001 frag_data last 0xfff8 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff frag_data last 0xfff8 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff frag_data spec 0x0001 frag_data last 0xfff8 / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id spec 0 packet_id last 0xffff packet_id mask 0xffff frag_data spec 0x0001 frag_data mask 0xffff / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv4 / ipv6_frag_ext packet_id is 47750 / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext packet_id is 0x10000 / end actions queue index 1 / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / end actions rss types ipv4-frag end key_len 0 queues end / end',\n+ 'flow create 0 ingress pattern eth / ipv4 / ipv6_frag_ext / end actions rss types ipv6-frag end key_len 0 queues end / end',\n+ 'flow create 0 ingress pattern eth / ipv6 / ipv6_frag_ext / end actions rss types ipv4-frag end key_len 0 queues end / end',\n+ ]\n+ self.launch_testpmd()\n+ self.rssprocess.create_rule(negative_rules, check_stats=False)\n\\ No newline at end of file\n", "prefixes": [ "V2", "2/3" ] }{ "id": 95089, "url": "