Skip to content

Commit

Permalink
mm: generalize ZONE_[DMA|DMA32]
Browse files Browse the repository at this point in the history
ZONE_[DMA|DMA32] configs have duplicate definitions on platforms that
subscribe to them.  Instead, just make them generic options which can be
selected on applicable platforms.

Also only x86/arm64 architectures could enable both ZONE_DMA and
ZONE_DMA32 if EXPERT, add ARCH_HAS_ZONE_DMA_SET to make dma zone
configurable and visible on the two architectures.

Link: https://lkml.kernel.org/r/20210528074557.17768-1-wangkefeng.wang@huawei.com
Signed-off-by: Kefeng Wang <wangkefeng.wang@huawei.com>
Acked-by: Catalin Marinas <catalin.marinas@arm.com>	[arm64]
Acked-by: Geert Uytterhoeven <geert@linux-m68k.org>	[m68k]
Acked-by: Mike Rapoport <rppt@linux.ibm.com>
Acked-by: Palmer Dabbelt <palmerdabbelt@google.com>	[RISC-V]
Acked-by: Michal Simek <michal.simek@xilinx.com>	[microblaze]
Acked-by: Michael Ellerman <mpe@ellerman.id.au>		[powerpc]
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Will Deacon <will@kernel.org>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Borislav Petkov <bp@alien8.de>
Cc: Richard Henderson <rth@twiddle.net>
Cc: Russell King <linux@armlinux.org.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
  • Loading branch information
Kefeng Wang authored and Linus Torvalds committed Jul 1, 2021
1 parent db1d915 commit 63703f3
Show file tree
Hide file tree
Showing 14 changed files with 23 additions and 60 deletions.
5 changes: 1 addition & 4 deletions arch/alpha/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ config ALPHA
select MMU_GATHER_NO_RANGE
select SET_FS
select SPARSEMEM_EXTREME if SPARSEMEM
select ZONE_DMA
help
The Alpha is a 64-bit general-purpose processor designed and
marketed by the Digital Equipment Corporation of blessed memory,
Expand All @@ -65,10 +66,6 @@ config GENERIC_CALIBRATE_DELAY
bool
default y

config ZONE_DMA
bool
default y

config GENERIC_ISA_DMA
bool
default y
Expand Down
3 changes: 0 additions & 3 deletions arch/arm/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -218,9 +218,6 @@ config GENERIC_CALIBRATE_DELAY
config ARCH_MAY_HAVE_PC_FDC
bool

config ZONE_DMA
bool

config ARCH_SUPPORTS_UPROBES
def_bool y

Expand Down
9 changes: 1 addition & 8 deletions arch/arm64/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ config ARM64
select ARCH_HAS_SYSCALL_WRAPPER
select ARCH_HAS_TEARDOWN_DMA_OPS if IOMMU_SUPPORT
select ARCH_HAS_TICK_BROADCAST if GENERIC_CLOCKEVENTS_BROADCAST
select ARCH_HAS_ZONE_DMA_SET if EXPERT
select ARCH_HAVE_ELF_PROT
select ARCH_HAVE_NMI_SAFE_CMPXCHG
select ARCH_INLINE_READ_LOCK if !PREEMPTION
Expand Down Expand Up @@ -306,14 +307,6 @@ config GENERIC_CSUM
config GENERIC_CALIBRATE_DELAY
def_bool y

config ZONE_DMA
bool "Support DMA zone" if EXPERT
default y

config ZONE_DMA32
bool "Support DMA32 zone" if EXPERT
default y

config ARCH_MHP_MEMMAP_ON_MEMORY_ENABLE
def_bool y

Expand Down
4 changes: 1 addition & 3 deletions arch/ia64/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@ config IA64
select NUMA if !FLATMEM
select PCI_MSI_ARCH_FALLBACKS if PCI_MSI
select SET_FS
select ZONE_DMA32
default y
help
The Itanium Processor Family is Intel's 64-bit successor to
Expand All @@ -72,9 +73,6 @@ config 64BIT
select ATA_NONSTANDARD if ATA
default y

config ZONE_DMA32
def_bool y

config MMU
bool
default y
Expand Down
5 changes: 1 addition & 4 deletions arch/m68k/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ config M68K
select SET_FS
select UACCESS_MEMCPY if !MMU
select VIRT_TO_BUS
select ZONE_DMA

config CPU_BIG_ENDIAN
def_bool y
Expand Down Expand Up @@ -62,10 +63,6 @@ config TIME_LOW_RES
config NO_IOPORT_MAP
def_bool y

config ZONE_DMA
bool
default y

config HZ
int
default 1000 if CLEOPATRA
Expand Down
4 changes: 1 addition & 3 deletions arch/microblaze/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ config MICROBLAZE
select MMU_GATHER_NO_RANGE
select SPARSE_IRQ
select SET_FS
select ZONE_DMA

# Endianness selection
choice
Expand All @@ -60,9 +61,6 @@ config CPU_LITTLE_ENDIAN

endchoice

config ZONE_DMA
def_bool y

config ARCH_HAS_ILOG2_U32
def_bool n

