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 2F521A00C4; Mon, 14 Feb 2022 10:37:00 +0100 (CET) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id A2ADC41161; Mon, 14 Feb 2022 10:35:58 +0100 (CET) Received: from NAM10-DM6-obe.outbound.protection.outlook.com (mail-dm6nam10on2088.outbound.protection.outlook.com [40.107.93.88]) by mails.dpdk.org (Postfix) with ESMTP id 72B0D41155 for ; Mon, 14 Feb 2022 10:35:57 +0100 (CET) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=N5mkWXdWbSdCO1tQ7e8CKkINyR99+rQu2zTuciW16+dmQWeq8qA8HQ5DvgyyIdRFNcPnPFpCGr8o8cg0VE4KqLu5DzDR03zyqun5d8gYZaUCLyrRQNQXyJYvDO+jVWDw7PLHIXfXHlJN+KPBM9lRFTGUWhHIHm1iBmnpkJ4rlWF3+K6MTuAnsGo7+GAfD1q47XL8N/NNPPj2ZrTJAlSxf3h6i7jyaCJwl35I16AHJ5VJnDuWkbB0BgyRYZxI0uSh7HTHE6KLaivuNkdQhii5ogh8g1m998TKi6qj6YEzpeHtDzlAwuABNEEYO0shIHv0zBo01JMuMqCaFET6S6dk5w== 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=9YEugeiqlqd8Ke1IFz2NEL7bLHojPuhnpEqzh7cxiJw=; b=E/DMaznPBuz6XPN39aI0uIIvYLhU076726IwFIDoQCVTMlmH/2tRo4iXSlnMF0wpKUydoZc6dGX6SzBbfpa2weGwnxbrhR1GqjdW0XlE410Fn/9BeWgJaImJGUVKUUqurXxlSCf09gDCadMb9tumcC/DjOdR+J30AB2vnHKE9iMOPeKq1W0r0vqSYpJQ5h46cWDq94on9dsoZZkqikjhxSrdNIeiU0L4lZprI7kDti8gphTckF/NR1ahQs3EXHxNoxsGzpcjQJvtt+IIS7+N8/JEJIj0tVcMjQUxmWiTGQEWOHaVokfz5DOiKEbMvEOVNZZ5ZXpHRiU36UaJDojEdw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 12.22.5.234) 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 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=9YEugeiqlqd8Ke1IFz2NEL7bLHojPuhnpEqzh7cxiJw=; b=spDs2MvGB/Tx0zRdpADsBIO9ibSvQcC6sLRW/KYVEwWBv7x+WsNCR1KanGNMz/b+1Rx5gI17+U9W8n3RBYAnSCtX9ctqU0e2Om/wuo4PcMi30ldVE4MvmM2FV26VRaOWoursmmtwblGUIKI77oqdsbmhPaAV8cKVCPG68LW+AxvhX/hUj20qmuD4H1RoY6fzgEV3Se7vVdC4kC5/1u6HUqTaH0m2+tyxE1Yvup/VcxKXqWmm9HRFTPteh/JwOWtCkcpDCH7/F8KtOV+uNSBjSgcziOYDT9gF+DjJoXU1NPXFDDYQKOTwGX5dQE65jO/cpHFX+1qgdF3LOoJIx17Wwg== Received: from MWHPR11CA0013.namprd11.prod.outlook.com (2603:10b6:301:1::23) by BY5PR12MB3841.namprd12.prod.outlook.com (2603:10b6:a03:194::27) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4975.14; Mon, 14 Feb 2022 09:35:53 +0000 Received: from CO1NAM11FT058.eop-nam11.prod.protection.outlook.com (2603:10b6:301:1:cafe::b5) by MWHPR11CA0013.outlook.office365.com (2603:10b6:301:1::23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4975.13 via Frontend Transport; Mon, 14 Feb 2022 09:35:53 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 12.22.5.234) 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 12.22.5.234 as permitted sender) receiver=protection.outlook.com; client-ip=12.22.5.234; helo=mail.nvidia.com; Received: from mail.nvidia.com (12.22.5.234) by CO1NAM11FT058.mail.protection.outlook.com (10.13.174.164) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384) id 15.20.4975.11 via Frontend Transport; Mon, 14 Feb 2022 09:35:53 +0000 Received: from rnnvmail203.nvidia.com (10.129.68.9) by DRHQMAIL101.nvidia.com (10.27.9.10) with Microsoft SMTP Server (TLS) id 15.0.1497.18; Mon, 14 Feb 2022 09:35:52 +0000 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.986.9; Mon, 14 Feb 2022 01:35:51 -0800 Received: from nvidia.com (10.127.8.13) 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.986.9 via Frontend Transport; Mon, 14 Feb 2022 01:35:49 -0800 From: Michael Baum To: CC: Matan Azrad , Raslan Darawsheh , Viacheslav Ovsiienko Subject: [PATCH v2 14/20] net/mlx5: rearrange device attribute structure Date: Mon, 14 Feb 2022 11:35:05 +0200 Message-ID: <20220214093511.1592698-15-michaelba@nvidia.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220214093511.1592698-1-michaelba@nvidia.com> References: <20220127153950.812953-1-michaelba@nvidia.com> <20220214093511.1592698-1-michaelba@nvidia.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 68231387-7297-4c1b-0bcd-08d9ef9d652a X-MS-TrafficTypeDiagnostic: BY5PR12MB3841:EE_ X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:82; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: aS2KtnilFiuMjfao+zB6iaqPz4VQNhtraKmlMNxnln0CckG/Jz2Nte4HnoIXvflS0f5Nrtv3hwBxCLvZKxfNJFSyCBAWMv4Z0NnUWjK7nOA1B7JbB26ILK9vi7Swgopmli+Rvy3BuPy7DeOoCTlFrF8bfaFhsj8SwvXzX5dfhTJm1OtNI168W+L43ezUYC9/Zacg4Qe1X3JxhDz+Xeb12BjjSMiCdi1nSkz+4dMl/tsGYkF/V63ZUiHA3kdBnd4dIl5ELRXrGH1tSZLwhulL0nOft3m2HfmHJtK+ZbB97eCyX6+WVoqm0y0W1zzu23iC4xwpNVYvDpbsiAM+jP2Ubmwy7qqn0P/mORb3yVnoSvLUe4ho0scp1tXfoIlf/SvfJSjIhIjbV/wv07+S8rxnUSW3kOhPIj1NhrnNOl0NZkFgpMrjQ33JaJhk5g2r7ceyIwh9lTQabYjoHujrKaVC2wnbSxRUN7xMgvOEokj1dNJ6kuk5ARecEa/RtlFungLgERUHkzsIsFlZy25dCg0foqcy6sBkFgfpqDsa5KljPiaJ/7+UekYYIEQaxQZ/0FQhIdz4jApQneqGvQWwRHT8gJtWgTKdGrtP0BaFSpxuex4+IFZWW+oxEHtv0s6xC3nL2e1CRVqrBJ1OFdJEDWvzt6gRtyiU0JwDZu15Y7b+e0nBctx6jCx7mAroW3P0To12ZWiZqKfAKpErXvjcPSiSy0reZmydqOQkKNbY3hvmhzica7x+l5Fr8PP1aZEWMgl8 X-Forefront-Antispam-Report: CIP:12.22.5.234; CTRY:US; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:mail.nvidia.com; PTR:InfoNoRecords; CAT:NONE; SFS:(13230001)(4636009)(46966006)(36840700001)(40470700004)(356005)(81166007)(2616005)(1076003)(6286002)(83380400001)(47076005)(36860700001)(186003)(26005)(107886003)(336012)(426003)(508600001)(40460700003)(82310400004)(6666004)(316002)(6916009)(70586007)(70206006)(54906003)(5660300002)(30864003)(55016003)(86362001)(8936002)(36756003)(2906002)(4326008)(8676002)(7696005)(36900700001)(309714004); DIR:OUT; SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 14 Feb 2022 09:35:53.4544 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 68231387-7297-4c1b-0bcd-08d9ef9d652a X-MS-Exchange-CrossTenant-Id: 43083d15-7273-40c1-b7db-39efd9ccc17a X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a; Ip=[12.22.5.234]; Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: CO1NAM11FT058.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY5PR12MB3841 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 Rearrange the mlx5_os_get_dev_attr() function in such a way that it first executes the queries and only then updates the fields. In addition, it changed its name in preparation for expanding its operations to configure the capabilities inside it. Signed-off-by: Michael Baum Acked-by: Matan Azrad --- drivers/net/mlx5/linux/mlx5_os.c | 124 +++++++++++++--------------- drivers/net/mlx5/linux/mlx5_verbs.c | 5 +- drivers/net/mlx5/mlx5.c | 4 +- drivers/net/mlx5/mlx5.h | 56 ++++++------- drivers/net/mlx5/mlx5_devx.c | 2 +- drivers/net/mlx5/mlx5_ethdev.c | 5 +- drivers/net/mlx5/mlx5_trigger.c | 8 +- drivers/net/mlx5/mlx5_txq.c | 18 ++-- drivers/net/mlx5/windows/mlx5_os.c | 67 ++++++--------- 9 files changed, 128 insertions(+), 161 deletions(-) diff --git a/drivers/net/mlx5/linux/mlx5_os.c b/drivers/net/mlx5/linux/mlx5_os.c index 69ba2aaf88..f0aa0f4164 100644 --- a/drivers/net/mlx5/linux/mlx5_os.c +++ b/drivers/net/mlx5/linux/mlx5_os.c @@ -131,46 +131,25 @@ mlx5_os_set_nonblock_channel_fd(int fd) * with out parameter of type 'struct ibv_device_attr_ex *'. Then fill in mlx5 * device attributes from the glue out parameter. * - * @param cdev - * Pointer to mlx5 device. - * - * @param device_attr - * Pointer to mlx5 device attributes. + * @param sh + * Pointer to shared device context. * * @return * 0 on success, a negative errno value otherwise and rte_errno is set. */ int -mlx5_os_get_dev_attr(struct mlx5_common_device *cdev, - struct mlx5_dev_attr *device_attr) +mlx5_os_capabilities_prepare(struct mlx5_dev_ctx_shared *sh) { int err; - struct ibv_context *ctx = cdev->ctx; - struct ibv_device_attr_ex attr_ex; + struct ibv_context *ctx = sh->cdev->ctx; + struct ibv_device_attr_ex attr_ex = { .comp_mask = 0 }; + struct mlx5dv_context dv_attr = { .comp_mask = 0 }; - memset(device_attr, 0, sizeof(*device_attr)); err = mlx5_glue->query_device_ex(ctx, NULL, &attr_ex); if (err) { rte_errno = errno; return -rte_errno; } - device_attr->device_cap_flags_ex = attr_ex.device_cap_flags_ex; - device_attr->max_qp_wr = attr_ex.orig_attr.max_qp_wr; - device_attr->max_sge = attr_ex.orig_attr.max_sge; - device_attr->max_cq = attr_ex.orig_attr.max_cq; - device_attr->max_cqe = attr_ex.orig_attr.max_cqe; - device_attr->max_mr = attr_ex.orig_attr.max_mr; - device_attr->max_pd = attr_ex.orig_attr.max_pd; - device_attr->max_qp = attr_ex.orig_attr.max_qp; - device_attr->max_srq = attr_ex.orig_attr.max_srq; - device_attr->max_srq_wr = attr_ex.orig_attr.max_srq_wr; - device_attr->raw_packet_caps = attr_ex.raw_packet_caps; - device_attr->max_rwq_indirection_table_size = - attr_ex.rss_caps.max_rwq_indirection_table_size; - device_attr->max_tso = attr_ex.tso_caps.max_tso; - device_attr->tso_supported_qpts = attr_ex.tso_caps.supported_qpts; - - struct mlx5dv_context dv_attr = { .comp_mask = 0 }; #ifdef HAVE_IBV_MLX5_MOD_SWP dv_attr.comp_mask |= MLX5DV_CONTEXT_MASK_SWP; #endif @@ -185,31 +164,40 @@ mlx5_os_get_dev_attr(struct mlx5_common_device *cdev, rte_errno = errno; return -rte_errno; } - - device_attr->flags = dv_attr.flags; - device_attr->comp_mask = dv_attr.comp_mask; + memset(&sh->dev_cap, 0, sizeof(struct mlx5_dev_cap)); + sh->dev_cap.device_cap_flags_ex = attr_ex.device_cap_flags_ex; + sh->dev_cap.max_qp_wr = attr_ex.orig_attr.max_qp_wr; + sh->dev_cap.max_sge = attr_ex.orig_attr.max_sge; + sh->dev_cap.max_cq = attr_ex.orig_attr.max_cq; + sh->dev_cap.max_qp = attr_ex.orig_attr.max_qp; + sh->dev_cap.raw_packet_caps = attr_ex.raw_packet_caps; + sh->dev_cap.max_rwq_indirection_table_size = + attr_ex.rss_caps.max_rwq_indirection_table_size; + sh->dev_cap.max_tso = attr_ex.tso_caps.max_tso; + sh->dev_cap.tso_supported_qpts = attr_ex.tso_caps.supported_qpts; + strlcpy(sh->dev_cap.fw_ver, attr_ex.orig_attr.fw_ver, + sizeof(sh->dev_cap.fw_ver)); + sh->dev_cap.flags = dv_attr.flags; + sh->dev_cap.comp_mask = dv_attr.comp_mask; #ifdef HAVE_IBV_MLX5_MOD_SWP - device_attr->sw_parsing_offloads = + sh->dev_cap.sw_parsing_offloads = dv_attr.sw_parsing_caps.sw_parsing_offloads; #endif #ifdef HAVE_IBV_DEVICE_STRIDING_RQ_SUPPORT - device_attr->min_single_stride_log_num_of_bytes = + sh->dev_cap.min_single_stride_log_num_of_bytes = dv_attr.striding_rq_caps.min_single_stride_log_num_of_bytes; - device_attr->max_single_stride_log_num_of_bytes = + sh->dev_cap.max_single_stride_log_num_of_bytes = dv_attr.striding_rq_caps.max_single_stride_log_num_of_bytes; - device_attr->min_single_wqe_log_num_of_strides = + sh->dev_cap.min_single_wqe_log_num_of_strides = dv_attr.striding_rq_caps.min_single_wqe_log_num_of_strides; - device_attr->max_single_wqe_log_num_of_strides = + sh->dev_cap.max_single_wqe_log_num_of_strides = dv_attr.striding_rq_caps.max_single_wqe_log_num_of_strides; - device_attr->stride_supported_qpts = + sh->dev_cap.stride_supported_qpts = dv_attr.striding_rq_caps.supported_qpts; #endif #ifdef HAVE_IBV_DEVICE_TUNNEL_SUPPORT - device_attr->tunnel_offloads_caps = dv_attr.tunnel_offloads_caps; + sh->dev_cap.tunnel_offloads_caps = dv_attr.tunnel_offloads_caps; #endif - strlcpy(device_attr->fw_ver, attr_ex.orig_attr.fw_ver, - sizeof(device_attr->fw_ver)); - return 0; } @@ -983,8 +971,8 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, * Multi-packet send is supported by ConnectX-4 Lx PF as well * as all ConnectX-5 devices. */ - if (sh->device_attr.flags & MLX5DV_CONTEXT_FLAGS_MPW_ALLOWED) { - if (sh->device_attr.flags & MLX5DV_CONTEXT_FLAGS_ENHANCED_MPW) { + if (sh->dev_cap.flags & MLX5DV_CONTEXT_FLAGS_MPW_ALLOWED) { + if (sh->dev_cap.flags & MLX5DV_CONTEXT_FLAGS_ENHANCED_MPW) { DRV_LOG(DEBUG, "enhanced MPW is supported"); mps = MLX5_MPW_ENHANCED; } else { @@ -996,41 +984,41 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, mps = MLX5_MPW_DISABLED; } #ifdef HAVE_IBV_MLX5_MOD_SWP - if (sh->device_attr.comp_mask & MLX5DV_CONTEXT_MASK_SWP) - swp = sh->device_attr.sw_parsing_offloads; + if (sh->dev_cap.comp_mask & MLX5DV_CONTEXT_MASK_SWP) + swp = sh->dev_cap.sw_parsing_offloads; DRV_LOG(DEBUG, "SWP support: %u", swp); #endif config->swp = swp & (MLX5_SW_PARSING_CAP | MLX5_SW_PARSING_CSUM_CAP | MLX5_SW_PARSING_TSO_CAP); #ifdef HAVE_IBV_DEVICE_STRIDING_RQ_SUPPORT - if (sh->device_attr.comp_mask & MLX5DV_CONTEXT_MASK_STRIDING_RQ) { + if (sh->dev_cap.comp_mask & MLX5DV_CONTEXT_MASK_STRIDING_RQ) { DRV_LOG(DEBUG, "\tmin_single_stride_log_num_of_bytes: %d", - sh->device_attr.min_single_stride_log_num_of_bytes); + sh->dev_cap.min_single_stride_log_num_of_bytes); DRV_LOG(DEBUG, "\tmax_single_stride_log_num_of_bytes: %d", - sh->device_attr.max_single_stride_log_num_of_bytes); + sh->dev_cap.max_single_stride_log_num_of_bytes); DRV_LOG(DEBUG, "\tmin_single_wqe_log_num_of_strides: %d", - sh->device_attr.min_single_wqe_log_num_of_strides); + sh->dev_cap.min_single_wqe_log_num_of_strides); DRV_LOG(DEBUG, "\tmax_single_wqe_log_num_of_strides: %d", - sh->device_attr.max_single_wqe_log_num_of_strides); + sh->dev_cap.max_single_wqe_log_num_of_strides); DRV_LOG(DEBUG, "\tsupported_qpts: %d", - sh->device_attr.stride_supported_qpts); + sh->dev_cap.stride_supported_qpts); DRV_LOG(DEBUG, "\tmin_stride_wqe_log_size: %d", config->mprq.log_min_stride_wqe_size); DRV_LOG(DEBUG, "device supports Multi-Packet RQ"); mprq = 1; config->mprq.log_min_stride_size = - sh->device_attr.min_single_stride_log_num_of_bytes; + sh->dev_cap.min_single_stride_log_num_of_bytes; config->mprq.log_max_stride_size = - sh->device_attr.max_single_stride_log_num_of_bytes; + sh->dev_cap.max_single_stride_log_num_of_bytes; config->mprq.log_min_stride_num = - sh->device_attr.min_single_wqe_log_num_of_strides; + sh->dev_cap.min_single_wqe_log_num_of_strides; config->mprq.log_max_stride_num = - sh->device_attr.max_single_wqe_log_num_of_strides; + sh->dev_cap.max_single_wqe_log_num_of_strides; } #endif #ifdef HAVE_IBV_DEVICE_TUNNEL_SUPPORT - if (sh->device_attr.comp_mask & MLX5DV_CONTEXT_MASK_TUNNEL_OFFLOADS) { - config->tunnel_en = sh->device_attr.tunnel_offloads_caps & + if (sh->dev_cap.comp_mask & MLX5DV_CONTEXT_MASK_TUNNEL_OFFLOADS) { + config->tunnel_en = sh->dev_cap.tunnel_offloads_caps & (MLX5DV_RAW_PACKET_CAP_TUNNELED_OFFLOAD_VXLAN | MLX5DV_RAW_PACKET_CAP_TUNNELED_OFFLOAD_GRE | MLX5DV_RAW_PACKET_CAP_TUNNELED_OFFLOAD_GENEVE); @@ -1052,9 +1040,9 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, "tunnel offloading disabled due to old OFED/rdma-core version"); #endif #ifdef HAVE_IBV_DEVICE_MPLS_SUPPORT - mpls_en = ((sh->device_attr.tunnel_offloads_caps & + mpls_en = ((sh->dev_cap.tunnel_offloads_caps & MLX5DV_RAW_PACKET_CAP_TUNNELED_OFFLOAD_CW_MPLS_OVER_GRE) && - (sh->device_attr.tunnel_offloads_caps & + (sh->dev_cap.tunnel_offloads_caps & MLX5DV_RAW_PACKET_CAP_TUNNELED_OFFLOAD_CW_MPLS_OVER_UDP)); DRV_LOG(DEBUG, "MPLS over GRE/UDP tunnel offloading is %ssupported", mpls_en ? "" : "not "); @@ -1215,7 +1203,7 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, DRV_LOG(DEBUG, "dev_port-%u new domain_id=%u\n", priv->dev_port, priv->domain_id); } - config->hw_csum = !!(sh->device_attr.device_cap_flags_ex & + config->hw_csum = !!(sh->dev_cap.device_cap_flags_ex & IBV_DEVICE_RAW_IP_CSUM); DRV_LOG(DEBUG, "checksum offloading is %ssupported", (config->hw_csum ? "" : "not ")); @@ -1224,7 +1212,7 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, DRV_LOG(DEBUG, "counters are not supported"); #endif config->ind_table_max_size = - sh->device_attr.max_rwq_indirection_table_size; + sh->dev_cap.max_rwq_indirection_table_size; /* * Remove this check once DPDK supports larger/variable * indirection tables. @@ -1233,16 +1221,16 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, config->ind_table_max_size = RTE_ETH_RSS_RETA_SIZE_512; DRV_LOG(DEBUG, "maximum Rx indirection table size is %u", config->ind_table_max_size); - config->hw_vlan_strip = !!(sh->device_attr.raw_packet_caps & + config->hw_vlan_strip = !!(sh->dev_cap.raw_packet_caps & IBV_RAW_PACKET_CAP_CVLAN_STRIPPING); DRV_LOG(DEBUG, "VLAN stripping is %ssupported", (config->hw_vlan_strip ? "" : "not ")); - config->hw_fcs_strip = !!(sh->device_attr.raw_packet_caps & + config->hw_fcs_strip = !!(sh->dev_cap.raw_packet_caps & IBV_RAW_PACKET_CAP_SCATTER_FCS); #if defined(HAVE_IBV_WQ_FLAG_RX_END_PADDING) - hw_padding = !!sh->device_attr.rx_pad_end_addr_align; + hw_padding = !!sh->dev_cap.rx_pad_end_addr_align; #elif defined(HAVE_IBV_WQ_FLAGS_PCI_WRITE_END_PADDING) - hw_padding = !!(sh->device_attr.device_cap_flags_ex & + hw_padding = !!(sh->dev_cap.device_cap_flags_ex & IBV_DEVICE_PCI_WRITE_END_PADDING); #endif if (config->hw_padding && !hw_padding) { @@ -1251,11 +1239,11 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, } else if (config->hw_padding) { DRV_LOG(DEBUG, "Rx end alignment padding is enabled"); } - config->tso = (sh->device_attr.max_tso > 0 && - (sh->device_attr.tso_supported_qpts & + config->tso = (sh->dev_cap.max_tso > 0 && + (sh->dev_cap.tso_supported_qpts & (1 << IBV_QPT_RAW_PACKET))); if (config->tso) - config->tso_max_payload_sz = sh->device_attr.max_tso; + config->tso_max_payload_sz = sh->dev_cap.max_tso; /* * MPW is disabled by default, while the Enhanced MPW is enabled * by default. @@ -1382,7 +1370,7 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, #endif } if (config->cqe_comp && RTE_CACHE_LINE_SIZE == 128 && - !(sh->device_attr.flags & MLX5DV_CONTEXT_FLAGS_CQE_128B_COMP)) { + !(sh->dev_cap.flags & MLX5DV_CONTEXT_FLAGS_CQE_128B_COMP)) { DRV_LOG(WARNING, "Rx CQE 128B compression is not supported"); config->cqe_comp = 0; } diff --git a/drivers/net/mlx5/linux/mlx5_verbs.c b/drivers/net/mlx5/linux/mlx5_verbs.c index 722017efa4..73c44138de 100644 --- a/drivers/net/mlx5/linux/mlx5_verbs.c +++ b/drivers/net/mlx5/linux/mlx5_verbs.c @@ -872,13 +872,12 @@ mlx5_txq_ibv_qp_create(struct rte_eth_dev *dev, uint16_t idx) /* CQ to be associated with the receive queue. */ qp_attr.recv_cq = txq_ctrl->obj->cq; /* Max number of outstanding WRs. */ - qp_attr.cap.max_send_wr = ((priv->sh->device_attr.max_qp_wr < desc) ? - priv->sh->device_attr.max_qp_wr : desc); + qp_attr.cap.max_send_wr = RTE_MIN(priv->sh->dev_cap.max_qp_wr, desc); /* * Max number of scatter/gather elements in a WR, must be 1 to prevent * libmlx5 from trying to affect must be 1 to prevent libmlx5 from * trying to affect too much memory. TX gather is not impacted by the - * device_attr.max_sge limit and will still work properly. + * dev_cap.max_sge limit and will still work properly. */ qp_attr.cap.max_send_sge = 1; qp_attr.qp_type = IBV_QPT_RAW_PACKET, diff --git a/drivers/net/mlx5/mlx5.c b/drivers/net/mlx5/mlx5.c index b26632d249..7487b1f87d 100644 --- a/drivers/net/mlx5/mlx5.c +++ b/drivers/net/mlx5/mlx5.c @@ -1262,9 +1262,9 @@ mlx5_alloc_shared_dev_ctx(const struct mlx5_dev_spawn_data *spawn, sh->esw_mode = !!(spawn->info.master || spawn->info.representor); if (spawn->bond_info) sh->bond = *spawn->bond_info; - err = mlx5_os_get_dev_attr(sh->cdev, &sh->device_attr); + err = mlx5_os_capabilities_prepare(sh); if (err) { - DRV_LOG(DEBUG, "mlx5_os_get_dev_attr() failed"); + DRV_LOG(ERR, "Fail to configure device capabilities."); goto error; } sh->refcnt = 1; diff --git a/drivers/net/mlx5/mlx5.h b/drivers/net/mlx5/mlx5.h index a713e61572..fd6350eee7 100644 --- a/drivers/net/mlx5/mlx5.h +++ b/drivers/net/mlx5/mlx5.h @@ -114,32 +114,31 @@ struct mlx5_flow_cb_ctx { void *data2; }; -/* Device attributes used in mlx5 PMD */ -struct mlx5_dev_attr { - uint64_t device_cap_flags_ex; - int max_qp_wr; - int max_sge; - int max_cq; - int max_qp; - int max_cqe; - uint32_t max_pd; - uint32_t max_mr; - uint32_t max_srq; - uint32_t max_srq_wr; - uint32_t raw_packet_caps; - uint32_t max_rwq_indirection_table_size; - uint32_t max_tso; - uint32_t tso_supported_qpts; - uint64_t flags; - uint64_t comp_mask; - uint32_t sw_parsing_offloads; - uint32_t min_single_stride_log_num_of_bytes; - uint32_t max_single_stride_log_num_of_bytes; - uint32_t min_single_wqe_log_num_of_strides; - uint32_t max_single_wqe_log_num_of_strides; - uint32_t stride_supported_qpts; - uint32_t tunnel_offloads_caps; - char fw_ver[64]; +/* Device capabilities structure which isn't changed in any stage. */ +struct mlx5_dev_cap { + uint64_t device_cap_flags_ex; + int max_cq; /* Maximum number of supported CQs */ + int max_qp; /* Maximum number of supported QPs. */ + int max_qp_wr; /* Maximum number of outstanding WR on any WQ. */ + int max_sge; + /* Maximum number of s/g per WR for SQ & RQ of QP for non RDMA Read + * operations. + */ + uint32_t raw_packet_caps; + uint32_t max_rwq_indirection_table_size; + /* Maximum receive WQ indirection table size. */ + uint32_t max_tso; /* Maximum TCP payload for TSO. */ + uint32_t tso_supported_qpts; + uint64_t flags; + uint64_t comp_mask; + uint32_t sw_parsing_offloads; + uint32_t min_single_stride_log_num_of_bytes; + uint32_t max_single_stride_log_num_of_bytes; + uint32_t min_single_wqe_log_num_of_strides; + uint32_t max_single_wqe_log_num_of_strides; + uint32_t stride_supported_qpts; + uint32_t tunnel_offloads_caps; + char fw_ver[64]; /* Firmware version of this device. */ }; /** Data associated with devices to spawn. */ @@ -1165,7 +1164,7 @@ struct mlx5_dev_ctx_shared { uint32_t tdn; /* Transport Domain number. */ char ibdev_name[MLX5_FS_NAME_MAX]; /* SYSFS dev name. */ char ibdev_path[MLX5_FS_PATH_MAX]; /* SYSFS dev path for secondary */ - struct mlx5_dev_attr device_attr; /* Device properties. */ + struct mlx5_dev_cap dev_cap; /* Device capabilities. */ int numa_node; /* Numa node of backing physical device. */ /* Packet pacing related structure. */ struct mlx5_dev_txpp txpp; @@ -1792,8 +1791,7 @@ void mlx5_flow_meter_rxq_flush(struct rte_eth_dev *dev); /* mlx5_os.c */ struct rte_pci_driver; -int mlx5_os_get_dev_attr(struct mlx5_common_device *dev, - struct mlx5_dev_attr *dev_attr); +int mlx5_os_capabilities_prepare(struct mlx5_dev_ctx_shared *sh); void mlx5_os_free_shared_dr(struct mlx5_priv *priv); int mlx5_os_net_probe(struct mlx5_common_device *cdev); void mlx5_os_dev_shared_handler_install(struct mlx5_dev_ctx_shared *sh); diff --git a/drivers/net/mlx5/mlx5_devx.c b/drivers/net/mlx5/mlx5_devx.c index 97c8925044..553df6424d 100644 --- a/drivers/net/mlx5/mlx5_devx.c +++ b/drivers/net/mlx5/mlx5_devx.c @@ -1305,7 +1305,7 @@ mlx5_txq_devx_obj_new(struct rte_eth_dev *dev, uint16_t idx) wqe_size = RTE_ALIGN(wqe_size, MLX5_WQE_SIZE) / MLX5_WQE_SIZE; /* Create Send Queue object with DevX. */ wqe_n = RTE_MIN((1UL << txq_data->elts_n) * wqe_size, - (uint32_t)priv->sh->device_attr.max_qp_wr); + (uint32_t)priv->sh->dev_cap.max_qp_wr); log_desc_n = log2above(wqe_n); ret = mlx5_txq_create_devx_sq_resources(dev, idx, log_desc_n); if (ret) { diff --git a/drivers/net/mlx5/mlx5_ethdev.c b/drivers/net/mlx5/mlx5_ethdev.c index 06d5acb75f..d970eb6904 100644 --- a/drivers/net/mlx5/mlx5_ethdev.c +++ b/drivers/net/mlx5/mlx5_ethdev.c @@ -313,8 +313,7 @@ mlx5_dev_infos_get(struct rte_eth_dev *dev, struct rte_eth_dev_info *info) * Since we need one CQ per QP, the limit is the minimum number * between the two values. */ - max = RTE_MIN(priv->sh->device_attr.max_cq, - priv->sh->device_attr.max_qp); + max = RTE_MIN(priv->sh->dev_cap.max_cq, priv->sh->dev_cap.max_qp); /* max_rx_queues is uint16_t. */ max = RTE_MIN(max, (unsigned int)UINT16_MAX); info->max_rx_queues = max; @@ -516,7 +515,7 @@ int mlx5_fw_version_get(struct rte_eth_dev *dev, char *fw_ver, size_t fw_size) { struct mlx5_priv *priv = dev->data->dev_private; - struct mlx5_dev_attr *attr = &priv->sh->device_attr; + struct mlx5_dev_cap *attr = &priv->sh->dev_cap; size_t size = strnlen(attr->fw_ver, sizeof(attr->fw_ver)) + 1; if (fw_size < size) diff --git a/drivers/net/mlx5/mlx5_trigger.c b/drivers/net/mlx5/mlx5_trigger.c index a00b56eecf..f46089fd56 100644 --- a/drivers/net/mlx5/mlx5_trigger.c +++ b/drivers/net/mlx5/mlx5_trigger.c @@ -215,10 +215,10 @@ mlx5_rxq_start(struct rte_eth_dev *dev) /* Should not release Rx queues but return immediately. */ return -rte_errno; } - DRV_LOG(DEBUG, "Port %u device_attr.max_qp_wr is %d.", - dev->data->port_id, priv->sh->device_attr.max_qp_wr); - DRV_LOG(DEBUG, "Port %u device_attr.max_sge is %d.", - dev->data->port_id, priv->sh->device_attr.max_sge); + DRV_LOG(DEBUG, "Port %u dev_cap.max_qp_wr is %d.", + dev->data->port_id, priv->sh->dev_cap.max_qp_wr); + DRV_LOG(DEBUG, "Port %u dev_cap.max_sge is %d.", + dev->data->port_id, priv->sh->dev_cap.max_sge); for (i = 0; i != priv->rxqs_n; ++i) { struct mlx5_rxq_priv *rxq = mlx5_rxq_ref(dev, i); struct mlx5_rxq_ctrl *rxq_ctrl; diff --git a/drivers/net/mlx5/mlx5_txq.c b/drivers/net/mlx5/mlx5_txq.c index 4e0bf7af9c..56e0937ca3 100644 --- a/drivers/net/mlx5/mlx5_txq.c +++ b/drivers/net/mlx5/mlx5_txq.c @@ -714,7 +714,7 @@ txq_calc_inline_max(struct mlx5_txq_ctrl *txq_ctrl) struct mlx5_priv *priv = txq_ctrl->priv; unsigned int wqe_size; - wqe_size = priv->sh->device_attr.max_qp_wr / desc; + wqe_size = priv->sh->dev_cap.max_qp_wr / desc; if (!wqe_size) return 0; /* @@ -982,8 +982,7 @@ txq_adjust_params(struct mlx5_txq_ctrl *txq_ctrl) " satisfied (%u) on port %u, try the smaller" " Tx queue size (%d)", txq_ctrl->txq.inlen_mode, max_inline, - priv->dev_data->port_id, - priv->sh->device_attr.max_qp_wr); + priv->dev_data->port_id, priv->sh->dev_cap.max_qp_wr); goto error; } if (txq_ctrl->txq.inlen_send > max_inline && @@ -994,8 +993,7 @@ txq_adjust_params(struct mlx5_txq_ctrl *txq_ctrl) " satisfied (%u) on port %u, try the smaller" " Tx queue size (%d)", txq_ctrl->txq.inlen_send, max_inline, - priv->dev_data->port_id, - priv->sh->device_attr.max_qp_wr); + priv->dev_data->port_id, priv->sh->dev_cap.max_qp_wr); goto error; } if (txq_ctrl->txq.inlen_empw > max_inline && @@ -1006,8 +1004,7 @@ txq_adjust_params(struct mlx5_txq_ctrl *txq_ctrl) " satisfied (%u) on port %u, try the smaller" " Tx queue size (%d)", txq_ctrl->txq.inlen_empw, max_inline, - priv->dev_data->port_id, - priv->sh->device_attr.max_qp_wr); + priv->dev_data->port_id, priv->sh->dev_cap.max_qp_wr); goto error; } if (txq_ctrl->txq.tso_en && max_inline < MLX5_MAX_TSO_HEADER) { @@ -1016,8 +1013,7 @@ txq_adjust_params(struct mlx5_txq_ctrl *txq_ctrl) " satisfied (%u) on port %u, try the smaller" " Tx queue size (%d)", MLX5_MAX_TSO_HEADER, max_inline, - priv->dev_data->port_id, - priv->sh->device_attr.max_qp_wr); + priv->dev_data->port_id, priv->sh->dev_cap.max_qp_wr); goto error; } if (txq_ctrl->txq.inlen_send > max_inline) { @@ -1098,12 +1094,12 @@ mlx5_txq_new(struct rte_eth_dev *dev, uint16_t idx, uint16_t desc, if (txq_adjust_params(tmpl)) goto error; if (txq_calc_wqebb_cnt(tmpl) > - priv->sh->device_attr.max_qp_wr) { + priv->sh->dev_cap.max_qp_wr) { DRV_LOG(ERR, "port %u Tx WQEBB count (%d) exceeds the limit (%d)," " try smaller queue size", dev->data->port_id, txq_calc_wqebb_cnt(tmpl), - priv->sh->device_attr.max_qp_wr); + priv->sh->dev_cap.max_qp_wr); rte_errno = ENOMEM; goto error; } diff --git a/drivers/net/mlx5/windows/mlx5_os.c b/drivers/net/mlx5/windows/mlx5_os.c index e509c34083..91e91e4d36 100644 --- a/drivers/net/mlx5/windows/mlx5_os.c +++ b/drivers/net/mlx5/windows/mlx5_os.c @@ -143,55 +143,42 @@ mlx5_init_once(void) } /** - * Get mlx5 device attributes. + * Get mlx5 device capabilities. * - * @param cdev - * Pointer to mlx5 device. - * - * @param device_attr - * Pointer to mlx5 device attributes. + * @param sh + * Pointer to shared device context. * * @return * 0 on success, a negative errno value otherwise and rte_errno is set. */ int -mlx5_os_get_dev_attr(struct mlx5_common_device *cdev, - struct mlx5_dev_attr *device_attr) +mlx5_os_capabilities_prepare(struct mlx5_dev_ctx_shared *sh) { - struct mlx5_context *mlx5_ctx; + struct mlx5_hca_attr *hca_attr = &sh->cdev->config.hca_attr; + struct mlx5_context *mlx5_ctx = sh->cdev->ctx; void *pv_iseg = NULL; u32 cb_iseg = 0; - if (!cdev || !cdev->ctx) { - rte_errno = EINVAL; - return -rte_errno; - } - mlx5_ctx = (struct mlx5_context *)cdev->ctx; - memset(device_attr, 0, sizeof(*device_attr)); - device_attr->max_cq = 1 << cdev->config.hca_attr.log_max_cq; - device_attr->max_qp = 1 << cdev->config.hca_attr.log_max_qp; - device_attr->max_qp_wr = 1 << cdev->config.hca_attr.log_max_qp_sz; - device_attr->max_cqe = 1 << cdev->config.hca_attr.log_max_cq_sz; - device_attr->max_mr = 1 << cdev->config.hca_attr.log_max_mrw_sz; - device_attr->max_pd = 1 << cdev->config.hca_attr.log_max_pd; - device_attr->max_srq = 1 << cdev->config.hca_attr.log_max_srq; - device_attr->max_srq_wr = 1 << cdev->config.hca_attr.log_max_srq_sz; - device_attr->max_tso = 1 << cdev->config.hca_attr.max_lso_cap; - if (cdev->config.hca_attr.rss_ind_tbl_cap) { - device_attr->max_rwq_indirection_table_size = - 1 << cdev->config.hca_attr.rss_ind_tbl_cap; - } - device_attr->sw_parsing_offloads = - mlx5_get_supported_sw_parsing_offloads(&cdev->config.hca_attr); - device_attr->tunnel_offloads_caps = - mlx5_get_supported_tunneling_offloads(&cdev->config.hca_attr); pv_iseg = mlx5_glue->query_hca_iseg(mlx5_ctx, &cb_iseg); if (pv_iseg == NULL) { - DRV_LOG(ERR, "Failed to get device hca_iseg"); + DRV_LOG(ERR, "Failed to get device hca_iseg."); rte_errno = errno; return -rte_errno; } - snprintf(device_attr->fw_ver, 64, "%x.%x.%04x", + memset(&sh->dev_cap, 0, sizeof(struct mlx5_dev_cap)); + sh->dev_cap.max_cq = 1 << hca_attr->log_max_cq; + sh->dev_cap.max_qp = 1 << hca_attr->log_max_qp; + sh->dev_cap.max_qp_wr = 1 << hca_attr->log_max_qp_sz; + sh->dev_cap.max_tso = 1 << hca_attr->max_lso_cap; + if (hca_attr->rss_ind_tbl_cap) { + sh->dev_cap.max_rwq_indirection_table_size = + 1 << hca_attr->rss_ind_tbl_cap; + } + sh->dev_cap.sw_parsing_offloads = + mlx5_get_supported_sw_parsing_offloads(hca_attr); + sh->dev_cap.tunnel_offloads_caps = + mlx5_get_supported_tunneling_offloads(hca_attr); + snprintf(sh->dev_cap.fw_ver, 64, "%x.%x.%04x", MLX5_GET(initial_seg, pv_iseg, fw_rev_major), MLX5_GET(initial_seg, pv_iseg, fw_rev_minor), MLX5_GET(initial_seg, pv_iseg, fw_rev_subminor)); @@ -335,12 +322,12 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, goto error; } DRV_LOG(DEBUG, "MPW isn't supported"); - config->swp = sh->device_attr.sw_parsing_offloads & + config->swp = sh->dev_cap.sw_parsing_offloads & (MLX5_SW_PARSING_CAP | MLX5_SW_PARSING_CSUM_CAP | MLX5_SW_PARSING_TSO_CAP); config->ind_table_max_size = - sh->device_attr.max_rwq_indirection_table_size; - config->tunnel_en = sh->device_attr.tunnel_offloads_caps & + sh->dev_cap.max_rwq_indirection_table_size; + config->tunnel_en = sh->dev_cap.tunnel_offloads_caps & (MLX5_TUNNELED_OFFLOADS_VXLAN_CAP | MLX5_TUNNELED_OFFLOADS_GRE_CAP | MLX5_TUNNELED_OFFLOADS_GENEVE_CAP); @@ -410,7 +397,7 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, } DRV_LOG(DEBUG, "counters are not supported"); config->ind_table_max_size = - sh->device_attr.max_rwq_indirection_table_size; + sh->dev_cap.max_rwq_indirection_table_size; /* * Remove this check once DPDK supports larger/variable * indirection tables. @@ -423,9 +410,9 @@ mlx5_dev_spawn(struct rte_device *dpdk_dev, DRV_LOG(DEBUG, "Rx end alignment padding isn't supported"); config->hw_padding = 0; } - config->tso = (sh->device_attr.max_tso > 0); + config->tso = (sh->dev_cap.max_tso > 0); if (config->tso) - config->tso_max_payload_sz = sh->device_attr.max_tso; + config->tso_max_payload_sz = sh->dev_cap.max_tso; DRV_LOG(DEBUG, "%sMPS is %s.", config->mps == MLX5_MPW_ENHANCED ? "enhanced " : config->mps == MLX5_MPW ? "legacy " : "", -- 2.25.1