Received: by 10.213.65.68 with SMTP id h4csp147653imn; Thu, 15 Mar 2018 12:18:28 -0700 (PDT) X-Google-Smtp-Source: AG47ELv+m1hOq02asbBbuOhG7ZVu4pe6PxCNSfV3IF6iXtrXcLJVlYi+Ve4ZqGXqLgfHdFUhFcx6 X-Received: by 10.98.36.25 with SMTP id r25mr8716691pfj.106.1521141507983; Thu, 15 Mar 2018 12:18:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521141507; cv=none; d=google.com; s=arc-20160816; b=a3XL6ecGTYp5V7YKq49uAIx3RTGVO/cMqmfTd3Idv+hTBu2OiH8EMrstf9PCN6OTXV zP1+nsChzHqDz6SJDc0dTk1DODodH3qvVp/diY8vDg2xnQiIOsYT1jOWPcFwkqTwbzXa 2iTKmC9lP1JuMTp8sDOPljJvXUKggzNVTg2aZ5ZSroJ6tzT1bD0xrflvzuvXnPXO735T Itflqa3ajdPQoOrkCcHiSf8YmU8o5wws31u/EbBmlz7z/SZmKWAX4xn3q5S+jGPc5+QY K7CU7j0bKwH099zuZLIIvHe6Khdm4H6gnQXjStM8D1Er6mIrElnax3Pj7bifXll3cSTF udSA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=f0oJX08xvTlOZXN3ZHyjot5a06v+pVzuUmqtq6DCrzI=; b=jG0qkNcZ1Vp3Q7DYhBTiDNip+mMV31jAmAD7D9OLXSa9JW63HfNOMNZkKrvrjocWEK 3PuuElvXrPiLdb1fIeizWJzwdkn5DIL37U/WEhOdSyKMSYFYP4Qo2h2v2hnhhiFsTNKk krPWiU3UHqenaS11GiZSBfxYL3vuua/MzoV4nQdHZGJsSB2LabJGBFwH/voF/oXOnXgE JCPMWhvd+UdICReao9NnuFVmEp4gBX4yNAFilFAp9uFLu6KYyzY61utIfi8Txs4t0gFD VDel2QScNKAtlDzG+YvZSKe8vrARXTn6gOsjL+dzx21mUjjqw5zeQfmNAsABe0O6Gz57 eU9A== 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 u1si3815013pgq.194.2018.03.15.12.18.13; Thu, 15 Mar 2018 12:18:27 -0700 (PDT) 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 S932537AbeCOTQa (ORCPT + 99 others); Thu, 15 Mar 2018 15:16:30 -0400 Received: from mx2.suse.de ([195.135.220.15]:45232 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752991AbeCOTQZ (ORCPT ); Thu, 15 Mar 2018 15:16:25 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de X-Amavis-Alert: BAD HEADER SECTION, Duplicate header field: "References" Received: from relay1.suse.de (charybdis-ext.suse.de [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id D2FB6AFB4; Thu, 15 Mar 2018 19:16:23 +0000 (UTC) From: Michal Suchanek To: linuxppc-dev@lists.ozlabs.org Cc: Kate Stewart , Madhavan Srinivasan , Paul Mackerras , Michael Neuling , "Bryant G. Ly" , Mahesh Salgaonkar , "Naveen N. Rao" , Daniel Axtens , Nicholas Piggin , Al Viro , David Gibson , Greg Kroah-Hartman , linux-kernel@vger.kernel.org, Sergey Senozhatsky , =?UTF-8?q?C=C3=A9dric=20Le=20Goater?= , Masami Hiramatsu , Andrew Donnellan , Philippe Ombredanne , Joe Perches , Oliver O'Halloran , Andrew Morton , "Tobin C. Harding" , Michal Suchanek Subject: [PATCH RFC rebase 6/9] powerpc/64: Patch barrier_nospec in modules Date: Thu, 15 Mar 2018 20:15:55 +0100 Message-Id: X-Mailer: git-send-email 2.13.6 In-Reply-To: References: <20180313200108.GA4082@hirez.programming.kicks-ass.net> In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Note that unlike RFI which is patched only in kernel the nospec state reflects settings at the time the module was loaded. Iterating all modules and re-patching every time the settings change is not implemented. Based on lwsync patching. Signed-off-by: Michal Suchanek --- arch/powerpc/include/asm/setup.h | 5 ++++- arch/powerpc/kernel/module.c | 6 ++++++ arch/powerpc/kernel/setup_64.c | 4 ++-- arch/powerpc/lib/feature-fixups.c | 17 ++++++++++++++--- 4 files changed, 26 insertions(+), 6 deletions(-) diff --git a/arch/powerpc/include/asm/setup.h b/arch/powerpc/include/asm/setup.h index c7e9e66c2a38..92520d2483b8 100644 --- a/arch/powerpc/include/asm/setup.h +++ b/arch/powerpc/include/asm/setup.h @@ -58,7 +58,10 @@ enum spec_barrier_type { void setup_rfi_flush(enum l1d_flush_type, bool enable); void do_rfi_flush_fixups(enum l1d_flush_type types); void setup_barrier_nospec(enum spec_barrier_type, bool enable); -void do_barrier_nospec_fixups(enum spec_barrier_type type); +void do_barrier_nospec_fixups_kernel(enum spec_barrier_type type); +void do_barrier_nospec_fixups(enum spec_barrier_type type, + void *start, void *end); +extern enum spec_barrier_type powerpc_barrier_nospec; #endif /* !__ASSEMBLY__ */ diff --git a/arch/powerpc/kernel/module.c b/arch/powerpc/kernel/module.c index 3f7ba0f5bf29..7b6d0ec06a21 100644 --- a/arch/powerpc/kernel/module.c +++ b/arch/powerpc/kernel/module.c @@ -72,6 +72,12 @@ int module_finalize(const Elf_Ehdr *hdr, do_feature_fixups(powerpc_firmware_features, (void *)sect->sh_addr, (void *)sect->sh_addr + sect->sh_size); + + sect = find_section(hdr, sechdrs, "__spec_barrier_fixup"); + if (sect != NULL) + do_barrier_nospec_fixups(powerpc_barrier_nospec, + (void *)sect->sh_addr, + (void *)sect->sh_addr + sect->sh_size); #endif sect = find_section(hdr, sechdrs, "__lwsync_fixup"); diff --git a/arch/powerpc/kernel/setup_64.c b/arch/powerpc/kernel/setup_64.c index 767240074cad..f60e0e3b5ad2 100644 --- a/arch/powerpc/kernel/setup_64.c +++ b/arch/powerpc/kernel/setup_64.c @@ -910,11 +910,11 @@ void barrier_nospec_enable(bool enable) if (enable) { powerpc_barrier_nospec = barrier_nospec_type; - do_barrier_nospec_fixups(powerpc_barrier_nospec); + do_barrier_nospec_fixups_kernel(powerpc_barrier_nospec); on_each_cpu(do_nothing, NULL, 1); } else { powerpc_barrier_nospec = SPEC_BARRIER_NONE; - do_barrier_nospec_fixups(powerpc_barrier_nospec); + do_barrier_nospec_fixups_kernel(powerpc_barrier_nospec); } } diff --git a/arch/powerpc/lib/feature-fixups.c b/arch/powerpc/lib/feature-fixups.c index dfeb7feeccef..a529ac6b2a5d 100644 --- a/arch/powerpc/lib/feature-fixups.c +++ b/arch/powerpc/lib/feature-fixups.c @@ -160,14 +160,15 @@ void do_rfi_flush_fixups(enum l1d_flush_type types) : "unknown"); } -void do_barrier_nospec_fixups(enum spec_barrier_type type) +void do_barrier_nospec_fixups(enum spec_barrier_type type, + void *fixup_start, void *fixup_end) { unsigned int instr, *dest; long *start, *end; int i; - start = PTRRELOC(&__start___spec_barrier_fixup), - end = PTRRELOC(&__stop___spec_barrier_fixup); + start = fixup_start; + end = fixup_end; instr = 0x60000000; /* nop */ @@ -186,6 +187,16 @@ void do_barrier_nospec_fixups(enum spec_barrier_type type) printk(KERN_DEBUG "barrier-nospec: patched %d locations\n", i); } +void do_barrier_nospec_fixups_kernel(enum spec_barrier_type type) +{ + void *start, *end; + + start = PTRRELOC(&__start___spec_barrier_fixup), + end = PTRRELOC(&__stop___spec_barrier_fixup); + + do_barrier_nospec_fixups(type, start, end); +} + #endif /* CONFIG_PPC_BOOK3S_64 */ void do_lwsync_fixups(unsigned long value, void *fixup_start, void *fixup_end) -- 2.13.6