Received: by 10.213.65.68 with SMTP id h4csp451533imn; Sun, 25 Mar 2018 04:03:38 -0700 (PDT) X-Google-Smtp-Source: AG47ELt4j0fmznjfpO1Q7sbRF9pEsG5yD/z++jdRVlKEAac0fkM9PqnjhTx4MFNZWU8JQFmGnQv5 X-Received: by 10.99.54.73 with SMTP id d70mr14629488pga.86.1521975818369; Sun, 25 Mar 2018 04:03:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521975818; cv=none; d=google.com; s=arc-20160816; b=HZNm4SP2EL1XF6mr90d0vx1k/d4/HOyQt1membNuS26NdNwwqlLrDVT00aE1n1Xpqi cVjv+jS9dGvbuAxAkNhI7wSUjMMspEhQqE8/za46zZExRqRs5Hk2kC+RxLWSWFpHmLju T8tIlkWeUkHEobCHDXsdIAROIsf3MYCJvEsFjpzdgn1WzOk01ny1R5jWx66HXY00VVm4 th42oSAWqDlI0Z+7c6VCkazlbPL//FGqTRWouwXcDWcRCHMurlEMas47h0ztBVmCX0+S SKK2bpUI9hcLy6J5TP3DnhetN20+NIxRDFHwTF/PFnhsRMLMl5smj55ClSMjIAe73M6W nLag== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:to:from :dkim-signature:arc-authentication-results; bh=YkgOg1ftodmovEOpRZL7mrHfuaWe9jEaNCSmD6Wg7uU=; b=Q3+Bl3q7JYvq5ZORU5WHbrqsPCTa9VaPddSuFqmA29dpqtEsmsBxbDmmCSTE1CTawq DwhBC3Gzi0nQfI9/dxZEN9/RnmxAWQCG5/YWjNYmj+JQtANKwAkhDrFsrFzO91kZHwGe yHEiu+Gwh/FYbNGW/nohFuAqqM8ScDpn0WH+pdf+UFeQz1rtowbw8IN+JE69Sr+DofUx X3oDQ4KarY8NpYePSCMoWLD1LbjGXo2nrBiy6A2MvRI5sfS2q4srq1xkWLova+nviStt dBAVnV+rcxaAyY9xxpGj69r7KAyY1JoYHa/cw/JUz4xuf0DyS4Wp/CKPKyd6WatBzWzD EHlg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=cWDXNLoD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k4-v6si486832pls.8.2018.03.25.04.03.24; Sun, 25 Mar 2018 04:03:38 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=cWDXNLoD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753355AbeCYLBk (ORCPT + 99 others); Sun, 25 Mar 2018 07:01:40 -0400 Received: from mail-wm0-f67.google.com ([74.125.82.67]:35829 "EHLO mail-wm0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751985AbeCYLAE (ORCPT ); Sun, 25 Mar 2018 07:00:04 -0400 Received: by mail-wm0-f67.google.com with SMTP id r82so10571066wme.0; Sun, 25 Mar 2018 04:00:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:subject:date:message-id:in-reply-to:references:mime-version :content-transfer-encoding; bh=YkgOg1ftodmovEOpRZL7mrHfuaWe9jEaNCSmD6Wg7uU=; b=cWDXNLoDZsWhV6kCR1AJio2GdwV6uuR7q2VzoRdCUrG1NV9n4hwwG0xnYp8oxBqNxT 53xjEMTLPbl3SsQ/k5wIcJaU73OEOW0oNAa9H4BRBuaEuZWgmHL2Cqa6O6+KdtWaPSZV toQ+ja3/IBHQ0zJvq0NmdxLSABv6k35287WIP/DFz3v1eSewnjcsJLdNIEfpCUbQmhIG ztCqSGnWKHq+ubJd1UuivLQFhVpPs9CAyfYdZm7eM+iZ5+Nazaxb7LaSkOnq3GWZrzfE UA5QTeb/RxL5fV2jFMkBaQuQ7zjeVp5qHpGHfxCMJj1zjnZ/ynL0aNcH7kUlfxyphMcG 5AKg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=YkgOg1ftodmovEOpRZL7mrHfuaWe9jEaNCSmD6Wg7uU=; b=qVlWKX9XwvvGnm8UdKJrPpDY3RPbZPDWsTTzi8HGUgyvcoYbfH2vqjQthDO+fYK6PZ xbOBES5FP2ThyFml5rE4sZFSy+O9xMSIwo9KeHCngNYfFIEzEAGHcZ9zF+U0s67tReeF gPmJ1ewrlFUSyuoj30wWQhileExZhyjXKlS+MZ9zdua/3+QUbTxyBbArp5IXaBrJ4egV 6zY3+B0fjlXo+mEODxuFnSo+BnTdg6BBh6aG5doVkagnbM+YguMyEq9NKwY2PBFlTWk6 Ie8EU7wFmuO/dVPVjpR9D4wCpGDvQ0phvdOFThjONTENYEvyyI0CWysbjZ5PX2nLHuMM ztsg== X-Gm-Message-State: AElRT7GBBqOxOxZ3nw0bn2D1as02/wjO1mbZ3trUf0XZWkO7CU54eww4 uQS4TVLFKNEwmKA6Ylo4Zs4= X-Received: by 10.28.109.27 with SMTP id i27mr13580230wmc.109.1521975603132; Sun, 25 Mar 2018 04:00:03 -0700 (PDT) Received: from baker.fritz.box ([2a02:908:1257:4460:80f2:8bcd:4355:2edc]) by smtp.gmail.com with ESMTPSA id z3sm20492230wme.3.2018.03.25.04.00.02 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sun, 25 Mar 2018 04:00:02 -0700 (PDT) From: "=?UTF-8?q?Christian=20K=C3=B6nig?=" X-Google-Original-From: =?UTF-8?q?Christian=20K=C3=B6nig?= To: linaro-mm-sig@lists.linaro.org, linux-media@vger.kernel.org, dri-devel@lists.freedesktop.org, amd-gfx@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: [PATCH 2/8] PCI: Add pci_find_common_upstream_dev() Date: Sun, 25 Mar 2018 12:59:54 +0200 Message-Id: <20180325110000.2238-2-christian.koenig@amd.com> X-Mailer: git-send-email 2.14.1 In-Reply-To: <20180325110000.2238-1-christian.koenig@amd.com> References: <20180325110000.2238-1-christian.koenig@amd.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: "wdavis@nvidia.com" Add an interface to find the first device which is upstream of both devices. Signed-off-by: Will Davis Signed-off-by: Christian König --- drivers/pci/search.c | 24 ++++++++++++++++++++++++ include/linux/pci.h | 2 ++ 2 files changed, 26 insertions(+) diff --git a/drivers/pci/search.c b/drivers/pci/search.c index bc1e023f1353..446648f4238b 100644 --- a/drivers/pci/search.c +++ b/drivers/pci/search.c @@ -393,3 +393,27 @@ int pci_dev_present(const struct pci_device_id *ids) return 0; } EXPORT_SYMBOL(pci_dev_present); + +/** + * pci_find_common_upstream_dev - Returns the first common upstream device + * @dev: the PCI device from which the bus hierarchy walk will start + * @other: the PCI device whose bus number will be used for the search + * + * Walks up the bus hierarchy from the @dev device, looking for the first bus + * which the @other device is downstream of. Returns %NULL if the devices do + * not share any upstream devices. + */ +struct pci_dev *pci_find_common_upstream_dev(struct pci_dev *dev, + struct pci_dev *other) +{ + struct pci_dev *pdev = dev; + + while (pdev != NULL) { + if ((other->bus->number >= pdev->bus->busn_res.start) && + (other->bus->number <= pdev->bus->busn_res.end)) + return pdev; + pdev = pci_upstream_bridge(pdev); + } + + return NULL; +} diff --git a/include/linux/pci.h b/include/linux/pci.h index 024a1beda008..0d29f5cdcb04 100644 --- a/include/linux/pci.h +++ b/include/linux/pci.h @@ -956,6 +956,8 @@ static inline struct pci_dev *pci_get_bus_and_slot(unsigned int bus, } struct pci_dev *pci_get_class(unsigned int class, struct pci_dev *from); int pci_dev_present(const struct pci_device_id *ids); +struct pci_dev *pci_find_common_upstream_dev(struct pci_dev *from, + struct pci_dev *to); int pci_bus_read_config_byte(struct pci_bus *bus, unsigned int devfn, int where, u8 *val); -- 2.14.1