summaryrefslogtreecommitdiffstats
path: root/fs/ceph/caps.c
diff options
context:
space:
mode:
authorChengguang Xu <cgxu519@icloud.com>2018-02-24 05:35:29 -0500
committerIlya Dryomov <idryomov@gmail.com>2018-04-02 04:12:46 -0400
commite327ce068518e38c0182739e879b9dce477c8d85 (patch)
treea727fff9856f7a0a6497c1425372056498cd4fc5 /fs/ceph/caps.c
parentb884014a91a49ed0e7198d276b28887cc48363bd (diff)
ceph: optimizing cap allocation
When setting high volume of caps_min_count or having many unreserved caps, unused caps may always keep in the ->caps_list even can't get new cap from kmem_cache_alloc because lack of maximum limitation of caps_avail_count. Hence reuse caps in ->caps_list if available, it's maybe better than setting max limitation of caps_avail_count and releasing unused caps when reaching the limit. Signed-off-by: Chengguang Xu <cgxu519@icloud.com> Reviewed-by: "Yan, Zheng" <zyan@redhat.com> Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
Diffstat (limited to 'fs/ceph/caps.c')
-rw-r--r--fs/ceph/caps.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/fs/ceph/caps.c b/fs/ceph/caps.c
index 1d02648788e3..421cdce71fb0 100644
--- a/fs/ceph/caps.c
+++ b/fs/ceph/caps.c
@@ -285,7 +285,23 @@ struct ceph_cap *ceph_get_cap(struct ceph_mds_client *mdsc,
285 mdsc->caps_use_count++; 285 mdsc->caps_use_count++;
286 mdsc->caps_total_count++; 286 mdsc->caps_total_count++;
287 spin_unlock(&mdsc->caps_list_lock); 287 spin_unlock(&mdsc->caps_list_lock);
288 } else {
289 spin_lock(&mdsc->caps_list_lock);
290 if (mdsc->caps_avail_count) {
291 BUG_ON(list_empty(&mdsc->caps_list));
292
293 mdsc->caps_avail_count--;
294 mdsc->caps_use_count++;
295 cap = list_first_entry(&mdsc->caps_list,
296 struct ceph_cap, caps_item);
297 list_del(&cap->caps_item);
298
299 BUG_ON(mdsc->caps_total_count != mdsc->caps_use_count +
300 mdsc->caps_reserve_count + mdsc->caps_avail_count);
301 }
302 spin_unlock(&mdsc->caps_list_lock);
288 } 303 }
304
289 return cap; 305 return cap;
290 } 306 }
291 307