2017-11-24 17:00:38 +03:00
# SPDX-License-Identifier: GPL-2.0
2005-04-17 02:20:36 +04:00
#
# s390/Makefile
#
# This file is included by the global makefile so that you can add your own
2021-10-13 09:36:22 +03:00
# architecture-specific flags and dependencies.
2005-04-17 02:20:36 +04:00
#
# Copyright (C) 1994 by Linus Torvalds
#
2010-02-27 00:37:53 +03:00
LD_BFD := elf64-s390
2018-08-24 02:20:39 +03:00
KBUILD_LDFLAGS := -m elf64_s390
2013-01-11 18:26:01 +04:00
KBUILD_AFLAGS_MODULE += -fPIC
KBUILD_CFLAGS_MODULE += -fPIC
2007-10-15 23:59:31 +04:00
KBUILD_AFLAGS += -m64
2018-06-15 13:28:05 +03:00
KBUILD_CFLAGS += -m64
2019-02-03 23:35:45 +03:00
KBUILD_CFLAGS += -fPIE
LDFLAGS_vmlinux := -pie
2018-06-28 20:22:21 +03:00
aflags_dwarf := -Wa,-gdwarf-2
2019-04-15 11:35:52 +03:00
KBUILD_AFLAGS_DECOMPRESSOR := $( CLANG_FLAGS) -m64 -D__ASSEMBLY__
2022-05-11 15:05:31 +03:00
i f n d e f C O N F I G _ A S _ I S _ L L V M
2018-06-28 20:22:21 +03:00
KBUILD_AFLAGS_DECOMPRESSOR += $( if $( CONFIG_DEBUG_INFO) ,$( aflags_dwarf) )
2022-05-11 15:05:31 +03:00
e n d i f
2022-01-29 02:34:13 +03:00
KBUILD_CFLAGS_DECOMPRESSOR := $( CLANG_FLAGS) -m64 -O2 -mpacked-stack
2018-06-15 13:28:05 +03:00
KBUILD_CFLAGS_DECOMPRESSOR += -DDISABLE_BRANCH_PROFILING -D__NO_FORTIFY
2020-11-10 19:05:35 +03:00
KBUILD_CFLAGS_DECOMPRESSOR += -fno-delete-null-pointer-checks -msoft-float -mbackchain
2018-06-15 13:28:05 +03:00
KBUILD_CFLAGS_DECOMPRESSOR += -fno-asynchronous-unwind-tables
2020-06-26 21:59:13 +03:00
KBUILD_CFLAGS_DECOMPRESSOR += -ffreestanding
2021-05-10 08:31:33 +03:00
KBUILD_CFLAGS_DECOMPRESSOR += -fno-stack-protector
2019-06-04 14:10:51 +03:00
KBUILD_CFLAGS_DECOMPRESSOR += $( call cc-disable-warning, address-of-packed-member)
2018-06-28 20:22:21 +03:00
KBUILD_CFLAGS_DECOMPRESSOR += $( if $( CONFIG_DEBUG_INFO) ,-g)
KBUILD_CFLAGS_DECOMPRESSOR += $( if $( CONFIG_DEBUG_INFO_DWARF4) , $( call cc-option, -gdwarf-4,) )
gcc-12: disable '-Warray-bounds' universally for now
In commit 8b202ee21839 ("s390: disable -Warray-bounds") the s390 people
disabled the '-Warray-bounds' warning for gcc-12, because the new logic
in gcc would cause warnings for their use of the S390_lowcore macro,
which accesses absolute pointers.
It turns out gcc-12 has many other issues in this area, so this takes
that s390 warning disable logic, and turns it into a kernel build config
entry instead.
Part of the intent is that we can make this all much more targeted, and
use this conflig flag to disable it in only particular configurations
that cause problems, with the s390 case as an example:
select GCC12_NO_ARRAY_BOUNDS
and we could do that for other configuration cases that cause issues.
Or we could possibly use the CONFIG_CC_NO_ARRAY_BOUNDS thing in a more
targeted way, and disable the warning only for particular uses: again
the s390 case as an example:
KBUILD_CFLAGS_DECOMPRESSOR += $(if $(CONFIG_CC_NO_ARRAY_BOUNDS),-Wno-array-bounds)
but this ends up just doing it globally in the top-level Makefile, since
the current issues are spread fairly widely all over:
KBUILD_CFLAGS-$(CONFIG_CC_NO_ARRAY_BOUNDS) += -Wno-array-bounds
We'll try to limit this later, since the gcc-12 problems are rare enough
that *much* of the kernel can be built with it without disabling this
warning.
Cc: Kees Cook <keescook@chromium.org>
Cc: Nathan Chancellor <nathan@kernel.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2022-06-09 20:11:12 +03:00
KBUILD_CFLAGS_DECOMPRESSOR += $( if $( CONFIG_CC_NO_ARRAY_BOUNDS) ,-Wno-array-bounds)
2022-04-25 15:17:42 +03:00
2005-04-17 02:20:36 +04:00
UTS_MACHINE := s390x
2018-10-26 16:29:59 +03:00
STACK_SIZE := $( if $( CONFIG_KASAN) ,65536,16384)
2018-05-28 21:27:35 +03:00
CHECKFLAGS += -D__s390__ -D__s390x__
2005-04-17 02:20:36 +04:00
2010-02-27 00:37:53 +03:00
export LD_BFD
2014-08-14 18:06:02 +04:00
mflags-$(CONFIG_MARCH_Z10) := -march= z10
mflags-$(CONFIG_MARCH_Z196) := -march= z196
mflags-$(CONFIG_MARCH_ZEC12) := -march= zEC12
2017-04-12 15:17:25 +03:00
mflags-$(CONFIG_MARCH_Z13) := -march= z13
mflags-$(CONFIG_MARCH_Z14) := -march= z14
2019-02-06 10:22:11 +03:00
mflags-$(CONFIG_MARCH_Z15) := -march= z15
2021-07-20 15:28:08 +03:00
mflags-$(CONFIG_MARCH_Z16) := -march= z16
2014-08-14 18:06:02 +04:00
2015-07-08 11:20:04 +03:00
export CC_FLAGS_MARCH := $( mflags-y)
2014-08-14 18:06:02 +04:00
aflags-y += $( mflags-y)
cflags-y += $( mflags-y)
2005-04-17 02:20:36 +04:00
2013-10-30 15:12:50 +04:00
cflags-$(CONFIG_MARCH_Z10_TUNE) += -mtune= z10
cflags-$(CONFIG_MARCH_Z196_TUNE) += -mtune= z196
cflags-$(CONFIG_MARCH_ZEC12_TUNE) += -mtune= zEC12
2017-04-12 15:17:25 +03:00
cflags-$(CONFIG_MARCH_Z13_TUNE) += -mtune= z13
cflags-$(CONFIG_MARCH_Z14_TUNE) += -mtune= z14
2019-02-06 10:22:11 +03:00
cflags-$(CONFIG_MARCH_Z15_TUNE) += -mtune= z15
2021-07-20 15:28:08 +03:00
cflags-$(CONFIG_MARCH_Z16_TUNE) += -mtune= z16
2013-10-30 15:12:50 +04:00
2016-09-06 11:46:36 +03:00
cflags-y += -Wa,-I$( srctree) /arch/$( ARCH) /include
2006-07-03 11:24:38 +04:00
#
# Prevent tail-call optimizations, to get clearer backtraces:
#
cflags-$(CONFIG_FRAME_POINTER) += -fno-optimize-sibling-calls
2018-06-15 13:28:05 +03:00
KBUILD_AFLAGS_DECOMPRESSOR += $( aflags-y)
KBUILD_CFLAGS_DECOMPRESSOR += $( cflags-y)
2021-08-17 03:21:04 +03:00
i f n e q ( $( call cc -option ,-mstack -size =8192 -mstack -guard =128) , )
2021-11-11 12:58:26 +03:00
CC_FLAGS_CHECK_STACK := -mstack-size= $( STACK_SIZE)
ifeq ( $( call cc-option,-mstack-size= 8192) ,)
CC_FLAGS_CHECK_STACK += -mstack-guard= $( CONFIG_STACK_GUARD)
endif
export CC_FLAGS_CHECK_STACK
cflags-$( CONFIG_CHECK_STACK) += $( CC_FLAGS_CHECK_STACK)
2007-04-27 18:01:46 +04:00
e n d i f
2005-04-17 02:20:36 +04:00
2018-01-26 14:46:47 +03:00
i f d e f C O N F I G _ E X P O L I N E
2022-03-06 22:56:07 +03:00
ifdef CONFIG_EXPOLINE_EXTERN
2022-06-27 15:50:53 +03:00
KBUILD_LDFLAGS_MODULE += arch/s390/lib/expoline/expoline.o
2022-03-06 22:56:07 +03:00
CC_FLAGS_EXPOLINE := -mindirect-branch= thunk-extern
CC_FLAGS_EXPOLINE += -mfunction-return= thunk-extern
else
2018-01-26 14:46:47 +03:00
CC_FLAGS_EXPOLINE := -mindirect-branch= thunk
CC_FLAGS_EXPOLINE += -mfunction-return= thunk
endif
2022-03-06 22:56:07 +03:00
CC_FLAGS_EXPOLINE += -mindirect-branch-table
export CC_FLAGS_EXPOLINE
cflags-y += $( CC_FLAGS_EXPOLINE) -DCC_USING_EXPOLINE
aflags-y += -DCC_USING_EXPOLINE
2018-01-26 14:46:47 +03:00
e n d i f
2015-01-09 15:08:28 +03: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
2021-08-17 03:21:04 +03:00
ifeq ( $( call cc-option,-mfentry -mnop-mcount) ,)
2018-08-06 16:17:47 +03:00
# make use of hotpatch feature if the compiler supports it
cc_hotpatch := -mhotpatch= 0,3
2021-08-17 03:21:04 +03:00
ifneq ( $( call cc-option,$( cc_hotpatch) ) ,)
2018-08-06 16:17:47 +03:00
CC_FLAGS_FTRACE := $( cc_hotpatch)
KBUILD_AFLAGS += -DCC_USING_HOTPATCH
KBUILD_CFLAGS += -DCC_USING_HOTPATCH
endif
endif
2015-01-09 15:08:28 +03:00
e n d i f
2017-11-20 13:46:13 +03: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)
2022-01-29 02:34:13 +03:00
KBUILD_CFLAGS += -mpacked-stack -mbackchain -msoft-float $( cflags-y)
2019-04-09 00:26:14 +03:00
KBUILD_CFLAGS += -pipe -Wno-sign-compare
2017-11-20 13:46:13 +03:00
KBUILD_CFLAGS += -fno-asynchronous-unwind-tables $( cfi)
KBUILD_AFLAGS += $( aflags-y) $( cfi)
2018-06-15 13:28:05 +03:00
export KBUILD_AFLAGS_DECOMPRESSOR
export KBUILD_CFLAGS_DECOMPRESSOR
2005-04-17 02:20:36 +04:00
OBJCOPYFLAGS := -O binary
2007-02-21 12:55:46 +03:00
libs-y += arch/s390/lib/
2005-04-17 02:20:36 +04:00
drivers-y += drivers/s390/
2007-02-21 12:55:46 +03:00
boot := arch/s390/boot
2017-12-11 16:54:08 +03:00
syscalls := arch/s390/kernel/syscalls
2015-02-02 09:08:44 +03:00
tools := arch/s390/tools
2005-04-17 02:20:36 +04:00
2018-06-11 15:35:01 +03:00
all : bzImage
2005-04-17 02:20:36 +04:00
2018-02-20 13:31:34 +03:00
#KBUILD_IMAGE is necessary for packaging targets like rpm-pkg, deb-pkg...
KBUILD_IMAGE := $( boot) /bzImage
2020-02-16 17:48:29 +03:00
install :
2022-05-03 05:47:16 +03:00
$( call cmd,install)
2005-04-17 02:20:36 +04:00
2018-06-11 15:35:01 +03:00
bzImage : vmlinux
2005-04-17 02:20:36 +04:00
$( Q) $( MAKE) $( build) = $( boot) $( boot) /$@
2007-04-27 18:01:49 +04:00
zfcpdump :
$( Q) $( MAKE) $( build) = $( boot) $( boot) /$@
2010-05-17 12:00:09 +04:00
vdso_install :
$( Q) $( MAKE) $( build) = arch/$( ARCH) /kernel/vdso64 $@
2017-12-11 16:54:08 +03:00
archheaders :
$( Q) $( MAKE) $( build) = $( syscalls) uapi
2015-02-02 09:08:44 +03:00
archprepare :
2017-12-11 16:54:08 +03:00
$( Q) $( MAKE) $( build) = $( syscalls) kapi
2018-01-11 14:13:18 +03:00
$( Q) $( MAKE) $( build) = $( tools) kapi
2021-06-25 15:50:08 +03:00
i f e q ( $( KBUILD_EXTMOD ) , )
# We need to generate vdso-offsets.h before compiling certain files in kernel/.
# In order to do that, we should use the archprepare target, but we can't since
# asm-offsets.h is included in some files used to generate vdso-offsets.h, and
# asm-offsets.h is built in prepare0, for which archprepare is a dependency.
# Therefore we need to generate the header after prepare0 has been made, hence
# this hack.
prepare : vdso_prepare
vdso_prepare : prepare 0
$( Q) $( MAKE) $( build) = arch/s390/kernel/vdso64 include/generated/vdso64-offsets.h
$( if $( CONFIG_COMPAT) ,$( Q) $( MAKE) \
$( build) = arch/s390/kernel/vdso32 include/generated/vdso32-offsets.h)
2022-06-27 15:50:53 +03:00
i f d e f C O N F I G _ E X P O L I N E _ E X T E R N
modules_prepare : expoline_prepare
2022-06-27 15:50:56 +03:00
expoline_prepare :
2022-06-27 15:50:53 +03:00
$( Q) $( MAKE) $( build) = arch/s390/lib/expoline arch/s390/lib/expoline/expoline.o
e n d i f
2021-06-25 15:50:08 +03:00
e n d i f
2005-04-17 02:20:36 +04: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 15:35:01 +03:00
echo '* bzImage - Kernel image for IPL ($(boot)/bzImage)'
2015-11-25 13:54:36 +03:00
echo ' install - Install kernel using'
echo ' (your) ~/bin/$(INSTALLKERNEL) or'
echo ' (distribution) /sbin/$(INSTALLKERNEL) or'
echo ' install to $$(INSTALL_PATH)'
2005-04-17 02:20:36 +04:00
e n d e f