Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752202AbdFMIb1 (ORCPT ); Tue, 13 Jun 2017 04:31:27 -0400 Received: from mail-oi0-f68.google.com ([209.85.218.68]:35551 "EHLO mail-oi0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752102AbdFMIbW (ORCPT ); Tue, 13 Jun 2017 04:31:22 -0400 MIME-Version: 1.0 In-Reply-To: <638b79cf-a0e8-7986-d8b4-26d3a3808ec4@suse.com> References: <20170613005531.77656-1-mka@chromium.org> <20170613005531.77656-2-mka@chromium.org> <638b79cf-a0e8-7986-d8b4-26d3a3808ec4@suse.com> From: Arnd Bergmann Date: Tue, 13 Jun 2017 10:31:21 +0200 X-Google-Sender-Auth: d3qWrzEbaVsVkb1VHcXrT57NMFE Message-ID: Subject: Re: [PATCH 1/3] kbuild: Add cc-option-no-kbuild macro To: Michal Marek Cc: Matthias Kaehlcke , Thomas Gleixner , Ingo Molnar , "H . Peter Anvin" , "H . J . Lu" , David Woodhouse , Masahiro Yamada , "the arch/x86 maintainers" , Linux Kbuild mailing list , Linux Kernel Mailing List , Michael Davidson , Greg Hackmann , Nick Desaulniers , Stephen Hines , Kees Cook , Bernhard.Rosenkranzer@linaro.org, Peter Foley , Behan Webster , Douglas Anderson Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4124 Lines: 88 On Tue, Jun 13, 2017 at 9:49 AM, Michal Marek wrote: > On 2017-06-13 02:55, Matthias Kaehlcke wrote: >> cc-option uses KBUILD_CFLAGS and KBUILD_CPPFLAGS when it determines >> whether an option is supported or not. This is fine for options used to >> build the kernel itself, however some components like the x86 boot code >> use a different set of flags. >> >> Add the new macro cc-option-no-kbuild which does the same as cc-option >> except that it has an additional parameter with the compiler options >> which are used instead of KBUILD_CFLAGS and KBUILD_CPPFLAGS. >> >> Signed-off-by: Matthias Kaehlcke >> --- >> scripts/Kbuild.include | 5 +++++ >> 1 file changed, 5 insertions(+) >> >> diff --git a/scripts/Kbuild.include b/scripts/Kbuild.include >> index 61f87a99bf0a..d9fdc740105f 100644 >> --- a/scripts/Kbuild.include >> +++ b/scripts/Kbuild.include >> @@ -128,6 +128,11 @@ cc-option-yn = $(call try-run,\ >> cc-option-align = $(subst -functions=0,,\ >> $(call cc-option,-falign-functions=0,-malign-functions=0)) >> >> +# cc-option-no-kbuild >> +# Usage: cflags-no-kbuild-y += $(call cc-option-no-kbuild,,-march=winchip-c6,-march=i586) >> +cc-option-no-kbuild = $(call try-run,\ >> + $(CC) -Werror $(filter-out $(GCC_PLUGINS_CFLAGS),$(1)) $(2) -c -x c /dev/null -o "$$TMP",$(2),$(3)) > > As this is a version of cc-option with an extrra argument, how about > implementing cc-option as a shorthand for cc-option-no-kbuild? It would > make it more obvious what cc-option-no-kbuild does differently (it's > probably just me, but I was unable to infer the semantics from its name). Agreed, also the hostcc-option could be based on the same I think, if we also make the $(CC) an argument of the low-level helper. For reference, these seem to be the files that might be affected here, as they override KBUILD_CFLAGS: $ git grep -w KBUILD_CFLAGS.*: arch/cris/Makefile:KBUILD_CFLAGS := $(subst -fomit-frame-pointer,,$(KBUILD_CFLAGS)) -g arch/ia64/Makefile:KBUILD_CFLAGS_KERNEL := -mconstant-gp arch/m68k/Makefile:KBUILD_CFLAGS := $(subst -fomit-frame-pointer,,$(KBUILD_CFLAGS)) -g arch/mips/boot/compressed/Makefile:KBUILD_CFLAGS := $(filter-out -pg, $(KBUILD_CFLAGS)) arch/mips/boot/compressed/Makefile:KBUILD_CFLAGS := $(filter-out -fstack-protector, $(KBUILD_CFLAGS)) arch/mips/boot/compressed/Makefile:KBUILD_CFLAGS := $(KBUILD_CFLAGS) -D__KERNEL__ \ arch/mips/vdso/Makefile:$(obj-vdso): KBUILD_CFLAGS := $(cflags-vdso) $(native-abi) arch/mips/vdso/Makefile:$(obj-vdso-o32): KBUILD_CFLAGS := $(cflags-vdso) -mabi=32 arch/mips/vdso/Makefile:$(obj-vdso-n32): KBUILD_CFLAGS := $(cflags-vdso) -mabi=n32 arch/s390/boot/compressed/Makefile:KBUILD_CFLAGS := -m64 -D__KERNEL__ -O2 arch/s390/kernel/vdso32/Makefile:KBUILD_CFLAGS_31 := $(filter-out -m64,$(KBUILD_CFLAGS)) arch/s390/kernel/vdso64/Makefile:KBUILD_CFLAGS_64 := $(filter-out -m64,$(KBUILD_CFLAGS)) arch/tile/kernel/vdso/Makefile:KBUILD_CFLAGS_32 := $(filter-out -m64,$(KBUILD_CFLAGS)) arch/x86/boot/Makefile:KBUILD_CFLAGS := $(REALMODE_CFLAGS) -D_SETUP arch/x86/boot/compressed/Makefile:KBUILD_CFLAGS := -m$(BITS) -D__KERNEL__ -O2 arch/x86/entry/vdso/Makefile:$(vobjs): KBUILD_CFLAGS := $(filter-out $(GCC_PLUGINS_CFLAGS),$(KBUILD_CFLAGS)) $(CFL) arch/x86/entry/vdso/Makefile:KBUILD_CFLAGS_32 := $(filter-out -m64,$(KBUILD_CFLAGS)) arch/x86/entry/vdso/Makefile:KBUILD_CFLAGS_32 := $(filter-out -mcmodel=kernel,$(KBUILD_CFLAGS_32)) arch/x86/entry/vdso/Makefile:KBUILD_CFLAGS_32 := $(filter-out -fno-pic,$(KBUILD_CFLAGS_32)) arch/x86/entry/vdso/Makefile:KBUILD_CFLAGS_32 := $(filter-out -mfentry,$(KBUILD_CFLAGS_32)) arch/x86/entry/vdso/Makefile:KBUILD_CFLAGS_32 := $(filter-out $(GCC_PLUGINS_CFLAGS),$(KBUILD_CFLAGS_32)) arch/x86/purgatory/Makefile:KBUILD_CFLAGS := -fno-strict-aliasing -Wall -Wstrict-prototypes -fno-zero-initialized-in-bss -fno-builtin -ffreestanding -c -MD -Os -mcmodel=large arch/x86/realmode/rm/Makefile:KBUILD_CFLAGS := $(REALMODE_CFLAGS) -D_SETUP -D_WAKEUP \ drivers/firmware/efi/libstub/Makefile:KBUILD_CFLAGS := $(cflags-y) -DDISABLE_BRANCH_PROFILING \ Arnd