From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id A54E545837; Wed, 21 Aug 2024 21:16:30 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 226B142D80; Wed, 21 Aug 2024 21:16:22 +0200 (CEST) Received: from mail-oo1-f100.google.com (mail-oo1-f100.google.com [209.85.161.100]) by mails.dpdk.org (Postfix) with ESMTP id AB8F142D35 for ; Wed, 21 Aug 2024 21:16:19 +0200 (CEST) Received: by mail-oo1-f100.google.com with SMTP id 006d021491bc7-5d5b1e33fa8so45820eaf.3 for ; Wed, 21 Aug 2024 12:16:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=iol.unh.edu; s=unh-iol; t=1724267779; x=1724872579; 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=Kbho/0kShULeyiHAdf9m/LQtacL2kMkDkmkWlDSkC9s=; b=Cxb7I9PGnUvLRVBHApe12VTtMBKSA2e3cgic5mJspn4BrxuZvv9UHnUepBQ9pEmmvh ZJOlbFcsEid0wpDiWvnEfVKh91V7V70IYHKcF7u/wNS8EupZ2QoIIUDjVX2Xo7KrPWdK 8UDW78frvHKOZgfxEIXM4O/gq9WHogXNLOB94= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1724267779; x=1724872579; 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=Kbho/0kShULeyiHAdf9m/LQtacL2kMkDkmkWlDSkC9s=; b=CQhrfmo0JtL7EEPqF2ZNdiVBntqEuDhzxZK3ByFmM6FVjEWuqVF2hq/q3ehB68tPxT saq77JSH3CpLTdq6TOK2stwThJouE58fM6iakBNmUj+WPHAkAFXxMgApSgVnNCJegj2S 9/mRv7ut0j4LOw0+LDB6kMc/CIDyWJIQuQv49qf6hG10+ibjwZewBlDlVA6cSPJheTvR s3V8IGveKO6kOzV/mFzdq/2U0e24RZsCBVerXQTP/qUchMPrtlFvGBpgWdzgUcfH0039 fT+ouz3oEQkRzmqhL/Q6L56SEpFWB4asLC2aVPRPbLcpVQBSffLUaVw0nbkSp5R+echf YEfg== X-Gm-Message-State: AOJu0YzphWZP0V+1ruQyZ1QRSD2NudybZNEKDFfS56F5E9/q1VOMGHu6 S2S4kpdwx88tJnipbYhXZM1hFGg7adG6+WCG3Nrurd6wbOCPLdustHC/G2gMwTKx9FfscyCDAcw ORZ/H9da7CZ7aabNFk7R6jul4pQ9/VH1Dqh/9en0kF1sA0GaZ X-Google-Smtp-Source: AGHT+IEB8cFIsHIw4JWN2uF2R8HnYPU+zKQQEyMgzepQNtO4xG7vfdlETqq2KcqDY8QZqex/KVF0nyefhBVq X-Received: by 2002:a05:6820:1611:b0:5da:a4a7:8f6a with SMTP id 006d021491bc7-5dca06950c9mr4518357eaf.4.1724267778961; Wed, 21 Aug 2024 12:16:18 -0700 (PDT) Received: from postal.iol.unh.edu (postal.iol.unh.edu. [2606:4100:3880:1234::84]) by smtp-relay.gmail.com with ESMTPS id 006d021491bc7-5dc93aac1c4sm156353eaf.9.2024.08.21.12.16.18 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Wed, 21 Aug 2024 12:16:18 -0700 (PDT) X-Relaying-Domain: iol.unh.edu Received: from iol.unh.edu (unknown [IPv6:2606:4100:3880:1257::1083]) by postal.iol.unh.edu (Postfix) with ESMTP id AE9FD605C352; Wed, 21 Aug 2024 15:16:17 -0400 (EDT) From: jspewock@iol.unh.edu To: npratte@iol.unh.edu, thomas@monjalon.net, Luca.Vizzarro@arm.com, yoan.picchi@foss.arm.com, alex.chapman@arm.com, juraj.linkes@pantheon.tech, probb@iol.unh.edu, wathsala.vithanage@arm.com, paul.szczepanek@arm.com, Honnappa.Nagarahalli@arm.com Cc: dev@dpdk.org, Jeremy Spewock Subject: [RFC PATCH v1 4/5] dts: add OS abstractions for creating virtual functions Date: Wed, 21 Aug 2024 15:15:56 -0400 Message-ID: <20240821191557.18744-5-jspewock@iol.unh.edu> X-Mailer: git-send-email 2.46.0 In-Reply-To: <20240821191557.18744-1-jspewock@iol.unh.edu> References: <20240821191557.18744-1-jspewock@iol.unh.edu> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit 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 Virtual functions in the framework are created using SR-IOV. The process for doing this can vary depending on the operating system, so the commands to create VFs have to be abstracted into different classes based on the operating system. This patch adds the stubs for methods that create VFs and get the PCI addresses of all VFs on a port to the abstract class as well as a linux implementation for the methods. Bugzilla ID: 1500 Signed-off-by: Jeremy Spewock --- dts/framework/testbed_model/linux_session.py | 36 +++++++++++++++++- dts/framework/testbed_model/os_session.py | 40 ++++++++++++++++++++ 2 files changed, 75 insertions(+), 1 deletion(-) diff --git a/dts/framework/testbed_model/linux_session.py b/dts/framework/testbed_model/linux_session.py index 99abc21353..48bf212f6a 100644 --- a/dts/framework/testbed_model/linux_session.py +++ b/dts/framework/testbed_model/linux_session.py @@ -15,7 +15,7 @@ from typing_extensions import NotRequired -from framework.exception import ConfigurationError, RemoteCommandExecutionError +from framework.exception import ConfigurationError, RemoteCommandExecutionError, InternalError from framework.utils import expand_range from .cpu import LogicalCore @@ -210,3 +210,37 @@ def configure_ipv4_forwarding(self, enable: bool) -> None: """Overrides :meth:`~.os_session.OSSession.configure_ipv4_forwarding`.""" state = 1 if enable else 0 self.send_command(f"sysctl -w net.ipv4.ip_forward={state}", privileged=True) + + def set_num_virtual_functions(self, num: int, pf_port: Port) -> bool: + """Overrides :meth:`~.os_session.OSSession.set_num_virtual_functions`.""" + sys_bus_path = f"/sys/bus/pci/devices/{pf_port.pci}/sriov_numvfs".replace(":", "\\:") + curr_num_vfs = int(self.send_command(f"cat {sys_bus_path}").stdout) + if num > 0 and curr_num_vfs >= num: + self._logger.info( + f"{curr_num_vfs} VFs already configured on port {pf_port.identifier.pci} on node " + f"{pf_port.identifier.node}." + ) + return False + elif num > 0 and curr_num_vfs > 0: + self._logger.error( + f"Not enough VFs configured on port {pf_port.identifier.pci} on node " + f"{pf_port.identifier.node}. Need {num} but only {curr_num_vfs} are configured. " + "DTS is unable to modify number of preexisting VFs." + ) + raise InternalError("Failed to create VFs on port.") + self.send_command(f"echo {num} > {sys_bus_path}", privileged=True, verify=True) + return True + + def get_pci_addr_of_vfs(self, pf_port: Port) -> list[str]: + """Overrides :meth:`~.os_session.OSSession.get_pci_addr_of_vfs`.""" + sys_bus_path = f"/sys/bus/pci/devices/{pf_port.pci}".replace(":", "\\:") + curr_num_vfs = int(self.send_command(f"cat {sys_bus_path}/sriov_numvfs").stdout) + if curr_num_vfs > 0: + pci_addrs = self.send_command( + 'awk -F "PCI_SLOT_NAME=" "/PCI_SLOT_NAME=/ {print \\$2}" ' + + f"{sys_bus_path}/virtfn*/uevent", + privileged=True, + ) + return pci_addrs.stdout.splitlines() + else: + return [] diff --git a/dts/framework/testbed_model/os_session.py b/dts/framework/testbed_model/os_session.py index 79f56b289b..191fc3c0c8 100644 --- a/dts/framework/testbed_model/os_session.py +++ b/dts/framework/testbed_model/os_session.py @@ -395,3 +395,43 @@ def configure_ipv4_forwarding(self, enable: bool) -> None: Args: enable: If :data:`True`, enable the forwarding, otherwise disable it. """ + + @abstractmethod + def set_num_virtual_functions(self, num: int, pf_port: Port) -> bool: + """Update the number of virtual functions (VFs) on a port. + + It should be noted that, due to the nature of VFs, if there are already VFs that exist on + the physical function (PF) prior to calling this function, additional ones cannot be added. + The only way to add more VFs is to remove the existing and then set the desired amount. For + this reason, this method will handle creation in the following order: + + 1. Use existing VFs on the PF if the number of existing VFs is greater than or equal to + `num` + 2. Throw an exception noting that VFs cannot be created if the PF has some VFs already set + on it, but the total VFs that it has are less then `num`. + 3. Create `num` VFs on the PF if there are none on it already + + Args: + num: The number of VFs to set on the port. + pf_port: The port to add the VFs to. + + Raises: + InternalError: If `pf_port` has less than `num` VFs configured on it + already. + + Returns: + :data:`True` if this method successfully created VFs, :data:`False` if existing VFs + were used instead. + """ + + @abstractmethod + def get_pci_addr_of_vfs(self, pf_port: Port) -> list[str]: + """Find the PCI addresses of all virtual functions (VFs) on the port `pf_port`. + + Args: + pf_port: The port to find the VFs on. + + Returns: + A list containing all of the PCI addresses of the VFs on the port. If the port has no + VFs then the list will be empty. + """ -- 2.46.0