From patchwork Mon Dec 5 14:50:46 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Yaqi Tang X-Patchwork-Id: 120456 Return-Path: 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]) by inbox.dpdk.org (Postfix) with ESMTP id C3E59A0547; Mon, 5 Dec 2022 15:51:03 +0100 (CET) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id B8CAB40A87; Mon, 5 Dec 2022 15:51:03 +0100 (CET) Received: from mga04.intel.com (mga04.intel.com [192.55.52.120]) by mails.dpdk.org (Postfix) with ESMTP id A98E84014F for ; Mon, 5 Dec 2022 15:51:01 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1670251861; x=1701787861; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=/Yy4R066rlPxGdTQtjeuBAuK57hduHXtLtiNqtCLih4=; b=lbLIisBRtyyijVm+Ki3hSBENiQgOk13zpeA386BySAq9jey/BQRVUhF2 hfhlyM9hzUOyB3ghbwAqFHNuZ2659zwq8BYih7dlyBz9HclO26eTuGsV1 QWWQw9nJE15N2cL8unyzV9tDZMXFMqXUCHBbZMd7Dl6ITXtuNd24TvyuH JJfeSq2hjoI/zswSJEv+ixQJXtEQVXxxJtVzaFz0wKukwgSSibe/Zj9si 9L94Ed5Tn71ysOnB8XAj13zKXbb0Uya0Iq90cWYcQEP2qkw/O3tEL7y7R 9FRdXbYKnnU6ormVP0wCg12byc0CM+uVP1oGvAHB3I0W6J5sfQoIRg/jd A==; X-IronPort-AV: E=McAfee;i="6500,9779,10552"; a="315065655" X-IronPort-AV: E=Sophos;i="5.96,219,1665471600"; d="scan'208";a="315065655" Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 05 Dec 2022 06:51:00 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6500,9779,10552"; a="752213217" X-IronPort-AV: E=Sophos;i="5.96,219,1665471600"; d="scan'208";a="752213217" Received: from dpdk-yaqi.sh.intel.com ([10.67.119.116]) by fmsmga002.fm.intel.com with ESMTP; 05 Dec 2022 06:50:59 -0800 From: Yaqi Tang To: dts@dpdk.org Cc: Yaqi Tang Subject: [dts][PATCH V1 2/3] test_plans/ice_buffer_split: ice PF enable buffer split Date: Mon, 5 Dec 2022 14:50:46 +0000 Message-Id: <20221205145047.878054-3-yaqi.tang@intel.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20221205145047.878054-1-yaqi.tang@intel.com> References: <20221205145047.878054-1-yaqi.tang@intel.com> MIME-Version: 1.0 X-BeenThere: dts@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: test suite reviews and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dts-bounces@dpdk.org Packets received in ice scalar path can be devided into two mempools with expected hdr and payload length/content specified by protocol type. Signed-off-by: Yaqi Tang --- test_plans/ice_buffer_split_test_plan.rst | 1201 +++++++++++++++++++++ 1 file changed, 1201 insertions(+) create mode 100644 test_plans/ice_buffer_split_test_plan.rst diff --git a/test_plans/ice_buffer_split_test_plan.rst b/test_plans/ice_buffer_split_test_plan.rst new file mode 100644 index 00000000..28535acf --- /dev/null +++ b/test_plans/ice_buffer_split_test_plan.rst @@ -0,0 +1,1201 @@ +.. SPDX-License-Identifier: BSD-3-Clause + Copyright(c) 2022 Intel Corporation + +========================== +ICE PF Enable Buffer Split +========================== + +Description +=========== +Protocol based buffer split consists of splitting a received packet into two separate regions based on the packet content. +It is useful in some scenarios, such as GPU acceleration. The splitting will help to enable true zero copy and hence +improve the performance significantly. + +It supports protocol split based on current buffer split. When Rx queue is +configured with RTE_ETH_RX_OFFLOAD_BUFFER_SPLIT offload and corresponding protocol, +packets received will be directly split into two different mempools with expected hdr and payload length/content. + +For validation, we will focus on: +1. Configuration of protocol based buffer split is applied. +Setup buffer split: +Per port: testpmd>port config 0 rx_offload buffer_split on +Per queue: testpmd>port 0 rxq 0 rx_offload buffer_split on + +Set the protocol type of buffer split: +testpmd>set rxhdrs eth|ipv4|ipv6|ipv4-tcp|ipv6-tcp|ipv4-udp|ipv6-udp| + ipv4-sctp|ipv6-sctp|grenat|inner-eth|inner-ipv4|inner-ipv6| + inner-ipv4-tcp|inner-ipv6-tcp|inner-ipv4-udp|inner-ipv6-udp| + inner-ipv4-sctp|inner-ipv6-sctp + +2. Packets received in ice scalar path(--force-max-simd-bitwidth=64) can be devided into + two mempools with expected hdr and payload length/content specified by protocol type. + +Pattern And Input Set +--------------------- + + +----------------------------------+----------------------------+-------------------------------------------------------------------------------+ + | Packet Type | Pattern | Input Set | + +----------------------------------+----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IPV4_PAY | [Dest MAC],[Source IP], [Dest IP], [IP protocol], [TTL], [DSCP] | + | +----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IPV4_UDP | [Dest MAC],[Source IP], [Dest IP], [TTL], [DSCP], [Source Port], [Dest Port] | + | +----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IPV4_TCP | [Dest MAC],[Source IP], [Dest IP], [TTL], [DSCP], [Source Port], [Dest Port] | + | +----------------------------+-------------------------------------------------------------------------------+ + | IPv4/IPv6 + TCP/UDP/SCTP |MAC_IPV4_SCTP | [Dest MAC],[Source IP], [Dest IP], [TTL], [DSCP], [Source Port], [Dest Port] | + | +----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IPV6_PAY | [Dest MAC],[Source IP], [Dest IP], [IP protocol], [TTL], [TC] | + | +----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IPV6_UDP | [Dest MAC],[Source IP], [Dest IP], [TTL], [TC], [Source Port], [Dest Port] | + | +----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IPV6_TCP | [Dest MAC],[Source IP], [Dest IP], [TTL], [TC], [Source Port], [Dest Port] | + | +----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IPV6_SCTP | [Dest MAC],[Source IP], [Dest IP], [TTL], [TC], [Source Port], [Dest Port] | + +----------------------------------+----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IP*_IP*_PAY | [Dest MAC],[Source IP], [Dest IP], [IP protocol], [TTL], [DSCP] | + | +----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IP*_IP*_UDP | [Dest MAC],[Source IP], [Dest IP], [TTL], [DSCP], [Source Port], [Dest Port] | + | IP* + IP* + TCP/UDP/SCTP +----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IP*_IP*_TCP | [Dest MAC],[Source IP], [Dest IP], [TTL], [DSCP], [Source Port], [Dest Port] | + | +----------------------------+-------------------------------------------------------------------------------+ + | |MAC_IP*_IP*_SCTP | [Dest MAC],[Source IP], [Dest IP], [TTL], [DSCP], [Source Port], [Dest Port] | + +----------------------------------+----------------------------+-------------------------------------------------------------------------------+ + | | MAC_IP*_TUN_IP*_PAY | [Inner Source IP], [Inner Dest IP] | + | +----------------------------+-------------------------------------------------------------------------------+ + | | MAC_IP*_TUN_IP*_UDP | [Inner Source IP], [Inner Dest IP], [Inner Source Port], [Inner Dest Port] | + | +----------------------------+-------------------------------------------------------------------------------+ + | | MAC_IP*_TUN_IP*_TCP | [Inner Source IP], [Inner Dest IP], [Inner Source Port], [Inner Dest Port] | + | +----------------------------+-------------------------------------------------------------------------------+ + | | MAC_IP*_TUN_IP*_SCTP | [Inner Source IP], [Inner Dest IP], [Inner Source Port], [Inner Dest Port] | + | tunnel: VXLAN/GRE +----------------------------+-------------------------------------------------------------------------------+ + | | MAC_IP*_TUN_MAC_IP*_PAY | [Inner Source IP], [Inner Dest IP] | + | +----------------------------+-------------------------------------------------------------------------------+ + | | MAC_IP*_TUN_MAC_IP*_UDP | [Inner Source IP], [Inner Dest IP], [Inner Source Port], [Inner Dest Port] | + | +----------------------------+-------------------------------------------------------------------------------+ + | | MAC_IP*_TUN_MAC_IP*_TCP | [Inner Source IP], [Inner Dest IP], [Inner Source Port], [Inner Dest Port] | + | +----------------------------+-------------------------------------------------------------------------------+ + | | MAC_IP*_TUN_MAC_IP*_SCTP | [Inner Source IP], [Inner Dest IP], [Inner Source Port], [Inner Dest Port] | + +----------------------------------+----------------------------+-------------------------------------------------------------------------------+ + +.. note:: + + 1. Each combination just need to change the IP* with IPV4 or IPV6, the inputset is same. there are 4 combinations in total: + IPV4+IPV4 + IPV4+IPV6 + IPV6+IPV4 + IPV6+IPV6 + 2. UDP tunnel only for VXLAN, for VXLAN case MAC_IPV4_TUN_*** means MAC_IPV4_UDP_VXLAN_***, for GRE case MAC_IPV4_TUN_*** means MAC_IPV4_GRE_*** + +Prerequisites +============= + +Topology +-------- +DUT port 0 <----> Tester port 0 + +Hardware +-------- +Supported NICs: Intel® Ethernet 800 Series E810-XXVDA4/E810-CQ + +Software +-------- +dpdk: http://dpdk.org/git/dpdk +runtime command: https://doc.dpdk.org/guides/testpmd_app_ug/testpmd_funcs.html + +General Set Up +-------------- +1. Compile DPDK with '-Dc_args='-DRTE_ETHDEV_DEBUG_RX=1' to dump segment data:: + + # CC=gcc meson --werror -Denable_kmods=True -Dlibdir=lib -Dc_args='-DRTE_ETHDEV_DEBUG_RX=1' --default-library=static + # ninja -C -j 110 + +2. Get the pci device id and interface of DUT and tester. + For example, 0000:3b:00.0 and 0000:3b:00.1 is pci device id, + ens785f0 and ens785f1 is interface:: + + # ./usertools/dpdk-devbind.py -s + + 0000:3b:00.0 'Device 159b' if=ens785f0 drv=ice unused=vfio-pci + 0000:3b:00.1 'Device 159b' if=ens785f1 drv=ice unused=vfio-pci + +3. Bind the DUT port to dpdk:: + + # ./usertools/dpdk-devbind.py -b vfio-pci + +Test Case +========= +Common Steps +------------ +1.port stop all +2.port config 0 rx_offload buffer_split on +3.show port 0 rx_offload configuration +4.port config 0 udp_tunnel_port add vxlan 4789 +5.set rxhdrs eth +6.show config rxhdrs +7.port start all +8.start + +Test Case 1: PORT_BUFFER_SPLIT_OUTER_MAC +---------------------------------------- +Launch two ports testpmd, configure port 0 buffer split on outer mac, send matched packets to port 0 and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the outer mac. + +Test Steps +~~~~~~~~~~ +1. Launch two ports testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 -a 3b:00.1 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 + +2. Execute common steps to configure port 0 buffer split on outer mac. + +3. Send matched packets to port 0. + + Send MAC_IPV4_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=50. + + Send MAC_IPV4_IPV6_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/IPv6()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=90. + + Send MAC_IPV4_UDP_VXLAN_MAC_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with har_len=14 and pay_len=80. + + Send MAC_IPV6_UDP_VXLAN_IPV6_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IPv6()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=126. + + Send MAC_IPV4_GRE_MAC_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=68. + + Send MAC_IPV4_GRE_IPV6_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/IPv6()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=94. + +4. Send matched packets to port 1:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/IPv6()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IPv6()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/IPv6()/("Y"*30)], iface="ens260f1") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +Test Case 2: PORT_BUFFER_SPLIT_INNER_MAC +---------------------------------------- +Launch two ports testpmd, configure port 0 buffer split on inner mac, send matched packets to port 0 and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the inner mac. + +Test Steps +~~~~~~~~~~ +1. Launch two ports testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 -a 3b:00.1 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 + +2. Modify common step 5 to:: + + set rxhdrs inner-eth + + Execute common steps to configure port 0 buffer split on inner mac. + +3. Send matched packets to port 0. + + Send MAC_IPV4_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=50. + + Send MAC_IPV4_IPV6_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/IPv6()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=90. + + Send MAC_IPV4_UDP_VXLAN_MAC_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=64 and pay_len=30. + + Send MAC_IPV6_UDP_VXLAN_IPV6_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IPv6()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=126. + + Send MAC_IPV4_GRE_MAC_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=52 and pay_len=30. + + Send MAC_IPV6_GRE_IPV6_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/IPv6()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=114. + +4. Send matched packets to port 1:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/IPv6()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IPv6()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/IPv6()/("Y"*30)], iface="ens260f1") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +Test Case 3: PORT_BUFFER_SPLIT_INNER_L3 +--------------------------------------- +Launch two ports testpmd, configure port 0 buffer split on inner l3, send matched packets to port 0 and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the inner l3. + +Test Steps +~~~~~~~~~~ +1. Send matched packets to port 0. + + Send MAC_IPV4_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=34 and pay_len=30. + + Send MAC_IPV6_IPV4_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/IP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=74 and pay_len=30. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV6_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IPv6()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=104 and pay_len=30. + + Send MAC_IPV6_UDP_VXLAN_IPV4_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=90 and pay_len=30. + + Send MAC_IPV4_GRE_MAC_IPV6_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/IPv6()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=92 and pay_len=30. + + Send MAC_IPV6_GRE_IPV4_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/IP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=78 and pay_len=30. + +2. Send matched packets to port 1:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/IP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IPv6()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether()/IPv6()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/IP()/("Y"*30)], iface="ens260f1") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +Subcase 1: buffer split ipv4 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch two ports testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 -a 3b:00.1 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 + +2. Modify common step 5 to:: + + set rxhdrs ipv4 + + Execute common steps to configure port 0 buffer split on inner l3. + +Subcase 2: buffer split ipv6 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 3: buffer split inner-ipv4 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 4: buffer split inner-ipv6 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Test Case 4: PORT_BUFFER_SPLIT_INNER_L4 +--------------------------------------- +Launch two ports testpmd, configure port 0 buffer split on inner udp/tcp, send matched packets to port 0 and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the inner udp/tcp. + +Test Steps +~~~~~~~~~~ +1. Send matched packets to port 0. + + #UDP packets + Send MAC_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=42 and pay_len=30. + + Send MAC_IPV4_IPV6_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/IPv6()/UDP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=82 and pay_len=30. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP()/UDP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=92 and pay_len=30. + + Send MAC_IPV6_UDP_VXLAN_IPV6_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IPv6()/UDP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=118 and pay_len=30. + + Send MAC_IPV6_GRE_MAC_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/Ether(dst="00:11:22:33:44:66")/IP()/UDP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=100 and pay_len=30. + + Send MAC_IPV4_GRE_IPV6_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/IPv6()/UDP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=86 and pay_len=30. + + #TCP packets + Send MAC_IPV6_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/TCP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=74 and pay_len=30. + + Send MAC_IPV6_IPV4_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/IP()/TCP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=94 and pay_len=30. + + Send MAC_IPV6_UDP_VXLAN_MAC_IPV6_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IPv6()/TCP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=144 and pay_len=30. + + Send MAC_IPV4_UDP_VXLAN_IPV4_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP()/TCP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=90 and pay_len=30. + + Send MAC_IPV4_GRE_MAC_IPV6_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/IPv6()/TCP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=112 and pay_len=30. + + Send MAC_IPV6_GRE_IPV4_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/IP()/TCP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=98 and pay_len=30. + +2. Send mismatched packet to port 0:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/IP()/SCTP()/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +3. Send matched packets to port 1:: + + #UDP packets + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/IPv6()/UDP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP()/UDP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IPv6()/UDP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/Ether(dst="00:11:22:33:44:66")/IP()/UDP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/IPv6()/UDP()/("Y"*30)], iface="ens260f1") + + #TCP packets + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/TCP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/IP()/TCP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IPv6()/TCP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP()/TCP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/Ether(dst="00:11:22:33:44:66")/IPv6()/TCP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/IP()/TCP()/("Y"*30)], iface="ens260f1") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +Subcase 1: buffer split ipv4-udp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch two ports testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 -a 3b:00.1 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 + +2. Modify common step 5 to:: + + set rxhdrs ipv4-udp + + Execute common steps to configure port 0 buffer split on inner udp/tcp. + +Subcase 2: buffer split ipv6-udp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 3: buffer split ipv4-tcp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 4: buffer split ipv6-tcp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 5: buffer split inner-ipv4-udp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 6: buffer split inner-ipv6-udp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 7: buffer split inner-ipv4-tcp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 8: buffer split inner-ipv6-tcp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Test Case 5: PORT_BUFFER_SPLIT_INNER_SCTP +----------------------------------------- +Launch two ports testpmd, configure port 0 buffer split on inner sctp, send matched packets to port 0 and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the inner sctp. + +Test Steps +~~~~~~~~~~ +1. Send matched packets to port 0. + + Send MAC_IPV4_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/SCTP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=46 and pay_len=30. + + Send MAC_IPV4_IPV6_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/IPv6()/SCTP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=86 and pay_len=30. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV4_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP()/SCTP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=96 and pay_len=30. + + Send MAC_IPV6_UDP_VXLAN_IPV6_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IPv6()/SCTP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=122 and pay_len=30. + + Send MAC_IPV6_GRE_MAC_IPV4_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/Ether(dst="00:11:22:33:44:66")/IP()/SCTP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=104 and pay_len=30. + + Send MAC_IPV4_GRE_IPV6_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/IPv6()/SCTP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=90 and pay_len=30. + +2. Send mismatched packet to port 0:: + + Send MAC_IPV4_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools with hdr_len=0 and pay_len=64. + + Send MAC_IPV4_GRE_MAC_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/IP()/UDP()/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools with hdr_len=0 and pay_len=110. + + Send MAC_IPV4_GRE_MAC_IPV4_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/IP()/TCP()/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools with hdr_len=0 and pay_len=122. + +3. Send matched packets to port 1:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/SCTP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/IPv6()/SCTP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP()/SCTP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IPv6()/SCTP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/Ether(dst="00:11:22:33:44:66")/IP()/SCTP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/IPv6()/SCTP()/("Y"*30)], iface="ens260f1") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +Subcase 1: buffer split ipv4-sctp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch two ports testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 -a 3b:00.1 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 + +2. Modify common step 5 to:: + + set rxhdrs ipv4-sctp + + Execute common steps to configure port 0 buffer split on inner sctp. + +Subcase 2: buffer split ipv6-sctp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 3: buffer split inner-ipv4-sctp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 4: buffer split inner-ipv6-sctp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Test Case 6: PORT_BUFFER_SPLIT_TUNNEL +------------------------------------- +Launch two ports testpmd, configure port 0 buffer split on tunnel, send matched packets to port 0 and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the tunnel. + +Test Steps +~~~~~~~~~~ +1. Launch two ports testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 -a 3b:00.1 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 + +2. Modify common step 5 to:: + + set rxhdrs grenat + + Execute common steps to configure port 0 buffer split on tunnel. + +3. Send matched packets to port 0. + + Send MAC_IPV4_IPV4_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/IP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=34 and pay_len=50. + + Send MAC_IPV6_IPV6_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/IPv6()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=54 and pay_len=70. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP()/UDP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=50 and pay_len=72. + + Send MAC_IPV6_UDP_VXLAN_IPV6_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IPv6()/TCP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=70 and pay_len=90. + + Send MAC_IPV4_GRE_MAC_IPV6_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/IPv6()/SCTP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=38 and pay_len=96. + + Send MAC_IPV6_GRE_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/IP()/UDP()/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=58 and pay_len=58. + +4. Send mismatched packet to port 0:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools with hdr_len=0 and pay_len=72. + +5. Send matched packets to port 1:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/IP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/IPv6()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP()/UDP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/UDP(sport=200, dport=4790)/VXLAN()/IPv6()/TCP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/GRE()/Ether(dst="00:11:22:33:44:66")/IPv6()/SCTP()/("Y"*30)], iface="ens260f1") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6()/GRE()/IP()/UDP()/("Y"*30)], iface="ens260f1") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +Test Case 7: QUEUE_BUFFER_SPLIT_OUTER_MAC +----------------------------------------- +Launch one port with multi queues testpmd, configure queue buffer split on outer mac, send matched packets and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the outer mac. + +Test Steps +~~~~~~~~~~ +1. Launch one port with multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 1 rx_offload buffer_split on + + Execute common steps to configure queue buffer split on outer mac. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv4 / udp / vxlan / eth / ipv4 src is 192.168.0.1 dst is 192.168.0.2 / end actions queue index 1 / mark / end + +4. Send matched packets. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.1",dst="192.168.0.2")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=100. + + Send MAC_IPV4_UDP_VXLAN_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1",dst="192.168.0.2")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=86. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.3",dst="192.168.0.2")/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1",dst="192.168.0.4")/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +6. Destroy the rule:: + + flow destroy 0 rule 0 + +Test Case 8: QUEUE_BUFFER_SPLIT_INNER_MAC +----------------------------------------- +Launch one port with multi queues testpmd, configure queue buffer split on inner mac, send matched packets and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the inner mac. + +Test Steps +~~~~~~~~~~ +1. Launch one port with multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 2 rx_offload buffer_split on + port 0 rxq 3 rx_offload buffer_split on + + Modify common step 5 to:: + + set rxhdrs inner-eth + + Execute common steps to configure queue buffer split on inner mac. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv4 / udp / vxlan / eth / ipv4 src is 192.168.0.1 dst is 192.168.0.2 / end actions rss queues 2 3 end / mark / end + +4. Send matched packets. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.1",dst="192.168.0.2")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=64 and pay_len=50. + + Send MAC_IPV4_UDP_VXLAN_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1",dst="192.168.0.2")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=14 and pay_len=86. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.3",dst="192.168.0.2")/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1",dst="192.168.0.4")/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +6. Destroy the rule:: + + flow destroy 0 rule 0 + +Test Case 9: QUEUE_BUFFER_SPLIT_INNER_IPV4 +------------------------------------------ +Launch one port with multi queues testpmd, configure queue buffer split on inner ipv4, send matched packets and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the inner ipv4. + +Test Steps +~~~~~~~~~~ +Subcase 1: buffer split ipv4 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch one port with multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 2 rx_offload buffer_split on + + Modify common step 5 to:: + + set rxhdrs ipv4 + + Execute common steps to configure queue buffer split on inner ipv4. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv4 / udp / vxlan / eth / ipv4 src is 192.168.0.1 dst is 192.168.0.2 / end actions queue index 2 / mark / end + +4. Send matched packets. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.1",dst="192.168.0.2")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=84 and pay_len=30. + + Send MAC_IPV4_UDP_VXLAN_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1",dst="192.168.0.2")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=70 and pay_len=30. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.3",dst="192.168.0.2")/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1",dst="192.168.0.4")/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +6. Destroy the rule:: + + flow destroy 0 rule 0 + +Subcase 2: buffer split inner-ipv4 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Test Case 10: QUEUE_BUFFER_SPLIT_INNER_IPV6 +------------------------------------------- +Launch one port with multi queues testpmd, configure queue buffer split on inner ipv6, send matched packets and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the inner ipv6. + +Test Steps +~~~~~~~~~~ +Subcase 1: buffer split ipv6 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch one port with multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 4 rx_offload buffer_split on + port 0 rxq 5 rx_offload buffer_split on + + Modify common step 5 to:: + + set rxhdrs ipv6 + + Execute common steps to configure queue buffer split on inner ipv6. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv6 src is 2001::1 dst is 2001::2 / end actions rss queues 4 5 end / mark / end + +4. Send matched packets. + + Send MAC_IPV6_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::1",dst="2001::2")/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=54 and pay_len=30. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::8",dst="2001::2")/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::1",dst="2001::9")/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +6. Destroy the rule:: + + flow destroy 0 rule 0 + +Subcase 2: buffer split inner-ipv6 +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Test Case 11: QUEUE_BUFFER_SPLIT_INNER_UDP +------------------------------------------ +Launch one port with multi queues testpmd, configure queue buffer split on inner udp, send matched packets and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the inner udp. + +Test Steps +~~~~~~~~~~ +Subcase 1: buffer split ipv4-udp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch one port with multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 3 rx_offload buffer_split on + + Modify common step 5 to:: + + set rxhdrs ipv4-udp + + Execute common steps to configure queue buffer split on inner udp. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv4 / udp / vxlan / eth / ipv4 src is 192.168.0.1 dst is 192.168.0.2 / udp dst is 23 / end actions queue index 3 / mark / end + +4. Send matched packets. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.1", dst="192.168.0.2")/UDP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=92 and pay_len=30. + + Send MAC_IPV4_UDP_VXLAN_IPV4_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1", dst="192.168.0.2")/UDP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=78 and pay_len=30. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.3", dst="192.168.0.2")/UDP(dport=23)/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1", dst="192.168.0.2")/UDP(dport=24)/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +6. Destroy the rule:: + + flow destroy 0 rule 0 + +Subcase 2: buffer split ipv6-udp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch one port multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 3 rx_offload buffer_split on + + Modify common step 5 to:: + + set rxhdrs ipv6-udp + + Execute common steps to configure queue buffer split on inner udp. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv6 src is 2001::1 dst is 2001::2 / udp dst is 23 / end actions queue index 3 / mark / end + +4. Send matched packets. + + Send MAC_IPV6_UDP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::1",dst="2001::2")/UDP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=62 and pay_len=30. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::8",dst="2001::2")/UDP(dport=23)/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::1",dst="2001::2")/UDP(dport=24)/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools.(hdr_len=0) + +6. Destroy the rule:: + + flow destroy 0 rule 0 + +Subcase 3: buffer split inner-ipv4-udp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 4: buffer split inner-ipv6-udp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Test Case 12: QUEUE_BUFFER_SPLIT_INNER_TCP +------------------------------------------ +Launch one port with multi queues testpmd, configure queue buffer split on inner tcp, send matched packets and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the inner tcp. + +Test Steps +~~~~~~~~~~ +Subcase 1: buffer split ipv4-tcp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch one port with multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 2 rx_offload buffer_split on + port 0 rxq 3 rx_offload buffer_split on + + Modify common step 5 to:: + + set rxhdrs ipv4-tcp + + Execute common steps to configure queue buffer split on inner tcp. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv4 / udp / vxlan / eth / ipv4 src is 192.168.0.1 dst is 192.168.0.2 / tcp dst is 23 / end actions rss queues 2 3 end / mark / end + +4. Send matched packets. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV4_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.1", dst="192.168.0.2")/TCP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=104 and pay_len=30. + + Send MAC_IPV4_UDP_VXLAN_IPV4_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1", dst="192.168.0.2")/TCP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=90 and pay_len=30. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.3", dst="192.168.0.2")/TCP(dport=23)/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1", dst="192.168.0.2")/TCP(dport=24)/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +6. Destroy the rule:: + + flow destroy 0 rule 0 + +Subcase 2: buffer split ipv6-tcp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch one port multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 2 rx_offload buffer_split on + port 0 rxq 3 rx_offload buffer_split on + + Modify common step 5 to:: + + set rxhdrs ipv6-tcp + + Execute common steps to configure queue buffer split on inner udp. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv6 src is 2001::1 dst is 2001::2 / tcp dst is 23 / end actions rss queues 2 3 end / mark / end + +4. Send matched packets. + + Send MAC_IPV6_TCP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::1",dst="2001::2")/TCP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=74 and pay_len=30. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::8",dst="2001::2")/TCP(dport=23)/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::1",dst="2001::2")/TCP(dport=24)/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +6. Destroy the rule:: + + flow destroy 0 rule 0 + +Subcase 3: buffer split inner-ipv4-tcp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 4: buffer split inner-ipv6-tcp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Test Case 13: QUEUE_BUFFER_SPLIT_INNER_SCTP +------------------------------------------- +Launch one port with multi queues testpmd, configure queue buffer split on inner sctp, send matched packets and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the inner sctp. + +Test Steps +~~~~~~~~~~ +Subcase 1: buffer split ipv4-sctp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch one port multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 5 rx_offload buffer_split on + + Modify common step 5 to:: + + set rxhdrs ipv4-sctp + + Execute common steps to configure queue buffer split on inner sctp. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv4 / udp / vxlan / eth / ipv4 src is 192.168.0.1 dst is 192.168.0.2 / sctp dst is 23 / end actions queue index 5 / mark / end + +4. Send matched packets. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV4_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.1", dst="192.168.0.2")/SCTP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=96 and pay_len=30. + + Send MAC_IPV4_UDP_VXLAN_IPV4_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1", dst="192.168.0.2")/SCTP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=82 and pay_len=30. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.3", dst="192.168.0.2")/SCTP(dport=23)/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1", dst="192.168.0.2")/SCTP(dport=24)/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +6. Destroy the rule:: + + flow destroy 0 rule 0 + +Subcase 2: buffer split ipv6-sctp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +1. Launch one port multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 5 rx_offload buffer_split on + + Modify common step 5 to:: + + set rxhdrs ipv6-sctp + + Execute common steps to configure queue buffer split on inner sctp. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv6 src is 2001::1 dst is 2001::2 / sctp dst is 23 / end actions queue index 5 / mark / end + +4. Send matched packets. + + Send MAC_IPV6_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::1",dst="2001::2")/SCTP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=66 and pay_len=30. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::8",dst="2001::2")/SCTP(dport=23)/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IPv6(src="2001::1",dst="2001::2")/SCTP(dport=24)/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +6. Destroy the rule:: + + flow destroy 0 rule 0 + +Subcase 3: buffer split inner-ipv4-sctp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Subcase 4: buffer split inner-ipv6-sctp +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Test Case 14: QUEUE_BUFFER_SPLIT_TUNNEL +--------------------------------------- +Launch one port with multi queues testpmd, configure queue buffer split on tunnel, send matched packets and check the received packets +can be devided into two mempools with expected hdr and payload length/content by the tunnel. + +Test Steps +~~~~~~~~~~ +1. Launch one port multi queues testpmd:: + + /app/dpdk-testpmd -a 3b:00.0 --force-max-simd-bitwidth=64 -- -i --mbuf-size=2048,2048 --txq=8 --rxq=8 + +2. Modify common step 2 to:: + + port 0 rxq 4 rx_offload buffer_split on + + port 0 rxq 5 rx_offload buffer_split on + + Modify common step 5 to:: + + set rxhdrs grenat + + Execute common steps to configure queue buffer split on inner udp. + +3. Create a fdir rule:: + + flow create 0 ingress pattern eth / ipv4 / udp / vxlan / eth / ipv4 src is 192.168.0.1 dst is 192.168.0.2 / udp dst is 23 / end actions rss queues 4 5 end / mark / end + +4. Send matched packets. + + Send MAC_IPV4_UDP_VXLAN_MAC_IPV4_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.0.1", dst="192.168.0.2")/UDP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=50 and pay_len=72. + + Send MAC_IPV4_UDP_VXLAN_IPV4_SCTP_PAY packet:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1", dst="192.168.0.2")/UDP(dport=23)/("Y"*30)], iface="ens260f0") + + Check the received packets can be devided into two mempools with hdr_len=50 and pay_len=58. + +5. Send mismatched packets:: + + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP()/VXLAN()/Ether(dst="00:11:22:33:44:66")/IP(src="192.168.1.1", dst="192.168.0.2")/UDP(dport=23)/("Y"*30)], iface="ens260f0") + sendp([Ether(dst="00:11:22:33:44:55")/IP()/UDP(sport=200, dport=4790)/VXLAN()/IP(src="192.168.0.1", dst="192.168.0.2")/UDP(dport=24)/("Y"*30)], iface="ens260f0") + + Check the received packets can't be devided into two mempools and hdr_len=0. + +6. Destroy the rule:: + + flow destroy 0 rule 0 +