Received: by 2002:a05:6358:45e:b0:b5:b6eb:e1f9 with SMTP id 30csp1267632rwe; Thu, 1 Sep 2022 15:43:59 -0700 (PDT) X-Google-Smtp-Source: AA6agR73bqG3LJ/8o5tYf5pVUHK+cMU3+y263bsjD1GI+c+fXVz6NL6GQI4UBwNO258ROpRK2q/X X-Received: by 2002:a17:907:6096:b0:73d:9d12:4b04 with SMTP id ht22-20020a170907609600b0073d9d124b04mr25724979ejc.745.1662072239354; Thu, 01 Sep 2022 15:43:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662072239; cv=none; d=google.com; s=arc-20160816; b=le4QJu1RFpDW4tFBhHPHILCTMpGnch/mKxohgIuTpwAcl680/2avH8zbDVowausaDp B7Px4TRI3Rv5G7+5Ii38PszBOsTWkmeS67BecAfKR2+OIlWOKzFcWZPBup3rmIO/P0n3 ZjQGNQThyU/S6TplwEjo5lOIAGvEjWV8aWGfj/eoBKUmZH+1kqFa8lOvxGxdSBBkF6Hb 6oEpeXrDMUlSjD7l2D8+hLyoh1ScTbaEP8ZPo+36QsSP8VnmrN3hEEX2i3NTdGDh3TzO b9aByryhTKVgQmVEu6yLGrCtH3YCvP1DLPHrKeH0L+qYODdXaa2lfH04SJsDMHNEvW0J 70gw== 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=5Y5kbAl2ZL0hvyMP3+b8/GM5tIuNKa2oHKBHOOJke14=; b=ed48+Z1i3H69IldEU1O6MaRmKpOM3iWZCl4zbi+WTuY8hzMtOY6M6HyoGXRRbag1o7 Y0jt5caGkczm85KgG40ee06P4YJ8PABAYP0kw/6S3S+s0+ZfZc98jxieUnEjGzquyXW+ U1fXKiMb2qMW01BCLpDtUGLlTMKz6vOhCSNhM3mLLALEhEjPW2PB9azeJ8syfqgvAVjW x26IKFJEir5X3ZUil48QlCx8A1Q8d8d2vjX6LCDLBsDSxovqCUzRMC7AH6T3KS5826tl HkwEfmrDF1Xu3ONXcSCUrEZseUvul4ntWxXxPflJaTRVnn0b3Khmsy13FJBWaJRpWfoK lAzg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b="DLk0B/+K"; 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 m30-20020a50d7de000000b00447c97a309csi274081edj.169.2022.09.01.15.43.33; Thu, 01 Sep 2022 15:43:59 -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="DLk0B/+K"; 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 S234906AbiIAWSh (ORCPT + 99 others); Thu, 1 Sep 2022 18:18:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45804 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234587AbiIAWSD (ORCPT ); Thu, 1 Sep 2022 18:18:03 -0400 Received: from mail-qv1-xf31.google.com (mail-qv1-xf31.google.com [IPv6:2607:f8b0:4864:20::f31]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AB987580B6 for ; Thu, 1 Sep 2022 15:18:02 -0700 (PDT) Received: by mail-qv1-xf31.google.com with SMTP id y17so171048qvr.5 for ; Thu, 01 Sep 2022 15:18:02 -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=5Y5kbAl2ZL0hvyMP3+b8/GM5tIuNKa2oHKBHOOJke14=; b=DLk0B/+Kjl2sEDnaJ5HNoOkF5QFsAHl3d/WO0kQdWt7MwUX6E9cr00jSheEW6r0ohh eKqnQ2mBJFjJ3kK0CphbuerOCVjht107mlZlGLAxmmWEJQT3dq2Zm0nFUcX0KPUZ68Qt UbZiWOQ9CWe4p662dEMWk9EB4AQrJh0Qr8MdY= 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=5Y5kbAl2ZL0hvyMP3+b8/GM5tIuNKa2oHKBHOOJke14=; b=vsdCds4KjKjgaxmU56IoN113fLi8jlVQnywXEG3e/fpeb1rSIabf/n3S3SNcSKFVE0 e5FpdSZaPpB7gaqigU2pnIVnlyBJnAfTm74aF7g1dk9Wb3WENwGuekMV/DoZ/+ikg2xM Zp0Yv6ClLlmJhL/R18xeEAugCmoQUaodgviizowNrySOEzdi28NrLnPIf/KFh+bRmjLG VoH0AVHT7FZG4dVuDCDmmG55+WgtOfviBd8y0V6NULKbj4XjoqwwV9QsTIkk0fjnE+19 e9aG5wEsnl5PCCx88HQ2sj0KuyQKgstB7pf9ZowHblD4Dhb9T87U2oZQ3eCp4pJcGHk4 2KIw== X-Gm-Message-State: ACgBeo05EFOFiG/riAM3MtXsHq5YXYfc24GGv4yGlTEb9EZGAt++cAwn zWBzsJK0wnC60kmnuohrQFFeQg== X-Received: by 2002:ad4:5bc2:0:b0:499:2c2c:1b0b with SMTP id t2-20020ad45bc2000000b004992c2c1b0bmr4677172qvt.115.1662070682335; Thu, 01 Sep 2022 15:18:02 -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 s16-20020ac85290000000b0034305a91aaesm11060794qtn.83.2022.09.01.15.18.01 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 01 Sep 2022 15:18:01 -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, boqun.feng@gmail.com, Joel Fernandes Subject: [PATCH v5 07/18] rcu: shrinker for lazy rcu Date: Thu, 1 Sep 2022 22:17:09 +0000 Message-Id: <20220901221720.1105021-8-joel@joelfernandes.org> X-Mailer: git-send-email 2.37.2.789.g6183377224-goog In-Reply-To: <20220901221720.1105021-1-joel@joelfernandes.org> References: <20220901221720.1105021-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/tree_nocb.h | 52 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) diff --git a/kernel/rcu/tree_nocb.h b/kernel/rcu/tree_nocb.h index 7e97a7b6e046..560ba87911c5 100644 --- a/kernel/rcu/tree_nocb.h +++ b/kernel/rcu/tree_nocb.h @@ -1333,6 +1333,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; @@ -1367,6 +1416,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 defined(CONFIG_NO_HZ_FULL) if (tick_nohz_full_running) cpumask_or(rcu_nocb_mask, rcu_nocb_mask, tick_nohz_full_mask); -- 2.37.2.789.g6183377224-goog