fs/ceph/inode.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)
In ceph, in fill_fscrypt_truncate(), the end flush position is calculated
by:
loff_t lend = orig_pos + CEPH_FSCRYPT_BLOCK_SHIFT - 1;
but that's using the block shift not the block size.
Fix this to use the block size instead.
Fixes: 5c64737d2536 ("ceph: add truncate size handling support for fscrypt")
Signed-off-by: David Howells <dhowells@redhat.com>
cc: Viacheslav Dubeyko <slava@dubeyko.com>
cc: Alex Markuze <amarkuze@redhat.com>
cc: Xiubo Li <xiubli@redhat.com>
cc: Ilya Dryomov <idryomov@gmail.com>
cc: ceph-devel@vger.kernel.org
cc: linux-fsdevel@vger.kernel.org
---
fs/ceph/inode.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/fs/ceph/inode.c b/fs/ceph/inode.c
index ab63c7ebce5b..ec9b80fec7be 100644
--- a/fs/ceph/inode.c
+++ b/fs/ceph/inode.c
@@ -2363,7 +2363,7 @@ static int fill_fscrypt_truncate(struct inode *inode,
/* Try to writeback the dirty pagecaches */
if (issued & (CEPH_CAP_FILE_BUFFER)) {
- loff_t lend = orig_pos + CEPH_FSCRYPT_BLOCK_SHIFT - 1;
+ loff_t lend = orig_pos + CEPH_FSCRYPT_BLOCK_SIZE - 1;
ret = filemap_write_and_wait_range(inode->i_mapping,
orig_pos, lend);
On Wed, 2025-03-12 at 10:47 +0000, David Howells wrote:
> In ceph, in fill_fscrypt_truncate(), the end flush position is calculated
> by:
>
> loff_t lend = orig_pos + CEPH_FSCRYPT_BLOCK_SHIFT - 1;
>
> but that's using the block shift not the block size.
>
> Fix this to use the block size instead.
>
> Fixes: 5c64737d2536 ("ceph: add truncate size handling support for fscrypt")
> Signed-off-by: David Howells <dhowells@redhat.com>
> cc: Viacheslav Dubeyko <slava@dubeyko.com>
> cc: Alex Markuze <amarkuze@redhat.com>
> cc: Xiubo Li <xiubli@redhat.com>
> cc: Ilya Dryomov <idryomov@gmail.com>
> cc: ceph-devel@vger.kernel.org
> cc: linux-fsdevel@vger.kernel.org
> ---
> fs/ceph/inode.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/fs/ceph/inode.c b/fs/ceph/inode.c
> index ab63c7ebce5b..ec9b80fec7be 100644
> --- a/fs/ceph/inode.c
> +++ b/fs/ceph/inode.c
> @@ -2363,7 +2363,7 @@ static int fill_fscrypt_truncate(struct inode *inode,
>
> /* Try to writeback the dirty pagecaches */
> if (issued & (CEPH_CAP_FILE_BUFFER)) {
> - loff_t lend = orig_pos + CEPH_FSCRYPT_BLOCK_SHIFT - 1;
> + loff_t lend = orig_pos + CEPH_FSCRYPT_BLOCK_SIZE - 1;
>
> ret = filemap_write_and_wait_range(inode->i_mapping,
> orig_pos, lend);
>
>
Looks good.
Reviewed-by: Viacheslav Dubeyko <Slava.Dubeyko@ibm.com>
Do we know easy way to reproduce the issue?
Thanks,
Slava.
Shall I ask Christian to stick this in the vfs tree? Or did you want to take it through the ceph tree? David
I'm sure @Ilya Dryomov will pick this up, this doesn't look urgent. On Thu, Mar 13, 2025 at 11:00 AM David Howells <dhowells@redhat.com> wrote: > > Shall I ask Christian to stick this in the vfs tree? Or did you want to take > it through the ceph tree? > > David >
Viacheslav Dubeyko <Slava.Dubeyko@ibm.com> wrote: > Do we know easy way to reproduce the issue? I found it by inspection of the code. Quite possibly the issue will never arise in actuality because whilst the code only specifies a flush of at least a few bytes of the tail page, it will be rounded up to the full page/eof. David
© 2016 - 2025 Red Hat, Inc.