Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757074Ab3HAUvn (ORCPT ); Thu, 1 Aug 2013 16:51:43 -0400 Received: from smtp151.iad.emailsrvr.com ([207.97.245.151]:57767 "EHLO smtp151.iad.emailsrvr.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751723Ab3HAUvl (ORCPT ); Thu, 1 Aug 2013 16:51:41 -0400 X-Greylist: delayed 646 seconds by postgrey-1.27 at vger.kernel.org; Thu, 01 Aug 2013 16:51:41 EDT Date: Thu, 1 Aug 2013 22:40:47 +0200 From: Andreas Herrmann To: Russell King , Rob Herring Cc: Marek Szyprowski , Hiroshi Doyu , Will Deacon , Nicolas Pitre , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH] ARM: dma-mapping: highbank: Restrict DMA to 32-bit addresses Message-ID: <20130801204047.GY20842@alberich> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2146 Lines: 66 Some devices on Calxeda ECX-2000 are restricted to 32-bit DMA. Thus the platform needs to set dma_zone_size, otherwise dma-mapping code is complaining, e.g. calxedaxgmac fff50000.ethernet: coherent DMA mask 0xffffffff is smaller than system GFP_DMA mask 0xffffffffffffffff Same is true for sata_highbank. For the latter dma_coherent_mask could be increased but due to the lack of DMA32 zone we need to adapt arm_dma_limit in general. Signed-off-by: Andreas Herrmann --- arch/arm/mach-highbank/Kconfig | 1 + arch/arm/mach-highbank/highbank.c | 3 +++ arch/arm/mm/dma-mapping.c | 4 ++++ 3 files changed, 8 insertions(+) diff --git a/arch/arm/mach-highbank/Kconfig b/arch/arm/mach-highbank/Kconfig index cd9fcb1..efe4961 100644 --- a/arch/arm/mach-highbank/Kconfig +++ b/arch/arm/mach-highbank/Kconfig @@ -18,3 +18,4 @@ config ARCH_HIGHBANK select PL320_MBOX select SPARSE_IRQ select USE_OF + select ZONE_DMA if ARM_LPAE diff --git a/arch/arm/mach-highbank/highbank.c b/arch/arm/mach-highbank/highbank.c index 8881579..31b26de 100644 --- a/arch/arm/mach-highbank/highbank.c +++ b/arch/arm/mach-highbank/highbank.c @@ -176,6 +176,9 @@ static const char *highbank_match[] __initconst = { }; DT_MACHINE_START(HIGHBANK, "Highbank") +#ifdef CONFIG_ZONE_DMA + .dma_zone_size = DMA_BIT_MASK(32), +#endif .smp = smp_ops(highbank_smp_ops), .init_irq = highbank_init_irq, .init_time = highbank_timer_init, diff --git a/arch/arm/mm/dma-mapping.c b/arch/arm/mm/dma-mapping.c index 7f9b179..f404dfc 100644 --- a/arch/arm/mm/dma-mapping.c +++ b/arch/arm/mm/dma-mapping.c @@ -651,7 +651,11 @@ static void *__dma_alloc(struct device *dev, size_t size, dma_addr_t *handle, if (!mask) return NULL; +#ifdef CONFIG_ARM_LPAE + if (mask <= 0xffffffffULL) +#else if (mask < 0xffffffffULL) +#endif gfp |= GFP_DMA; /* -- 1.7.9.5 -- 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/