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 4DF184387F; Wed, 10 Jan 2024 08:13:02 +0100 (CET) Received: from mails.dpdk.org (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id CADC040298; Wed, 10 Jan 2024 08:13:01 +0100 (CET) Received: from NAM11-BN8-obe.outbound.protection.outlook.com (mail-bn8nam11on2041.outbound.protection.outlook.com [40.107.236.41]) by mails.dpdk.org (Postfix) with ESMTP id 3693540269 for ; Wed, 10 Jan 2024 08:13:00 +0100 (CET) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=V82UV3c1mLy65FQKvoaD8K7qz6bPIHmIg93cJxEUdarReHNG6fssWVfnwqMSr2/OZwd1zx0oMS8AetEwCYM/xZuxGFpU5bd2Ow5xgca33iI5xSDcUBKMMdMj9kk6VOwUsLS6zlO9doEUKHIeTI3LOZEzysVCsX6wJd+K5yuxWHy1ABWUqgCf7470fsECcEEtGKFXNKkNNOPaAIliIoxIBIiNXatiBwg6dCTJpTJ/xULCXPEK/CKfCYbXtUltBIksWDKQNfYsc7kop+xC/dl/Qx0LXNWyfV5BxDriDzPKINzAuC2RAmCZtW5ss7IBOBCB5nC29S6F7MNzgNT6IhpYEw== 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=kXT1Z6Sq4GEC6BE1tFuspdjgw3BeGp9ZY37m0//qGKc=; b=FIDsCUMjEUftSyKbX/uwLBVKqFM/YbZu84KxLtELxTfjLqRJAgY6uFs8TMxOUU6GMdHP8i8+jFElUzghCEZoRVZA7g5XiDVFzQ09x77/gwlqCwpIgzHKWZi2NPvBmmXO2Ew6zDY9NR95jBtNBQ/SfYSBEcyPYfjgzAPUEOmEXLYkInBNUnklouEwoPJOj7U07kvwHmV9cAz+Zije97P4hhyTTnxtoIqGIYU2khrCRq96vZdysr29xDFehDqwiMn9+mPvhSbO0lRDdyLoWA0dxqV5FgxIXq1OI5HV2qkiAxWb685E0TIphi+WgjVZ7lTyHOVuE86Cw02n0eGFhPIcNw== 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=kXT1Z6Sq4GEC6BE1tFuspdjgw3BeGp9ZY37m0//qGKc=; b=QwwPZIGozshZD181TKFYy5M7wtB8V6H4DdhzsU++mudAq+9XZr3TWldpItB1m2KLiACTxBwlbffk30he+wB6tvxHgErdqsH4Gj5HMpwDRI2NGyq2iq0EIt7Bbanw50fLIbTBGqoFK60wzW+6Mpc8XA/9HU7AXVphXJ4Ar0qeRyYXcNUryPl7UnyajZDZAV2lZSx8N9vlOG5VQMAXTWOGVSbBrSkX8/od0kzE74SMdd/jAeXPgyOD16lMOsI6CxXlJibRycIr8/mwMkR+KaG6jyw0Qiw2brG0lwLQzpzEBNfzQexQoLIHRXsMt9bU3fU8/WPCl0u35gBPsNie+zbtGQ== Received: from DM5PR07CA0108.namprd07.prod.outlook.com (2603:10b6:4:ae::37) by PH7PR12MB6763.namprd12.prod.outlook.com (2603:10b6:510:1ad::8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7159.23; Wed, 10 Jan 2024 07:12:56 +0000 Received: from CY4PEPF0000EE3A.namprd03.prod.outlook.com (2603:10b6:4:ae:cafe::d1) by DM5PR07CA0108.outlook.office365.com (2603:10b6:4:ae::37) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7159.23 via Frontend Transport; Wed, 10 Jan 2024 07:12:56 +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 CY4PEPF0000EE3A.mail.protection.outlook.com (10.167.242.14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7181.14 via Frontend Transport; Wed, 10 Jan 2024 07:12:56 +0000 Received: from rnnvmail201.nvidia.com (10.129.68.8) 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.986.41; Tue, 9 Jan 2024 23:12:41 -0800 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.986.41; Tue, 9 Jan 2024 23:12:39 -0800 From: Gavin Li To: , , , , , CC: , Subject: [RFC 1/2] net/mlx5: discover IPv6 traffic class support in RDMA core Date: Wed, 10 Jan 2024 09:12:19 +0200 Message-ID: <20240110071220.1262271-2-gavinl@nvidia.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20240110071220.1262271-1-gavinl@nvidia.com> References: <20240110071220.1262271-1-gavinl@nvidia.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Originating-IP: [10.126.230.35] X-ClientProxiedBy: rnnvmail202.nvidia.com (10.129.68.7) To rnnvmail201.nvidia.com (10.129.68.8) X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CY4PEPF0000EE3A:EE_|PH7PR12MB6763:EE_ X-MS-Office365-Filtering-Correlation-Id: 2f328629-e137-45d7-9588-08dc11ab91fa X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: pFxahQhmWYS327yW98473QRupMHR9qFnD9EAZSE9J6IXcVXZYXJzno8NJt1Xif0W7Fwe/4p/oKvb7XEheHDO7elUazNxCT1t8lQiH82ykDwsrOZVXgbZqqwW/C43ZUA+FtikPKWW9Z865QJCvUsYPknhXE3sVaPUSnQlqy4PiWAsYAaj2esc3wudx0hDyC5P47pHbWRFbZhlSwgIu0m0TJ4sOTNhAYG/83FAime8tnr51NhROd8BpTh9srxZRAlxQ0isK2oIh0P2U6OjWJ2XYd4i5KQVrwhztfqkkvPYpZOp7QO8SnBvlhVCAjglYLr7potkKh+uv9VCSPaNfUOssOdyioJcFhXGTrsRptRsBckeVuSn0PQZNOQJa5DoZPys9vZsIswdEFpS7OztcU6wuBMB+jMM7m2ceADTSMd++7YCgBqkUcx6+zd769FXKnE2lTd05w1qVoAtDhKdFL6xTSqaoKG2SArOJFHekQHePSiZVu+rgp9UR4jU6EG6RpEtwOQfk61rxFs+YLz/I+iwtfjJRCl58eQUaH+d7/LVpUIV6add2E2GOicGssW6yPIacpkwYBSVQ9SqJ4NOJdrLPaXh5QUfTwSSNmlMb2Zsm8X3kRADyvCN9E8hesjc4jo7bqYZblrVdmBtTMYn7OdXq4fwZGG0xzPZc8Enz0Lb0WWsV4QGJNTPK9UEaiqCZl+wWuixFh2oo7Wykeqxud6FxYFG3Bg4TgtUhz5pcNWkMjAGhZtj7W5QY31yEGBKwYbrnK7YBJlR4KqnZZ4wPueclQ== 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)(4636009)(376002)(346002)(136003)(396003)(39860400002)(230922051799003)(186009)(82310400011)(64100799003)(451199024)(1800799012)(46966006)(36840700001)(40470700004)(2616005)(316002)(478600001)(70206006)(7696005)(54906003)(55016003)(110136005)(6666004)(4326008)(6636002)(40460700003)(26005)(83380400001)(1076003)(107886003)(40480700001)(8936002)(8676002)(6286002)(16526019)(336012)(70586007)(426003)(5660300002)(2906002)(47076005)(7636003)(36860700001)(356005)(82740400003)(41300700001)(36756003)(86362001)(2101003); DIR:OUT; SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 10 Jan 2024 07:12:56.4559 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 2f328629-e137-45d7-9588-08dc11ab91fa 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: CY4PEPF0000EE3A.namprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH7PR12MB6763 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 Previously, IPv6 traffic class used the same ids of IPv4 DSCP and ECN by rdam core and firmware. New FW support new IPv6 traffic class id which is recommended to be used though the old way is still working. FW exposed a new cap bit to indicate the supporting of the new id while RDMA core does not have such mechanism. To fix the backward compatibility issue of combination of RDMA core and FW of different versions, a new function and a new flag were introduced to check if the new IPv6 traffic class id is supported by RDMA core. Signed-off-by: Gavin Li --- drivers/net/mlx5/linux/mlx5_os.c | 4 +++ drivers/net/mlx5/mlx5.h | 1 + drivers/net/mlx5/mlx5_flow.c | 42 ++++++++++++++++++++++++++++++++ drivers/net/mlx5/mlx5_flow.h | 1 + 4 files changed, 48 insertions(+) diff --git a/drivers/net/mlx5/linux/mlx5_os.c b/drivers/net/mlx5/linux/mlx5_os.c index ae82e1e5d8..5ae31c88f4 100644 --- a/drivers/net/mlx5/linux/mlx5_os.c +++ b/drivers/net/mlx5/linux/mlx5_os.c @@ -1602,6 +1602,10 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, goto error; } rte_rwlock_init(&priv->ind_tbls_lock); + if (sh->config.dv_flow_en == 1 && + !priv->sh->ipv6_tc_fallback && + mlx5_flow_discover_ipv6_tc_support(eth_dev)) + priv->sh->ipv6_tc_fallback = 1; if (priv->sh->config.dv_flow_en == 2) { #ifdef HAVE_MLX5_HWS_SUPPORT if (priv->sh->config.dv_esw_en) { diff --git a/drivers/net/mlx5/mlx5.h b/drivers/net/mlx5/mlx5.h index 263ebead7f..779805bcd8 100644 --- a/drivers/net/mlx5/mlx5.h +++ b/drivers/net/mlx5/mlx5.h @@ -1444,6 +1444,7 @@ struct mlx5_dev_ctx_shared { uint32_t lag_rx_port_affinity_en:1; /* lag_rx_port_affinity is supported. */ uint32_t hws_max_log_bulk_sz:5; + uint32_t ipv6_tc_fallback:1; /* Log of minimal HWS counters created hard coded. */ uint32_t hws_max_nb_counters; /* Maximal number for HWS counters. */ uint32_t max_port; /* Maximal IB device port index. */ diff --git a/drivers/net/mlx5/mlx5_flow.c b/drivers/net/mlx5/mlx5_flow.c index 85e8c77c81..90b72b7b0a 100644 --- a/drivers/net/mlx5/mlx5_flow.c +++ b/drivers/net/mlx5/mlx5_flow.c @@ -12476,3 +12476,45 @@ mlx5_flow_pick_transfer_proxy(struct rte_eth_dev *dev, RTE_FLOW_ERROR_TYPE_UNSPECIFIED, NULL, "unable to find a proxy port"); } + +/** + * Discover ipv6 traffic class id support in rdma core and firmware. + * + * @param dev + * Ethernet device. + * + * @return + * 0, rdma core is good to work with firmware. + * -EOPNOTSUPP, rdma core could not work with new ipv6 tc id. + */ +int +mlx5_flow_discover_ipv6_tc_support(struct rte_eth_dev *dev) +{ + struct rte_flow_action_set_dscp set_dscp; + struct rte_flow_attr attr; + struct rte_flow_action actions[2]; + struct rte_flow_item items[3]; + struct rte_flow_error error; + uint32_t flow_idx; + + memset(&attr, 0, sizeof(attr)); + memset(actions, 0, sizeof(actions)); + memset(items, 0, sizeof(items)); + attr.group = 1; + attr.egress = 1; + items[0].type = RTE_FLOW_ITEM_TYPE_ETH; + items[1].type = RTE_FLOW_ITEM_TYPE_IPV6; + items[2].type = RTE_FLOW_ITEM_TYPE_END; + /* Random value */ + set_dscp.dscp = 9; + actions[0].type = RTE_FLOW_ACTION_TYPE_SET_IPV6_DSCP; + actions[0].conf = &set_dscp; + actions[1].type = RTE_FLOW_ACTION_TYPE_END; + + flow_idx = flow_list_create(dev, MLX5_FLOW_TYPE_GEN, &attr, items, actions, true, &error); + if (!flow_idx) + return -EOPNOTSUPP; + + flow_list_destroy(dev, MLX5_FLOW_TYPE_GEN, flow_idx); + return 0; +} diff --git a/drivers/net/mlx5/mlx5_flow.h b/drivers/net/mlx5/mlx5_flow.h index 120609c595..33d4a28077 100644 --- a/drivers/net/mlx5/mlx5_flow.h +++ b/drivers/net/mlx5/mlx5_flow.h @@ -2638,6 +2638,7 @@ void mlx5_flow_destroy_sub_policy_with_rxq(struct rte_eth_dev *dev, struct mlx5_flow_meter_policy *mtr_policy); int mlx5_flow_dv_discover_counter_offset_support(struct rte_eth_dev *dev); int mlx5_flow_discover_dr_action_support(struct rte_eth_dev *dev); +int mlx5_flow_discover_ipv6_tc_support(struct rte_eth_dev *dev); int mlx5_action_handle_attach(struct rte_eth_dev *dev); int mlx5_action_handle_detach(struct rte_eth_dev *dev); int mlx5_action_handle_flush(struct rte_eth_dev *dev); -- 2.39.1