ksmbd: fix wrong DataOffset validation of create context
authorNamjae Jeon <linkinjeon@kernel.org>
Fri, 25 Aug 2023 14:39:40 +0000 (23:39 +0900)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 6 Sep 2023 20:26:59 +0000 (21:26 +0100)
commit 17d5b135bb720832364e8f55f6a887a3c7ec8fdb upstream.

If ->DataOffset of create context is 0, DataBuffer size is not correctly
validated. This patch change wrong validation code and consider tag
length in request.

Cc: stable@vger.kernel.org
Reported-by: zdi-disclosures@trendmicro.com # ZDI-CAN-21824
Signed-off-by: Namjae Jeon <linkinjeon@kernel.org>
Signed-off-by: Steve French <stfrench@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/smb/server/oplock.c

index 4b210cd..c81aee9 100644 (file)
@@ -1492,7 +1492,7 @@ struct create_context *smb2_find_context_vals(void *open_req, const char *tag, i
                    name_len < 4 ||
                    name_off + name_len > cc_len ||
                    (value_off & 0x7) != 0 ||
-                   (value_off && (value_off < name_off + name_len)) ||
+                   (value_len && value_off < name_off + (name_len < 8 ? 8 : name_len)) ||
                    ((u64)value_off + value_len > cc_len))
                        return ERR_PTR(-EINVAL);