1# SPDX-License-Identifier: GPL-2.0 2# 3# Makefile for the linux kernel. 4# 5 6CFLAGS_armv8_deprecated.o := -I$(src) 7 8CFLAGS_REMOVE_ftrace.o = $(CC_FLAGS_FTRACE) 9CFLAGS_REMOVE_insn.o = $(CC_FLAGS_FTRACE) 10CFLAGS_REMOVE_return_address.o = $(CC_FLAGS_FTRACE) 11CFLAGS_io.o := -D__DISABLE_TRACE_MMIO__ 12 13# Remove stack protector to avoid triggering unneeded stack canary 14# checks due to randomize_kstack_offset. 15CFLAGS_REMOVE_syscall.o = -fstack-protector -fstack-protector-strong 16CFLAGS_syscall.o += -fno-stack-protector 17 18# When KASAN is enabled, a stack trace is recorded for every alloc/free, which 19# can significantly impact performance. Avoid instrumenting the stack trace 20# collection code to minimize this impact. 21KASAN_SANITIZE_stacktrace.o := n 22 23# It's not safe to invoke KCOV when portions of the kernel environment aren't 24# available or are out-of-sync with HW state. Since `noinstr` doesn't always 25# inhibit KCOV instrumentation, disable it for the entire compilation unit. 26KCOV_INSTRUMENT_entry-common.o := n 27KCOV_INSTRUMENT_idle.o := n 28 29# Object file lists. 30obj-y := debug-monitors.o entry.o irq.o fpsimd.o \ 31 entry-common.o entry-fpsimd.o process.o ptrace.o \ 32 setup.o signal.o sys.o stacktrace.o time.o traps.o \ 33 io.o vdso.o hyp-stub.o psci.o cpu_ops.o \ 34 return_address.o cpuinfo.o cpu_errata.o \ 35 cpufeature.o alternative.o cacheinfo.o \ 36 smp.o smp_spin_table.o topology.o smccc-call.o \ 37 syscall.o proton-pack.o idreg-override.o idle.o \ 38 patching.o 39 40targets += efi-entry.o 41 42OBJCOPYFLAGS := --prefix-symbols=__efistub_ 43$(obj)/%.stub.o: $(obj)/%.o FORCE 44 $(call if_changed,objcopy) 45 46obj-$(CONFIG_COMPAT) += sys32.o signal32.o \ 47 sys_compat.o 48obj-$(CONFIG_COMPAT) += sigreturn32.o 49obj-$(CONFIG_KUSER_HELPERS) += kuser32.o 50obj-$(CONFIG_FUNCTION_TRACER) += ftrace.o entry-ftrace.o 51obj-$(CONFIG_MODULES) += module.o 52obj-$(CONFIG_ARM64_MODULE_PLTS) += module-plts.o 53obj-$(CONFIG_PERF_EVENTS) += perf_regs.o perf_callchain.o 54obj-$(CONFIG_HW_PERF_EVENTS) += perf_event.o 55obj-$(CONFIG_HAVE_HW_BREAKPOINT) += hw_breakpoint.o 56obj-$(CONFIG_CPU_PM) += sleep.o suspend.o 57obj-$(CONFIG_CPU_IDLE) += cpuidle.o 58obj-$(CONFIG_JUMP_LABEL) += jump_label.o 59obj-$(CONFIG_KGDB) += kgdb.o 60obj-$(CONFIG_EFI) += efi.o efi-entry.stub.o \ 61 efi-rt-wrapper.o 62obj-$(CONFIG_PCI) += pci.o 63obj-$(CONFIG_ARMV8_DEPRECATED) += armv8_deprecated.o 64obj-$(CONFIG_ACPI) += acpi.o 65obj-$(CONFIG_ACPI_NUMA) += acpi_numa.o 66obj-$(CONFIG_ARM64_ACPI_PARKING_PROTOCOL) += acpi_parking_protocol.o 67obj-$(CONFIG_PARAVIRT) += paravirt.o 68obj-$(CONFIG_RANDOMIZE_BASE) += kaslr.o 69obj-$(CONFIG_HIBERNATION) += hibernate.o hibernate-asm.o 70obj-$(CONFIG_KEXEC_CORE) += machine_kexec.o relocate_kernel.o \ 71 cpu-reset.o 72obj-$(CONFIG_KEXEC_FILE) += machine_kexec_file.o kexec_image.o 73obj-$(CONFIG_ARM64_RELOC_TEST) += arm64-reloc-test.o 74arm64-reloc-test-y := reloc_test_core.o reloc_test_syms.o 75obj-$(CONFIG_CRASH_DUMP) += crash_dump.o 76obj-$(CONFIG_CRASH_CORE) += crash_core.o 77obj-$(CONFIG_ARM_SDE_INTERFACE) += sdei.o 78obj-$(CONFIG_ARM64_PTR_AUTH) += pointer_auth.o 79obj-$(CONFIG_ARM64_MTE) += mte.o 80obj-y += vdso-wrap.o 81obj-$(CONFIG_COMPAT_VDSO) += vdso32-wrap.o 82obj-$(CONFIG_UNWIND_PATCH_PAC_INTO_SCS) += patch-scs.o 83 84# We need to prevent the SCS patching code from patching itself. Using 85# -mbranch-protection=none here to avoid the patchable PAC opcodes from being 86# generated triggers an issue with full LTO on Clang, which stops emitting PAC 87# instructions altogether. So disable LTO as well for the compilation unit. 88CFLAGS_patch-scs.o += -mbranch-protection=none 89CFLAGS_REMOVE_patch-scs.o += $(CC_FLAGS_LTO) 90 91# Force dependency (vdso*-wrap.S includes vdso.so through incbin) 92$(obj)/vdso-wrap.o: $(obj)/vdso/vdso.so 93$(obj)/vdso32-wrap.o: $(obj)/vdso32/vdso.so 94 95obj-y += probes/ 96head-y := head.o 97extra-y += $(head-y) vmlinux.lds 98 99ifeq ($(CONFIG_DEBUG_EFI),y) 100AFLAGS_head.o += -DVMLINUX_PATH="\"$(realpath $(objtree)/vmlinux)\"" 101endif 102