test suite reviews and discussions
 help / color / mirror / Atom feed
From: "huilong,xu" <huilongx.xu@intel.com>
To: dts@dpdk.org
Subject: [dts] [dts 3/3] [PATCH V2] add generic filter test case
Date: Tue, 26 May 2015 14:31:58 +0800	[thread overview]
Message-ID: <1432621918-18883-3-git-send-email-huilongx.xu@intel.com> (raw)
In-Reply-To: <1432621918-18883-1-git-send-email-huilongx.xu@intel.com>

From: huilong xu <huilongx.xu@intel.com>

    1. generic filter type:
      a) 5 tuple filter
      b) 2 tuple filter
      c) syn filter
      d) ethertype filter
      e) flex filter
    2.) NIC list:
      a) niantic
      b) kawela_4
      c) bartonhills
      d) powerville
      e) fortville
    3) test case list:
      a) all filter test
      b) filter priority test
      c) filter priority test
      d) filter jumbo_frame test
      e) generic_filter performance test
      f) niantic max queue test

Signed-off-by: huilong xu <huilongx.xu@intel.com>
---
 tests/TestSuite_generic_filter.py |  828 +++++++++++++++++++++++++++++++++++++
 1 files changed, 828 insertions(+), 0 deletions(-)
 create mode 100644 tests/TestSuite_generic_filter.py

diff --git a/tests/TestSuite_generic_filter.py b/tests/TestSuite_generic_filter.py
new file mode 100644
index 0000000..26abea2
--- /dev/null
+++ b/tests/TestSuite_generic_filter.py
@@ -0,0 +1,828 @@
+# BSD LICENSE
+#
+# Copyright(c) 2010-2014 Intel Corporation. All rights reserved.
+# 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 form 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.
+
+"""
+DPDK Test suite.
+
+Test the support of VLAN Offload Features by Poll Mode Drivers.
+
+"""
+
+import dts
+import time
+import re
+
+from test_case import TestCase
+from settings import HEADER_SIZE
+from pmd_output import PmdOutput
+from settings import DRIVERS
+
+
+class TestGeneric_filter(TestCase):
+
+    def set_up_all(self):
+        """
+        Run at the start of each test suite.
+
+
+        Generic filter Prerequistites
+        """
+
+        # Based on h/w type, choose how many ports to use
+        ports = self.dut.get_ports(self.nic)
+        # Verify that enough ports are available
+        self.verify(len(ports) >= 2, "Insufficient ports")
+        cores = self.dut.get_core_list("all")
+        self.verify(len(cores) >= 10, "Insufficient core")
+        global coreMask
+        coreMask = dts.create_mask(cores)
+        # Based on h/w type, choose how many ports to use
+        global valports
+        valports = [_ for _ in ports if self.tester.get_local_port(_) != -1]
+        global portMask
+        portMask = dts.create_mask(valports[:2])
+        self.pmdout = PmdOutput(self.dut)
+        self.ethertype_filter = "off"
+
+    def request_mbufs(self, queue_num):
+        """
+        default txq/rxq descriptor is 64
+        """
+        return 128 * queue_num + 512
+
+    def port_config(self):
+        """
+         set port queue mapping, fortville not support this function
+        """
+        if self.nic not in ["fortville_eagle", "fortville_spirit", "fortville_spirit_single"]:
+            self.dut.send_expect(
+                "set stat_qmap rx %s 0 0" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "set stat_qmap rx %s 0 0" % valports[1], "testpmd> ")
+            self.dut.send_expect(
+                "set stat_qmap rx %s 1 1" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "set stat_qmap rx %s 1 1" % valports[1], "testpmd> ")
+            self.dut.send_expect(
+                "set stat_qmap rx %s 2 2" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "set stat_qmap rx %s 2 2" % valports[1], "testpmd> ")
+            self.dut.send_expect(
+                "set stat_qmap rx %s 3 3" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "set stat_qmap rx %s 3 3" % valports[1], "testpmd> ")
+            self.dut.send_expect(
+                "vlan set strip off %s" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "vlan set strip off %s" % valports[1], "testpmd> ")
+            self.dut.send_expect(
+                "vlan set filter off %s" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "vlan set filter off %s" % valports[1], "testpmd> ")
+
+        self.dut.send_expect("set flush_rx on", "testpmd> ")
+
+    def set_up(self):
+        """
+        Run before each test case.
+        """
+        pass
+
+    def filter_send_packet(self, type):
+        """
+        Send  packet to portid
+        """
+
+        port = self.tester.get_local_port(valports[0])
+        txItf = self.tester.get_interface(port)
+
+        port = self.tester.get_local_port(valports[1])
+        rxItf = self.tester.get_interface(port)
+
+        mac = self.dut.get_mac_address(valports[0])
+        self.tester.scapy_foreground()
+
+        if (type == "syn"):
+            self.tester.scapy_append(
+                'sendp([Ether(dst="%s")/IP(src="2.2.2.5",dst="2.2.2.4")/TCP(dport=80,flags="S")], iface="%s")' % (mac, txItf))
+        elif (type == "arp"):
+            self.tester.scapy_append(
+                'sendp([Ether(dst="ff:ff:ff:ff:ff:ff")/ARP(pdst="192.168.1.1")], iface="%s")' % (txItf))
+        elif (type == "arp_prio"):
+            self.tester.scapy_append(
+                'sendp([Ether(dst="ff:ff:ff:ff:ff:ff")/Dot1Q(prio=3)/ARP(pdst="192.168.1.1")], iface="%s")' % (txItf))
+        elif (type == "fivetuple"):
+            if self.nic == "niantic":
+                self.tester.scapy_append(
+                    'sendp([Ether(dst="%s")/Dot1Q(prio=3)/IP(src="2.2.2.4",dst="2.2.2.5")/TCP(sport=1,dport=1,flags=0)], iface="%s")' % (mac, txItf))
+            else:
+                self.tester.scapy_append(
+                    'sendp([Ether(dst="%s")/Dot1Q(prio=3)/IP(src="2.2.2.4",dst="2.2.2.5")/TCP(sport=1,dport=1)], iface="%s")' % (mac, txItf))
+        elif (type == "udp"):
+            self.tester.scapy_append(
+                'sendp([Ether(dst="%s")/IP(src="2.2.2.4",dst="2.2.2.5")/UDP(dport=64)], iface="%s")' % (mac, txItf))
+        elif (type == "ip"):
+            self.tester.scapy_append(
+                'sendp([Ether(dst="%s")/IP(src="2.2.2.4",dst="2.2.2.5")/TCP(sport=80,dport=80,flags=0)], iface="%s")' % (mac, txItf))
+        elif (type == "jumbo"):
+            self.tester.scapy_append(
+                'sendp([Ether(dst="%s")/IP(src="2.2.2.5",dst="2.2.2.4")/TCP(dport=80,flags="S")/Raw(load="\x50"*1500)], iface="%s")' % (mac, txItf))
+        elif (type == "packet"):
+            if (filters_index == 0):
+                self.tester.scapy_append(
+                    'sendp([Ether(dst="%s")/IP(src="2.2.2.4",dst="2.2.2.5")/TCP(sport=1,dport=1,flags=0)], iface="%s")' % (mac, txItf))
+            if (filters_index == 1):
+                self.tester.scapy_append(
+                    'sendp([Ether(dst="%s")/Dot1Q(prio=3)/IP(src="2.2.2.4",dst="2.2.2.5")/TCP(sport=1,dport=2,flags=0)], iface="%s")' % (mac, txItf))
+        self.tester.scapy_execute()
+
+    def verify_result(self, outstring, tx_pkts, expect_queue):
+
+        result_scanner = r"Forward Stats for RX Port= %s/Queue= ([0-9]+)" % valports[
+            0]
+
+        scanner = re.compile(result_scanner, re.DOTALL)
+        m = scanner.search(outstring)
+        queue_id = m.group(1)
+        if self.nic == "niantic" and self.ethertype_filter == "on" and expect_queue == "0":
+            self.ethertype_filter = "off"
+            self.verify(queue_id == "0", "packet pass  error")
+        if expect_queue != queue_id:
+            scanner = re.compile(result_scanner, re.DOTALL)
+            m = scanner.search(outstring)
+            queue_id = m.group(1)
+            result_scanner = r"RX-packets: ([0-9]+) \s*"
+            scanner = re.compile(result_scanner, re.DOTALL)
+            m = scanner.search(outstring)
+            p0tx_pkts = m.group(1)
+            
+        else:
+
+            result_scanner = r"RX-packets: ([0-9]+) \s*"
+
+            scanner = re.compile(result_scanner, re.DOTALL)
+            m = scanner.search(outstring)
+            p0tx_pkts = m.group(1)
+
+        self.verify(p0tx_pkts == tx_pkts, "packet pass  error")
+
+    # TODO: failing test even in non-converted version
+    def test_syn_filter(self):
+        """
+        Enable receipt of SYN packets
+        """
+        self.verify(self.nic in ["niantic", "kawela_4", "bartonhills", "powerville"], "%s nic not support syn filter" % self.nic)
+        self.pmdout.start_testpmd(
+            "all", "--disable-rss --rxq=4 --txq=4 --portmask=%s --nb-cores=8 --nb-ports=1" % portMask)
+        self.port_config()
+        self.dut.send_expect(
+            "syn_filter %s add priority high queue 2" % valports[0], "testpmd> ")
+        self.dut.send_expect("start", "testpmd> ", 120)
+
+        self.filter_send_packet("syn")
+        time.sleep(2)
+
+        out = self.dut.send_expect("stop", "testpmd> ")
+
+        self.verify_result(out, tx_pkts="1", expect_queue="2")
+
+        self.dut.send_expect("clear port stats all", "testpmd> ")
+        self.dut.send_expect("start", "testpmd> ")
+
+        self.filter_send_packet("arp")
+        time.sleep(2)
+        out = self.dut.send_expect("stop", "testpmd> ")
+
+        self.verify_result(out, tx_pkts="1", expect_queue="0")
+
+        self.dut.send_expect(
+            "syn_filter %s del priority high queue 2" % valports[0], "testpmd> ")
+        self.dut.send_expect("clear port stats all", "testpmd> ")
+        self.dut.send_expect("start", "testpmd> ", 120)
+        self.filter_send_packet("syn")
+        time.sleep(2)
+        out = self.dut.send_expect("stop", "testpmd> ")
+
+        self.verify_result(out, tx_pkts="1", expect_queue="0")
+        self.dut.send_expect("quit", "#")
+
+    def test_priority_filter(self):
+        """
+        priority filter
+        """
+        self.pmdout.start_testpmd(
+            "all", "--disable-rss --rxq=4 --txq=4 --portmask=%s --nb-cores=8 --nb-ports=1" % portMask)
+        self.port_config()
+
+        if self.nic == "niantic":
+            cmd = "5tuple_filter %s add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask 0x1f tcp_flags 0x0 priority 3 queue 3 " % (
+                valports[0])
+            self.dut.send_expect("%s" % cmd, "testpmd> ")
+            cmd = "5tuple_filter %s add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 2 src_port 1 protocol 0x06 mask 0x18 tcp_flags 0x0 priority 2 queue 2 " % (
+                valports[0])
+            self.dut.send_expect("%s" % cmd, "testpmd> ")
+            self.dut.send_expect("start", "testpmd> ", 120)
+            self.filter_send_packet("fivetuple")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="3")
+            cmd = "5tuple_filter %s del dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask 0x1f tcp_flags 0x0 priority 3 queue 3 " % (
+                valports[0])
+            self.dut.send_expect(cmd, "testpmd> ")
+
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.dut.send_expect("start", "testpmd> ", 120)
+            self.filter_send_packet("fivetuple")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="2")
+        elif self.nic == "kawela_4":
+            cmd = "5tuple_filter %s add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask 0x1f tcp_flags 0x02 priority 3 queue 3" % (
+                valports[0])
+            self.dut.send_expect("%s" % (cmd), "testpmd> ")
+            self.dut.send_expect(
+                "syn_filter %s add priority high queue 2" % valports[0], "testpmd> ")
+
+            self.dut.send_expect("start", "testpmd> ", 120)
+            self.filter_send_packet("fivetuple")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="2")
+            self.dut.send_expect(
+                "syn_filter %s del priority high queue 2" % valports[0], "testpmd> ")
+
+            self.dut.send_expect("start", "testpmd> ", 120)
+            self.filter_send_packet("fivetuple")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="3")
+        elif self.nic in ["bartonhills", "powerville"]:
+            self.dut.send_expect(
+                "flex_filter %s add len 16 bytes 0x0123456789abcdef0000000008000000 mask 000C priority 2 queue 1" % (valports[0]), "testpmd> ")
+            self.dut.send_expect(
+                "2tuple_filter %s add dst_port 64 protocol 0x11 mask 1 tcp_flags 0 priority 3 queue 2" % valports[0], "testpmd> ")
+            self.dut.send_expect("start", "testpmd> ", 120)
+            self.filter_send_packet("udp")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="1")
+            self.dut.send_expect(
+                "flex_filter %s del len 16 bytes 0x0123456789abcdef0000000008000000 mask 000C priority 2 queue 1" % valports[0], "testpmd> ")
+            self.dut.send_expect("start", "testpmd> ", 120)
+            self.filter_send_packet("udp")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="2")
+        else:
+            self.verify(False, "%s nic not support this test" % self.nic)
+
+    def test_five_tuple_filter(self):
+        """
+        five tuple filter
+        """
+        if self.nic in ["niantic", "kawela_4"]:
+            self.pmdout.start_testpmd(
+                "all", "--disable-rss --rxq=4 --txq=4 --portmask=%s --nb-cores=8 --nb-ports=1" % portMask)
+            self.port_config()
+
+            mask = ['0x1f', '0x0']
+            for case in mask:
+                if case == "0x1f":
+                    if self.nic == "niantic":
+                        cmd = "5tuple_filter %s add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask %s tcp_flags 0x0 priority 3 queue 3" % (
+                            valports[0], case)
+                    if self.nic == "kawela_4":
+                        cmd = "5tuple_filter %s add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask %s tcp_flags 0x02 priority 3 queue 3" % (
+                            valports[0], case)
+                else:
+                    if self.nic == "niantic":
+                        cmd = "5tuple_filter %s add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask %s tcp_flags 0x0 priority 3 queue 3" % (
+                            valports[0], case)
+                    if self.nic == "kawela_4":
+                        cmd = "5tuple_filter %s add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask %s tcp_flags 0x02 priority 3 queue 3" % (
+                            valports[0], case)
+
+                self.dut.send_expect("%s" % (cmd), "testpmd> ")
+                # if case == "0x1f":
+                #    out = self.dut.send_expect("get_5tuple_filter %s index 1" % valports[0], "testpmd> ")
+                #    self.verify('Destination IP:  0x02020205    mask: 1' in out, "set 5-tuple filter error")
+                #    self.verify('Source IP:       0x02020204    mask: 1' in out, "set 5-tuple filter error")
+                self.dut.send_expect("start", "testpmd> ", 120)
+
+                self.filter_send_packet("fivetuple")
+
+                out = self.dut.send_expect("stop", "testpmd> ")
+                self.verify_result(out, tx_pkts="1", expect_queue="3")
+                self.dut.send_expect("start", "testpmd> ", 120)
+                self.filter_send_packet("arp")
+                out = self.dut.send_expect("stop", "testpmd> ")
+                self.verify_result(out, tx_pkts="1", expect_queue="0")
+                if case == "0x1f":
+                    if self.nic == "niantic":
+                        cmd = "5tuple_filter %s del dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask %s tcp_flags 0x0 priority 3 queue 3" % (
+                            valports[0], case)
+                    if self.nic == "kawela_4":
+                        cmd = "5tuple_filter %s del dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask %s tcp_flags 0x02 priority 3 queue 3" % (
+                            valports[0], case)
+                else:
+                    if self.nic == "niantic":
+                        cmd = "5tuple_filter %s del dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask %s tcp_flags 0x0 priority 3 queue 3" % (
+                            valports[0], case)
+                    if self.nic == "kawela_4":
+                        cmd = "5tuple_filter %s del dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask %s tcp_flags 0x02 priority 3 queue 3" % (
+                            valports[0], case)
+
+                self.dut.send_expect("%s" % (cmd), "testpmd> ")
+                self.dut.send_expect("start", "testpmd> ", 120)
+                self.filter_send_packet("fivetuple")
+                out = self.dut.send_expect("stop", "testpmd> ")
+                self.verify_result(out, tx_pkts="1", expect_queue="0")
+            self.dut.send_expect("quit", "#")
+        else:
+            self.verify(False, "%s nic not support syn filter" % self.nic)
+
+    def test_ethertype_filter(self):
+
+        self.verify(self.nic in ["niantic", "kawela_4", "bartonhills", 
+                           "powerville", "fortville_eagle", "fortville_spirit",
+                           "fortville_spirit_single"], "%s nic not support syn filter" % self.nic)
+        self.pmdout.start_testpmd(
+            "all", "--disable-rss --rxq=4 --txq=4 --portmask=%s --nb-cores=8 --nb-ports=1" % portMask)
+        self.port_config()
+        self.ethertype_filter = "on"
+        ethertype = "0x0806"
+        self.dut.send_expect(
+            "ethertype_filter %s add mac_ignr 00:00:00:00:00:00 ethertype %s fwd queue 2" %
+            (valports[0], ethertype), "testpmd> ")
+        self.dut.send_expect("start", "testpmd> ", 120)
+
+        self.filter_send_packet("arp")
+        time.sleep(2)
+        out = self.dut.send_expect("stop", "testpmd> ")
+        self.dut.send_expect("clear port stats all", "testpmd> ")
+
+        self.verify_result(out, tx_pkts="1", expect_queue="2")
+        if self.nic == "niantic":
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("arp_prio")
+            time.sleep(2)
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="2")
+
+        self.dut.send_expect(
+            "ethertype_filter %s del mac_ignr 00:00:00:00:00:00 ethertype %s fwd queue 2" %
+            (valports[0], ethertype), "testpmd> ")
+        self.dut.send_expect("start", "testpmd> ", 120)
+        self.filter_send_packet("arp")
+        time.sleep(2)
+        out = self.dut.send_expect("stop", "testpmd> ")
+        self.dut.send_expect("clear port stats all", "testpmd> ")
+
+        self.verify_result(out, tx_pkts="1", expect_queue="0")
+
+    def test_multiple_filters_10GB(self):
+        if self.nic == "niantic":
+            self.pmdout.start_testpmd(
+                "all", "--disable-rss --rxq=4 --txq=4 --portmask=%s --nb-cores=8 --nb-ports=1" % portMask)
+            self.port_config()
+            self.dut.send_expect(
+                "syn_filter %s add priority high queue 1" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "ethertype_filter %s add mac_ignr 00:00:00:00:00:00 ethertype 0x0806 fwd queue 2" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "5tuple_filter %s add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask 0x1f tcp_flags 0x0 priority 3 queue 3 " % (valports[0]), "testpmd> ")
+            self.dut.send_expect("start", "testpmd> ")
+
+            self.filter_send_packet("syn")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="1")
+
+            self.ethertype_filter = "on"
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("arp")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="2")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("arp_prio")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="2")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("fivetuple")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="3")
+
+            self.dut.send_expect(
+                "5tuple_filter %s del dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask 0x1f tcp_flags 0x0 priority 3 queue 3 " % (valports[0]), "testpmd> ")
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("syn")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="1")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("arp")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="2")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("fivetuple")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="0")
+            self.dut.send_expect(
+                "ethertype_filter %s del mac_ignr 00:00:00:00:00:00 ethertype 0x0806 fwd queue 2" % valports[0], "testpmd> ")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("arp")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="0")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("syn")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="1")
+
+            self.dut.send_expect(
+                "syn_filter %s del priority high queue 1" % valports[0], "testpmd> ")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("syn")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.dut.send_expect("clear port stats all", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="0")
+
+        else:
+            self.verify(False, "%s nic not support this test" % self.nic)
+
+    def test_twotuple_filter(self):
+
+        if self.nic in ["powerville", "bartonhills"]:
+            self.pmdout.start_testpmd(
+                "all", "--disable-rss --rxq=4 --txq=4 --portmask=%s --nb-cores=8 --nb-ports=1" % portMask)
+            self.port_config()
+            self.dut.send_expect(
+                "2tuple_filter %s add dst_port 64 protocol 0x11 mask 1 tcp_flags 0 priority 3 queue 1" % valports[0], "testpmd> ")
+            self.dut.send_expect("start", "testpmd> ", 120)
+
+            self.filter_send_packet("udp")
+            out = self.dut.send_expect("stop", "testpmd> ")
+
+            self.verify_result(out, tx_pkts="1", expect_queue="1")
+
+            self.dut.send_expect("start", "testpmd> ")
+
+            self.filter_send_packet("syn")
+            time.sleep(2)
+            out = self.dut.send_expect("stop", "testpmd> ")
+
+            self.verify_result(out, tx_pkts="1", expect_queue="0")
+            self.dut.send_expect(
+                "2tuple_filter %s del dst_port 64 protocol 0x11 mask 1 tcp_flags 0 priority 3 queue 1" % valports[0], "testpmd> ")
+            self.dut.send_expect("start", "testpmd> ", 120)
+            self.filter_send_packet("udp")
+            time.sleep(2)
+            out = self.dut.send_expect("stop", "testpmd> ")
+
+            self.verify_result(out, tx_pkts="1", expect_queue="0")
+            self.dut.send_expect("quit", "#")
+        else:
+            self.verify(False, "%s nic not support two tuple filter" % self.nic)
+
+    def test_flex_filter(self):
+        self.verify(self.nic in ["powerville", "bartonhills"], '%s not support flex filter' % self.nic)
+
+        masks = ['000C', '000C']
+        self.pmdout.start_testpmd(
+            "all", "--disable-rss --rxq=4 --txq=4 --portmask=%s --nb-cores=8 --nb-ports=1" % portMask)
+        self.port_config()
+        for i in [0, 1]:
+            if i == 0:
+                self.dut.send_expect(
+                    "flex_filter %s add len 16 bytes 0x0123456789abcdef0000000008060000 mask %s priority 3 queue 1" %
+                    (valports[0], masks[i]), "testpmd> ")
+            else:
+                self.dut.send_expect(
+                    "flex_filter %s add len 16 bytes 0x0123456789abcdef0000000008000000 mask %s priority 3 queue 1" %
+                    (valports[0], masks[i]), "testpmd> ")
+
+            self.dut.send_expect("start", "testpmd> ", 120)
+
+            if i == 0:
+                self.filter_send_packet("arp")
+            else:
+                self.filter_send_packet("ip")
+            time.sleep(2)
+            out = self.dut.send_expect("stop", "testpmd> ")
+
+            self.verify_result(out, tx_pkts="1", expect_queue="1")
+
+            self.dut.send_expect("start", "testpmd> ")
+
+            if i == 0:
+                self.filter_send_packet("syn")
+            else:
+                self.filter_send_packet("arp")
+            time.sleep(2)
+            out = self.dut.send_expect("stop", "testpmd> ")
+
+            self.verify_result(out, tx_pkts="1", expect_queue="0")
+            if i == 0:
+                self.dut.send_expect(
+                    "flex_filter %s del len 16 bytes 0x0123456789abcdef0000000008060000 mask %s priority 3 queue 1" %
+                    (valports[0], masks[i]), "testpmd> ")
+            else:
+                self.dut.send_expect(
+                    "flex_filter %s del len 16 bytes 0x0123456789abcdef0000000008000000 mask %s priority 3 queue 1" %
+                    (valports[0], masks[i]), "testpmd> ")
+            self.dut.send_expect("start", "testpmd> ", 120)
+            if i == 0:
+                self.filter_send_packet("arp")
+            else:
+                self.filter_send_packet("ip")
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="0")
+
+    def test_multiple_filters_1GB(self):
+
+        if self.nic in ["powerville", "kawela_4", "bartonhills"]:
+            self.pmdout.start_testpmd(
+                "all", "--disable-rss --rxq=4 --txq=4 --portmask=%s --nb-cores=8 --nb-ports=1" % portMask)
+            self.port_config()
+            self.dut.send_expect(
+                "syn_filter %s add priority high queue 1" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "ethertype_filter %s add mac_ignr 00:00:00:00:00:00 ethertype 0x0806 fwd queue 3" % (valports[0]), "testpmd> ")
+            self.dut.send_expect("start", "testpmd> ")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("arp")
+            time.sleep(2)
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="3")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("syn")
+            time.sleep(2)
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="1")
+
+            # remove all filter
+
+            self.dut.send_expect(
+                "syn_filter %s del priority high queue 1" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "ethertype_filter %s del mac_ignr 00:00:00:00:00:00 ethertype 0x0806 fwd queue 3" % valports[0], "testpmd> ")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("arp")
+            time.sleep(2)
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="0")
+
+            self.dut.send_expect("start", "testpmd> ")
+            self.filter_send_packet("syn")
+            time.sleep(2)
+            out = self.dut.send_expect("stop", "testpmd> ")
+            self.verify_result(out, tx_pkts="1", expect_queue="0")
+        else:
+            self.verify(False, "%s nic not support this test" % self.nic)
+    def test_jumbo_frame_size(self):
+        
+        self.verify(self.nic not in ["fortville_eagle", "fortville_spirit", "fortville_spirit_single"], "%s nic not support this test" % self.nic)
+        self.pmdout.start_testpmd(
+            "all", "--disable-rss --rxq=4 --txq=4 --portmask=%s --nb-cores=8 --nb-ports=1 --mbcache=200 --mbuf-size=2048 --max-pkt-len=9600" % portMask)
+        port = self.tester.get_local_port(valports[0])
+        txItf = self.tester.get_interface(port)
+
+        port = self.tester.get_local_port(valports[1])
+        rxItf = self.tester.get_interface(port)
+        self.tester.send_expect("ifconfig %s mtu %s" % (txItf, 9200), "# ")
+        self.tester.send_expect("ifconfig %s mtu %s" % (rxItf, 9200), "# ")
+
+        self.dut.send_expect(
+            "set stat_qmap rx %s 0 0" % valports[0], "testpmd> ")
+        self.dut.send_expect(
+            "set stat_qmap rx %s 0 0" % valports[1], "testpmd> ")
+        self.dut.send_expect(
+            "set stat_qmap rx %s 1 1" % valports[0], "testpmd> ")
+        self.dut.send_expect(
+            "set stat_qmap rx %s 1 1" % valports[1], "testpmd> ")
+        self.dut.send_expect(
+            "set stat_qmap rx %s 2 2" % valports[0], "testpmd> ")
+        self.dut.send_expect(
+            "set stat_qmap rx %s 2 2" % valports[1], "testpmd> ")
+        self.dut.send_expect(
+            "set stat_qmap rx %s 3 3" % valports[0], "testpmd> ")
+        self.dut.send_expect(
+            "set stat_qmap rx %s 3 3" % valports[1], "testpmd> ")
+        self.dut.send_expect(
+            "vlan set strip off %s" % valports[0], "testpmd> ")
+        self.dut.send_expect(
+            "vlan set strip off %s" % valports[1], "testpmd> ")
+        self.dut.send_expect(
+            "vlan set filter off %s" % valports[0], "testpmd> ")
+        self.dut.send_expect(
+            "vlan set filter off %s" % valports[1], "testpmd> ")
+        self.dut.send_expect(
+            "syn_filter %s add priority high queue 2" % valports[0], "testpmd> ")
+
+        self.dut.send_expect("start", "testpmd> ", 120)
+
+        self.filter_send_packet("jumbo")
+        time.sleep(1)
+
+        out = self.dut.send_expect("stop", "testpmd> ")
+        self.dut.send_expect("clear port stats all", "testpmd>")
+
+        self.verify_result(out, tx_pkts="1", expect_queue="2")
+
+        self.dut.send_expect("start", "testpmd> ")
+
+        self.filter_send_packet("arp")
+        time.sleep(1)
+        out = self.dut.send_expect("stop", "testpmd> ")
+        self.dut.send_expect("clear port stats all", "testpmd>")
+
+        self.verify_result(out, tx_pkts="1", expect_queue="0")
+
+        self.dut.send_expect(
+            "syn_filter %s del priority high queue 2" % valports[0], "testpmd> ")
+        self.dut.send_expect("start", "testpmd> ", 120)
+        self.filter_send_packet("jumbo")
+        time.sleep(1)
+        out = self.dut.send_expect("stop", "testpmd> ")
+        self.dut.send_expect("clear port stats all", "testpmd>")
+
+        self.verify_result(out, tx_pkts="1", expect_queue="0")
+        self.tester.send_expect("ifconfig %s mtu %s" % (txItf, 1500), "# ")
+        self.tester.send_expect("ifconfig %s mtu %s" % (rxItf, 1500), "# ")
+
+    def test_128_queues(self):
+        # testpmd can't support assign queue to received package, so can't test
+        self.verify(False, "testpmd not support assign queue 127 received package")
+        if self.nic == "niantic":
+            global valports
+            total_mbufs = self.request_mbufs(128) * len(valports)
+            self.pmdout.start_testpmd(
+                "all", "--disable-rss --rxq=128 --txq=128 --portmask=%s --nb-cores=8 --total-num-mbufs=%d" % (portMask, total_mbufs))
+            self.dut.send_expect(
+                "set stat_qmap rx %s 0 0" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "set stat_qmap rx %s 0 0" % valports[1], "testpmd> ")
+            self.dut.send_expect(
+                "vlan set strip off %s" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "vlan set strip off %s" % valports[1], "testpmd> ")
+            self.dut.send_expect(
+                "vlan set filter off %s" % valports[0], "testpmd> ")
+            self.dut.send_expect(
+                "vlan set filter off %s" % valports[1], "testpmd> ")
+            frames_to_send = 1
+            queue = ['64', '127', '128']
+
+            for i in [0, 1, 2]:
+                if i == 2:
+                    out = self.dut.send_expect(
+                        "set stat_qmap rx %s %s %s" % (valports[0], queue[i], (i + 1)), "testpmd> ")
+                    self.verify('Invalid RX queue %s' %
+                                (queue[i]) in out, "set filters error")
+                    out = self.dut.send_expect(
+                        "5tuple_filter %s add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port %s src_port 1 protocol 0x06 mask 0x1f tcp_flags 0x0 priority 3 queue %s " % (valports[0], (i + 1), queue[i]), "testpmd> ")
+                    self.verify('error' in out, "set filters error")
+                    continue
+                else:
+                    self.dut.send_expect("set stat_qmap rx %s %s %s" %
+                                         (valports[0], queue[i], (i + 1)), "testpmd> ")
+                    out = self.dut.send_expect("5tuple_filter %s add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port %s src_port 1 protocol 0x06 mask 0x1f tcp_flags 0x0 priority %d queue %s " % (
+                        valports[0], (i + 1), (3 - i), queue[i]), "testpmd> ")
+                    self.dut.send_expect("start", "testpmd> ", 120)
+                global filters_index
+                filters_index = i
+                self.filter_send_packet("packet")
+                time.sleep(1)
+                out = self.dut.send_expect("stop", "testpmd> ")
+                cmd = "Stats reg  %s RX-packets:             ([0-9]+)" % (
+                    i + 1)
+                result_scanner = r"%s" % cmd
+                scanner = re.compile(result_scanner, re.DOTALL)
+                m = scanner.search(out)
+                cur_pkt = m.group(1)
+                self.verify(
+                    int(cur_pkt) == frames_to_send, "packet pass assert error")
+
+            self.dut.send_expect("quit", "#")
+        else:
+            self.verify(False, "%s not support this test" % self.nic)
+
+    def test_perf_generic_filter_perf(self):
+        self.pmdout.start_testpmd(
+            "all", "--disable-rss --rxq=4 --txq=4 --portmask=%s --nb-cores=8 --nb-ports=1" % portMask)
+        self.port_config()
+        print valports[0], valports[1]
+        tx_port = self.tester.get_local_port(valports[0])
+        tx_mac = self.dut.get_mac_address(valports[0])
+        txItf = self.tester.get_interface(tx_port)
+
+        rx_port = self.tester.get_local_port(valports[1])
+        rxItf = self.tester.get_interface(rx_port)
+        package_sizes = [64, 128, 256, 512, 1024, 1280, 1518]
+        print tx_mac
+        print self.dut.ports_info[valports[0]], self.dut.ports_info[valports[1]]
+        test_type = {
+            "syn": ["syn_filter add 0 priority high queue 1", "syn_filter del 0 priority high queue 1"],
+            "ethertype": ["add_ethertype_filter 0 ethertype 0x0806 priority disable 0 queue 2 index 1", "remove_ethertype_filter 0 index 1"],
+            "5tuple": ["5tuple_filter 0 add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask 0x1f tcp_flags 0x02 priority 3 queue 3", "5tuple_filter 0 add dst_ip 2.2.2.5 src_ip 2.2.2.4 dst_port 1 src_port 1 protocol 0x06 mask 0x1f tcp_flags 0x02 priority 3 queue 3"]
+        }
+        stream_config = {
+            "syn": 'Ether(dst="%s")/IP(src="2.2.2.5",dst="2.2.2.4")/TCP(dport=80,flags="S")/("X"*64)',
+            "ethertype": 'Ether(dst="%s")/ARP(pdst="192.168.1.1")' % tx_mac,
+            "5tuple": 'flows.append(Ether(dst="%s")/IP(src="2.2.2.4",dst="2.2.2.5")/TCP(sport=1,dport=1,flags=0)/("X"*%d))',
+        }
+        dts.results_table_add_header(
+            ['pack_size', "filter_type", "enable", "disable", "perf_compare"])
+        for key in test_type.keys():
+            if "5tuple" != key:
+                pps_lists = []
+                for i in range(2):
+                    self.dut.send_expect(test_type[key][i], "testpmd> ", 15)
+                    self.dut.send_expect("start", "testpmd> ", 120)
+                    self.tester.scapy_append('flows = []')
+                    self.tester.scapy_append(
+                        'flows.append(%s)' % stream_config[key])
+                    self.tester.scapy_append(
+                        'wrpcap("generic_firlter.pcap",flows)')
+                    self.tester.scapy_execute()
+                    tgen_input = []
+                    tgen_input.append(
+                        (tx_port, rx_port, "generic_firlter.pcap"))
+                    _, pps = self.tester.traffic_generator_throughput(
+                        tgen_input)
+                    pps_lists.append(pps)
+                dts.results_table_add_row(
+                    ["defult", key, pps_lists[0], pps_lists[1], (pps_lists[0] - pps_lists[1]) / float(pps_lists[1])])
+            # this is a TCP/IP package, need test different payload_size
+            if ("5tuple" == key) and ("niantic" == self.nic):
+                for package_size in package_sizes:
+                    payload_size = package_size - \
+                        HEADER_SIZE["tcp"] - HEADER_SIZE[
+                            'ip'] - HEADER_SIZE['eth']
+                    pps_lists = []
+                    for i in range(2):
+                        self.dut.send_expect(
+                            test_type[key][i], "testpmd> ", 15)
+                        self.dut.send_expect("start", "testpmd> ", 120)
+                        self.tester.scapy_append('flows = []')
+                        self.tester.scapy_append('flows.append(%s)' % (
+                            stream_config[key] % (tx_mac, payload_size)))
+                        self.tester.scapy_append(
+                            'wrpcap("generic_firlter.pcap",flows)')
+                        self.tester.scapy_execute()
+                        tgen_input = []
+                        # tgen_input.append((txItf, rxItf, "generic_firlter.pcap"))
+                        tgen_input.append(
+                            (tx_port, rx_port, "generic_firlter.pcap"))
+                        print tgen_input
+                        _, pps = self.tester.traffic_generator_throughput(
+                            tgen_input)
+                        pps_lists.append(pps)
+                    dts.results_table_add_row(
+                        [package_size, key, pps_lists[0], pps_lists[1], (pps_lists[0] - pps_lists[1]) / float(pps_lists[1])])
+        dts.results_table_print()
+
+    def tear_down(self):
+        """
+        Run after each test case.
+        """
+        self.dut.kill_all()
-- 
1.7.4.4

  parent reply	other threads:[~2015-05-26  6:32 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-05-26  6:31 [dts] [dts 1/3] [PATCH V2] add generic filter test for niantic and fortville nic test huilong,xu
2015-05-26  6:31 ` [dts] [dts 2/3] [PATCH V2] add generic filter test plan huilong,xu
2015-05-26  6:31 ` huilong,xu [this message]
2015-06-01  9:02 ` [dts] [dts 1/3] [PATCH V2] add generic filter test for niantic and fortville nic test Liu, Yong

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1432621918-18883-3-git-send-email-huilongx.xu@intel.com \
    --to=huilongx.xu@intel.com \
    --cc=dts@dpdk.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).