From patchwork Thu May 30 07:24:11 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Suanming Mou X-Patchwork-Id: 962 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 8C01A4410C; Thu, 30 May 2024 09:24:46 +0200 (CEST) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 6C3F940608; Thu, 30 May 2024 09:24:46 +0200 (CEST) Received: from NAM04-BN8-obe.outbound.protection.outlook.com (mail-bn8nam04on2063.outbound.protection.outlook.com [40.107.100.63]) by mails.dpdk.org (Postfix) with ESMTP id 407BA40041 for ; Thu, 30 May 2024 09:24:44 +0200 (CEST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=hZQqc36RcqJkFD/LnjLLG3wIx5eH0T5dGmrHDhnMqrVW4bYPnqpZ5cfyTvn4nQevFZSkzyxDkaW3YLXm2VK899ZH88upLU38/+nlj4XSt+cUTV2x56vMKPkOjto7P9wT7oZz6ctQB4L9yK+q0EGD5JBWxATc07Gj+6QWePz7mEqE6ylp6Z613w5KnIyFB2WJiegfFAZTVQz+epkIGnzX7N7/SWBDRSy2EYta4vMeYvc6py9tB7H0lHyANZca2zLNzOn3+rsg6imI7cxYlsGRsvqGfYAIdO//Lz8i7i1lOWjcD8+waaj3hIBICp000UvuB5+uQoCRS5iCDyHk3Xc2Tg== 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=b+QNkmteJMtxcq2sgjBGkGoOVQfuA4p6XjdUaj6qqlQ=; b=OwU+xGXOIpyEWPPIkGEILK0YnacZzX6Bu2QotaSp5UoXh8oaSD5LQLrXn/mLlMCDqQ4vRHZo74NZcJAdROnrP1ZCo1KwTmmNcajiX2xzDrmTV3m14nRYsu4z4Vs69KhMCVNhZUmj0S5CX2b6IrDGBHVTE3SlABQBrIvwSN4UbYTtxydbCqpJXIe0T0ANFMmNy/zi+fJowBBsliXnBpNWeDveB3iDb7lShMk2BCN3IYNmqh1HB3mQoxcwXHemFamp+rVs4xvmbcUPwkseh7AExVkCESwi96ViQ8D0Su2JQz9M832xJSkTzBOeKSYYXPL2k8EC1LD5q7Y8MaOjeqiGWA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.117.161) 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=b+QNkmteJMtxcq2sgjBGkGoOVQfuA4p6XjdUaj6qqlQ=; b=qXdiwX2o7Rix0KQJ4Pw6LL4visKKRacsWcr2aiuzrDUNDgzmW9p564LK4WLzBdmmc6bWvqv9cEUwmzsc2RPVfzKpBO8J2bC1jalar2Dbqm8TSh/HcblQCJw1YyFGxhf9Q6589h5LlBp6+QNJHk6683ObJEsbBVqy913KaBzrjMERie2vn518ctxouM1Y+6F+N/7Yu+m8eReKJzXs0buqxpLa3X/LjA5rt0ztdan/3sq4JC6c5vwL4ZtwS7tRPNyxwIMljThtDsHPgFU9CM3aeAAuq45nVQnnEXG9mAl7aLqgf5iPHA8JECxanGOLcuKwx22QLknJ4U9QA7WF3E3jYQ== Received: from SA1PR02CA0001.namprd02.prod.outlook.com (2603:10b6:806:2cf::7) by BY5PR12MB4115.namprd12.prod.outlook.com (2603:10b6:a03:20f::20) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7633.21; Thu, 30 May 2024 07:24:40 +0000 Received: from SN1PEPF00026367.namprd02.prod.outlook.com (2603:10b6:806:2cf:cafe::1c) by SA1PR02CA0001.outlook.office365.com (2603:10b6:806:2cf::7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7633.21 via Frontend Transport; Thu, 30 May 2024 07:24:39 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 216.228.117.161) 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.161 as permitted sender) receiver=protection.outlook.com; client-ip=216.228.117.161; helo=mail.nvidia.com; pr=C Received: from mail.nvidia.com (216.228.117.161) by SN1PEPF00026367.mail.protection.outlook.com (10.167.241.132) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7633.15 via Frontend Transport; Thu, 30 May 2024 07:24:39 +0000 Received: from rnnvmail201.nvidia.com (10.129.68.8) by mail.nvidia.com (10.129.200.67) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.4; Thu, 30 May 2024 00:24:28 -0700 Received: from nvidia.com (10.126.230.35) by rnnvmail201.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; Thu, 30 May 2024 00:24:27 -0700 From: Suanming Mou To: CC: Subject: [PATCH 0/2] crypto/mlx5: optimize AES-GCM IPsec operation Date: Thu, 30 May 2024 15:24:11 +0800 Message-ID: <20240530072413.1602343-1-suanmingm@nvidia.com> X-Mailer: git-send-email 2.34.1 MIME-Version: 1.0 X-Originating-IP: [10.126.230.35] X-ClientProxiedBy: rnnvmail203.nvidia.com (10.129.68.9) To rnnvmail201.nvidia.com (10.129.68.8) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: SN1PEPF00026367:EE_|BY5PR12MB4115:EE_ X-MS-Office365-Filtering-Correlation-Id: db7780a7-7245-4a15-58a6-08dc80799151 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; ARA:13230031|82310400017|36860700004|376005|1800799015; X-Microsoft-Antispam-Message-Info: i7QCrhasExYmLXGoz7VjzpTSrrUobtqhkSmI3xv4ZIS9S7uXRb9tqEg4QGR30X38+lQGt1LJ7vXdNuYkDc9pYO1t9p9arfCHvIjJ7Hq00WSqTmVyCVq0NoDkhJxysHGtJep9IDC4EVHWs2HTA6HaSiBm9vWAwd9L6B8FLvFcAAQDtAVpXe+7kOtxBBRFrLb0UkazgfO8QTFsYnv6SEt4XLFSQ7hAnYSkyKr3K6cDY2VF5w0zeipO0rQUu/lfmRMM47HcJdp5lpmxmmNYQ2u37QIIGsl8bPmMtxDMZp9+lsKnNk90AgT57HTMkju5nm6tDuZ3Asb3S4Lj0ST1UemasAWLvlKU/GOD9vBEMBnCiC4/PjxDTUECXmVybJDYuNi8XNA7nwEMCN/ri4XRPsuRiSeZgCuCsJDf/63mDioSEvkmLf/L8mHACRc9/QZSNnB8XMTKsWZ6xPS18bR/G1+FZjFPSHmAZm861eJim98/jQ3VyOFD5PrqOeN7DE/UTaRzMR9lvn8jAO01Dpl54AJ6/6jvY295MmDuIkHWZq5pY/Njg5W6lHh3YnJxOVW5dB3WVjwDiZp7oWBk2VPjudEbkz6UVgBw7DgziNMnsrGQ1jW+FfU83qna6FcwRTgvVFf098Eyao6RSl42gkYfBcwqPzSsdAeqweqCbjM19bWKdnQW+PoJT1S1bVDTVNwhpzSC2WslKJeKlIkPSkKGcGbCu15Om0RHC7y8FVktihfGhdC38cutZfFZKS29OGOH8yMn7LWv1oZRoCO4gpM4mGUx+EYjuabGAwGj+hO4VrY+eKwlVBBTW6vHhLJiq0g9C47QHzjZ735zCwtXRdiGRUS7PKdtCYjp5NtzbMWABvDzvZKW73PGeEqxoa6m7X886WgFFVeLJS6MAVpZgv5ikO4jb0lVNZPYGh6Osf7h6MbHIzXzEYsAHdNTJcmNiEfM2Yk8RhJmCmM77up1uPg6s1c1loyBZVP0/vT6+8Dehjbt5aSViJW5ei79wYh1VW27X0dLUq39O7M80HL/pSNgQau7ZN2L1LjcSIOEPcHpOhhtZLE4gbtEFObs2gsXSt/xkTS86TSxjkXMf470/Gr/N0OUDmnknBOwch3GY+YhkFn1EylxsNT95ZPFsJsXTBaDuZQMVtptqSGrZkZABB8m4B7QFqcGMovucDYTUtyKERNge2t/ByBrfC/G45wKdn38UiVJjjGnLNw9fpOKC0x1h8nRRGKfCcFBMO4kCsZOVIaRWuyQKLNm3G8pPdwkloAKXyZH2RiUnM/4neeLVRBOBIGNIaCGYhgOzuFmyoWXqwyGO0zf5fB6JkJawsREyTYon2r8gIvx6Qa/2z41gSDrm89EdRzR6t5rbcu5jDjdDLw5G9/Pz66hh5sfgL8k17WBDG+H X-Forefront-Antispam-Report: CIP:216.228.117.161; CTRY:US; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:mail.nvidia.com; PTR:dc6edge2.nvidia.com; CAT:NONE; SFS:(13230031)(82310400017)(36860700004)(376005)(1800799015); DIR:OUT; SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 30 May 2024 07:24:39.5630 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: db7780a7-7245-4a15-58a6-08dc80799151 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.161]; Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: SN1PEPF00026367.namprd02.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY5PR12MB4115 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 To optimize AES-GCM IPsec operation within crypto/mlx5, the DPDK API typically supplies AES_GCM AAD/Payload/Digest in separate locations, potentially disrupting their contiguous layout. In cases where the memory layout fails to meet hardware (HW) requirements, an UMR WQE is initiated ahead of the GCM's GGA WQE to establish a continuous AAD/Payload/Digest virtual memory space for the HW MMU. For IPsec scenarios, where the memory layout consistently adheres to the fixed order of AAD/IV/Payload/Digest, directly shrinking memory for AAD proves more efficient than preparing a UMR WQE. To address this, a new devarg "crypto_mode" with mode "ipsec_opt" is introduced in the commit, offering an optimization hint specifically for IPsec cases. When enabled, the PMD copies AAD directly before Payload in the enqueue_burst function instead of employing the UMR WQE. Subsequently, in the dequeue_burst function, the overridden IV before Payload is restored from the GGA WQE. It's crucial for users to avoid utilizing the input mbuf data during processing. Suanming Mou (2): crypto/mlx5: optimize AES-GCM IPsec operation crypto/mlx5: add out of place mode for IPsec operation doc/guides/cryptodevs/mlx5.rst | 23 +++ doc/guides/rel_notes/release_24_07.rst | 4 + drivers/crypto/mlx5/mlx5_crypto.c | 22 ++- drivers/crypto/mlx5/mlx5_crypto.h | 19 ++ drivers/crypto/mlx5/mlx5_crypto_gcm.c | 245 +++++++++++++++++++++++-- 5 files changed, 292 insertions(+), 21 deletions(-)