Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755582AbbKRMmf (ORCPT ); Wed, 18 Nov 2015 07:42:35 -0500 Received: from mout.kundenserver.de ([217.72.192.74]:61195 "EHLO mout.kundenserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751513AbbKRMme (ORCPT ); Wed, 18 Nov 2015 07:42:34 -0500 From: Arnd Bergmann To: Robin Murphy Cc: Suravee Suthikulpanit , bhelgaas@google.com, rjw@rjwysocki.net, lenb@kernel.org, catalin.marinas@arm.com, will.deacon@arm.com, thomas.lendacky@amd.com, herbert@gondor.apana.org.au, linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, linux-acpi@vger.kernel.org, hanjun.guo@linaro.org, davem@davemloft.net, linux-arm-kernel@lists.infradead.org Subject: Re: [PATCH V5 8/9] PCI: OF: Move of_pci_dma_configure() to pci_dma_configure() Date: Wed, 18 Nov 2015 13:41:39 +0100 Message-ID: <3822315.uJPjk3L2zB@wuerfel> User-Agent: KMail/4.11.5 (Linux/3.16.0-10-generic; KDE/4.11.5; x86_64; ; ) In-Reply-To: <564C6860.4000002@arm.com> References: <1446072654-5608-1-git-send-email-Suravee.Suthikulpanit@amd.com> <564B4111.6010805@arm.com> <564C6860.4000002@arm.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" X-Provags-ID: V03:K0:ky+STEmnWqMr5DNFeADEcAkYwoWC5uiTpY/+PMWEc/2Gb55hn1M PnlhTyMygCoVIIfx5Fy+V/Yk7jWBH8SouDvt1BwKn15VrKRnvGk+M8ze1Yq3+bUS8VJt4QV 78pNexNoNSnLhK082um8Us1jZuRYItU6K4P7+w8r0X5jWiJH84g0VsmQlnYH/8BybWysiM1 MML9EroX3jHHoOta9nsSA== X-UI-Out-Filterresults: notjunk:1;V01:K0:Xxv95GuX6fo=:Uck+YEHUCHOAuvNJzaNF7P PZ1D8APiisoW1khTsbLqhzzfSaQTEU7Odik0++Z2wbQnHgwHcYEByd3J/akkW6BhD8TQ22xEK 4vZGch6KLTC9kQJGcT7Ckbq2CYPlJ1VZ3i9shdBzOulEORvWCUYZvMQ6YSYy5TmJlu/TTfvJk qhutdGVNxPxwpoh3+5/yi7drufLugHVgs+lpTo6yjqS4dqGw2U8Egi1F/iMSc58En8AEW8mGA 8+4TQ8IaBBttU8KGLgdXWn7cILOV3jvE8jigV24kRcGOmvXdoZc1ta/IQymTf/uHqqGTt4xes ObqOkS+CHvR+18Fxxy5kKyPu0OLrWdP+CATG3RT4QJit+GF4rw/Jilkzu4NMQQ7laCFkdpXaq e0hFs2/QpJQLMYtmG5y1J4Q0310LtgCaJzC2ROiy9L00KjJPCGQ2YhmiobQZs2ZF6MI4sin83 OKFuM0WTAjkJU+DwlvLNpPI/wkJH1DD6+olUKNYuDNYiJUgahG3DYP8rx7jS2/YeZ3XkIhMK8 TCKipWOCJAT1kafxVNiRLlEvukIW9qM+x+lq/1XJcQU2PzupSsVMUQwGF3Y8XctSEvl5D0O2g 723umczW+TwqojHtBdAt667OxI8ihq/iB8EiUiDkNEj9kTUK8wgZCI2G7ftUEAAvlXnfy+h+Z S/HaWaZbRv1Ao1Pt0+sX+hzp6TYsfLd2wmxH+vB7kIpfT/6c+ETz56fXXAatP9elmEKroz4Mn n2r/GjzktUFHv5Sl Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1995 Lines: 43 On Wednesday 18 November 2015 12:00:32 Robin Murphy wrote: > On 17/11/15 15:00, Robin Murphy wrote: > > On 28/10/15 22:50, Suravee Suthikulpanit wrote: > >> Signed-off-by: Suravee Suthikulpanit > >> Acked-by: Rob Herring > >> Acked-by: Bjorn Helgaas > >> Reviewed-by: Hanjun Guo > >> CC: Rafael J. Wysocki > [...] > >> +/** > >> + * pci_dma_configure - Setup DMA configuration > >> + * @dev: ptr to pci_dev struct of the PCI device > >> + * > >> + * Function to update PCI devices's DMA configuration using the same > >> + * info from the OF node of host bridge's parent (if any). > >> + */ > >> +static void pci_dma_configure(struct pci_dev *dev) > >> +{ > >> + struct device *bridge = pci_get_host_bridge_device(dev); > >> + > >> + if (IS_ENABLED(CONFIG_OF) && dev->dev.of_node) { > > > > Previously I was seeing of_dma_configure, and thus of_iommu_configure, > > called for every PCI device on Juno. The check above now prevents this > > happening, since the PCI devices are probed directly from the bus and > > don't have OF nodes of their own. They now get left in some > > half-configured state where arch_setup_dma_ops isn't called either. > > Just to follow up on that, Arnd's patch to tidy up dma_get_ops (now > queued[1]) makes this even worse, since preventing arch_setup_dma_ops > being called means the PCI devices now get the dummy DMA ops which leave > the drivers failing to probe at all, IOMMU hacks or not Ok, glad we found that with my patch then. We really have to configure the DMA (offset/size/coherency/iommu) for all devices that might be masters, otherwise things can randomly go wrong. ARnd -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/