Commit 82cf18f2 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Fix deadlock in journal replay

btree_key_can_insert_cached() should be checking the watermark -
BCH_TRANS_COMMIT_journal_replay really means nonblocking mode when
watermark < reclaim, it was being used incorrectly.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 4518e80a
...@@ -397,12 +397,13 @@ static int btree_key_can_insert_cached(struct btree_trans *trans, unsigned flags ...@@ -397,12 +397,13 @@ static int btree_key_can_insert_cached(struct btree_trans *trans, unsigned flags
struct bkey_cached *ck = (void *) path->l[0].b; struct bkey_cached *ck = (void *) path->l[0].b;
unsigned new_u64s; unsigned new_u64s;
struct bkey_i *new_k; struct bkey_i *new_k;
unsigned watermark = flags & BCH_WATERMARK_MASK;
EBUG_ON(path->level); EBUG_ON(path->level);
if (!test_bit(BKEY_CACHED_DIRTY, &ck->flags) && if (watermark < BCH_WATERMARK_reclaim &&
bch2_btree_key_cache_must_wait(c) && !test_bit(BKEY_CACHED_DIRTY, &ck->flags) &&
!(flags & BCH_TRANS_COMMIT_journal_reclaim)) bch2_btree_key_cache_must_wait(c))
return -BCH_ERR_btree_insert_need_journal_reclaim; return -BCH_ERR_btree_insert_need_journal_reclaim;
/* /*
......
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