]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
6.1-stable patches
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 22 Apr 2025 09:59:53 +0000 (11:59 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 22 Apr 2025 09:59:53 +0000 (11:59 +0200)
added patches:
smb-server-fix-potential-null-ptr-deref-of-lease_ctx_info-in-smb2_open.patch

queue-6.1/series
queue-6.1/smb-server-fix-potential-null-ptr-deref-of-lease_ctx_info-in-smb2_open.patch [new file with mode: 0644]

index 2fdcde6912c26b12fcd95d0fca254f20b325f5b9..63cb054bd62fdcb07a626ce9793c160d66a79f86 100644 (file)
@@ -277,3 +277,4 @@ landlock-add-the-errata-interface.patch
 revert-loongarch-bpf-fix-off-by-one-error-in-build_prologue.patch
 nvmet-fc-remove-unused-functions.patch
 smb-client-fix-use-after-free-of-network-namespace.patch
+smb-server-fix-potential-null-ptr-deref-of-lease_ctx_info-in-smb2_open.patch
diff --git a/queue-6.1/smb-server-fix-potential-null-ptr-deref-of-lease_ctx_info-in-smb2_open.patch b/queue-6.1/smb-server-fix-potential-null-ptr-deref-of-lease_ctx_info-in-smb2_open.patch
new file mode 100644 (file)
index 0000000..33ae210
--- /dev/null
@@ -0,0 +1,52 @@
+From 4e8771a3666c8f216eefd6bd2fd50121c6c437db Mon Sep 17 00:00:00 2001
+From: ChenXiaoSong <chenxiaosong@kylinos.cn>
+Date: Thu, 22 Aug 2024 08:20:51 +0000
+Subject: smb/server: fix potential null-ptr-deref of lease_ctx_info in smb2_open()
+
+From: ChenXiaoSong <chenxiaosong@kylinos.cn>
+
+commit 4e8771a3666c8f216eefd6bd2fd50121c6c437db upstream.
+
+null-ptr-deref will occur when (req_op_level == SMB2_OPLOCK_LEVEL_LEASE)
+and parse_lease_state() return NULL.
+
+Fix this by check if 'lease_ctx_info' is NULL.
+
+Additionally, remove the redundant parentheses in
+parse_durable_handle_context().
+
+Signed-off-by: ChenXiaoSong <chenxiaosong@kylinos.cn>
+Signed-off-by: Steve French <stfrench@microsoft.com>
+[ Drop the parentheses clean-up since the parentheses was introduced by
+  c8efcc786146 ("ksmbd: add support for durable handles v1/v2") in v6.9
+  Minor context change fixed ]
+Signed-off-by: Jianqi Ren <jianqi.ren.cn@windriver.com>
+Signed-off-by: He Zhe <zhe.he@windriver.com>
+Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
+---
+ fs/smb/server/oplock.c  |    2 +-
+ fs/smb/server/smb2pdu.c |    2 +-
+ 2 files changed, 2 insertions(+), 2 deletions(-)
+
+--- a/fs/smb/server/oplock.c
++++ b/fs/smb/server/oplock.c
+@@ -1515,7 +1515,7 @@ void create_lease_buf(u8 *rbuf, struct l
+  * @open_req: buffer containing smb2 file open(create) request
+  * @is_dir:   whether leasing file is directory
+  *
+- * Return:  oplock state, -ENOENT if create lease context not found
++ * Return: allocated lease context object on success, otherwise NULL
+  */
+ struct lease_ctx_info *parse_lease_state(void *open_req, bool is_dir)
+ {
+--- a/fs/smb/server/smb2pdu.c
++++ b/fs/smb/server/smb2pdu.c
+@@ -3243,7 +3243,7 @@ int smb2_open(struct ksmbd_work *work)
+                       goto err_out1;
+               }
+       } else {
+-              if (req_op_level == SMB2_OPLOCK_LEVEL_LEASE) {
++              if (req_op_level == SMB2_OPLOCK_LEVEL_LEASE && lc) {
+                       /*
+                        * Compare parent lease using parent key. If there is no
+                        * a lease that has same parent key, Send lease break