Skip to content

Commit a40b73f

Browse files
fs/ntfs3: Correct use bh_read
Signed-off-by: Konstantin Komarov <almaz.alexandrovich@paragon-software.com>
1 parent d155617 commit a40b73f

2 files changed

Lines changed: 12 additions & 14 deletions

File tree

fs/ntfs3/file.c

Lines changed: 9 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -188,6 +188,7 @@ static int ntfs_zero_range(struct inode *inode, u64 vbo, u64 vbo_to)
188188
u32 bh_next, bh_off, to;
189189
sector_t iblock;
190190
struct folio *folio;
191+
bool dirty = false;
191192

192193
for (; idx < idx_end; idx += 1, from = 0) {
193194
page_off = (loff_t)idx << PAGE_SHIFT;
@@ -223,29 +224,27 @@ static int ntfs_zero_range(struct inode *inode, u64 vbo, u64 vbo_to)
223224
/* Ok, it's mapped. Make sure it's up-to-date. */
224225
if (folio_test_uptodate(folio))
225226
set_buffer_uptodate(bh);
226-
227-
if (!buffer_uptodate(bh)) {
228-
err = bh_read(bh, 0);
229-
if (err < 0) {
230-
folio_unlock(folio);
231-
folio_put(folio);
232-
goto out;
233-
}
227+
else if (bh_read(bh, 0) < 0) {
228+
err = -EIO;
229+
folio_unlock(folio);
230+
folio_put(folio);
231+
goto out;
234232
}
235233

236234
mark_buffer_dirty(bh);
237-
238235
} while (bh_off = bh_next, iblock += 1,
239236
head != (bh = bh->b_this_page));
240237

241238
folio_zero_segment(folio, from, to);
239+
dirty = true;
242240

243241
folio_unlock(folio);
244242
folio_put(folio);
245243
cond_resched();
246244
}
247245
out:
248-
mark_inode_dirty(inode);
246+
if (dirty)
247+
mark_inode_dirty(inode);
249248
return err;
250249
}
251250

fs/ntfs3/inode.c

Lines changed: 3 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -345,9 +345,7 @@ static struct inode *ntfs_read_mft(struct inode *inode,
345345
inode->i_size = le16_to_cpu(rp.SymbolicLinkReparseBuffer
346346
.PrintNameLength) /
347347
sizeof(u16);
348-
349348
ni->i_valid = inode->i_size;
350-
351349
/* Clear directory bit. */
352350
if (ni->ni_flags & NI_FLAG_DIR) {
353351
indx_clear(&ni->dir);
@@ -653,9 +651,10 @@ static noinline int ntfs_get_block_vbo(struct inode *inode, u64 vbo,
653651
off = vbo & (PAGE_SIZE - 1);
654652
folio_set_bh(bh, folio, off);
655653

656-
err = bh_read(bh, 0);
657-
if (err < 0)
654+
if (bh_read(bh, 0) < 0) {
655+
err = -EIO;
658656
goto out;
657+
}
659658
folio_zero_segment(folio, off + voff, off + block_size);
660659
}
661660
}

0 commit comments

Comments
 (0)