Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp3678393rwb; Mon, 3 Oct 2022 20:08:13 -0700 (PDT) X-Google-Smtp-Source: AMsMyM5kQccFGHaNSgIHE49/xaVj7Phmkk7hQ0ie97z5MnCluaTofEZKE0U75GIB5rk9PE2ZlxP+ X-Received: by 2002:a17:907:78a:b0:782:2223:a7cd with SMTP id xd10-20020a170907078a00b007822223a7cdmr17227022ejb.532.1664852893614; Mon, 03 Oct 2022 20:08:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1664852893; cv=none; d=google.com; s=arc-20160816; b=OL7nkaC0Fqj0eCSlJukIC2KQL7CpscSPbapLq3quihUXzo0xcvj9vrIQjdwyX+z2SH SoonnDN7nHgEFFNlACDbbv1APuA2XRb/2lmK9MrTi+fB9cqzbwgih5qCEsKiuxlMClMg jU6sthpIGpeHMn99L8bH1xXR19VV17Cx81hiZ/TJEFG9WQvEE2EjSE/ar8iGMTWbyP2A fjdxIeOsefGyGXyJ0FrGGnhScIZUlyLfAsotVoElmQlsieCTDkR7KmluKeo1lcqpqMLp Gb5cuBcLRRNBtEqq6DZAeiv+V7kJl1dJwI7Y2SNYT9BY85cws/nmIkqA4+CzjMGeyHas +4MA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=aIQWgogL70KBeJErO0exnOrlpnBgvI8Xk7BtYbAB+wo=; b=cRL4EhgS7Fkuj8Kqm3O6PptQkJalbXOdc4spWsBAi2n5RAbELC++coY2v7RJi0j8uU Jikhi0gfdfGTyltC74WUHqMvkXGQLanjYHhUXBWBy1lIsPI0Jh2xNp5MaWZYPyoec/lW wyXe5gCozrWXA1hk6tFtQxSU9OCcO9By40iiqwkO9irTjdu4xrpG2z5lzJATjhicWYgO v1feOQecTrrsPlhhtit1a6IddV5HY937U32jnWzASrPJSg8n62f3hQ9Jk0VkByg3aMOa 1z+V5GxcMMuWI7fgxIBWxeB7XE3kx3oq6TYfarfYG01RcwUO0JDQ+vHjulgOL1kUVkTI Oz/Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=jQNACJXo; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hq22-20020a1709073f1600b0078a76811e33si7099043ejc.408.2022.10.03.20.07.48; Mon, 03 Oct 2022 20:08:13 -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=@joelfernandes.org header.s=google header.b=jQNACJXo; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229866AbiJDCmp (ORCPT + 99 others); Mon, 3 Oct 2022 22:42:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54606 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229790AbiJDCmZ (ORCPT ); Mon, 3 Oct 2022 22:42:25 -0400 Received: from mail-qv1-xf2e.google.com (mail-qv1-xf2e.google.com [IPv6:2607:f8b0:4864:20::f2e]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 54CDC20BF0 for ; Mon, 3 Oct 2022 19:42:23 -0700 (PDT) Received: by mail-qv1-xf2e.google.com with SMTP id g9so4220764qvo.12 for ; Mon, 03 Oct 2022 19:42:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date; bh=aIQWgogL70KBeJErO0exnOrlpnBgvI8Xk7BtYbAB+wo=; b=jQNACJXowFiDkPWD7+EFcZtDHi/hgxEROq6hvkGBx1hTz4J0GkRV3isC2wHPBb3ykG OEPa3FVqr30DpKZJ9uUX+TB2RBrtEF5ezf848U0JO51ZQ13+JEgDkAqDFyuYJ548qpfm TyIUrbvtIsFy2uZtb+/9GPClszwiWCMz2zxJ0= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date; bh=aIQWgogL70KBeJErO0exnOrlpnBgvI8Xk7BtYbAB+wo=; b=CxwDu4i1trkxkJm72Z6viU+nuozRfUgMEIUtuM/c+9p9GFu3wAzqlBn1PJ5DG9LZny w0zN8pqD3ZzMgnqy0rvDyiX0zVICqAUvPyrxVE1RMI37U/xYeowNlkoC+wrivc0eBCh0 qVOBOi6nQ7m/LjD1xkBIOncggQEDz1q8vec/SEDMjJ/P7dWiflmK9ycoBOlFTw/GuAia 0cahIuQRIb1P9El67Y1CUq+PMUao3lAObAu9U6g/jql5eBnEEckE6f66D0aFhfe5LAYv LAuYAFUYLwL+a/FLyNzdNPlOpYmkX4esVBZsbQcuJjZibYzmi3iVyEwXscom2T6SOpFY Ybsw== X-Gm-Message-State: ACrzQf1NBZhE5aQ5rp0qt1SFkigdH2a4M1JDrzqSPBon+900DF+WoJtH zK//MS1yRQiyfHc9UU+KyhRBew== X-Received: by 2002:a0c:c684:0:b0:4af:a08c:f4c7 with SMTP id d4-20020a0cc684000000b004afa08cf4c7mr18006438qvj.91.1664851342486; Mon, 03 Oct 2022 19:42:22 -0700 (PDT) Received: from joelboxx.c.googlers.com.com (228.221.150.34.bc.googleusercontent.com. [34.150.221.228]) by smtp.gmail.com with ESMTPSA id 1-20020ac85901000000b0035cf5edefa6sm11793875qty.56.2022.10.03.19.42.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 03 Oct 2022 19:42:22 -0700 (PDT) From: "Joel Fernandes (Google)" To: rcu@vger.kernel.org Cc: linux-kernel@vger.kernel.org, rushikesh.s.kadam@intel.com, urezki@gmail.com, neeraj.iitr10@gmail.com, frederic@kernel.org, paulmck@kernel.org, rostedt@goodmis.org, youssefesmat@google.com, surenb@google.com, Vineeth Pillai , Joel Fernandes Subject: [PATCH v7 04/11] rcu: shrinker for lazy rcu Date: Tue, 4 Oct 2022 02:41:50 +0000 Message-Id: <20221004024157.2470238-5-joel@joelfernandes.org> X-Mailer: git-send-email 2.38.0.rc1.362.ged0d419d3c-goog In-Reply-To: <20221004024157.2470238-1-joel@joelfernandes.org> References: <20221004024157.2470238-1-joel@joelfernandes.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS autolearn=unavailable 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 From: Vineeth Pillai The shrinker is used to speed up the free'ing of memory potentially held by RCU lazy callbacks. RCU kernel module test cases show this to be effective. Test is introduced in a later patch. Signed-off-by: Vineeth Pillai Signed-off-by: Joel Fernandes (Google) --- kernel/rcu/tree_nocb.h | 52 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) diff --git a/kernel/rcu/tree_nocb.h b/kernel/rcu/tree_nocb.h index dfa736da68ab..0162aa10f9e4 100644 --- a/kernel/rcu/tree_nocb.h +++ b/kernel/rcu/tree_nocb.h @@ -1313,6 +1313,55 @@ int rcu_nocb_cpu_offload(int cpu) } EXPORT_SYMBOL_GPL(rcu_nocb_cpu_offload); +static unsigned long +lazy_rcu_shrink_count(struct shrinker *shrink, struct shrink_control *sc) +{ + int cpu; + unsigned long count = 0; + + /* Snapshot count of all CPUs */ + for_each_possible_cpu(cpu) { + struct rcu_data *rdp = per_cpu_ptr(&rcu_data, cpu); + + count += READ_ONCE(rdp->lazy_len); + } + + return count ? count : SHRINK_EMPTY; +} + +static unsigned long +lazy_rcu_shrink_scan(struct shrinker *shrink, struct shrink_control *sc) +{ + int cpu; + unsigned long flags; + unsigned long count = 0; + + /* Snapshot count of all CPUs */ + for_each_possible_cpu(cpu) { + struct rcu_data *rdp = per_cpu_ptr(&rcu_data, cpu); + int _count = READ_ONCE(rdp->lazy_len); + + if (_count == 0) + continue; + rcu_nocb_lock_irqsave(rdp, flags); + WRITE_ONCE(rdp->lazy_len, 0); + rcu_nocb_unlock_irqrestore(rdp, flags); + wake_nocb_gp(rdp, false); + sc->nr_to_scan -= _count; + count += _count; + if (sc->nr_to_scan <= 0) + break; + } + return count ? count : SHRINK_STOP; +} + +static struct shrinker lazy_rcu_shrinker = { + .count_objects = lazy_rcu_shrink_count, + .scan_objects = lazy_rcu_shrink_scan, + .batch = 0, + .seeks = DEFAULT_SEEKS, +}; + void __init rcu_init_nohz(void) { int cpu; @@ -1343,6 +1392,9 @@ void __init rcu_init_nohz(void) if (!rcu_state.nocb_is_setup) return; + if (register_shrinker(&lazy_rcu_shrinker, "rcu-lazy")) + pr_err("Failed to register lazy_rcu shrinker!\n"); + if (!cpumask_subset(rcu_nocb_mask, cpu_possible_mask)) { pr_info("\tNote: kernel parameter 'rcu_nocbs=', 'nohz_full', or 'isolcpus=' contains nonexistent CPUs.\n"); cpumask_and(rcu_nocb_mask, cpu_possible_mask, -- 2.38.0.rc1.362.ged0d419d3c-goog