* [PATCH 0/2] Consolidate zone adjustment @ 2011-05-11 16:24 Russell King - ARM Linux 2011-05-11 16:25 ` [PATCH 1/2] ARM: Replace platform definition of ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS Russell King - ARM Linux ` (2 more replies) 0 siblings, 3 replies; 9+ messages in thread From: Russell King - ARM Linux @ 2011-05-11 16:24 UTC (permalink / raw) To: linux-arm-kernel This patch mini-series consolidates the adjustment to system zones which some of our platforms require. Rather than having each platform/machine class specify ISA_DMA_THRESHOLD, MAX_DMA_ADDRESS and an arch_adjust_zones function, they really only need to provide a single sizing definition, which in this series will be called ARM_DMA_ZONE_SIZE. arch/arm/common/sa1111.c | 8 ------- arch/arm/include/asm/dma.h | 4 ++- arch/arm/include/asm/memory.h | 10 ++------ arch/arm/mach-davinci/include/mach/memory.h | 18 +---------------- arch/arm/mach-h720x/include/mach/memory.h | 3 +- arch/arm/mach-ixp4xx/common-pci.c | 23 ---------------------- arch/arm/mach-ixp4xx/include/mach/memory.h | 12 +--------- arch/arm/mach-pxa/cm-x2xx-pci.c | 27 -------------------------- arch/arm/mach-pxa/include/mach/memory.h | 10 +------- arch/arm/mach-realview/core.c | 19 ------------------ arch/arm/mach-realview/include/mach/memory.h | 9 +------ arch/arm/mach-sa1100/include/mach/memory.h | 12 +---------- arch/arm/mach-shark/include/mach/memory.h | 20 +------------------ arch/arm/mm/init.c | 23 +++++++++++++++++++++- 14 files changed, 38 insertions(+), 160 deletions(-) ^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH 1/2] ARM: Replace platform definition of ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS 2011-05-11 16:24 [PATCH 0/2] Consolidate zone adjustment Russell King - ARM Linux @ 2011-05-11 16:25 ` Russell King - ARM Linux 2011-05-11 17:22 ` Catalin Marinas 2011-05-12 7:16 ` Nicolas Pitre 2011-05-11 16:25 ` [PATCH 2/2] ARM: use ARM_DMA_ZONE_SIZE to adjust the zone sizes Russell King - ARM Linux 2011-05-19 10:56 ` [PATCH 0/2] Consolidate zone adjustment Nori, Sekhar 2 siblings, 2 replies; 9+ messages in thread From: Russell King - ARM Linux @ 2011-05-11 16:25 UTC (permalink / raw) To: linux-arm-kernel The values of ISA_DMA_THRESHOLD and MAX_DMA_ADDRESS are related; one is the physical/bus address, the other is the virtual address. Both need to be kept in step, so rather than having platforms define both, allow them to define a single macro which sets both of these macros appropraitely. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> --- arch/arm/include/asm/dma.h | 4 +++- arch/arm/include/asm/memory.h | 4 +++- arch/arm/mach-davinci/include/mach/memory.h | 3 +-- arch/arm/mach-h720x/include/mach/memory.h | 3 +-- arch/arm/mach-ixp4xx/include/mach/memory.h | 3 +-- arch/arm/mach-pxa/include/mach/memory.h | 3 +-- arch/arm/mach-realview/include/mach/memory.h | 3 +-- arch/arm/mach-sa1100/include/mach/memory.h | 3 +-- arch/arm/mach-shark/include/mach/memory.h | 3 +-- 9 files changed, 13 insertions(+), 16 deletions(-) diff --git a/arch/arm/include/asm/dma.h b/arch/arm/include/asm/dma.h index ca51143..4200554 100644 --- a/arch/arm/include/asm/dma.h +++ b/arch/arm/include/asm/dma.h @@ -6,8 +6,10 @@ /* * This is the maximum virtual address which can be DMA'd from. */ -#ifndef MAX_DMA_ADDRESS +#ifndef ARM_DMA_ZONE_SIZE #define MAX_DMA_ADDRESS 0xffffffff +#else +#define MAX_DMA_ADDRESS (PAGE_OFFSET + ARM_DMA_ZONE_SIZE) #endif #ifdef CONFIG_ISA_DMA_API diff --git a/arch/arm/include/asm/memory.h b/arch/arm/include/asm/memory.h index 431077c..ee5ff41 100644 --- a/arch/arm/include/asm/memory.h +++ b/arch/arm/include/asm/memory.h @@ -209,8 +209,10 @@ static inline unsigned long __phys_to_virt(unsigned long x) * allocations. This must be the smallest DMA mask in the system, * so a successful GFP_DMA allocation will always satisfy this. */ -#ifndef ISA_DMA_THRESHOLD +#ifndef ARM_DMA_ZONE_SIZE #define ISA_DMA_THRESHOLD (0xffffffffULL) +#else +#define ISA_DMA_THRESHOLD (PHYS_OFFSET + ARM_DMA_ZONE_SIZE - 1) #endif #ifndef arch_adjust_zones diff --git a/arch/arm/mach-davinci/include/mach/memory.h b/arch/arm/mach-davinci/include/mach/memory.h index 7882272..8d27246 100644 --- a/arch/arm/mach-davinci/include/mach/memory.h +++ b/arch/arm/mach-davinci/include/mach/memory.h @@ -59,8 +59,7 @@ __arch_adjust_zones(unsigned long *size, unsigned long *holes) #define arch_adjust_zones(zone_size, holes) \ if ((meminfo.bank[0].size >> 20) > 128) __arch_adjust_zones(zone_size, holes) -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + (128<<20) - 1) -#define MAX_DMA_ADDRESS (PAGE_OFFSET + (128<<20)) +#define ARM_DMA_ZONE_SIZE SZ_128M #endif diff --git a/arch/arm/mach-h720x/include/mach/memory.h b/arch/arm/mach-h720x/include/mach/memory.h index 9d36876..b0b3bae 100644 --- a/arch/arm/mach-h720x/include/mach/memory.h +++ b/arch/arm/mach-h720x/include/mach/memory.h @@ -13,7 +13,6 @@ * There should not be more than (0xd0000000 - 0xc0000000) * bytes of RAM. */ -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_256M - 1) -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_256M) +#define ARM_DMA_ZONE_SIZE SZ_256M #endif diff --git a/arch/arm/mach-ixp4xx/include/mach/memory.h b/arch/arm/mach-ixp4xx/include/mach/memory.h index 6d388c9..a5c26f8 100644 --- a/arch/arm/mach-ixp4xx/include/mach/memory.h +++ b/arch/arm/mach-ixp4xx/include/mach/memory.h @@ -21,8 +21,7 @@ void ixp4xx_adjust_zones(unsigned long *size, unsigned long *holes); #define arch_adjust_zones(size, holes) \ ixp4xx_adjust_zones(size, holes) -#define ISA_DMA_THRESHOLD (SZ_64M - 1) -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_64M) +#define ARM_DMA_ZONE_SIZE SZ_64M #endif diff --git a/arch/arm/mach-pxa/include/mach/memory.h b/arch/arm/mach-pxa/include/mach/memory.h index 7f68724..57a0b68 100644 --- a/arch/arm/mach-pxa/include/mach/memory.h +++ b/arch/arm/mach-pxa/include/mach/memory.h @@ -23,8 +23,7 @@ void cmx2xx_pci_adjust_zones(unsigned long *size, unsigned long *holes); #define arch_adjust_zones(size, holes) \ cmx2xx_pci_adjust_zones(size, holes) -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_64M - 1) -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_64M) +#define ARM_DMA_ZONE_SIZE SZ_64M #endif #endif diff --git a/arch/arm/mach-realview/include/mach/memory.h b/arch/arm/mach-realview/include/mach/memory.h index e05fc2c..973428d 100644 --- a/arch/arm/mach-realview/include/mach/memory.h +++ b/arch/arm/mach-realview/include/mach/memory.h @@ -34,8 +34,7 @@ extern void realview_adjust_zones(unsigned long *size, unsigned long *hole); #define arch_adjust_zones(size, hole) \ realview_adjust_zones(size, hole) -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_256M - 1) -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_256M) +#define ARM_DMA_ZONE_SIZE SZ_256M #endif #ifdef CONFIG_SPARSEMEM diff --git a/arch/arm/mach-sa1100/include/mach/memory.h b/arch/arm/mach-sa1100/include/mach/memory.h index a44da6a..090b829 100644 --- a/arch/arm/mach-sa1100/include/mach/memory.h +++ b/arch/arm/mach-sa1100/include/mach/memory.h @@ -22,8 +22,7 @@ void sa1111_adjust_zones(unsigned long *size, unsigned long *holes); #define arch_adjust_zones(size, holes) \ sa1111_adjust_zones(size, holes) -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_1M - 1) -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_1M) +#define ARM_DMA_ZONE_SIZE SZ_1M #endif #endif diff --git a/arch/arm/mach-shark/include/mach/memory.h b/arch/arm/mach-shark/include/mach/memory.h index 9afb170..48fe84b 100644 --- a/arch/arm/mach-shark/include/mach/memory.h +++ b/arch/arm/mach-shark/include/mach/memory.h @@ -32,8 +32,7 @@ static inline void __arch_adjust_zones(unsigned long *zone_size, unsigned long * #define arch_adjust_zones(size, holes) \ __arch_adjust_zones(size, holes) -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_4M - 1) -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_4M) +#define ARM_DMA_ZONE_SIZE SZ_4M #endif -- 1.7.4.4 ^ permalink raw reply related [flat|nested] 9+ messages in thread
* [PATCH 1/2] ARM: Replace platform definition of ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS 2011-05-11 16:25 ` [PATCH 1/2] ARM: Replace platform definition of ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS Russell King - ARM Linux @ 2011-05-11 17:22 ` Catalin Marinas 2011-05-12 7:16 ` Nicolas Pitre 1 sibling, 0 replies; 9+ messages in thread From: Catalin Marinas @ 2011-05-11 17:22 UTC (permalink / raw) To: linux-arm-kernel On Wed, 2011-05-11 at 17:25 +0100, Russell King - ARM Linux wrote: > The values of ISA_DMA_THRESHOLD and MAX_DMA_ADDRESS are related; one is > the physical/bus address, the other is the virtual address. Both need > to be kept in step, so rather than having platforms define both, allow > them to define a single macro which sets both of these macros > appropraitely. > > Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> Acked-by: Catalin Marinas <catalin.marinas@arm.com> ^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH 1/2] ARM: Replace platform definition of ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS 2011-05-11 16:25 ` [PATCH 1/2] ARM: Replace platform definition of ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS Russell King - ARM Linux 2011-05-11 17:22 ` Catalin Marinas @ 2011-05-12 7:16 ` Nicolas Pitre 1 sibling, 0 replies; 9+ messages in thread From: Nicolas Pitre @ 2011-05-12 7:16 UTC (permalink / raw) To: linux-arm-kernel On Wed, 11 May 2011, Russell King - ARM Linux wrote: > The values of ISA_DMA_THRESHOLD and MAX_DMA_ADDRESS are related; one is > the physical/bus address, the other is the virtual address. Both need > to be kept in step, so rather than having platforms define both, allow > them to define a single macro which sets both of these macros > appropraitely. > > Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> Acked-by: Nicolas Pitre <nicolas.pitre@linaro.org> > --- > arch/arm/include/asm/dma.h | 4 +++- > arch/arm/include/asm/memory.h | 4 +++- > arch/arm/mach-davinci/include/mach/memory.h | 3 +-- > arch/arm/mach-h720x/include/mach/memory.h | 3 +-- > arch/arm/mach-ixp4xx/include/mach/memory.h | 3 +-- > arch/arm/mach-pxa/include/mach/memory.h | 3 +-- > arch/arm/mach-realview/include/mach/memory.h | 3 +-- > arch/arm/mach-sa1100/include/mach/memory.h | 3 +-- > arch/arm/mach-shark/include/mach/memory.h | 3 +-- > 9 files changed, 13 insertions(+), 16 deletions(-) > > diff --git a/arch/arm/include/asm/dma.h b/arch/arm/include/asm/dma.h > index ca51143..4200554 100644 > --- a/arch/arm/include/asm/dma.h > +++ b/arch/arm/include/asm/dma.h > @@ -6,8 +6,10 @@ > /* > * This is the maximum virtual address which can be DMA'd from. > */ > -#ifndef MAX_DMA_ADDRESS > +#ifndef ARM_DMA_ZONE_SIZE > #define MAX_DMA_ADDRESS 0xffffffff > +#else > +#define MAX_DMA_ADDRESS (PAGE_OFFSET + ARM_DMA_ZONE_SIZE) > #endif > > #ifdef CONFIG_ISA_DMA_API > diff --git a/arch/arm/include/asm/memory.h b/arch/arm/include/asm/memory.h > index 431077c..ee5ff41 100644 > --- a/arch/arm/include/asm/memory.h > +++ b/arch/arm/include/asm/memory.h > @@ -209,8 +209,10 @@ static inline unsigned long __phys_to_virt(unsigned long x) > * allocations. This must be the smallest DMA mask in the system, > * so a successful GFP_DMA allocation will always satisfy this. > */ > -#ifndef ISA_DMA_THRESHOLD > +#ifndef ARM_DMA_ZONE_SIZE > #define ISA_DMA_THRESHOLD (0xffffffffULL) > +#else > +#define ISA_DMA_THRESHOLD (PHYS_OFFSET + ARM_DMA_ZONE_SIZE - 1) > #endif > > #ifndef arch_adjust_zones > diff --git a/arch/arm/mach-davinci/include/mach/memory.h b/arch/arm/mach-davinci/include/mach/memory.h > index 7882272..8d27246 100644 > --- a/arch/arm/mach-davinci/include/mach/memory.h > +++ b/arch/arm/mach-davinci/include/mach/memory.h > @@ -59,8 +59,7 @@ __arch_adjust_zones(unsigned long *size, unsigned long *holes) > #define arch_adjust_zones(zone_size, holes) \ > if ((meminfo.bank[0].size >> 20) > 128) __arch_adjust_zones(zone_size, holes) > > -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + (128<<20) - 1) > -#define MAX_DMA_ADDRESS (PAGE_OFFSET + (128<<20)) > +#define ARM_DMA_ZONE_SIZE SZ_128M > > #endif > > diff --git a/arch/arm/mach-h720x/include/mach/memory.h b/arch/arm/mach-h720x/include/mach/memory.h > index 9d36876..b0b3bae 100644 > --- a/arch/arm/mach-h720x/include/mach/memory.h > +++ b/arch/arm/mach-h720x/include/mach/memory.h > @@ -13,7 +13,6 @@ > * There should not be more than (0xd0000000 - 0xc0000000) > * bytes of RAM. > */ > -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_256M - 1) > -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_256M) > +#define ARM_DMA_ZONE_SIZE SZ_256M > > #endif > diff --git a/arch/arm/mach-ixp4xx/include/mach/memory.h b/arch/arm/mach-ixp4xx/include/mach/memory.h > index 6d388c9..a5c26f8 100644 > --- a/arch/arm/mach-ixp4xx/include/mach/memory.h > +++ b/arch/arm/mach-ixp4xx/include/mach/memory.h > @@ -21,8 +21,7 @@ void ixp4xx_adjust_zones(unsigned long *size, unsigned long *holes); > #define arch_adjust_zones(size, holes) \ > ixp4xx_adjust_zones(size, holes) > > -#define ISA_DMA_THRESHOLD (SZ_64M - 1) > -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_64M) > +#define ARM_DMA_ZONE_SIZE SZ_64M > > #endif > > diff --git a/arch/arm/mach-pxa/include/mach/memory.h b/arch/arm/mach-pxa/include/mach/memory.h > index 7f68724..57a0b68 100644 > --- a/arch/arm/mach-pxa/include/mach/memory.h > +++ b/arch/arm/mach-pxa/include/mach/memory.h > @@ -23,8 +23,7 @@ void cmx2xx_pci_adjust_zones(unsigned long *size, unsigned long *holes); > #define arch_adjust_zones(size, holes) \ > cmx2xx_pci_adjust_zones(size, holes) > > -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_64M - 1) > -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_64M) > +#define ARM_DMA_ZONE_SIZE SZ_64M > #endif > > #endif > diff --git a/arch/arm/mach-realview/include/mach/memory.h b/arch/arm/mach-realview/include/mach/memory.h > index e05fc2c..973428d 100644 > --- a/arch/arm/mach-realview/include/mach/memory.h > +++ b/arch/arm/mach-realview/include/mach/memory.h > @@ -34,8 +34,7 @@ extern void realview_adjust_zones(unsigned long *size, unsigned long *hole); > #define arch_adjust_zones(size, hole) \ > realview_adjust_zones(size, hole) > > -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_256M - 1) > -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_256M) > +#define ARM_DMA_ZONE_SIZE SZ_256M > #endif > > #ifdef CONFIG_SPARSEMEM > diff --git a/arch/arm/mach-sa1100/include/mach/memory.h b/arch/arm/mach-sa1100/include/mach/memory.h > index a44da6a..090b829 100644 > --- a/arch/arm/mach-sa1100/include/mach/memory.h > +++ b/arch/arm/mach-sa1100/include/mach/memory.h > @@ -22,8 +22,7 @@ void sa1111_adjust_zones(unsigned long *size, unsigned long *holes); > #define arch_adjust_zones(size, holes) \ > sa1111_adjust_zones(size, holes) > > -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_1M - 1) > -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_1M) > +#define ARM_DMA_ZONE_SIZE SZ_1M > > #endif > #endif > diff --git a/arch/arm/mach-shark/include/mach/memory.h b/arch/arm/mach-shark/include/mach/memory.h > index 9afb170..48fe84b 100644 > --- a/arch/arm/mach-shark/include/mach/memory.h > +++ b/arch/arm/mach-shark/include/mach/memory.h > @@ -32,8 +32,7 @@ static inline void __arch_adjust_zones(unsigned long *zone_size, unsigned long * > #define arch_adjust_zones(size, holes) \ > __arch_adjust_zones(size, holes) > > -#define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_4M - 1) > -#define MAX_DMA_ADDRESS (PAGE_OFFSET + SZ_4M) > +#define ARM_DMA_ZONE_SIZE SZ_4M > > #endif > > -- > 1.7.4.4 > ^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH 2/2] ARM: use ARM_DMA_ZONE_SIZE to adjust the zone sizes 2011-05-11 16:24 [PATCH 0/2] Consolidate zone adjustment Russell King - ARM Linux 2011-05-11 16:25 ` [PATCH 1/2] ARM: Replace platform definition of ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS Russell King - ARM Linux @ 2011-05-11 16:25 ` Russell King - ARM Linux 2011-05-11 17:21 ` Catalin Marinas 2011-05-12 7:28 ` Nicolas Pitre 2011-05-19 10:56 ` [PATCH 0/2] Consolidate zone adjustment Nori, Sekhar 2 siblings, 2 replies; 9+ messages in thread From: Russell King - ARM Linux @ 2011-05-11 16:25 UTC (permalink / raw) To: linux-arm-kernel Rather than each platform providing its own function to adjust the zone sizes, use the new ARM_DMA_ZONE_SIZE definition to perform this adjustment. This ensures that the actual DMA zone size and the ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS definitions are consistent with each other, and moves this complexity out of the platform code. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> --- arch/arm/common/sa1111.c | 8 ------- arch/arm/include/asm/memory.h | 6 ----- arch/arm/mach-davinci/include/mach/memory.h | 15 -------------- arch/arm/mach-ixp4xx/common-pci.c | 23 ---------------------- arch/arm/mach-ixp4xx/include/mach/memory.h | 9 +------- arch/arm/mach-pxa/cm-x2xx-pci.c | 27 -------------------------- arch/arm/mach-pxa/include/mach/memory.h | 7 +----- arch/arm/mach-realview/core.c | 19 ------------------ arch/arm/mach-realview/include/mach/memory.h | 6 +---- arch/arm/mach-sa1100/include/mach/memory.h | 9 -------- arch/arm/mach-shark/include/mach/memory.h | 17 ---------------- arch/arm/mm/init.c | 23 +++++++++++++++++++++- 12 files changed, 25 insertions(+), 144 deletions(-) diff --git a/arch/arm/common/sa1111.c b/arch/arm/common/sa1111.c index a12b33c..9c49a46 100644 --- a/arch/arm/common/sa1111.c +++ b/arch/arm/common/sa1111.c @@ -185,14 +185,6 @@ static struct sa1111_dev_info sa1111_devices[] = { }, }; -void __init sa1111_adjust_zones(unsigned long *size, unsigned long *holes) -{ - unsigned int sz = SZ_1M >> PAGE_SHIFT; - - size[1] = size[0] - sz; - size[0] = sz; -} - /* * SA1111 interrupt support. Since clearing an IRQ while there are * active IRQs causes the interrupt output to pulse, the upper levels diff --git a/arch/arm/include/asm/memory.h b/arch/arm/include/asm/memory.h index ee5ff41..af44a8f 100644 --- a/arch/arm/include/asm/memory.h +++ b/arch/arm/include/asm/memory.h @@ -215,12 +215,6 @@ static inline unsigned long __phys_to_virt(unsigned long x) #define ISA_DMA_THRESHOLD (PHYS_OFFSET + ARM_DMA_ZONE_SIZE - 1) #endif -#ifndef arch_adjust_zones -#define arch_adjust_zones(size,holes) do { } while (0) -#elif !defined(CONFIG_ZONE_DMA) -#error "custom arch_adjust_zones() requires CONFIG_ZONE_DMA" -#endif - /* * PFNs are used to describe any physical page; this means * PFN 0 == physical address 0. diff --git a/arch/arm/mach-davinci/include/mach/memory.h b/arch/arm/mach-davinci/include/mach/memory.h index 8d27246..491249e 100644 --- a/arch/arm/mach-davinci/include/mach/memory.h +++ b/arch/arm/mach-davinci/include/mach/memory.h @@ -41,26 +41,11 @@ */ #define CONSISTENT_DMA_SIZE (14<<20) -#ifndef __ASSEMBLY__ /* * Restrict DMA-able region to workaround silicon bug. The bug * restricts buffers available for DMA to video hardware to be * below 128M */ -static inline void -__arch_adjust_zones(unsigned long *size, unsigned long *holes) -{ - unsigned int sz = (128<<20) >> PAGE_SHIFT; - - size[1] = size[0] - sz; - size[0] = sz; -} - -#define arch_adjust_zones(zone_size, holes) \ - if ((meminfo.bank[0].size >> 20) > 128) __arch_adjust_zones(zone_size, holes) - #define ARM_DMA_ZONE_SIZE SZ_128M -#endif - #endif /* __ASM_ARCH_MEMORY_H */ diff --git a/arch/arm/mach-ixp4xx/common-pci.c b/arch/arm/mach-ixp4xx/common-pci.c index a54b3db..e9a5893 100644 --- a/arch/arm/mach-ixp4xx/common-pci.c +++ b/arch/arm/mach-ixp4xx/common-pci.c @@ -342,29 +342,6 @@ int dma_needs_bounce(struct device *dev, dma_addr_t dma_addr, size_t size) return (dev->bus == &pci_bus_type ) && ((dma_addr + size) >= SZ_64M); } -/* - * Only first 64MB of memory can be accessed via PCI. - * We use GFP_DMA to allocate safe buffers to do map/unmap. - * This is really ugly and we need a better way of specifying - * DMA-capable regions of memory. - */ -void __init ixp4xx_adjust_zones(unsigned long *zone_size, - unsigned long *zhole_size) -{ - unsigned int sz = SZ_64M >> PAGE_SHIFT; - - /* - * Only adjust if > 64M on current system - */ - if (zone_size[0] <= sz) - return; - - zone_size[1] = zone_size[0] - sz; - zone_size[0] = sz; - zhole_size[1] = zhole_size[0]; - zhole_size[0] = 0; -} - void __init ixp4xx_pci_preinit(void) { unsigned long cpuid = read_cpuid_id(); diff --git a/arch/arm/mach-ixp4xx/include/mach/memory.h b/arch/arm/mach-ixp4xx/include/mach/memory.h index a5c26f8..34e7940 100644 --- a/arch/arm/mach-ixp4xx/include/mach/memory.h +++ b/arch/arm/mach-ixp4xx/include/mach/memory.h @@ -14,15 +14,8 @@ */ #define PLAT_PHYS_OFFSET UL(0x00000000) -#if !defined(__ASSEMBLY__) && defined(CONFIG_PCI) - -void ixp4xx_adjust_zones(unsigned long *size, unsigned long *holes); - -#define arch_adjust_zones(size, holes) \ - ixp4xx_adjust_zones(size, holes) - +#ifdef CONFIG_PCI #define ARM_DMA_ZONE_SIZE SZ_64M - #endif #endif diff --git a/arch/arm/mach-pxa/cm-x2xx-pci.c b/arch/arm/mach-pxa/cm-x2xx-pci.c index 8b1a309..1afc0fb 100644 --- a/arch/arm/mach-pxa/cm-x2xx-pci.c +++ b/arch/arm/mach-pxa/cm-x2xx-pci.c @@ -29,33 +29,6 @@ unsigned long it8152_base_address; static int cmx2xx_it8152_irq_gpio; -/* - * Only first 64MB of memory can be accessed via PCI. - * We use GFP_DMA to allocate safe buffers to do map/unmap. - * This is really ugly and we need a better way of specifying - * DMA-capable regions of memory. - */ -void __init cmx2xx_pci_adjust_zones(unsigned long *zone_size, - unsigned long *zhole_size) -{ - unsigned int sz = SZ_64M >> PAGE_SHIFT; - - if (machine_is_armcore()) { - pr_info("Adjusting zones for CM-X2XX\n"); - - /* - * Only adjust if > 64M on current system - */ - if (zone_size[0] <= sz) - return; - - zone_size[1] = zone_size[0] - sz; - zone_size[0] = sz; - zhole_size[1] = zhole_size[0]; - zhole_size[0] = 0; - } -} - static void cmx2xx_it8152_irq_demux(unsigned int irq, struct irq_desc *desc) { /* clear our parent irq */ diff --git a/arch/arm/mach-pxa/include/mach/memory.h b/arch/arm/mach-pxa/include/mach/memory.h index 57a0b68..07734f3 100644 --- a/arch/arm/mach-pxa/include/mach/memory.h +++ b/arch/arm/mach-pxa/include/mach/memory.h @@ -17,12 +17,7 @@ */ #define PLAT_PHYS_OFFSET UL(0xa0000000) -#if !defined(__ASSEMBLY__) && defined(CONFIG_MACH_ARMCORE) && defined(CONFIG_PCI) -void cmx2xx_pci_adjust_zones(unsigned long *size, unsigned long *holes); - -#define arch_adjust_zones(size, holes) \ - cmx2xx_pci_adjust_zones(size, holes) - +#if defined(CONFIG_MACH_ARMCORE) && defined(CONFIG_PCI) #define ARM_DMA_ZONE_SIZE SZ_64M #endif diff --git a/arch/arm/mach-realview/core.c b/arch/arm/mach-realview/core.c index 75dbc87..525ad17 100644 --- a/arch/arm/mach-realview/core.c +++ b/arch/arm/mach-realview/core.c @@ -56,25 +56,6 @@ #include "core.h" -#ifdef CONFIG_ZONE_DMA -/* - * Adjust the zones if there are restrictions for DMA access. - */ -void __init realview_adjust_zones(unsigned long *size, unsigned long *hole) -{ - unsigned long dma_size = SZ_256M >> PAGE_SHIFT; - - if (!machine_is_realview_pbx() || size[0] <= dma_size) - return; - - size[ZONE_NORMAL] = size[0] - dma_size; - size[ZONE_DMA] = dma_size; - hole[ZONE_NORMAL] = hole[0]; - hole[ZONE_DMA] = 0; -} -#endif - - #define REALVIEW_FLASHCTRL (__io_address(REALVIEW_SYS_BASE) + REALVIEW_SYS_FLASH_OFFSET) static int realview_flash_init(void) diff --git a/arch/arm/mach-realview/include/mach/memory.h b/arch/arm/mach-realview/include/mach/memory.h index 973428d..1759fa6 100644 --- a/arch/arm/mach-realview/include/mach/memory.h +++ b/arch/arm/mach-realview/include/mach/memory.h @@ -29,11 +29,7 @@ #define PLAT_PHYS_OFFSET UL(0x00000000) #endif -#if !defined(__ASSEMBLY__) && defined(CONFIG_ZONE_DMA) -extern void realview_adjust_zones(unsigned long *size, unsigned long *hole); -#define arch_adjust_zones(size, hole) \ - realview_adjust_zones(size, hole) - +#ifdef CONFIG_ZONE_DMA #define ARM_DMA_ZONE_SIZE SZ_256M #endif diff --git a/arch/arm/mach-sa1100/include/mach/memory.h b/arch/arm/mach-sa1100/include/mach/memory.h index 090b829..cff31ee 100644 --- a/arch/arm/mach-sa1100/include/mach/memory.h +++ b/arch/arm/mach-sa1100/include/mach/memory.h @@ -14,17 +14,8 @@ */ #define PLAT_PHYS_OFFSET UL(0xc0000000) -#ifndef __ASSEMBLY__ - #ifdef CONFIG_SA1111 -void sa1111_adjust_zones(unsigned long *size, unsigned long *holes); - -#define arch_adjust_zones(size, holes) \ - sa1111_adjust_zones(size, holes) - #define ARM_DMA_ZONE_SIZE SZ_1M - -#endif #endif /* diff --git a/arch/arm/mach-shark/include/mach/memory.h b/arch/arm/mach-shark/include/mach/memory.h index 48fe84b..4c0831f8 100644 --- a/arch/arm/mach-shark/include/mach/memory.h +++ b/arch/arm/mach-shark/include/mach/memory.h @@ -17,25 +17,8 @@ */ #define PLAT_PHYS_OFFSET UL(0x08000000) -#ifndef __ASSEMBLY__ - -static inline void __arch_adjust_zones(unsigned long *zone_size, unsigned long *zhole_size) -{ - /* Only the first 4 MB (=1024 Pages) are usable for DMA */ - /* See dev / -> .properties in OpenFirmware. */ - zone_size[1] = zone_size[0] - 1024; - zone_size[0] = 1024; - zhole_size[1] = zhole_size[0]; - zhole_size[0] = 0; -} - -#define arch_adjust_zones(size, holes) \ - __arch_adjust_zones(size, holes) - #define ARM_DMA_ZONE_SIZE SZ_4M -#endif - /* * Cache flushing area */ diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c index e5f6fc4..49eaad9 100644 --- a/arch/arm/mm/init.c +++ b/arch/arm/mm/init.c @@ -201,6 +201,20 @@ static void __init arm_bootmem_init(unsigned long start_pfn, } } +#ifdef CONFIG_ZONE_DMA +static void __init arm_adjust_dma_zone(unsigned long *size, unsigned long *hole, + unsigned long dma_size) +{ + if (size[0] <= dma_size) + return; + + size[ZONE_NORMAL] = size[0] - dma_size; + size[ZONE_DMA] = dma_size; + hole[ZONE_NORMAL] = hole[0]; + hole[ZONE_DMA] = 0; +} +#endif + static void __init arm_bootmem_free(unsigned long min, unsigned long max_low, unsigned long max_high) { @@ -243,11 +257,18 @@ static void __init arm_bootmem_free(unsigned long min, unsigned long max_low, #endif } +#ifdef ARM_DMA_ZONE_SIZE +#ifndef CONFIG_ZONE_DMA +#error ARM_DMA_ZONE_SIZE set but no DMA zone to limit allocations +#endif + /* * Adjust the sizes according to any special requirements for * this machine type. */ - arch_adjust_zones(zone_size, zhole_size); + arm_adjust_dma_zone(zone_size, zhole_size, + ARM_DMA_ZONE_SIZE >> PAGE_SHIFT); +#endif free_area_init_node(0, zone_size, min, zhole_size); } -- 1.7.4.4 ^ permalink raw reply related [flat|nested] 9+ messages in thread
* [PATCH 2/2] ARM: use ARM_DMA_ZONE_SIZE to adjust the zone sizes 2011-05-11 16:25 ` [PATCH 2/2] ARM: use ARM_DMA_ZONE_SIZE to adjust the zone sizes Russell King - ARM Linux @ 2011-05-11 17:21 ` Catalin Marinas 2011-05-11 17:24 ` Russell King - ARM Linux 2011-05-12 7:28 ` Nicolas Pitre 1 sibling, 1 reply; 9+ messages in thread From: Catalin Marinas @ 2011-05-11 17:21 UTC (permalink / raw) To: linux-arm-kernel On Wed, 2011-05-11 at 17:25 +0100, Russell King - ARM Linux wrote: > Rather than each platform providing its own function to adjust the > zone sizes, use the new ARM_DMA_ZONE_SIZE definition to perform this > adjustment. This ensures that the actual DMA zone size and the > ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS definitions are consistent with > each other, and moves this complexity out of the platform code. ... > diff --git a/arch/arm/mach-realview/include/mach/memory.h b/arch/arm/mach-realview/include/mach/memory.h > index 973428d..1759fa6 100644 > --- a/arch/arm/mach-realview/include/mach/memory.h > +++ b/arch/arm/mach-realview/include/mach/memory.h > @@ -29,11 +29,7 @@ > #define PLAT_PHYS_OFFSET UL(0x00000000) > #endif > > -#if !defined(__ASSEMBLY__) && defined(CONFIG_ZONE_DMA) > -extern void realview_adjust_zones(unsigned long *size, unsigned long *hole); > -#define arch_adjust_zones(size, hole) \ > - realview_adjust_zones(size, hole) > - > +#ifdef CONFIG_ZONE_DMA > #define ARM_DMA_ZONE_SIZE SZ_256M > #endif We only use ZONE_DMA for PBX and realview_adjust_zones() does this check. We end up with limiting the DMA zone to 256MB on all RealView platforms if we compile a single kernel image that includes PBX. Not a big problem though: Acked-by: Catalin Marinas <catalin.marinas@arm.com> ^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH 2/2] ARM: use ARM_DMA_ZONE_SIZE to adjust the zone sizes 2011-05-11 17:21 ` Catalin Marinas @ 2011-05-11 17:24 ` Russell King - ARM Linux 0 siblings, 0 replies; 9+ messages in thread From: Russell King - ARM Linux @ 2011-05-11 17:24 UTC (permalink / raw) To: linux-arm-kernel On Wed, May 11, 2011 at 06:21:38PM +0100, Catalin Marinas wrote: > On Wed, 2011-05-11 at 17:25 +0100, Russell King - ARM Linux wrote: > > Rather than each platform providing its own function to adjust the > > zone sizes, use the new ARM_DMA_ZONE_SIZE definition to perform this > > adjustment. This ensures that the actual DMA zone size and the > > ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS definitions are consistent with > > each other, and moves this complexity out of the platform code. > ... > > diff --git a/arch/arm/mach-realview/include/mach/memory.h b/arch/arm/mach-realview/include/mach/memory.h > > index 973428d..1759fa6 100644 > > --- a/arch/arm/mach-realview/include/mach/memory.h > > +++ b/arch/arm/mach-realview/include/mach/memory.h > > @@ -29,11 +29,7 @@ > > #define PLAT_PHYS_OFFSET UL(0x00000000) > > #endif > > > > -#if !defined(__ASSEMBLY__) && defined(CONFIG_ZONE_DMA) > > -extern void realview_adjust_zones(unsigned long *size, unsigned long *hole); > > -#define arch_adjust_zones(size, hole) \ > > - realview_adjust_zones(size, hole) > > - > > +#ifdef CONFIG_ZONE_DMA > > #define ARM_DMA_ZONE_SIZE SZ_256M > > #endif > > We only use ZONE_DMA for PBX and realview_adjust_zones() does this > check. We end up with limiting the DMA zone to 256MB on all RealView > platforms if we compile a single kernel image that includes PBX. Not a > big problem though: You've already implicitly limited it by the ISA_DMA_THRESHOLD/ MAX_DMA_ADDRESS definition - what's left is an inconsistent relative size of those definitions and the actual DMA zone. That inconsistency can cause the DMA allocator to fail unexpectedly as it assumes that GFP_DMA will return a page which will satisfy ISA_DMA_THRESHOLD. > Acked-by: Catalin Marinas <catalin.marinas@arm.com> Thanks. ^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH 2/2] ARM: use ARM_DMA_ZONE_SIZE to adjust the zone sizes 2011-05-11 16:25 ` [PATCH 2/2] ARM: use ARM_DMA_ZONE_SIZE to adjust the zone sizes Russell King - ARM Linux 2011-05-11 17:21 ` Catalin Marinas @ 2011-05-12 7:28 ` Nicolas Pitre 1 sibling, 0 replies; 9+ messages in thread From: Nicolas Pitre @ 2011-05-12 7:28 UTC (permalink / raw) To: linux-arm-kernel On Wed, 11 May 2011, Russell King - ARM Linux wrote: > Rather than each platform providing its own function to adjust the > zone sizes, use the new ARM_DMA_ZONE_SIZE definition to perform this > adjustment. This ensures that the actual DMA zone size and the > ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS definitions are consistent with > each other, and moves this complexity out of the platform code. > > Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> Acked-by: Nicolas Pitre <nicolas.pitre@linaro.org> > --- > arch/arm/common/sa1111.c | 8 ------- > arch/arm/include/asm/memory.h | 6 ----- > arch/arm/mach-davinci/include/mach/memory.h | 15 -------------- > arch/arm/mach-ixp4xx/common-pci.c | 23 ---------------------- > arch/arm/mach-ixp4xx/include/mach/memory.h | 9 +------- > arch/arm/mach-pxa/cm-x2xx-pci.c | 27 -------------------------- > arch/arm/mach-pxa/include/mach/memory.h | 7 +----- > arch/arm/mach-realview/core.c | 19 ------------------ > arch/arm/mach-realview/include/mach/memory.h | 6 +---- > arch/arm/mach-sa1100/include/mach/memory.h | 9 -------- > arch/arm/mach-shark/include/mach/memory.h | 17 ---------------- > arch/arm/mm/init.c | 23 +++++++++++++++++++++- > 12 files changed, 25 insertions(+), 144 deletions(-) > > diff --git a/arch/arm/common/sa1111.c b/arch/arm/common/sa1111.c > index a12b33c..9c49a46 100644 > --- a/arch/arm/common/sa1111.c > +++ b/arch/arm/common/sa1111.c > @@ -185,14 +185,6 @@ static struct sa1111_dev_info sa1111_devices[] = { > }, > }; > > -void __init sa1111_adjust_zones(unsigned long *size, unsigned long *holes) > -{ > - unsigned int sz = SZ_1M >> PAGE_SHIFT; > - > - size[1] = size[0] - sz; > - size[0] = sz; > -} > - > /* > * SA1111 interrupt support. Since clearing an IRQ while there are > * active IRQs causes the interrupt output to pulse, the upper levels > diff --git a/arch/arm/include/asm/memory.h b/arch/arm/include/asm/memory.h > index ee5ff41..af44a8f 100644 > --- a/arch/arm/include/asm/memory.h > +++ b/arch/arm/include/asm/memory.h > @@ -215,12 +215,6 @@ static inline unsigned long __phys_to_virt(unsigned long x) > #define ISA_DMA_THRESHOLD (PHYS_OFFSET + ARM_DMA_ZONE_SIZE - 1) > #endif > > -#ifndef arch_adjust_zones > -#define arch_adjust_zones(size,holes) do { } while (0) > -#elif !defined(CONFIG_ZONE_DMA) > -#error "custom arch_adjust_zones() requires CONFIG_ZONE_DMA" > -#endif > - > /* > * PFNs are used to describe any physical page; this means > * PFN 0 == physical address 0. > diff --git a/arch/arm/mach-davinci/include/mach/memory.h b/arch/arm/mach-davinci/include/mach/memory.h > index 8d27246..491249e 100644 > --- a/arch/arm/mach-davinci/include/mach/memory.h > +++ b/arch/arm/mach-davinci/include/mach/memory.h > @@ -41,26 +41,11 @@ > */ > #define CONSISTENT_DMA_SIZE (14<<20) > > -#ifndef __ASSEMBLY__ > /* > * Restrict DMA-able region to workaround silicon bug. The bug > * restricts buffers available for DMA to video hardware to be > * below 128M > */ > -static inline void > -__arch_adjust_zones(unsigned long *size, unsigned long *holes) > -{ > - unsigned int sz = (128<<20) >> PAGE_SHIFT; > - > - size[1] = size[0] - sz; > - size[0] = sz; > -} > - > -#define arch_adjust_zones(zone_size, holes) \ > - if ((meminfo.bank[0].size >> 20) > 128) __arch_adjust_zones(zone_size, holes) > - > #define ARM_DMA_ZONE_SIZE SZ_128M > > -#endif > - > #endif /* __ASM_ARCH_MEMORY_H */ > diff --git a/arch/arm/mach-ixp4xx/common-pci.c b/arch/arm/mach-ixp4xx/common-pci.c > index a54b3db..e9a5893 100644 > --- a/arch/arm/mach-ixp4xx/common-pci.c > +++ b/arch/arm/mach-ixp4xx/common-pci.c > @@ -342,29 +342,6 @@ int dma_needs_bounce(struct device *dev, dma_addr_t dma_addr, size_t size) > return (dev->bus == &pci_bus_type ) && ((dma_addr + size) >= SZ_64M); > } > > -/* > - * Only first 64MB of memory can be accessed via PCI. > - * We use GFP_DMA to allocate safe buffers to do map/unmap. > - * This is really ugly and we need a better way of specifying > - * DMA-capable regions of memory. > - */ > -void __init ixp4xx_adjust_zones(unsigned long *zone_size, > - unsigned long *zhole_size) > -{ > - unsigned int sz = SZ_64M >> PAGE_SHIFT; > - > - /* > - * Only adjust if > 64M on current system > - */ > - if (zone_size[0] <= sz) > - return; > - > - zone_size[1] = zone_size[0] - sz; > - zone_size[0] = sz; > - zhole_size[1] = zhole_size[0]; > - zhole_size[0] = 0; > -} > - > void __init ixp4xx_pci_preinit(void) > { > unsigned long cpuid = read_cpuid_id(); > diff --git a/arch/arm/mach-ixp4xx/include/mach/memory.h b/arch/arm/mach-ixp4xx/include/mach/memory.h > index a5c26f8..34e7940 100644 > --- a/arch/arm/mach-ixp4xx/include/mach/memory.h > +++ b/arch/arm/mach-ixp4xx/include/mach/memory.h > @@ -14,15 +14,8 @@ > */ > #define PLAT_PHYS_OFFSET UL(0x00000000) > > -#if !defined(__ASSEMBLY__) && defined(CONFIG_PCI) > - > -void ixp4xx_adjust_zones(unsigned long *size, unsigned long *holes); > - > -#define arch_adjust_zones(size, holes) \ > - ixp4xx_adjust_zones(size, holes) > - > +#ifdef CONFIG_PCI > #define ARM_DMA_ZONE_SIZE SZ_64M > - > #endif > > #endif > diff --git a/arch/arm/mach-pxa/cm-x2xx-pci.c b/arch/arm/mach-pxa/cm-x2xx-pci.c > index 8b1a309..1afc0fb 100644 > --- a/arch/arm/mach-pxa/cm-x2xx-pci.c > +++ b/arch/arm/mach-pxa/cm-x2xx-pci.c > @@ -29,33 +29,6 @@ > unsigned long it8152_base_address; > static int cmx2xx_it8152_irq_gpio; > > -/* > - * Only first 64MB of memory can be accessed via PCI. > - * We use GFP_DMA to allocate safe buffers to do map/unmap. > - * This is really ugly and we need a better way of specifying > - * DMA-capable regions of memory. > - */ > -void __init cmx2xx_pci_adjust_zones(unsigned long *zone_size, > - unsigned long *zhole_size) > -{ > - unsigned int sz = SZ_64M >> PAGE_SHIFT; > - > - if (machine_is_armcore()) { > - pr_info("Adjusting zones for CM-X2XX\n"); > - > - /* > - * Only adjust if > 64M on current system > - */ > - if (zone_size[0] <= sz) > - return; > - > - zone_size[1] = zone_size[0] - sz; > - zone_size[0] = sz; > - zhole_size[1] = zhole_size[0]; > - zhole_size[0] = 0; > - } > -} > - > static void cmx2xx_it8152_irq_demux(unsigned int irq, struct irq_desc *desc) > { > /* clear our parent irq */ > diff --git a/arch/arm/mach-pxa/include/mach/memory.h b/arch/arm/mach-pxa/include/mach/memory.h > index 57a0b68..07734f3 100644 > --- a/arch/arm/mach-pxa/include/mach/memory.h > +++ b/arch/arm/mach-pxa/include/mach/memory.h > @@ -17,12 +17,7 @@ > */ > #define PLAT_PHYS_OFFSET UL(0xa0000000) > > -#if !defined(__ASSEMBLY__) && defined(CONFIG_MACH_ARMCORE) && defined(CONFIG_PCI) > -void cmx2xx_pci_adjust_zones(unsigned long *size, unsigned long *holes); > - > -#define arch_adjust_zones(size, holes) \ > - cmx2xx_pci_adjust_zones(size, holes) > - > +#if defined(CONFIG_MACH_ARMCORE) && defined(CONFIG_PCI) > #define ARM_DMA_ZONE_SIZE SZ_64M > #endif > > diff --git a/arch/arm/mach-realview/core.c b/arch/arm/mach-realview/core.c > index 75dbc87..525ad17 100644 > --- a/arch/arm/mach-realview/core.c > +++ b/arch/arm/mach-realview/core.c > @@ -56,25 +56,6 @@ > > #include "core.h" > > -#ifdef CONFIG_ZONE_DMA > -/* > - * Adjust the zones if there are restrictions for DMA access. > - */ > -void __init realview_adjust_zones(unsigned long *size, unsigned long *hole) > -{ > - unsigned long dma_size = SZ_256M >> PAGE_SHIFT; > - > - if (!machine_is_realview_pbx() || size[0] <= dma_size) > - return; > - > - size[ZONE_NORMAL] = size[0] - dma_size; > - size[ZONE_DMA] = dma_size; > - hole[ZONE_NORMAL] = hole[0]; > - hole[ZONE_DMA] = 0; > -} > -#endif > - > - > #define REALVIEW_FLASHCTRL (__io_address(REALVIEW_SYS_BASE) + REALVIEW_SYS_FLASH_OFFSET) > > static int realview_flash_init(void) > diff --git a/arch/arm/mach-realview/include/mach/memory.h b/arch/arm/mach-realview/include/mach/memory.h > index 973428d..1759fa6 100644 > --- a/arch/arm/mach-realview/include/mach/memory.h > +++ b/arch/arm/mach-realview/include/mach/memory.h > @@ -29,11 +29,7 @@ > #define PLAT_PHYS_OFFSET UL(0x00000000) > #endif > > -#if !defined(__ASSEMBLY__) && defined(CONFIG_ZONE_DMA) > -extern void realview_adjust_zones(unsigned long *size, unsigned long *hole); > -#define arch_adjust_zones(size, hole) \ > - realview_adjust_zones(size, hole) > - > +#ifdef CONFIG_ZONE_DMA > #define ARM_DMA_ZONE_SIZE SZ_256M > #endif > > diff --git a/arch/arm/mach-sa1100/include/mach/memory.h b/arch/arm/mach-sa1100/include/mach/memory.h > index 090b829..cff31ee 100644 > --- a/arch/arm/mach-sa1100/include/mach/memory.h > +++ b/arch/arm/mach-sa1100/include/mach/memory.h > @@ -14,17 +14,8 @@ > */ > #define PLAT_PHYS_OFFSET UL(0xc0000000) > > -#ifndef __ASSEMBLY__ > - > #ifdef CONFIG_SA1111 > -void sa1111_adjust_zones(unsigned long *size, unsigned long *holes); > - > -#define arch_adjust_zones(size, holes) \ > - sa1111_adjust_zones(size, holes) > - > #define ARM_DMA_ZONE_SIZE SZ_1M > - > -#endif > #endif > > /* > diff --git a/arch/arm/mach-shark/include/mach/memory.h b/arch/arm/mach-shark/include/mach/memory.h > index 48fe84b..4c0831f8 100644 > --- a/arch/arm/mach-shark/include/mach/memory.h > +++ b/arch/arm/mach-shark/include/mach/memory.h > @@ -17,25 +17,8 @@ > */ > #define PLAT_PHYS_OFFSET UL(0x08000000) > > -#ifndef __ASSEMBLY__ > - > -static inline void __arch_adjust_zones(unsigned long *zone_size, unsigned long *zhole_size) > -{ > - /* Only the first 4 MB (=1024 Pages) are usable for DMA */ > - /* See dev / -> .properties in OpenFirmware. */ > - zone_size[1] = zone_size[0] - 1024; > - zone_size[0] = 1024; > - zhole_size[1] = zhole_size[0]; > - zhole_size[0] = 0; > -} > - > -#define arch_adjust_zones(size, holes) \ > - __arch_adjust_zones(size, holes) > - > #define ARM_DMA_ZONE_SIZE SZ_4M > > -#endif > - > /* > * Cache flushing area > */ > diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c > index e5f6fc4..49eaad9 100644 > --- a/arch/arm/mm/init.c > +++ b/arch/arm/mm/init.c > @@ -201,6 +201,20 @@ static void __init arm_bootmem_init(unsigned long start_pfn, > } > } > > +#ifdef CONFIG_ZONE_DMA > +static void __init arm_adjust_dma_zone(unsigned long *size, unsigned long *hole, > + unsigned long dma_size) > +{ > + if (size[0] <= dma_size) > + return; > + > + size[ZONE_NORMAL] = size[0] - dma_size; > + size[ZONE_DMA] = dma_size; > + hole[ZONE_NORMAL] = hole[0]; > + hole[ZONE_DMA] = 0; > +} > +#endif > + > static void __init arm_bootmem_free(unsigned long min, unsigned long max_low, > unsigned long max_high) > { > @@ -243,11 +257,18 @@ static void __init arm_bootmem_free(unsigned long min, unsigned long max_low, > #endif > } > > +#ifdef ARM_DMA_ZONE_SIZE > +#ifndef CONFIG_ZONE_DMA > +#error ARM_DMA_ZONE_SIZE set but no DMA zone to limit allocations > +#endif > + > /* > * Adjust the sizes according to any special requirements for > * this machine type. > */ > - arch_adjust_zones(zone_size, zhole_size); > + arm_adjust_dma_zone(zone_size, zhole_size, > + ARM_DMA_ZONE_SIZE >> PAGE_SHIFT); > +#endif > > free_area_init_node(0, zone_size, min, zhole_size); > } > -- > 1.7.4.4 > ^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH 0/2] Consolidate zone adjustment 2011-05-11 16:24 [PATCH 0/2] Consolidate zone adjustment Russell King - ARM Linux 2011-05-11 16:25 ` [PATCH 1/2] ARM: Replace platform definition of ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS Russell King - ARM Linux 2011-05-11 16:25 ` [PATCH 2/2] ARM: use ARM_DMA_ZONE_SIZE to adjust the zone sizes Russell King - ARM Linux @ 2011-05-19 10:56 ` Nori, Sekhar 2 siblings, 0 replies; 9+ messages in thread From: Nori, Sekhar @ 2011-05-19 10:56 UTC (permalink / raw) To: linux-arm-kernel On Wed, May 11, 2011 at 21:54:50, Russell King - ARM Linux wrote: > This patch mini-series consolidates the adjustment to system zones > which some of our platforms require. Rather than having each > platform/machine class specify ISA_DMA_THRESHOLD, MAX_DMA_ADDRESS > and an arch_adjust_zones function, they really only need to provide > a single sizing definition, which in this series will be called > ARM_DMA_ZONE_SIZE. Boot tested this series on DaVinci DA850. Tested-by: Sekhar Nori <nsekhar@ti.com> Thanks, Sekhar ^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2011-05-19 10:56 UTC | newest] Thread overview: 9+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2011-05-11 16:24 [PATCH 0/2] Consolidate zone adjustment Russell King - ARM Linux 2011-05-11 16:25 ` [PATCH 1/2] ARM: Replace platform definition of ISA_DMA_THRESHOLD/MAX_DMA_ADDRESS Russell King - ARM Linux 2011-05-11 17:22 ` Catalin Marinas 2011-05-12 7:16 ` Nicolas Pitre 2011-05-11 16:25 ` [PATCH 2/2] ARM: use ARM_DMA_ZONE_SIZE to adjust the zone sizes Russell King - ARM Linux 2011-05-11 17:21 ` Catalin Marinas 2011-05-11 17:24 ` Russell King - ARM Linux 2011-05-12 7:28 ` Nicolas Pitre 2011-05-19 10:56 ` [PATCH 0/2] Consolidate zone adjustment Nori, Sekhar
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).