提交 5d2f0b10 编写于 作者: N Namjae Jeon 提交者: Steve French

ksmbd: set unique value to volume serial field in FS_VOLUME_INFORMATION

Steve French reported ksmbd set fixed value to volume serial field in
FS_VOLUME_INFORMATION. Volume serial value needs to be set to a unique
value for client fscache. This patch set crc value that is generated
with share name, path name and netbios name to volume serial.

Fixes: e2f34481 ("cifsd: add server-side procedures for SMB3")
Cc: stable@vger.kernel.org # v5.15
Reported-by: NSteve French <smfrench@gmail.com>
Signed-off-by: NNamjae Jeon <linkinjeon@kernel.org>
Signed-off-by: NSteve French <stfrench@microsoft.com>
上级 b53ad810
...@@ -19,6 +19,7 @@ config SMB_SERVER ...@@ -19,6 +19,7 @@ config SMB_SERVER
select CRYPTO_GCM select CRYPTO_GCM
select ASN1 select ASN1
select OID_REGISTRY select OID_REGISTRY
select CRC32
default n default n
help help
Choose Y here if you want to allow SMB3 compliant clients Choose Y here if you want to allow SMB3 compliant clients
......
...@@ -632,5 +632,6 @@ MODULE_SOFTDEP("pre: sha512"); ...@@ -632,5 +632,6 @@ MODULE_SOFTDEP("pre: sha512");
MODULE_SOFTDEP("pre: aead2"); MODULE_SOFTDEP("pre: aead2");
MODULE_SOFTDEP("pre: ccm"); MODULE_SOFTDEP("pre: ccm");
MODULE_SOFTDEP("pre: gcm"); MODULE_SOFTDEP("pre: gcm");
MODULE_SOFTDEP("pre: crc32");
module_init(ksmbd_server_init) module_init(ksmbd_server_init)
module_exit(ksmbd_server_exit) module_exit(ksmbd_server_exit)
...@@ -4892,11 +4892,18 @@ static int smb2_get_info_filesystem(struct ksmbd_work *work, ...@@ -4892,11 +4892,18 @@ static int smb2_get_info_filesystem(struct ksmbd_work *work,
{ {
struct filesystem_vol_info *info; struct filesystem_vol_info *info;
size_t sz; size_t sz;
unsigned int serial_crc = 0;
info = (struct filesystem_vol_info *)(rsp->Buffer); info = (struct filesystem_vol_info *)(rsp->Buffer);
info->VolumeCreationTime = 0; info->VolumeCreationTime = 0;
serial_crc = crc32_le(serial_crc, share->name,
strlen(share->name));
serial_crc = crc32_le(serial_crc, share->path,
strlen(share->path));
serial_crc = crc32_le(serial_crc, ksmbd_netbios_name(),
strlen(ksmbd_netbios_name()));
/* Taking dummy value of serial number*/ /* Taking dummy value of serial number*/
info->SerialNumber = cpu_to_le32(0xbc3ac512); info->SerialNumber = cpu_to_le32(serial_crc);
len = smbConvertToUTF16((__le16 *)info->VolumeLabel, len = smbConvertToUTF16((__le16 *)info->VolumeLabel,
share->name, PATH_MAX, share->name, PATH_MAX,
conn->local_nls, 0); conn->local_nls, 0);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册