summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKent Overstreet <kent.overstreet@gmail.com>2019-03-31 18:40:01 -0400
committerKent Overstreet <kent.overstreet@gmail.com>2019-03-31 18:59:59 -0400
commit6fdc6fa2042fe18c2eda508a4335e3d7b80b4e23 (patch)
treeefa53f9bc901a1724822d9df892f45e8bb49a422
parent107f74d3ce6cf2aa685c8b336d57fc469801e4d3 (diff)
bcachefs: fix bch2_trans_unlock()
-rw-r--r--fs/bcachefs/btree_iter.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/fs/bcachefs/btree_iter.c b/fs/bcachefs/btree_iter.c
index bbf6d17355ba..ef0d058dc9a9 100644
--- a/fs/bcachefs/btree_iter.c
+++ b/fs/bcachefs/btree_iter.c
@@ -1704,7 +1704,7 @@ void bch2_trans_preload_iters(struct btree_trans *trans)
static int btree_trans_iter_alloc(struct btree_trans *trans)
{
- unsigned idx = ffz(trans->iters_linked);
+ unsigned idx = __ffs64(~trans->iters_linked);
if (idx < trans->nr_iters)
goto got_slot;
@@ -1869,17 +1869,17 @@ void *bch2_trans_kmalloc(struct btree_trans *trans,
int bch2_trans_unlock(struct btree_trans *trans)
{
- unsigned iters = trans->iters_linked;
+ u64 iters = trans->iters_linked;
int ret = 0;
while (iters) {
- unsigned idx = __ffs(iters);
+ unsigned idx = __ffs64(iters);
struct btree_iter *iter = &trans->iters[idx];
ret = ret ?: btree_iter_err(iter);
__bch2_btree_iter_unlock(iter);
- iters ^= 1 << idx;
+ iters ^= 1ULL << idx;
}
return ret;