Commit 06ab86d5 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Fix btree_node_write_blocked() not being cleared

The btree_node_write_blocked bit was a later addition to this code,
it only mirrors the state of the b->write_blocked list (empty or
nonempty) - unfortunately, when it was added it wasn't correctly kept in
sync - oops.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 434b1c75
...@@ -161,6 +161,7 @@ static void __btree_node_free(struct bch_fs *c, struct btree *b) ...@@ -161,6 +161,7 @@ static void __btree_node_free(struct bch_fs *c, struct btree *b)
{ {
trace_and_count(c, btree_node_free, c, b); trace_and_count(c, btree_node_free, c, b);
BUG_ON(btree_node_write_blocked(b));
BUG_ON(btree_node_dirty(b)); BUG_ON(btree_node_dirty(b));
BUG_ON(btree_node_need_write(b)); BUG_ON(btree_node_need_write(b));
BUG_ON(b == btree_node_root(c, b)); BUG_ON(b == btree_node_root(c, b));
...@@ -807,6 +808,7 @@ static void btree_update_updated_node(struct btree_update *as, struct btree *b) ...@@ -807,6 +808,7 @@ static void btree_update_updated_node(struct btree_update *as, struct btree *b)
BUG_ON(as->mode != BTREE_INTERIOR_NO_UPDATE); BUG_ON(as->mode != BTREE_INTERIOR_NO_UPDATE);
BUG_ON(!btree_node_dirty(b)); BUG_ON(!btree_node_dirty(b));
BUG_ON(!b->c.level);
as->mode = BTREE_INTERIOR_UPDATING_NODE; as->mode = BTREE_INTERIOR_UPDATING_NODE;
as->b = b; as->b = b;
...@@ -976,6 +978,7 @@ static void bch2_btree_interior_update_will_free_node(struct btree_update *as, ...@@ -976,6 +978,7 @@ static void bch2_btree_interior_update_will_free_node(struct btree_update *as,
clear_btree_node_dirty_acct(c, b); clear_btree_node_dirty_acct(c, b);
clear_btree_node_need_write(b); clear_btree_node_need_write(b);
clear_btree_node_write_blocked(b);
/* /*
* Does this node have unwritten data that has a pin on the journal? * Does this node have unwritten data that has a pin on the journal?
......
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