Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp7541505imu; Wed, 14 Nov 2018 20:03:03 -0800 (PST) X-Google-Smtp-Source: AJdET5ccAgjIC8A28yM9sWbteGToI9FUpKsQ2YgfoCwYJ70VsBBscicp+tpjQgivdUkNUjhLKMOv X-Received: by 2002:a62:6408:: with SMTP id y8mr4756909pfb.202.1542254583539; Wed, 14 Nov 2018 20:03:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542254583; cv=none; d=google.com; s=arc-20160816; b=FY3/Q58el4RGeGsGhSMNPxwN+iTH6Qa+zo/DqMNpJuiU43Kcerr7J2qBWKAJzTjUzY zE/MGxzS+O1EvlcpvS46rU3vFFWJHHW2CFt+GFKbBlizYbQnUr4E14UtLYkwXp+tb4BT pWfse5lrv3bvqcPzJkhl5bT7v/0AvY4LRbt7A/s3Xb+p8wuqjgCO0jJgLUH823iwoIgt tXr7h/n/hWxMsg0BFECdEjcHefPOKqf6/sjDRTwbm2N/PTzLL7jWQARs59n5E81/zuJ9 CY4vniwboC/xXCRfETbcPklOeNyxep26dYRjeJQRHs/9lMjtQ+4FOx8HkD7hVh8UTGiB 5u2A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from; bh=cNuFmOM3ILXCup2ZhtVVfx0v2RndMBTuvRuBeaoVp7M=; b=dunXz8ewhcfb8iAH1EMXY/4ThXKKs4zRR9yDZenJSJDLWqaGiIUW0h9Ps/QZzFMA9G Hr/GeEcFpNLGBz0NV0IkIiOnLSLr0Udt146v/hBHOk7G1EP7vb6wuzrRSpq+viKYWf02 8z7t9s80yxEiAlK+SxKIQjDxb8eM67qBhGYatkc2+J6k3vxU6XROVjJXKmHnzSufO/Eq BIyd0QaUoEkIBfJ4Ar2PK+lTzxSlIW8ahfVDzjoyvwIMISxU1393ywThyAfYPPibmIwM GtyEkrE2lS3HkxJxYzhXg8EzZ7o30oJfdSiNEL9F8UmNnjzM2XlS8BVh6LGU3uoIs3c2 BlAA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=vmware.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b3si25221247pgh.496.2018.11.14.20.02.48; Wed, 14 Nov 2018 20:03:03 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=vmware.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728296AbeKOOHE (ORCPT + 99 others); Thu, 15 Nov 2018 09:07:04 -0500 Received: from ex13-edg-ou-001.vmware.com ([208.91.0.189]:42825 "EHLO EX13-EDG-OU-001.vmware.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726689AbeKOOHD (ORCPT ); Thu, 15 Nov 2018 09:07:03 -0500 Received: from sc9-mailhost2.vmware.com (10.113.161.72) by EX13-EDG-OU-001.vmware.com (10.113.208.155) with Microsoft SMTP Server id 15.0.1156.6; Wed, 14 Nov 2018 20:00:26 -0800 Received: from sc2-haas01-esx0118.eng.vmware.com (sc2-haas01-esx0118.eng.vmware.com [10.172.44.118]) by sc9-mailhost2.vmware.com (Postfix) with ESMTP id E2F961B803A; Wed, 14 Nov 2018 23:00:54 -0500 (EST) From: Nadav Amit To: Masahiro Yamada , Ingo Molnar CC: Michal Marek , Thomas Gleixner , Borislav Petkov , "H. Peter Anvin" , , , , Nadav Amit Subject: [PATCH v2 1/2] Makefile: Fix distcc compilation with x86 macros Date: Wed, 14 Nov 2018 12:43:08 -0800 Message-ID: <20181114204309.18645-2-namit@vmware.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20181114204309.18645-1-namit@vmware.com> References: <20181114204309.18645-1-namit@vmware.com> MIME-Version: 1.0 Content-Type: text/plain Received-SPF: None (EX13-EDG-OU-001.vmware.com: namit@vmware.com does not designate permitted sender hosts) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Introducing the use of asm macros in c-code broke distcc, since it only sends the preprocessed source file. The solution is to break the compilation into two separate phases of compilation and assembly, and between the two concatenate the assembly macros and the compiled (yet not assembled) source file. Since this is less efficient, this compilation mode is only used when distcc or icecc are used. Note that the assembly stage should also be distributed, if distcc is configured using "CFLAGS=-DENABLE_REMOTE_ASSEMBLE". Reported-by: Logan Gunthorpe Signed-off-by: Nadav Amit --- Makefile | 4 +++- arch/x86/Makefile | 7 +++++-- scripts/Makefile.build | 30 ++++++++++++++++++++++++++++-- 3 files changed, 36 insertions(+), 5 deletions(-) diff --git a/Makefile b/Makefile index 9fce8b91c15f..c07349fc38c7 100644 --- a/Makefile +++ b/Makefile @@ -743,7 +743,9 @@ KBUILD_CFLAGS += $(call cc-option, -gsplit-dwarf, -g) else KBUILD_CFLAGS += -g endif -KBUILD_AFLAGS += -Wa,-gdwarf-2 +AFLAGS_DEBUG_INFO = -Wa,-gdwarf-2 +export AFLAGS_DEBUG_INFO +KBUILD_AFLAGS += $(AFLAGS_DEBUG_INFO) endif ifdef CONFIG_DEBUG_INFO_DWARF4 KBUILD_CFLAGS += $(call cc-option, -gdwarf-4,) diff --git a/arch/x86/Makefile b/arch/x86/Makefile index f5d7f4134524..b5953cbcc9c8 100644 --- a/arch/x86/Makefile +++ b/arch/x86/Makefile @@ -235,10 +235,13 @@ archscripts: scripts_basic archheaders: $(Q)$(MAKE) $(build)=arch/x86/entry/syscalls all +ASM_MACRO_FILE = arch/x86/kernel/macros.s +export ASM_MACRO_FILE + archmacros: - $(Q)$(MAKE) $(build)=arch/x86/kernel arch/x86/kernel/macros.s + $(Q)$(MAKE) $(build)=arch/x86/kernel $(ASM_MACRO_FILE) -ASM_MACRO_FLAGS = -Wa,arch/x86/kernel/macros.s +ASM_MACRO_FLAGS = -Wa,$(ASM_MACRO_FILE) export ASM_MACRO_FLAGS KBUILD_CFLAGS += $(ASM_MACRO_FLAGS) diff --git a/scripts/Makefile.build b/scripts/Makefile.build index 6a6be9f440cf..b8d26bdf48b0 100644 --- a/scripts/Makefile.build +++ b/scripts/Makefile.build @@ -155,8 +155,34 @@ $(obj)/%.ll: $(src)/%.c FORCE quiet_cmd_cc_o_c = CC $(quiet_modtag) $@ +# If distcc (or icecc) are used, and when assembly macro files are needed, the +# compilation stage and the assembly stage needs to be separated. Providing the +# "IGNORE_DISTCC=y" option disables separate compilation and assembly. + +cmd_cc_o_c_direct = $(CC) $(c_flags) -c -o $(1) $< + +ifneq ($(if $(IGNORE_DISTCC),,$(shell $(CC) --version 2>&1 | head -n 1 | grep -E 'distcc|ICECC')),) +a_flags_no_debug = $(filter-out $(AFLAGS_DEBUG_INFO), $(a_flags)) +c_flags_no_macros = $(filter-out $(ASM_MACRO_FLAGS), $(c_flags)) + +cmd_cc_o_c_two_steps = \ + $(CC) $(c_flags_no_macros) $(DISABLE_LTO) -fverbose-asm -S \ + -o $(@D)/.$(@F:.o=.s) $<; \ + cat $(ASM_MACRO_FILE) $(@D)/.$(@F:.o=.s) > \ + $(@D)/.tmp_$(@F:.o=.s); \ + $(CC) $(a_flags_no_debug) -c -o $(1) $(@D)/.tmp_$(@F:.o=.s); \ + rm -f $(@D)/.$(@F:.o=.s) $(@D)/.tmp_$(@F:.o=.s) \ + +cmd_cc_o_c_helper = \ + $(if $(findstring $(ASM_MACRO_FLAGS),$(c_flags)), \ + $(call cmd_cc_o_c_two_steps, $(1)), \ + $(call cmd_cc_o_c_direct, $(1))) +else +cmd_cc_o_c_helper = $(call cmd_cc_o_c_direct, $(1)) +endif + ifndef CONFIG_MODVERSIONS -cmd_cc_o_c = $(CC) $(c_flags) -c -o $@ $< +cmd_cc_o_c = $(call cmd_cc_o_c_helper,$@) else # When module versioning is enabled the following steps are executed: @@ -171,7 +197,7 @@ else # replace the unresolved symbols __crc_exported_symbol with # the actual value of the checksum generated by genksyms -cmd_cc_o_c = $(CC) $(c_flags) -c -o $(@D)/.tmp_$(@F) $< +cmd_cc_o_c = $(call cmd_cc_o_c_helper,$(@D)/.tmp_$(@F)) cmd_modversions_c = \ if $(OBJDUMP) -h $(@D)/.tmp_$(@F) | grep -q __ksymtab; then \ -- 2.17.1