44. ICE Switch Filter Tests

44.1. Description

This document provides the plan for testing switch filter feature of Intel® Ethernet 800 Series, including:

  • Enable switch filter for PPPOE in non-pipeline/pipeline mode (comm #1 package)

In pipeline mode, a flow can be set at one specific stage by setting parameter priority. Currently, we support two stages: priority = 0 or !0. Flows with priority 0 located at the first pipeline stage which typically be used as a firewall. At this stage, flow rules are created for the device’s exact match engine: switch. Flows with priority !0 located at the second stage, typically packets are classified here and be steered to specific queue or queue group. At this stage, flow rules are created for device’s flow director engine.

In non-pipeline mode, priority is ignored, a flow rule can be created as a flow director rule or a switch rule depends on its pattern/action. If a rule is supported by switch or fdir at the same time, it will be created in the fdir table first. Therefore, to test switch filter in non-pipeline mode, we need to fill the fdir table first, and then the rules are created in the switch filter table. The capacity of fdir table is 16K, of which 14K is shared by all pfs and vfs, and the remaining 2K is gurantee for pfs. If 4*25G NIC, the gurantee for each pf is 512. If 2*100G NIC, the gurantee of each pf is 1024. so 1 pf can create at most 14848 rules on 4 ports card and 15360 rules on 2 ports card.

44.1.1. Pattern and input set

Packet Types Pattern Input Set
non-pipeline mode pipeline mode
ethertype filter ethertype filter_PPPOES [Ether type] [Ether type]
ethertype filter_PPPOED [Ether type] [Ether type]
PPPOES MAC_VLAN_PPPOE_IPV4_PAY _session_id_proto_id [Dest MAC], [VLAN], [seid], [pppoe_proto_id] [Dest MAC], [VLAN], [seid], [pppoe_proto_id]
MAC_VLAN_PPPOE_IPV6_PAY _session_id_proto_id [Dest MAC], [VLAN], [seid], [pppoe_proto_id] [Dest MAC], [VLAN], [seid], [pppoe_proto_id]
MAC_PPPOE_IPV4_PAY_session_id _proto_id [Dest MAC], [seid], [pppoe_proto_id] [Dest MAC], [seid], [pppoe_proto_id]
MAC_PPPOE_IPV6_PAY_session_id _proto_id [Dest MAC], [seid], [pppoe_proto_id] [Dest MAC], [seid], [pppoe_proto_id]
MAC_PPPOE_IPV4_PAY_IP_address [Source IP], [Dest IP] [Source IP], [Dest IP]
MAC_PPPOE_IPV4_UDP_PAY [Source IP], [Dest IP], [Source Port], [Dest Port] [Source IP], [Dest IP], [Source Port], [Dest Port]
MAC_PPPOE_IPV4_UDP_PAY _non_src_dst_port [Source IP], [Dest IP] [Source IP], [Dest IP]
MAC_PPPOE_IPV4_TCP_PAY [Source IP], [Dest IP], [Source Port], [Dest Port] [Source IP], [Dest IP], [Source Port], [Dest Port]
MAC_PPPOE_IPV4_TCP_PAY _non_src_dst_port [Source IP], [Dest IP] [Source IP], [Dest IP]
MAC_PPPOE_IPV6_PAY_IP_address [Source IP], [Dest IP] [Source IP], [Dest IP]
MAC_PPPOE_IPV6_UDP_PAY [Source IP], [Dest IP], [Source Port], [Dest Port] [Source IP], [Dest IP], [Source Port], [Dest Port]
MAC_PPPOE_IPV6_UDP_PAY _non_src_dst_port [Source IP], [Dest IP] [Source IP], [Dest IP]
MAC_PPPOE_IPV6_TCP_PAY [Source IP], [Dest IP], [Source Port], [Dest Port] [Source IP], [Dest IP], [Source Port], [Dest Port]
MAC_PPPOE_IPV6_TCP_PAY _non_src_dst_port [Source IP], [Dest IP], [Source IP], [Dest IP],
MAC_VLAN_PPPOE_IPV4_PAY _IP_address [VLAN], [Source IP], [Dest IP] [VLAN], [Source IP], [Dest IP]
MAC_VLAN_PPPOE_IPV4_UDP_PAY [VLAN], [Source IP], [Dest IP] [Source Port], [Dest Port] [VLAN], [Source IP], [Dest IP] [Source Port], [Dest Port]
MAC_VLAN_PPPOE_IPV4_UDP_PAY _non_src_dst_port [VLAN], [Source IP], [Dest IP] [VLAN], [Source IP], [Dest IP]
MAC_VLAN_PPPOE_IPV4_TCP_PAY [VLAN], [Source IP], [Dest IP] [Source Port], [Dest Port] [VLAN], [Source IP], [Dest IP] [Source Port], [Dest Port]
MAC_VLAN_PPPOE_IPV4_TCP_PAY _non_src_dst_port [VLAN], [Source IP], [Dest IP] [VLAN], [Source IP], [Dest IP]
MAC_VLAN_PPPOE_IPV6_PAY _IP_address [VLAN], [Source IP], [Dest IP] [VLAN], [Source IP], [Dest IP]
MAC_VLAN_PPPOE_IPV6_UDP_PAY [VLAN], [Source IP], [Dest IP] [Source Port], [Dest Port] [VLAN], [Source IP], [Dest IP] [Source Port], [Dest Port]
MAC_VLAN_PPPOE_IPV6_UDP_PAY _non_src_dst_port [VLAN], [Source IP], [Dest IP] [VLAN], [Source IP], [Dest IP]
MAC_VLAN_PPPOE_IPV6_TCP_PAY [VLAN], [Source IP], [Dest IP] [Source Port], [Dest Port] [VLAN], [Source IP], [Dest IP] [Source Port], [Dest Port]
MAC_VLAN_PPPOE_IPV6_TCP_PAY _non_src_dst_port [VLAN], [Source IP], [Dest IP] [VLAN], [Source IP], [Dest IP]
MAC_PPPOE_LCP_PAY [Dest MAC], [seid], [pppoe_proto_id] [Dest MAC], [seid], [pppoe_proto_id]
MAC_PPPOE_IPCP_PAY [Dest MAC], [seid], [pppoe_proto_id] [Dest MAC], [seid], [pppoe_proto_id]
MAC_VLAN_PPPOE_LCP_PAY [Dest MAC], [VLAN], [seid], [pppoe_proto_id] [Dest MAC], [VLAN], [seid], [pppoe_proto_id]
MAC_VLAN_PPPOE_IPCP_PAY [Dest MAC], [VLAN], [seid], [pppoe_proto_id] [Dest MAC], [VLAN], [seid], [pppoe_proto_id]

Note

  1. The maximum input set length of a switch rule is 32 bytes, and src ipv6, dst ipv6 account for 32 bytes. Therefore, for ipv6 cases, if need to test fields other than src, dst ip, we create rule by removing src or dst ip in the test plan.
  2. For MAC_IPV4_TUN_IPV4_FRAG/MAC_IPV4_TUN_IPV4_PAY cases and MAC_IPV4_TUN_MAC_IPV4_FRAG/MAC_IPV4_TUN_MAC_IPV4_PAY cases, the input set of each pair is the same, so use MAC_IPV4_TUN_IPV4 and MAC_IPV4_TUN_MAC_IPV4 pattern to replace them in the test plan.

44.1.2. Supported function type

  • validate
  • create
  • destroy
  • flush
  • list

44.1.3. Supported action type

  • to queue
  • to queue group
  • drop

44.2. Prerequisites

  1. Hardware: Intel® Ethernet 800 Series: E810-XXVDA4/E810-CQ design the cases with 2 ports card.

  2. software:

  3. Copy comm #1 package to /lib/firmware/intel/ice/ddp/ice.pkg, then load driver:

    rmmod ice
    insmod ice.ko
    
  4. Compile DPDK:

    CC=gcc meson -Denable_kmods=True -Dlibdir=lib  --default-library=static x86_64-native-linuxapp-gcc
    ninja -C x86_64-native-linuxapp-gcc
    
  5. Bind pf to dpdk driver:

    ./usertools/dpdk-devbind.py -b vfio-pci 18:00.2
    
  6. Launch dpdk with the following arguments in non-pipeline mode:

    ./x86_64-native-linuxapp-gcc/app/dpdk-testpmd -c 0xf -n 4 -a 0000:18:00.0 --log-level="ice,7" -- -i --txq=16 --rxq=16
    testpmd> port config 0 rss-hash-key ipv4 1234abcd1234abcd1234abcd1234abcd1234abcd1234abcd1234abcd1234abcd1234abcd1234abcd1234abcd1234abcd1234abcd
    testpmd> set fwd rxonly
    testpmd> set verbose 1
    testpmd> start
    

    If set VXLAN flow rule:

    testpmd> rx_vxlan_port add 4789 0
    

    Note: file testpmd_fdir_rules contains 15,360 fdir rules to make fdir table full.

    Launch dpdk in pipeline mode with the following testpmd command line:

    ./x86_64-native-linuxapp-gcc/app/dpdk-testpmd -c 0xf -n 4 -a 0000:18:00.0,pipeline-mode-support=1 --log-level="ice,7" -- -i --txq=16 --rxq=16
    

44.3. Test case: Ethertype filter

44.3.1. Ethertype filter_PPPOES

create PPPOE rule to enable RSS for PPPOE packets:

testpmd> flow create 0 ingress pattern eth / pppoes / end actions rss types pppoe end key_len 0 queues end / end

matched packets:

sendp([Ether(dst="00:11:22:33:44:55", type=0x8864)/PPPoE(sessionid=3)/Raw("x" *80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55", type=0x8863)/PPPoED()/Raw("x" *80)],iface="ens786f0",count=1)

44.3.1.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth type is 0x8864 / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth type is 0x8864 / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth type is 0x8864 / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth type is 0x8864 / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.3.1.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth type is 0x8864 / end actions rss queues 4 5 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth type is 0x8864 / end actions rss queues 4 5 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 4 or 5. send mismatched packets, check the packets are not to queue 4 and 5.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 0
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 4 and 5.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth type is 0x8864 / end actions rss queues 4 5 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth type is 0x8864 / end actions rss queues 4 5 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.3.1.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth type is 0x8864 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth type is 0x8864 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth type is 0x8864 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth type is 0x8864 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.3.2. Ethertype filter_PPPOED

matched packets:

sendp([Ether(dst="00:11:22:33:44:55", type=0x8863)/Raw("x" *80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55")/PPPoED()/Raw("x" *80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55", type=0x8864)/Raw("x" *80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55")/PPPoE()/Raw("x" *80)],iface="ens786f0",count=1)

44.3.2.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth type is 0x8863 / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth type is 0x8863 / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    The rules in pipeline mode are similar to rules in non-pipeline mode, just need to add priority 0 to show it is created as a switch filter rule.

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth type is 0x8863 / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth type is 0x8863 / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.3.2.2. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth type is 0x8863 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth type is 0x8863 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth type is 0x8863 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth type is 0x8863 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.4. Test case: MAC_VLAN_PPPOE_IPV4_PAY_session_id_proto_id

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x"*80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:54",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=4)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6()/Raw("x" * 80)],iface="ens786f0",count=1)

44.4.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.4.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions rss queues 4 5 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions rss queues 4 5 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 4 or 5. send mismatched packets, check the packets are not to queue 4 and 5.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 4 and 5.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions rss queues 4 5 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions rss queues 4 5 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.4.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.5. Test case: MAC_VLAN_PPPOE_IPV6_PAY_session_id_proto_id

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6()/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:54",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=4)/PPP(proto=0x0057)/IPv6()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)

44.5.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.5.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions rss queues 4 5 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions rss queues 4 5 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 4 or 5. send mismatched packets, check the packets are not to queue 4 and 5.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 4 and 5.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions rss queues 4 5 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions rss queues 4 5 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.5.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.6. Test steps for supported pattern

  1. validate rules.

  2. create rules and list rules.

  3. send matched packets, check the action is correct::

    queue index: to correct queue rss queues: to correct queue group drop: not receive pkt

  4. send mismatched packets, check the action is not correct::

    queue index: not to correct queue rss queues: not to correct queue group drop: receive pkt

  5. destroy rule, list rules, check no rules.

  6. send matched packets, check the action is not right.

44.7. Test case: IPv4/IPv6 + TCP/UDP pipeline mode

44.7.1. MAC_PPPOE_IPV4_UDP + L4 MASK

matched packets:

sendp([Ether()/PPPoE(sessionid=3)/PPP(b\'\\x00\\x21\')/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=2304,dport=23)/Raw("x"*80)],iface="ens260f0",count=1)

mismatched packets:

sendp([Ether()/PPPoE(sessionid=3)/PPP(b\'\\x00\\x21\')/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=2244,dport=23)/Raw("x"*80)],iface="ens260f0",count=1)

44.7.1.1. queue index

flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 2500 src mask 0xf00 / end actions queue index 1 / end

44.7.2. MAC_PPPOE_IPV4_TCP + L4 MASK

matched packets:

sendp([Ether()/PPPoE(sessionid=3)/PPP(b\'\\x00\\x21\')/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=2304,dport=23)/Raw("x" * 80)],iface="ens260f0",count=1)

mismatched packets:

sendp([Ether()/PPPoE(sessionid=3)/PPP(b\'\\x00\\x21\')/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=2244,dport=23)/Raw("x" * 80)],iface="ens260f0",count=1)

44.7.2.1. queue index

flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 2500 src mask 0xf00 / end actions queue index 3 / end

44.7.3. MAC_PPPOE_IPV6_UDP + L4 MASK

matched packets:

sendp([Ether()/PPPoE(sessionid=3)/PPP(b\'\\x00\\x57\')/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=1282)/Raw("x"*80)],iface="ens260f0",count=1)

mismatched packets:

sendp([Ether()/PPPoE(sessionid=3)/PPP(b\'\\x00\\x57\')/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=1040)/Raw("x"*80)],iface="ens260f0",count=1)

44.7.3.1. rss queues

flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp dst is 1025 dst mask 0xf0 / end actions rss queues 4 5 end / end

44.7.4. MAC_PPPOE_IPV6_TCP + L4 MASK

matched packets:

sendp([Ether()/PPPoE(sessionid=3)/PPP(b\'\\x00\\x57\')/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=1282)/Raw("x"*80)],iface="ens260f0",count=1)

mismatched packets:

sendp([Ether()/PPPoE(sessionid=3)/PPP(b\'\\x00\\x57\')/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=1040)/Raw("x"*80)],iface="ens260f0",count=1)

44.7.4.1. drop

flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp dst is 1025 dst mask 0xf0 / end actions drop / end

44.8. Test case: VLAN non-pipeline mode

44.8.1. MAC_VLAN_PPPOE_IPV4_UDP + L4 MASK

matched packets:

sendp([Ether()/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(b\'\\x00\\x21\')/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=50,dport=1024)/Raw("x"*80)],iface="ens260f0",count=1)

mismatched packets:

sendp([Ether()/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(b\'\\x00\\x21\')/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=50,dport=1281)/Raw("x"*80)],iface="ens260f0",count=1)

44.8.1.1. queue index

flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp dst is 1280 dst mask 0x00ff / end actions queue index 1 / end

44.8.2. MAC_VLAN_PPPOE_IPV4_TCP + L4 MASK

matched packets:

sendp([Ether()/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(b\'\\x00\\x21\')/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=50,dport=1024)/Raw("x"*80)],iface="ens260f0",count=1)

mismatched packets:

sendp([Ether()/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(b\'\\x00\\x21\')/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=50,dport=1281)/Raw("x"*80)],iface="ens260f0",count=1)

44.8.2.1. rss queues

flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 dst is 192.168.1.2 / tcp dst is 1280 dst mask 0x00ff / end actions rss queues 4 5 end / end

44.9. Test case: VLAN pipeline mode

44.9.1. MAC_VLAN_PPPOE_IPV6_UDP + L4 MASK

matched packets:

sendp([Ether()/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(b\'\\x00\\x57\')/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=16,dport=23)/Raw("x"*80)],iface="ens260f0",count=1)

mismatched packets:

sendp([Ether()/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(b\'\\x00\\x57\')/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=17,dport=23)/Raw("x"*80)],iface="ens260f0",count=1)

44.9.1.1. drop

flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 32 src mask 0x0f / end actions drop / end

44.9.2. MAC_VLAN_PPPOE_IPV6_TCP + L4 MASK

matched packets:

sendp([Ether()/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(b\'\\x00\\x57\')/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(dport=16)/Raw("x"*80)],iface="ens260f0",count=1)

mismatched packets:

sendp([Ether()/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(b\'\\x00\\x57\')/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(dport=17)/Raw("x"*80)],iface="ens260f0",count=1)

44.9.2.1. queue index

flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp dst is 32 dst mask 0x0f / end actions queue index 7 / end

44.10. Test case: MAC_PPPOE_IPV4_PAY_session_id_proto_id

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:54",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=4)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6()/Raw("x" * 80)],iface="ens786f0",count=1)

44.10.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.10.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions rss queues 4 5 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions rss queues 4 5 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 4 or 5. send mismatched packets, check the packets are not to queue 4 and 5.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 4 and 5.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions rss queues 4 5 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions rss queues 4 5 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.10.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

     testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions drop / end
    
    get the message::
    
     Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0021 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.11. Test case: MAC_PPPOE_IPV6_PAY_session_id_proto_id

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6()/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:54",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=4)/PPP(proto=0x0057)/IPv6()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)

44.11.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packet are distributed to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.11.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions rss queues 4 5 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions rss queues 4 5 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packet to queue 4 or 5. send mismatched packets, check the packet not to queue 4 and 5.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 4 and 5.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions rss queues 4 5 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions rss queues 4 5 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.11.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packet is dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x0057 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12. Test case: PPPoE data

44.12.1. Subcase 1: MAC_PPPOE_IPV4_PAY_IP_address

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/Raw("x"*80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.3", dst="192.168.1.2")/Raw("x"*80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.4")/Raw("x"*80)],iface="ens786f0",count=1)

44.12.1.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.1.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.1.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.2. Subcase 2: MAC_PPPOE_IPV4_UDP_PAY

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.3", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.4")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=27,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=25,dport=19)/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.2.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.2.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 7 or 8. send mismatched packets, check the packets are not to queue 7 and 8.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 7 and 8.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.2.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.3. Subcase 3: MAC_PPPOE_IPV4_UDP_PAY_non_src_dst_port

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.3", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.4")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.3.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.3.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.3.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.4. Subcase 4: MAC_PPPOE_IPV4_TCP_PAY

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.3", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.4")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=27,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=25,dport=19)/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.4.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.4.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 7 or 8. send mismatched packets, check the packets are not to queue 7 and 8.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 7 and 8.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.4.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.5. Subcase 5: MAC_PPPOE_IPV4_TCP_PAY_non_src_dst_port

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.3", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.4")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.5.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.5.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions rss queues 7 8 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions rss queues 7 8 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 7 or 8. send mismatched packets, check the packets are not to queue 7 and 8.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 7 and 8.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions rss queues 7 8 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions rss queues 7 8 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.5.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.6. Subcase 6: MAC_PPPOE_IPV6_PAY_IP_address

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/Raw("x"*80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1537", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/Raw("x"*80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2023")/Raw("x"*80)],iface="ens786f0",count=1)

44.12.6.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.6.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.6.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.7. Subcase 7: MAC_PPPOE_IPV6_UDP_PAY

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2023")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=27,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=19)/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.7.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.7.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 4 or 5. send mismatched packets, check the packets are not to queue 4 and 5.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 4 and 5.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.7.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.8. Subcase 8: MAC_PPPOE_IPV6_UDP_PAY_non_src_dst_port

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1537", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2023")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.8.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.8.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.8.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.9. Subcase 9: MAC_PPPOE_IPV6_TCP_PAY

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2023")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=27,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=19)/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.9.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.9.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 4 or 5. send mismatched packets, check the packets are not to queue 4 and 5.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 4 and 5.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.9.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.10. Subcase 10: MAC_PPPOE_IPV6_TCP_PAY_non_src_dst_port

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1537", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2023")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.10.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.10.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.10.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.11. Subcase 11: MAC_VLAN_PPPOE_IPV4_PAY_IP_address

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/Raw("x"*80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/Raw("x"*80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.3", dst="192.168.1.2")/Raw("x"*80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.4")/Raw("x"*80)],iface="ens786f0",count=1)

44.12.11.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.11.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.11.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.12. Subcase 12: MAC_VLAN_PPPOE_IPV4_UDP_PAY

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.3", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.4")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=27,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=25,dport=19)/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.12.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    create a rule:

    flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.12.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 7 or 8. send mismatched packets, check the packets are not to queue 7 and 8.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 7 and 8.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.12.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp src is 25 dst is 23 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.13. Subcase 13: MAC_VLAN_PPPOE_IPV4_UDP_PAY_non_src_dst_port

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.3", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.4")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.13.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.13.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions rss queues 7 8 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions rss queues 7 8 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 7 or 8. send mismatched packets, check the packets are not to queue 7 and 8.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 7 and 8.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions rss queues 7 8 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions rss queues 7 8 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.13.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / udp / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.14. Subcase 14: MAC_VLAN_PPPOE_IPV4_TCP_PAY

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.3", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.4")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=27,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=25,dport=19)/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.14.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.14.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 7 or 8. send mismatched packets, check the packets are not to queue 7 and 8.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 7 and 8.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions rss queues 7 8 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.14.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp src is 25 dst is 23 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.15. Subcase 15: MAC_VLAN_PPPOE_IPV4_TCP_PAY_non_src_dst_port

matched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.3", dst="192.168.1.2")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.4")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP(src="192.168.1.1", dst="192.168.1.2")/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.15.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions queue index 2 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions queue index 2 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2. send mismatched packets, check the packets are not to queue 2.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions queue index 2 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions queue index 2 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.15.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions rss queues 7 8 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions rss queues 7 8 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 7 or 8. send mismatched packets, check the packets are not to queue 7 and 8.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 7 and 8.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions rss queues 7 8 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions rss queues 7 8 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.15.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv4 src is 192.168.1.1 dst is 192.168.1.2 / tcp / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.16. Subcase 16: MAC_VLAN_PPPOE_IPV6_PAY_IP_address

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/Raw("x"*80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/Raw("x"*80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1537", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/Raw("x"*80)],iface="ens786f0",count=1)

44.12.16.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.16.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.16.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.17. Subcase 17: MAC_VLAN_PPPOE_IPV6_UDP_PAY

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2023")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=27,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=19)/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.17.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.17.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 4 or 5. send mismatched packets, check the packets are not to queue 4 and 5.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 4 and 5.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.17.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.18. Subcase 18: MAC_VLAN_PPPOE_IPV6_UDP_PAY_non_src_dst_port

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1537", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.18.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.18.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.18.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / udp / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.19. Subcase 19: MAC_VLAN_PPPOE_IPV6_TCP_PAY

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2023")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=27,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=19)/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.19.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.19.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 4 or 5. send mismatched packets, check the packets are not to queue 4 and 5.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 4 and 5.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions rss queues 4 5 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.19.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / tcp src is 25 dst is 23 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.20. Subcase 20: MAC_VLAN_PPPOE_IPV6_TCP_PAY_non_src_dst_port

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1537", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/TCP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/Raw("x" * 80)],iface="ens786f0",count=1)

44.12.20.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.20.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.12.20.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / vlan tci is 1 / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 / tcp / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13. Test case: PPPoE Control

create a PPPOE rule to enable RSS for PPPOE_control packets:

testpmd> flow create 0 ingress pattern eth / pppoes / end actions rss types pppoe end key_len 0 queues end / end

44.13.1. Subcase 1: MAC_PPPOE_LCP_PAY

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0xc021)/PPP_LCP()/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:53",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0xc021)/PPP_LCP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=4)/PPP(proto=0xc021)/PPP_LCP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)

44.13.1.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.1.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow destroy 0 rule 15361
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.1.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.2. Subcase 2: MAC_PPPOE_IPCP_PAY

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x8021)/PPP_IPCP()/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:53",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x8021)/PPP_IPCP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=4)/PPP(proto=0x8021)/PPP_IPCP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)

44.13.2.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.2.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow destroy 0 rule 15361
    testpmd> flow list 0
    

    check the rules not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.2.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.3. Subcase 3: MAC_VLAN_PPPOE_LCP_PAY

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0xc021)/PPP_LCP()/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:53",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0xc021)/PPP_LCP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0xc021)/PPP_LCP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=4)/PPP(proto=0xc021)/PPP_LCP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)

44.13.3.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.3.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow destroy 0 rule 15361
    testpmd> flow list 0
    

    check the rules not exist in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.3.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0xc021 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.4. Subcase 4: MAC_VLAN_PPPOE_IPCP_PAY

matched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x8021)/PPP_IPCP()/Raw("x" * 80)],iface="ens786f0",count=1)

mismatched packets:

sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:53",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x8021)/PPP_IPCP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=2,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x8021)/PPP_IPCP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=4)/PPP(proto=0x8021)/PPP_IPCP()/Raw("x" * 80)],iface="ens786f0",count=1)
sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8100)/Dot1Q(vlan=1,type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0021)/IP()/Raw("x" * 80)],iface="ens786f0",count=1)

44.13.4.1. to queue action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions queue index 1 / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions queue index 1 / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 1. send mismatched packets, check the packets are not to queue 1.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions queue index 1 / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions queue index 1 / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.4.2. to queue group action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions rss queues 2 3 end / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions rss queues 2 3 end / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are to queue 2 or 3. send mismatched packets, check the packets are not to queue 2 and 3.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow destroy 0 rule 15361
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 2 and 3.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions rss queues 2 3 end / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions rss queues 2 3 end / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.13.4.3. drop action

  1. validate a rule:

    testpmd> flow validate 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions drop / end
    

    get the message:

    Flow rule validated
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  2. create a rule:

    testpmd> flow create 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions drop / end
    

    get the message:

    Succeeded to create (2) flow
    

    check the flow list:

    testpmd> flow list 0
    

    check the rule exists in the list.

  3. send matched packets, check the packets are dropped. send mismatched packets, check the packets are not dropped.

  4. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not dropped.

  5. check the pattern in pipeline mode

    validate a rule:

    testpmd> flow validate 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions drop / end
    

    create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth dst is 00:11:22:33:44:55 / vlan tci is 1 / pppoes seid is 3 / pppoe_proto_id is 0x8021 / end actions drop / end
    

    repeat step 1-4 to check the pattern in pipeline mode.

44.14. Test case: negative cases

Note: some of the error messages may be differernt.

44.14.1. Subcase 1: invalid parameters of queue index

  1. create a rule with invalid queue index:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions queue index 16 / end
    

    Failed to create flow, report message:

    Invalid action type or queue number: Invalid argument
    
  2. check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

44.14.2. Subcase 2: invalid parameters of rss queues

  1. Invalid number of queues:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues 1 2 3 end / end
    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues 0 end / end
    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues end / end
    

    Failed to create flow, report messag:

    Invalid action type or queue number: Invalid argument
    
  2. Discontinuous queues:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues 1 2 3 5 end / end
    

    Failed to create flow, report message:

    Discontinuous queue region: Invalid argument
    
  3. Invalid queue index:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues 15 16 end / end
    

    Failed to create flow, report message:

    Invalid queue region indexes: Invalid argument
    
  4. set queue group 17 queues:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 end / end
    

    Failed to create flow, report message:

    Invalid action type or queue number: Invalid argument
    
  5. check the flow list:

    testpmd> flow list 0
    

    check the rules not exist in the list.

44.14.3. Subcase 4: unsupported input set

  1. create an nvgre rule with unsupported input set field [inner tos]:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 dst is 192.168.0.1 / nvgre tni is 2 / eth dst is 68:05:ca:8d:ed:a8 / ipv4 src is 192.168.1.2 dst is 192.168.1.3 tos is 4 / end actions queue index 1 / end
    
  2. Failed to create flow, report message:

    Invalid input set: Invalid argument
    
  3. check the rule list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

44.14.4. Subcase 5: duplicated rules

  1. create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions queue index 1 / end
    testpmd> flow list 0
    

    check the rule exists in the list.

  2. create the same rule again, Failed to create flow, report message:

    switch filter create flow fail: Invalid argument
    
  3. check the flow list:

    testpmd> flow list 0
    

    check only the first rule exists in the list.

44.14.5. Subcase 6: conflicted rules

  1. create a rule:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions queue index 1 / end
    testpmd> flow list 0
    

    check the rule exists in the list.

  2. create a rule with same input set but different actions:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions queue index 2 / end
    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions drop / end
    

    Failed to create the two rules, report message:

    switch filter create flow fail: Invalid argument
    
  3. check the flow list:

    testpmd> flow list 0
    

    check only the first rule exists in the list.

44.14.6. Subcase 7: multiple actions

  1. create a rule with two conflicted actions:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions queue index 1 / rss queues 2 3 end / end
    

    Failed to create flow, report message:

    Invalid input action number: Invalid argument
    
  2. check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

44.14.7. Subcase 8: void action

  1. create a rule with void action:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 / udp src is 25 dst is 23 / end actions end
    

    Failed to create flow, report message:

    NULL action.: Invalid argument
    
  2. check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

44.14.8. Subcase 9: unsupported action

  1. create a rule with void action:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions mark id 1 / end
    

    Failed to create flow, report message:

    Invalid action type: Invalid argument
    
  2. check the flow list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

44.14.9. Subcase 10: delete a non-existing rule

  1. check the rule list:

    testpmd> flow list 0
    

    check no switch filter rule exists in the list.

  2. destroy the rule 20000:

    testpmd> flow destroy 0 rule 20000
    

    check no error reports.

44.14.10. Subcase 11: add long switch rule

Description: A recipe has 5 words, one of which is reserved for switch ID, so a recipe can use 4 words, and a maximum of 5 recipes can be chained, one of which is reserved. Therefore, a rule can use up to 4*4*2 = 32 bytes. This case is used to test that a rule whose input set is longer than 32 bytes can not be created successfully, and will not affect the creation of other rules.

  1. create a rule with input set length longer than 32 bytes:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end
    

    Failed to create flow, report message:

    Invalid input set: Invalid argument
    
  2. check the rule list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

  3. create a MAC_PPPOE_IPV6_UDP_PAY rule with to queue action:

    testpmd> flow create 0 priority 0 ingress pattern eth / pppoes / ipv6 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end
    testpmd> flow list 0
    

    check the rule exists in the list.

  4. send matched packets:

    sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
    

    check queue 1 receive the packet. send mismatched packets:

    sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2023")/UDP(sport=25,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
    sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=27,dport=23)/Raw("x" * 80)],iface="ens786f0",count=1)
    sendp([Ether(src="11:22:33:44:55:99",dst="00:11:22:33:44:55",type=0x8864)/PPPoE(sessionid=3)/PPP(proto=0x0057)/IPv6(src="CDCD:910A:2222:5498:8475:1111:3900:1536", dst="CDCD:910A:2222:5498:8475:1111:3900:2022")/UDP(sport=25,dport=19)/Raw("x" * 80)],iface="ens786f0",count=1)
    

    check the packets are not to queue 1.

  5. verify rules can be destroyed:

    testpmd> flow destroy 0 rule 15360
    testpmd> flow list 0
    

    check the rule not exists in the list. send matched packets, check the packets are not to queue 1.

44.14.11. Subcase 12: void input set value

  1. create a IPV4_PAY rule with void input set value:

    testpmd> flow create 0 priority 0 ingress pattern eth / ipv4 / end actions queue index 1 / end
    

    Failed to create flow, report message:

    Invalid input set: Invalid argument
    
  2. check the rule list:

    testpmd> flow list 0
    

    check the rule not exists in the list.

44.14.12. Subcase 13: invalid port

  1. create a rule with invalid port:

    testpmd> flow create 1 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions queue index 1 / end
    

    Failed to create flow, report message:

    No such device: No such device
    
  2. check the rule list on port 0:

    testpmd> flow list 0
    

    check the rule not exists in the list. check on port 1:

    testpmd> flow list 1
    

    get the message:

    Invalid port 1
    

44.15. Test case: negative validation

Note: some of the error messages may be different.

  1. invalid parameters of queue index

    testpmd> flow validate 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions queue index 16 / end

    get the error message:

    Invalid action type or queue number: Invalid argument
    
  2. invalid parameters of rss queues

    Invalid number of queues:

    testpmd> flow validate 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues 1 2 3 end / end
    testpmd> flow validate 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues 0 end / end
    testpmd> flow validate 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues end / end
    

    get the error message:

    Invalid action type or queue number: Invalid argument
    

    Discontinuous queues:

    testpmd> flow validate 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues 1 2 3 5 end / end
    

    get the error message:

    Discontinuous queue region: Invalid argument
    

    Invalid rss queues index:

    testpmd> flow validate 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions rss queues 15 16 end / end
    

    get the error message:

    Invalid queue region indexes: Invalid argument
    
  1. unsupported input set

    testpmd> flow validate 0 priority 0 ingress pattern eth / ipv4 dst is 192.168.0.1 / nvgre tni is 2 / eth dst is 68:05:ca:8d:ed:a8 / ipv4 src is 192.168.1.2 dst is 192.168.1.3 tos is 4 / end actions queue index 1 / end

    get the error message:

    Invalid input set: Invalid argument
    
  2. multiple actions

    testpmd> flow validate 0 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions queue index 1 / rss queues 2 3 end / end

    get the error message:

    Invalid input action number: Invalid argument
    
  3. void action

    testpmd> flow validate 0 priority 0 ingress pattern eth / ipv4 / udp src is 25 dst is 23 / end actions end

    get the error message:

    NULL action.: Invalid argument
    
  4. unsupported action

    testpmd> flow validate 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions mark id 1 / end

    get the error message:

    Invalid action type: Invalid argument
    
  5. long switch rule

    testpmd> flow validate 0 priority 0 ingress pattern eth / pppoes / ipv6 src is CDCD:910A:2222:5498:8475:1111:3900:1536 dst is CDCD:910A:2222:5498:8475:1111:3900:2022 / udp src is 25 dst is 23 / end actions queue index 1 / end

    get the error message:

    Invalid input set: Invalid argument
    
  6. void input set value

    testpmd> flow validate 0 priority 0 ingress pattern eth / ipv4 / end actions queue index 1 / end

    get the error message:

    Invalid input set: Invalid argument
    
  7. invalid port

    testpmd> flow validate 1 priority 0 ingress pattern eth / ipv4 src is 192.168.0.20 dst is 192.168.0.21 ttl is 2 tos is 4 / end actions queue index 1 / end

    get the error message:

    No such device: No such device
    
  8. check the rule list:

    testpmd> flow list 0
    

    no rule exists in the list.