From mboxrd@z Thu Jan 1 00:00:00 1970 From: Xiao Wang Subject: [PATCH] igb_uio: allow multi-process access Date: Fri, 8 Dec 2017 17:57:33 -0800 Message-ID: <1512784653-128951-1-git-send-email-xiao.w.wang@intel.com> Cc: dev@dpdk.org, Xiao Wang To: ferruh.yigit@intel.com Return-path: Received: from mga05.intel.com (mga05.intel.com [192.55.52.43]) by dpdk.org (Postfix) with ESMTP id 4F93B37B1 for ; Sat, 9 Dec 2017 02:55:14 +0100 (CET) List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" In some case, one device are accessed by different processes via different BARs, so one uio device may be opened by more than one process, for this case we just need to enable interrupt once, and pci_clear_master only when the last process closed. Fixes: 5f6ff30dc507 ("igb_uio: fix interrupt enablement after FLR in VM") Signed-off-by: Xiao Wang --- lib/librte_eal/linuxapp/igb_uio/igb_uio.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/lib/librte_eal/linuxapp/igb_uio/igb_uio.c b/lib/librte_eal/linuxapp/igb_uio/igb_uio.c index a3a98c1..c239d98 100644 --- a/lib/librte_eal/linuxapp/igb_uio/igb_uio.c +++ b/lib/librte_eal/linuxapp/igb_uio/igb_uio.c @@ -45,6 +45,7 @@ struct rte_uio_pci_dev { struct uio_info info; struct pci_dev *pdev; enum rte_intr_mode mode; + uint32_t ref_cnt; }; static char *intr_mode; @@ -336,6 +337,9 @@ struct rte_uio_pci_dev { struct pci_dev *dev = udev->pdev; int err; + if (++(udev->ref_cnt) > 1) + return 0; + /* set bus master, which was cleared by the reset function */ pci_set_master(dev); @@ -354,6 +358,9 @@ struct rte_uio_pci_dev { struct rte_uio_pci_dev *udev = info->priv; struct pci_dev *dev = udev->pdev; + if (--(udev->ref_cnt) > 0) + return 0; + /* disable interrupts */ igbuio_pci_disable_interrupts(udev); -- 1.8.3.1