Makefile 4.0 KB

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