Commit | Line | Data |
---|---|---|
0b73214f | 1 | # SPDX-License-Identifier: GPL-2.0 |
1da177e4 LT |
2 | # |
3 | # s390/Makefile | |
4 | # | |
5 | # This file is included by the global makefile so that you can add your own | |
8212f898 | 6 | # architecture-specific flags and dependencies. |
1da177e4 | 7 | # |
1da177e4 LT |
8 | # Copyright (C) 1994 by Linus Torvalds |
9 | # | |
10 | ||
1844c9bc | 11 | LD_BFD := elf64-s390 |
d503ac53 | 12 | KBUILD_LDFLAGS := -m elf64_s390 |
7bdc229f MS |
13 | KBUILD_AFLAGS_MODULE += -fPIC |
14 | KBUILD_CFLAGS_MODULE += -fPIC | |
222d394d | 15 | KBUILD_AFLAGS += -m64 |
76bf9d6c | 16 | KBUILD_CFLAGS += -m64 |
805bc0bc GS |
17 | KBUILD_CFLAGS += -fPIE |
18 | LDFLAGS_vmlinux := -pie | |
ee6d777d | 19 | aflags_dwarf := -Wa,-gdwarf-2 |
96fb54a1 | 20 | KBUILD_AFLAGS_DECOMPRESSOR := $(CLANG_FLAGS) -m64 -D__ASSEMBLY__ |
bb31074d | 21 | ifndef CONFIG_AS_IS_LLVM |
ee6d777d | 22 | KBUILD_AFLAGS_DECOMPRESSOR += $(if $(CONFIG_DEBUG_INFO),$(aflags_dwarf)) |
bb31074d | 23 | endif |
42b01a55 | 24 | KBUILD_CFLAGS_DECOMPRESSOR := $(CLANG_FLAGS) -m64 -O2 -mpacked-stack |
76bf9d6c | 25 | KBUILD_CFLAGS_DECOMPRESSOR += -DDISABLE_BRANCH_PROFILING -D__NO_FORTIFY |
8977ab65 | 26 | KBUILD_CFLAGS_DECOMPRESSOR += -fno-delete-null-pointer-checks -msoft-float -mbackchain |
76bf9d6c | 27 | KBUILD_CFLAGS_DECOMPRESSOR += -fno-asynchronous-unwind-tables |
685969e0 | 28 | KBUILD_CFLAGS_DECOMPRESSOR += -ffreestanding |
42e8d652 | 29 | KBUILD_CFLAGS_DECOMPRESSOR += -fno-stack-protector |
938f0c35 | 30 | KBUILD_CFLAGS_DECOMPRESSOR += -fPIE |
f9364df3 | 31 | KBUILD_CFLAGS_DECOMPRESSOR += $(call cc-disable-warning, address-of-packed-member) |
ee6d777d VG |
32 | KBUILD_CFLAGS_DECOMPRESSOR += $(if $(CONFIG_DEBUG_INFO),-g) |
33 | KBUILD_CFLAGS_DECOMPRESSOR += $(if $(CONFIG_DEBUG_INFO_DWARF4), $(call cc-option, -gdwarf-4,)) | |
f0be87c4 | 34 | KBUILD_CFLAGS_DECOMPRESSOR += $(if $(CONFIG_CC_NO_ARRAY_BOUNDS),-Wno-array-bounds) |
8b202ee2 | 35 | |
1da177e4 | 36 | UTS_MACHINE := s390x |
9fed920e | 37 | STACK_SIZE := $(if $(CONFIG_KASAN),65536,16384) |
14516765 | 38 | CHECKFLAGS += -D__s390__ -D__s390x__ |
1da177e4 | 39 | |
1844c9bc MS |
40 | export LD_BFD |
41 | ||
0f1b1ff5 HC |
42 | mflags-$(CONFIG_MARCH_Z10) := -march=z10 |
43 | mflags-$(CONFIG_MARCH_Z196) := -march=z196 | |
44 | mflags-$(CONFIG_MARCH_ZEC12) := -march=zEC12 | |
6997c323 MS |
45 | mflags-$(CONFIG_MARCH_Z13) := -march=z13 |
46 | mflags-$(CONFIG_MARCH_Z14) := -march=z14 | |
a0e22511 | 47 | mflags-$(CONFIG_MARCH_Z15) := -march=z15 |
e69a7ff8 | 48 | mflags-$(CONFIG_MARCH_Z16) := -march=z16 |
0f1b1ff5 | 49 | |
22362a0e MS |
50 | export CC_FLAGS_MARCH := $(mflags-y) |
51 | ||
0f1b1ff5 HC |
52 | aflags-y += $(mflags-y) |
53 | cflags-y += $(mflags-y) | |
1da177e4 | 54 | |
1db9e051 HC |
55 | cflags-$(CONFIG_MARCH_Z10_TUNE) += -mtune=z10 |
56 | cflags-$(CONFIG_MARCH_Z196_TUNE) += -mtune=z196 | |
57 | cflags-$(CONFIG_MARCH_ZEC12_TUNE) += -mtune=zEC12 | |
6997c323 MS |
58 | cflags-$(CONFIG_MARCH_Z13_TUNE) += -mtune=z13 |
59 | cflags-$(CONFIG_MARCH_Z14_TUNE) += -mtune=z14 | |
a0e22511 | 60 | cflags-$(CONFIG_MARCH_Z15_TUNE) += -mtune=z15 |
e69a7ff8 | 61 | cflags-$(CONFIG_MARCH_Z16_TUNE) += -mtune=z16 |
1db9e051 | 62 | |
c783b91e MS |
63 | cflags-y += -Wa,-I$(srctree)/arch/$(ARCH)/include |
64 | ||
cbbd1fa7 HC |
65 | # |
66 | # Prevent tail-call optimizations, to get clearer backtraces: | |
67 | # | |
68 | cflags-$(CONFIG_FRAME_POINTER) += -fno-optimize-sibling-calls | |
69 | ||
76bf9d6c VG |
70 | KBUILD_AFLAGS_DECOMPRESSOR += $(aflags-y) |
71 | KBUILD_CFLAGS_DECOMPRESSOR += $(cflags-y) | |
72 | ||
ff00f64b | 73 | ifneq ($(call cc-option,-mstack-size=8192 -mstack-guard=128),) |
00b55eaf SS |
74 | CC_FLAGS_CHECK_STACK := -mstack-size=$(STACK_SIZE) |
75 | ifeq ($(call cc-option,-mstack-size=8192),) | |
76 | CC_FLAGS_CHECK_STACK += -mstack-guard=$(CONFIG_STACK_GUARD) | |
77 | endif | |
78 | export CC_FLAGS_CHECK_STACK | |
79 | cflags-$(CONFIG_CHECK_STACK) += $(CC_FLAGS_CHECK_STACK) | |
be796285 | 80 | endif |
1da177e4 | 81 | |
f19fbd5e | 82 | ifdef CONFIG_EXPOLINE |
1d2ad084 | 83 | ifdef CONFIG_EXPOLINE_EXTERN |
c4e78957 | 84 | KBUILD_LDFLAGS_MODULE += arch/s390/lib/expoline/expoline.o |
1d2ad084 VG |
85 | CC_FLAGS_EXPOLINE := -mindirect-branch=thunk-extern |
86 | CC_FLAGS_EXPOLINE += -mfunction-return=thunk-extern | |
87 | else | |
f19fbd5e MS |
88 | CC_FLAGS_EXPOLINE := -mindirect-branch=thunk |
89 | CC_FLAGS_EXPOLINE += -mfunction-return=thunk | |
f19fbd5e | 90 | endif |
1d2ad084 VG |
91 | CC_FLAGS_EXPOLINE += -mindirect-branch-table |
92 | export CC_FLAGS_EXPOLINE | |
93 | cflags-y += $(CC_FLAGS_EXPOLINE) -DCC_USING_EXPOLINE | |
94 | aflags-y += -DCC_USING_EXPOLINE | |
f19fbd5e MS |
95 | endif |
96 | ||
e6d60b36 | 97 | ifdef CONFIG_FUNCTION_TRACER |
ff00f64b | 98 | ifeq ($(call cc-option,-mfentry -mnop-mcount),) |
d983c89c VG |
99 | # make use of hotpatch feature if the compiler supports it |
100 | cc_hotpatch := -mhotpatch=0,3 | |
ff00f64b | 101 | ifneq ($(call cc-option,$(cc_hotpatch)),) |
d983c89c VG |
102 | CC_FLAGS_FTRACE := $(cc_hotpatch) |
103 | KBUILD_AFLAGS += -DCC_USING_HOTPATCH | |
104 | KBUILD_CFLAGS += -DCC_USING_HOTPATCH | |
105 | endif | |
106 | endif | |
e6d60b36 HC |
107 | endif |
108 | ||
7bceec4e HB |
109 | # Test CFI features of binutils |
110 | cfi := $(call as-instr,.cfi_startproc\n.cfi_val_offset 15$(comma)-160\n.cfi_endproc,-DCONFIG_AS_CFI_VAL_OFFSET=1) | |
111 | ||
42b01a55 | 112 | KBUILD_CFLAGS += -mpacked-stack -mbackchain -msoft-float $(cflags-y) |
c1afcaec | 113 | KBUILD_CFLAGS += -pipe -Wno-sign-compare |
7bceec4e HB |
114 | KBUILD_CFLAGS += -fno-asynchronous-unwind-tables $(cfi) |
115 | KBUILD_AFLAGS += $(aflags-y) $(cfi) | |
76bf9d6c VG |
116 | export KBUILD_AFLAGS_DECOMPRESSOR |
117 | export KBUILD_CFLAGS_DECOMPRESSOR | |
1da177e4 LT |
118 | |
119 | OBJCOPYFLAGS := -O binary | |
1da177e4 | 120 | |
4562c9ff | 121 | libs-y += arch/s390/lib/ |
1da177e4 | 122 | |
4562c9ff | 123 | boot := arch/s390/boot |
5c75824d | 124 | syscalls := arch/s390/kernel/syscalls |
c30f6828 | 125 | tools := arch/s390/tools |
1da177e4 | 126 | |
00f2fb57 | 127 | all: bzImage |
1da177e4 | 128 | |
e0aa099c VG |
129 | #KBUILD_IMAGE is necessary for packaging targets like rpm-pkg, deb-pkg... |
130 | KBUILD_IMAGE := $(boot)/bzImage | |
131 | ||
94e90f72 | 132 | install: |
f774f5bb | 133 | $(call cmd,install) |
1da177e4 | 134 | |
00f2fb57 | 135 | bzImage: vmlinux |
1da177e4 LT |
136 | $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ |
137 | ||
411ed322 MH |
138 | zfcpdump: |
139 | $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ | |
140 | ||
f3cb31e4 | 141 | vdso_install: |
f3cb31e4 | 142 | $(Q)$(MAKE) $(build)=arch/$(ARCH)/kernel/vdso64 $@ |
f3cb31e4 | 143 | |
5c75824d HB |
144 | archheaders: |
145 | $(Q)$(MAKE) $(build)=$(syscalls) uapi | |
146 | ||
c30f6828 | 147 | archprepare: |
5c75824d | 148 | $(Q)$(MAKE) $(build)=$(syscalls) kapi |
7fbf8315 | 149 | $(Q)$(MAKE) $(build)=$(tools) kapi |
779df224 SS |
150 | ifeq ($(KBUILD_EXTMOD),) |
151 | # We need to generate vdso-offsets.h before compiling certain files in kernel/. | |
152 | # In order to do that, we should use the archprepare target, but we can't since | |
153 | # asm-offsets.h is included in some files used to generate vdso-offsets.h, and | |
154 | # asm-offsets.h is built in prepare0, for which archprepare is a dependency. | |
155 | # Therefore we need to generate the header after prepare0 has been made, hence | |
156 | # this hack. | |
157 | prepare: vdso_prepare | |
158 | vdso_prepare: prepare0 | |
159 | $(Q)$(MAKE) $(build)=arch/s390/kernel/vdso64 include/generated/vdso64-offsets.h | |
160 | $(if $(CONFIG_COMPAT),$(Q)$(MAKE) \ | |
161 | $(build)=arch/s390/kernel/vdso32 include/generated/vdso32-offsets.h) | |
c4e78957 VG |
162 | |
163 | ifdef CONFIG_EXPOLINE_EXTERN | |
164 | modules_prepare: expoline_prepare | |
7bb2107e | 165 | expoline_prepare: scripts |
c4e78957 VG |
166 | $(Q)$(MAKE) $(build)=arch/s390/lib/expoline arch/s390/lib/expoline/expoline.o |
167 | endif | |
779df224 | 168 | endif |
1da177e4 | 169 | |
1da177e4 LT |
170 | # Don't use tabs in echo arguments |
171 | define archhelp | |
00f2fb57 | 172 | echo '* bzImage - Kernel image for IPL ($(boot)/bzImage)' |
b8eecf36 MH |
173 | echo ' install - Install kernel using' |
174 | echo ' (your) ~/bin/$(INSTALLKERNEL) or' | |
175 | echo ' (distribution) /sbin/$(INSTALLKERNEL) or' | |
176 | echo ' install to $$(INSTALL_PATH)' | |
1da177e4 | 177 | endef |