]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
netfs: Fix early issue of write op on partial write to folio tail
authorDavid Howells <dhowells@redhat.com>
Wed, 5 Jun 2024 21:18:04 +0000 (22:18 +0100)
committerChristian Brauner <brauner@kernel.org>
Wed, 26 Jun 2024 12:16:04 +0000 (14:16 +0200)
During the writeback procedure, at the end of netfs_write_folio(), pending
write operations are flushed if the amount of write-streaming data stored
in a page is less than the size of the folio because if we haven't modified
a folio to the end, it cannot be contiguous with the following folio...
except if the dirty region of the folio is right at the end of the folio
space.

Fix the test to take the offset into the folio into account as well, such
that if the dirty region runs right up to the end of the folio, we leave
the flushing for later.

Fixes: 288ace2f57c9 ("netfs: New writeback implementation")
Signed-off-by: David Howells <dhowells@redhat.com>
cc: Jeff Layton <jlayton@kernel.org>
cc: Eric Van Hensbergen <ericvh@kernel.org>
cc: Latchesar Ionkov <lucho@ionkov.net>
cc: Dominique Martinet <asmadeus@codewreck.org>
cc: Christian Schoenebeck <linux_oss@crudebyte.com>
cc: Marc Dionne <marc.dionne@auristor.com>
cc: Steve French <sfrench@samba.org>
cc: Paulo Alcantara <pc@manguebit.com> (DFS, global name space)
cc: v9fs@lists.linux.dev
cc: linux-afs@lists.infradead.org
cc: linux-cifs@vger.kernel.org
cc: netfs@lists.linux.dev
cc: linux-fsdevel@vger.kernel.org
Link: https://lore.kernel.org/r/20240620173137.610345-4-dhowells@redhat.com
Signed-off-by: Christian Brauner <brauner@kernel.org>
fs/netfs/write_issue.c

index 3aa86e268f40d4a7b01a85715d41b7fd4a270da6..ec6cf8707fb02f5c56290095e1a544e094a93e20 100644 (file)
@@ -483,7 +483,7 @@ static int netfs_write_folio(struct netfs_io_request *wreq,
        if (!debug)
                kdebug("R=%x: No submit", wreq->debug_id);
 
-       if (flen < fsize)
+       if (foff + flen < fsize)
                for (int s = 0; s < NR_IO_STREAMS; s++)
                        netfs_issue_write(wreq, &wreq->io_streams[s]);