Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp4009393ybv; Mon, 10 Feb 2020 10:31:15 -0800 (PST) X-Google-Smtp-Source: APXvYqyWAyzVYfdT836d6PrRb9wFCeCP59rAg5yFBJK3DZUukPjCRDmdnlM78S0ApDLRbFEeulm6 X-Received: by 2002:a9d:20c1:: with SMTP id x59mr2133752ota.286.1581359475809; Mon, 10 Feb 2020 10:31:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581359475; cv=none; d=google.com; s=arc-20160816; b=Z/OOc4yYtQB1GmWvPfPFaw6IZEWaF5ChYWzwRV87lnGOidakIsMfPf3B3/45uQH3BI RMQPfxjCwBdDvjzz46QOQLCU8hERZzxRXABG+wiksiwiCTX34RddfcTP9opTh4mG7qIy ty4tii17wv77paXpU/WBREWugGw5+Ee0I98n18+5Q0rlbGSiXqMzWqXRbGtLcXp9p5q+ loiSfYDEWlvr6vG2cFNtWcoDJo4itbUQcFXddxgTFW26FOEI700uYEYmenrHSCIk9A2e m4vOsgjd/3/Wwx/MvRFRGQW3vzVUY2keqxKEbspOmA9n+gdTp5aVbm9Skbn4V1yNKF9A EEWQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date; bh=q5OIqK3zlbLaNiVYb7iTrTL6bemQ8lJKOLMZcijhcvM=; b=T4dJaXcRkt3J0x+573jol4r91JSnzNonY/+9bIDzZHxrgA/mysMC3ryYZk5+DdTmkt 8tTGi5+gehYF3EJfY8BBQIIcqVgmFnMwwY5k9/J2iKR5BK8aMqizsyCkIGE6CEK0A7t+ VJ0ZXmWj6YeMpv9pPnDwO2FtEDLtWXKajZqhz77BfHObggAZqf7dvFBceItuvGRmyGJI af5f6MWjSO2VuTsBKCAqrPW5b/9Z3A6NDGZNIDCRiHVPH5xTIeh8AejezHNBC4eKewbw bVkid63KCV0csubj/l7985WlLHoGEMHMnzALUPYQi5E/XMa1M4iNb4eeoETcubUsw/w1 DQ3Q== 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 e64si472491oib.4.2020.02.10.10.31.03; Mon, 10 Feb 2020 10:31:15 -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; 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 S1727575AbgBJSat (ORCPT + 99 others); Mon, 10 Feb 2020 13:30:49 -0500 Received: from mail.kernel.org ([198.145.29.99]:50106 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726950AbgBJSat (ORCPT ); Mon, 10 Feb 2020 13:30:49 -0500 Received: from gandalf.local.home (cpe-66-24-58-225.stny.res.rr.com [66.24.58.225]) (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 3C01C20838; Mon, 10 Feb 2020 18:30:47 +0000 (UTC) Date: Mon, 10 Feb 2020 13:30:45 -0500 From: Steven Rostedt To: Mathieu Desnoyers Cc: Peter Zijlstra , "Joel Fernandes, Google" , linux-kernel , Greg Kroah-Hartman , "Gustavo A. R. Silva" , Ingo Molnar , Richard Fontana , Thomas Gleixner , paulmck , Josh Triplett , Lai Jiangshan , Arnaldo Carvalho de Melo Subject: Re: [RFC 0/3] Revert SRCU from tracepoint infrastructure Message-ID: <20200210133045.3beb774e@gandalf.local.home> In-Reply-To: <1966694237.616758.1581355984287.JavaMail.zimbra@efficios.com> References: <20200207205656.61938-1-joel@joelfernandes.org> <1997032737.615438.1581179485507.JavaMail.zimbra@efficios.com> <20200210094616.GC14879@hirez.programming.kicks-ass.net> <20200210120552.1a06a7aa@gandalf.local.home> <1966694237.616758.1581355984287.JavaMail.zimbra@efficios.com> X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 10 Feb 2020 12:33:04 -0500 (EST) Mathieu Desnoyers wrote: > The rcu_irq_enter/exit_irqson() does atomic_add_return(), which is even worse > than a memory barrier. As we discussed on IRC, would something like this work (not even compiled tested). -- Steve diff --git a/include/linux/tracepoint.h b/include/linux/tracepoint.h index 1fb11daa5c53..a83fd076a312 100644 --- a/include/linux/tracepoint.h +++ b/include/linux/tracepoint.h @@ -179,10 +179,8 @@ static inline struct tracepoint *tracepoint_ptr_deref(tracepoint_ptr_t *p) * For rcuidle callers, use srcu since sched-rcu \ * doesn't work from the idle path. \ */ \ - if (rcuidle) { \ + if (rcuidle) \ __idx = srcu_read_lock_notrace(&tracepoint_srcu);\ - rcu_irq_enter_irqson(); \ - } \ \ it_func_ptr = rcu_dereference_raw((tp)->funcs); \ \ @@ -194,10 +192,8 @@ static inline struct tracepoint *tracepoint_ptr_deref(tracepoint_ptr_t *p) } while ((++it_func_ptr)->func); \ } \ \ - if (rcuidle) { \ - rcu_irq_exit_irqson(); \ + if (rcuidle) \ srcu_read_unlock_notrace(&tracepoint_srcu, __idx);\ - } \ \ preempt_enable_notrace(); \ } while (0) diff --git a/include/trace/perf.h b/include/trace/perf.h index dbc6c74defc3..86d3b2eb00cd 100644 --- a/include/trace/perf.h +++ b/include/trace/perf.h @@ -39,17 +39,27 @@ perf_trace_##call(void *__data, proto) \ u64 __count = 1; \ struct task_struct *__task = NULL; \ struct hlist_head *head; \ + bool rcu_watching; \ int __entry_size; \ int __data_size; \ int rctx; \ \ + rcu_watching = rcu_is_watching(); \ + \ + /* Can not use RCU if rcu is not watching and in NMI */ \ + if (!rcu_watching && in_nmi()) \ + return; \ + \ __data_size = trace_event_get_offsets_##call(&__data_offsets, args); \ \ + if (!rcu_watching) \ + rcu_irq_enter_irqson(); \ + \ head = this_cpu_ptr(event_call->perf_events); \ if (!bpf_prog_array_valid(event_call) && \ __builtin_constant_p(!__task) && !__task && \ hlist_empty(head)) \ - return; \ + goto out; \ \ __entry_size = ALIGN(__data_size + sizeof(*entry) + sizeof(u32),\ sizeof(u64)); \ @@ -57,7 +67,7 @@ perf_trace_##call(void *__data, proto) \ \ entry = perf_trace_buf_alloc(__entry_size, &__regs, &rctx); \ if (!entry) \ - return; \ + goto out; \ \ perf_fetch_caller_regs(__regs); \ \ @@ -68,6 +78,9 @@ perf_trace_##call(void *__data, proto) \ perf_trace_run_bpf_submit(entry, __entry_size, rctx, \ event_call, __count, __regs, \ head, __task); \ +out: \ + if (!rcu_watching) \ + rcu_irq_exit_irqson(); \ } /*