summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKent Overstreet <kent.overstreet@gmail.com>2018-11-24 18:27:16 -0500
committerKent Overstreet <kent.overstreet@gmail.com>2018-12-27 11:38:34 -0500
commit443bca45d2cc5563f25d4d943942eab721250100 (patch)
tree724ffde791b123fc9adf3cf2523edda5f9059ce2
parent917826ea208cbe991fe98a49d56cf33bd7600c50 (diff)
bcachefs: drop bogus percpu_ref_tryget
caller should already be guarding against rw, and checking here breaks when caller needs to finish updates for going RO
-rw-r--r--fs/bcachefs/btree_update_interior.c8
1 files changed, 1 insertions, 7 deletions
diff --git a/fs/bcachefs/btree_update_interior.c b/fs/bcachefs/btree_update_interior.c
index 7b6766659f3f..6fc4b9b5b575 100644
--- a/fs/bcachefs/btree_update_interior.c
+++ b/fs/bcachefs/btree_update_interior.c
@@ -561,7 +561,6 @@ static void bch2_btree_update_free(struct btree_update *as)
closure_debug_destroy(&as->cl);
mempool_free(as, &c->btree_interior_update_pool);
- percpu_ref_put(&c->writes);
closure_wake_up(&c->btree_interior_update_wait);
mutex_unlock(&c->btree_interior_update_lock);
@@ -1011,14 +1010,9 @@ bch2_btree_update_start(struct bch_fs *c, enum btree_id id,
struct btree_reserve *reserve;
struct btree_update *as;
- if (unlikely(!percpu_ref_tryget(&c->writes)))
- return ERR_PTR(-EROFS);
-
reserve = bch2_btree_reserve_get(c, nr_nodes, flags, cl);
- if (IS_ERR(reserve)) {
- percpu_ref_put(&c->writes);
+ if (IS_ERR(reserve))
return ERR_CAST(reserve);
- }
as = mempool_alloc(&c->btree_interior_update_pool, GFP_NOIO);
memset(as, 0, sizeof(*as));