ksmbd: release interim response after sending status pending response
authorNamjae Jeon <linkinjeon@kernel.org>
Wed, 22 Nov 2023 14:00:22 +0000 (23:00 +0900)
committerSteve French <stfrench@microsoft.com>
Fri, 24 Nov 2023 02:50:45 +0000 (20:50 -0600)
Add missing release async id and delete interim response entry after
sending status pending response. This only cause when smb2 lease is enable.

Signed-off-by: Namjae Jeon <linkinjeon@kernel.org>
Signed-off-by: Steve French <stfrench@microsoft.com>
fs/smb/server/ksmbd_work.c
fs/smb/server/oplock.c

index 2510b9f3c8c14a750ba6a29fe5e405f051dd1b66..d7c676c151e209e89cb29b68eb9d14e7e3b9d70c 100644 (file)
@@ -56,6 +56,9 @@ void ksmbd_free_work_struct(struct ksmbd_work *work)
        kfree(work->tr_buf);
        kvfree(work->request_buf);
        kfree(work->iov);
+       if (!list_empty(&work->interim_entry))
+               list_del(&work->interim_entry);
+
        if (work->async_id)
                ksmbd_release_id(&work->conn->async_ida, work->async_id);
        kmem_cache_free(work_cache, work);
index 9bc0103720f57c323846b7faa6a7f8bcd0756ad5..50c68beb71d6c49855b3f3dc8b8b2789e25e90c5 100644 (file)
@@ -833,7 +833,8 @@ static int smb2_lease_break_noti(struct oplock_info *opinfo)
                                             interim_entry);
                        setup_async_work(in_work, NULL, NULL);
                        smb2_send_interim_resp(in_work, STATUS_PENDING);
-                       list_del(&in_work->interim_entry);
+                       list_del_init(&in_work->interim_entry);
+                       release_async_work(in_work);
                }
                INIT_WORK(&work->work, __smb2_lease_break_noti);
                ksmbd_queue_work(work);