]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blame - arch/s390/Makefile
Merge tag 'armsoc-soc' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc
[mirror_ubuntu-bionic-kernel.git] / arch / s390 / Makefile
CommitLineData
1da177e4
LT
1#
2# s390/Makefile
3#
4# This file is included by the global makefile so that you can add your own
5# architecture-specific flags and dependencies. Remember to do have actions
6# for "archclean" and "archdep" for cleaning up and making dependencies for
7# this architecture
8#
9# This file is subject to the terms and conditions of the GNU General Public
10# License. See the file "COPYING" in the main directory of this archive
11# for more details.
12#
13# Copyright (C) 1994 by Linus Torvalds
14#
15
1844c9bc 16LD_BFD := elf64-s390
1da177e4 17LDFLAGS := -m elf64_s390
7bdc229f
MS
18KBUILD_AFLAGS_MODULE += -fPIC
19KBUILD_CFLAGS_MODULE += -fPIC
a0f97e06 20KBUILD_CFLAGS += -m64
222d394d 21KBUILD_AFLAGS += -m64
1da177e4
LT
22UTS_MACHINE := s390x
23STACK_SIZE := 16384
3b42c17a 24CHECKFLAGS += -D__s390__ -D__s390x__ -mbig-endian
1da177e4 25
1844c9bc
MS
26export LD_BFD
27
0f1b1ff5
HC
28mflags-$(CONFIG_MARCH_Z900) := -march=z900
29mflags-$(CONFIG_MARCH_Z990) := -march=z990
30mflags-$(CONFIG_MARCH_Z9_109) := -march=z9-109
31mflags-$(CONFIG_MARCH_Z10) := -march=z10
32mflags-$(CONFIG_MARCH_Z196) := -march=z196
33mflags-$(CONFIG_MARCH_ZEC12) := -march=zEC12
6997c323
MS
34mflags-$(CONFIG_MARCH_Z13) := -march=z13
35mflags-$(CONFIG_MARCH_Z14) := -march=z14
0f1b1ff5 36
22362a0e
MS
37export CC_FLAGS_MARCH := $(mflags-y)
38
0f1b1ff5
HC
39aflags-y += $(mflags-y)
40cflags-y += $(mflags-y)
1da177e4 41
1db9e051
HC
42cflags-$(CONFIG_MARCH_Z900_TUNE) += -mtune=z900
43cflags-$(CONFIG_MARCH_Z990_TUNE) += -mtune=z990
44cflags-$(CONFIG_MARCH_Z9_109_TUNE) += -mtune=z9-109
45cflags-$(CONFIG_MARCH_Z10_TUNE) += -mtune=z10
46cflags-$(CONFIG_MARCH_Z196_TUNE) += -mtune=z196
47cflags-$(CONFIG_MARCH_ZEC12_TUNE) += -mtune=zEC12
6997c323
MS
48cflags-$(CONFIG_MARCH_Z13_TUNE) += -mtune=z13
49cflags-$(CONFIG_MARCH_Z14_TUNE) += -mtune=z14
1db9e051 50
c783b91e
MS
51cflags-y += -Wa,-I$(srctree)/arch/$(ARCH)/include
52
1681ceda
CB
53#KBUILD_IMAGE is necessary for make rpm
54KBUILD_IMAGE :=arch/s390/boot/image
55
cbbd1fa7
HC
56#
57# Prevent tail-call optimizations, to get clearer backtraces:
58#
59cflags-$(CONFIG_FRAME_POINTER) += -fno-optimize-sibling-calls
60
1da177e4
LT
61# old style option for packed stacks
62ifeq ($(call cc-option-yn,-mkernel-backchain),y)
63cflags-$(CONFIG_PACK_STACK) += -mkernel-backchain -D__PACK_STACK
64aflags-$(CONFIG_PACK_STACK) += -D__PACK_STACK
1da177e4
LT
65endif
66
67# new style option for packed stacks
68ifeq ($(call cc-option-yn,-mpacked-stack),y)
69cflags-$(CONFIG_PACK_STACK) += -mpacked-stack -D__PACK_STACK
70aflags-$(CONFIG_PACK_STACK) += -D__PACK_STACK
1da177e4
LT
71endif
72
73ifeq ($(call cc-option-yn,-mstack-size=8192 -mstack-guard=128),y)
74cflags-$(CONFIG_CHECK_STACK) += -mstack-size=$(STACK_SIZE)
be796285 75ifneq ($(call cc-option-yn,-mstack-size=8192),y)
1da177e4
LT
76cflags-$(CONFIG_CHECK_STACK) += -mstack-guard=$(CONFIG_STACK_GUARD)
77endif
be796285 78endif
1da177e4
LT
79
80ifeq ($(call cc-option-yn,-mwarn-dynamicstack),y)
2c190da4 81cflags-$(CONFIG_WARN_DYNAMIC_STACK) += -mwarn-dynamicstack
1da177e4
LT
82endif
83
e6d60b36
HC
84ifdef CONFIG_FUNCTION_TRACER
85# make use of hotpatch feature if the compiler supports it
86cc_hotpatch := -mhotpatch=0,3
87ifeq ($(call cc-option-yn,$(cc_hotpatch)),y)
88CC_FLAGS_FTRACE := $(cc_hotpatch)
89KBUILD_AFLAGS += -DCC_USING_HOTPATCH
90KBUILD_CFLAGS += -DCC_USING_HOTPATCH
91endif
92endif
93
a0f97e06
SR
94KBUILD_CFLAGS += -mbackchain -msoft-float $(cflags-y)
95KBUILD_CFLAGS += -pipe -fno-strength-reduce -Wno-sign-compare
222d394d 96KBUILD_AFLAGS += $(aflags-y)
1da177e4
LT
97
98OBJCOPYFLAGS := -O binary
1da177e4 99
1844c9bc 100head-y := arch/s390/kernel/head.o
5a79859a 101head-y += arch/s390/kernel/head64.o
1da177e4 102
01485943
HC
103# See arch/s390/Kbuild for content of core part of the kernel
104core-y += arch/s390/
155af2f9 105
4562c9ff 106libs-y += arch/s390/lib/
1da177e4 107drivers-y += drivers/s390/
1da177e4
LT
108
109# must be linked after kernel
110drivers-$(CONFIG_OPROFILE) += arch/s390/oprofile/
111
4562c9ff 112boot := arch/s390/boot
c30f6828 113tools := arch/s390/tools
1da177e4 114
1844c9bc 115all: image bzImage
1da177e4
LT
116
117install: vmlinux
118 $(Q)$(MAKE) $(build)=$(boot) $@
119
1844c9bc 120image bzImage: vmlinux
1da177e4
LT
121 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
122
411ed322
MH
123zfcpdump:
124 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
125
f3cb31e4 126vdso_install:
f3cb31e4 127 $(Q)$(MAKE) $(build)=arch/$(ARCH)/kernel/vdso64 $@
f3cb31e4
HB
128 $(Q)$(MAKE) $(build)=arch/$(ARCH)/kernel/vdso32 $@
129
1da177e4
LT
130archclean:
131 $(Q)$(MAKE) $(clean)=$(boot)
c30f6828
HC
132 $(Q)$(MAKE) $(clean)=$(tools)
133
134archprepare:
135 $(Q)$(MAKE) $(build)=$(tools) include/generated/facilities.h
8bc1e4ec 136 $(Q)$(MAKE) $(build)=$(tools) include/generated/dis.h
1da177e4 137
1da177e4
LT
138# Don't use tabs in echo arguments
139define archhelp
140 echo '* image - Kernel image for IPL ($(boot)/image)'
1844c9bc 141 echo '* bzImage - Compressed kernel image for IPL ($(boot)/bzImage)'
b8eecf36
MH
142 echo ' install - Install kernel using'
143 echo ' (your) ~/bin/$(INSTALLKERNEL) or'
144 echo ' (distribution) /sbin/$(INSTALLKERNEL) or'
145 echo ' install to $$(INSTALL_PATH)'
1da177e4 146endef