Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp75767ybf; Wed, 26 Feb 2020 09:06:06 -0800 (PST) X-Google-Smtp-Source: APXvYqyK8YtFBsdFpk164A/rwqSLz0imi7xF0eAR8E17A5DVvmOiemUnts7oUaqliKXu5+EyzVYx X-Received: by 2002:a9d:6e98:: with SMTP id a24mr3825188otr.53.1582736766245; Wed, 26 Feb 2020 09:06:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582736766; cv=none; d=google.com; s=arc-20160816; b=aAL4+iQGrYujkBOHVhKLimDPvQGzBGtTLLAsgoTXCFtuwO8mnle5T/lSg8NX+Zbeaf T/I4UK0uO/tuJTAy3G1aibr4tHhEGlE1AdvPg4NViEMoP0Q1Pk8FGp+VM2Wh2RPZT30Y czwhTUMF9Tx6B1ER+U6iLZTPSu8jLADeDl3tA2vuGwvEpr7niIT8NZET7mxlMKdd2uQt bTbk6hUNmEQIhL+n1TeixvSjThA0E+6OVDvJ7++mSOj3WTP6WX2g6/p+0v5/Ac0vSfxO IqiKNkj6MgFDppBzUwX3izCRtPEu+I2CEkfJxnHI4gjoPT6gKKFH9JUjyLNjoJ3cQSGp Nuwg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=K5ckkMeQHr84Dva6yR67M6tk+DSSjChVCWdK6ytrK0A=; b=0nT/CLMMg4KlUBkA3VLk/d1NSl9yUjPvghpJdmUMQ4cgCCD9ssbubWs9NQLa0i4s4u DpyyLlJHZKvq/4U4tLjyurabShPeIyBZSh+uyO1Vx2OPfm2sS/T0kQ6napaLAUz4Lc5c 1mSMAmWBa3B4fPzVieGeoKUVncGmquBatWgmsPpdn7aEf4BOoOpGyt2rb+Erb2pCPNuh Qli48fgYBLy2oiHsJDP7bkonV9ASH0YFUg3AYdwu8LzCt0IQ+IFICg/WBIDYCsByzdCt p/PrsxQKohwkilZ3CwpFx0IJq3Tn9EiXNyeZ9v4BFU91UaHr4MM3gnqx1l4h0zlcT674 C/rQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=UVDa7A3z; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g26si81229otn.180.2020.02.26.09.05.54; Wed, 26 Feb 2020 09:06:06 -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; dkim=pass header.i=@kernel.org header.s=default header.b=UVDa7A3z; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728287AbgBZRFi (ORCPT + 99 others); Wed, 26 Feb 2020 12:05:38 -0500 Received: from mail.kernel.org ([198.145.29.99]:39974 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727470AbgBZRFh (ORCPT ); Wed, 26 Feb 2020 12:05:37 -0500 Received: from localhost (lfbn-ncy-1-985-231.w90-101.abo.wanadoo.fr [90.101.63.231]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id E5A9F2467F; Wed, 26 Feb 2020 17:05:36 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1582736737; bh=gp7rt0swzmkwBxsp/s8luVlqOPQiL0kUz3kCiX51OH0=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=UVDa7A3zUwKqkzrlmofusxPaCbBRxpcMUgH8PLkkkaksvdDhMXmNMc3PMjCiXbmXj aiskMinuhgWX38059o3YO4Nj4rfVhdmB9mrkPemUVWKCcEuINAtVs/E258gh+HaU6Z sqhWsMD5uIvtTczTVkPC9UfL2u5gyfEPovQu/wQ0= Date: Wed, 26 Feb 2020 18:05:34 +0100 From: Frederic Weisbecker To: Peter Zijlstra Cc: Thomas Gleixner , LKML , x86@kernel.org, Steven Rostedt , Brian Gerst , Juergen Gross , Paolo Bonzini , Arnd Bergmann Subject: Re: [patch 13/16] x86/entry: Move irqflags and context tracking to C for simple idtentries Message-ID: <20200226170534.GA6075@lenoir> References: <20200225223321.231477305@linutronix.de> <20200225224145.444611199@linutronix.de> <20200226080538.GO18400@hirez.programming.kicks-ass.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200226080538.GO18400@hirez.programming.kicks-ass.net> User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Feb 26, 2020 at 09:05:38AM +0100, Peter Zijlstra wrote: > On Tue, Feb 25, 2020 at 11:33:34PM +0100, Thomas Gleixner wrote: > > > --- a/arch/x86/include/asm/idtentry.h > > +++ b/arch/x86/include/asm/idtentry.h > > @@ -7,14 +7,31 @@ > > > > #ifndef __ASSEMBLY__ > > > > +#ifdef CONFIG_CONTEXT_TRACKING > > +static __always_inline void enter_from_user_context(void) > > +{ > > + CT_WARN_ON(ct_state() != CONTEXT_USER); > > + user_exit_irqoff(); > > +} > > +#else > > +static __always_inline void enter_from_user_context(void) { } > > +#endif > > + > > /** > > * idtentry_enter - Handle state tracking on idtentry > > * @regs: Pointer to pt_regs of interrupted context > > * > > - * Place holder for now. > > + * Invokes: > > + * - The hardirq tracer to keep the state consistent as low level ASM > > + * entry disabled interrupts. > > + * > > + * - Context tracking if the exception hit user mode > > */ > > static __always_inline void idtentry_enter(struct pt_regs *regs) > > { > > + trace_hardirqs_off(); > > + if (user_mode(regs)) > > + enter_from_user_context(); > > } > > So: > > asm_exc_int3 > exc_int3 > idtentry_enter() > enter_from_user_context > if (context_tracking_enabled()) > > poke_int3_handler(); > > Is, AFAICT, completely buggered. > > You can't have a static_branch before the poke_int3_handler that deals > with text_poke. #BP is treated like an NMI in your patchset IIRC? In that case and since that implies we can't schedule, we can remove the call to context tracking there once we have nmi_enter()/nmi_exit() called unconditionally.