x86_64: ZONE_DMA/ZONE_DMA32 optional Allow the use to specify CONFIG_ZONE_DMA32 and CONFIG_ZONE_DMA (via CONFIG_GENERIC_ISA_DMA). Not that this is incomplete. What really needs to occur is that devices using ISA DMA need to depend on ZONE_DMA. I am also not sure if this works for all configuration. Works fine on my desktop x86_64 system with a single zone. Signed-off-by: Christoph Lameter Index: linux-2.6.18-rc5-mm1/arch/x86_64/mm/init.c =================================================================== --- linux-2.6.18-rc5-mm1.orig/arch/x86_64/mm/init.c 2006-09-04 20:45:41.000000000 -0700 +++ linux-2.6.18-rc5-mm1/arch/x86_64/mm/init.c 2006-09-04 21:00:44.000000000 -0700 @@ -406,9 +406,15 @@ #ifndef CONFIG_NUMA void __init paging_init(void) { - unsigned long max_zone_pfns[MAX_NR_ZONES] = {MAX_DMA_PFN, - MAX_DMA32_PFN, - end_pfn}; + unsigned long max_zone_pfns[MAX_NR_ZONES] = { +#ifdef CONFIG_ZONE_DMA + MAX_DMA_PFN, +#endif +#ifdef CONFIG_ZONE_DMA32 + MAX_DMA32_PFN, +#endif + end_pfn + }; memory_present(0, 0, end_pfn); sparse_init(); free_area_init_nodes(max_zone_pfns); Index: linux-2.6.18-rc5-mm1/arch/x86_64/Kconfig =================================================================== --- linux-2.6.18-rc5-mm1.orig/arch/x86_64/Kconfig 2006-09-04 20:45:40.000000000 -0700 +++ linux-2.6.18-rc5-mm1/arch/x86_64/Kconfig 2006-09-04 20:55:47.000000000 -0700 @@ -24,10 +24,6 @@ bool default y -config ZONE_DMA32 - bool - default y - config LOCKDEP_SUPPORT bool default y @@ -73,10 +69,6 @@ bool default y -config GENERIC_ISA_DMA - bool - default y - config GENERIC_IOMAP bool default y @@ -251,6 +243,23 @@ See for more information. +config ZONE_DMA32 + bool "32 Bit DMA Zone (only needed if memory >4GB)" + default y + help + Some x64 configurations have 32 bit DMA controllers that cannot + write to all of memory. If you have one of these and you have RAM + beyond the 4GB boundary then enable this option. + +config GENERIC_ISA_DMA + bool "ISA DMA zone (to support ISA legacy DMA)" + default y + help + If DMA for ISA boards needs to be supported then this option + needs to be enabled. An additional DMA zone for <16MB memory + will be created and memory below 16MB will be used for those + devices. + config SMP bool "Symmetric multi-processing support" ---help--- Index: linux-2.6.18-rc5-mm1/arch/x86_64/kernel/Makefile =================================================================== --- linux-2.6.18-rc5-mm1.orig/arch/x86_64/kernel/Makefile 2006-09-04 20:45:40.000000000 -0700 +++ linux-2.6.18-rc5-mm1/arch/x86_64/kernel/Makefile 2006-09-04 20:56:53.000000000 -0700 @@ -7,9 +7,10 @@ obj-y := process.o signal.o entry.o traps.o irq.o \ ptrace.o time.o ioport.o ldt.o setup.o i8259.o sys_x86_64.o \ x8664_ksyms.o i387.o syscall.o vsyscall.o \ - setup64.o bootflag.o e820.o reboot.o quirks.o i8237.o \ + setup64.o bootflag.o e820.o reboot.o quirks.o \ pci-dma.o pci-nommu.o alternative.o early-quirks.o +obj-$(CONFIG_GENERIC_ISA_DMA) += i8237.o obj-$(CONFIG_STACKTRACE) += stacktrace.o obj-$(CONFIG_X86_MCE) += mce.o obj-$(CONFIG_X86_MCE_INTEL) += mce_intel.o