Commit 43de721a authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Unlock in bch2_trans_begin() if we've held locks more than 10us

We try to ensure we never hold btree locks for too long - bcachefs tries
to be soft realtime. This adds a check when restarting a transaction,
where a transaction restart is cheap - if we've been holding locks for
too long, drop and retake them.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
parent a1783320
...@@ -3224,12 +3224,19 @@ void bch2_trans_begin(struct btree_trans *trans) ...@@ -3224,12 +3224,19 @@ void bch2_trans_begin(struct btree_trans *trans)
path->preserve = false; path->preserve = false;
} }
bch2_trans_cond_resched(trans); if (!trans->restarted &&
(need_resched() ||
ktime_get_ns() - trans->last_begin_time > BTREE_TRANS_MAX_LOCK_HOLD_TIME_NS)) {
bch2_trans_unlock(trans);
cond_resched();
bch2_trans_relock(trans);
}
if (trans->restarted) if (trans->restarted)
bch2_btree_path_traverse_all(trans); bch2_btree_path_traverse_all(trans);
trans->restarted = false; trans->restarted = false;
trans->last_begin_time = ktime_get_ns();
} }
static void bch2_trans_alloc_paths(struct btree_trans *trans, struct bch_fs *c) static void bch2_trans_alloc_paths(struct btree_trans *trans, struct bch_fs *c)
...@@ -3259,6 +3266,7 @@ void __bch2_trans_init(struct btree_trans *trans, struct bch_fs *c, ...@@ -3259,6 +3266,7 @@ void __bch2_trans_init(struct btree_trans *trans, struct bch_fs *c,
memset(trans, 0, sizeof(*trans)); memset(trans, 0, sizeof(*trans));
trans->c = c; trans->c = c;
trans->fn = fn; trans->fn = fn;
trans->last_begin_time = ktime_get_ns();
trans->task = current; trans->task = current;
trans->journal_replay_not_finished = trans->journal_replay_not_finished =
!test_bit(JOURNAL_REPLAY_DONE, &c->journal.flags); !test_bit(JOURNAL_REPLAY_DONE, &c->journal.flags);
......
...@@ -382,10 +382,13 @@ struct btree_trans_commit_hook { ...@@ -382,10 +382,13 @@ struct btree_trans_commit_hook {
#define BTREE_TRANS_MEM_MAX (1U << 16) #define BTREE_TRANS_MEM_MAX (1U << 16)
#define BTREE_TRANS_MAX_LOCK_HOLD_TIME_NS 10000
struct btree_trans { struct btree_trans {
struct bch_fs *c; struct bch_fs *c;
const char *fn; const char *fn;
struct list_head list; struct list_head list;
u64 last_begin_time;
struct btree *locking; struct btree *locking;
unsigned locking_path_idx; unsigned locking_path_idx;
struct bpos locking_pos; struct bpos locking_pos;
......
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