Received: by 10.223.176.46 with SMTP id f43csp1248756wra; Sat, 20 Jan 2018 14:24:28 -0800 (PST) X-Google-Smtp-Source: AH8x225SXSoRHUwjmiLTdgVbNTcf0AqjL7YqHnXaCwa2l9ZrNV2lqp/s7p1g7HBaBRCNi/m+C6R7 X-Received: by 10.99.103.198 with SMTP id b189mr3020524pgc.20.1516487068062; Sat, 20 Jan 2018 14:24:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516487068; cv=none; d=google.com; s=arc-20160816; b=FgRA+dF9+WCi8+fVsBoE9c0Rcqza27Roz7Gz4tiZwtu/teQ6oqxGYycU4P/omsy9vm b9a7cJZLFHOqsvDzFgfYhFc1i4YW8fFETS9oPYRwHWElh9KuJe6j0CHvWjA0Ug01gGLU johhTwLJKalTE2EtZ2vGwWfrbPb6zwBAFU69AOzRAYMwDHcDEugwiVM5XrUWkMtaghgc 5YnZqstNn3nUiBdvKHPrSDzN2EJ6c/FYbdUSkdpX54jWSuNyPcHnsYve4l+QZlovl6/t 3lMxTfgswHVT8YyMi4JORyrFhj4efUcUnu3xQPlueNEM0nsVWi9q3EkAfsgqAYcygGJT FTKQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :message-id:in-reply-to:subject:cc:to:from:date :arc-authentication-results; bh=zT0dsJPCMxnWxohAihyfrpAH5J5PDU67ypJFU2z8vNs=; b=rNw7ukvLDJxa46bGSNgtEXbgqiKjWYWPeDsvdNmu9qjvpiKFzxMW9GXMgkfRLkHO4Y UMxefKewvpeU9jQVQ/ZntiN/TErJknkMHve6MsrMgJlJOvTAKWMfkZ0vq1kcq/3AlnbG dAjsCN/RRL92CAbAxJPH+jA8oBBmXkt6d7qWjDWLz+LdWGIOz8erw7q/NuOBxTkj6fjN eHFQaYD00xb2jsJhxJ9wkvH++cjVfm45AeeNfIIWI1PV7l4Q5BNptIe4QX9hOIa6CsQi 93XeLTPmRjDiLpLweBSGUrS44FIoLzJaAfpWCSM1DJ4uCAG9XSbfFGOPE+in4mLKHPUB Qknw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f6si10794403pgn.336.2018.01.20.14.24.13; Sat, 20 Jan 2018 14:24:28 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756793AbeATWWU (ORCPT + 99 others); Sat, 20 Jan 2018 17:22:20 -0500 Received: from twin.jikos.cz ([91.219.245.39]:59695 "EHLO twin.jikos.cz" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756712AbeATWWN (ORCPT ); Sat, 20 Jan 2018 17:22:13 -0500 Received: from twin.jikos.cz (jikos@[127.0.0.1]) by twin.jikos.cz (8.13.6/8.13.6) with ESMTP id w0KMLBRB024781 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Sat, 20 Jan 2018 23:21:11 +0100 Received: from localhost (jikos@localhost) by twin.jikos.cz (8.13.6/8.13.6/Submit) with ESMTP id w0KML8Rg024776; Sat, 20 Jan 2018 23:21:09 +0100 X-Authentication-Warning: twin.jikos.cz: jikos owned process doing -bs Date: Sat, 20 Jan 2018 23:21:08 +0100 (CET) From: Jiri Kosina To: "gregkh@linuxfoundation.org" cc: "Woodhouse, David" , "linux-kernel@vger.kernel.org" , "jslaby@suse.cz" , "Ghitulete, Razvan-alin" , "mingo@kernel.org" , "peterz@infradead.org" , "arjan@linux.intel.com" , "tim.c.chen@linux.intel.com" , "torvalds@linux-foundation.org" , "tglx@linutronix.de" , "jpoimboe@redhat.com" , "stable@vger.kernel.org" , "ak@linux.intel.com" , "riel@redhat.com" , "keescook@google.com" , "gnomes@lxorguk.ukuu.org.uk" , "pjt@google.com" , "dave.hansen@intel.com" , "jikos@kernel.org" , "luto@amacapital.net" , "thomas.lendacky@amd.com" Subject: Re: [PATCH 4.9 85/96] x86/retpoline: Add initial retpoline support In-Reply-To: <20180117135144.GB3957@kroah.com> Message-ID: References: <20180115123404.270241256@linuxfoundation.org> <20180115123411.215283265@linuxfoundation.org> <1516099115.4937.40.camel@amazon.co.uk> <20180117135144.GB3957@kroah.com> User-Agent: Alpine 2.00 (LRH 1167 2008-08-23) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 17 Jan 2018, gregkh@linuxfoundation.org wrote: > > http://git.infradead.org/retpoline-stable.git/shortlog/refs/heads/linux-4.4.y > > And I've now queued up all of these patches, thanks very much for doing > this work! The patch below is needed on top of it, otherwise if CONFIG_MODVERSIONS is enabled, all the _thunk symbols end up with 0x0 checksum and fail to load due to mismatch. 0x00000000 __x86_indirect_thunk_rcx vmlinux EXPORT_SYMBOL so please consider queuing it on top; I am queuing it in SLE12 codestreams now. From: Nicholas Piggin Date: Tue, 1 Nov 2016 12:46:19 +1100 Subject: [PATCH] kbuild: modversions for EXPORT_SYMBOL() for asm Git-commit: 4efca4ed05cbdfd13ec3e8cb623fb77d6e4ab187 Patch-mainline: 4.9-rc6 [jkosina@suse.cz: folded cc6acc11cad1 fixup in as well ] Allow architectures to create asm/asm-prototypes.h file that provides C prototypes for exported asm functions, which enables proper CRC versions to be generated for them. Signed-off-by: Nicholas Piggin Signed-off-by: Michal Marek Signed-off-by: Jiri Kosina --- scripts/Makefile.build | 87 +++++++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 80 insertions(+), 7 deletions(-) --- a/scripts/Makefile.build +++ b/scripts/Makefile.build @@ -158,7 +158,8 @@ cmd_cc_i_c = $(CPP) $(c_flags) - $(obj)/%.i: $(src)/%.c FORCE $(call if_changed_dep,cc_i_c) -cmd_gensymtypes = \ +# These mirror gensymtypes_S and co below, keep them in synch. +cmd_gensymtypes_c = \ $(CPP) -D__GENKSYMS__ $(c_flags) $< | \ $(GENKSYMS) $(if $(1), -T $(2)) \ $(patsubst y,-s _,$(CONFIG_HAVE_UNDERSCORE_SYMBOL_PREFIX)) \ @@ -169,7 +170,7 @@ cmd_gensymtypes = quiet_cmd_cc_symtypes_c = SYM $(quiet_modtag) $@ cmd_cc_symtypes_c = \ set -e; \ - $(call cmd_gensymtypes,true,$@) >/dev/null; \ + $(call cmd_gensymtypes_c,true,$@) >/dev/null; \ test -s $@ || rm -f $@ $(obj)/%.symtypes : $(src)/%.c FORCE @@ -198,9 +199,10 @@ else # the actual value of the checksum generated by genksyms cmd_cc_o_c = $(CC) $(c_flags) -c -o $(@D)/.tmp_$(@F) $< -cmd_modversions = \ + +cmd_modversions_c = \ if $(OBJDUMP) -h $(@D)/.tmp_$(@F) | grep -q __ksymtab; then \ - $(call cmd_gensymtypes,$(KBUILD_SYMTYPES),$(@:.o=.symtypes)) \ + $(call cmd_gensymtypes_c,$(KBUILD_SYMTYPES),$(@:.o=.symtypes)) \ > $(@D)/.tmp_$(@F:.o=.ver); \ \ $(LD) $(LDFLAGS) -r -o $@ $(@D)/.tmp_$(@F) \ @@ -245,7 +247,7 @@ endif define rule_cc_o_c $(call echo-cmd,checksrc) $(cmd_checksrc) \ $(call echo-cmd,cc_o_c) $(cmd_cc_o_c); \ - $(cmd_modversions) \ + $(cmd_modversions_c) \ $(call echo-cmd,record_mcount) \ $(cmd_record_mcount) \ scripts/basic/fixdep $(depfile) $@ '$(call make-cmd,cc_o_c)' > \ @@ -254,6 +256,15 @@ define rule_cc_o_c mv -f $(dot-target).tmp $(dot-target).cmd endef +define rule_as_o_S + $(call echo-cmd,as_o_S) $(cmd_as_o_S); \ + scripts/basic/fixdep $(depfile) $@ '$(call make-cmd,as_o_S)' > \ + $(dot-target).tmp; \ + $(cmd_modversions_S) \ + rm -f $(depfile); \ + mv -f $(dot-target).tmp $(dot-target).cmd +endef + # Built-in and composite module parts $(obj)/%.o: $(src)/%.c $(recordmcount_source) FORCE $(call cmd,force_checksrc) @@ -282,6 +293,38 @@ modkern_aflags := $(KBUILD_AFLAGS_KERNEL $(real-objs-m) : modkern_aflags := $(KBUILD_AFLAGS_MODULE) $(AFLAGS_MODULE) $(real-objs-m:.o=.s): modkern_aflags := $(KBUILD_AFLAGS_MODULE) $(AFLAGS_MODULE) +# .S file exports must have their C prototypes defined in asm/asm-prototypes.h +# or a file that it includes, in order to get versioned symbols. We build a +# dummy C file that includes asm-prototypes and the EXPORT_SYMBOL lines from +# the .S file (with trailing ';'), and run genksyms on that, to extract vers. +# +# This is convoluted. The .S file must first be preprocessed to run guards and +# expand names, then the resulting exports must be constructed into plain +# EXPORT_SYMBOL(symbol); to build our dummy C file, and that gets preprocessed +# to make the genksyms input. +# +# These mirror gensymtypes_c and co above, keep them in synch. +cmd_gensymtypes_S = \ + (echo "\#include " ; \ + echo "\#include " ; \ + $(CPP) $(a_flags) $< | \ + grep "\<___EXPORT_SYMBOL\>" | \ + sed 's/.*___EXPORT_SYMBOL[[:space:]]*\([a-zA-Z0-9_]*\)[[:space:]]*,.*/EXPORT_SYMBOL(\1);/' ) | \ + $(CPP) -D__GENKSYMS__ $(c_flags) -xc - | \ + $(GENKSYMS) $(if $(1), -T $(2)) \ + $(patsubst y,-s _,$(CONFIG_HAVE_UNDERSCORE_SYMBOL_PREFIX)) \ + $(if $(KBUILD_PRESERVE),-p) \ + -r $(firstword $(wildcard $(2:.symtypes=.symref) /dev/null)) + +quiet_cmd_cc_symtypes_S = SYM $(quiet_modtag) $@ +cmd_cc_symtypes_S = \ + set -e; \ + $(call cmd_gensymtypes_S,true,$@) >/dev/null; \ + test -s $@ || rm -f $@ + +$(obj)/%.symtypes : $(src)/%.S FORCE + $(call cmd,cc_symtypes_S) + quiet_cmd_as_s_S = CPP $(quiet_modtag) $@ cmd_as_s_S = $(CPP) $(a_flags) -o $@ $< @@ -289,10 +332,40 @@ $(obj)/%.s: $(src)/%.S FORCE $(call if_changed_dep,as_s_S) quiet_cmd_as_o_S = AS $(quiet_modtag) $@ -cmd_as_o_S = $(CC) $(a_flags) -c -o $@ $< + +ifndef CONFIG_MODVERSIONS +cmd_as_o_S = $(CC) $(a_flags) -c -o $@ $< + +else + +ASM_PROTOTYPES := $(wildcard $(srctree)/arch/$(SRCARCH)/include/asm/asm-prototypes.h) + +ifeq ($(ASM_PROTOTYPES),) +cmd_as_o_S = $(CC) $(a_flags) -c -o $@ $< + +else + +# versioning matches the C process described above, with difference that +# we parse asm-prototypes.h C header to get function definitions. + +cmd_as_o_S = $(CC) $(a_flags) -c -o $(@D)/.tmp_$(@F) $< + +cmd_modversions_S = \ + if $(OBJDUMP) -h $(@D)/.tmp_$(@F) | grep -q __ksymtab; then \ + $(call cmd_gensymtypes_S,$(KBUILD_SYMTYPES),$(@:.o=.symtypes)) \ + > $(@D)/.tmp_$(@F:.o=.ver); \ + \ + $(LD) $(LDFLAGS) -r -o $@ $(@D)/.tmp_$(@F) \ + -T $(@D)/.tmp_$(@F:.o=.ver); \ + rm -f $(@D)/.tmp_$(@F) $(@D)/.tmp_$(@F:.o=.ver); \ + else \ + mv -f $(@D)/.tmp_$(@F) $@; \ + fi; +endif +endif $(obj)/%.o: $(src)/%.S FORCE - $(call if_changed_dep,as_o_S) + $(call if_changed_rule,as_o_S) targets += $(real-objs-y) $(real-objs-m) $(lib-y) targets += $(extra-y) $(MAKECMDGOALS) $(always) -- Jiri Kosina SUSE Labs