Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp866987pxu; Sun, 25 Oct 2020 20:12:10 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwf40OLt5/zQd/OpxeS4TK6qPMK+x+MCd5zesREXWAjH2VI18nB+5hzrtItblIif805CuL6 X-Received: by 2002:a17:906:8401:: with SMTP id n1mr13336110ejx.215.1603681930593; Sun, 25 Oct 2020 20:12:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603681930; cv=none; d=google.com; s=arc-20160816; b=FYVuzZOrc89vRQSV6msc8aJ6J90aw0XU5zVgSn20eLVcuWNHHRqQ2g6B1fufvCEs3u Bt5gw5zq65ER35r3xrux2nsd593MPi/e6TYilfNE4+V7icxFcgHMaMHLum/LyVCXwC4X svYyZu/6L7xgUa+Nda42SM57t2QLI1Y5JFc9ZvVqIDRLROkV1cnfBXW5eM3BayKdfyz0 bzldI0ZkeEPR7VYccbAC5/jIPZB7qSyVk5/yDx0S7ZV0ipfyHh9eMuyBy6awDfAibHPp JsjpChwOEZ25h+5D911LjuaJ8LSTxOCTUkWzDoUYYh4astXrs0Hb1Vs3iZia6l/EOnwq mWUw== 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:dkim-signature; bh=Wd5N67I5+irmfT7qXtPRdXDzr04HHmXNKiWBtQmdtf8=; b=EU1+HN4ozUIRvnJzZDHh0G+gH7+XjFPImarFRxt++J/ij2/X/syHgNy+WctXKHAUrm VfMeJOdLwyaU8Xdyymxht2lvcCYqpyGcKWvQL+xxu7/2jDTIS1zSGnCCOP90Uhjp8+RY wM3rwi5LdlKaR/CdVrhIFuIYlG7gvsfGl+1+luaw6PN0rnHQtjbY/B+SdgWc3qSYTToc d4tZePVrPVy2IbXocHpXjqjbrjtTQTT47YXReQ4bt/PSstiL41xJqzMRIn1sGMjOHxgA nvdLHEsBPXfeA+gtLODR03VVI3gy/JOMU31VXbf/7XFd0ti43Gnlr3dbdACDXjuDdOji xfSg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=0eBEDMPe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id da5si7906166edb.261.2020.10.25.20.11.48; Sun, 25 Oct 2020 20:12:10 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=0eBEDMPe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S1420938AbgJZAvC (ORCPT + 99 others); Sun, 25 Oct 2020 20:51:02 -0400 Received: from mail.kernel.org ([198.145.29.99]:44910 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2393433AbgJZAvC (ORCPT ); Sun, 25 Oct 2020 20:51:02 -0400 Received: from localhost (unknown [176.177.109.29]) (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 11C2F2225C; Mon, 26 Oct 2020 00:51:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1603673461; bh=AcS6PXAs1RZnOH5u61roMZctAoVNQhD1wmdMA5GBS50=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=0eBEDMPe64ba02woGUtqblEyg57p7Ytfubf2gkufw+aSENX3XiHywL1o3TSncWKc7 weaJD6R+wHyFj+UiECF5OFy+wqWNFlNMT7WWHXdfLqLugCHpy3HYCTtMygYZV7Jsf+ DEVMhDZIk1/ckoWiurGfLv41YtI+ISw2i6Xb27N8= Date: Mon, 26 Oct 2020 01:50:58 +0100 From: Frederic Weisbecker To: "Joel Fernandes (Google)" Cc: linux-kernel@vger.kernel.org, Josh Triplett , Lai Jiangshan , Marco Elver , Mathieu Desnoyers , "Paul E. McKenney" , rcu@vger.kernel.org, Steven Rostedt , "Uladzislau Rezki (Sony)" , fweisbec@gmail.com, neeraj.iitr10@gmail.com Subject: Re: [PATCH v8 2/6] rcu/segcblist: Add counters to segcblist datastructure Message-ID: <20201026005058.GB104441@lothringen> References: <20201021190813.3005054-1-joel@joelfernandes.org> <20201021190813.3005054-3-joel@joelfernandes.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20201021190813.3005054-3-joel@joelfernandes.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Oct 21, 2020 at 03:08:09PM -0400, Joel Fernandes (Google) wrote: > bool rcu_segcblist_accelerate(struct rcu_segcblist *rsclp, unsigned long seq) > { > - int i; > + int i, j; > > WARN_ON_ONCE(!rcu_segcblist_is_enabled(rsclp)); > if (rcu_segcblist_restempty(rsclp, RCU_DONE_TAIL)) > @@ -487,6 +508,10 @@ bool rcu_segcblist_accelerate(struct rcu_segcblist *rsclp, unsigned long seq) > if (rcu_segcblist_restempty(rsclp, i) || ++i >= RCU_NEXT_TAIL) > return false; > > + /* Accounting: everything below i is about to get merged into i. */ > + for (j = i + 1; j <= RCU_NEXT_TAIL; j++) > + rcu_segcblist_move_seglen(rsclp, j, i); > + Can you perhaps reuse the below loop to move the seglen? Thanks. > /* > * Merge all later callbacks, including newly arrived callbacks, > * into the segment located by the for-loop above. Assign "seq"