Received: by 10.223.164.221 with SMTP id h29csp141368wrb; Fri, 3 Nov 2017 06:54:30 -0700 (PDT) X-Google-Smtp-Source: ABhQp+TuS3qIhha4/4q/Pk7LqPiOgHBPfKo5I8kyz2gH/iUdzkPrLyXZp9kVn2kIB/ZKZFmj1L/4 X-Received: by 10.84.242.136 with SMTP id d8mr6916895pll.307.1509717270684; Fri, 03 Nov 2017 06:54:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1509717270; cv=none; d=google.com; s=arc-20160816; b=LQ8A38c8X1b7sGsjWsMjYPOi2m0dttr87fvEjfTZlaCHsPfdpFw4khDGQ+awJVCwN1 L7TLI2VEKac6hcom6snP6MoP6sn8UA+7EWlxvnTTBsiqG6QWoNocu3G5xcaOBTScKpTp DT1gwKhaD4dU0AbcJYY4WjX7t1G7+63OPE4eezDk1WBbnk4iS9eHIMc07dUjKNruNAJ9 3pL5HvxzCCCnMrwUCIbvibVK0xv6sK3eNxoBAOT5kOaUV8YvPDyHuRfA9ZfaFqI6zPOx +WsQyIBB3OMqQP8eIOqfyEy5bDozASIIpUy//gUAE/Ujze5BA7smrZ860BWtemSbfujx 0IkA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=LXB43xZQF9NRykNSw1kR8xmU1g5DvvAOdyiBv8A1tHU=; b=PhCnJoPS9VeX6G1DLwF0sM5Ax50HEm6/CpdkQa1nikTOFzsfNi2NeV7C3KtNo4U1ry AVYiC0JEaF+lcjO05bMtG+1P6++R7KofMVyUjDePWmKTm7SYYKuXVSD/KbHQz1C/hyQa 2Y/R0o0IFt4s27bp3E1J99oWJKgBFRYChqQ/YCRthmr3OpYjTqmQqmA9c6O+OYT6c4SC 45yITMxYU3lOt78N5Ix8qp7wLBaKYj8IhNIxV02/pKWzi7V2XlMrUyXOR8ANDkf0KiVf NEFcr+coVNI3iWBVVa3qK7lRGgITqT0+i7sWMlLdZNMX5fzqGqHptAxYdLd18ma6ou4i R5yg== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id o7si6455240pgr.606.2017.11.03.06.54.17; Fri, 03 Nov 2017 06:54:30 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756560AbdKCNwI (ORCPT + 95 others); Fri, 3 Nov 2017 09:52:08 -0400 Received: from bastet.se.axis.com ([195.60.68.11]:51488 "EHLO bastet.se.axis.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756307AbdKCNrk (ORCPT ); Fri, 3 Nov 2017 09:47:40 -0400 Received: from localhost (localhost [127.0.0.1]) by bastet.se.axis.com (Postfix) with ESMTP id B7DC41896E; Fri, 3 Nov 2017 14:47:38 +0100 (CET) X-Virus-Scanned: Debian amavisd-new at bastet.se.axis.com Received: from bastet.se.axis.com ([IPv6:::ffff:127.0.0.1]) by localhost (bastet.se.axis.com [::ffff:127.0.0.1]) (amavisd-new, port 10024) with LMTP id ljPNEtnbxWh1; Fri, 3 Nov 2017 14:47:36 +0100 (CET) Received: from boulder03.se.axis.com (boulder03.se.axis.com [10.0.8.17]) by bastet.se.axis.com (Postfix) with ESMTPS id 7582118945; Fri, 3 Nov 2017 14:47:36 +0100 (CET) Received: from boulder03.se.axis.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 42DA01E07F; Fri, 3 Nov 2017 14:47:36 +0100 (CET) Received: from boulder03.se.axis.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 3524C1E07C; Fri, 3 Nov 2017 14:47:36 +0100 (CET) Received: from seth.se.axis.com (unknown [10.0.2.172]) by boulder03.se.axis.com (Postfix) with ESMTP; Fri, 3 Nov 2017 14:47:36 +0100 (CET) Received: from lnxartpec1.se.axis.com (lnxartpec1.se.axis.com [10.88.4.10]) by seth.se.axis.com (Postfix) with ESMTP id 289CE2629; Fri, 3 Nov 2017 14:47:36 +0100 (CET) Received: by lnxartpec1.se.axis.com (Postfix, from userid 20283) id 2507340101; Fri, 3 Nov 2017 14:47:36 +0100 (CET) From: Niklas Cassel To: Jingoo Han , Joao Pinto , Bjorn Helgaas Cc: Niklas Cassel , linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v4 01/17] PCI: dwc: Use the DMA-API to get the MSI address Date: Fri, 3 Nov 2017 14:47:05 +0100 Message-Id: <20171103134722.5532-2-niklas.cassel@axis.com> X-Mailer: git-send-email 2.14.2 In-Reply-To: <20171103134722.5532-1-niklas.cassel@axis.com> References: <20171103134722.5532-1-niklas.cassel@axis.com> X-TM-AS-GCONF: 00 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use the DMA-API to get the MSI address. This address will be written to our PCI config space and to the register which determines which AXI address the DWC IP will spoof for incoming MSI irqs. Since it is a PCIe endpoint device, rather than the CPU, that is supposed to write to the MSI address, the proper way to get the MSI address is by using the DMA API, not by using virt_to_phys(). Using virt_to_phys() might work on some systems, but using the DMA API should work on all systems. This is essentially the same thing as allocating a buffer in a driver to which the endpoint will write to. To do this, we use the DMA API. Signed-off-by: Niklas Cassel --- drivers/pci/dwc/pcie-designware-host.c | 15 ++++++++++++--- drivers/pci/dwc/pcie-designware.h | 3 ++- 2 files changed, 14 insertions(+), 4 deletions(-) diff --git a/drivers/pci/dwc/pcie-designware-host.c b/drivers/pci/dwc/pcie-designware-host.c index 81e2157a7cfb..33b52fe98a01 100644 --- a/drivers/pci/dwc/pcie-designware-host.c +++ b/drivers/pci/dwc/pcie-designware-host.c @@ -83,10 +83,19 @@ irqreturn_t dw_handle_msi_irq(struct pcie_port *pp) void dw_pcie_msi_init(struct pcie_port *pp) { + struct dw_pcie *pci = to_dw_pcie_from_pp(pp); + struct device *dev = pci->dev; + struct page *page; u64 msi_target; - pp->msi_data = __get_free_pages(GFP_KERNEL, 0); - msi_target = virt_to_phys((void *)pp->msi_data); + page = alloc_page(GFP_KERNEL | GFP_DMA32); + pp->msi_data = dma_map_page(dev, page, 0, PAGE_SIZE, DMA_FROM_DEVICE); + if (dma_mapping_error(dev, pp->msi_data)) { + dev_err(dev, "failed to map MSI data\n"); + __free_page(page); + return; + } + msi_target = (u64)pp->msi_data; /* program the msi_data */ dw_pcie_wr_own_conf(pp, PCIE_MSI_ADDR_LO, 4, @@ -187,7 +196,7 @@ static void dw_msi_setup_msg(struct pcie_port *pp, unsigned int irq, u32 pos) if (pp->ops->get_msi_addr) msi_target = pp->ops->get_msi_addr(pp); else - msi_target = virt_to_phys((void *)pp->msi_data); + msi_target = (u64)pp->msi_data; msg.address_lo = (u32)(msi_target & 0xffffffff); msg.address_hi = (u32)(msi_target >> 32 & 0xffffffff); diff --git a/drivers/pci/dwc/pcie-designware.h b/drivers/pci/dwc/pcie-designware.h index e5d9d77b778e..ecdede68522a 100644 --- a/drivers/pci/dwc/pcie-designware.h +++ b/drivers/pci/dwc/pcie-designware.h @@ -14,6 +14,7 @@ #ifndef _PCIE_DESIGNWARE_H #define _PCIE_DESIGNWARE_H +#include #include #include #include @@ -168,7 +169,7 @@ struct pcie_port { const struct dw_pcie_host_ops *ops; int msi_irq; struct irq_domain *irq_domain; - unsigned long msi_data; + dma_addr_t msi_data; DECLARE_BITMAP(msi_irq_in_use, MAX_MSI_IRQS); }; -- 2.14.2 From 1584695721793824329@xxx Tue Nov 21 17:00:09 +0000 2017 X-GM-THRID: 1584693816321755727 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread