Commit 943f9946 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Don't quash error in bch2_bucket_alloc_set_trans()

We were incorrectly returning -BCH_ERR_insufficient_devices when we'd
received a different error from bch2_bucket_alloc_trans(), which
(erronously) turns into -EROFS further up the call chain.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 685e0f0c
...@@ -671,7 +671,7 @@ static int bch2_bucket_alloc_set_trans(struct btree_trans *trans, ...@@ -671,7 +671,7 @@ static int bch2_bucket_alloc_set_trans(struct btree_trans *trans,
bch2_dev_alloc_list(c, stripe, devs_may_alloc); bch2_dev_alloc_list(c, stripe, devs_may_alloc);
unsigned dev; unsigned dev;
struct bch_dev *ca; struct bch_dev *ca;
int ret = 0; int ret = -BCH_ERR_insufficient_devices;
unsigned i; unsigned i;
BUG_ON(*nr_effective >= nr_replicas); BUG_ON(*nr_effective >= nr_replicas);
...@@ -701,8 +701,8 @@ static int bch2_bucket_alloc_set_trans(struct btree_trans *trans, ...@@ -701,8 +701,8 @@ static int bch2_bucket_alloc_set_trans(struct btree_trans *trans,
bch2_dev_stripe_increment(ca, stripe); bch2_dev_stripe_increment(ca, stripe);
percpu_ref_put(&ca->ref); percpu_ref_put(&ca->ref);
ret = PTR_ERR_OR_ZERO(ob); if (IS_ERR(ob)) {
if (ret) { ret = PTR_ERR(ob);
if (bch2_err_matches(ret, BCH_ERR_transaction_restart) || cl) if (bch2_err_matches(ret, BCH_ERR_transaction_restart) || cl)
break; break;
continue; continue;
...@@ -711,14 +711,11 @@ static int bch2_bucket_alloc_set_trans(struct btree_trans *trans, ...@@ -711,14 +711,11 @@ static int bch2_bucket_alloc_set_trans(struct btree_trans *trans,
add_new_bucket(c, ptrs, devs_may_alloc, add_new_bucket(c, ptrs, devs_may_alloc,
nr_effective, have_cache, flags, ob); nr_effective, have_cache, flags, ob);
if (*nr_effective >= nr_replicas) if (*nr_effective >= nr_replicas) {
ret = 0;
break; break;
} }
}
if (*nr_effective >= nr_replicas)
ret = 0;
else if (!ret)
ret = -BCH_ERR_insufficient_devices;
return ret; return ret;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment