1# 2# Makefile for the linux kernel. 3# 4 5ifdef CONFIG_FUNCTION_TRACER 6# Don't trace early setup code and tracing code 7CFLAGS_REMOVE_early.o = $(CC_FLAGS_FTRACE) 8CFLAGS_REMOVE_ftrace.o = $(CC_FLAGS_FTRACE) 9endif 10 11# 12# Passing null pointers is ok for smp code, since we access the lowcore here. 13# 14CFLAGS_smp.o := -Wno-nonnull 15 16# 17# Disable tailcall optimizations for stack / callchain walking functions 18# since this might generate broken code when accessing register 15 and 19# passing its content to other functions. 20# 21CFLAGS_stacktrace.o += -fno-optimize-sibling-calls 22CFLAGS_dumpstack.o += -fno-optimize-sibling-calls 23 24# 25# Pass UTS_MACHINE for user_regset definition 26# 27CFLAGS_ptrace.o += -DUTS_MACHINE='"$(UTS_MACHINE)"' 28 29CFLAGS_sysinfo.o += -Iinclude/math-emu -Iarch/s390/math-emu -w 30 31obj-y := traps.o time.o process.o base.o early.o setup.o idle.o vtime.o 32obj-y += processor.o sys_s390.o ptrace.o signal.o cpcmd.o ebcdic.o nmi.o 33obj-y += debug.o irq.o ipl.o dis.o diag.o sclp.o vdso.o 34obj-y += sysinfo.o jump_label.o lgr.o os_info.o machine_kexec.o pgm_check.o 35obj-y += dumpstack.o 36 37obj-y += $(if $(CONFIG_64BIT),entry64.o,entry.o) 38obj-y += $(if $(CONFIG_64BIT),reipl64.o,reipl.o) 39obj-y += $(if $(CONFIG_64BIT),relocate_kernel64.o,relocate_kernel.o) 40 41extra-y += head.o vmlinux.lds 42extra-y += $(if $(CONFIG_64BIT),head64.o,head31.o) 43 44obj-$(CONFIG_MODULES) += s390_ksyms.o module.o 45obj-$(CONFIG_SMP) += smp.o 46obj-$(CONFIG_SCHED_BOOK) += topology.o 47obj-$(CONFIG_HIBERNATION) += suspend.o swsusp_asm64.o 48obj-$(CONFIG_AUDIT) += audit.o 49compat-obj-$(CONFIG_AUDIT) += compat_audit.o 50obj-$(CONFIG_COMPAT) += compat_linux.o compat_signal.o 51obj-$(CONFIG_COMPAT) += compat_wrapper.o $(compat-obj-y) 52 53obj-$(CONFIG_STACKTRACE) += stacktrace.o 54obj-$(CONFIG_KPROBES) += kprobes.o 55obj-$(CONFIG_FUNCTION_TRACER) += mcount.o ftrace.o 56obj-$(CONFIG_CRASH_DUMP) += crash_dump.o 57obj-$(CONFIG_UPROBES) += uprobes.o 58 59ifdef CONFIG_64BIT 60obj-$(CONFIG_PERF_EVENTS) += perf_event.o perf_cpum_cf.o perf_cpum_sf.o \ 61 perf_cpum_cf_events.o 62obj-y += runtime_instr.o cache.o 63endif 64 65# vdso 66obj-$(CONFIG_64BIT) += vdso64/ 67obj-$(CONFIG_32BIT) += vdso32/ 68obj-$(CONFIG_COMPAT) += vdso32/ 69