Makefile 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. # SPDX-License-Identifier: GPL-2.0
  2. #
  3. # Makefile for the linux kernel.
  4. #
  5. ifdef CONFIG_PPC32
  6. CFLAGS_prom_init.o += -fPIC
  7. CFLAGS_btext.o += -fPIC
  8. endif
  9. CFLAGS_early_32.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
  10. CFLAGS_cputable.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
  11. CFLAGS_prom_init.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
  12. CFLAGS_btext.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
  13. CFLAGS_prom.o += $(DISABLE_LATENT_ENTROPY_PLUGIN)
  14. CFLAGS_prom_init.o += -fno-stack-protector
  15. CFLAGS_prom_init.o += -DDISABLE_BRANCH_PROFILING
  16. CFLAGS_prom_init.o += -ffreestanding
  17. CFLAGS_prom_init.o += $(call cc-option, -ftrivial-auto-var-init=uninitialized)
  18. ifdef CONFIG_FUNCTION_TRACER
  19. # Do not trace early boot code
  20. CFLAGS_REMOVE_cputable.o = $(CC_FLAGS_FTRACE)
  21. CFLAGS_REMOVE_prom_init.o = $(CC_FLAGS_FTRACE)
  22. CFLAGS_REMOVE_btext.o = $(CC_FLAGS_FTRACE)
  23. CFLAGS_REMOVE_prom.o = $(CC_FLAGS_FTRACE)
  24. endif
  25. KASAN_SANITIZE_early_32.o := n
  26. KASAN_SANITIZE_cputable.o := n
  27. KASAN_SANITIZE_prom_init.o := n
  28. KASAN_SANITIZE_btext.o := n
  29. KASAN_SANITIZE_paca.o := n
  30. KASAN_SANITIZE_setup_64.o := n
  31. KASAN_SANITIZE_mce.o := n
  32. KASAN_SANITIZE_mce_power.o := n
  33. KASAN_SANITIZE_udbg.o := n
  34. KASAN_SANITIZE_udbg_16550.o := n
  35. # we have to be particularly careful in ppc64 to exclude code that
  36. # runs with translations off, as we cannot access the shadow with
  37. # translations off. However, ppc32 can sanitize this.
  38. ifdef CONFIG_PPC64
  39. KASAN_SANITIZE_traps.o := n
  40. endif
  41. ifdef CONFIG_KASAN
  42. CFLAGS_early_32.o += -DDISABLE_BRANCH_PROFILING
  43. CFLAGS_cputable.o += -DDISABLE_BRANCH_PROFILING
  44. CFLAGS_btext.o += -DDISABLE_BRANCH_PROFILING
  45. endif
  46. KCSAN_SANITIZE_early_32.o := n
  47. KCSAN_SANITIZE_cputable.o := n
  48. KCSAN_SANITIZE_btext.o := n
  49. KCSAN_SANITIZE_paca.o := n
  50. KCSAN_SANITIZE_setup_64.o := n
  51. #ifdef CONFIG_RANDOMIZE_KSTACK_OFFSET
  52. # Remove stack protector to avoid triggering unneeded stack canary
  53. # checks due to randomize_kstack_offset.
  54. CFLAGS_REMOVE_syscall.o = -fstack-protector -fstack-protector-strong
  55. CFLAGS_syscall.o += -fno-stack-protector
  56. #endif
  57. obj-y := cputable.o syscalls.o switch.o \
  58. irq.o align.o signal_$(BITS).o pmc.o vdso.o \
  59. process.o systbl.o idle.o \
  60. signal.o sysfs.o cacheinfo.o time.o \
  61. prom.o traps.o setup-common.o \
  62. udbg.o misc.o io.o misc_$(BITS).o \
  63. of_platform.o prom_parse.o firmware.o \
  64. hw_breakpoint_constraints.o interrupt.o \
  65. kdebugfs.o stacktrace.o syscall.o
  66. obj-y += ptrace/
  67. obj-$(CONFIG_PPC64) += setup_64.o irq_64.o\
  68. paca.o nvram_64.o note.o
  69. obj-$(CONFIG_PPC32) += sys_ppc32.o
  70. obj-$(CONFIG_COMPAT) += sys_ppc32.o signal_32.o
  71. obj-$(CONFIG_VDSO32) += vdso32_wrapper.o
  72. obj-$(CONFIG_PPC_WATCHDOG) += watchdog.o
  73. obj-$(CONFIG_HAVE_HW_BREAKPOINT) += hw_breakpoint.o
  74. obj-$(CONFIG_PPC_DAWR) += dawr.o
  75. obj-$(CONFIG_PPC_BOOK3S_64) += cpu_setup_ppc970.o cpu_setup_pa6t.o
  76. obj-$(CONFIG_PPC_BOOK3S_64) += cpu_setup_power.o
  77. obj-$(CONFIG_PPC_BOOK3S_64) += dexcr.o
  78. obj-$(CONFIG_PPC_BOOK3S_64) += mce.o mce_power.o
  79. obj-$(CONFIG_PPC_BOOK3E_64) += exceptions-64e.o idle_64e.o
  80. obj-$(CONFIG_PPC_BARRIER_NOSPEC) += security.o
  81. obj-$(CONFIG_PPC64) += vdso64_wrapper.o
  82. obj-$(CONFIG_ALTIVEC) += vecemu.o
  83. obj-$(CONFIG_PPC_BOOK3S_IDLE) += idle_book3s.o
  84. procfs-y := proc_powerpc.o
  85. obj-$(CONFIG_PROC_FS) += $(procfs-y)
  86. rtaspci-$(CONFIG_PPC64)-$(CONFIG_PCI) := rtas_pci.o
  87. obj-$(CONFIG_PPC_RTAS) += rtas_entry.o rtas.o rtas-rtc.o $(rtaspci-y-y)
  88. obj-$(CONFIG_PPC_RTAS_DAEMON) += rtasd.o
  89. obj-$(CONFIG_RTAS_FLASH) += rtas_flash.o
  90. obj-$(CONFIG_RTAS_PROC) += rtas-proc.o
  91. obj-$(CONFIG_PPC_DT_CPU_FTRS) += dt_cpu_ftrs.o
  92. obj-$(CONFIG_EEH) += eeh.o eeh_pe.o eeh_cache.o \
  93. eeh_driver.o eeh_event.o eeh_sysfs.o
  94. obj-$(CONFIG_GENERIC_TBSYNC) += smp-tbsync.o
  95. obj-$(CONFIG_CRASH_DUMP) += crash_dump.o
  96. obj-$(CONFIG_FA_DUMP) += fadump.o
  97. obj-$(CONFIG_PRESERVE_FA_DUMP) += fadump.o
  98. obj-$(CONFIG_PPC_85xx) += idle_85xx.o
  99. obj-$(CONFIG_PPC_BOOK3S_32) += idle_6xx.o l2cr_6xx.o cpu_setup_6xx.o
  100. obj-$(CONFIG_TAU) += tau_6xx.o
  101. obj-$(CONFIG_HIBERNATION) += swsusp.o suspend.o
  102. ifdef CONFIG_PPC_85xx
  103. obj-$(CONFIG_HIBERNATION) += swsusp_85xx.o
  104. else
  105. obj-$(CONFIG_HIBERNATION) += swsusp_$(BITS).o
  106. endif
  107. obj64-$(CONFIG_HIBERNATION) += swsusp_asm64.o
  108. obj-$(CONFIG_MODULES) += module.o module_$(BITS).o
  109. obj-$(CONFIG_44x) += cpu_setup_44x.o
  110. obj-$(CONFIG_PPC_E500) += cpu_setup_e500.o
  111. obj-$(CONFIG_PPC_DOORBELL) += dbell.o
  112. obj-$(CONFIG_JUMP_LABEL) += jump_label.o
  113. obj-$(CONFIG_PPC64) += head_64.o
  114. obj-$(CONFIG_PPC_BOOK3S_32) += head_book3s_32.o
  115. obj-$(CONFIG_44x) += head_44x.o
  116. obj-$(CONFIG_PPC_8xx) += head_8xx.o
  117. obj-$(CONFIG_PPC_85xx) += head_85xx.o
  118. extra-y += vmlinux.lds
  119. obj-$(CONFIG_RELOCATABLE) += reloc_$(BITS).o
  120. obj-$(CONFIG_PPC32) += entry_32.o setup_32.o early_32.o static_call.o
  121. obj-$(CONFIG_PPC64) += dma-iommu.o iommu.o
  122. obj-$(CONFIG_KGDB) += kgdb.o
  123. obj-$(CONFIG_BOOTX_TEXT) += btext.o
  124. obj-$(CONFIG_SMP) += smp.o
  125. obj-$(CONFIG_KPROBES) += kprobes.o
  126. obj-$(CONFIG_OPTPROBES) += optprobes.o optprobes_head.o
  127. obj-$(CONFIG_KPROBES_ON_FTRACE) += kprobes-ftrace.o
  128. obj-$(CONFIG_UPROBES) += uprobes.o
  129. obj-$(CONFIG_RETHOOK) += rethook.o
  130. obj-$(CONFIG_PPC_UDBG_16550) += legacy_serial.o udbg_16550.o
  131. obj-$(CONFIG_SWIOTLB) += dma-swiotlb.o
  132. obj-$(CONFIG_ARCH_HAS_DMA_SET_MASK) += dma-mask.o
  133. pci64-$(CONFIG_PPC64) += pci_dn.o pci-hotplug.o isa-bridge.o
  134. obj-$(CONFIG_PCI) += pci_$(BITS).o $(pci64-y) \
  135. pci-common.o pci_of_scan.o
  136. obj-$(CONFIG_PCI_MSI) += msi.o
  137. obj-$(CONFIG_AUDIT) += audit.o
  138. obj64-$(CONFIG_AUDIT) += compat_audit.o
  139. obj-$(CONFIG_PPC_IO_WORKAROUNDS) += io-workarounds.o
  140. obj-y += trace/
  141. ifneq ($(CONFIG_PPC_INDIRECT_PIO),y)
  142. obj-y += iomap.o
  143. endif
  144. obj64-$(CONFIG_PPC_TRANSACTIONAL_MEM) += tm.o
  145. obj-y += ppc_save_regs.o
  146. obj-$(CONFIG_EPAPR_PARAVIRT) += epapr_paravirt.o epapr_hcalls.o
  147. obj-$(CONFIG_KVM_GUEST) += kvm.o kvm_emul.o
  148. ifneq ($(CONFIG_PPC_POWERNV)$(CONFIG_PPC_SVM),)
  149. obj-y += ucall.o
  150. endif
  151. obj-$(CONFIG_PPC_SECURE_BOOT) += secure_boot.o ima_arch.o secvar-ops.o
  152. obj-$(CONFIG_PPC_SECVAR_SYSFS) += secvar-sysfs.o
  153. # Disable GCOV, KCOV & sanitizers in odd or sensitive code
  154. GCOV_PROFILE_prom_init.o := n
  155. KCOV_INSTRUMENT_prom_init.o := n
  156. KCSAN_SANITIZE_prom_init.o := n
  157. UBSAN_SANITIZE_prom_init.o := n
  158. GCOV_PROFILE_kprobes.o := n
  159. KCOV_INSTRUMENT_kprobes.o := n
  160. KCSAN_SANITIZE_kprobes.o := n
  161. UBSAN_SANITIZE_kprobes.o := n
  162. GCOV_PROFILE_kprobes-ftrace.o := n
  163. KCOV_INSTRUMENT_kprobes-ftrace.o := n
  164. KCSAN_SANITIZE_kprobes-ftrace.o := n
  165. UBSAN_SANITIZE_kprobes-ftrace.o := n
  166. UBSAN_SANITIZE_vdso.o := n
  167. # Necessary for booting with kcov enabled on book3e machines
  168. KCOV_INSTRUMENT_cputable.o := n
  169. KCOV_INSTRUMENT_setup_64.o := n
  170. KCOV_INSTRUMENT_paca.o := n
  171. CFLAGS_setup_64.o += -fno-stack-protector
  172. CFLAGS_paca.o += -fno-stack-protector
  173. obj-$(CONFIG_PPC_FPU) += fpu.o
  174. obj-$(CONFIG_ALTIVEC) += vector.o
  175. obj-$(CONFIG_PPC_OF_BOOT_TRAMPOLINE) += prom_init.o
  176. obj64-$(CONFIG_PPC_OF_BOOT_TRAMPOLINE) += prom_entry_64.o
  177. extra-$(CONFIG_PPC_OF_BOOT_TRAMPOLINE) += prom_init_check
  178. obj-$(CONFIG_PPC64) += $(obj64-y)
  179. obj-$(CONFIG_PPC32) += $(obj32-y)
  180. quiet_cmd_prom_init_check = PROMCHK $@
  181. cmd_prom_init_check = $(CONFIG_SHELL) $< "$(NM)" $(obj)/prom_init.o; touch $@
  182. $(obj)/prom_init_check: $(src)/prom_init_check.sh $(obj)/prom_init.o FORCE
  183. $(call if_changed,prom_init_check)
  184. targets += prom_init_check
  185. clean-files := vmlinux.lds
  186. # Force dependency (incbin is bad)
  187. $(obj)/vdso32_wrapper.o : $(obj)/vdso/vdso32.so.dbg
  188. $(obj)/vdso64_wrapper.o : $(obj)/vdso/vdso64.so.dbg
  189. # for cleaning
  190. subdir- += vdso