From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751099AbdAQNpO (ORCPT ); Tue, 17 Jan 2017 08:45:14 -0500 Received: from merlin.infradead.org ([205.233.59.134]:45578 "EHLO merlin.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750888AbdAQNpN (ORCPT ); Tue, 17 Jan 2017 08:45:13 -0500 Date: Tue, 17 Jan 2017 14:44:54 +0100 From: Peter Zijlstra To: Vlastimil Babka Cc: Stafford Horne , linux-kernel@vger.kernel.org, Andrew Morton , Thomas Gleixner , Kees Cook , Jessica Yu , Petr Mladek , Rasmus Villemoes , Yang Shi , Tejun Heo , Prarit Bhargava , Yaowei Bai , Andrey Ryabinin Subject: Re: [PATCH -next] init/main: Init jump_labels before they are used to build zonelists Message-ID: <20170117134454.GB6515@twins.programming.kicks-ass.net> References: <20170117125624.8535-1-shorne@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.23.1 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jan 17, 2017 at 02:07:36PM +0100, Vlastimil Babka wrote: > Anyway I'm not sure if this patch is safe. Hopefully Peter can judge > this better... > > > Cc: Vlastimil Babka > > Signed-off-by: Stafford Horne > > --- > > init/main.c | 3 +-- > > 1 file changed, 1 insertion(+), 2 deletions(-) > > > > diff --git a/init/main.c b/init/main.c > > index 8b1adb6e..d1ca7cb 100644 > > --- a/init/main.c > > +++ b/init/main.c > > @@ -513,6 +513,7 @@ asmlinkage __visible void __init start_kernel(void) > > boot_cpu_state_init(); > > smp_prepare_boot_cpu(); /* arch-specific boot-cpu hooks */ > > > > + jump_label_init(); > > build_all_zonelists(NULL, NULL); > > page_alloc_init(); > > > > @@ -526,8 +527,6 @@ asmlinkage __visible void __init start_kernel(void) > > parse_args("Setting init args", after_dashes, NULL, 0, -1, -1, > > NULL, set_init_arg); > > > > - jump_label_init(); > > - Urgh, that means auditing all archs that implement this. The thing you're looking for is if the self-modifying code cruft can be done that early. x86 looks to be fine, because this is after setup_arch() which is required for ideal_nops[] to be initialied and we use text_poke_early() which doesn't really need anything else. I've not gone through the other arches...