Commit c5bb1690 authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Fix journal_flush_seq()

The error check was inverted - leading fsyncs to get stuck and hang,
oops.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 3eb26d01
...@@ -552,16 +552,13 @@ int bch2_journal_flush_seq_async(struct journal *j, u64 seq, ...@@ -552,16 +552,13 @@ int bch2_journal_flush_seq_async(struct journal *j, u64 seq,
struct journal_buf *buf; struct journal_buf *buf;
int ret = 0; int ret = 0;
if (seq <= j->err_seq)
return -EIO;
if (seq <= j->seq_ondisk) if (seq <= j->seq_ondisk)
return 1; return 1;
spin_lock(&j->lock); spin_lock(&j->lock);
/* Recheck under lock: */ /* Recheck under lock: */
if (seq <= j->err_seq) { if (j->err_seq && seq >= j->err_seq) {
ret = -EIO; ret = -EIO;
goto out; goto out;
} }
......
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