Received: by 2002:a25:e7d8:0:0:0:0:0 with SMTP id e207csp904634ybh; Tue, 10 Mar 2020 10:28:39 -0700 (PDT) X-Google-Smtp-Source: ADFU+vtCD1WR68YxD3mp18Gf1hXa5Id58qEBlQnXzdyewmlaDd8F3zA3YZegZ3BvjdIafmdhO/cB X-Received: by 2002:a9d:2c69:: with SMTP id f96mr9289010otb.62.1583861319167; Tue, 10 Mar 2020 10:28:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1583861319; cv=none; d=google.com; s=arc-20160816; b=cOtIiJPEX4dzBgZQS29EF9zNBgUEEtb8pTz5TRR0hvugjhcbRzGFhbgn0WXlRbJ8d1 jqGkvREEfI7pJaDkSQjhzxEbyZxALfvMw8p3HOPspXqo1GqEpRfUT3p8h7Cpm0M4jFFX /L4o2zQ7Yd9zAK7z6+AmwC1MiH/V6+btmsQYMtGRk646+u9jakKV34IapvdTYYhiVDEv VSNl9XFCe+YmQcXFuhlO/fTegYwyX5rXWLpP18YyC/CpWs5J+72GJzGiGPN8kLIac2dr nexyGuy3QsKWUzwoN2tE+sCNt40bsbzqFqrYdJKBJo8xHXX2gnNXE1KKZfY2RswFJ865 LxYA== 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:reply-to:message-id :subject:cc:to:from:date:dkim-signature; bh=ONo4OFTdJRiYNsK97v+3riYTEyReBoiP7eEnRIEgKzo=; b=wibT3YQhklUdTsAJgWe8E/5Q4WUqYyCcZuK8bwRe7GwWQ5DUWmvtNhbG6tgXov76B1 voYtWjTz2wQFem3j3jyQsb3OrTZEGuUhl1TVNNpSnrk0snxL71VXZWBcfJfVLaZ5Mxvh 8vRLkFcAlF0WPbwRJv4kHactUAHKCxnsdwN6vPaDmPH1PzZ5BfxrFmb+1fGLEwNyq2pv lLt3LYiSsLl7McHRe9Z+NL1koP6u+R/10fkStbFCizDDhmNL08mdGqQ5ZYVI+ikmGp15 nAr72Poy7VEYILWXgoVvzsVp8QcyDxIOJz0mQDaE9DbgVcgH6ig4prwdZYyUWC0LhK03 wPSQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=fWii4LBO; 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 u7si5772512otq.323.2020.03.10.10.28.27; Tue, 10 Mar 2020 10:28:39 -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; dkim=pass header.i=@kernel.org header.s=default header.b=fWii4LBO; 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 S1726647AbgCJR0n (ORCPT + 99 others); Tue, 10 Mar 2020 13:26:43 -0400 Received: from mail.kernel.org ([198.145.29.99]:36006 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726271AbgCJR0n (ORCPT ); Tue, 10 Mar 2020 13:26:43 -0400 Received: from paulmck-ThinkPad-P72.home (50-39-105-78.bvtn.or.frontiernet.net [50.39.105.78]) (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 9CC8E2146E; Tue, 10 Mar 2020 17:26:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1583861202; bh=bDNkvVl2IUXM6TlbwkSJ/orXHQ/JdYR8AwtLVGVWtDk=; h=Date:From:To:Cc:Subject:Reply-To:References:In-Reply-To:From; b=fWii4LBOv1kQRuFHgrE2gSUuVI3Gd95dTbma4MU3XqeS7WnRIeefoDeNSH8DVfexJ 6Alq5QRW2J0Qo5e5UQ6eJwkXwk4gCF80vLdGkbJkTxOW3Q3zFSeMGYsXmMcyisybRh IEhJ4zpJnMh8riNiyeKZ8qJ0Wi/dD2B3ptDuKr08= Received: by paulmck-ThinkPad-P72.home (Postfix, from userid 1000) id 7381635229CC; Tue, 10 Mar 2020 10:26:42 -0700 (PDT) Date: Tue, 10 Mar 2020 10:26:42 -0700 From: "Paul E. McKenney" To: Mathieu Desnoyers Cc: Thomas Gleixner , linux-kernel , Peter Zijlstra , rostedt , Masami Hiramatsu , Alexei Starovoitov , "Joel Fernandes, Google" , Frederic Weisbecker Subject: Re: Instrumentation and RCU Message-ID: <20200310172642.GG2935@paulmck-ThinkPad-P72> Reply-To: paulmck@kernel.org References: <87mu8p797b.fsf@nanos.tec.linutronix.de> <20200309204710.GU2935@paulmck-ThinkPad-P72> <379743142.23419.1583853207158.JavaMail.zimbra@efficios.com> <20200310164927.GD2935@paulmck-ThinkPad-P72> <1800881789.23773.1583860965967.JavaMail.zimbra@efficios.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1800881789.23773.1583860965967.JavaMail.zimbra@efficios.com> 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 Tue, Mar 10, 2020 at 01:22:45PM -0400, Mathieu Desnoyers wrote: > ----- On Mar 10, 2020, at 12:49 PM, paulmck paulmck@kernel.org wrote: > > > On Tue, Mar 10, 2020 at 11:13:27AM -0400, Mathieu Desnoyers wrote: > >> > >> > >> ----- On Mar 9, 2020, at 4:47 PM, paulmck paulmck@kernel.org wrote: > >> [...] > >> > >> > > >> > Suppose that we had a variant of RCU that had about the same read-side > >> > overhead as Preempt-RCU, but which could be used from idle as well as > >> > from CPUs in the process of coming online or going offline? I have not > >> > thought through the irq/NMI/exception entry/exit cases, but I don't see > >> > why that would be problem. > >> > > >> > This would have explicit critical-section entry/exit code, so it would > >> > not be any help for trampolines. > >> > > >> > Would such a variant of RCU help? > >> > > >> > Yeah, I know. Just what the kernel doesn't need, yet another variant > >> > of RCU... > >> > >> Hi Paul, > >> > >> I think that before introducing yet another RCU flavor, it's important > >> to take a step back and look at the tracer requirements first. If those > >> end up being covered by currently available RCU flavors, then why add > >> another ? > > > > Well, we have BPF requirements as well. > > > >> I can start with a few use-cases I have in mind. Others should feel free > >> to pitch in: > >> > >> Tracing callsite context: > >> > >> 1) Thread context > >> > >> 1.1) Preemption enabled > >> > >> One tracepoint in this category is syscall enter/exit. We should introduce > >> a variant of tracepoints relying on SRCU for this use-case so we can take > >> page faults when fetching userspace data. > > > > Agreed, SRCU works fine for the page-fault case, as the read-side memory > > barriers are in the noise compared to page-fault overhead. Back in > > the day, there were light-weight system calls. Are all of these now > > converted to VDSO or similar? > > There is a big difference between allowing page faults to happen, and expecting > page faults to happen every time. I suspect many use-cases will end up having > a fast-path which touches user-space data which is in the page cache, but > may end up triggering page faults in rare occasions. > > Therefore, this might justify an SRCU which has low-overhead read-side. OK, good to know, thank you! Thanx, Paul