Skip to content

Commit 52da69c

Browse files
dhkts1namjaejeon
authored andcommitted
ksmbd: add a permission check for FSCTL_SET_ZERO_DATA
FSCTL_SET_ZERO_DATA in smb2_ioctl() destroys file data via ksmbd_vfs_zero_data() -> vfs_fallocate(PUNCH_HOLE/ZERO_RANGE) after checking only the share-level KSMBD_TREE_CONN_FLAG_WRITABLE, with no per-handle access check. A handle opened with only FILE_WRITE_ATTRIBUTES still yields an FMODE_WRITE filp (FILE_WRITE_ATTRIBUTES is part of FILE_WRITE_DESIRE_ACCESS_LE, so smb2_create_open_flags() opens it O_WRONLY), so the vfs_fallocate FMODE_WRITE check does not stop it; only the missing fp->daccess gate would. Reproduced on mainline 7.1-rc7 with KASAN by an authenticated SMB client: a FILE_WRITE_ATTRIBUTES-only handle zeroed 4096 bytes of file data it had no FILE_WRITE_DATA right to (6/6; a FILE_READ_DATA-only handle was correctly denied). This is the unfixed sibling of cc57232cae23 ("ksmbd: fix FSCTL permission bypass by adding a permission check for FSCTL_SET_SPARSE"). Because SET_ZERO_DATA writes data (not an attribute), require FILE_WRITE_DATA. Cc: stable@vger.kernel.org Signed-off-by: Gil Portnoy <dddhkts1@gmail.com> Signed-off-by: Namjae Jeon <linkinjeon@kernel.org>
1 parent 8fd4796 commit 52da69c

1 file changed

Lines changed: 6 additions & 0 deletions

File tree

smb2pdu.c

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9035,6 +9035,12 @@ int smb2_ioctl(struct ksmbd_work *work)
90359035
goto out;
90369036
}
90379037

9038+
if (!(fp->daccess & FILE_WRITE_DATA_LE)) {
9039+
ksmbd_fd_put(work, fp);
9040+
ret = -EACCES;
9041+
goto out;
9042+
}
9043+
90389044
ret = ksmbd_vfs_zero_data(work, fp, off, len);
90399045
ksmbd_fd_put(work, fp);
90409046
if (ret < 0)

0 commit comments

Comments
 (0)