[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[PATCH v2 17/47] rcu: dynamically allocate the rcu-lazy shrinker



Use new APIs to dynamically allocate the rcu-lazy shrinker.

Signed-off-by: Qi Zheng <zhengqi.arch@xxxxxxxxxxxxx>
---
 kernel/rcu/tree_nocb.h | 19 +++++++++++--------
 1 file changed, 11 insertions(+), 8 deletions(-)

diff --git a/kernel/rcu/tree_nocb.h b/kernel/rcu/tree_nocb.h
index 43229d2b0c44..919f17561733 100644
--- a/kernel/rcu/tree_nocb.h
+++ b/kernel/rcu/tree_nocb.h
@@ -1397,12 +1397,7 @@ lazy_rcu_shrink_scan(struct shrinker *shrink, struct 
shrink_control *sc)
        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,
-};
+static struct shrinker *lazy_rcu_shrinker;
 #endif // #ifdef CONFIG_RCU_LAZY
 
 void __init rcu_init_nohz(void)
@@ -1436,8 +1431,16 @@ void __init rcu_init_nohz(void)
                return;
 
 #ifdef CONFIG_RCU_LAZY
-       if (register_shrinker(&lazy_rcu_shrinker, "rcu-lazy"))
-               pr_err("Failed to register lazy_rcu shrinker!\n");
+       lazy_rcu_shrinker = shrinker_alloc(0, "rcu-lazy");
+       if (!lazy_rcu_shrinker) {
+               pr_err("Failed to allocate lazy_rcu shrinker!\n");
+       } else {
+               lazy_rcu_shrinker->count_objects = lazy_rcu_shrink_count;
+               lazy_rcu_shrinker->scan_objects = lazy_rcu_shrink_scan;
+               lazy_rcu_shrinker->seeks = DEFAULT_SEEKS;
+
+               shrinker_register(lazy_rcu_shrinker);
+       }
 #endif // #ifdef CONFIG_RCU_LAZY
 
        if (!cpumask_subset(rcu_nocb_mask, cpu_possible_mask)) {
-- 
2.30.2




 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.