Loading...
1# SPDX-License-Identifier: GPL-2.0
2#
3# Makefile for the linux memory manager.
4#
5
6KASAN_SANITIZE_slab_common.o := n
7KASAN_SANITIZE_slab.o := n
8KASAN_SANITIZE_slub.o := n
9
10# These files are disabled because they produce non-interesting and/or
11# flaky coverage that is not a function of syscall inputs. E.g. slab is out of
12# free pages, or a task is migrated between nodes.
13KCOV_INSTRUMENT_slab_common.o := n
14KCOV_INSTRUMENT_slob.o := n
15KCOV_INSTRUMENT_slab.o := n
16KCOV_INSTRUMENT_slub.o := n
17KCOV_INSTRUMENT_page_alloc.o := n
18KCOV_INSTRUMENT_debug-pagealloc.o := n
19KCOV_INSTRUMENT_kmemleak.o := n
20KCOV_INSTRUMENT_memcontrol.o := n
21KCOV_INSTRUMENT_mmzone.o := n
22KCOV_INSTRUMENT_vmstat.o := n
23
24mmu-y := nommu.o
25mmu-$(CONFIG_MMU) := gup.o highmem.o memory.o mincore.o \
26 mlock.o mmap.o mprotect.o mremap.o msync.o \
27 page_vma_mapped.o pagewalk.o pgtable-generic.o \
28 rmap.o vmalloc.o
29
30
31ifdef CONFIG_CROSS_MEMORY_ATTACH
32mmu-$(CONFIG_MMU) += process_vm_access.o
33endif
34
35obj-y := filemap.o mempool.o oom_kill.o \
36 maccess.o page_alloc.o page-writeback.o \
37 readahead.o swap.o truncate.o vmscan.o shmem.o \
38 util.o mmzone.o vmstat.o backing-dev.o \
39 mm_init.o mmu_context.o percpu.o slab_common.o \
40 compaction.o vmacache.o \
41 interval_tree.o list_lru.o workingset.o \
42 debug.o $(mmu-y)
43
44obj-y += init-mm.o
45
46ifdef CONFIG_NO_BOOTMEM
47 obj-y += nobootmem.o
48else
49 obj-y += bootmem.o
50endif
51
52obj-$(CONFIG_ADVISE_SYSCALLS) += fadvise.o
53ifdef CONFIG_MMU
54 obj-$(CONFIG_ADVISE_SYSCALLS) += madvise.o
55endif
56obj-$(CONFIG_HAVE_MEMBLOCK) += memblock.o
57
58obj-$(CONFIG_SWAP) += page_io.o swap_state.o swapfile.o swap_slots.o
59obj-$(CONFIG_FRONTSWAP) += frontswap.o
60obj-$(CONFIG_ZSWAP) += zswap.o
61obj-$(CONFIG_HAS_DMA) += dmapool.o
62obj-$(CONFIG_HUGETLBFS) += hugetlb.o
63obj-$(CONFIG_NUMA) += mempolicy.o
64obj-$(CONFIG_SPARSEMEM) += sparse.o
65obj-$(CONFIG_SPARSEMEM_VMEMMAP) += sparse-vmemmap.o
66obj-$(CONFIG_SLOB) += slob.o
67obj-$(CONFIG_MMU_NOTIFIER) += mmu_notifier.o
68obj-$(CONFIG_KSM) += ksm.o
69obj-$(CONFIG_PAGE_POISONING) += page_poison.o
70obj-$(CONFIG_SLAB) += slab.o
71obj-$(CONFIG_SLUB) += slub.o
72obj-$(CONFIG_KASAN) += kasan
73obj-$(CONFIG_FAILSLAB) += failslab.o
74obj-$(CONFIG_MEMORY_HOTPLUG) += memory_hotplug.o
75obj-$(CONFIG_MEMTEST) += memtest.o
76obj-$(CONFIG_MIGRATION) += migrate.o
77obj-$(CONFIG_QUICKLIST) += quicklist.o
78obj-$(CONFIG_TRANSPARENT_HUGEPAGE) += huge_memory.o khugepaged.o
79obj-$(CONFIG_PAGE_COUNTER) += page_counter.o
80obj-$(CONFIG_MEMCG) += memcontrol.o vmpressure.o
81obj-$(CONFIG_MEMCG_SWAP) += swap_cgroup.o
82obj-$(CONFIG_CGROUP_HUGETLB) += hugetlb_cgroup.o
83obj-$(CONFIG_GUP_BENCHMARK) += gup_benchmark.o
84obj-$(CONFIG_MEMORY_FAILURE) += memory-failure.o
85obj-$(CONFIG_HWPOISON_INJECT) += hwpoison-inject.o
86obj-$(CONFIG_DEBUG_KMEMLEAK) += kmemleak.o
87obj-$(CONFIG_DEBUG_KMEMLEAK_TEST) += kmemleak-test.o
88obj-$(CONFIG_DEBUG_RODATA_TEST) += rodata_test.o
89obj-$(CONFIG_PAGE_OWNER) += page_owner.o
90obj-$(CONFIG_CLEANCACHE) += cleancache.o
91obj-$(CONFIG_MEMORY_ISOLATION) += page_isolation.o
92obj-$(CONFIG_ZPOOL) += zpool.o
93obj-$(CONFIG_ZBUD) += zbud.o
94obj-$(CONFIG_ZSMALLOC) += zsmalloc.o
95obj-$(CONFIG_Z3FOLD) += z3fold.o
96obj-$(CONFIG_GENERIC_EARLY_IOREMAP) += early_ioremap.o
97obj-$(CONFIG_CMA) += cma.o
98obj-$(CONFIG_MEMORY_BALLOON) += balloon_compaction.o
99obj-$(CONFIG_PAGE_EXTENSION) += page_ext.o
100obj-$(CONFIG_CMA_DEBUGFS) += cma_debug.o
101obj-$(CONFIG_USERFAULTFD) += userfaultfd.o
102obj-$(CONFIG_IDLE_PAGE_TRACKING) += page_idle.o
103obj-$(CONFIG_FRAME_VECTOR) += frame_vector.o
104obj-$(CONFIG_DEBUG_PAGE_REF) += debug_page_ref.o
105obj-$(CONFIG_HARDENED_USERCOPY) += usercopy.o
106obj-$(CONFIG_PERCPU_STATS) += percpu-stats.o
107obj-$(CONFIG_HMM) += hmm.o
1#
2# Makefile for the linux memory manager.
3#
4
5mmu-y := nommu.o
6mmu-$(CONFIG_MMU) := fremap.o highmem.o madvise.o memory.o mincore.o \
7 mlock.o mmap.o mprotect.o mremap.o msync.o rmap.o \
8 vmalloc.o pagewalk.o pgtable-generic.o
9
10ifdef CONFIG_CROSS_MEMORY_ATTACH
11mmu-$(CONFIG_MMU) += process_vm_access.o
12endif
13
14obj-y := filemap.o mempool.o oom_kill.o fadvise.o \
15 maccess.o page_alloc.o page-writeback.o \
16 readahead.o swap.o truncate.o vmscan.o shmem.o \
17 prio_tree.o util.o mmzone.o vmstat.o backing-dev.o \
18 page_isolation.o mm_init.o mmu_context.o percpu.o \
19 compaction.o $(mmu-y)
20obj-y += init-mm.o
21
22ifdef CONFIG_NO_BOOTMEM
23 obj-y += nobootmem.o
24else
25 obj-y += bootmem.o
26endif
27
28obj-$(CONFIG_HAVE_MEMBLOCK) += memblock.o
29
30obj-$(CONFIG_BOUNCE) += bounce.o
31obj-$(CONFIG_SWAP) += page_io.o swap_state.o swapfile.o
32obj-$(CONFIG_FRONTSWAP) += frontswap.o
33obj-$(CONFIG_HAS_DMA) += dmapool.o
34obj-$(CONFIG_HUGETLBFS) += hugetlb.o
35obj-$(CONFIG_NUMA) += mempolicy.o
36obj-$(CONFIG_SPARSEMEM) += sparse.o
37obj-$(CONFIG_SPARSEMEM_VMEMMAP) += sparse-vmemmap.o
38obj-$(CONFIG_SLOB) += slob.o
39obj-$(CONFIG_MMU_NOTIFIER) += mmu_notifier.o
40obj-$(CONFIG_KSM) += ksm.o
41obj-$(CONFIG_PAGE_POISONING) += debug-pagealloc.o
42obj-$(CONFIG_SLAB) += slab.o
43obj-$(CONFIG_SLUB) += slub.o
44obj-$(CONFIG_KMEMCHECK) += kmemcheck.o
45obj-$(CONFIG_FAILSLAB) += failslab.o
46obj-$(CONFIG_MEMORY_HOTPLUG) += memory_hotplug.o
47obj-$(CONFIG_FS_XIP) += filemap_xip.o
48obj-$(CONFIG_MIGRATION) += migrate.o
49obj-$(CONFIG_QUICKLIST) += quicklist.o
50obj-$(CONFIG_TRANSPARENT_HUGEPAGE) += huge_memory.o
51obj-$(CONFIG_CGROUP_MEM_RES_CTLR) += memcontrol.o page_cgroup.o
52obj-$(CONFIG_MEMORY_FAILURE) += memory-failure.o
53obj-$(CONFIG_HWPOISON_INJECT) += hwpoison-inject.o
54obj-$(CONFIG_DEBUG_KMEMLEAK) += kmemleak.o
55obj-$(CONFIG_DEBUG_KMEMLEAK_TEST) += kmemleak-test.o
56obj-$(CONFIG_CLEANCACHE) += cleancache.o