From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from dpdk.org (dpdk.org [92.243.14.124]) by inbox.dpdk.org (Postfix) with ESMTP id E202CA04B3; Mon, 16 Dec 2019 08:55:13 +0100 (CET) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id EDB461C133; Mon, 16 Dec 2019 08:55:12 +0100 (CET) Received: from mx0b-0016f401.pphosted.com (mx0a-0016f401.pphosted.com [67.231.148.174]) by dpdk.org (Postfix) with ESMTP id 191C81C132 for ; Mon, 16 Dec 2019 08:55:10 +0100 (CET) Received: from pps.filterd (m0045849.ppops.net [127.0.0.1]) by mx0a-0016f401.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id xBG7oeRc024143 for ; Sun, 15 Dec 2019 23:55:10 -0800 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=marvell.com; h=from : to : cc : subject : date : message-id : mime-version : content-type; s=pfpt0818; bh=Am1CC2mQG6a2ereCZfX3g4/7rFRXwBB7LxBxm4fRja8=; b=JnFLDee/CwbX2GFsZRqV9xypMqrXf7nJ3bnDsZsNK6B9jOlzobiWmpyOinfYj9Uo+/u0 B8sM1cRpnu66Jp54nfcjLXiiVUzXgbcBxd/hwh/CeHpPU5ghrpIoLRIaIn44NPrtgxdU eKZc2DK+I4iSQCEbaayhqnqu7SyeefQMD1h/YITTCRT8saCJdBm1up6kp4kkKkBRzLtk WBl6C5I/1iUNqC7E6m3B9yT2O47kj8TCTgpCcrbuuYIcGHGv+gU/rTlBrkryz9EQPheL QEpJMPKg/hHycZzbwWrXXNAUyVR4inTDbhQrM6Q35PVFm5epheh9ZLvBGPs+Vefpza8o XQ== Received: from sc-exch04.marvell.com ([199.233.58.184]) by mx0a-0016f401.pphosted.com with ESMTP id 2wvwyv5ht7-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-SHA384 bits=256 verify=NOT) for ; Sun, 15 Dec 2019 23:55:09 -0800 Received: from SC-EXCH01.marvell.com (10.93.176.81) by SC-EXCH04.marvell.com (10.93.176.84) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Sun, 15 Dec 2019 23:55:08 -0800 Received: from maili.marvell.com (10.93.176.43) by SC-EXCH01.marvell.com (10.93.176.81) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Sun, 15 Dec 2019 23:55:08 -0800 Received: from localhost.localdomain (unknown [10.28.34.200]) by maili.marvell.com (Postfix) with ESMTP id F14933F7040; Sun, 15 Dec 2019 23:55:07 -0800 (PST) From: Sunil Kumar Kori To: CC: , Sunil Kumar Kori Date: Mon, 16 Dec 2019 13:25:01 +0530 Message-ID: <20191216075501.15669-1-skori@marvell.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.95,18.0.572 definitions=2019-12-16_01:2019-12-16,2019-12-16 signatures=0 Subject: [dpdk-dev] [PATCH] bus/pci: restricted bus scanning to allowed devices X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" rte_bus_scan API scans all the available PCI devices irrespective of white or black listing parameters then further devices are probed based on white or black listing parameters. So unnecessary CPU cycles are wasted during rte_pci_scan. For Octeontx2 platform with core frequency 2.4 Ghz, rte_bus_scan consumes around 26ms to scan around 90 PCI devices but all may not be used by the application. So for the application which uses 2 NICs, rte_bus_scan consumes few microseconds and rest time is saved with this patch. Patch restricts devices to be scanned as per below mentioned conditions: - All devices will be scanned if no parameters are passed. - Only white listed devices will be scanned if white list is available. - All devices, except black listed, will be scanned if black list is available. Signed-off-by: Sunil Kumar Kori --- drivers/bus/pci/bsd/pci.c | 18 +++++++++++++++++- drivers/bus/pci/linux/pci.c | 11 +++++++++++ drivers/bus/pci/pci_common.c | 4 ++-- drivers/bus/pci/private.h | 20 ++++++++++++++++++++ 4 files changed, 50 insertions(+), 3 deletions(-) diff --git a/drivers/bus/pci/bsd/pci.c b/drivers/bus/pci/bsd/pci.c index ebbfeb13a..58fa7a241 100644 --- a/drivers/bus/pci/bsd/pci.c +++ b/drivers/bus/pci/bsd/pci.c @@ -338,6 +338,9 @@ rte_pci_scan(void) .match_buf_len = sizeof(matches), .matches = &matches[0], }; + struct rte_pci_device dummy_dev; + + memset(&dummy_dev, 0, sizeof(struct rte_pci_device)); /* for debug purposes, PCI can be disabled */ if (!rte_eal_has_pci()) @@ -357,9 +360,22 @@ rte_pci_scan(void) goto error; } - for (i = 0; i < conf_io.num_matches; i++) + for (i = 0; i < conf_io.num_matches; i++) { + /* Create dummy pci device to get devargs */ + dummy_dev.addr.domain = matches[i].pc_sel.pc_domain; + dummy_dev.addr.bus = matches[i].pc_sel.pc_bus; + dummy_dev.addr.devid = matches[i].pc_sel.pc_dev; + dummy_dev.addr.function = matches[i].pc_sel.pc_func; + dummy_dev.device.devargs = + pci_devargs_lookup(&dummy_dev); + + /* Check that device should be ignored or not */ + if (pci_ignore_device(&dummy_dev)) + continue; + if (pci_scan_one(fd, &matches[i]) < 0) goto error; + } dev_count += conf_io.num_matches; } while(conf_io.status == PCI_GETCONF_MORE_DEVS); diff --git a/drivers/bus/pci/linux/pci.c b/drivers/bus/pci/linux/pci.c index 740a2cdad..f6335810b 100644 --- a/drivers/bus/pci/linux/pci.c +++ b/drivers/bus/pci/linux/pci.c @@ -458,6 +458,9 @@ rte_pci_scan(void) DIR *dir; char dirname[PATH_MAX]; struct rte_pci_addr addr; + struct rte_pci_device dummy_dev; + + memset(&dummy_dev, 0, sizeof(struct rte_pci_device)); /* for debug purposes, PCI can be disabled */ if (!rte_eal_has_pci()) @@ -482,6 +485,14 @@ rte_pci_scan(void) if (parse_pci_addr_format(e->d_name, sizeof(e->d_name), &addr) != 0) continue; + /* Create dummy pci device to get devargs */ + dummy_dev.addr = addr; + dummy_dev.device.devargs = pci_devargs_lookup(&dummy_dev); + + /* Check that device should be ignored or not */ + if (pci_ignore_device(&dummy_dev)) + continue; + snprintf(dirname, sizeof(dirname), "%s/%s", rte_pci_get_sysfs_path(), e->d_name); diff --git a/drivers/bus/pci/pci_common.c b/drivers/bus/pci/pci_common.c index 3f5542076..ec063e832 100644 --- a/drivers/bus/pci/pci_common.c +++ b/drivers/bus/pci/pci_common.c @@ -42,7 +42,7 @@ const char *rte_pci_get_sysfs_path(void) return path; } -static struct rte_devargs *pci_devargs_lookup(struct rte_pci_device *dev) +struct rte_devargs *pci_devargs_lookup(struct rte_pci_device *dev) { struct rte_devargs *devargs; struct rte_pci_addr addr; @@ -589,7 +589,7 @@ pci_dma_unmap(struct rte_device *dev, void *addr, uint64_t iova, size_t len) return -1; } -static bool +bool pci_ignore_device(const struct rte_pci_device *dev) { struct rte_devargs *devargs = dev->device.devargs; diff --git a/drivers/bus/pci/private.h b/drivers/bus/pci/private.h index a205d4d9f..fc47768c6 100644 --- a/drivers/bus/pci/private.h +++ b/drivers/bus/pci/private.h @@ -42,6 +42,26 @@ int rte_pci_scan(void); void pci_name_set(struct rte_pci_device *dev); +/** + * Get the devargs of a PCI device. + * + * @param pci_dev + * PCI device to be validated + * @return + * devargs on succes, NULL otherwise + */ +struct rte_devargs *pci_devargs_lookup(struct rte_pci_device *pci_dev); + +/** + * Validate whether a pci device should be ignored or not. + * + * @param pci_dev + * PCI device to be validated + * @return + * 1 if device is to be ignored, 0 otherwise + */ +bool pci_ignore_device(const struct rte_pci_device *pci_dev); + /** * Add a PCI device to the PCI Bus (append to PCI Device list). This function * also updates the bus references of the PCI Device (and the generic device -- 2.17.1