2017-11-24 15:00:38 +01:00
# SPDX-License-Identifier: GPL-2.0
2005-04-16 15:20:36 -07:00
#
# s390/Makefile
#
# This file is included by the global makefile so that you can add your own
# architecture-specific flags and dependencies. Remember to do have actions
# for "archclean" and "archdep" for cleaning up and making dependencies for
# this architecture
#
# Copyright (C) 1994 by Linus Torvalds
#
2010-02-26 22:37:53 +01:00
LD_BFD := elf64-s390
2018-08-24 08:20:39 +09:00
KBUILD_LDFLAGS := -m elf64_s390
2013-01-11 15:26:01 +01:00
KBUILD_AFLAGS_MODULE += -fPIC
KBUILD_CFLAGS_MODULE += -fPIC
2007-10-15 21:59:31 +02:00
KBUILD_AFLAGS += -m64
2018-06-15 12:28:05 +02:00
KBUILD_CFLAGS += -m64
2019-02-03 21:35:45 +01:00
i f e q ( $( CONFIG_RELOCATABLE ) , y )
KBUILD_CFLAGS += -fPIE
LDFLAGS_vmlinux := -pie
e n d i f
2018-06-28 19:22:21 +02:00
aflags_dwarf := -Wa,-gdwarf-2
2019-04-15 10:35:52 +02:00
KBUILD_AFLAGS_DECOMPRESSOR := $( CLANG_FLAGS) -m64 -D__ASSEMBLY__
2018-06-28 19:22:21 +02:00
KBUILD_AFLAGS_DECOMPRESSOR += $( if $( CONFIG_DEBUG_INFO) ,$( aflags_dwarf) )
2019-04-15 10:35:52 +02:00
KBUILD_CFLAGS_DECOMPRESSOR := $( CLANG_FLAGS) -m64 -O2
2018-06-15 12:28:05 +02:00
KBUILD_CFLAGS_DECOMPRESSOR += -DDISABLE_BRANCH_PROFILING -D__NO_FORTIFY
KBUILD_CFLAGS_DECOMPRESSOR += -fno-delete-null-pointer-checks -msoft-float
KBUILD_CFLAGS_DECOMPRESSOR += -fno-asynchronous-unwind-tables
2020-06-27 03:59:13 +09:00
KBUILD_CFLAGS_DECOMPRESSOR += -ffreestanding
2019-06-04 13:10:51 +02:00
KBUILD_CFLAGS_DECOMPRESSOR += $( call cc-disable-warning, address-of-packed-member)
2018-06-28 19:22:21 +02:00
KBUILD_CFLAGS_DECOMPRESSOR += $( if $( CONFIG_DEBUG_INFO) ,-g)
KBUILD_CFLAGS_DECOMPRESSOR += $( if $( CONFIG_DEBUG_INFO_DWARF4) , $( call cc-option, -gdwarf-4,) )
2005-04-16 15:20:36 -07:00
UTS_MACHINE := s390x
2018-10-26 15:29:59 +02:00
STACK_SIZE := $( if $( CONFIG_KASAN) ,65536,16384)
2018-05-28 20:27:35 +02:00
CHECKFLAGS += -D__s390__ -D__s390x__
2005-04-16 15:20:36 -07:00
2010-02-26 22:37:53 +01:00
export LD_BFD
2014-08-14 16:06:02 +02:00
mflags-$(CONFIG_MARCH_Z900) := -march= z900
mflags-$(CONFIG_MARCH_Z990) := -march= z990
mflags-$(CONFIG_MARCH_Z9_109) := -march= z9-109
mflags-$(CONFIG_MARCH_Z10) := -march= z10
mflags-$(CONFIG_MARCH_Z196) := -march= z196
mflags-$(CONFIG_MARCH_ZEC12) := -march= zEC12
2017-04-12 14:17:25 +02:00
mflags-$(CONFIG_MARCH_Z13) := -march= z13
mflags-$(CONFIG_MARCH_Z14) := -march= z14
2019-02-06 08:22:11 +01:00
mflags-$(CONFIG_MARCH_Z15) := -march= z15
2014-08-14 16:06:02 +02:00
2015-07-08 10:20:04 +02:00
export CC_FLAGS_MARCH := $( mflags-y)
2014-08-14 16:06:02 +02:00
aflags-y += $( mflags-y)
cflags-y += $( mflags-y)
2005-04-16 15:20:36 -07:00
2013-10-30 12:12:50 +01:00
cflags-$(CONFIG_MARCH_Z900_TUNE) += -mtune= z900
cflags-$(CONFIG_MARCH_Z990_TUNE) += -mtune= z990
cflags-$(CONFIG_MARCH_Z9_109_TUNE) += -mtune= z9-109
cflags-$(CONFIG_MARCH_Z10_TUNE) += -mtune= z10
cflags-$(CONFIG_MARCH_Z196_TUNE) += -mtune= z196
cflags-$(CONFIG_MARCH_ZEC12_TUNE) += -mtune= zEC12
2017-04-12 14:17:25 +02:00
cflags-$(CONFIG_MARCH_Z13_TUNE) += -mtune= z13
cflags-$(CONFIG_MARCH_Z14_TUNE) += -mtune= z14
2019-02-06 08:22:11 +01:00
cflags-$(CONFIG_MARCH_Z15_TUNE) += -mtune= z15
2013-10-30 12:12:50 +01:00
2016-09-06 10:46:36 +02:00
cflags-y += -Wa,-I$( srctree) /arch/$( ARCH) /include
2006-07-03 00:24:38 -07:00
#
# Prevent tail-call optimizations, to get clearer backtraces:
#
cflags-$(CONFIG_FRAME_POINTER) += -fno-optimize-sibling-calls
2020-01-08 14:46:00 +01:00
i f e q ( $( call cc -option -yn ,-mpacked -stack -mbackchain -msoft -float ) , y )
2005-04-16 15:20:36 -07:00
cflags-$(CONFIG_PACK_STACK) += -mpacked-stack -D__PACK_STACK
aflags-$(CONFIG_PACK_STACK) += -D__PACK_STACK
e n d i f
2018-06-15 12:28:05 +02:00
KBUILD_AFLAGS_DECOMPRESSOR += $( aflags-y)
KBUILD_CFLAGS_DECOMPRESSOR += $( cflags-y)
2005-04-16 15:20:36 -07:00
i f e q ( $( call cc -option -yn ,-mstack -size =8192 -mstack -guard =128) , y )
cflags-$(CONFIG_CHECK_STACK) += -mstack-size= $( STACK_SIZE)
2007-04-27 16:01:46 +02:00
i f n e q ( $( call cc -option -yn ,-mstack -size =8192) , y )
2005-04-16 15:20:36 -07:00
cflags-$(CONFIG_CHECK_STACK) += -mstack-guard= $( CONFIG_STACK_GUARD)
e n d i f
2007-04-27 16:01:46 +02:00
e n d i f
2005-04-16 15:20:36 -07:00
2018-06-15 12:28:05 +02:00
i f d e f C O N F I G _ W A R N _ D Y N A M I C _ S T A C K
ifeq ( $( call cc-option-yn,-mwarn-dynamicstack) ,y)
KBUILD_CFLAGS += -mwarn-dynamicstack
KBUILD_CFLAGS_DECOMPRESSOR += -mwarn-dynamicstack
endif
2005-04-16 15:20:36 -07:00
e n d i f
2018-01-26 12:46:47 +01:00
i f d e f C O N F I G _ E X P O L I N E
ifeq ( $( call cc-option-yn,$( CC_FLAGS_MARCH) -mindirect-branch= thunk) ,y)
CC_FLAGS_EXPOLINE := -mindirect-branch= thunk
CC_FLAGS_EXPOLINE += -mfunction-return= thunk
CC_FLAGS_EXPOLINE += -mindirect-branch-table
export CC_FLAGS_EXPOLINE
2018-03-23 13:04:49 +01:00
cflags-y += $( CC_FLAGS_EXPOLINE) -DCC_USING_EXPOLINE
2018-06-15 10:22:18 +02:00
aflags-y += -DCC_USING_EXPOLINE
2018-01-26 12:46:47 +01:00
endif
e n d i f
2015-01-09 13:08:28 +01:00
i f d e f C O N F I G _ F U N C T I O N _ T R A C E R
2018-08-06 15:17:47 +02:00
ifeq ( $( call cc-option-yn,-mfentry -mnop-mcount) ,n)
# make use of hotpatch feature if the compiler supports it
cc_hotpatch := -mhotpatch= 0,3
ifeq ( $( call cc-option-yn,$( cc_hotpatch) ) ,y)
CC_FLAGS_FTRACE := $( cc_hotpatch)
KBUILD_AFLAGS += -DCC_USING_HOTPATCH
KBUILD_CFLAGS += -DCC_USING_HOTPATCH
endif
endif
2015-01-09 13:08:28 +01:00
e n d i f
2017-11-20 11:46:13 +01:00
# Test CFI features of binutils
cfi := $( call as-instr,.cfi_startproc\n .cfi_val_offset 15$( comma) -160\n .cfi_endproc,-DCONFIG_AS_CFI_VAL_OFFSET= 1)
2007-10-14 22:21:35 +02:00
KBUILD_CFLAGS += -mbackchain -msoft-float $( cflags-y)
2019-04-08 23:26:14 +02:00
KBUILD_CFLAGS += -pipe -Wno-sign-compare
2017-11-20 11:46:13 +01:00
KBUILD_CFLAGS += -fno-asynchronous-unwind-tables $( cfi)
KBUILD_AFLAGS += $( aflags-y) $( cfi)
2018-06-15 12:28:05 +02:00
export KBUILD_AFLAGS_DECOMPRESSOR
export KBUILD_CFLAGS_DECOMPRESSOR
2005-04-16 15:20:36 -07:00
OBJCOPYFLAGS := -O binary
2018-06-12 15:11:40 +02:00
head-y := arch/s390/kernel/head64.o
2005-04-16 15:20:36 -07:00
2010-10-25 16:10:09 +02:00
# See arch/s390/Kbuild for content of core part of the kernel
core-y += arch/s390/
2009-06-16 10:30:52 +02:00
2007-02-21 10:55:46 +01:00
libs-y += arch/s390/lib/
2005-04-16 15:20:36 -07:00
drivers-y += drivers/s390/
# must be linked after kernel
drivers-$(CONFIG_OPROFILE) += arch/s390/oprofile/
2007-02-21 10:55:46 +01:00
boot := arch/s390/boot
2017-12-11 14:54:08 +01:00
syscalls := arch/s390/kernel/syscalls
2015-02-02 07:08:44 +01:00
tools := arch/s390/tools
2005-04-16 15:20:36 -07:00
2018-06-11 14:35:01 +02:00
all : bzImage
2005-04-16 15:20:36 -07:00
2018-02-20 11:31:34 +01:00
#KBUILD_IMAGE is necessary for packaging targets like rpm-pkg, deb-pkg...
KBUILD_IMAGE := $( boot) /bzImage
2020-02-16 23:48:29 +09:00
install :
2005-04-16 15:20:36 -07:00
$( Q) $( MAKE) $( build) = $( boot) $@
2018-06-11 14:35:01 +02:00
bzImage : vmlinux
2005-04-16 15:20:36 -07:00
$( Q) $( MAKE) $( build) = $( boot) $( boot) /$@
2007-04-27 16:01:49 +02:00
zfcpdump :
$( Q) $( MAKE) $( build) = $( boot) $( boot) /$@
2010-05-17 10:00:09 +02:00
vdso_install :
$( Q) $( MAKE) $( build) = arch/$( ARCH) /kernel/vdso64 $@
2005-04-16 15:20:36 -07:00
archclean :
$( Q) $( MAKE) $( clean) = $( boot)
2015-02-02 07:08:44 +01:00
$( Q) $( MAKE) $( clean) = $( tools)
2017-12-11 14:54:08 +01:00
archheaders :
$( Q) $( MAKE) $( build) = $( syscalls) uapi
2015-02-02 07:08:44 +01:00
archprepare :
2017-12-11 14:54:08 +01:00
$( Q) $( MAKE) $( build) = $( syscalls) kapi
2018-01-11 12:13:18 +01:00
$( Q) $( MAKE) $( build) = $( tools) kapi
2005-04-16 15:20:36 -07:00
# Don't use tabs in echo arguments
d e f i n e a r c h h e l p
2018-06-11 14:35:01 +02:00
echo '* bzImage - Kernel image for IPL ($(boot)/bzImage)'
2015-11-25 11:54:36 +01:00
echo ' install - Install kernel using'
echo ' (your) ~/bin/$(INSTALLKERNEL) or'
echo ' (distribution) /sbin/$(INSTALLKERNEL) or'
echo ' install to $$(INSTALL_PATH)'
2005-04-16 15:20:36 -07:00
e n d e f