Re: [PATCH v2 3/3] netfs: fix test for whether we can skip read when writing beyond EOF
From: Matthew Wilcox
Date: Mon Jun 21 2021 - 10:51:56 EST
On Thu, Jun 17, 2021 at 09:24:27AM +0100, David Howells wrote:
> From: Jeff Layton <jlayton@xxxxxxxxxx>
>
> It's not sufficient to skip reading when the pos is beyond the EOF.
> There may be data at the head of the page that we need to fill in
> before the write.
>
> Add a new helper function that corrects and clarifies the logic of
> when we can skip reads, and have it only zero out the part of the page
> that won't have data copied in for the write.
>
> Finally, don't set the page Uptodate after zeroing. It's not up to date
> since the write data won't have been copied in yet.
>
> [DH made the following changes:
>
> - Prefixed the new function with "netfs_".
>
> - Don't call zero_user_segments() for a full-page write.
>
> - Altered the beyond-last-page check to avoid a DIV instruction and got
> rid of then-redundant zero-length file check.
> ]
>
> Fixes: e1b1240c1ff5f ("netfs: Add write_begin helper")
> Reported-by: Andrew W Elble <aweits@xxxxxxx>
> Signed-off-by: Jeff Layton <jlayton@xxxxxxxxxx>
> Signed-off-by: David Howells <dhowells@xxxxxxxxxx>
> cc: ceph-devel@xxxxxxxxxxxxxxx
> Link: https://lore.kernel.org/r/20210613233345.113565-1-jlayton@xxxxxxxxxx/
> Link: https://lore.kernel.org/r/162367683365.460125.4467036947364047314.stgit@xxxxxxxxxxxxxxxxxxxxxx/ # v1
Reviewed-by: Matthew Wilcox (Oracle) <willy@xxxxxxxxxxxxx>