Commit a7dc10ce authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Make sure allocation failure errors are logged

The previous patch fixed a bug in allocation path error handling, and it
would've been noticed sooner had it been logged properly.

Generally speaking, errors that shouldn't happen in normal operation and
are being returned up the stack should be logged: the write path was
already logging IO errors, but non IO errors were missed.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 548673f8
...@@ -326,6 +326,12 @@ do { \ ...@@ -326,6 +326,12 @@ do { \
bch_err(_c, "%s(): error %s", __func__, bch2_err_str(_ret));\ bch_err(_c, "%s(): error %s", __func__, bch2_err_str(_ret));\
} while (0) } while (0)
#define bch_err_fn_ratelimited(_c, _ret) \
do { \
if (should_print_err(_ret)) \
bch_err_ratelimited(_c, "%s(): error %s", __func__, bch2_err_str(_ret));\
} while (0)
#define bch_err_msg(_c, _ret, _msg, ...) \ #define bch_err_msg(_c, _ret, _msg, ...) \
do { \ do { \
if (should_print_err(_ret)) \ if (should_print_err(_ret)) \
......
...@@ -1190,6 +1190,9 @@ bch2_btree_update_start(struct btree_trans *trans, struct btree_path *path, ...@@ -1190,6 +1190,9 @@ bch2_btree_update_start(struct btree_trans *trans, struct btree_path *path,
return as; return as;
err: err:
bch2_btree_update_free(as, trans); bch2_btree_update_free(as, trans);
if (!bch2_err_matches(ret, ENOSPC) &&
!bch2_err_matches(ret, EROFS))
bch_err_fn_ratelimited(c, ret);
return ERR_PTR(ret); return ERR_PTR(ret);
} }
......
...@@ -418,6 +418,8 @@ static void bch2_update_unwritten_extent(struct btree_trans *trans, ...@@ -418,6 +418,8 @@ static void bch2_update_unwritten_extent(struct btree_trans *trans,
continue; continue;
} }
bch_err_fn_ratelimited(c, ret);
if (ret) if (ret)
return; return;
......
...@@ -61,7 +61,7 @@ int bch2_extent_fallocate(struct btree_trans *trans, ...@@ -61,7 +61,7 @@ int bch2_extent_fallocate(struct btree_trans *trans,
*/ */
ret = bch2_disk_reservation_get(c, &disk_res, sectors, new_replicas, 0); ret = bch2_disk_reservation_get(c, &disk_res, sectors, new_replicas, 0);
if (unlikely(ret)) if (unlikely(ret))
goto err; goto err_noprint;
bch2_bkey_buf_reassemble(&old, c, k); bch2_bkey_buf_reassemble(&old, c, k);
} }
...@@ -125,7 +125,12 @@ int bch2_extent_fallocate(struct btree_trans *trans, ...@@ -125,7 +125,12 @@ int bch2_extent_fallocate(struct btree_trans *trans,
err: err:
if (!ret && sectors_allocated) if (!ret && sectors_allocated)
bch2_increment_clock(c, sectors_allocated, WRITE); bch2_increment_clock(c, sectors_allocated, WRITE);
if (should_print_err(ret))
bch_err_inum_offset_ratelimited(c,
inum.inum,
iter->pos.offset << 9,
"%s(): error: %s", __func__, bch2_err_str(ret));
err_noprint:
bch2_open_buckets_put(c, &open_buckets); bch2_open_buckets_put(c, &open_buckets);
bch2_disk_reservation_put(c, &disk_res); bch2_disk_reservation_put(c, &disk_res);
bch2_bkey_buf_exit(&new, c); bch2_bkey_buf_exit(&new, c);
......
...@@ -1463,6 +1463,10 @@ static void __bch2_write(struct bch_write_op *op) ...@@ -1463,6 +1463,10 @@ static void __bch2_write(struct bch_write_op *op)
op->flags |= BCH_WRITE_DONE; op->flags |= BCH_WRITE_DONE;
if (ret < 0) { if (ret < 0) {
bch_err_inum_offset_ratelimited(c,
op->pos.inode,
op->pos.offset << 9,
"%s(): error: %s", __func__, bch2_err_str(ret));
op->error = ret; op->error = ret;
break; break;
} }
......
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