* [dts] [PATCH V3 1/2] add fdir test case in plan
@ 2017-03-09 7:22 xu,huilong
2017-03-09 7:22 ` [dts] [PATCH V3 2/2] add fdir test code for new case xu,huilong
0 siblings, 1 reply; 2+ messages in thread
From: xu,huilong @ 2017-03-09 7:22 UTC (permalink / raw)
To: dts; +Cc: xu,huilong
update list:
1. Add url for fdir cmdline describe
2. Expand Flow Director for fortville to support ipv4 TOS, ipv4 PROTO, ipv4 TTL and ipv6 tc, ipv6 next-header, ipv6 hop-limits and ivlan
Signed-off-by: xu,huilong <huilongx.xu@intel.com>
---
test_plans/fdir_test_plan.rst | 384 +++++++++++++++++++++++++++++++++++++++++-
1 file changed, 376 insertions(+), 8 deletions(-)
diff --git a/test_plans/fdir_test_plan.rst b/test_plans/fdir_test_plan.rst
index 95a2926..b9fe789 100644
--- a/test_plans/fdir_test_plan.rst
+++ b/test_plans/fdir_test_plan.rst
@@ -42,6 +42,8 @@ The DUT has a dual port Intel 82599 10GbE Ethernet Controller, with one of these
ports connected to a port on another device that is controlled by the Scapy
packet generator.
+There are three cases only support fortville, the case list is test case 8,9,10.
+
The Ethernet interface identifier of the port that Scapy will use must be known.
In all tests below, it is referred to as "eth9".
@@ -77,7 +79,9 @@ be given but other fields must be as shown::
IP(src="192.168.0.1", dst="192.168.0.2")/GRE(proto=0xff)/IP()/UDP()
The test commands below assume that port 0 on the DUT is the port that is
-connected to the traffic generator. If this is not the case, the following
+connected to the traffic generator. All fdir cmdline please see doc on
+http://www.dpdk.org/doc/guides/testpmd_app_ug/testpmd_funcs.html#filter-functions.
+If this is not the case, the following
``testpmd`` commands must be changed, and also the ``--portmask`` parameter.
* ``show port fdir <port>``
@@ -96,7 +100,7 @@ forwarding mode must be set to rxonly, and the verbosity level > 0 ::
testpmd> set fwd rxonly
-Test case: Setting memory reserved for FDir filters
+Test case 1: Setting memory reserved for FDir filters
===================================================
Each FDir filter requires space in the Rx Packet Buffer (perfect filters require
@@ -165,7 +169,7 @@ are free to be used is equal to 8192 (8192 * 32B = 256KB).::
########################################################################
-Test case: Control levels of FDir match reporting
+Test case 2: Control levels of FDir match reporting
=================================================
The status of FDir filter matching for each packet can be reported by the
@@ -299,7 +303,7 @@ This time, the filter ID is different, and the packet goes to queue 1 ::
PKT_RX_IPV4_HDR
-Test case: FDir signature matching mode
+Test case 3: FDir signature matching mode
=======================================
This test adds signature filters to the hardware, and then checks whether sent
@@ -366,7 +370,7 @@ filter and check that there is a match::
PKT_RX_IPV6_HDR
-Test case: FDir perfect matching mode
+Test case 4: FDir perfect matching mode
=====================================
This test adds perfect-match filters to the hardware, and then checks whether
@@ -438,7 +442,7 @@ filter and check that there is a match::
PKT_RX_IPV4_HDR
-Test case: FDir filter masks
+Test case 5: FDir filter masks
============================
This section tests the functionality of the setting FDir masks to to affect
@@ -558,7 +562,7 @@ match the filter::
PKT_RX_IPV4_HDR
-Test case: FDir ``flexbytes`` filtering
+Test case 6: FDir ``flexbytes`` filtering
=======================================
The FDir feature supports setting up filters that can match on any two byte
@@ -619,7 +623,7 @@ check that this time both packets match (``p_gre1`` and ``p_gre2``)::
PKT_RX_IPV4_HDR
-Test case: FDir VLAN field filtering
+Test case 7: FDir VLAN field filtering
====================================
Connect port 0 of the DUT to a traffic generator capable of sending packets with
@@ -684,3 +688,367 @@ and then to 0x0017. The packets should still match the filter:::
PKT_RX_PKT_RX_FDIR
PKT_RX_IP_CKSUM
PKT_RX_IPV4_HDR
+
+
+Test Case 8: test with ipv4 TOS, PROTO, TTL
+===========================================
+
+1) start testpmd and initialize flow director flex payload configuration::
+
+ ./testpmd -c fffff -n 4 -- -i --disable-rss --pkt-filter-mode=perfect --rxq=8 --txq=8 --nb-cores=8
+ testpmd> port stop 0
+ testpmd> flow_director_flex_payload 0 l2 (0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15)
+ testpmd> flow_director_flex_payload 0 l3 (0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15)
+ testpmd> flow_director_flex_payload 0 l4 (0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15)
+ testpmd> flow_director_flex_mask 0 flow all (0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff)
+ testpmd> port start 0
+ testpmd> set verbose 1
+ testpmd> set fwd rxonly
+ testpmd> start
+
+Note::
+ assume FLEXBYTES = "0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88"
+ assume payload = "\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88"
+
+2) setup the fdir input set of IPv4::
+
+ testpmd> set_fdir_input_set 0 ipv4-other none select
+ testpmd> set_fdir_input_set 0 ipv4-other src-ipv4 add
+ testpmd> set_fdir_input_set 0 ipv4-other dst-ipv4 add
+
+3) add ipv4-tos to fdir input set, set tos to 16 and 8::
+
+ testpmd> set_fdir_input_set 0 ipv4-other ipv4-tos add
+ setup flow director filter rules,
+
+rule_1::
+ flow_director_filter 0 mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 tos 16 proto 255 ttl 255 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 1 fd_id 1
+
+rule_2::
+ flow_director_filter 0 mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 tos 8 proto 255 ttl 255 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 2 fd_id 2
+
+send packet to DUT,
+
+packet_1::
+ 'sendp([Ether(dst="%s")/IP(src="192.168.0.1", dst="192.168.0.2", tos=16, proto=255, ttl=255)/Raw(%s)], iface="%s")'\
+ %(dst_mac, payload, itf)
+
+packet_1 should be received by queue 1.
+
+packet_2::
+ 'sendp([Ether(dst="%s")/IP(src="192.168.0.1", dst="192.168.0.2", tos=8, proto=255, ttl=255)/Raw(%s)], iface="%s")'\
+ %(dst_mac, payload, itf)
+
+packet_2 should be received by queue 2.
+
+delete rule_1, send packet_1 again, packet_1 should be received by queue 0.
+delete rule_2, send packet_2 again, packet_2 should be received by queue 0.
+
+4) add ipv4-proto to fdir input set, set proto to 253 and 254::
+
+ testpmd> set_fdir_input_set 0 ipv4-other ipv4-proto add
+
+setup flow director filter rules
+rule_3::
+ flow_director_filter 0 mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 tos 16 proto 253 ttl 255 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 3 fd_id 3
+
+rule_4::
+ flow_director_filter 0 mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 tos 8 proto 254 ttl 255 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 4 fd_id 4
+
+send packet to DUT,
+
+packet_3::
+ 'sendp([Ether(dst="%s")/IP(src="192.168.0.1", dst="192.168.0.2", tos=16, proto=253, ttl=255)/Raw(%s)], iface="%s")'\
+ %(dst_mac, payload, itf)
+
+packet_3 should be received by queue 3.
+
+packet_4::
+ 'sendp([Ether(dst="%s")/IP(src="192.168.0.1", dst="192.168.0.2", tos=8, proto=254, ttl=255)/Raw(%s)], iface="%s")'\
+ %(dst_mac, payload, itf)
+
+packet_4 should be received by queue 4.
+
+delete rule_3, send packet_3 again, packet_3 should be received by queue 0.
+delete rule_4, send packet_4 again, packet_4 should be received by queue 0.
+
+5) test ipv4-ttl, set ttl to 32 and 64::
+
+ testpmd> set_fdir_input_set 0 ipv4-other ipv4-ttl add
+
+setup flow director filter rules,
+rule_5::
+ flow_director_filter 0 mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 tos 16 proto 253 ttl 32 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 5 fd_id 5
+
+rule_6::
+ flow_director_filter 0 mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 tos 8 proto 254 ttl 64 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 6 fd_id 6
+
+send packet to DUT,
+
+packet_5::
+ 'sendp([Ether(dst="%s")/IP(src="192.168.0.1", dst="192.168.0.2", tos=16, proto=253, ttl=32)/Raw(%s)], iface="%s")'\
+ %(dst_mac, payload, itf)
+
+packet_5 should be received by queue 5.
+
+packet_6::
+ 'sendp([Ether(dst="%s")/IP(src="192.168.0.1", dst="192.168.0.2", tos=8, proto=254, ttl=64)/Raw(%s)], iface="%s")'\
+ %(dst_mac, payload, itf)
+
+packet_6 should be received by queue 6.
+
+delete rule_5, send packet_5 again, packet_5 should be received by queue 0.
+delete rule_6, send packet_6 again, packet_6 should be received by queue 0.
+
+6) removed all entry of fdir::
+
+ testpmd>flush_flow_director 0
+ testpmd>show port fdir 0
+
+example::
+
+ flow_director_filter 0 mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 tos 16 proto 255 ttl 255 vlan 0 flexbytes (0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88) fwd pf queue 1 fd_id 1
+
+ flow_director_filter 0 mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 tos 8 proto 255 ttl 255 vlan 0 flexbytes (0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88) fwd pf queue 2 fd_id 2
+
+ sendp([Ether(src="00:00:00:00:00:01", dst="00:00:00:00:01:00")/IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255)/Raw(load="\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88")], iface="ens260f0")
+
+ sendp([Ether(src="00:00:00:00:00:01", dst="00:00:00:00:01:00")/IP(src="192.168.1.1", dst="192.168.1.2", tos=8, proto=255, ttl=255)/Raw(load="\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88")], iface="ens260f0")
+
+Test Case 9: test with ipv6 tc, next-header, hop-limits
+=======================================================
+1) start testpmd and initialize flow director flex payload configuration::
+
+ ./testpmd -c fffff -n 4 -- -i --disable-rss --pkt-filter-mode=perfect --rxq=8 --txq=8 --nb-cores=8
+ testpmd> port stop 0
+ testpmd> flow_director_flex_payload 0 l2 (0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15)
+ testpmd> flow_director_flex_payload 0 l3 (0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15)
+ testpmd> flow_director_flex_payload 0 l4 (0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15)
+ testpmd> flow_director_flex_mask 0 flow all (0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff)
+ testpmd> port start 0
+ testpmd> set verbose 1
+ testpmd> set fwd rxonly
+ testpmd> start
+
+Note::
+ assume FLEXBYTES = "0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88"
+ assume payload = "\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88"
+
+2) setup the fdir input set of IPv6::
+
+ testpmd> set_fdir_input_set 0 ipv6-other none select
+ testpmd> set_fdir_input_set 0 ipv6-other src-ipv6 add
+ testpmd> set_fdir_input_set 0 ipv6-other dst-ipv6 add
+
+3) add ipv6-tc to fdir input set, set tc to 16 and 8::
+
+ testpmd> set_fdir_input_set 0 ipv6-other ipv6-tc add
+
+setup flow director filter rules,
+
+rule_1::
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 16 proto 255 ttl 64 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 1 fd_id 1
+
+rule_2::
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 8 proto 255 ttl 64 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 2 fd_id 2
+
+send packet to DUT,
+
+packet_1::
+ 'sendp([Ether(dst="%s")/IPv6(src="2000::1", dst="2000::2", tc=16, nh=255, hlim=64)/Raw(%s)], iface="%s")' \
+ %(dst_mac, payload, itf)
+
+packet_1 should be received by queue 1.
+
+packet_2::
+ 'sendp([Ether(dst="%s")/IPv6(src="2000::1", dst="2000::2", tc=8, nh=255, hlim=64)/Raw(%s)], iface="%s")' \
+ %(dst_mac, payload, itf)
+
+packet_2 should be received by queue 2.
+
+delete rule_1, send packet_1 again, packet_1 should be received by queue 0.
+delete rule_2, send packet_2 again, packet_2 should be received by queue 0.
+
+4) add ipv6-next-header to fdir input set, set nh to 253 and 254::
+
+ testpmd> set_fdir_input_set 0 ipv6-other ipv6-next-header add
+
+setup flow director filter rules,
+rule_3::
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 16 proto 253 ttl 255 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 3 fd_id 3
+
+rule_4::
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 8 proto 254 ttl 255 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 4 fd_id 4
+
+send packet to DUT,
+
+packet_3::
+ 'sendp([Ether(dst="%s")/IPv6(src="2000::1", dst="2000::2", tc=16, nh=253, hlim=64)/Raw(%s)], iface="%s")'\
+ %(dst_mac, payload, itf)
+
+packet_3 should be received by queue 3.
+
+packet_4::
+ 'sendp([Ether(dst="%s")/IPv6(src="2000::1", dst="2000::2", tc=8, nh=254, hlim=64)/Raw(%s)], iface="%s")'\
+ %(dst_mac, payload, itf)
+
+packet_4 should be received by queue 4.
+
+delete rule_3, send packet_3 again, packet_3 should be received by queue 0.
+delete rule_4, send packet_4 again, packet_4 should be received by queue 0.
+
+5) add ipv6-hop-limits to fdir input set, set hlim to 32 and 64::
+
+ testpmd> set_fdir_input_set 0 ipv6-other ipv6-hop-limits add
+
+setup flow director filter rules,
+rule_5::
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 16 proto 253 ttl 32 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 5 fd_id 5
+
+rule_6::
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 8 proto 254 ttl 64 vlan 0 \
+ flexbytes (FLEXBYTES) fwd pf queue 6 fd_id 6
+
+send packet to DUT,
+
+packet_5::
+ 'sendp([Ether(dst="%s")/IPv6(src="2000::1", dst="2000::2", tc=16, nh=253, hlim=32)/Raw(%s)], iface="%s")'\
+ %(dst_mac, payload, itf)
+
+packet_5 should be received by queue 5.
+
+packet_6::
+ 'sendp([Ether(dst="%s")/IPv6(src="2000::1", dst="2000::2", tc=8, nh=254, hlim=64)/Raw(%s)], iface="%s")'\
+ %(dst_mac, payload, itf)
+
+packet_6 should be received by queue 6.
+
+delete rule_5, send packet_5 again, packet_5 should be received by queue 0.
+delete rule_6, send packet_6 again, packet_6 should be received by queue 0.
+
+6) removed all entry of fdir::
+
+ testpmd>flush_flow_director 0
+ testpmd>show port fdir 0
+
+example::
+
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 16 proto 255 ttl 64 vlan 0 flexbytes (0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88) fwd pf queue 1 fd_id 1
+
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 8 proto 255 ttl 64 vlan 0 flexbytes (0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88) fwd pf queue 2 fd_id 2
+
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 16 proto 253 ttl 64 vlan 0 flexbytes (0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88) fwd pf queue 3 fd_id 3
+
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 8 proto 254 ttl 64 vlan 0 flexbytes (0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88) fwd pf queue 4 fd_id 4
+
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 16 proto 253 ttl 32 vlan 0 flexbytes (0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88) fwd pf queue 5 fd_id 5
+
+ flow_director_filter 0 mode IP add flow ipv6-other src 2000::1 dst 2000::2 tos 8 proto 254 ttl 48 vlan 0 flexbytes (0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88) fwd pf queue 6 fd_id 6
+
+ sendp([Ether(src="00:00:00:00:00:01", dst="00:00:00:00:01:00")/IPv6(src="2000::1", dst="2000::2", tc=16, nh=255, hlim=64)/Raw(load="\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88")], iface="ens260f0")
+
+ sendp([Ether(src="00:00:00:00:00:01", dst="00:00:00:00:01:00")/IPv6(src="2000::1", dst="2000::2", tc=8, nh=255, hlim=64)/Raw(load="\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88")], iface="ens260f0")
+
+ sendp([Ether(src="00:00:00:00:00:01", dst="00:00:00:00:01:00")/IPv6(src="2000::1", dst="2000::2", tc=16, nh=253, hlim=64)/Raw(load="\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88")], iface="ens260f0")
+
+ sendp([Ether(src="00:00:00:00:00:01", dst="00:00:00:00:01:00")/IPv6(src="2000::1", dst="2000::2", tc=8, nh=254, hlim=64)/Raw(load="\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88")], iface="ens260f0")
+
+ sendp([Ether(src="00:00:00:00:00:01", dst="00:00:00:00:01:00")/IPv6(src="2000::1", dst="2000::2", tc=16, nh=253, hlim=32)/Raw(load="\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88")], iface="ens260f0")
+
+ sendp([Ether(src="00:00:00:00:00:01", dst="00:00:00:00:01:00")/IPv6(src="2000::1", dst="2000::2", tc=8, nh=254, hlim=48)/Raw(load="\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88")], iface="ens260f0")
+
+
+Test Case 10: test with ivlan (qinq not work)
+============================
+1) start testpmd and initialize flow director flex payload configuration::
+
+ ./testpmd -c fffff -n 4 -- -i --disable-rss --pkt-filter-mode=perfect --rxq=8 --txq=8 --nb-cores=8
+ testpmd> port stop 0
+ testpmd> flow_director_flex_payload 0 l2 (0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15)
+ testpmd> flow_director_flex_payload 0 l3 (0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15)
+ testpmd> flow_director_flex_payload 0 l4 (0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15)
+ testpmd> flow_director_flex_mask 0 flow all (0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff)
+ testpmd> port start 0
+
+ testpmd> vlan set qinq on 0
+
+ testpmd> set verbose 1
+ testpmd> set fwd rxonly
+ testpmd> start
+
+Note::
+ assume FLEXBYTES = "0x11,0x11,0x22,0x22,0x33,0x33,0x44,0x44,0x55,0x55,0x66,0x66,0x77,0x77,0x88,0x88"
+ assume payload = "\x11\x11\x22\x22\x33\x33\x44\x44\x55\x55\x66\x66\x77\x77\x88\x88"
+
+2) setup the fdir input set::
+
+ testpmd> set_fdir_input_set 0 ipv4-udp none select
+ testpmd> set_fdir_input_set 0 ipv4-udp ivlan add
+
+
+3) setup flow director filter rules,
+
+rule_1::
+ flow_director_filter 0 mode IP add flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 tos 16 ttl 255 \
+ vlan 1 flexbytes (FLEXBYTES) fwd pf queue 1 fd_id 1
+
+rule_2::
+ flow_director_filter 0 mode IP add flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 tos 16 ttl 255 \
+ vlan 15 flexbytes (FLEXBYTES) fwd pf queue 2 fd_id 2
+
+rule_3::
+ flow_director_filter 0 mode IP add flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 tos 16 ttl 255 \
+ vlan 255 flexbytes (FLEXBYTES) fwd pf queue 3 fd_id 3
+
+rule_4::
+ flow_director_filter 0 mode IP add flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 tos 16 ttl 255 \
+ vlan 4095 flexbytes (FLEXBYTES) fwd pf queue 4 fd_id 4
+
+4) send packet to DUT,
+
+packet_1::
+
+ 'sendp([Ether(dst="%s")/Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=1)/IP(src="192.168.0.1",dst="192.168.0.2", \
+ tos=16, ttl=255)/UDP(sport="1021",dport="1022")/Raw(%s)], iface="%s")' % (dst_mac, payload, itf)
+
+packet_1 should be received by queue 1.
+
+packet_2::
+ 'sendp([Ether(dst="%s")/Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=15)/IP(src="192.168.0.1",dst="192.168.0.2", \
+ tos=16, ttl=255)/UDP(sport="1021",dport="1022")/Raw(%s)], iface="%s")' % (dst_mac, payload, itf)
+
+packet_2 should be received by queue 2.
+
+packet_3::
+ 'sendp([Ether(dst="%s")/Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=255)/IP(src="192.168.0.1",dst="192.168.0.2", \
+ tos=16, ttl=255)/UDP(sport="1021",dport="1022")/Raw(%s)], iface="%s")' % (dst_mac, payload, itf)
+
+packet_3 should be received by queue 3.
+
+packet_4::
+ 'sendp([Ether(dst="%s")/Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=4095)/IP(src="192.168.0.1",dst="192.168.0.2", \
+ tos=16, ttl=255)/UDP(sport="1021",dport="1022")/Raw(%s)], iface="%s")' % (dst_mac, payload, itf)
+
+packet_4 should be received by queue 4.
+
+delete rule_1, send packet_1 again, packet_1 should be received by queue 0.
+delete rule_2, send packet_2 again, packet_2 should be received by queue 0.
+delete rule_3, send packet_3 again, packet_3 should be received by queue 0.
+delete rule_4, send packet_4 again, packet_4 should be received by queue 0.
+
+5) removed all entry of fdir::
+
+ testpmd>flush_flow_director 0
+ testpmd>show port fdir 0
+
--
1.9.3
^ permalink raw reply [flat|nested] 2+ messages in thread
* [dts] [PATCH V3 2/2] add fdir test code for new case
2017-03-09 7:22 [dts] [PATCH V3 1/2] add fdir test case in plan xu,huilong
@ 2017-03-09 7:22 ` xu,huilong
0 siblings, 0 replies; 2+ messages in thread
From: xu,huilong @ 2017-03-09 7:22 UTC (permalink / raw)
To: dts; +Cc: xu,huilong
update list:
1. update send_and_verify function for support check designated queue
2. add fdir_tos_proto_ttl, fdir_ipv6_tc, fdir_ivlan test case
Signed-off-by: xu,huilong <huilongx.xu@intel.com>
---
tests/TestSuite_fdir.py | 349 +++++++++++++++++++++++++++++++++++++++++++++++-
1 file changed, 348 insertions(+), 1 deletion(-)
diff --git a/tests/TestSuite_fdir.py b/tests/TestSuite_fdir.py
index aa0ec52..f49ec24 100644
--- a/tests/TestSuite_fdir.py
+++ b/tests/TestSuite_fdir.py
@@ -64,7 +64,7 @@ class TestFdir(TestCase, IxiaPacketGenerator):
#
###########################################################################
- def send_and_verify(self, condition, packet):
+ def send_and_verify(self, condition, packet, queueid = -2):
"""
Send packages and verify behavior.
"""
@@ -89,6 +89,8 @@ class TestFdir(TestCase, IxiaPacketGenerator):
self.queue = 0
else:
self.queue = -1
+ else:
+ self.queue = queueid
result_scanner = r"port ([0-9]+)/queue ([0-9]+): received ([0-9]+) packets\s*src=[A-F\d]{2}:[A-F\d]{2}:[A-F\d]{2}:[A-F\d]{2}:[A-F\d]{2}:[A-F\d]{2} - dst=[A-F\d]{2}:[A-F\d]{2}:[A-F\d]{2}:[A-F\d]{2}:[A-F\d]{2}:[A-F\d]{2}"
scanner = re.compile(result_scanner, re.DOTALL)
@@ -764,6 +766,351 @@ class TestFdir(TestCase, IxiaPacketGenerator):
self.dut.send_expect("quit", "# ", 30)
+ def test_ipv4_tos_proto_ttl(self):
+ """
+ Expand Flow Director for fortville to support ipv4 TOS, ipv4 PROTO, ipv4 TTL
+ """
+ if not self.nic in ["fortville_eagle", "fortville_spirit", "fortville_spirit_single"]:
+ self.verify(False, "This case only support fortville nic")
+ self.dut.kill_all()
+ self.dut.send_expect("./%s/app/testpmd -c %s -n 4 -- -i --portmask=%s --disable-rss --rxq=4 --txq=4 --nb-cores=4 --nb-ports=1 --pkt-filter-mode=perfect" % (self.target, self.coreMask, utils.create_mask([self.dut_ports[0]])), "testpmd>", 120)
+ self.dut.send_expect("set verbose 1", "testpmd>")
+ self.dut.send_expect("set fwd rxonly", "testpmd>")
+
+ self.fdir_set_rule()
+ self.fdir_get_flexbytes()
+ # fwd comand testing
+ self.fdir_type = " "
+ self.dut.send_expect("set_fdir_input_set %d ipv4-other none select" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("set_fdir_input_set %d ipv4-other src-ipv4 add" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("set_fdir_input_set %d ipv4-other dst-ipv4 add" % self.dut_ports[0], "testpmd>")
+
+ # test add and remove tso rule
+ self.dut.send_expect("set_fdir_input_set %d ipv4-other ipv4-tos add" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 16 proto 255 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 8 proto 255 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 1)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=8, proto=255, ttl=255) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 2)
+
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 16 proto 255 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 8 proto 255 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=8, proto=255, ttl=255) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+
+ # test add and remove proto reul
+ self.dut.send_expect("set_fdir_input_set %d ipv4-other ipv4-proto add" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 16 proto 253 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 16 proto 254 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=253, ttl=255) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 1)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=254, ttl=255) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 2)
+
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 16 proto 253 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 16 proto 254 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=253, ttl=255) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=254, ttl=255) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+
+ # test add and remove ttl rule
+ self.dut.send_expect("set_fdir_input_set %d ipv4-other ipv4-ttl add" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 16 proto 255 ttl 32 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 16 proto 255 ttl 64 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=32) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 1)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=64) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 2)
+
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 16 proto 255 ttl 32 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv4-other src 192.168.1.1 dst 192.168.1.2 \
+ tos 16 proto 255 ttl 64 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=32) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=64) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+
+ def test_fdir_ipv6_tc(self):
+ """
+ Expand Flow Director for fortville to support ipv6 TC, next-header, hop-limits
+ """
+ if not self.nic in ["fortville_eagle", "fortville_spirit", "fortville_spirit_single"]:
+ self.verify(False, "This case only support fortville nic")
+ self.dut.kill_all()
+ self.dut.send_expect("./%s/app/testpmd -c %s -n 4 -- -i --portmask=%s --disable-rss --rxq=4 --txq=4 --nb-cores=4 --nb-ports=1 --pkt-filter-mode=perfect" % (self.target, self.coreMask, utils.create_mask([self.dut_ports[0]])), "testpmd>", 120)
+ self.dut.send_expect("set verbose 1", "testpmd>")
+ self.dut.send_expect("set fwd rxonly", "testpmd>")
+
+ self.fdir_set_rule()
+ self.fdir_get_flexbytes()
+ # fwd comand testing
+ self.fdir_type = " "
+ self.dut.send_expect("set_fdir_input_set %d ipv6-other none select" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("set_fdir_input_set %d ipv6-other src-ipv6 add" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("set_fdir_input_set %d ipv6-other dst-ipv6 add" % self.dut_ports[0], "testpmd>")
+
+ # test add and remove ipv6 tc reul
+ self.dut.send_expect("set_fdir_input_set %d ipv6-other ipv6-tc add" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 16 proto 255 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 8 proto 255 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=16, nh=255, hlim=64) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 1)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=8, nh=255, hlim=64) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 2)
+
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 16 proto 255 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 8 proto 255 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=16, nh=255, hlim=64) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=8, nh=255, hlim=255) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+
+ # test add and remove pv6-next-header reul
+ self.dut.send_expect("set_fdir_input_set %d ipv6-other ipv6-next-header add" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 16 proto 253 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 16 proto 254 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=16, nh=253, hlim=64) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 1)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=16, nh=254, hlim=64) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 2)
+
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 16 proto 253 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 16 proto 254 ttl 255 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=16, nh=253, hlim=64) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=16, nh=254, hlim=255) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+
+ # test add and remove ipv6-hop-limits rule
+ self.dut.send_expect("set_fdir_input_set %d ipv6-other ipv6-hop-limits add" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 16 proto 255 ttl 32 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 16 proto 255 ttl 64 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=16, nh=255, hlim=32) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 1)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=16, nh=255, hlim=64) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 2)
+
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 16 proto 255 ttl 32 vlan 0 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv6-other src 2000::1 dst 2000::2 \
+ tos 16 proto 255 ttl 64 vlan 0 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=16, nh=255, hlim=32) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /IPv6(src="2000::1", dst="2000::2", tc=16, nh=255, hlim=64) \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+
+ def test_fdir_ivlan(self):
+ """
+ Expand Flow Director for fortville to support ipv4 TOS, ipv4 PROTO, ipv4 TTL
+ """
+ if not self.nic in ["fortville_eagle", "fortville_spirit", "fortville_spirit_single"]:
+ self.verify(False, "This case only support fortville nic")
+ self.dut.kill_all()
+ self.dut.send_expect("./%s/app/testpmd -c %s -n 4 -- -i --portmask=%s --disable-rss --rxq=4 --txq=4 --nb-cores=4 --nb-ports=1 --pkt-filter-mode=perfect" % (self.target, self.coreMask, utils.create_mask([self.dut_ports[0]])), "testpmd>", 120)
+ self.dut.send_expect("set verbose 1", "testpmd>")
+ self.dut.send_expect("set fwd rxonly", "testpmd>")
+
+ self.fdir_set_rule()
+ self.fdir_get_flexbytes()
+ # fwd comand testing
+ self.fdir_type = " "
+ self.dut.send_expect("set_fdir_input_set %d ipv4-other none select" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("set_fdir_input_set %d ipv4-other src-ipv4 add" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("set_fdir_input_set %d ipv4-other dst-ipv4 add" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("vlan set qinq on %d" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("set_fdir_input_set %d ipv4-udp none select" % self.dut_ports[0], "testpmd>")
+ self.dut.send_expect("set_fdir_input_set %d ipv4-udp ivlan add" % self.dut_ports[0], "testpmd>")
+
+
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 \
+ tos 16 proto 255 ttl 32 vlan 1 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 \
+ tos 16 proto 255 ttl 32 vlan 15 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 \
+ tos 16 proto 255 ttl 32 vlan 255 flexbytes (%s) fwd pf queue 3 fd_id 3"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP add flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 \
+ tos 16 proto 255 ttl 32 vlan 4095 flexbytes (%s) fwd pf queue 4 fd_id 4"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=1) \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255) \
+ /UDP(sport="1021",dport="1022") \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 1)
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=15) \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255) \
+ /UDP(sport="1021",dport="1022") \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 2)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=255) \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255) \
+ /UDP(sport="1021",dport="1022") \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 3)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=4095) \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255) \
+ /UDP(sport="1021",dport="1022") \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 4)
+
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 \
+ tos 16 proto 255 ttl 32 vlan 1 flexbytes (%s) fwd pf queue 1 fd_id 1"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 \
+ tos 16 proto 255 ttl 32 vlan 15 flexbytes (%s) fwd pf queue 2 fd_id 2"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 \
+ tos 16 proto 255 ttl 32 vlan 255 flexbytes (%s) fwd pf queue 3 fd_id 3"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+ self.dut.send_expect("flow_director_filter %d mode IP del flow ipv4-udp src 192.168.1.1 1021 dst 192.168.1.2 1022 \
+ tos 16 proto 255 ttl 32 vlan 4095 flexbytes (%s) fwd pf queue 4 fd_id 4"
+ % (self.dut_ports[0], self.flexbytes), "testpmd>")
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=1) \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255) \
+ /UDP(sport="1021",dport="1022") \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=15) \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255) \
+ /UDP(sport="1021",dport="1022") \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=255) \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255) \
+ /UDP(sport="1021",dport="1022") \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+ self.send_and_verify(True, 'sendp([Ether(src=get_if_hwaddr("%s"), dst="00:1B:21:8E:B2:30") \
+ /Dot1Q(id=0x8100,vlan=16)/Dot1Q(id=0x8100,vlan=4095) \
+ /IP(src="192.168.1.1", dst="192.168.1.2", tos=16, proto=255, ttl=255) \
+ /UDP(sport="1021",dport="1022") \
+ /Raw(load="%s")], iface="%s")' \
+ % (self.dut_rx_interface, self.payload, self.dut_rx_interface), queueid = 0)
+
+
+
def failed_test_fdir_flush(self):
"""
FDir flush in Fortville.
--
1.9.3
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2017-03-09 7:21 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-03-09 7:22 [dts] [PATCH V3 1/2] add fdir test case in plan xu,huilong
2017-03-09 7:22 ` [dts] [PATCH V3 2/2] add fdir test code for new case xu,huilong
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).