From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from hqemgate15.nvidia.com ([216.228.121.64]:13419 "EHLO hqemgate15.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751005AbbIORLm (ORCPT ); Tue, 15 Sep 2015 13:11:42 -0400 From: Will Davis To: Bjorn Helgaas CC: Alex Williamson , Joerg Roedel , , , Konrad Wilk , Mark Hounschell , "David S. Miller" , Jonathan Corbet , Terence Ripperda , John Hubbard , Jerome Glisse , Will Davis Subject: [PATCH 10/22] PCI: Add pci_resource_to_peer() Date: Tue, 15 Sep 2015 12:10:55 -0500 Message-ID: <1442337067-22964-11-git-send-email-wdavis@nvidia.com> In-Reply-To: <1442337067-22964-1-git-send-email-wdavis@nvidia.com> References: <1442337067-22964-1-git-send-email-wdavis@nvidia.com> MIME-Version: 1.0 Content-Type: text/plain Sender: linux-pci-owner@vger.kernel.org List-ID: Add helper to convert a struct resource to a peer DMA address. Signed-off-by: Will Davis --- include/linux/pci.h | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/include/linux/pci.h b/include/linux/pci.h index db0cb51..2a9deff 100644 --- a/include/linux/pci.h +++ b/include/linux/pci.h @@ -1508,6 +1508,22 @@ static inline void pci_resource_to_user(const struct pci_dev *dev, int bar, } #endif /* HAVE_ARCH_PCI_RESOURCE_TO_USER */ +#ifdef CONFIG_HAS_DMA_P2P +static inline bool pci_resource_to_peer(struct pci_dev *dev, + struct pci_dev *peer, + struct resource *res, + dma_peer_addr_t *peer_addr) { + if (pci_peer_traffic_supported(dev, peer)) { + struct pci_bus_region region; + + pcibios_resource_to_bus(dev->bus, ®ion, res); + *peer_addr = region.start; + return true; + } + + return false; +} +#endif /* CONFIG_HAS_DMA_P2P */ /* * The world is not perfect and supplies us with broken PCI devices. -- 2.5.1