Makefile 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. #
  2. # Makefile for the linux kernel.
  3. #
  4. ifdef CONFIG_FUNCTION_TRACER
  5. # Do not trace tracer code
  6. CFLAGS_REMOVE_ftrace.o = $(CC_FLAGS_FTRACE)
  7. # Do not trace early setup code
  8. CFLAGS_REMOVE_als.o = $(CC_FLAGS_FTRACE)
  9. CFLAGS_REMOVE_early.o = $(CC_FLAGS_FTRACE)
  10. CFLAGS_REMOVE_sclp.o = $(CC_FLAGS_FTRACE)
  11. endif
  12. GCOV_PROFILE_als.o := n
  13. GCOV_PROFILE_early.o := n
  14. GCOV_PROFILE_sclp.o := n
  15. KCOV_INSTRUMENT_als.o := n
  16. KCOV_INSTRUMENT_early.o := n
  17. KCOV_INSTRUMENT_sclp.o := n
  18. UBSAN_SANITIZE_als.o := n
  19. UBSAN_SANITIZE_early.o := n
  20. UBSAN_SANITIZE_sclp.o := n
  21. #
  22. # Use -march=z900 for sclp.c and als.c to be able to print an error
  23. # message if the kernel is started on a machine which is too old
  24. #
  25. ifneq ($(CC_FLAGS_MARCH),-march=z900)
  26. CFLAGS_REMOVE_als.o += $(CC_FLAGS_MARCH)
  27. CFLAGS_als.o += -march=z900
  28. CFLAGS_REMOVE_sclp.o += $(CC_FLAGS_MARCH)
  29. CFLAGS_sclp.o += -march=z900
  30. AFLAGS_REMOVE_head.o += $(CC_FLAGS_MARCH)
  31. AFLAGS_head.o += -march=z900
  32. endif
  33. #
  34. # Passing null pointers is ok for smp code, since we access the lowcore here.
  35. #
  36. CFLAGS_smp.o := -Wno-nonnull
  37. #
  38. # Disable tailcall optimizations for stack / callchain walking functions
  39. # since this might generate broken code when accessing register 15 and
  40. # passing its content to other functions.
  41. #
  42. CFLAGS_stacktrace.o += -fno-optimize-sibling-calls
  43. CFLAGS_dumpstack.o += -fno-optimize-sibling-calls
  44. #
  45. # Pass UTS_MACHINE for user_regset definition
  46. #
  47. CFLAGS_ptrace.o += -DUTS_MACHINE='"$(UTS_MACHINE)"'
  48. CFLAGS_sysinfo.o += -w
  49. obj-y := traps.o time.o process.o base.o early.o setup.o idle.o vtime.o
  50. obj-y += processor.o sys_s390.o ptrace.o signal.o cpcmd.o ebcdic.o nmi.o
  51. obj-y += debug.o irq.o ipl.o dis.o diag.o sclp.o vdso.o als.o
  52. obj-y += sysinfo.o jump_label.o lgr.o os_info.o machine_kexec.o pgm_check.o
  53. obj-y += runtime_instr.o cache.o fpu.o dumpstack.o
  54. obj-y += entry.o reipl.o relocate_kernel.o
  55. extra-y += head.o head64.o vmlinux.lds
  56. obj-$(CONFIG_MODULES) += module.o
  57. obj-$(CONFIG_SMP) += smp.o
  58. obj-$(CONFIG_SCHED_TOPOLOGY) += topology.o
  59. obj-$(CONFIG_HIBERNATION) += suspend.o swsusp.o
  60. obj-$(CONFIG_AUDIT) += audit.o
  61. compat-obj-$(CONFIG_AUDIT) += compat_audit.o
  62. obj-$(CONFIG_COMPAT) += compat_linux.o compat_signal.o
  63. obj-$(CONFIG_COMPAT) += compat_wrapper.o $(compat-obj-y)
  64. obj-$(CONFIG_STACKTRACE) += stacktrace.o
  65. obj-$(CONFIG_KPROBES) += kprobes.o
  66. obj-$(CONFIG_FUNCTION_TRACER) += mcount.o ftrace.o
  67. obj-$(CONFIG_CRASH_DUMP) += crash_dump.o
  68. obj-$(CONFIG_UPROBES) += uprobes.o
  69. obj-$(CONFIG_PERF_EVENTS) += perf_event.o perf_cpum_cf.o perf_cpum_sf.o
  70. obj-$(CONFIG_PERF_EVENTS) += perf_cpum_cf_events.o
  71. obj-$(CONFIG_TRACEPOINTS) += trace.o
  72. # vdso
  73. obj-y += vdso64/
  74. obj-$(CONFIG_COMPAT) += vdso32/