From patchwork Wed Dec 21 07:39:13 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Rongwei Liu X-Patchwork-Id: 121163 X-Patchwork-Delegate: andrew.rybchenko@oktetlabs.ru 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 E79CDA034C; Wed, 21 Dec 2022 08:40:05 +0100 (CET) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id C78E642D23; Wed, 21 Dec 2022 08:39:56 +0100 (CET) Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10on2073.outbound.protection.outlook.com [40.107.93.73]) by mails.dpdk.org (Postfix) with ESMTP id 2798D42D14 for ; Wed, 21 Dec 2022 08:39:55 +0100 (CET) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=ih3c0/3GUL9tqH2M+JKs2PCCPciefMCvQY09zR6rv2MG/0tTAwmOTEbKQgZ7RQYz3OE+0wgHOWMgLCJDWS6rVmOJfPLO1nN9S4ob9xX4lsYdUjZufFVnZNVMNpYIgFNzO1ScdBber1P6mCv4bo9ozCYdv50lQ8g55eXk0+rN2aNZANJgoVsqEgXuc+ZLuLnhTrg7V9P0+8bCKEM1QseQEuRcUBUm1oG5vPJj8feliw+JXuuv+xBllOOps8KWAFeB1XAXLkibmb4TrDp4rSsKw+2BCXSgGeK7beHqoDc/F8lcfljYEq+IRlErXOCnJl4R2Tf6+aldEXygCB+nm20bsw== 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=Ih9uIuZxSERXupOXCm2N7QvTLt0WhKESiwpU858wFko=; b=DLIehHHMvLo7lVhvARRoIycDd0A3DrgDvn+Yj5gjDW+PlQ/crAZHX9jctnlBmHM2j84gRTo+KMA2QDxTQiF8wXgWkYKXjgC0ff8vkL33P4mf/9egZVOv/fYosbYH0Cfs91efwo5BlqYhqY6dWN6EFBlHKt5ZOExIWZJtiIyQbWyUUtrLH53yTbs/F94eqh8/c1Xsvlj/6bp+n0iry18F+i33bGVF7nPg6hOvD/YjR7QTXbmx9Wj7hRCpTCZTeB3lBnk5lgPm5ZsE1euhyrgGtcM4kRjYBw4qIej/joNYKd3Yhf57y6VZfkbDykhKbVrd1wD7389i1BH4Tk7dYQhYyw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 216.228.117.161) smtp.rcpttodomain=monjalon.net 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 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=Ih9uIuZxSERXupOXCm2N7QvTLt0WhKESiwpU858wFko=; b=K2Xv79dL2SnraCOK2hu0NtZkBma3Cf452nZ2bafIbAEk4YUBzjAl8YzowRcatPT1ANOf+vwpI44OwaWn158Tl9q5JhdYxY3ks4uu2dfDfdHzCd6ZCyxD7BRXsXglaA5BYMSse8D6csPuHj4uL8Ppn+d6901pxccRdNqxI5QMn3TEaVoADGKn+83F7YAYlMLilvqrbPvE4d4nxdo9VFuU+2EitlHP3omREx4ocqTJIORuZBRIxSRER2FeL/wgj1TojLGzmXBxp1oTFq0MyYD8Y6iJheVikvXatmXkB8SfXt2BxaB6RbycS5bubkqTbHcqDesa9Q/G5TB4WIl8yMbFKg== Received: from DM6PR08CA0052.namprd08.prod.outlook.com (2603:10b6:5:1e0::26) by BL1PR12MB5923.namprd12.prod.outlook.com (2603:10b6:208:39a::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5924.16; Wed, 21 Dec 2022 07:39:53 +0000 Received: from DM6NAM11FT029.eop-nam11.prod.protection.outlook.com (2603:10b6:5:1e0:cafe::a1) by DM6PR08CA0052.outlook.office365.com (2603:10b6:5:1e0::26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5924.21 via Frontend Transport; Wed, 21 Dec 2022 07:39:53 +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 DM6NAM11FT029.mail.protection.outlook.com (10.13.173.23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5944.6 via Frontend Transport; Wed, 21 Dec 2022 07:39:52 +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.986.36; Tue, 20 Dec 2022 23:39:45 -0800 Received: from nvidia.com (10.126.231.37) 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.986.36; Tue, 20 Dec 2022 23:39:43 -0800 From: Rongwei Liu To: , , , CC: , Subject: [RFC 4/9] net/mlx5: enable hws flex item create Date: Wed, 21 Dec 2022 09:39:13 +0200 Message-ID: <20221221073918.3581151-5-rongweil@nvidia.com> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20221221073918.3581151-1-rongweil@nvidia.com> References: <20221221073918.3581151-1-rongweil@nvidia.com> MIME-Version: 1.0 X-Originating-IP: [10.126.231.37] X-ClientProxiedBy: rnnvmail201.nvidia.com (10.129.68.8) To rnnvmail201.nvidia.com (10.129.68.8) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: DM6NAM11FT029:EE_|BL1PR12MB5923:EE_ X-MS-Office365-Filtering-Correlation-Id: df9ebbb9-bdd5-41a1-7fb7-08dae3268c78 X-LD-Processed: 43083d15-7273-40c1-b7db-39efd9ccc17a,ExtAddr X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: FLMRHLYNkLWw4GMKV1jVodtcMP+tfFvbhlkvkDQf4UGmElvooMqnE8uGSLMZ0rNPVrF8H3PVXhBQVhIiFCvu6Wg2hmVSW3dp/GkZclrJVos3wiQOOejdngnzlKTC1yK9g1/rlFlhtVhXG8UlaJaFFbXKsHPnVqWK6Ew/OCOHFsYBxKFcOroh1jqoV1nbHyaZK7Jgdqlz7E8qgCn83lJqvARnfPB/OTQ0GPlPKIFikdVpvWVKQuKR11zq3wcl54gK1vEtcYwOF6wsUB6ZYWNLJOZR28mHUxDEUxGq/bf1UPKqlUkjaro8PbFuq23hbId3bTstGKFy2NfBE32+S7W4JzOI9VOQtqC6mcDp0ZSeP7uJFCGuyT4noLZCDRd4bkIGM23MYhYWHwupUBFQp21Z61wzJAhnJiOL/AMWdeVgAIhvYeou55Hpuy5r2qMZ6SK23oHQas+sZ4VtiLYZ6MnzHn8z3IY0WUuoqrPuAazJ7DfSNE73egYMoZ3A6qxYyVfbS+8s7zvCAZqkYgnfwLfbXXS0MtOZlpPD07MOKlhGxPHcuOIF8vR+ZaamwZRG89EhgeMYdWifSYq1psOjs3OZOCJN83ZBGS+JV55DmGivBHlRusUzcJk4vpfEsV9pno3LKPcuBk/NznCG7MYKtyFyWoHm4Egt76y5ZS00mK1DL9UQih+2YXI1IlI9ffuZzunT/+EQBjZQBchwyifH53mpIg== 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:(13230022)(4636009)(136003)(376002)(39860400002)(346002)(396003)(451199015)(46966006)(40470700004)(36840700001)(36860700001)(54906003)(110136005)(4326008)(336012)(41300700001)(47076005)(426003)(40460700003)(55016003)(86362001)(8936002)(36756003)(83380400001)(5660300002)(316002)(40480700001)(8676002)(2616005)(2906002)(70206006)(16526019)(1076003)(70586007)(82310400005)(6666004)(107886003)(26005)(82740400003)(6286002)(478600001)(7636003)(356005)(7696005)(186003); DIR:OUT; SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 21 Dec 2022 07:39:52.9753 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: df9ebbb9-bdd5-41a1-7fb7-08dae3268c78 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: DM6NAM11FT029.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BL1PR12MB5923 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 Enable flex item create and destroy with dv_flow_en=2 Signed-off-by: Rongwei Liu --- drivers/net/mlx5/linux/mlx5_os.c | 27 +++++++++++++++------------ drivers/net/mlx5/mlx5_flow_hw.c | 2 ++ 2 files changed, 17 insertions(+), 12 deletions(-) diff --git a/drivers/net/mlx5/linux/mlx5_os.c b/drivers/net/mlx5/linux/mlx5_os.c index d48b9b68ac..3022c0ea1c 100644 --- a/drivers/net/mlx5/linux/mlx5_os.c +++ b/drivers/net/mlx5/linux/mlx5_os.c @@ -486,10 +486,20 @@ mlx5_alloc_shared_dr(struct mlx5_priv *priv) err = mlx5_alloc_table_hash_list(priv); if (err) goto error; - if (priv->sh->config.dv_flow_en == 2) - return 0; /* The resources below are only valid with DV support. */ #ifdef HAVE_IBV_FLOW_DV_SUPPORT + /* Init shared flex parsers list, no need lcore_share */ + snprintf(s, sizeof(s), "%s_flex_parsers_list", sh->ibdev_name); + sh->flex_parsers_dv = mlx5_list_create(s, sh, false, + mlx5_flex_parser_create_cb, + mlx5_flex_parser_match_cb, + mlx5_flex_parser_remove_cb, + mlx5_flex_parser_clone_cb, + mlx5_flex_parser_clone_free_cb); + if (!sh->flex_parsers_dv) + goto error; + if (priv->sh->config.dv_flow_en == 2) + return 0; /* Init port id action list. */ snprintf(s, sizeof(s), "%s_port_id_action_list", sh->ibdev_name); sh->port_id_action_list = mlx5_list_create(s, sh, true, @@ -530,16 +540,9 @@ mlx5_alloc_shared_dr(struct mlx5_priv *priv) flow_dv_dest_array_clone_free_cb); if (!sh->dest_array_list) goto error; - /* Init shared flex parsers list, no need lcore_share */ - snprintf(s, sizeof(s), "%s_flex_parsers_list", sh->ibdev_name); - sh->flex_parsers_dv = mlx5_list_create(s, sh, false, - mlx5_flex_parser_create_cb, - mlx5_flex_parser_match_cb, - mlx5_flex_parser_remove_cb, - mlx5_flex_parser_clone_cb, - mlx5_flex_parser_clone_free_cb); - if (!sh->flex_parsers_dv) - goto error; +#else + if (priv->sh->config.dv_flow_en == 2) + return 0; #endif #ifdef HAVE_MLX5DV_DR void *domain; diff --git a/drivers/net/mlx5/mlx5_flow_hw.c b/drivers/net/mlx5/mlx5_flow_hw.c index 0705002d99..b9c7459646 100644 --- a/drivers/net/mlx5/mlx5_flow_hw.c +++ b/drivers/net/mlx5/mlx5_flow_hw.c @@ -8824,6 +8824,8 @@ const struct mlx5_flow_driver_ops mlx5_flow_hw_drv_ops = { .query = flow_hw_query, .get_aged_flows = flow_hw_get_aged_flows, .get_q_aged_flows = flow_hw_get_q_aged_flows, + .item_create = flow_dv_item_create, + .item_release = flow_dv_item_release, }; /**