Makefile 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. # SPDX-License-Identifier: GPL-2.0
  2. #
  3. # Makefile for the linux kernel.
  4. #
  5. CPPFLAGS_vmlinux.lds := -DTEXT_OFFSET=$(TEXT_OFFSET)
  6. AFLAGS_head.o := -DTEXT_OFFSET=$(TEXT_OFFSET)
  7. ifdef CONFIG_FUNCTION_TRACER
  8. CFLAGS_REMOVE_ftrace.o = -pg
  9. CFLAGS_REMOVE_insn.o = -pg
  10. CFLAGS_REMOVE_patch.o = -pg
  11. endif
  12. CFLAGS_REMOVE_return_address.o = -pg
  13. # Object file lists.
  14. obj-y := elf.o entry-common.o irq.o opcodes.o \
  15. process.o ptrace.o reboot.o return_address.o \
  16. setup.o signal.o sigreturn_codes.o \
  17. stacktrace.o sys_arm.o time.o traps.o
  18. obj-$(CONFIG_ATAGS) += atags_parse.o
  19. obj-$(CONFIG_ATAGS_PROC) += atags_proc.o
  20. obj-$(CONFIG_DEPRECATED_PARAM_STRUCT) += atags_compat.o
  21. ifeq ($(CONFIG_CPU_V7M),y)
  22. obj-y += entry-v7m.o v7m.o
  23. else
  24. obj-y += entry-armv.o
  25. endif
  26. obj-$(CONFIG_MMU) += bugs.o
  27. obj-$(CONFIG_CPU_IDLE) += cpuidle.o
  28. obj-$(CONFIG_ISA_DMA_API) += dma.o
  29. obj-$(CONFIG_FIQ) += fiq.o fiqasm.o
  30. obj-$(CONFIG_MODULES) += armksyms.o module.o
  31. obj-$(CONFIG_ARM_MODULE_PLTS) += module-plts.o
  32. obj-$(CONFIG_ISA_DMA) += dma-isa.o
  33. obj-$(CONFIG_PCI) += bios32.o isa.o
  34. obj-$(CONFIG_ARM_CPU_SUSPEND) += sleep.o suspend.o
  35. obj-$(CONFIG_HIBERNATION) += hibernate.o
  36. obj-$(CONFIG_SMP) += smp.o
  37. ifdef CONFIG_MMU
  38. obj-$(CONFIG_SMP) += smp_tlb.o
  39. endif
  40. obj-$(CONFIG_HAVE_ARM_SCU) += smp_scu.o
  41. obj-$(CONFIG_HAVE_ARM_TWD) += smp_twd.o
  42. obj-$(CONFIG_ARM_ARCH_TIMER) += arch_timer.o
  43. obj-$(CONFIG_FUNCTION_TRACER) += entry-ftrace.o
  44. obj-$(CONFIG_DYNAMIC_FTRACE) += ftrace.o insn.o
  45. obj-$(CONFIG_FUNCTION_GRAPH_TRACER) += ftrace.o insn.o
  46. obj-$(CONFIG_JUMP_LABEL) += jump_label.o insn.o patch.o
  47. obj-$(CONFIG_KEXEC) += machine_kexec.o relocate_kernel.o
  48. # Main staffs in KPROBES are in arch/arm/probes/ .
  49. obj-$(CONFIG_KPROBES) += patch.o insn.o
  50. obj-$(CONFIG_OABI_COMPAT) += sys_oabi-compat.o
  51. obj-$(CONFIG_ARM_THUMBEE) += thumbee.o
  52. obj-$(CONFIG_KGDB) += kgdb.o patch.o
  53. obj-$(CONFIG_ARM_UNWIND) += unwind.o
  54. obj-$(CONFIG_HAVE_TCM) += tcm.o
  55. obj-$(CONFIG_OF) += devtree.o
  56. obj-$(CONFIG_CRASH_DUMP) += crash_dump.o
  57. obj-$(CONFIG_SWP_EMULATE) += swp_emulate.o
  58. CFLAGS_swp_emulate.o := -Wa,-march=armv7-a
  59. obj-$(CONFIG_HAVE_HW_BREAKPOINT) += hw_breakpoint.o
  60. obj-$(CONFIG_CPU_XSCALE) += xscale-cp0.o
  61. obj-$(CONFIG_CPU_XSC3) += xscale-cp0.o
  62. obj-$(CONFIG_CPU_MOHAWK) += xscale-cp0.o
  63. obj-$(CONFIG_CPU_PJ4) += pj4-cp0.o
  64. obj-$(CONFIG_CPU_PJ4B) += pj4-cp0.o
  65. obj-$(CONFIG_IWMMXT) += iwmmxt.o
  66. obj-$(CONFIG_PERF_EVENTS) += perf_regs.o perf_callchain.o
  67. obj-$(CONFIG_HW_PERF_EVENTS) += perf_event_xscale.o perf_event_v6.o \
  68. perf_event_v7.o
  69. AFLAGS_iwmmxt.o := -Wa,-mcpu=iwmmxt
  70. obj-$(CONFIG_ARM_CPU_TOPOLOGY) += topology.o
  71. obj-$(CONFIG_VDSO) += vdso.o
  72. obj-$(CONFIG_EFI) += efi.o
  73. ifneq ($(CONFIG_ARCH_EBSA110),y)
  74. obj-y += io.o
  75. endif
  76. obj-$(CONFIG_PARAVIRT) += paravirt.o
  77. head-y := head$(MMUEXT).o
  78. obj-$(CONFIG_DEBUG_LL) += debug.o
  79. obj-$(CONFIG_EARLY_PRINTK) += early_printk.o
  80. # This is executed very early using a temporary stack when no memory allocator
  81. # nor global data is available. Everything has to be allocated on the stack.
  82. CFLAGS_head-inflate-data.o := $(call cc-option,-Wframe-larger-than=10240)
  83. obj-$(CONFIG_XIP_DEFLATED_DATA) += head-inflate-data.o
  84. obj-$(CONFIG_ARM_VIRT_EXT) += hyp-stub.o
  85. AFLAGS_hyp-stub.o :=-Wa,-march=armv7-a
  86. ifeq ($(CONFIG_ARM_PSCI),y)
  87. obj-$(CONFIG_SMP) += psci_smp.o
  88. endif
  89. obj-$(CONFIG_HAVE_ARM_SMCCC) += smccc-call.o
  90. extra-y := $(head-y) vmlinux.lds