Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp5258949iog; Wed, 22 Jun 2022 15:54:07 -0700 (PDT) X-Google-Smtp-Source: AGRyM1uajs7i+C8fH/ChHJfRGA5SFgKxLxAnUzP3cKCSfSuIoE4RA31dN9vZkmWWIe5QdBokYaD2 X-Received: by 2002:a05:6402:32a2:b0:435:8b5a:4081 with SMTP id f34-20020a05640232a200b004358b5a4081mr6962921eda.232.1655938446969; Wed, 22 Jun 2022 15:54:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655938446; cv=none; d=google.com; s=arc-20160816; b=OMLPKs1jMP0gmRCadcl5BGhLR7XJUb+Cv3QrOgEoWilCAnqnsUu7g6m9IsKBsJZYSV AFF7xEhFkviqRIaJe9jlgNI7jhc/N10eh/SdDG2+W/rHnuaY4R/E5cZeQsI2o6pSOwvm FJwp/vC3J2Lu9m+M2ZIfDiXQypQswo9IAY4dDrzYLn5N3f6MraKhYV019I7yjMLecXmx SdXlrxGlO1rhBS0lSsjQLQnWzPbtI9croaRC7sQe3Fr6k8RaYabQNsTv3qZ9BYHuDZh9 axrvitIfK+CciqNqzwKWTkBS67n2nh5cLOh2OyogPf6GbCQ0V4wDu9CKtUeeSmApNHfa rYnw== 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=tZ2VmzE2lHGW4TDS5ibElbKctouxZ1GAoFxv9DWSNFQ=; b=NyOcj5BrJrTFq4NtWIETh6p80B9dj82ps9KuYWv7b/MfF7XqZQ4pspCvRD3PhJY/NZ mRNfKpy+JD/zDzxQdQ8tss82zJX6neVj2R9Hy379YbC7J0BO9EbxX7BFc8LFgfvenRKD BRtiutYZ8Yqx1tQYJPUzCEhtbgdmjRHSyzP7oV9KUBxDgeZ1CbmpgsT1Z+9fLkIbRTHs vDCqMlCfHMVNaVk0MHqWrUd79XTKe/4+RQHczq65Om29byIZYOvwhV+B6BgtBrYzdWcA ZX0mKHTTEf/ti1ym5VoNHopQhp4n5FXMa8HImgXdw8JD2iU4jhv/aMQWGNgTW/vRWxOA jYcA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=uAvtO1wT; 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 c28-20020a1709063f1c00b00722e89ba02bsi1170505ejj.736.2022.06.22.15.53.42; Wed, 22 Jun 2022 15:54:06 -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=uAvtO1wT; 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 S1359847AbiFVWvx (ORCPT + 99 others); Wed, 22 Jun 2022 18:51:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45630 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345645AbiFVWvp (ORCPT ); Wed, 22 Jun 2022 18:51:45 -0400 Received: from mail-qv1-xf2f.google.com (mail-qv1-xf2f.google.com [IPv6:2607:f8b0:4864:20::f2f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DDBB740A3E for ; Wed, 22 Jun 2022 15:51:43 -0700 (PDT) Received: by mail-qv1-xf2f.google.com with SMTP id y14so22113329qvs.10 for ; Wed, 22 Jun 2022 15:51:43 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=tZ2VmzE2lHGW4TDS5ibElbKctouxZ1GAoFxv9DWSNFQ=; b=uAvtO1wTymA1OKGzMjhdAg4Xrl4FVIKHWotoJraXcn07le/b0XJ7l01X76a8WK4Q90 kmUbwQlNMXoi/6t3IXkCKFj3BN/t49X5NpYdWKYhWTCqUvfHy+wkYe934MhNMPgDiTFa hN6xqJX72Ktoan5doV3c3TtrMl4Bo7T3X2iuo= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=tZ2VmzE2lHGW4TDS5ibElbKctouxZ1GAoFxv9DWSNFQ=; b=BSXZ3NpuKo4reGTLj93kvrgXuUBwAjG/cyUd3VbUqQyezACXSXu6VjIGQmUNNxLi+W Udu1JtINVlI7mVjM/lkNMGyELGHMQi6AowGZg6KpMS4zCo2sRRkn/VTqhHwN57Kgbb+S /Ap9okn7vrMDXtm33rnHcB5LLCyfo1a22MslsXQdJGCxaq0XwetRbGOz1lg9mS7IhKhA KW/lf/d3H/UHNrw1ICX0LFRjF8vNoyerOBOCOyH8k4Tv7407PYj17fmGEyHGb8udnAk+ NMNDXBSvWFbyAAP1+nBGIZlemsbjB1euY+IpqoHfafcFstX2p/OvF8closmDtnHJ6s43 wKRg== X-Gm-Message-State: AJIora/N6QQmnt6BoPuknDoBEGYExGm0/reNni37bXfn33eqmQfE9/CI PJWs3F9BDHk8yiq643ujOKo+yQ== X-Received: by 2002:a05:6214:f08:b0:470:519a:168a with SMTP id gw8-20020a0562140f0800b00470519a168amr9962716qvb.29.1655938303002; Wed, 22 Jun 2022 15:51:43 -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 k66-20020a37a145000000b006ab91fd03fasm1794022qke.19.2022.06.22.15.51.41 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 22 Jun 2022 15:51:42 -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, vineeth@bitbyteword.org, Joel Fernandes Subject: [PATCH v2 2/8] rcu: shrinker for lazy rcu Date: Wed, 22 Jun 2022 22:50:56 +0000 Message-Id: <20220622225102.2112026-4-joel@joelfernandes.org> X-Mailer: git-send-email 2.37.0.rc0.104.g0611611a94-goog In-Reply-To: <20220622225102.2112026-1-joel@joelfernandes.org> References: <20220622225102.2112026-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,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 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/rcu_segcblist.h | 14 +++++++++-- kernel/rcu/tree_nocb.h | 48 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 60 insertions(+), 2 deletions(-) diff --git a/kernel/rcu/rcu_segcblist.h b/kernel/rcu/rcu_segcblist.h index c3d7de65b689..cf71425dbb5e 100644 --- a/kernel/rcu/rcu_segcblist.h +++ b/kernel/rcu/rcu_segcblist.h @@ -15,16 +15,26 @@ static inline long rcu_cblist_n_cbs(struct rcu_cblist *rclp) return READ_ONCE(rclp->len); } +#ifdef CONFIG_RCU_LAZY /* Return number of callbacks in the specified callback list. */ static inline long rcu_cblist_n_lazy_cbs(struct rcu_cblist *rclp) { -#ifdef CONFIG_RCU_LAZY return READ_ONCE(rclp->lazy_len); +} + +static inline void rcu_cblist_reset_lazy_len(struct rcu_cblist *rclp) +{ + WRITE_ONCE(rclp->lazy_len, 0); +} #else +static inline long rcu_cblist_n_lazy_cbs(struct rcu_cblist *rclp) +{ return 0; -#endif } +static inline void rcu_cblist_reset_lazy_len(struct rcu_cblist *rclp) {} +#endif + /* Return number of callbacks in segmented callback list by summing seglen. */ long rcu_segcblist_n_segment_cbs(struct rcu_segcblist *rsclp); diff --git a/kernel/rcu/tree_nocb.h b/kernel/rcu/tree_nocb.h index b9244f22e102..2f5da12811a5 100644 --- a/kernel/rcu/tree_nocb.h +++ b/kernel/rcu/tree_nocb.h @@ -1207,6 +1207,51 @@ 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 += rcu_cblist_n_lazy_cbs(&rdp->nocb_bypass); + } + + 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 = rcu_cblist_n_lazy_cbs(&rdp->nocb_bypass); + if (_count == 0) + continue; + rcu_nocb_lock_irqsave(rdp, flags); + rcu_cblist_reset_lazy_len(&rdp->nocb_bypass); + 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; @@ -1244,6 +1289,9 @@ void __init rcu_init_nohz(void) if (!rcu_state.nocb_is_setup) return; + if (register_shrinker(&lazy_rcu_shrinker)) + pr_err("Failed to register lazy_rcu shrinker!\n"); + #if defined(CONFIG_NO_HZ_FULL) if (tick_nohz_full_running) cpumask_or(rcu_nocb_mask, rcu_nocb_mask, tick_nohz_full_mask); -- 2.37.0.rc0.104.g0611611a94-goog