Thread (67 messages) 67 messages, 4 authors, 2023-07-29

Re: [PATCH v3 15/49] nfs: dynamically allocate the nfs-acl shrinker

From: Qi Zheng <hidden>
Date: 2023-07-27 09:16:54
Also in: dm-devel, dri-devel, kvm, linux-arm-msm, linux-bcache, linux-btrfs, linux-ext4, linux-f2fs-devel, linux-fsdevel, linux-mm, linux-nfs, linux-raid, linux-xfs, lkml, rcu, xen-devel


On 2023/7/27 16:04, Qi Zheng wrote:
quoted hunk ↗ jump to hunk
Use new APIs to dynamically allocate the nfs-acl shrinker.

Signed-off-by: Qi Zheng <redacted>
Reviewed-by: Muchun Song <redacted>
---
  fs/nfs/super.c | 20 ++++++++++++--------
  1 file changed, 12 insertions(+), 8 deletions(-)
diff --git a/fs/nfs/super.c b/fs/nfs/super.c
index 2284f749d892..072d82e1be06 100644
--- a/fs/nfs/super.c
+++ b/fs/nfs/super.c
@@ -129,11 +129,7 @@ static void nfs_ssc_unregister_ops(void)
  }
  #endif /* CONFIG_NFS_V4_2 */
  
-static struct shrinker acl_shrinker = {
-	.count_objects	= nfs_access_cache_count,
-	.scan_objects	= nfs_access_cache_scan,
-	.seeks		= DEFAULT_SEEKS,
-};
+static struct shrinker *acl_shrinker;
  
  /*
   * Register the NFS filesystems
@@ -153,9 +149,17 @@ int __init register_nfs_fs(void)
  	ret = nfs_register_sysctl();
  	if (ret < 0)
  		goto error_2;
-	ret = register_shrinker(&acl_shrinker, "nfs-acl");
-	if (ret < 0)
+
+	acl_shrinker = shrinker_alloc(0, "nfs-acl");
+	if (!acl_shrinker)
  		goto error_3;
Here should set ret to -ENOMEM, will fix.
quoted hunk ↗ jump to hunk
+
+	acl_shrinker->count_objects = nfs_access_cache_count;
+	acl_shrinker->scan_objects = nfs_access_cache_scan;
+	acl_shrinker->seeks = DEFAULT_SEEKS;
+
+	shrinker_register(acl_shrinker);
+
  #ifdef CONFIG_NFS_V4_2
  	nfs_ssc_register_ops();
  #endif
@@ -175,7 +179,7 @@ int __init register_nfs_fs(void)
   */
  void __exit unregister_nfs_fs(void)
  {
-	unregister_shrinker(&acl_shrinker);
+	shrinker_free(acl_shrinker);
  	nfs_unregister_sysctl();
  	unregister_nfs4_fs();
  #ifdef CONFIG_NFS_V4_2
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help