Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp5060946iog; Wed, 22 Jun 2022 11:08:08 -0700 (PDT) X-Google-Smtp-Source: AGRyM1uRSAMAIm/gxPpAcviVO+A1lKKBPj5kFZ0EwaOCe4q6HIE5u/jpDzn6ftzrLQV9YwTpjIED X-Received: by 2002:a63:1e1d:0:b0:401:a251:767e with SMTP id e29-20020a631e1d000000b00401a251767emr3947744pge.26.1655921287934; Wed, 22 Jun 2022 11:08:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655921287; cv=none; d=google.com; s=arc-20160816; b=HsAy/VA08Os4WIhl6KKvJtF9yzWr6y5NXSHrpAQHIwyLNq+LxfNqhcAv1KKg7ED/es VI+gzTcqPctxhuI9Th8peY8M0e69jZVZe1spnRFXQ1MRFr/umgDW5CFnf5FQ/jE/MGYN Fb3S7Z7LlpBO48XT2th8QxL4adFljPmndUdOnA6fMCgOdzDJYwcAX9N5c7MVDaB+CNOk +rUZRM5lpQOuqGSmYkII2a2XhE0G/amD8cOWLXxjjDhlV3LQDpFm97cfLm6XX/x91F+e 8LOL4eOUz41kmCbyzZHaUQC+pmUkUvEemoGPyTdtmUHXPvnqko/wjCM0huOwxykQjIQJ mVzA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:feedback-id :dkim-signature; bh=1FM/ZQ8a2ZHSH54UjftXe1OE1A5MBWIZme5bKp0p2VU=; b=meQ9eZE36gnV2YMhX49v7fC4KCRKrxTdnmHZD5ntXit3lvzqmIybKIKNyq3A+ebrsP G2wdqvTtPYW9qnxXThGL/GaVaIglVoGrjEzkYIRxpxX89m/YtLUIkyL2L3JuTfxSs2t6 bFn8Vyo7qYumJ5a9WpB3WhDf3ZID91o5HgRbK2iSKwRRTkKp/2em/YQ8UlhUHVbPZV2Q prNUfqISBnhrKKY0681ITEtW5+oEVrBTNepO3SlyqfSi+Ad8qnu+KhCVOrUPejl8UYQw zCgyMHUI/Al7+AL0kMh2Ag+lTrrdz+9jeaUsEnZZUvIRGMlpwgru6NL4/GErq3E0NDAt C3kg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=ltYQlE+u; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id l16-20020a635710000000b0040c8a3cab3esi16886055pgb.638.2022.06.22.11.07.54; Wed, 22 Jun 2022 11:08:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=ltYQlE+u; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1359139AbiFVR0R (ORCPT + 99 others); Wed, 22 Jun 2022 13:26:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34634 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1376536AbiFVR0O (ORCPT ); Wed, 22 Jun 2022 13:26:14 -0400 Received: from mail-qv1-xf2a.google.com (mail-qv1-xf2a.google.com [IPv6:2607:f8b0:4864:20::f2a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E3EE12A40D; Wed, 22 Jun 2022 10:26:13 -0700 (PDT) Received: by mail-qv1-xf2a.google.com with SMTP id i17so19482037qvo.13; Wed, 22 Jun 2022 10:26:13 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=feedback-id:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=1FM/ZQ8a2ZHSH54UjftXe1OE1A5MBWIZme5bKp0p2VU=; b=ltYQlE+ufZavWCAouqv1TW9vS56tCbDMQa++jPKFWEYtLWl8ACUnL4k9uEPqHBwUGW prvthkK9L28PzIv7uXjkM8v9wnCRyuNu3ya1KX8RCk7AGR44NdOpW1iGvCqcrR9IE1Zc yKhRnFv0idELEytDZVBPvlL1N2TMZvfD+Opj4QFBqCoker1VfDii6c2MwaIyeN+Rdy5N MjC1ZlFmPSL2yJsOM7OBZn6+E4ZaTQW462yg/kfOblDH7yt2wX97oEx64jDPvyfZ25JI Y9sjBjql49LnSHTlysm8ZzP1V3fW/3A0nN4ykHiKviQ/uvr62VgPwy0EP/fSWok1K8gP ix4w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:feedback-id:date:from:to:cc:subject:message-id :references:mime-version:content-disposition:in-reply-to; bh=1FM/ZQ8a2ZHSH54UjftXe1OE1A5MBWIZme5bKp0p2VU=; b=NNXrMMtiAAx1o/sIb9gfasGm0wlRUGVM5PJiKGmn5S7h2yH+V42pjHgi5JJsXir2Il Q5bQ9L2iFsgsFHcsk1jfvaDa/vmPLoNsBi8Erh6mmgrDFGWAYG6BK08oKF7l1/jQ1OLj Lyp3nJq1SD1e9XIVqUCHdtKgm3nMr+DjkGKLlFeo1QdzSmw66FwOy0cVeoSrH8zMeDSI H+uTMYrWVkz6+hrZGXB5VRe0cT9RGghhCvACvc37msbNp2t7iHaTYhpbIu2D/x0diNSS 7GcEEvgGERJCxoLmnidcNVGw4sSW1QzJGXZMVZFvvmYT+jp4PHYWTLygtovsdaA7qbtP d/2Q== X-Gm-Message-State: AJIora8jAVu2xsMZvijPTlQuZl00Kzlu3N2w6h4/lntLcUqIxrzMd4QZ mK2W7oqEQ9sVyQCiTjpd26Q= X-Received: by 2002:ac8:5ad1:0:b0:305:864:2eb0 with SMTP id d17-20020ac85ad1000000b0030508642eb0mr3941296qtd.168.1655918772862; Wed, 22 Jun 2022 10:26:12 -0700 (PDT) Received: from auth1-smtp.messagingengine.com (auth1-smtp.messagingengine.com. [66.111.4.227]) by smtp.gmail.com with ESMTPSA id bi20-20020a05620a319400b006a6dcd92eb3sm16277571qkb.121.2022.06.22.10.26.11 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 22 Jun 2022 10:26:12 -0700 (PDT) Received: from compute4.internal (compute4.nyi.internal [10.202.2.44]) by mailauth.nyi.internal (Postfix) with ESMTP id B91F027C0054; Wed, 22 Jun 2022 13:26:11 -0400 (EDT) Received: from mailfrontend2 ([10.202.2.163]) by compute4.internal (MEProxy); Wed, 22 Jun 2022 13:26:11 -0400 X-ME-Sender: X-ME-Received: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgedvfedrudefhedguddufecutefuodetggdotefrod ftvfcurfhrohhfihhlvgemucfhrghsthforghilhdpqfgfvfdpuffrtefokffrpgfnqfgh necuuegrihhlohhuthemuceftddtnecunecujfgurhepfffhvfevuffkfhggtggujgesth dtrodttddtvdenucfhrhhomhepuehoqhhunhcuhfgvnhhguceosghoqhhunhdrfhgvnhhg sehgmhgrihhlrdgtohhmqeenucggtffrrghtthgvrhhnpeeitdefvefhteeklefgtefhge elkeefffelvdevhfehueektdevhfettddvteevvdenucevlhhushhtvghrufhiiigvpedt necurfgrrhgrmhepmhgrihhlfhhrohhmpegsohhquhhnodhmvghsmhhtphgruhhthhhpvg hrshhonhgrlhhithihqdeiledvgeehtdeigedqudejjeekheehhedvqdgsohhquhhnrdhf vghngheppehgmhgrihhlrdgtohhmsehfihigmhgvrdhnrghmvg X-ME-Proxy: Feedback-ID: iad51458e:Fastmail Received: by mail.messagingengine.com (Postfix) with ESMTPA; Wed, 22 Jun 2022 13:26:11 -0400 (EDT) Date: Wed, 22 Jun 2022 10:25:59 -0700 From: Boqun Feng To: Zqiang Cc: paulmck@kernel.org, frederic@kernel.org, rcu@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] rcu: Add exp QS check in rcu_exp_handler() for no-preemptible expedited RCU Message-ID: References: <20220622103549.2840087-1-qiang1.zhang@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20220622103549.2840087-1-qiang1.zhang@intel.com> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On Wed, Jun 22, 2022 at 06:35:49PM +0800, Zqiang wrote: > In CONFIG_PREEMPT=n and CONFIG_PREEMPT_COUNT=y kernel, after a exp > grace period begins, if detected current CPU enters idle in > rcu_exp_handler() IPI handler, will immediately report the exp QS of the > current cpu, at this time, maybe not being in an RCU read-side critical > section, but need wait until rcu-softirq or sched-clock irq or sched-switch > occurs on current CPU to check and report exp QS. > I think the idea is OK, however, this "optimization" is based on the implementation detail that rcu_read_lock() counts preempt_count when CONFIG_PREEMPT_COUNT=y, right? It's a little bit dangerous because the preempt_count when CONFIG_PREEMPT_COUNT=y and CONFIG_PREEMPT=n is mostly for debugging purposes IIUC, and in other words, _it could be gone_. Also I'm not aware of any but there could be someone assuming that RCU read-side critical sections can be formed without rcu_read_{lock,unlock}() in CONFIG_PREEMPT=n kernel. For example, there might be "creative" code like the following: void do_something_only_in_nonpreempt(void) { int *p; // This function only gets called in PREEMPT=n kernel, // which means everywhere is a RCU read-side critical // section, let's save some lines of code. p = rcu_dereference_check(gp, !IS_ENABLED(PREEMPT)); ... // of course no schedule() here. } Again, I'm not aware of any existing code that does this but we need to be sure. Regards, Boqun > This commit add a exp QS check in rcu_exp_handler(), when not being > in an RCU read-side critical section, report exp QS earlier. > > Signed-off-by: Zqiang > --- > kernel/rcu/tree_exp.h | 5 ++++- > 1 file changed, 4 insertions(+), 1 deletion(-) > > diff --git a/kernel/rcu/tree_exp.h b/kernel/rcu/tree_exp.h > index be667583a554..34f08267410f 100644 > --- a/kernel/rcu/tree_exp.h > +++ b/kernel/rcu/tree_exp.h > @@ -828,11 +828,14 @@ static void rcu_exp_handler(void *unused) > { > struct rcu_data *rdp = this_cpu_ptr(&rcu_data); > struct rcu_node *rnp = rdp->mynode; > + bool preempt_bh_disabled = > + !!(preempt_count() & (PREEMPT_MASK | SOFTIRQ_MASK)); > > if (!(READ_ONCE(rnp->expmask) & rdp->grpmask) || > __this_cpu_read(rcu_data.cpu_no_qs.b.exp)) > return; > - if (rcu_is_cpu_rrupt_from_idle()) { > + if (rcu_is_cpu_rrupt_from_idle() || > + (IS_ENABLED(CONFIG_PREEMPT_COUNT) && !preempt_bh_disabled)) { > rcu_report_exp_rdp(this_cpu_ptr(&rcu_data)); > return; > } > -- > 2.25.1 >