Received: by 2002:a25:e7d8:0:0:0:0:0 with SMTP id e207csp872076ybh; Tue, 10 Mar 2020 09:50:07 -0700 (PDT) X-Google-Smtp-Source: ADFU+vtlLtZ9Qw2tmBMKaY5yJRMQ0gXMtymgUjUtOBM61YosiIjatlBdJHkgfc0hEQ/Z33AoCQWt X-Received: by 2002:a05:6830:1d6e:: with SMTP id l14mr17187103oti.32.1583859007310; Tue, 10 Mar 2020 09:50:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1583859007; cv=none; d=google.com; s=arc-20160816; b=JZzyBa3zHARQrCAmdKkqkRce3vwUO+5DyobuiXHZkLo5sfMCAKm9OXhCwNqkUzk5xi e6kxI/hkYL7skC9us+OCRZ+FVE5xQTQP5DOE/PgtJgh5MdZAqMd0EiJPl7AD38JcANDv FR/eurKHF3kL7pVGy2iOK5e0Xlavd3TkIE5dUNbw81i0+/7CwaX+dGhH4OtOjV4gGRnb N7vZaQb1pglxLs7Q/uyuvkXEWb1Je1QBYwITHbQrDU7DlaTD5zbORWtuepQPZs00d7mG IUOfSdTdbfJftLOfqwA4t5+vstl+a4fqOwQqvodz6uUDMEx0ZUPdbWAXNdSzoP6stOF2 AwhQ== 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=A9sFah62oxKq/TCmYvm/zRSWv53LY7fuqVZUNBZAZ24=; b=m1Mvc/7CERbwWmzT55/NcmPN2RiiidZKrxridR9MMstENYmZR9uhdxIYd5YwhF3732 xcILsKreBatWQmeP8NPoKDuDRuVnim+PJswSXGKoN4PS9PgnJ2f/1EsRfZqWzokD7DtD O3YHb3Yss1OJJW776xR9NdspaKe2a4M1afdD8/PETGMbDbr57Od+5z0Loa8NTVqaYzDg mARZ6Rn0eMT30Jbrl4Nz0G7eWJCAAXP10rqmy6F1qHIhBLgXkvLROhAUhMzRigE+6e4f WjfLkMEP9pR2zQAo9xCOKH/WSQCEcgtaiNXUEm1LInLPJjsbxD9v01dkf0286ssTJ31q II5w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=EN8bsFrH; 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 v142si530053oie.217.2020.03.10.09.49.54; Tue, 10 Mar 2020 09:50:07 -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=EN8bsFrH; 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 S1726788AbgCJQt2 (ORCPT + 99 others); Tue, 10 Mar 2020 12:49:28 -0400 Received: from mail.kernel.org ([198.145.29.99]:51602 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726307AbgCJQt2 (ORCPT ); Tue, 10 Mar 2020 12:49:28 -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 3C1D321927; Tue, 10 Mar 2020 16:49:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1583858967; bh=aZeeJI4m4VA8ZtSKMjKdiWAG3VUJVrzCbJacfmOigbk=; h=Date:From:To:Cc:Subject:Reply-To:References:In-Reply-To:From; b=EN8bsFrHW5CSe5hqSMYnzI6bVJxJrFU1KeDLhy7aWdoO69m+Qh9WglObnp+WfrWbe 9NegxcjuXjpEdBF0vCmlcMxg5CENvEmjq2kHND9IeSg/1eBSeP3nHHp4W1S5KmPzMQ SQIYJvibJM6bn0EGU+a1EwuBcrVaUw37T8s5jJUc= Received: by paulmck-ThinkPad-P72.home (Postfix, from userid 1000) id 190C035229CC; Tue, 10 Mar 2020 09:49:27 -0700 (PDT) Date: Tue, 10 Mar 2020 09:49:27 -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: <20200310164927.GD2935@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> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <379743142.23419.1583853207158.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 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? > 1.2) Preemption disabled > > Tree-RCU works fine. > > 1.3) IRQs disabled > > Tree-RCU works fine. > > 2) IRQ handler context > > Tree-RCU works fine. > > 3) NMI context > > Tree-RCU works fine. > > 4) cpuidle context (!rcu_is_watching()) > > - By all means, we should not have tracepoints requiring to temporarily enable > RCU in frequent code-paths. It appears that we should be able to remove the few > offenders we currently have (e.g. enter from usermode), > - For tracepoints which are infrequently called from !rcu_is_watching context, checking > whether RCU is watching and only enabling when needed should be fast enough. > > Are there other use-cases am I missing that would justify adding another flavor of RCU ? BPF programs that might sometimes sleep, but are usually lightweight. I will be double-checking this, of course. Thanx, Paul