xref: /openbmc/linux/arch/s390/kernel/Makefile (revision 7eec52db361a6ae6fbbd86c2299718586866b664)
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