Commit 5c1d808a authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Drop trans->nounlock

Since we're no longer doing btree node merging post commit, we can now
delete a bunch of code.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent b182ff60
...@@ -267,17 +267,12 @@ bool __bch2_btree_node_lock(struct btree *b, struct bpos pos, ...@@ -267,17 +267,12 @@ bool __bch2_btree_node_lock(struct btree *b, struct bpos pos,
*/ */
if (type == SIX_LOCK_intent && if (type == SIX_LOCK_intent &&
linked->nodes_locked != linked->nodes_intent_locked) { linked->nodes_locked != linked->nodes_intent_locked) {
if (!(trans->nounlock)) { linked->locks_want = max_t(unsigned,
linked->locks_want = max_t(unsigned, linked->locks_want,
linked->locks_want, __fls(linked->nodes_locked) + 1);
__fls(linked->nodes_locked) + 1); if (!btree_iter_get_locks(linked, true, false)) {
if (!btree_iter_get_locks(linked, true, false)) {
deadlock_iter = linked;
reason = 1;
}
} else {
deadlock_iter = linked; deadlock_iter = linked;
reason = 2; reason = 1;
} }
} }
...@@ -307,18 +302,13 @@ bool __bch2_btree_node_lock(struct btree *b, struct bpos pos, ...@@ -307,18 +302,13 @@ bool __bch2_btree_node_lock(struct btree *b, struct bpos pos,
* we're about to lock, it must have the ancestors locked too: * we're about to lock, it must have the ancestors locked too:
*/ */
if (level > __fls(linked->nodes_locked)) { if (level > __fls(linked->nodes_locked)) {
if (!(trans->nounlock)) { linked->locks_want =
linked->locks_want = max(level + 1, max_t(unsigned,
max(level + 1, max_t(unsigned, linked->locks_want,
linked->locks_want, iter->locks_want));
iter->locks_want)); if (!btree_iter_get_locks(linked, true, false)) {
if (!btree_iter_get_locks(linked, true, false)) {
deadlock_iter = linked;
reason = 5;
}
} else {
deadlock_iter = linked; deadlock_iter = linked;
reason = 6; reason = 5;
} }
} }
...@@ -441,30 +431,6 @@ bool __bch2_btree_iter_upgrade(struct btree_iter *iter, ...@@ -441,30 +431,6 @@ bool __bch2_btree_iter_upgrade(struct btree_iter *iter,
return false; return false;
} }
bool __bch2_btree_iter_upgrade_nounlock(struct btree_iter *iter,
unsigned new_locks_want)
{
unsigned l = iter->level;
EBUG_ON(iter->locks_want >= new_locks_want);
iter->locks_want = new_locks_want;
do {
if (!btree_iter_node(iter, l))
break;
if (!bch2_btree_node_upgrade(iter, l)) {
iter->locks_want = l;
return false;
}
l++;
} while (l < iter->locks_want);
return true;
}
void __bch2_btree_iter_downgrade(struct btree_iter *iter, void __bch2_btree_iter_downgrade(struct btree_iter *iter,
unsigned downgrade_to) unsigned downgrade_to)
{ {
...@@ -1046,7 +1012,7 @@ void bch2_btree_iter_node_drop(struct btree_iter *iter, struct btree *b) ...@@ -1046,7 +1012,7 @@ void bch2_btree_iter_node_drop(struct btree_iter *iter, struct btree *b)
trans_for_each_iter(iter->trans, linked) trans_for_each_iter(iter->trans, linked)
if (linked->l[level].b == b) { if (linked->l[level].b == b) {
__btree_node_unlock(linked, level); btree_node_unlock(linked, level);
linked->l[level].b = BTREE_ITER_NO_NODE_DROP; linked->l[level].b = BTREE_ITER_NO_NODE_DROP;
} }
} }
...@@ -2083,8 +2049,10 @@ struct btree_iter *__bch2_trans_get_iter(struct btree_trans *trans, ...@@ -2083,8 +2049,10 @@ struct btree_iter *__bch2_trans_get_iter(struct btree_trans *trans,
if (!(iter->flags & BTREE_ITER_INTENT)) if (!(iter->flags & BTREE_ITER_INTENT))
bch2_btree_iter_downgrade(iter); bch2_btree_iter_downgrade(iter);
else if (!iter->locks_want) else if (!iter->locks_want) {
__bch2_btree_iter_upgrade_nounlock(iter, 1); iter->locks_want = 1;
btree_iter_get_locks(iter, true, false);
}
bch2_btree_iter_set_pos(iter, pos); bch2_btree_iter_set_pos(iter, pos);
btree_iter_set_search_pos(iter, btree_iter_search_key(iter)); btree_iter_set_search_pos(iter, btree_iter_search_key(iter));
...@@ -2352,11 +2320,22 @@ bch2_btree_iter_node_to_text(struct printbuf *out, ...@@ -2352,11 +2320,22 @@ bch2_btree_iter_node_to_text(struct printbuf *out,
struct btree_bkey_cached_common *_b, struct btree_bkey_cached_common *_b,
enum btree_iter_type type) enum btree_iter_type type)
{ {
pr_buf(out, " %px l=%u %s:", pr_buf(out, " l=%u %s:",
_b, _b->level, bch2_btree_ids[_b->btree_id]); _b->level, bch2_btree_ids[_b->btree_id]);
bch2_bpos_to_text(out, btree_node_pos(_b, type)); bch2_bpos_to_text(out, btree_node_pos(_b, type));
} }
static bool trans_has_btree_nodes_locked(struct btree_trans *trans)
{
struct btree_iter *iter;
trans_for_each_iter(trans, iter)
if (btree_iter_type(iter) != BTREE_ITER_CACHED &&
iter->nodes_locked)
return true;
return false;
}
void bch2_btree_trans_to_text(struct printbuf *out, struct bch_fs *c) void bch2_btree_trans_to_text(struct printbuf *out, struct bch_fs *c)
{ {
#ifdef CONFIG_BCACHEFS_DEBUG #ifdef CONFIG_BCACHEFS_DEBUG
...@@ -2367,14 +2346,18 @@ void bch2_btree_trans_to_text(struct printbuf *out, struct bch_fs *c) ...@@ -2367,14 +2346,18 @@ void bch2_btree_trans_to_text(struct printbuf *out, struct bch_fs *c)
mutex_lock(&c->btree_trans_lock); mutex_lock(&c->btree_trans_lock);
list_for_each_entry(trans, &c->btree_trans_list, list) { list_for_each_entry(trans, &c->btree_trans_list, list) {
pr_buf(out, "%i %px %ps\n", trans->pid, trans, (void *) trans->ip); if (!trans_has_btree_nodes_locked(trans))
continue;
pr_buf(out, "%i %ps\n", trans->pid, (void *) trans->ip);
trans_for_each_iter(trans, iter) { trans_for_each_iter(trans, iter) {
if (!iter->nodes_locked) if (!iter->nodes_locked)
continue; continue;
pr_buf(out, " iter %u %s:", pr_buf(out, " iter %u %c %s:",
iter->idx, iter->idx,
btree_iter_type(iter) == BTREE_ITER_CACHED ? 'c' : 'b',
bch2_btree_ids[iter->btree_id]); bch2_btree_ids[iter->btree_id]);
bch2_bpos_to_text(out, iter->pos); bch2_bpos_to_text(out, iter->pos);
pr_buf(out, "\n"); pr_buf(out, "\n");
...@@ -2393,17 +2376,18 @@ void bch2_btree_trans_to_text(struct printbuf *out, struct bch_fs *c) ...@@ -2393,17 +2376,18 @@ void bch2_btree_trans_to_text(struct printbuf *out, struct bch_fs *c)
b = READ_ONCE(trans->locking); b = READ_ONCE(trans->locking);
if (b) { if (b) {
pr_buf(out, " locking iter %u l=%u %s:", iter = &trans->iters[trans->locking_iter_idx];
pr_buf(out, " locking iter %u %c l=%u %s:",
trans->locking_iter_idx, trans->locking_iter_idx,
btree_iter_type(iter) == BTREE_ITER_CACHED ? 'c' : 'b',
trans->locking_level, trans->locking_level,
bch2_btree_ids[trans->locking_btree_id]); bch2_btree_ids[trans->locking_btree_id]);
bch2_bpos_to_text(out, trans->locking_pos); bch2_bpos_to_text(out, trans->locking_pos);
pr_buf(out, " node "); pr_buf(out, " node ");
bch2_btree_iter_node_to_text(out, bch2_btree_iter_node_to_text(out,
(void *) b, (void *) b,
btree_iter_type(&trans->iters[trans->locking_iter_idx])); btree_iter_type(iter));
pr_buf(out, "\n"); pr_buf(out, "\n");
} }
} }
......
...@@ -116,7 +116,6 @@ bool bch2_trans_relock(struct btree_trans *); ...@@ -116,7 +116,6 @@ bool bch2_trans_relock(struct btree_trans *);
void bch2_trans_unlock(struct btree_trans *); void bch2_trans_unlock(struct btree_trans *);
bool __bch2_btree_iter_upgrade(struct btree_iter *, unsigned); bool __bch2_btree_iter_upgrade(struct btree_iter *, unsigned);
bool __bch2_btree_iter_upgrade_nounlock(struct btree_iter *, unsigned);
static inline bool bch2_btree_iter_upgrade(struct btree_iter *iter, static inline bool bch2_btree_iter_upgrade(struct btree_iter *iter,
unsigned new_locks_want) unsigned new_locks_want)
...@@ -124,9 +123,7 @@ static inline bool bch2_btree_iter_upgrade(struct btree_iter *iter, ...@@ -124,9 +123,7 @@ static inline bool bch2_btree_iter_upgrade(struct btree_iter *iter,
new_locks_want = min(new_locks_want, BTREE_MAX_DEPTH); new_locks_want = min(new_locks_want, BTREE_MAX_DEPTH);
return iter->locks_want < new_locks_want return iter->locks_want < new_locks_want
? (!iter->trans->nounlock ? __bch2_btree_iter_upgrade(iter, new_locks_want)
? __bch2_btree_iter_upgrade(iter, new_locks_want)
: __bch2_btree_iter_upgrade_nounlock(iter, new_locks_want))
: iter->uptodate <= BTREE_ITER_NEED_PEEK; : iter->uptodate <= BTREE_ITER_NEED_PEEK;
} }
......
...@@ -94,7 +94,7 @@ btree_lock_want(struct btree_iter *iter, int level) ...@@ -94,7 +94,7 @@ btree_lock_want(struct btree_iter *iter, int level)
return BTREE_NODE_UNLOCKED; return BTREE_NODE_UNLOCKED;
} }
static inline void __btree_node_unlock(struct btree_iter *iter, unsigned level) static inline void btree_node_unlock(struct btree_iter *iter, unsigned level)
{ {
int lock_type = btree_node_locked_type(iter, level); int lock_type = btree_node_locked_type(iter, level);
...@@ -105,13 +105,6 @@ static inline void __btree_node_unlock(struct btree_iter *iter, unsigned level) ...@@ -105,13 +105,6 @@ static inline void __btree_node_unlock(struct btree_iter *iter, unsigned level)
mark_btree_node_unlocked(iter, level); mark_btree_node_unlocked(iter, level);
} }
static inline void btree_node_unlock(struct btree_iter *iter, unsigned level)
{
EBUG_ON(!level && iter->trans->nounlock);
__btree_node_unlock(iter, level);
}
static inline void __bch2_btree_iter_unlock(struct btree_iter *iter) static inline void __bch2_btree_iter_unlock(struct btree_iter *iter)
{ {
btree_iter_set_dirty(iter, BTREE_ITER_NEED_RELOCK); btree_iter_set_dirty(iter, BTREE_ITER_NEED_RELOCK);
......
...@@ -374,7 +374,6 @@ struct btree_trans { ...@@ -374,7 +374,6 @@ struct btree_trans {
u8 nr_updates2; u8 nr_updates2;
unsigned used_mempool:1; unsigned used_mempool:1;
unsigned error:1; unsigned error:1;
unsigned nounlock:1;
unsigned in_traverse_all:1; unsigned in_traverse_all:1;
u64 iters_linked; u64 iters_linked;
......
...@@ -984,17 +984,14 @@ int __bch2_trans_commit(struct btree_trans *trans) ...@@ -984,17 +984,14 @@ int __bch2_trans_commit(struct btree_trans *trans)
goto out; goto out;
} }
/* if (unlikely(!bch2_btree_iter_upgrade(i->iter, i->level + 1))) {
* We're not using bch2_btree_iter_upgrade here because
* we know trans->nounlock can't be set:
*/
if (unlikely(!btree_node_intent_locked(i->iter, i->iter->level) &&
!__bch2_btree_iter_upgrade(i->iter, i->iter->level + 1))) {
trace_trans_restart_upgrade(trans->ip); trace_trans_restart_upgrade(trans->ip);
ret = -EINTR; ret = -EINTR;
goto out; goto out;
} }
BUG_ON(!btree_node_intent_locked(i->iter, i->level));
u64s = jset_u64s(i->k->k.u64s); u64s = jset_u64s(i->k->k.u64s);
if (btree_iter_type(i->iter) == BTREE_ITER_CACHED && if (btree_iter_type(i->iter) == BTREE_ITER_CACHED &&
likely(!(trans->flags & BTREE_INSERT_JOURNAL_REPLAY))) likely(!(trans->flags & BTREE_INSERT_JOURNAL_REPLAY)))
......
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