test suite reviews and discussions
 help / color / mirror / Atom feed
From: "Tu, Lijuan" <lijuan.tu@intel.com>
To: "Chen, Zhaoyan" <zhaoyan.chen@intel.com>, "dts@dpdk.org" <dts@dpdk.org>
Cc: "Chen, Zhaoyan" <zhaoyan.chen@intel.com>
Subject: Re: [dts] [PATCH V1] Add flexible RXd test plan
Date: Wed, 4 Dec 2019 05:55:36 +0000	[thread overview]
Message-ID: <8CE3E05A3F976642AAB0F4675D0AD20E0BB7D34D@SHSMSX101.ccr.corp.intel.com> (raw)
In-Reply-To: <20191129024519.111046-1-zhaoyan.chen@intel.com>

Some minus warning, could you please fix them, thanks

.git/rebase-apply/patch:52: trailing whitespace.
The test suite will cover the flexible RX descriptor on Intel E810
.git/rebase-apply/patch:80: trailing whitespace.

.git/rebase-apply/patch:81: trailing whitespace.

.git/rebase-apply/patch:83: trailing whitespace.

.git/rebase-apply/patch:84: trailing whitespace.

warning: squelched 5 whitespace errors
warning: 10 lines add whitespace errors.

> -----Original Message-----
> From: dts [mailto:dts-bounces@dpdk.org] On Behalf Of Chen, Zhaoyan
> Sent: Friday, November 29, 2019 10:45 AM
> To: dts@dpdk.org
> Cc: Chen, Zhaoyan <zhaoyan.chen@intel.com>
> Subject: [dts] [PATCH V1] Add flexible RXd test plan
> 
> Add flexible RXd test plan
> 
> ---
>  test_plans/flexible_rxd_test_plan.rst | 343
> ++++++++++++++++++++++++++++++++++
>  1 file changed, 343 insertions(+)
>  create mode 100644 test_plans/flexible_rxd_test_plan.rst
> 
> diff --git a/test_plans/flexible_rxd_test_plan.rst
> b/test_plans/flexible_rxd_test_plan.rst
> new file mode 100644
> index 0000000..87f27d5
> --- /dev/null
> +++ b/test_plans/flexible_rxd_test_plan.rst
> @@ -0,0 +1,343 @@
> +.. 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 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.
> +
> +=======================================
> +Cryptodev Performance Application Tests
> +=======================================
> +
> +
> +Description
> +===========
> +
> +The test suite will cover the flexible RX descriptor on Intel E810
> +network interface card.
> +
> +
> +Prerequisites
> +=============
> +
> +Copy correct ``ice.pkg`` into ``/usr/lib/firmware/intel/ice/ddp/``, \
> +For the test cases, comms package is expected.
> +
> +Prepare test toplogoy, in the test case, it requires
> +
> +- 1 Intel E810 interface
> +- 1 network interface for sending test packet,
> +  which could be connect to the E810 interface
> +- Directly connect the 2 interfaces
> +
> +Patch testpmd for dumping flexible fields from RXD::
> +
> +  diff --git a/app/test-pmd/util.c b/app/test-pmd/util.c  index
> + a1164b7..b90344d 100644
> +  --- a/app/test-pmd/util.c
> +  +++ b/app/test-pmd/util.c
> +  @@ -10,6 +10,7 @@
> +  #include <rte_ether.h>
> +  #include <rte_ethdev.h>
> +  #include <rte_flow.h>
> +  +#include <rte_pmd_ice.h>
> +
> +
> +  #include "testpmd.h"
> +
> +
> +  @@ -73,6 +74,9 @@ dump_pkt_burst(uint16_t port_id, uint16_t queue,
> struct rte_mbuf *pkts[],
> +                                  printf("hash=0x%x ID=0x%x ",
> +                                         mb->hash.fdir.hash, mb->hash.fdir.id);
> +                  }
> +  +               rte_net_ice_dump_proto_xtr_metadata(mb);
> +                  if (ol_flags & PKT_RX_TIMESTAMP)
> +                          printf(" - timestamp %"PRIu64" ", mb->timestamp);
> +                  if (ol_flags & PKT_RX_QINQ)
> +
> +
> +Compile DPDK and testpmd::
> +
> +  make install -j T=x86_64-native-linuxapp-gcc
> +
> +Bind Intel E810 interface to igb_uio driver, (e.g. 0000:18:00.0) ::
> +
> +  ./usertools/dpdk-devbind.py -b igb_uio 18:00.0
> +
> +
> +
> +Test Case 01: Check single VLAN fields in RXD (802.1Q)
> +======================================================
> +
> +Launch testpmd by::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr=vlan -- -i --rxq=32 --txq=32 --portmask=0x1
> + --nb-cores=2
> +
> +  testpmd>set verbose 1
> +  testpmd>set fwd io
> +  testpmd>start
> +
> +Please change the core setting (-l option) and port's PCI (-w option) \
> +by your DUT environment
> +
> +Send a packet with VLAN tag from test network interface::
> +
> +  scapy #launch scapy in shell
> +
> +  #In scapy interactive UI
> +  p = Ether(src="3c:fd:fe:c0:e1:8c", dst="00:00:00:00:01:02",
> + type=0x8100)/Dot1Q(prio=1,vlan=23)/IP()/UDP()/DNS()
> +  sendp(p, iface='enp175s0f0', count=1)
> +
> +Please notice
> +
> +- Change ethernet source address with your test network interface's
> +address
> +- Make sure the ethernet destination addres is NOT your real E810
> +interface's address
> +
> +Check the output in testpmd, **ctag=1:0:23** is expected, which is
> consistent with VLAN tag set in test packet::
> +
> +  testpmd> port 0/queue 28: received 1 packets  src=3C:FD:FE:C0:E1:8C -
> + dst=00:00:00:00:01:02 - type=0x8100 - length=60 - nb_segs=1 - RSS
> + hash=0xf31f649c - RSS queue=0x1c - Protocol
> + Extraction:[0x0000:0x2017],vlan,stag=0:0:0,ctag=1:0:23  - hw ptype:
> + L2_ETHER L3_IPV4_EXT_UNKNOWN L4_UDP  - sw ptype: L2_ETHER_VLAN
> L3_IPV4
> + L4_UDP  - l2_len=18 - l3_len=20 - l4_len=8 - Receive queue=0x1c
> +  ol_flags: PKT_RX_RSS_HASH PKT_RX_L4_CKSUM_GOOD
> PKT_RX_IP_CKSUM_GOOD
> + PKT_RX_OUTER_L4_CKSUM_UNKNOWN
> +
> +
> +Test Case 02: Check single VLAN fields in RXD (802.1ad)
> +=======================================================
> +
> +Test steps are same to ``Test Case 01``, just change the launch command
> +of testpmd, test packet and expected output
> +
> +Launch testpmd command::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr=vlan -- -i --rxq=32 --txq=32 --portmask=0x1
> + --nb-cores=2
> +
> +Test packet::
> +
> +  p = Ether(src='3c:fd:fe:bc:f6:78', dst='68:05:ca:a3:13:4c',
> + type=0x88A8)/Dot1Q(prio=1,vlan=23)/IP()/UDP()/DNS()
> +
> +Expected output in testpmd::
> +
> +  stag=1:0:23
> +
> +
> +Test Case 03: Check double VLAN fields in RXD (802.1Q) only 1 VLAN tag
> +===============================================================
> =======
> +
> +Test steps are same to ``Test Case 01``, just change the launch command
> +of testpmd, test packet and expected output
> +
> +Launch testpmd command::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr=vlan -- -i --rxq=32 --txq=32 --portmask=0x1
> + --nb-cores=2
> +
> +Test packet::
> +
> +  p = Ether(src='3c:fd:fe:bc:f6:78', dst='68:05:ca:a3:13:4c',
> + type=0x9100)/Dot1Q(prio=1,vlan=23)/IP()/UDP()/DNS()
> +
> +Expected output in testpmd::
> +
> +  stag=1:0:23
> +
> +
> +Test Case 04: Check double VLAN fields in RXD (802.1Q) 2 VLAN tags
> +===============================================================
> ===
> +
> +Test steps are same to ``Test Case 01``, just change the launch command
> +of testpmd, test packet and expected output
> +
> +Launch testpmd command::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr=vlan -- -i --rxq=32 --txq=32 --portmask=0x1
> + --nb-cores=2
> +
> +Test packet::
> +
> +  p = Ether(src='3c:fd:fe:bc:f6:78', dst='68:05:ca:a3:13:4c',
> +
> type=0x9100)/Dot1Q(prio=1,vlan=23)/Dot1Q(prio=4,vlan=56)/IP()/UDP()/DN
> + S()
> +
> +Expected output in testpmd::
> +
> +  stag=1:0:23
> +  ctag=4:0:56
> +
> +
> +Test Case 05: Check double VLAN fields in RXD (802.1ad)
> +=======================================================
> +
> +Test steps are same to ``Test Case 01``, just change the launch command
> +of testpmd, test packet and expected output
> +
> +Launch testpmd command::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr=vlan -- -i --rxq=32 --txq=32 --portmask=0x1
> + --nb-cores=2
> +
> +Test packet::
> +
> +  p = Ether(src='3c:fd:fe:bc:f6:78', dst='68:05:ca:a3:13:4c',
> +
> type=0x88A8)/Dot1Q(prio=1,vlan=23)/Dot1Q(prio=4,vlan=56)/IP()/UDP()/DN
> + S()
> +
> +Expected output in testpmd::
> +
> +  stag=1:0:23
> +  ctag=4:0:56
> +
> +
> +Test Case 06: Check IPv4 fields in RXD
> +======================================
> +
> +Test steps are same to ``Test Case 01``, just change the launch command
> +of testpmd, test packet and expected output
> +
> +Launch testpmd command::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr=ipv4 -- -i --rxq=32 --txq=32 --portmask=0x1
> + --nb-cores=2
> +
> +Test packet::
> +
> +  p = Ether(src='3c:fd:fe:bc:f6:78',
> + dst='68:05:ca:a3:13:4c')/IP(tos=23,ttl=98)/UDP()/Raw(load='XXXXXXXXXX'
> + )
> +
> +Expected output in testpmd::
> +
> +  ver=4
> +  hdrlen=5
> +  tos=23
> +  ttl=98
> +  proto=17
> +
> +
> +Test Case 07: Check IPv6 fields in RXD
> +=======================================================
> +
> +Test steps are same to ``Test Case 01``, just change the launch command
> +of testpmd, test packet and expected output
> +
> +Launch testpmd command::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr=ipv6 -- -i --rxq=32 --txq=32 --portmask=0x1
> + --nb-cores=2
> +
> +Test packet::
> +
> +  p = Ether(src='3c:fd:fe:bc:f6:78',
> + dst='68:05:ca:a3:13:4c')/IPv6(tc=12,hlim=34,fl=0x98765)/UDP()/Raw(load
> + ='XXXXXXXXXX')
> +
> +Expected output in testpmd::
> +
> +  ver=6
> +  tc=12
> +  flow_hi4=0x9
> +  nexthdr=17
> +  hoplimit=34
> +
> +
> +Test Case 08: Check IPv6 flow field in RXD
> +=======================================================
> +
> +Test steps are same to ``Test Case 01``, just change the launch command
> +of testpmd, test packet and expected output
> +
> +Launch testpmd command::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr=ipv6_flow -- -i --rxq=32 --txq=32 --portmask=0x1
> + --nb-cores=2
> +
> +Test packet::
> +
> +  p = Ether(src='3c:fd:fe:bc:f6:78',
> + dst='68:05:ca:a3:13:4c')/IPv6(tc=12,hlim=34,fl=0x98765)/UDP()/Raw(load
> + ='XXXXXXXXXX')
> +
> +Expected output in testpmd::
> +
> +  ver=6
> +  tc=12
> +  flow=0x98765
> +
> +
> +Test Case 09: Check TCP fields in IPv4 in RXD
> +=======================================================
> +
> +Test steps are same to ``Test Case 01``, just change the launch command
> +of testpmd, test packet and expected output
> +
> +Launch testpmd command::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr=tcp -- -i --rxq=32 --txq=32 --portmask=0x1
> + --nb-cores=2
> +
> +Test packet::
> +
> +  p = Ether(src='3c:fd:fe:bc:f6:78',
> + dst='68:05:ca:a3:13:4c')/IP()/TCP(flags='AS')/Raw(load='XXXXXXXXXX')
> +
> +Expected output in testpmd::
> +
> +  doff=5
> +  flags=AS
> +
> +
> +Test Case 10: Check TCP fields in IPv6 in RXD
> +=======================================================
> +
> +Test steps are same to ``Test Case 01``, just change the launch command
> +of testpmd, test packet and expected output
> +
> +Launch testpmd command::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr=tcp -- -i --rxq=32 --txq=32 --portmask=0x1
> + --nb-cores=2
> +
> +Test packet::
> +
> +  p = Ether(src='3c:fd:fe:bc:f6:78',
> + dst='68:05:ca:a3:13:4c')/IPv6()/TCP(flags='S')/Raw(load='XXXXXXXXXX')
> +
> +Expected output in testpmd::
> +
> +  doff=5
> +  flags=S
> +
> +
> +Test Case 11: Check IPv4, IPv6, TCP fields in RXD on specific queues
> +===============================================================
> =====
> +
> +Test steps are same to ``Test Case 01``, just change the launch command
> +of testpmd, test packet and expected output
> +
> +Launch testpmd command::
> +
> +  ./x86_64-native-linux-gcc/app/testpmd -l 6-9 -n 4 -w
> + 18:00.0,proto_xtr='[(2):ipv4,(3):ipv6,(4):tcp]' -- -i --rxq=64
> + --txq=64 --portmask=0x1
> +
> +Create generic flow on NIC::
> +
> +  flow create 0 ingress pattern eth dst is 68:05:ca:a3:13:4c / ipv4 src
> + is 192.168.0.1 dst is 192.168.0.2 tos is 23 ttl is 98 / end actions
> + queue index 2 / end  flow create 0 ingress pattern eth / ipv6 src is
> + 2001::3 dst is 2001::4 tc is 8 / end actions queue index 3 / end  flow
> + create 0 ingress pattern eth dst is 68:05:ca:8d:ed:a9 / ipv4 src is
> + 192.168.0.1 dst is 192.168.0.2 / tcp src is 25 dst is 23 / end actions
> + queue index 63 / end
> +
> +Test packet::
> +
> +  p =
> + Ether(dst="68:05:ca:a3:13:4c")/IP(src="192.168.0.1",dst="192.168.0.2",
> + tos=23,ttl=98)/UDP()/Raw(load='XXXXXXXXXX')
> +  p = Ether(src='3c:fd:fe:bc:f6:78',
> + dst='68:05:ca:a3:13:4c')/IPv6(src='2001::3', dst='2001::4',
> + tc=8,hlim=34,fl=0x98765)/UDP()/Raw(load='XXXXXXXXXX')
> +  p = Ether(dst='68:05:ca:8d:ed:a9')/IP(src='192.168.0.1',
> + dst='192.168.0.2')/TCP(flags='AS', dport=23,
> + sport=25)/Raw(load='XXXXXXXXXX')
> +
> +Expected output in testpmd::
> +
> +  Receive queue=0x2
> +  ver=4
> +  hdrlen=5
> +  tos=23
> +  ttl=98
> +  proto=17
> +
> +  Receive queue=0x3
> +  ver=6
> +  tc=12
> +  flow_hi4=0x9
> +  nexthdr=17
> +  hoplimit=34
> +
> +  Receive queue=0x3f
> +  doff=5
> +  flags=AS
> \ No newline at end of file
> --
> 2.13.0.windows.1


      reply	other threads:[~2019-12-04  5:55 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-11-29  2:45 Chen, Zhaoyan
2019-12-04  5:55 ` Tu, Lijuan [this message]

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=8CE3E05A3F976642AAB0F4675D0AD20E0BB7D34D@SHSMSX101.ccr.corp.intel.com \
    --to=lijuan.tu@intel.com \
    --cc=dts@dpdk.org \
    --cc=zhaoyan.chen@intel.com \
    /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).