Expand Down
7 changes: 0 additions & 7 deletions arch/mips/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -3274,13 +3274,6 @@ config I8253
select CLKSRC_I8253
select CLKEVT_I8253
select MIPS_EXTERNAL_TIMER

config ZONE_DMA
bool

config ZONE_DMA32
bool

endmenu

config TRAD_SIGNALS
Expand Down
4 changes: 0 additions & 4 deletions arch/powerpc/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -403,10 +403,6 @@ config PPC_ADV_DEBUG_DAC_RANGE
config PPC_DAWR
bool

config ZONE_DMA
bool
default y if PPC_BOOK3E_64

config PGTABLE_LEVELS
int
default 2 if !PPC64
Expand Down
1 change: 1 addition & 0 deletions arch/powerpc/platforms/Kconfig.cputype
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,7 @@ config PPC_BOOK3E_64
select PPC_FPU # Make it a choice ?
select PPC_SMP_MUXED_IPI
select PPC_DOORBELL
select ZONE_DMA

endchoice

Expand Down
5 changes: 1 addition & 4 deletions arch/riscv/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,7 @@ config RISCV
select SYSCTL_EXCEPTION_TRACE
select THREAD_INFO_IN_TASK
select UACCESS_MEMCPY if !MMU
select ZONE_DMA32 if 64BIT

config ARCH_MMAP_RND_BITS_MIN
default 18 if 64BIT
Expand Down Expand Up @@ -133,10 +134,6 @@ config MMU
Select if you want MMU-based virtualised addressing space
support by paged memory management. If unsure, say 'Y'.

config ZONE_DMA32
bool
default y if 64BIT

config VA_BITS
int
default 32 if 32BIT
Expand Down
4 changes: 1 addition & 3 deletions arch/s390/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,6 @@
config MMU
def_bool y

config ZONE_DMA
def_bool y

config CPU_BIG_ENDIAN
def_bool y

Expand Down Expand Up @@ -210,6 +207,7 @@ config S390
select THREAD_INFO_IN_TASK
select TTY
select VIRT_CPU_ACCOUNTING
select ZONE_DMA
# Note: keep the above list sorted alphabetically

config SCHED_OMIT_FRAME_POINTER
Expand Down
5 changes: 1 addition & 4 deletions arch/sparc/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,7 @@ config SPARC32
select CLZ_TAB
select HAVE_UID16
select OLD_SIGACTION
select ZONE_DMA

config SPARC64
def_bool 64BIT
Expand Down Expand Up @@ -141,10 +142,6 @@ config HIGHMEM
default y if SPARC32
select KMAP_LOCAL

config ZONE_DMA
bool
default y if SPARC32

config GENERIC_ISA_DMA
bool
default y if SPARC32
Expand Down
15 changes: 2 additions & 13 deletions arch/x86/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ config X86_64
select NEED_DMA_MAP_STATE
select SWIOTLB
select ARCH_HAS_ELFCORE_COMPAT
select ZONE_DMA32

config FORCE_DYNAMIC_FTRACE
def_bool y
Expand Down Expand Up @@ -93,6 +94,7 @@ config X86
select ARCH_HAS_SYSCALL_WRAPPER
select ARCH_HAS_UBSAN_SANITIZE_ALL
select ARCH_HAS_DEBUG_WX
select ARCH_HAS_ZONE_DMA_SET if EXPERT
select ARCH_HAVE_NMI_SAFE_CMPXCHG
select ARCH_MIGHT_HAVE_ACPI_PDC if ACPI
select ARCH_MIGHT_HAVE_PC_PARPORT
Expand Down Expand Up @@ -343,9 +345,6 @@ config ARCH_SUSPEND_POSSIBLE
config ARCH_WANT_GENERAL_HUGETLB
def_bool y

config ZONE_DMA32
def_bool y if X86_64

config AUDIT_ARCH
def_bool y if X86_64

Expand Down Expand Up @@ -393,16 +392,6 @@ config CC_HAS_SANE_STACKPROTECTOR

menu "Processor type and features"

config ZONE_DMA
bool "DMA memory allocation support" if EXPERT
default y
help
DMA memory allocation support allows devices with less than 32-bit
addressing to allocate within the first 16MB of address space.
Disable if no such devices will be used.

If unsure, say Y.

config SMP
bool "Symmetric multi-processing support"
help
Expand Down
12 changes: 12 additions & 0 deletions mm/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -761,6 +761,18 @@ config ARCH_HAS_CACHE_LINE_SIZE
config ARCH_HAS_PTE_DEVMAP
bool

config ARCH_HAS_ZONE_DMA_SET
bool

config ZONE_DMA
bool "Support DMA zone" if ARCH_HAS_ZONE_DMA_SET
default y if ARM64 || X86

config ZONE_DMA32
bool "Support DMA32 zone" if ARCH_HAS_ZONE_DMA_SET
depends on !X86_32
default y if ARM64

config ZONE_DEVICE
bool "Device memory (pmem, HMM, etc...) hotplug support"
depends on MEMORY_HOTPLUG
Expand Down

0 comments on commit 63703f3

Please sign in to comment.