On Mon, 2019-07-01 at 18:16 +0100, Luis Henriques wrote:
> Commit e450f4d1a5d6 ("ceph: pass inclusive lend parameter to
> filemap_write_and_wait_range()") fixed the end offset parameter used to
> call filemap_write_and_wait_range and invalidate_inode_pages2_range.
> Unfortunately it missed truncate_inode_pages_range, introducing a
> regression that is easily detected by xfstest generic/130.
> 
> The problem is that when doing direct IO it is possible that an extra page
> is truncated from the page cache when the end offset is page aligned.
> This can cause data loss if that page hasn't been sync'ed to the OSDs.
> 
> While there, change code to use PAGE_ALIGN macro instead.
> 
> Fixes: e450f4d1a5d6 ("ceph: pass inclusive lend parameter to 
> filemap_write_and_wait_range()")
> Signed-off-by: Luis Henriques <lhenriq...@suse.com>
> ---
>  fs/ceph/file.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/fs/ceph/file.c b/fs/ceph/file.c
> index 183c37c0a8fc..7a57db8e2fa9 100644
> --- a/fs/ceph/file.c
> +++ b/fs/ceph/file.c
> @@ -1007,7 +1007,7 @@         (struct kiocb *iocb, struct iov_iter *iter,
>                        * may block.
>                        */
>                       truncate_inode_pages_range(inode->i_mapping, pos,
> -                                     (pos+len) | (PAGE_SIZE - 1));
> +                                                PAGE_ALIGN(pos + len) - 1);
>  
>                       req->r_mtime = mtime;
>               }

Reviewed-by: Jeff Layton <jlay...@kernel.org>

Reply via email to