diff options
author | Namjae Jeon <linkinjeon@kernel.org> | 2022-06-19 22:35:48 +0900 |
---|---|---|
committer | Steve French <stfrench@microsoft.com> | 2022-06-23 23:30:46 -0500 |
commit | 18e39fb960e6a908ac5230b57e3d0d6c25232368 (patch) | |
tree | 54560a6220dad6bab4620f1abd96e0c3dc6253c8 | |
parent | 745bbc0995c25917dfafb645b8efb29813ef9e0b (diff) | |
download | lwn-18e39fb960e6a908ac5230b57e3d0d6c25232368.tar.gz lwn-18e39fb960e6a908ac5230b57e3d0d6c25232368.zip |
ksmbd: set the range of bytes to zero without extending file size in FSCTL_ZERO_DATA
generic/091, 263 test failed since commit f66f8b94e7f2 ("cifs: when
extending a file with falloc we should make files not-sparse").
FSCTL_ZERO_DATA sets the range of bytes to zero without extending file
size. The VFS_FALLOCATE_FL_KEEP_SIZE flag should be used even on
non-sparse files.
Cc: stable@vger.kernel.org
Reviewed-by: Hyunchul Lee <hyc.lee@gmail.com>
Signed-off-by: Namjae Jeon <linkinjeon@kernel.org>
Signed-off-by: Steve French <stfrench@microsoft.com>
-rw-r--r-- | fs/ksmbd/vfs.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/fs/ksmbd/vfs.c b/fs/ksmbd/vfs.c index dcdd07c6efff..f194bf764f9f 100644 --- a/fs/ksmbd/vfs.c +++ b/fs/ksmbd/vfs.c @@ -1015,7 +1015,9 @@ int ksmbd_vfs_zero_data(struct ksmbd_work *work, struct ksmbd_file *fp, FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE, off, len); - return vfs_fallocate(fp->filp, FALLOC_FL_ZERO_RANGE, off, len); + return vfs_fallocate(fp->filp, + FALLOC_FL_ZERO_RANGE | FALLOC_FL_KEEP_SIZE, + off, len); } int ksmbd_vfs_fqar_lseek(struct ksmbd_file *fp, loff_t start, loff_t length, |