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 F37A241F67; Mon, 10 Jun 2024 10:51:40 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 66FCE40A71; Mon, 10 Jun 2024 10:51:33 +0200 (CEST) Received: from NAM10-BN7-obe.outbound.protection.outlook.com (mail-bn7nam10on2058.outbound.protection.outlook.com [40.107.92.58]) by mails.dpdk.org (Postfix) with ESMTP id B38F640A75 for ; Mon, 10 Jun 2024 10:51:31 +0200 (CEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=dWowtK6Jph5Lk6ar7qDzOdnx8rEouWr6B+ttoesVTMtLY90DGXivXYb7Xqjez9PXWMrf+JysUfhUh//IwTd9sjktaXTIhxD+2xiwCDIcAqNlcqHI5GoFgmbmSv/R9/FbUMYxD7CYbpDgCjypyJfRd89aEV6qKzvDISfSNfx8q0fCKhck8AwXyPMq5GP47PPO548MIFZj1dCc7MiD1xPzFORZ3bK7tXSakTUFXVLZq1gdV/1DAWKV/gMENgMhnXdE1X6m80AVjRt3wBFFVY3LOB3k9wM5QvRg5WVHi9IJDlvrXLXPeDrdqnMFG3mjBb31IfUspnWMWYXGGtKvsBSrDg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=4y5iUWtRoYjbNO5JTH/P90+5m69xTscA2OGzNxIjnTw=; b=jgO0fzpCSCvl3zjgxg4Ci+63IYrIaw572Q96kl6Z3hFQK8VESbAnVGGbJjy8IkVkgDqonbIbltf8WbJ/hiRsTzcQt8bYE/Lb8apzZ3KVw0TMbWrDSCqS7s48nbzQPhrQ0RLETNN45p6xGaxpONdS0W8liKq7H6jwiMa4wM2LP5P6zfeoRN+pOVUf2ZIrjGi5912togf7n1TjVmxhtIG9FbD4nJseSTSLqqFdOF1mNGFgZdeQL4nyYo7XuUebudyt2Qg86xeLZMWaXTo9l+XSanlPbbQQC37QjN+Aqvr5vDFnAXsbH3deIt8b0XoyninQ0Ech7XWmqmYgsjCZLMNzqQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.117.160) smtp.rcpttodomain=dpdk.org smtp.mailfrom=nvidia.com; dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com; dkim=none (message not signed); arc=none (0) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=4y5iUWtRoYjbNO5JTH/P90+5m69xTscA2OGzNxIjnTw=; b=ju+HcGFLhKcKZgk1HXy1qsnDdEIQKTmqGNkfw0hR8WaFgYucSFp0WFvmCqeFgIG5DZJH2nrLgGIzfNSISlCZoWx4PHzzNKZbrhRxwooXTPHs/bGPD1j6mO04bhZOurpjYPPUOuHnID9LZMKVGmNHDqH2Z9ndw4bs8a42J5oQKap1rduDTAwDldDFTDt1T2DzfIbnD6k1H3c774StgzVi4UZspSuFSbZ4dLTSQG//6vCBNYDRbsW09jSg7rLjtIlpGtUzWE8D1vQG8J+xSXh8oWNTjhnOVDXdzEogrZgyl1ZcKNg5Tr7GUWHAtzBCaR5zdYFVDtMMNgJW8AWP+qpoZQ== Received: from MW4PR03CA0249.namprd03.prod.outlook.com (2603:10b6:303:b4::14) by SN7PR12MB6981.namprd12.prod.outlook.com (2603:10b6:806:263::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7633.36; Mon, 10 Jun 2024 08:51:29 +0000 Received: from CO1PEPF000044F6.namprd21.prod.outlook.com (2603:10b6:303:b4:cafe::b0) by MW4PR03CA0249.outlook.office365.com (2603:10b6:303:b4::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7656.21 via Frontend Transport; Mon, 10 Jun 2024 08:51:29 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 216.228.117.160) smtp.mailfrom=nvidia.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=nvidia.com; Received-SPF: Pass (protection.outlook.com: domain of nvidia.com designates 216.228.117.160 as permitted sender) receiver=protection.outlook.com; client-ip=216.228.117.160; helo=mail.nvidia.com; pr=C Received: from mail.nvidia.com (216.228.117.160) by CO1PEPF000044F6.mail.protection.outlook.com (10.167.241.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7677.0 via Frontend Transport; Mon, 10 Jun 2024 08:51:28 +0000 Received: from rnnvmail203.nvidia.com (10.129.68.9) by mail.nvidia.com (10.129.200.66) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.4; Mon, 10 Jun 2024 01:51:16 -0700 Received: from rnnvmail201.nvidia.com (10.129.68.8) by rnnvmail203.nvidia.com (10.129.68.9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.4; Mon, 10 Jun 2024 01:51:15 -0700 Received: from nvidia.com (10.127.8.14) by mail.nvidia.com (10.129.68.8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.4 via Frontend Transport; Mon, 10 Jun 2024 01:51:13 -0700 From: Maayan Kashani To: CC: , , , Gregory Etelson , Viacheslav Ovsiienko , Ori Kam , Suanming Mou , Matan Azrad Subject: [PATCH v5 5/6] net/mlx5: update HWS ASO actions validation Date: Mon, 10 Jun 2024 11:50:38 +0300 Message-ID: <20240610085039.146356-5-mkashani@nvidia.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20240610085039.146356-1-mkashani@nvidia.com> References: <20240606101214.172057-1-mkashani@nvidia.com> <20240610085039.146356-1-mkashani@nvidia.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-NV-OnPremToCloud: ExternallySecured X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CO1PEPF000044F6:EE_|SN7PR12MB6981:EE_ X-MS-Office365-Filtering-Correlation-Id: c7e4cd43-81e1-41ee-7198-08dc892a84c6 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; ARA:13230031|82310400017|1800799015|36860700004|376005; X-Microsoft-Antispam-Message-Info: =?us-ascii?Q?npTCbTXP1ydjWrbaRpuuiEmb7AYszsNZZQ8R0si0U8sM8INLHH5U/EgHQoMO?= =?us-ascii?Q?1fTonCsWIMARUSeXrBEQTvn2JLGfDIoVCocyRorkqVQEP/9wC/F9BK2NmKq0?= =?us-ascii?Q?FPwrsnQ+jvOsW0mkS8XVtAz3kXh85nyZAL9S24H/5+RCighAfAQaDn73o9y+?= =?us-ascii?Q?kr8TjEr5nFa+D8jt8jvZHM+N4dxuhgipGZaYvefTK4LC/Y9iB4GzqjvMVnGQ?= =?us-ascii?Q?Vc8EjUlKcuUqGmVVPup3ApzUUUMupGEeRpOqMd2YBwscN/eHilJMyXyhdNJ6?= =?us-ascii?Q?9JYKXkSZ8zXhoUrAHRXXgQSpeh67M1fCuikiEIHRYzX03U4EmSosLDRtrKbT?= =?us-ascii?Q?NtkVV3zukeizv7Ky5zJkNaDhVgrWuC6DZymeUhyTs5n15hiWD1408/cqlrnX?= =?us-ascii?Q?HZf5TFbU/dSq7ZtzlgU9CICMWtjj4XNQNdDq460X6M3MWpxavGA5ZC9Hb0+r?= =?us-ascii?Q?wLYmcqvaZJ+ojmuluCxn55jn2HREosAMzt1JTojjigPteKSUjdcn0lkqm5LO?= =?us-ascii?Q?e5HgkijifAABsQD9X7ubWEAF346JtAt8nn/Onk4xKiaOwJdcqUeovRlKpkhQ?= =?us-ascii?Q?w2uIT6V0C2ePuDiUPoNyBuFy59JL1KModQIjeLmlp+ladtiQOSPWWA55bYwy?= =?us-ascii?Q?4qFo2ARVLDK+BowkQWYfIBOlM94SBVFFQyxTUhjZG2pCJp9RnQil85g3sxyE?= =?us-ascii?Q?rPS3x4kWw/Id5PHkacLkCjiu4IEPFDfWYxbG7LcoDppQvoQmxJntopPOJ91D?= =?us-ascii?Q?65B++UbFtH1PNuk/TgmotkUpCw3Efs0R3qyUafuFBWySoPl7A110OG+3A8k4?= =?us-ascii?Q?YLQ6vXakd9CFtYLhvUM9pF36RJGTBvxRNbm/TQVh1wxrBIRv0U+CBsarRPLZ?= =?us-ascii?Q?yUKrEG7s52LfWwU0qb1ZtlcKdjONWglLypoZcfOQ4WKsoawVNMeFFY0qZsZp?= =?us-ascii?Q?H5Uo9tOKUv+KfXb3LqVX2GzEz/ihnYVSK+4rI9RxSKgiTxGgmzKqkedU9qY7?= =?us-ascii?Q?JqMO2fmeKN6IhN9TtyQTXuR3FdHJ3XSChnvLxcKHz04antJe7PZNIYcFzEwJ?= =?us-ascii?Q?IjNdRVWQYEimRB9wzWYCnB4YMkkl483K8onL4mUCEDXhbeTH1Aq2WNkCJsQn?= =?us-ascii?Q?69jaoW6a8y8nGMoz/XCpMF11JxyCO3XKSoIEdx70w2Ej03/FxbcNEJ8HdHBB?= =?us-ascii?Q?BK5ocx+6jzT+Ks3IaGLNrR1Dn07twb0wcMQgxlp1oHvcvoF5Yyz1K5wo4va1?= =?us-ascii?Q?3fuD6oBcKWyNIQsumbfaFAkuxvWvNlXkdY36zB12UzVRNnmdxBtJ6ehotWTT?= =?us-ascii?Q?XXrpYDFPPrQyeSHC1xkubx5JWlbY4Veyd0Buub6m9QvDr8deuv3/AGIHGf1X?= =?us-ascii?Q?5xbLoE9SuMFa4XQKAXg7gadomPg5ExaYwbQRKD1GXD4xKti1qA=3D=3D?= X-Forefront-Antispam-Report: CIP:216.228.117.160; CTRY:US; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:mail.nvidia.com; PTR:dc6edge1.nvidia.com; CAT:NONE; SFS:(13230031)(82310400017)(1800799015)(36860700004)(376005); DIR:OUT; SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 10 Jun 2024 08:51:28.8059 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: c7e4cd43-81e1-41ee-7198-08dc892a84c6 X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a; Ip=[216.228.117.160]; Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: CO1PEPF000044F6.namprd21.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: SN7PR12MB6981 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: Gregory Etelson HWS ASO actions validation required PMD to allocate resources during the port configuration, before the action validation was called. That approach does not work in the HWS non-template setup, because non-template setup does not have explicit port configuration procedure and port allocates ASO resources "on demand". The patch assumes that if port did not have ASO resources during action validation PMD was configured for the non-template and allocates missing resources. Signed-off-by: Gregory Etelson Acked-by: Dariusz Sosnowski --- drivers/net/mlx5/mlx5_flow_hw.c | 41 +++++++++++++++++++++------------ 1 file changed, 26 insertions(+), 15 deletions(-) diff --git a/drivers/net/mlx5/mlx5_flow_hw.c b/drivers/net/mlx5/mlx5_flow_hw.c index f464ee6f19a..2cb67180a60 100644 --- a/drivers/net/mlx5/mlx5_flow_hw.c +++ b/drivers/net/mlx5/mlx5_flow_hw.c @@ -222,6 +222,11 @@ mlx5_hw_ctx_validate(const struct rte_eth_dev *dev, struct rte_flow_error *error return true; } +static int +flow_hw_allocate_actions(struct rte_eth_dev *dev, + uint64_t action_flags, + struct rte_flow_error *error); + static __rte_always_inline int mlx5_multi_pattern_reformat_to_index(enum mlx5dr_action_type type) { @@ -12024,25 +12029,31 @@ flow_hw_action_handle_validate(struct rte_eth_dev *dev, uint32_t queue, RTE_SET_USED(user_data); switch (action->type) { case RTE_FLOW_ACTION_TYPE_AGE: - if (!priv->hws_age_req) - return rte_flow_error_set(error, EINVAL, - RTE_FLOW_ERROR_TYPE_ACTION, - NULL, - "aging pool not initialized"); + if (!priv->hws_age_req) { + if (flow_hw_allocate_actions(dev, MLX5_FLOW_ACTION_AGE, + error)) + return rte_flow_error_set + (error, EINVAL, RTE_FLOW_ERROR_TYPE_ACTION, + NULL, "aging pool not initialized"); + } break; case RTE_FLOW_ACTION_TYPE_COUNT: - if (!priv->hws_cpool) - return rte_flow_error_set(error, EINVAL, - RTE_FLOW_ERROR_TYPE_ACTION, - NULL, - "counters pool not initialized"); + if (!priv->hws_cpool) { + if (flow_hw_allocate_actions(dev, MLX5_FLOW_ACTION_COUNT, + error)) + return rte_flow_error_set + (error, EINVAL, RTE_FLOW_ERROR_TYPE_ACTION, + NULL, "counters pool not initialized"); + } break; case RTE_FLOW_ACTION_TYPE_CONNTRACK: - if (priv->hws_ctpool == NULL) - return rte_flow_error_set(error, EINVAL, - RTE_FLOW_ERROR_TYPE_ACTION, - NULL, - "CT pool not initialized"); + if (priv->hws_ctpool == NULL) { + if (flow_hw_allocate_actions(dev, MLX5_FLOW_ACTION_CT, + error)) + return rte_flow_error_set + (error, EINVAL, RTE_FLOW_ERROR_TYPE_ACTION, + NULL, "CT pool not initialized"); + } return mlx5_validate_action_ct(dev, action->conf, error); case RTE_FLOW_ACTION_TYPE_METER_MARK: return flow_hw_validate_action_meter_mark(dev, action, true, error); -- 2.21.0