Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp2451653rwr; Fri, 28 Apr 2023 10:27:48 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ4X7dt0o6r2pTkJMHMlxq74kcrJKeN0JUgf8NQ7gVju4rccUnSJ5ezy2MAl/OcXNqvbbHIT X-Received: by 2002:a05:6a20:3c8b:b0:ef:6e5a:8b1e with SMTP id b11-20020a056a203c8b00b000ef6e5a8b1emr7247203pzj.24.1682702868187; Fri, 28 Apr 2023 10:27:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1682702868; cv=none; d=google.com; s=arc-20160816; b=WethM2I5WiQyTEDF+leqkxvWafmTBZ/+s9U0pvGHIelVDtUOBIiJrE3HjtsTpM6xsx 1FAb77ZnS0H/O98r7OhCKUDPHE8B4ReIjXbzf/XuKAN3sWg4GGUMnqR1d5oV3XsrsCzz upkc0mfkP3PnuCwSU2o9u0fCrwKQQz/ux6WkV936kWIbnjM/mvlaFz3xmXgJgGqIub6q Xld9TH1z3MBwm+lxJ7Swl7wZHmB68W7E+VLUvtSDA+owoG7MXWe3o06tKjQncvJunZ9x mY6++rJwRm1drcP8XIItWzYSu898i9k+AxlDgYs/v0v3N6CqYIj6x/Vh4QWBhpLfIRzQ TOJw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=jYpNnylGJHgq8QdgUzYnN4n+L+5QNmyTeDA2Ga8l8RY=; b=T6lWOV+gN7gtqNX0YKt/BvpXewQjVSLBBciNw2+5H0IZ8bqNwPy8Yao1hQDX1Kkrr4 GvTV0gADIiikx8W8IdadrIXHzK4aYWkZXL3HlOANO2KqzDR/oH8pVH2w8yup5kw7G1mp 9c0iReKKKMN7L6JoTMcrEE8bjzLuIkmcrrilV/xy4JxEwfskZKIYuqLZOieNLL4GCynD dcJ3EekskI6Xl9rRNctt+aBkIuOczh6sE3rin8aE/nXSBcLDoolEldsrx1+TfxEo0895 KQ8yKAjVmukrRbb4f6wHObSiN2LFZTEV23fsX+nA5jpTDDa8i96q2nkjchj7EPpQM6aH WKdQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20221208 header.b=c1TFqUjb; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b13-20020aa78ecd000000b0063d27f81f05si22549611pfr.247.2023.04.28.10.27.33; Fri, 28 Apr 2023 10:27:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20221208 header.b=c1TFqUjb; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345847AbjD1R1X (ORCPT + 99 others); Fri, 28 Apr 2023 13:27:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56230 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229544AbjD1R1V (ORCPT ); Fri, 28 Apr 2023 13:27:21 -0400 Received: from mail-pj1-x1036.google.com (mail-pj1-x1036.google.com [IPv6:2607:f8b0:4864:20::1036]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8175A1BE8 for ; Fri, 28 Apr 2023 10:27:19 -0700 (PDT) Received: by mail-pj1-x1036.google.com with SMTP id 98e67ed59e1d1-24986c7cf2dso193968a91.2 for ; Fri, 28 Apr 2023 10:27:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20221208; t=1682702839; x=1685294839; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=jYpNnylGJHgq8QdgUzYnN4n+L+5QNmyTeDA2Ga8l8RY=; b=c1TFqUjbMlG8d+PtKNIeuJGhnVkXEVFm5OJpR+jZHN9QGhY+qOiKdUK4+shywcnUk2 OwzelfQZlcpZYzeB9UPgDrAtv8MILZNznIvZAc64BS/sRlARMp/OeDQcKRPR5kjhHqjt IXtz+RE1RfEjWrPJ3AmzwjWq7InBZ/iZp6ZOF/fyF0GSP8g1uUt/IfL/1w5h0FO874EN HdYdXapFssQ9/S4dHxxHCrh1NAnr95QXpVpFm5+iNjcl+FT0pTJy9wxyTimM3FjigwXO oFiV1+afM3X5qBprcXqkrQDmDj7jr3SGvPeZiDzun9y/A/u2kelir96G1A23amYLcJZZ ez3A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1682702839; x=1685294839; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=jYpNnylGJHgq8QdgUzYnN4n+L+5QNmyTeDA2Ga8l8RY=; b=KUKuvK+KaacTwsOEd7r+tImZ69rZaPw6oeRNvK+VLPiIZ8lQ3frZhHulljt3n3T9SL eQpdFcwx5XGmk82yFMLjUQPyYATb32wCEr1yBewZZyY8j0AZdeF4wHpZgRaitsuproWD YhQIaJH4bjUsU+hj0DXhZeiZPb9PBUIDGuEvdCEZvAzcvE/Lyk+jSUTH3aZtFCSJYfQn wQuS3Gn+IZQ0WCPDLaFRXKyhsYeGZ+WwS9F7PE7ALtfhPFrl/SLvSb427tVAq29TWchI ac0fi/yfdAq+R9G3ZqPX9a0sn3jXi7vr3/65fLQbBEI8RlLF2od2DF4V3jbazec5qMyO gHaw== X-Gm-Message-State: AC+VfDyJBtpGrtpR2dEw21TJ+HxZ6vPi/GUPMFsEkf/qN460ILwr/rCh txY7cRjcg5RjFdtlrhChm0fUuGAlhL8Fodn0wp1SZA== X-Received: by 2002:a17:90a:8414:b0:246:9ef5:3c45 with SMTP id j20-20020a17090a841400b002469ef53c45mr6317303pjn.13.1682702838648; Fri, 28 Apr 2023 10:27:18 -0700 (PDT) MIME-Version: 1.0 References: <20220919170828.3718437-1-ndesaulniers@google.com> <597ef55f-e7c1-ab60-b4aa-0071ff4b5e0e@collabora.com> In-Reply-To: <597ef55f-e7c1-ab60-b4aa-0071ff4b5e0e@collabora.com> From: Nick Desaulniers Date: Fri, 28 Apr 2023 10:27:07 -0700 Message-ID: Subject: Re: [PATCH v4] Makefile.compiler: replace cc-ifversion with compiler-specific macros To: Shreeya Patel Cc: Michal Marek , Masahiro Yamada , Linux Kernel Mailing List , clang-built-linux , Bill Wendling , Nathan Chancellor , regressions@lists.linux.dev Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable X-Spam-Status: No, score=-17.6 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF, ENV_AND_HDR_SPF_MATCH,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED,USER_IN_DEF_DKIM_WL, USER_IN_DEF_SPF_WL autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Apr 27, 2023 at 4:54=E2=80=AFAM Shreeya Patel wrote: > > Hi Nick, > > On 19/09/22 22:38, Nick Desaulniers wrote: > > cc-ifversion is GCC specific. Replace it with compiler specific > > variants. Update the users of cc-ifversion to use these new macros. > > > > Link: https://github.com/ClangBuiltLinux/linux/issues/350 > > Link: https://lore.kernel.org/llvm/CAGG=3D3QWSAUakO42kubrCap8fp-gm1ERJJ= AYXTnP1iHk_wrH=3DBQ@mail.gmail.com/ > > Suggested-by: Bill Wendling > > Reviewed-by: Nathan Chancellor > > Signed-off-by: Nick Desaulniers > > KernelCI found this patch causes a regression in the > baseline.logintest on qemu_arm-virt-gicv3-uefi [1], > see the bisection report for more details [2]. > > Let me know if you have any questions. > > > [1] https://linux.kernelci.org/test/case/id/644596a0beca2ead032e8669/ Hi Shreeya, Thanks for the report. When I click the above link, then click `multi_v7_defconfig+debug` to get the config necessary to reproduce, I get an HTTP 404. https://storage.kernelci.org/mainline/master/v6.3/arm/multi_v7_defconfig+de= bug/gcc-10/kernel.config Same for zImage https://storage.kernelci.org/mainline/master/v6.3/arm/multi_v7_defconfig+de= bug/gcc-10/zImage If I click on the log https://storage.kernelci.org/mainline/master/v6.3/arm/multi_v7_defconfig+de= bug/gcc-10/lab-collabora/baseline-qemu_arm-virt-gicv3-uefi.txt It looks like the machine powered up, then powered off. Is the test actually failing? I was able to boot ARCH=3Darm defconfig with CC=3Darm-linux-gnueabihf-gcc (Debian 10.2.1-6) in QEMU just fine. So I'm going to need some more information to help reproduce what specifically is failing. Linux version 6.3.0 (root@61385772abae) (arm-linux-gnueabihf-gcc (Debian 10.2.1-6) 10.2.1 20210110, GNU ld (GNU Binutils for Debian) 2.35.2) #1 SMP Fri Apr 28 17:19:59 UTC 2023 --- It does look like UBSAN is flagging an array OOB: <3>[ 0.417001][ T1] UBSAN: array-index-out-of-bounds in ../arch/arm/mach-sunxi/mc_smp.c:811:29 And potentially another issue with ftrace <4>[ 0.000000][ T0] WARNING: CPU: 0 PID: 0 at kernel/trace/ftrace.c:2176 ftrace_bug+0x340/0x3b4 > [2] https://groups.io/g/kernelci-results/message/40804 > > > Thanks, > Shreeya Patel > > #regzbot introduced: 88b61e3bff93 > > > --- > > Changes v3 -> v4: > > * Split into its own patch again from series, as per Masahiro. > > * Rebase on top of b0839b281c427e844143dba3893e25c83cdd6c17 and update > > clang -Wformat logic in scripts/Makefile.extrawarn, as per Masahiro. > > > > Documentation/kbuild/makefiles.rst | 29 ++++++++++++--------= - > > Makefile | 6 ++--- > > drivers/gpu/drm/amd/display/dc/dml/Makefile | 2 +- > > scripts/Makefile.compiler | 10 ++++--- > > scripts/Makefile.extrawarn | 4 +-- > > 5 files changed, 29 insertions(+), 22 deletions(-) > > > > diff --git a/Documentation/kbuild/makefiles.rst b/Documentation/kbuild/= makefiles.rst > > index 11a296e52d68..ee7e3ea1fbe1 100644 > > --- a/Documentation/kbuild/makefiles.rst > > +++ b/Documentation/kbuild/makefiles.rst > > @@ -682,22 +682,27 @@ more details, with real examples. > > In the above example, -Wno-unused-but-set-variable will be added = to > > KBUILD_CFLAGS only if gcc really accepts it. > > > > - cc-ifversion > > - cc-ifversion tests the version of $(CC) and equals the fourth par= ameter > > - if version expression is true, or the fifth (if given) if the ver= sion > > - expression is false. > > + gcc-min-version > > + gcc-min-version tests if the value of $(CONFIG_GCC_VERSION) is gr= eater than > > + or equal to the provided value and evaluates to y if so. > > > > Example:: > > > > - #fs/reiserfs/Makefile > > - ccflags-y :=3D $(call cc-ifversion, -lt, 0402, -O1) > > + cflags-$(call gcc-min-version, 70100) :=3D -foo > > > > - In this example, ccflags-y will be assigned the value -O1 if the > > - $(CC) version is less than 4.2. > > - cc-ifversion takes all the shell operators: > > - -eq, -ne, -lt, -le, -gt, and -ge > > - The third parameter may be a text as in this example, but it may = also > > - be an expanded variable or a macro. > > + In this example, cflags-y will be assigned the value -foo if $(CC= ) is gcc and > > + $(CONFIG_GCC_VERSION) is >=3D 7.1. > > + > > + clang-min-version > > + clang-min-version tests if the value of $(CONFIG_CLANG_VERSION) i= s greater > > + than or equal to the provided value and evaluates to y if so. > > + > > + Example:: > > + > > + cflags-$(call clang-min-version, 110000) :=3D -foo > > + > > + In this example, cflags-y will be assigned the value -foo if $(CC= ) is clang > > + and $(CONFIG_CLANG_VERSION) is >=3D 11.0.0. > > > > cc-cross-prefix > > cc-cross-prefix is used to check if there exists a $(CC) in path = with > > diff --git a/Makefile b/Makefile > > index 298f69060f10..411c8480b37e 100644 > > --- a/Makefile > > +++ b/Makefile > > @@ -790,7 +790,6 @@ KBUILD_CFLAGS +=3D $(stackp-flags-y) > > > > KBUILD_CFLAGS-$(CONFIG_WERROR) +=3D -Werror > > KBUILD_CFLAGS-$(CONFIG_CC_NO_ARRAY_BOUNDS) +=3D -Wno-array-bounds > > -KBUILD_CFLAGS +=3D $(KBUILD_CFLAGS-y) $(CONFIG_CC_IMPLICIT_FALLTHROUGH= ) > > > > ifdef CONFIG_CC_IS_CLANG > > KBUILD_CPPFLAGS +=3D -Qunused-arguments > > @@ -972,7 +971,6 @@ ifdef CONFIG_CC_IS_GCC > > KBUILD_CFLAGS +=3D -Wno-maybe-uninitialized > > endif > > > > -ifdef CONFIG_CC_IS_GCC > > # The allocators already balk at large sizes, so silence the compiler > > # warnings for bounds checks involving those possible values. While > > # -Wno-alloc-size-larger-than would normally be used here, earlier ve= rsions > > @@ -984,8 +982,8 @@ ifdef CONFIG_CC_IS_GCC > > # ignored, continuing to default to PTRDIFF_MAX. So, left with no oth= er > > # choice, we must perform a versioned check to disable this warning. > > # https://lore.kernel.org/lkml/20210824115859.187f272f@canb.auug.org.= au > > -KBUILD_CFLAGS +=3D $(call cc-ifversion, -ge, 0901, -Wno-alloc-size-lar= ger-than) > > -endif > > +KBUILD_CFLAGS-$(call gcc-min-version, 90100) +=3D -Wno-alloc-size-larg= er-than > > +KBUILD_CFLAGS +=3D $(KBUILD_CFLAGS-y) $(CONFIG_CC_IMPLICIT_FALLTHROUGH= ) > > > > # disable invalid "can't wrap" optimizations for signed / pointers > > KBUILD_CFLAGS +=3D -fno-strict-overflow > > diff --git a/drivers/gpu/drm/amd/display/dc/dml/Makefile b/drivers/gpu/= drm/amd/display/dc/dml/Makefile > > index cb81ed2fbd53..d70838edba80 100644 > > --- a/drivers/gpu/drm/amd/display/dc/dml/Makefile > > +++ b/drivers/gpu/drm/amd/display/dc/dml/Makefile > > @@ -34,7 +34,7 @@ dml_ccflags :=3D -mhard-float -maltivec > > endif > > > > ifdef CONFIG_CC_IS_GCC > > -ifeq ($(call cc-ifversion, -lt, 0701, y), y) > > +ifneq ($(call gcc-min-version, 70100),y) > > IS_OLD_GCC =3D 1 > > endif > > endif > > diff --git a/scripts/Makefile.compiler b/scripts/Makefile.compiler > > index 94d0d40cddb3..9d18fb91890e 100644 > > --- a/scripts/Makefile.compiler > > +++ b/scripts/Makefile.compiler > > @@ -61,9 +61,13 @@ cc-option-yn =3D $(call try-run,\ > > cc-disable-warning =3D $(call try-run,\ > > $(CC) -Werror $(KBUILD_CPPFLAGS) $(KBUILD_CFLAGS) -W$(strip $(1))= -c -x c /dev/null -o "$$TMP",-Wno-$(strip $(1))) > > > > -# cc-ifversion > > -# Usage: EXTRA_CFLAGS +=3D $(call cc-ifversion, -lt, 0402, -O1) > > -cc-ifversion =3D $(shell [ $(CONFIG_GCC_VERSION)0 $(1) $(2)000 ] && ec= ho $(3) || echo $(4)) > > +# gcc-min-version > > +# Usage: cflags-$(call gcc-min-version, 70100) +=3D -foo > > +gcc-min-version =3D $(shell [ $(CONFIG_GCC_VERSION) -ge $(1) ] && echo= y) > > + > > +# clang-min-version > > +# Usage: cflags-$(call clang-min-version, 110000) +=3D -foo > > +clang-min-version =3D $(shell [ $(CONFIG_CLANG_VERSION) -ge $(1) ] && = echo y) > > > > # ld-option > > # Usage: KBUILD_LDFLAGS +=3D $(call ld-option, -X, -Y) > > diff --git a/scripts/Makefile.extrawarn b/scripts/Makefile.extrawarn > > index 6ae482158bc4..5769c1939d40 100644 > > --- a/scripts/Makefile.extrawarn > > +++ b/scripts/Makefile.extrawarn > > @@ -48,7 +48,7 @@ else > > ifdef CONFIG_CC_IS_CLANG > > KBUILD_CFLAGS +=3D -Wno-initializer-overrides > > # Clang before clang-16 would warn on default argument promotions. > > -ifeq ($(shell [ $(CONFIG_CLANG_VERSION) -lt 160000 ] && echo y),y) > > +ifneq ($(call clang-min-version, 160000),y) > > # Disable -Wformat > > KBUILD_CFLAGS +=3D -Wno-format > > # Then re-enable flags that were part of the -Wformat group that aren= 't > > @@ -56,7 +56,7 @@ KBUILD_CFLAGS +=3D -Wno-format > > KBUILD_CFLAGS +=3D -Wformat-extra-args -Wformat-invalid-specifier > > KBUILD_CFLAGS +=3D -Wformat-zero-length -Wnonnull > > # Requires clang-12+. > > -ifeq ($(shell [ $(CONFIG_CLANG_VERSION) -ge 120000 ] && echo y),y) > > +ifeq ($(call clang-min-version, 120000),y) > > KBUILD_CFLAGS +=3D -Wformat-insufficient-args > > endif > > endif --=20 Thanks, ~Nick Desaulniers