summaryrefslogtreecommitdiff
path: root/fs/smb
diff options
context:
space:
mode:
authorArnd Bergmann <arnd@arndb.de>2023-06-19 11:19:38 +0300
committerSteve French <stfrench@microsoft.com>2023-06-29 06:58:28 +0300
commit9cedc58bdbe9fff9aacd0ca19ee5777659f28fd7 (patch)
treede0f05648330fa19e85aaafc10c9a3ff4826012b /fs/smb
parent11d5e2061e973a8d4ff2b95a114b4b8ef8652633 (diff)
downloadlinux-9cedc58bdbe9fff9aacd0ca19ee5777659f28fd7.tar.xz
ksmbd: avoid field overflow warning
clang warns about a possible field overflow in a memcpy: In file included from fs/smb/server/smb_common.c:7: include/linux/fortify-string.h:583:4: error: call to '__write_overflow_field' declared with 'warning' attribute: detected write beyond size of field (1st parameter); maybe use struct_group()? [-Werror,-Wattribute-warning] __write_overflow_field(p_size_field, size); It appears to interpret the "&out[baselen + 4]" as referring to a single byte of the character array, while the equivalen "out + baselen + 4" is seen as an offset into the array. I don't see that kind of warning elsewhere, so just go with the simple rework. Fixes: e2f34481b24d ("cifsd: add server-side procedures for SMB3") Signed-off-by: Arnd Bergmann <arnd@arndb.de> Acked-by: Namjae Jeon <linkinjeon@kernel.org> Signed-off-by: Steve French <stfrench@microsoft.com>
Diffstat (limited to 'fs/smb')
-rw-r--r--fs/smb/server/smb_common.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/smb/server/smb_common.c b/fs/smb/server/smb_common.c
index b51f431ade01..ef20f63e55e6 100644
--- a/fs/smb/server/smb_common.c
+++ b/fs/smb/server/smb_common.c
@@ -536,7 +536,7 @@ int ksmbd_extract_shortname(struct ksmbd_conn *conn, const char *longname,
out[baselen + 3] = PERIOD;
if (dot_present)
- memcpy(&out[baselen + 4], extension, 4);
+ memcpy(out + baselen + 4, extension, 4);
else
out[baselen + 4] = '\0';
smbConvertToUTF16((__le16 *)shortname, out, PATH_MAX,