Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp763679ybh; Sat, 18 Jul 2020 21:09:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxJvXUaMn815WQ/fqIKYiZoJJwqWra/oiXH/NyUZTi44YXP03nLZpQDXvlkLTP4SnZRWIes X-Received: by 2002:a05:6402:b1a:: with SMTP id bm26mr15725494edb.144.1595131768700; Sat, 18 Jul 2020 21:09:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595131768; cv=none; d=google.com; s=arc-20160816; b=Hyo3AfjgCEMxv3N6D+XD2r/JTOzyCoNBtvy4pE9M/WM2geTy96u7I+OFB0YusJqRvd gRw/vDOHs1DLd+lg5Gy1LI5wmm1819yHhKhKwofzrhrlHlC5dEoyIJ0DUrIyQ6N1mba1 tBk3257F4lIRj5TYNYwcgVMnDGGka/7P+uM6h2SNam1zpy5Oi5FaM4V5NZlwF1AdM+qg WzmSX9wFSUPDhxwrYOL7I2H7qDKR+HPsZF7fjOqyon3DQyS5Ur9bDCPK1nKCTfnxKCLd BIvuWoWN2N4NoGuSrHhn7KvkRHgE3AZHNHK/tK+SLePg7ry/C3yG+OELeb5rfoFGOu14 fAng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=ihKeSQeLv7BBxInfCJI8ZRk0YjhCHk5lYGDi1OJs57k=; b=plJn3LIWGSWUPFmLIxLD1QyQkX0evCG+BpOoWJqwrkA4dEe2MP9sL9yWR+guDHbfWV +s+MrTal7cxbjWEChBUvQw3vxF8zv31ujeyaeK1ARuqWKezx74v39cwaqaoaFyIfhwai edNQsxqW+5ol6H4pUuEwlAJVdpkW/3Kl8T7mAA9SYspqEYVCgG7Uu21KUeWATxwhP+/I 0vK27ILMWhDAmLzejfnnjrBxfqaoBASz09MtVMFxP3E1gZKpAMt5Wc2yTbWdqjW6eoeT g7MY3ZorlAaL3rgEOLH8Y8HhN7Vbj5QDusg7NVroT3KLfnGz3AaZkkgnno60uSyWHawO bfog== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=YN+yV8+9; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p2si7924986edj.167.2020.07.18.21.09.02; Sat, 18 Jul 2020 21:09:28 -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=@joelfernandes.org header.s=google header.b=YN+yV8+9; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725812AbgGSEGk (ORCPT + 99 others); Sun, 19 Jul 2020 00:06:40 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50836 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725272AbgGSEGk (ORCPT ); Sun, 19 Jul 2020 00:06:40 -0400 Received: from mail-io1-xd43.google.com (mail-io1-xd43.google.com [IPv6:2607:f8b0:4864:20::d43]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 11E6CC0619D4 for ; Sat, 18 Jul 2020 21:06:40 -0700 (PDT) Received: by mail-io1-xd43.google.com with SMTP id v8so14313829iox.2 for ; Sat, 18 Jul 2020 21:06:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=ihKeSQeLv7BBxInfCJI8ZRk0YjhCHk5lYGDi1OJs57k=; b=YN+yV8+92VHbOUHL0HTyo5JNlm0zk+zZ0D57uInpIH9RnDoAIgBQIeKKdSuXadAb3/ qeA9TZEqiX/maRX4jLkStfPgYILKEI3eedN9CJXP991d15Qnhgwdm9R3rpXGoRQGd8XK q6UcbKVbPO726Dsdu1TyHnYDmNQzOMwUlYUAM= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=ihKeSQeLv7BBxInfCJI8ZRk0YjhCHk5lYGDi1OJs57k=; b=ImdIaZdZ/WsVBtRAu2iFsq53iMTCEWXHMVkYfIbKosRoK5ilOT+Ep+/tBORY79sxmk Y+hu0jQslM8BwY65weztt7GrllSNXMNDjzj9w4GBth4g/WcZZQrv0rSbrOhh7+Dsogb1 o34Vrwa25WWUbdOQ8XpQXde9H6Gz6BZUwJ0dNxeyA4mb1oXVfaiHIz1BaBxT2yz2pCLh zmmOAsVO/tK9CxUUcALlnZB31/XaCXGp34NepZB9YB0fRwDX6qDqZP3QtXHUTbkWqNJB cVHd6Nd8+URVwGmmzveVjNiLicxt6K2YFzFihFq0FnNfI9PdJ+JIMh/iQmV3KkOqdkgk l3tw== X-Gm-Message-State: AOAM532fB5LIcWH3L6Yhd5WiHDe6w8zVMTOeKc1OdJi/p0PW89erUIe4 /iaOQHZAn1fvhiUAcIBCgHZu4aLKh/JacZ/eOmRBKgWCCqA= X-Received: by 2002:a05:6638:1504:: with SMTP id b4mr16212035jat.23.1595131599242; Sat, 18 Jul 2020 21:06:39 -0700 (PDT) MIME-Version: 1.0 References: <20200719035518.2386828-1-joel@joelfernandes.org> In-Reply-To: <20200719035518.2386828-1-joel@joelfernandes.org> From: Joel Fernandes Date: Sun, 19 Jul 2020 00:06:28 -0400 Message-ID: Subject: Re: [PATCH RFC v2] rcu/segcblist: Add counters to segcblist datastructure To: LKML Cc: Josh Triplett , Lai Jiangshan , Mathieu Desnoyers , "Paul E. McKenney" , rcu , Steven Rostedt Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Jul 18, 2020 at 11:55 PM Joel Fernandes (Google) wrote: [...] > /* If no callbacks moved, nothing more need be done. */ > @@ -419,10 +494,9 @@ void rcu_segcblist_advance(struct rcu_segcblist *rsclp, unsigned long seq) > * callbacks. The overall effect is to copy down the later pointers > * into the gap that was created by the now-ready segments. > */ > - for (j = RCU_WAIT_TAIL; i < RCU_NEXT_TAIL; i++, j++) { > - if (rsclp->tails[j] == rsclp->tails[RCU_NEXT_TAIL]) > - break; /* No more callbacks. */ > + for (j = RCU_WAIT_TAIL; i < RCU_NEXT_TAIL && j < RCU_NEXT_TAIL; i++, j++) { > WRITE_ONCE(rsclp->tails[j], rsclp->tails[i]); > + rcu_segcblist_move_seglen(rsclp, i, j); > rsclp->gp_seq[j] = rsclp->gp_seq[i]; > } Unfortunately I broke this code, _sigh_. I need to reinstate the if (rsclp->tails[j] == rsclp->tails[RCU_NEXT_TAIL]) , I completely misunderstood that.