Skip to content

Commit 8b202ee

Browse files
svens-s390hcahca
authored andcommitted
s390: disable -Warray-bounds
gcc-12 shows a lot of array bound warnings on s390. This is caused by the S390_lowcore macro which uses a hardcoded address of 0. Wrapping that with absolute_pointer() works, but gcc no longer knows that a 12 bit displacement is sufficient to access lowcore. So it emits instructions like 'lghi %r1,0; l %rx,xxx(%r1)' instead of a single load/store instruction. As s390 stores variables often read/written in lowcore, this is considered problematic. Therefore disable -Warray-bounds on s390 for gcc-12 for the time being, until there is a better solution. Signed-off-by: Sven Schnelle <[email protected]> Link: https://lore.kernel.org/r/[email protected] Link: https://lore.kernel.org/r/[email protected] Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Heiko Carstens <[email protected]>
1 parent af2d861 commit 8b202ee

File tree

1 file changed

+10
-0
lines changed

1 file changed

+10
-0
lines changed

arch/s390/Makefile

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -30,6 +30,16 @@ KBUILD_CFLAGS_DECOMPRESSOR += -fno-stack-protector
3030
KBUILD_CFLAGS_DECOMPRESSOR += $(call cc-disable-warning, address-of-packed-member)
3131
KBUILD_CFLAGS_DECOMPRESSOR += $(if $(CONFIG_DEBUG_INFO),-g)
3232
KBUILD_CFLAGS_DECOMPRESSOR += $(if $(CONFIG_DEBUG_INFO_DWARF4), $(call cc-option, -gdwarf-4,))
33+
34+
ifdef CONFIG_CC_IS_GCC
35+
ifeq ($(call cc-ifversion, -ge, 1200, y), y)
36+
ifeq ($(call cc-ifversion, -lt, 1300, y), y)
37+
KBUILD_CFLAGS += $(call cc-disable-warning, array-bounds)
38+
KBUILD_CFLAGS_DECOMPRESSOR += $(call cc-disable-warning, array-bounds)
39+
endif
40+
endif
41+
endif
42+
3343
UTS_MACHINE := s390x
3444
STACK_SIZE := $(if $(CONFIG_KASAN),65536,16384)
3545
CHECKFLAGS += -D__s390__ -D__s390x__

0 commit comments

Comments
 (0)