Commit 34fdcf06 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Check for folios that don't have bch_folio attached

With large folios, it's now incidentally possible to end up with a
clean, uptodate folio in the page cache that doesn't have a bch_folio
attached, if a folio has to be split.

This patch fixes __bch2_truncate_folio() to check for this; other code
paths appear to handle it.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 9567413c
...@@ -926,6 +926,8 @@ static void bch2_set_folio_dirty(struct bch_fs *c, ...@@ -926,6 +926,8 @@ static void bch2_set_folio_dirty(struct bch_fs *c,
WARN_ON((u64) folio_pos(folio) + offset + len > WARN_ON((u64) folio_pos(folio) + offset + len >
round_up((u64) i_size_read(&inode->v), block_bytes(c))); round_up((u64) i_size_read(&inode->v), block_bytes(c)));
BUG_ON(!s->uptodate);
spin_lock(&s->lock); spin_lock(&s->lock);
for (i = round_down(offset, block_bytes(c)) >> 9; for (i = round_down(offset, block_bytes(c)) >> 9;
...@@ -2853,7 +2855,11 @@ static int __bch2_truncate_folio(struct bch_inode_info *inode, ...@@ -2853,7 +2855,11 @@ static int __bch2_truncate_folio(struct bch_inode_info *inode,
goto unlock; goto unlock;
} }
BUG_ON(!s->uptodate); if (!s->uptodate) {
ret = bch2_folio_set(c, inode_inum(inode), &folio, 1);
if (ret)
goto unlock;
}
for (i = round_up(start_offset, block_bytes(c)) >> 9; for (i = round_up(start_offset, block_bytes(c)) >> 9;
i < round_down(end_offset, block_bytes(c)) >> 9; i < round_down(end_offset, block_bytes(c)) >> 9;
......
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