+++ /dev/null
-From c5794709bc9105935dbedef8b9cf9c06f2b559fa Mon Sep 17 00:00:00 2001
-From: Eric Biggers <ebiggers@kernel.org>
-Date: Tue, 17 Feb 2026 20:28:29 -0800
-Subject: ksmbd: Compare MACs in constant time
-
-From: Eric Biggers <ebiggers@kernel.org>
-
-commit c5794709bc9105935dbedef8b9cf9c06f2b559fa upstream.
-
-To prevent timing attacks, MAC comparisons need to be constant-time.
-Replace the memcmp() with the correct function, crypto_memneq().
-
-Fixes: e2f34481b24d ("cifsd: add server-side procedures for SMB3")
-Cc: stable@vger.kernel.org
-Signed-off-by: Eric Biggers <ebiggers@kernel.org>
-Acked-by: Namjae Jeon <linkinjeon@kernel.org>
-Signed-off-by: Steve French <stfrench@microsoft.com>
-Signed-off-by: Rajani Kantha <681739313@139.com>
-Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
----
- fs/ksmbd/Kconfig | 1 +
- fs/ksmbd/auth.c | 4 +++-
- fs/ksmbd/smb2pdu.c | 5 +++--
- 3 files changed, 7 insertions(+), 3 deletions(-)
-
---- a/fs/ksmbd/Kconfig
-+++ b/fs/ksmbd/Kconfig
-@@ -10,6 +10,7 @@ config SMB_SERVER
- select CRYPTO_HMAC
- select CRYPTO_ECB
- select CRYPTO_LIB_DES
-+ select CRYPTO_LIB_UTILS
- select CRYPTO_SHA256
- select CRYPTO_CMAC
- select CRYPTO_SHA512
---- a/fs/ksmbd/auth.c
-+++ b/fs/ksmbd/auth.c
-@@ -13,6 +13,7 @@
- #include <linux/xattr.h>
- #include <crypto/hash.h>
- #include <crypto/aead.h>
-+#include <crypto/utils.h>
- #include <linux/random.h>
- #include <linux/scatterlist.h>
-
-@@ -281,7 +282,8 @@ int ksmbd_auth_ntlmv2(struct ksmbd_conn
- goto out;
- }
-
-- if (memcmp(ntlmv2->ntlmv2_hash, ntlmv2_rsp, CIFS_HMAC_MD5_HASH_SIZE) != 0)
-+ if (crypto_memneq(ntlmv2->ntlmv2_hash, ntlmv2_rsp,
-+ CIFS_HMAC_MD5_HASH_SIZE))
- rc = -EINVAL;
- out:
- if (ctx)
---- a/fs/ksmbd/smb2pdu.c
-+++ b/fs/ksmbd/smb2pdu.c
-@@ -4,6 +4,7 @@
- * Copyright (C) 2018 Samsung Electronics Co., Ltd.
- */
-
-+#include <crypto/utils.h>
- #include <linux/inetdevice.h>
- #include <net/addrconf.h>
- #include <linux/syscalls.h>
-@@ -8440,7 +8441,7 @@ int smb2_check_sign_req(struct ksmbd_wor
- signature))
- return 0;
-
-- if (memcmp(signature, signature_req, SMB2_SIGNATURE_SIZE)) {
-+ if (crypto_memneq(signature, signature_req, SMB2_SIGNATURE_SIZE)) {
- pr_err("bad smb2 signature\n");
- return 0;
- }
-@@ -8528,7 +8529,7 @@ int smb3_check_sign_req(struct ksmbd_wor
- if (ksmbd_sign_smb3_pdu(conn, signing_key, iov, 1, signature))
- return 0;
-
-- if (memcmp(signature, signature_req, SMB2_SIGNATURE_SIZE)) {
-+ if (crypto_memneq(signature, signature_req, SMB2_SIGNATURE_SIZE)) {
- pr_err("bad smb2 signature\n");
- return 0;
- }