Skip to content

Commit fbf1bdd

Browse files
committed
Merge tag 'iomap-5.14-fixes-1' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux
Pull iomap fixes from Darrick Wong: "A handful of bugfixes for the iomap code. There's nothing especially exciting here, just fixes for UBSAN (not KASAN as I erroneously wrote in the tag message) warnings about undefined behavior in the SEEK_DATA/SEEK_HOLE code, and some reshuffling of per-page block state info to fix some problems with gfs2. - Fix KASAN warnings due to integer overflow in SEEK_DATA/SEEK_HOLE - Fix assertion errors when using inlinedata files on gfs2" * tag 'iomap-5.14-fixes-1' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux: iomap: Don't create iomap_page objects in iomap_page_mkwrite_actor iomap: Don't create iomap_page objects for inline files iomap: Permit pages without an iop to enter writeback iomap: remove the length variable in iomap_seek_hole iomap: remove the length variable in iomap_seek_data
2 parents 6750691 + 229adf3 commit fbf1bdd

File tree

2 files changed

+13
-20
lines changed

2 files changed

+13
-20
lines changed

fs/iomap/buffered-io.c

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -215,6 +215,7 @@ iomap_read_inline_data(struct inode *inode, struct page *page,
215215
if (PageUptodate(page))
216216
return;
217217

218+
BUG_ON(page_has_private(page));
218219
BUG_ON(page->index);
219220
BUG_ON(size > PAGE_SIZE - offset_in_page(iomap->inline_data));
220221

@@ -239,7 +240,7 @@ iomap_readpage_actor(struct inode *inode, loff_t pos, loff_t length, void *data,
239240
{
240241
struct iomap_readpage_ctx *ctx = data;
241242
struct page *page = ctx->cur_page;
242-
struct iomap_page *iop = iomap_page_create(inode, page);
243+
struct iomap_page *iop;
243244
bool same_page = false, is_contig = false;
244245
loff_t orig_pos = pos;
245246
unsigned poff, plen;
@@ -252,6 +253,7 @@ iomap_readpage_actor(struct inode *inode, loff_t pos, loff_t length, void *data,
252253
}
253254

254255
/* zero post-eof blocks as the page may be mapped */
256+
iop = iomap_page_create(inode, page);
255257
iomap_adjust_read_range(inode, iop, &pos, length, &poff, &plen);
256258
if (plen == 0)
257259
goto done;
@@ -967,7 +969,6 @@ iomap_page_mkwrite_actor(struct inode *inode, loff_t pos, loff_t length,
967969
block_commit_write(page, 0, length);
968970
} else {
969971
WARN_ON_ONCE(!PageUptodate(page));
970-
iomap_page_create(inode, page);
971972
set_page_dirty(page);
972973
}
973974

@@ -1304,14 +1305,13 @@ iomap_writepage_map(struct iomap_writepage_ctx *wpc,
13041305
struct writeback_control *wbc, struct inode *inode,
13051306
struct page *page, u64 end_offset)
13061307
{
1307-
struct iomap_page *iop = to_iomap_page(page);
1308+
struct iomap_page *iop = iomap_page_create(inode, page);
13081309
struct iomap_ioend *ioend, *next;
13091310
unsigned len = i_blocksize(inode);
13101311
u64 file_offset; /* file offset of page */
13111312
int error = 0, count = 0, i;
13121313
LIST_HEAD(submit_list);
13131314

1314-
WARN_ON_ONCE(i_blocks_per_page(inode, page) > 1 && !iop);
13151315
WARN_ON_ONCE(iop && atomic_read(&iop->write_bytes_pending) != 0);
13161316

13171317
/*

fs/iomap/seek.c

Lines changed: 9 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -35,23 +35,20 @@ loff_t
3535
iomap_seek_hole(struct inode *inode, loff_t offset, const struct iomap_ops *ops)
3636
{
3737
loff_t size = i_size_read(inode);
38-
loff_t length = size - offset;
3938
loff_t ret;
4039

4140
/* Nothing to be found before or beyond the end of the file. */
4241
if (offset < 0 || offset >= size)
4342
return -ENXIO;
4443

45-
while (length > 0) {
46-
ret = iomap_apply(inode, offset, length, IOMAP_REPORT, ops,
47-
&offset, iomap_seek_hole_actor);
44+
while (offset < size) {
45+
ret = iomap_apply(inode, offset, size - offset, IOMAP_REPORT,
46+
ops, &offset, iomap_seek_hole_actor);
4847
if (ret < 0)
4948
return ret;
5049
if (ret == 0)
5150
break;
52-
5351
offset += ret;
54-
length -= ret;
5552
}
5653

5754
return offset;
@@ -83,27 +80,23 @@ loff_t
8380
iomap_seek_data(struct inode *inode, loff_t offset, const struct iomap_ops *ops)
8481
{
8582
loff_t size = i_size_read(inode);
86-
loff_t length = size - offset;
8783
loff_t ret;
8884

8985
/* Nothing to be found before or beyond the end of the file. */
9086
if (offset < 0 || offset >= size)
9187
return -ENXIO;
9288

93-
while (length > 0) {
94-
ret = iomap_apply(inode, offset, length, IOMAP_REPORT, ops,
95-
&offset, iomap_seek_data_actor);
89+
while (offset < size) {
90+
ret = iomap_apply(inode, offset, size - offset, IOMAP_REPORT,
91+
ops, &offset, iomap_seek_data_actor);
9692
if (ret < 0)
9793
return ret;
9894
if (ret == 0)
99-
break;
100-
95+
return offset;
10196
offset += ret;
102-
length -= ret;
10397
}
10498

105-
if (length <= 0)
106-
return -ENXIO;
107-
return offset;
99+
/* We've reached the end of the file without finding data */
100+
return -ENXIO;
108101
}
109102
EXPORT_SYMBOL_GPL(iomap_seek_data);

0 commit comments

Comments
 (0)