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 836B6A00C4; Mon, 14 Feb 2022 10:37:29 +0100 (CET) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 4172F4116D; Mon, 14 Feb 2022 10:36:07 +0100 (CET) Received: from NAM10-MW2-obe.outbound.protection.outlook.com (mail-mw2nam10on2049.outbound.protection.outlook.com [40.107.94.49]) by mails.dpdk.org (Postfix) with ESMTP id AD8F7426DE for ; Mon, 14 Feb 2022 10:36:05 +0100 (CET) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=k3hDs4L9+7vxoqeMYC1sU9OqXU/bdOV8V/dg8qjt/0tYRhTpncTEAxVdx4KKiRoW8nb14ei7vEDSJa8s27IDVh1is/b3EwYVbE8ficpsTqACQ/UFUxtVXXEsuM73fhjHFNQLoqYhsFH0mvuFtqV7Ua9Q77mhtO2U1DzROS4HOmrvJTRmJcCcDuG1NKE6ktrIFIsY9fWzD39larJTYrgLbbtd/CxSF0+jL8GHpoXXDNu2DsrHvMVsUfLEmSMN6MejuRJqwwEYyxAx5+aUkPgrunnYE+iRN2b1hOKUQBJ/IbU/FE5k0NxkLIt2jEkl8YVYjTn3gkoat0BmPHNPe8fOxQ== 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=7LdWAm/1G4k2B0QnsyFZk57yluue2EWzSVxy9r7jduI=; b=UEcMoQ07k0VG13wagaTjcKxlOo5dkDx5bHYRlPQ7vQ+wKcU6l2PB7+oldaUybuCF9xfgXp1v8zSkAqhfR7YhP9HxnWwN7SIEsjdIOzObw5aBg8bzAC0qM6s8dZxGa8UWq6VFIFMek0BZxqTr1BtlJMhiJeDbu9pkmokPnHJVbBIIqSLvYe9avpY+qE77FZh7FNoOfXq/A9SE+P0FO0mcVTR3SR9AqFPf01V9oIB4MG3ilAPgXiSCRBMTSb40WSbSABUgkRqyniTEPiUILaZEi3h23FP8H7ttZZ4u51SmRO3hwB/s5seK2EEpysMxxTkz0UvHeqCYfyLyH8etquU93Q== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 12.22.5.235) 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=7LdWAm/1G4k2B0QnsyFZk57yluue2EWzSVxy9r7jduI=; b=sCizQMAV74ArVZpvFE7JEblAZcmhw1E26u7/NDESkQFb9/437xB4Hl13i7Z5PsQQbZhpEbO8px6Fc2Ju3X2D+WwIE6t2chhJ9BAzKQBwLZSKi12LzvGITt92Ue/koSX4XoFpRCcOf09yjpQoSsPq93hKh4BaZec8ZvBMLykPPsqua98QVrKRmh8t3y41cY747V8zHtjE2+RExaA2Yzfv6TFk4Y6KnXssRMDxmcm0OScHJHuu4mLqwfVgMype1nGMQh9UoZEuTvKkdyS23bIFMdo/zZoMtWp+GUVCQ5vNp8GMTSA1a0WQTimNeNcvK9TjHTT6W2qvX/5Mz/Kn+oa3Pg== Received: from DS7PR03CA0100.namprd03.prod.outlook.com (2603:10b6:5:3b7::15) by BN8PR12MB2961.namprd12.prod.outlook.com (2603:10b6:408:65::32) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4975.12; Mon, 14 Feb 2022 09:36:03 +0000 Received: from DM6NAM11FT054.eop-nam11.prod.protection.outlook.com (2603:10b6:5:3b7:cafe::8f) by DS7PR03CA0100.outlook.office365.com (2603:10b6:5:3b7::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4975.14 via Frontend Transport; Mon, 14 Feb 2022 09:36:03 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 12.22.5.235) 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.235 as permitted sender) receiver=protection.outlook.com; client-ip=12.22.5.235; helo=mail.nvidia.com; Received: from mail.nvidia.com (12.22.5.235) by DM6NAM11FT054.mail.protection.outlook.com (10.13.173.95) 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:36:03 +0000 Received: from rnnvmail203.nvidia.com (10.129.68.9) by DRHQMAIL107.nvidia.com (10.27.9.16) with Microsoft SMTP Server (TLS) id 15.0.1497.18; Mon, 14 Feb 2022 09:36:02 +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:36:01 -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:59 -0800 From: Michael Baum To: CC: Matan Azrad , Raslan Darawsheh , Viacheslav Ovsiienko Subject: [PATCH v2 19/20] common/mlx5: add check for common devargs in probing again Date: Mon, 14 Feb 2022 11:35:10 +0200 Message-ID: <20220214093511.1592698-20-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: b0b67231-141f-4f71-1a8a-08d9ef9d6b01 X-MS-TrafficTypeDiagnostic: BN8PR12MB2961:EE_ X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:4502; X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: DRyRf1vECBTMkVHgdCuTcQV9cpRpuI+VOiwmlkFYYqKbYGC9zQNAaod30XihGgc0UQBv956Qt2zT90Ln/U/muDW8MlqgO/4VmKGnGngG/As/ws7iDWaKW13ZtKU0fzqHCNk2ui2rYRKlIjpLPA2E4B0XtNKy/cI+N65yndVpaQ0FwQJIAFT4UCCtu/C9AQm1IWWpHbCjGcacrR2yMmDFUOX28S5K4BhdMb2fpLvf+8D2a8itksJRtjdO1YwRowjkVb1iSukF3KatN9cLZickqoN51eaZpHuoyy7meweDLXUWE42O4MPUpKRiXowW+t+ycM2dwF60YAL5iv63q+MoT33oidnSXNTVW2PTDzn3pWUMFVW/sRDONF3BK6yxWFhOp1WQVW1xngGvfiEJaPa/UazT/yFGqKwqASisadt0p9/PzZe0FQ3GV6l6L+5v7yzyJt8bfZ/oIODufSfRBgUSoprzu27/1IYUeSK1mqtyq+PwOTyweWr2dGrE/uFasBrG8yNJo3GlkTRsyufABUyec2XTm2igAqFnyFwlnDmSb02I/i+uBgibvbXnxPZPtzRwTsFgCm/w6xhAvRVsXd8B4kyhTLF1Up3etajNJbkOZvY++6Vx8JfiUekUFuXftGubJDKS3eV5erWi8p9+6pEBc7hdcmR7h8iE3o0yuNxz4Fdp/oXTdW6pbegkj/PUtcUmgq/RAq1EyCxxZko9T4sOLA== X-Forefront-Antispam-Report: CIP:12.22.5.235; CTRY:US; LANG:en; SCL:1; SRV:; IPV:CAL; SFV:NSPM; H:mail.nvidia.com; PTR:InfoNoRecords; CAT:NONE; SFS:(13230001)(4636009)(40470700004)(46966006)(36840700001)(6916009)(70206006)(86362001)(8936002)(54906003)(426003)(356005)(336012)(6286002)(26005)(82310400004)(107886003)(70586007)(8676002)(4326008)(7696005)(2616005)(81166007)(316002)(186003)(36860700001)(1076003)(508600001)(83380400001)(47076005)(40460700003)(2906002)(5660300002)(55016003)(36756003)(6666004)(36900700001); DIR:OUT; SFP:1101; X-OriginatorOrg: Nvidia.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 14 Feb 2022 09:36:03.2680 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: b0b67231-141f-4f71-1a8a-08d9ef9d6b01 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.235]; Helo=[mail.nvidia.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT054.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BN8PR12MB2961 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 MLX5 common driver supports probing again in two scenarios: - Add new driver under existing device. common probe function gets it in devargs, then calls the requested driver's probe function (regardless of the driver's own support in probing again) with the existing device as parameter. - Transfer the probing again support of the drivers themselves (currently only net). In this scenario, the existing device is sent as a parameter to the existing driver's probe too. In both cases it gets a new set of arguments that do not necessarily match the configured arguments in the existing device. Some of the arguments belong to the configuration of the existing device, so they can't be updated in the probing again. On the other hand, there are arguments that belong to a specific driver or specific port and might get a new value in the probing again. The user might generate any argument he wants in probing again, but when he generates arguments belonging to the common device configuration, it does not affect. This patch adds an explicit check for the devargs belonging to the common device configuration. If there is no match to the existing configuration, it returns an error. Signed-off-by: Michael Baum Acked-by: Matan Azrad --- drivers/common/mlx5/mlx5_common.c | 100 ++++++++++++++++++++++++++++++ 1 file changed, 100 insertions(+) diff --git a/drivers/common/mlx5/mlx5_common.c b/drivers/common/mlx5/mlx5_common.c index 47a541f5ef..f74d27e74d 100644 --- a/drivers/common/mlx5/mlx5_common.c +++ b/drivers/common/mlx5/mlx5_common.c @@ -613,6 +613,86 @@ mlx5_common_dev_create(struct rte_device *eal_dev, uint32_t classes) return cdev; } +/** + * Validate common devargs when probing again. + * + * When common device probing again, it cannot change its configurations. + * If user ask non compatible configurations in devargs, it is error. + * This function checks the match between: + * - Common device configurations requested by probe again devargs. + * - Existing common device configurations. + * + * @param cdev + * Pointer to mlx5 device structure. + * + * @return + * 0 on success, a negative errno value otherwise and rte_errno is set. + */ +static int +mlx5_common_probe_again_args_validate(struct mlx5_common_device *cdev) +{ + struct mlx5_common_dev_config *config; + int ret; + + /* Secondary process should not handle devargs. */ + if (rte_eal_process_type() != RTE_PROC_PRIMARY) + return 0; + /* Probe again doesn't have to generate devargs. */ + if (cdev->dev->devargs == NULL) + return 0; + config = mlx5_malloc(MLX5_MEM_ZERO | MLX5_MEM_RTE, + sizeof(struct mlx5_common_dev_config), + RTE_CACHE_LINE_SIZE, SOCKET_ID_ANY); + if (config == NULL) { + rte_errno = -ENOMEM; + return -rte_errno; + } + /* + * Creates a temporary common configure structure according to new + * devargs attached in probing again. + */ + ret = mlx5_common_config_get(cdev->dev->devargs, config); + if (ret) { + DRV_LOG(ERR, "Failed to process device configure: %s", + strerror(rte_errno)); + mlx5_free(config); + return ret; + } + /* + * Checks the match between the temporary structure and the existing + * common device structure. + */ + if (cdev->config.mr_ext_memseg_en ^ config->mr_ext_memseg_en) { + DRV_LOG(ERR, "\"mr_ext_memseg_en\" " + "configuration mismatch for device %s.", + cdev->dev->name); + goto error; + } + if (cdev->config.mr_mempool_reg_en ^ config->mr_mempool_reg_en) { + DRV_LOG(ERR, "\"mr_mempool_reg_en\" " + "configuration mismatch for device %s.", + cdev->dev->name); + goto error; + } + if (cdev->config.sys_mem_en ^ config->sys_mem_en) { + DRV_LOG(ERR, + "\"sys_mem_en\" configuration mismatch for device %s.", + cdev->dev->name); + goto error; + } + if (cdev->config.dbnc ^ config->dbnc) { + DRV_LOG(ERR, "\"dbnc\" configuration mismatch for device %s.", + cdev->dev->name); + goto error; + } + mlx5_free(config); + return 0; +error: + mlx5_free(config); + rte_errno = EINVAL; + return -rte_errno; +} + static int drivers_remove(struct mlx5_common_device *cdev, uint32_t enabled_classes) { @@ -699,12 +779,32 @@ mlx5_common_dev_probe(struct rte_device *eal_dev) if (classes == 0) /* Default to net class. */ classes = MLX5_CLASS_ETH; + /* + * MLX5 common driver supports probing again in two scenarios: + * - Add new driver under existing common device (regardless of the + * driver's own support in probing again). + * - Transfer the probing again support of the drivers themselves. + * + * In both scenarios it uses in the existing device. here it looks for + * device that match to rte device, if it exists, the request classes + * were probed with this device. + */ cdev = to_mlx5_device(eal_dev); if (!cdev) { + /* It isn't probing again, creates a new device. */ cdev = mlx5_common_dev_create(eal_dev, classes); if (!cdev) return -ENOMEM; new_device = true; + } else { + /* It is probing again, validate common devargs match. */ + ret = mlx5_common_probe_again_args_validate(cdev); + if (ret) { + DRV_LOG(ERR, + "Probe again parameters aren't compatible : %s", + strerror(rte_errno)); + return ret; + } } /* * Validate combination here. -- 2.25.1