From: Weiyuan Li <weiyuanx.li@intel.com>
To: dts@dpdk.org
Cc: Weiyuan Li <weiyuanx.li@intel.com>
Subject: [dts][PATCH V1 2/2] tests/mac_filter: add the vlan filter check after setting multicast filter
Date: Thu, 12 Jan 2023 17:15:19 +0800 [thread overview]
Message-ID: <20230112091519.29607-2-weiyuanx.li@intel.com> (raw)
In-Reply-To: <20230112091519.29607-1-weiyuanx.li@intel.com>
Add the vlan filter check after setting multicast filter.
1. Enable vlan filter and add vlan id. Send a packet with multicast dst
mac and vlan tag can receive packet.
2. Disable vlan filter and remove vlan id. Send a packet with multicast
dst mac can receive packet.
Signed-off-by: Weiyuan Li <weiyuanx.li@intel.com>
---
tests/TestSuite_mac_filter.py | 45 +++++++++++++++++++++++++++++++----
1 file changed, 41 insertions(+), 4 deletions(-)
diff --git a/tests/TestSuite_mac_filter.py b/tests/TestSuite_mac_filter.py
index a0ba65c7..afd99080 100644
--- a/tests/TestSuite_mac_filter.py
+++ b/tests/TestSuite_mac_filter.py
@@ -8,6 +8,7 @@ Test the support of Allowlist Features by Poll Mode Drivers
"""
import operator
+import random
import time
import framework.utils as utils
@@ -15,6 +16,8 @@ from framework.packet import Packet
from framework.pmd_output import PmdOutput
from framework.test_case import TestCase
+MAX_VLAN = 4095
+
class TestMacFilter(TestCase):
def set_up_all(self):
@@ -56,7 +59,9 @@ class TestMacFilter(TestCase):
out, "Maximum number of MAC addresses: ([0-9]+)"
)
- def allowlist_send_packet(self, portid, destMac="00:11:22:33:44:55", count=-1):
+ def allowlist_send_packet(
+ self, portid, destMac="00:11:22:33:44:55", count=-1, pkt_type="UDP", vlan=""
+ ):
"""
Send 1 packet to portid.
"""
@@ -65,8 +70,13 @@ class TestMacFilter(TestCase):
count = self.frames_to_send
itf = self.tester.get_interface(self.tester.get_local_port(portid))
- pkt = Packet(pkt_type="UDP")
- pkt.config_layer("ether", {"src": "52:00:00:00:00:00", "dst": destMac})
+ if pkt_type == "VLAN_UDP" and vlan is not None:
+ pkt = Packet(pkt_type="VLAN_UDP")
+ pkt.config_layer("vlan", {"vlan": vlan})
+ pkt.config_layer("ether", {"dst": destMac})
+ else:
+ pkt = Packet(pkt_type="UDP")
+ pkt.config_layer("ether", {"src": "52:00:00:00:00:00", "dst": destMac})
pkt.send_pkt(self.tester, tx_port=itf, count=count)
def test_add_remove_mac_address(self):
@@ -188,6 +198,7 @@ class TestMacFilter(TestCase):
Remove mac address and check packet can't received
"""
# initialise first port without promiscuous mode
+ random_vlan = random.randint(1, MAX_VLAN)
mcast_addr = "01:00:5E:00:00:00"
portid = self.dutPorts[0]
self.dut.send_expect(f"set promisc {portid:d} off", "testpmd> ")
@@ -201,7 +212,33 @@ class TestMacFilter(TestCase):
"received" in out,
"Packet has not been received when it should have on a broadcast address",
)
-
+ # enable vlan filter
+ self.dut.send_expect("vlan set filter on 0", "testpmd> ")
+ self.dut.send_expect("rx_vlan add %d 0" % random_vlan, "testpmd> ")
+ # passed vlan id
+ self.allowlist_send_packet(
+ portid, destMac=mcast_addr, pkt_type="VLAN_UDP", vlan=random_vlan
+ )
+ out = self.dut.get_session_output()
+ self.verify("received" in out, "Not receive vlan packet with multicast mac!!!")
+ # wrong vlan id
+ self.allowlist_send_packet(
+ portid, destMac=mcast_addr, pkt_type="VLAN_UDP", vlan=random_vlan - 1
+ )
+ out = self.dut.get_session_output()
+ self.verify(
+ "received" not in out,
+ "Wrong vlan packet can't receive with multicast mac!!!",
+ )
+ # disbale vlan filter and remove vlan id
+ self.dut.send_expect("rx_vlan rm %d 0" % random_vlan, "testpmd> ")
+ self.dut.send_expect("vlan set filter off 0", "testpmd> ")
+ self.allowlist_send_packet(portid, mcast_addr, count=1)
+ out = self.dut.get_session_output()
+ self.verify(
+ "received" in out,
+ "Packet has not been received when it should have on a broadcast address",
+ )
self.dut.send_expect(f"mcast_addr remove {portid:d} {mcast_addr}", "testpmd>")
self.allowlist_send_packet(portid, mcast_addr, count=1)
time.sleep(1)
--
2.27.0
next prev parent reply other threads:[~2023-01-12 9:15 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-01-12 9:15 [dts][PATCH V1 1/2] test_plans/mac_filter: " Weiyuan Li
2023-01-12 9:15 ` Weiyuan Li [this message]
2023-01-13 2:46 ` [dts][PATCH V1 2/2] tests/mac_filter: " lijuan.tu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20230112091519.29607-2-weiyuanx.li@intel.com \
--to=weiyuanx.li@intel.com \
--cc=dts@dpdk.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).