From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from dpdk.org (dpdk.org [92.243.14.124]) by dpdk.space (Postfix) with ESMTP id 7E3C8A05D3 for ; Mon, 22 Apr 2019 10:15:52 +0200 (CEST) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 6EB6E1B148; Mon, 22 Apr 2019 10:15:52 +0200 (CEST) Received: from mga09.intel.com (mga09.intel.com [134.134.136.24]) by dpdk.org (Postfix) with ESMTP id 51D8B1B13C for ; Mon, 22 Apr 2019 10:15:48 +0200 (CEST) X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga007.jf.intel.com ([10.7.209.58]) by orsmga102.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 22 Apr 2019 01:15:47 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.60,381,1549958400"; d="scan'208";a="133315519" Received: from npg-dpdk-project-yinanwang-1.sh.intel.com ([10.67.110.176]) by orsmga007.jf.intel.com with ESMTP; 22 Apr 2019 01:15:46 -0700 From: Yinan To: dts@dpdk.org Cc: Wang Yinan Date: Mon, 22 Apr 2019 01:13:22 +0000 Message-Id: <20190422011322.27699-1-yinan.wang@intel.com> X-Mailer: git-send-email 2.17.1 Subject: [dts] [PATCH v1] test_plans/loopback_multi_queues: add test plan for loopback multi-queues test X-BeenThere: dts@dpdk.org X-Mailman-Version: 2.1.15 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 Sender: "dts" From: Wang Yinan Signed-off-by: Wang Yinan --- .../loopback_multi_queues_test_plan.rst | 306 ++++++++++++++++++ 1 file changed, 306 insertions(+) create mode 100644 test_plans/loopback_multi_queues_test_plan.rst diff --git a/test_plans/loopback_multi_queues_test_plan.rst b/test_plans/loopback_multi_queues_test_plan.rst new file mode 100644 index 0000000..68fb61f --- /dev/null +++ b/test_plans/loopback_multi_queues_test_plan.rst @@ -0,0 +1,306 @@ +.. Copyright (c) <2019>, Intel Corporation + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + - Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + + - Redistributions in binary forim must reproduce the above copyright + notice, this list of conditions and the following disclaimer in + the documentation and/or other materials provided with the + distribution. + + - Neither the name of Intel Corporation nor the names of its + contributors may be used to endorse or promote products derived + from this software without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS + FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE + COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, + INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED + OF THE POSSIBILITY OF SUCH DAMAGE. + +===================================================== +vhost/virtio-user loopback with multi-queue test plan +===================================================== + +Description +=========== + +Benchmark vhost/virtio-user loopback multi-queues test with 8 rx/tx paths, virtio-user support 8 queues in maximum. +Includes mergeable, normal, vector_rx, inorder mergeable, +inorder no-mergeable, virtio 1.1 mergeable, virtio 1.1 inorder, virtio 1.1 normal path. + +Test Case 1: loopback 2 queues test with virtio 1.1 mergeable path +================================================================== +1. Launch testpmd by below command:: + + rm -rf vhost-net* + ./testpmd -c 0xe -n 4 --socket-mem 1024,1024 --no-pci \ + --vdev 'eth_vhost0,iface=vhost-net,queues=2' -- \ + -i --nb-cores=2 --rxq=2 --txq=2 --txd=1024 --rxd=1024 + testpmd>set fwd mac + +2. Launch virtio-user by below command:: + + ./testpmd -n 4 -l 5-7 --socket-mem 1024,1024 \ + --legacy-mem --no-pci --file-prefix=virtio \ + --vdev=net_virtio_user0,mac=00:01:02:03:04:05,path=./vhost-net,queues=2,packed_vq=1,mrg_rxbuf=1,in_order=0 \ + -- -i --tx-offloads=0x0 --enable-hw-vlan-strip --rss-ip --nb-cores=2 --rxq=2 --txq=2 --txd=1024 --rxd=1024 + >set fwd mac + >start + +3. Send packets with vhost-testpmd,[frame_size] is the parameter changs in [64, 128, 256, 512, 1024, 1518]:: + + testpmd>set txpkts [frame_size] + testpmd>start tx_first 32 + +4. Get throughput 10 times and calculate the average throughput:: + + testpmd>show port stats all + +5. Check each queue's RX/TX packet numbers:: + + testpmd>stop + +Test Case 2: loopback 2 queues test with virtio 1.1 normal path +=============================================================== + +1. Launch testpmd by below command:: + + rm -rf vhost-net* + ./testpmd -c 0xe -n 4 --socket-mem 1024,1024 --no-pci \ + --vdev 'eth_vhost0,iface=vhost-net,queues=2' -- \ + -i --nb-cores=2 --rxq=2 --txq=2 --txd=1024 --rxd=1024 + testpmd>set fwd mac + +2. Launch virtio-user by below command:: + + ./testpmd -n 4 -l 5-7 --socket-mem 1024,1024 \ + --legacy-mem --no-pci --file-prefix=virtio \ + --vdev=net_virtio_user0,mac=00:01:02:03:04:05,path=./vhost-net,queues=2,packed_vq=1,mrg_rxbuf=0,in_order=0 \ + -- -i --tx-offloads=0x0 --enable-hw-vlan-strip --rss-ip --nb-cores=2 --rxq=2 --txq=2 --txd=1024 --rxd=1024 + >set fwd mac + >start + +3. Send packets with vhost-testpmd,[frame_size] is the parameter changs in [64, 128, 256, 512, 1024, 1518]:: + + testpmd>set txpkts [frame_size] + testpmd>start tx_first 32 + +4. Get throughput 10 times and calculate the average throughput:: + + testpmd>show port stats all + +5. Check each queue's RX/TX packet numbers:: + + testpmd>stop + +Test Case 3: loopback 2 queues test with virtio 1.1 inorder path +================================================================ + +1. Launch testpmd by below command:: + + rm -rf vhost-net* + ./testpmd -c 0xe -n 4 --socket-mem 1024,1024 --no-pci \ + --vdev 'eth_vhost0,iface=vhost-net,queues=2' -- \ + -i --nb-cores=2 --rxq=2 --txq=2 --txd=1024 --rxd=1024 + testpmd>set fwd mac + +2. Launch virtio-user by below command:: + + ./testpmd -n 4 -l 5-7 --socket-mem 1024,1024 \ + --legacy-mem --no-pci --file-prefix=virtio \ + --vdev=net_virtio_user0,mac=00:01:02:03:04:05,path=./vhost-net,queues=2,packed_vq=1,mrg_rxbuf=0,in_order=1 \ + -- -i --tx-offloads=0x0 --enable-hw-vlan-strip --rss-ip --nb-cores=2 --rxq=2 --txq=2 --txd=1024 --rxd=1024 + >set fwd mac + >start + +3. Send packets with vhost-testpmd,[frame_size] is the parameter changs in [64, 128, 256, 512, 1024, 1518]:: + + testpmd>set txpkts [frame_size] + testpmd>start tx_first 32 + +4. Get throughput 10 times and calculate the average throughput:: + + testpmd>show port stats all + +5. Check each queue's RX/TX packet numbers:: + + testpmd>stop + +Test Case 4: loopback 2 queues test with inorder mergeable path +=============================================================== + +1. Launch testpmd by below command:: + + rm -rf vhost-net* + ./testpmd -c 0xe -n 4 --socket-mem 1024,1024 --no-pci \ + --vdev 'eth_vhost0,iface=vhost-net,queues=2' -- \ + -i --nb-cores=2 --rxq=2 --txq=2 --txd=1024 --rxd=1024 + testpmd>set fwd mac + +2. Launch virtio-user by below command:: + + ./testpmd -n 4 -l 5-7 --socket-mem 1024,1024 \ + --legacy-mem --no-pci --file-prefix=virtio \ + --vdev=net_virtio_user0,mac=00:01:02:03:04:05,path=./vhost-net,queues=2,in_order=1,mrg_rxbuf=1 \ + -- -i --tx-offloads=0x0 --enable-hw-vlan-strip --rss-ip --nb-cores=2 --rxq=2 --txq=2 --txd=1024 --rxd=1024 + >set fwd mac + >start + +3. Send packets with vhost-testpmd,[frame_size] is the parameter changs in [64, 128, 256, 512, 1024, 1518]:: + + testpmd>set txpkts [frame_size] + testpmd>start tx_first 32 + +4. Get throughput 10 times and calculate the average throughput:: + + testpmd>show port stats all + +5. Check each queue's RX/TX packet numbers:: + + testpmd>stop + +Test Case 5: loopback 2 queues test with inorder no-mergeable path +================================================================== + +1. Launch testpmd by below command:: + + rm -rf vhost-net* + ./testpmd -c 0xe -n 4 --socket-mem 1024,1024 --no-pci \ + --vdev 'eth_vhost0,iface=vhost-net,queues=2' -- \ + -i --nb-cores=2 --rxq=2 --txq=2 --txd=1024 --rxd=1024 + testpmd>set fwd mac + +2. Launch virtio-user by below command:: + + ./testpmd -n 4 -l 5-7 --socket-mem 1024,1024 \ + --legacy-mem --no-pci --file-prefix=virtio \ + --vdev=net_virtio_user0,mac=00:01:02:03:04:05,path=./vhost-net,queues=2,in_order=1,mrg_rxbuf=0 \ + -- -i --tx-offloads=0x0 --enable-hw-vlan-strip --rss-ip --nb-cores=2 --rxq=2 --txq=2 --txd=1024 --rxd=1024 + >set fwd mac + >start + +3. Send packets with vhost-testpmd,[frame_size] is the parameter changs in [64, 128, 256, 512, 1024, 1518]:: + + testpmd>set txpkts [frame_size] + testpmd>start tx_first 32 + +4. Get throughput 10 times and calculate the average throughput:: + + testpmd>show port stats all + +5. Check each queue's RX/TX packet numbers:: + + testpmd>stop + +Test Case 6: loopback 8 queues test with mergeable path +======================================================= + +1. Launch testpmd by below command:: + + rm -rf vhost-net* + ./testpmd -l 2-6 -n 4 --socket-mem 1024,1024 --no-pci \ + --vdev 'eth_vhost0,iface=vhost-net,queues=8' -- \ + -i --nb-cores=4 --rxq=8 --txq=8 --txd=1024 --rxd=1024 + testpmd>set fwd mac + +2. Launch virtio-user by below command:: + + ./testpmd -n 4 -l 7-11 --socket-mem 1024,1024 \ + --legacy-mem --no-pci --file-prefix=virtio \ + --vdev=net_virtio_user0,mac=00:01:02:03:04:05,path=./vhost-net,queues=8,in_order=0,mrg_rxbuf=1 \ + -- -i --tx-offloads=0x0 --enable-hw-vlan-strip --rss-ip --nb-cores=4--rxq=8 --txq=8 --txd=1024 --rxd=1024 + >set fwd mac + >start + +3. Send packets with vhost-testpmd,[frame_size] is the parameter changs in [64, 128, 256, 512, 1024, 1518]:: + + testpmd>set txpkts [frame_size] + testpmd>start tx_first 32 + +4. Get throughput 10 times and calculate the average throughput:: + + testpmd>show port stats all + +5. Check each queue's RX/TX packet numbers:: + + testpmd>stop + + +Test Case 7: loopback 8 queues test with normal path +==================================================== + +1. Launch vhost by below command:: + + rm -rf vhost-net* + ./testpmd -n 4 -l 2-6 --socket-mem 1024,1024 --legacy-mem --no-pci \ + --file-prefix=vhost --vdev 'net_vhost0,iface=vhost-net,queues=8' -- \ + -i --nb-cores=4 --rxq=8 --txq=8 --txd=1024 --rxd=1024 + >set fwd mac + +2. Launch virtio-user by below command:: + + ./testpmd -n 4 -l 7-11 --socket-mem 1024,1024 \ + --legacy-mem --no-pci --file-prefix=virtio \ + --vdev=net_virtio_user0,mac=00:01:02:03:04:05,path=./vhost-net,queues=8,in_order=0,mrg_rxbuf=0 \ + -- -i --tx-offloads=0x0 --enable-hw-vlan-strip --rss-ip --nb-cores=4 --rxq=8 --txq=8 --txd=1024 --rxd=1024 + >set fwd mac + >start + +3. Send packets with vhost-testpmd,[frame_size] is the parameter changs in [64, 128, 256, 512, 1024, 1518]:: + + testpmd>set txpkts [frame_size] + testpmd>start tx_first 32 + +4. Get throughput 10 times and calculate the average throughput:: + + testpmd>show port stats all + +5. Check each queue's RX/TX packet numbers:: + + testpmd>stop + +Test Case 8: loopback 8 queues test with vector_rx path +======================================================= + +1. Launch vhost by below command:: + + rm -rf vhost-net* + ./testpmd -n 4 -l 2-6 --socket-mem 1024,1024 --legacy-mem --no-pci \ + --file-prefix=vhost --vdev 'net_vhost0,iface=vhost-net,queues=8' -- \ + -i --nb-cores=4 --rxq=8 --txq=8 --txd=1024 --rxd=1024 + >set fwd mac + +2. Launch virtio-user by below command:: + + ./testpmd -n 4 -l 7-11 --socket-mem 1024,1024 \ + --legacy-mem --no-pci --file-prefix=virtio \ + --vdev=net_virtio_user0,mac=00:01:02:03:04:05,path=./vhost-net,queues=8,in_order=0,mrg_rxbuf=0 \ + -- -i --tx-offloads=0x0 --rss-ip --nb-cores=4 --rxq=8 --txq=8 --txd=1024 --rxd=1024 + >set fwd mac + >start + +3. Send packets with vhost-testpmd,[frame_size] is the parameter changs in [64, 128, 256, 512, 1024, 1518]:: + + testpmd>set txpkts [frame_size] + testpmd>start tx_first 32 + +4. Get throughput 10 times and calculate the average throughput:: + + testpmd>show port stats all + +5. Check each queue's RX/TX packet numbers:: + + testpmd>stop -- 2.17.1