Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp221603rwb; Mon, 26 Sep 2022 17:40:29 -0700 (PDT) X-Google-Smtp-Source: AMsMyM5o5fSnWMaFN8wPn+h05ZA0liIgcIyK/migON+mHKYyViEW92vXaiGr6yP7lSVelw2r17Xv X-Received: by 2002:a17:907:2c54:b0:77d:971f:be12 with SMTP id hf20-20020a1709072c5400b0077d971fbe12mr19743589ejc.560.1664239229197; Mon, 26 Sep 2022 17:40:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1664239229; cv=none; d=google.com; s=arc-20160816; b=y9i6Idl03AAUwAODNju6Q8fe5h+qMWWajiBJfe8RaopwX3X4zTkJtuHCZQgf4xKR0g jkm26qySB1R4NLwguMLqR53wOx98OfalxCEV6DKT0uOwXJHOTICh2CDx1Da4pCKG/K+q pPEfnCdaSADmZfP4W+vfsnB5n3U1qW2pmLl/BorJ3zYahmJAhTLWvhOcw6HY3z7RxMUu P/BVXEjL6/FH/N+HT2vaNpFCVdSz4jzweIzF4OGPOsf+FdTzMIFq68WODi7Zwn/q96gr 8AkzkuucoW3L1imXzPsqKjVWKQPXCMKOzLmfLKpvDK0+2VJkvXQrwY7NDF717OCqXogo nPJw== 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-transfer-encoding :content-disposition:mime-version:references:reply-to:message-id :subject:cc:to:from:date:dkim-signature; bh=8S9Kj0XpD8SbajNueoPVsup23b29AamYuYFh7O4r/aw=; b=QxAGnbKigFuANO9TgUdrD0ZgQIjGul441yxfKv2DefwNBadI/Y4IrXxFp7KvuOzE4K s3LT9tq6m6DeUEfNbBbLuMydWphWOJyfg+BHkU3LfesqJwWIW6ic9czaZL7UTY2of9tj S9kcpMFpY3N22Ekwh/8L0UgfU9EsrZhySj7tXFjNF3Vy0Vl3gKVrf5CcLDhznMTgyF/J /8QlDuGPiHGRydf3gQ617ZIcpBMlgVZlIyxEACL7pR+sHEUEHAfXoKqRjfBSDJ8XVE7l mwMmadDJOZVE/eRuq1EYsGylHK2pPhSFyMv3e43H9ssAH1moAQZBc9tbCg8zukQh5Kik uboA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=HJtmuFa5; 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=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hb16-20020a170907161000b00782ee59ad7fsi1703955ejc.977.2022.09.26.17.40.03; Mon, 26 Sep 2022 17:40:29 -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=@kernel.org header.s=k20201202 header.b=HJtmuFa5; 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=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229488AbiIZXyB (ORCPT + 99 others); Mon, 26 Sep 2022 19:54:01 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52060 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229544AbiIZXx5 (ORCPT ); Mon, 26 Sep 2022 19:53:57 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CEBE99413F; Mon, 26 Sep 2022 16:53:53 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id EB2986116E; Mon, 26 Sep 2022 23:53:52 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 55594C433C1; Mon, 26 Sep 2022 23:53:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1664236432; bh=ss+RqrDvxS78Z81A4zz/FrOgTm3pJNYbCSgCQe3jqMQ=; h=Date:From:To:Cc:Subject:Reply-To:References:In-Reply-To:From; b=HJtmuFa5U1ojMu53aKK7Qqg4UNfWqfRDr9q/Lsiwle74FCdTJKk8ysoF8JKAD0HhO EuM/wBt1WOYJnbRwzGQbKOOS3HOQuWYtRAuAWv6ECwZFE6EgwNRTV+zQJr4cy6L8yp kZFWb4/nwTCxnrUc/fsbVT5EqFR0rZCrlXlb7YJe749meCkCfFFfSel2tQAAWMSnCy F3B9HcrJZvGGM4KKfH/W0nnSOtEhL2nzPyN117T/sSeSfQCEmPTLmYut7/m/DW3rfL 1i0Ca2YoIEobg0qCY0ih7t3t9oCr208U7TlHtvkUN6tdh6NbyPOWhbd6tNjDlSXGaj P/H4iuPx9J+yw== Received: by paulmck-ThinkPad-P17-Gen-1.home (Postfix, from userid 1000) id 02B6F5C0BE3; Mon, 26 Sep 2022 16:53:52 -0700 (PDT) Date: Mon, 26 Sep 2022 16:53:51 -0700 From: "Paul E. McKenney" To: Joel Fernandes Cc: rcu@vger.kernel.org, linux-kernel@vger.kernel.org, rushikesh.s.kadam@intel.com, urezki@gmail.com, neeraj.iitr10@gmail.com, frederic@kernel.org, rostedt@goodmis.org Subject: Re: [PATCH v6 1/4] rcu: Make call_rcu() lazy to save power Message-ID: <20220926235351.GC4196@paulmck-ThinkPad-P17-Gen-1> Reply-To: paulmck@kernel.org References: <20220926223751.GZ4196@paulmck-ThinkPad-P17-Gen-1> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: X-Spam-Status: No, score=-7.2 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS 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 On Mon, Sep 26, 2022 at 07:33:17PM -0400, Joel Fernandes wrote: > > > > On Sep 26, 2022, at 6:37 PM, Paul E. McKenney wrote: > > > > On Mon, Sep 26, 2022 at 09:07:12PM +0000, Joel Fernandes wrote: > >> Hi Paul, > >> > >> On Mon, Sep 26, 2022 at 10:42:40AM -0700, Paul E. McKenney wrote: > >> [..] > >>>>>>>> + WRITE_ONCE(rdp->lazy_len, 0); > >>>>>>>> + } else { > >>>>>>>> + rcu_cblist_flush_enqueue(&rcl, &rdp->nocb_bypass, rhp); > >>>>>>>> + WRITE_ONCE(rdp->lazy_len, 0); > >>>>>>> > >>>>>>> This WRITE_ONCE() can be dropped out of the "if" statement, correct? > >>>>>> > >>>>>> Yes will update. > >>>>> > >>>>> Thank you! > >>>>> > >>>>>>> If so, this could be an "if" statement with two statements in its "then" > >>>>>>> clause, no "else" clause, and two statements following the "if" statement. > >>>>>> > >>>>>> I don’t think we can get rid of the else part but I’ll see what it looks like. > >>>>> > >>>>> In the function header, s/rhp/rhp_in/, then: > >>>>> > >>>>> struct rcu_head *rhp = rhp_in; > >>>>> > >>>>> And then: > >>>>> > >>>>> if (lazy && rhp) { > >>>>> rcu_cblist_enqueue(&rdp->nocb_bypass, rhp); > >>>>> rhp = NULL; > >>>> > >>>> This enqueues on to the bypass list, where as if lazy && rhp, I want to queue > >>>> the new rhp on to the main cblist. So the pseudo code in my patch is: > >>>> > >>>> if (lazy and rhp) then > >>>> 1. flush bypass CBs on to main list. > >>>> 2. queue new CB on to main list. > >>> > >>> And the difference is here, correct? I enqueue to the bypass list, > >>> which is then flushed (in order) to the main list. In contrast, you > >>> flush the bypass list, then enqueue to the main list. Either way, > >>> the callback referenced by rhp ends up at the end of ->cblist. > >>> > >>> Or am I on the wrong branch of this "if" statement? > >> > >> But we have to flush first, and then queue the new one. Otherwise wouldn't > >> the callbacks be invoked out of order? Or did I miss something? > > > > I don't think so... > > > > We want the new callback to be last, right? One way to do that is to > > flush the bypass, then queue the new callback onto ->cblist. Another way > > to do that is to enqueue the new callback onto the end of the bypass, > > then flush the bypass. Why wouldn't these result in the same order? > > Yes you are right, sorry. I was fixated on the main list. Both your snippet and my patch will be equivalent then. However I find your snippet a bit confusing, as in it is not immediately obvious - why would we queue something on to a list, if we were about to flush it. But any way, it does make it a clever piece of code in some sense and I am ok with doing it this way ;-) As long as the ->cblist.len comes out with the right value. ;-) Thanx, Paul > Thanks, > > - Joel > > > > > >>>> else > >>>> 1. flush bypass CBs on to main list > >>>> 2. queue new CB on to bypass list. > >>>> > >>>>> } > >>>>> rcu_cblist_flush_enqueue(&rcl, &rdp->nocb_bypass, rhp); > >>>>> WRITE_ONCE(rdp->lazy_len, 0); > >>>>> > >>>>> Or did I mess something up? > >>>> > >>>> So the rcu_cblist_flush_enqueue() has to happen before the > >>>> rcu_cblist_enqueue() to preserve the ordering of flushing into the main list, > >>>> and queuing on to the main list for the "if". Where as in your snip, the > >>>> order is reversed. > >>> > >>> Did I pick the correct branch of the "if" statement above? Or were you > >>> instead talking about the "else" clause? > >>> > >>> I would have been more worried about getting cblist->len right. > >> > >> Hmm, I think my concern was more the ordering of callbacks, and moving the > >> write to length should be Ok. > > > > OK, sounds good to me! ;-) > > > >>>> If I consolidate it then, it looks like the following. However, it is a bit > >>>> more unreadable. I could instead just take the WRITE_ONCE out of both if/else > >>>> and move it to after the if/else, that would be cleanest. Does that sound > >>>> good to you? Thanks! > >>> > >>> Let's first figure out whether or not we are talking past one another. ;-) > >> > >> Haha yeah :-) > > > > So were we? ;-) > > > > Thanx, Paul