From patchwork Thu Nov 9 23:07:31 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jeremy Spewock X-Patchwork-Id: 134039 X-Patchwork-Delegate: thomas@monjalon.net Return-Path: X-Original-To: patchwork@inbox.dpdk.org Delivered-To: patchwork@inbox.dpdk.org Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id B4312432EC; Fri, 10 Nov 2023 00:09:13 +0100 (CET) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id E74CA40FDE; Fri, 10 Nov 2023 00:09:11 +0100 (CET) Received: from mail-io1-f97.google.com (mail-io1-f97.google.com [209.85.166.97]) by mails.dpdk.org (Postfix) with ESMTP id ADA7540156 for ; Fri, 10 Nov 2023 00:09:08 +0100 (CET) Received: by mail-io1-f97.google.com with SMTP id ca18e2360f4ac-7a66aa8ebb7so50997639f.3 for ; Thu, 09 Nov 2023 15:09:08 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=iol.unh.edu; s=unh-iol; t=1699571348; x=1700176148; darn=dpdk.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=XeGhsEWscqMfEmEUcxpZr6BRiyV0QtEgWJmNXiR6cMU=; b=Ft2pO+vIt5MoTqZzV68unaUZvqsZqCLH/ksKZGXSS1m/5NnV0Z9xATDeCekRlXuytW I7XgazRvndBBX08Cj7MPWlWEq7+ITW5OFaYeFdGpFKOQAe9cINBIowS7UEQt+hqILj3H W2oXGA7LijmJi3p7X/DhpvueHLbpFDstx+CHE= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1699571348; x=1700176148; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=XeGhsEWscqMfEmEUcxpZr6BRiyV0QtEgWJmNXiR6cMU=; b=qcq40jcqPg2II8YbTGVKKgexIsb6SjYBCt8G73AX09bzaXNkKdJR50aHLgOjkiaqYM oW3wrdxhvYFttUmRy0jWmHm0P5JfNfIq6MIqbm/0LOl1BdhIn5MQUajdBWLQkCabgPa7 yV2YKu65X/EUGb9NFvGWXfM/a680QbUR7/PBHYGwKc3yTygxsrtaQ0RjQeC5aU2dTh2r 8WUeCc6oAgKs6nC26WCAdbr1OIW/gWXpXoQqgV2N/AA+T3tIUBF/7vojSoolPwioNNfJ 6qh4O63NDJkKr12ydabPJcPaHfBO5mOtNHfIgWXywN9lX420+Myf64IfGbEgL5ZB4kj1 KvMQ== X-Gm-Message-State: AOJu0Yw9U/LrWPnunr8lLniokfBSU7xhKDvk8UmiooDokS/9XgZB64i/ 0e1yJHiVIWm7SEQgaie8bGpqNnqLyst4TjNSHlaY0RamKqTwrpxZNsDxQtr1UHDeJg== X-Google-Smtp-Source: AGHT+IGqQfoPc9VmHCwNgGk942v/XurqBPlcvFSBlmfh3FRs/VGl5a9KDQLjyFSQ7ybVToSuk1WpSILZDOOQ X-Received: by 2002:a6b:f203:0:b0:7a9:7de6:7cbc with SMTP id q3-20020a6bf203000000b007a97de67cbcmr3444660ioh.18.1699571348011; Thu, 09 Nov 2023 15:09:08 -0800 (PST) Received: from postal.iol.unh.edu (postal.iol.unh.edu. [2606:4100:3880:1234::84]) by smtp-relay.gmail.com with ESMTPS id e14-20020a056638020e00b0042b0c440bafsm926270jaq.70.2023.11.09.15.09.07 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Thu, 09 Nov 2023 15:09:07 -0800 (PST) X-Relaying-Domain: iol.unh.edu Received: from iol.unh.edu (unknown [IPv6:2606:4100:3880:1271:90f9:1b64:f6e6:867f]) by postal.iol.unh.edu (Postfix) with ESMTP id 6E43A605C319; Thu, 9 Nov 2023 18:09:07 -0500 (EST) From: jspewock@iol.unh.edu To: Honnappa.Nagarahalli@arm.com, juraj.linkes@pantheon.tech, thomas@monjalon.net, wathsala.vithanage@arm.com, probb@iol.unh.edu, paul.szczepanek@arm.com, yoan.picchi@foss.arm.com, ferruh.yigit@amd.com, andrew.rybchenko@oktetlabs.ru Cc: dev@dpdk.org, Jeremy Spewock Subject: [PATCH v1 1/7] dts: Add scatter test suite Date: Thu, 9 Nov 2023 18:07:31 -0500 Message-ID: <20231109230900.24572-2-jspewock@iol.unh.edu> X-Mailer: git-send-email 2.42.0 In-Reply-To: <20231109230900.24572-1-jspewock@iol.unh.edu> References: <20231109230900.24572-1-jspewock@iol.unh.edu> MIME-Version: 1.0 X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org From: Jeremy Spewock This test suite provides testing the support of scattered packets by Poll Mode Drivers using testpmd. It incorporates 5 different test cases which test the sending and receiving of packets with lengths that are less than the mbuf data buffer size, the same as the mbuf data buffer size, and the mbuf data buffer size plus 1, 4, and 5. The goal of this test suite is to align with the existing dts test plan for scattered packets within DTS. Signed-off-by: Jeremy Spewock --- dts/tests/TestSuite_scatter.py | 85 ++++++++++++++++++++++++++++++++++ 1 file changed, 85 insertions(+) create mode 100644 dts/tests/TestSuite_scatter.py diff --git a/dts/tests/TestSuite_scatter.py b/dts/tests/TestSuite_scatter.py new file mode 100644 index 0000000000..0adaad1b2c --- /dev/null +++ b/dts/tests/TestSuite_scatter.py @@ -0,0 +1,85 @@ +# SPDX-License-Identifier: BSD-3-Clause +# Copyright(c) 2023 University of New Hampshire + +import struct + +from scapy.layers.inet import IP # type: ignore[import] +from scapy.layers.l2 import Ether # type: ignore[import] +from scapy.packet import Raw # type: ignore[import] +from scapy.utils import hexstr # type: ignore[import] + +from framework.remote_session import TestPmdShell +from framework.test_suite import TestSuite + + +class Scatter(TestSuite): + mbsize: int + + def set_up_suite(self) -> None: + self.verify( + len(self._port_links) > 1, + "Must have at least two port links to run scatter", + ) + if self._sut_port_egress.os_driver in ["i40e", "ixgbe", "ice"]: + self.mbsize = 2048 + else: + self.mbsize = 1024 + + self.tg_node.main_session.configure_port_mtu(9000, self._tg_port_egress) + self.tg_node.main_session.configure_port_mtu(9000, self._tg_port_ingress) + + def scatter_pktgen_send_packet(self, pktsize: int) -> str: + """Generate and send packet to the SUT. + + Functional test for scatter packets. + + Args: + pktsize: Size of the packet to generate and send. + """ + packet = Ether() / IP() / Raw() + packet.getlayer(2).load = "" + payload_len = pktsize - len(packet) - 4 + payload = ["58"] * payload_len + # pack the payload + for X_in_hex in payload: + packet.load += struct.pack( + "=B", int("%s%s" % (X_in_hex[0], X_in_hex[1]), 16) + ) + received_packets = self.send_packet_and_capture(packet) + self.verify(len(received_packets) > 0, "Did not receive any packets.") + load = hexstr(received_packets[0].getlayer(2), onlyhex=1) + + return load + + def test_scatter_mbuf_2048(self) -> None: + """ + Test: + Start testpmd and run functional test with preset mbsize. + """ + testpmd = self.sut_node.create_interactive_shell( + TestPmdShell, + app_parameters=( + "--mbcache=200 " + f"--mbuf-size={self.mbsize} " + "--max-pkt-len=9000 " + "--port-topology=paired " + "--tx-offloads=0x00008000" + ), + privileged=True, + ) + testpmd.send_command("set fwd mac") + testpmd.send_command("start") + link_is_up = testpmd.wait_link_status_up(0) and testpmd.wait_link_status_up(1) + self.verify(link_is_up, "Links never came up in TestPMD.") + + for offset in [-1, 0, 1, 4, 5]: + recv_payload = self.scatter_pktgen_send_packet(self.mbsize + offset) + self.verify( + ("58 " * 8).strip() in recv_payload, + "Received packet had incorrect payload", + ) + testpmd.send_command("stop") + + def tear_down_suite(self) -> None: + self.tg_node.main_session.configure_port_mtu(1500, self._tg_port_egress) + self.tg_node.main_session.configure_port_mtu(1500, self._tg_port_ingress)