Commit edf5f054 authored by Jakob Koschel's avatar Jakob Koschel Committed by Steve French

ksmbd: replace usage of found with dedicated list iterator variable

To move the list iterator variable into the list_for_each_entry_*()
macro in the future it should be avoided to use the list iterator
variable after the loop body.

To *never* use the list iterator variable after the loop it was
concluded to use a separate iterator variable instead of a
found boolean [1].

This removes the need to use a found variable and simply checking if
the variable was set, can determine if the break/goto was hit.

Link: https://lore.kernel.org/all/CAHk-=wgRr_D8CB-D9Kg-c=EHreAsk5SqXPwr9Y7k9sA6cWXJ6w@mail.gmail.com/Signed-off-by: default avatarJakob Koschel <jakobkoschel@gmail.com>
Reviewed-by: default avatarHyunchul Lee <hyc.lee@gmail.com>
Acked-by: default avatarNamjae Jeon <linkinjeon@kernel.org>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent 56b401fb
...@@ -6618,8 +6618,7 @@ int smb2_cancel(struct ksmbd_work *work) ...@@ -6618,8 +6618,7 @@ int smb2_cancel(struct ksmbd_work *work)
struct ksmbd_conn *conn = work->conn; struct ksmbd_conn *conn = work->conn;
struct smb2_hdr *hdr = smb2_get_msg(work->request_buf); struct smb2_hdr *hdr = smb2_get_msg(work->request_buf);
struct smb2_hdr *chdr; struct smb2_hdr *chdr;
struct ksmbd_work *cancel_work = NULL; struct ksmbd_work *cancel_work = NULL, *iter;
int canceled = 0;
struct list_head *command_list; struct list_head *command_list;
ksmbd_debug(SMB, "smb2 cancel called on mid %llu, async flags 0x%x\n", ksmbd_debug(SMB, "smb2 cancel called on mid %llu, async flags 0x%x\n",
...@@ -6629,11 +6628,11 @@ int smb2_cancel(struct ksmbd_work *work) ...@@ -6629,11 +6628,11 @@ int smb2_cancel(struct ksmbd_work *work)
command_list = &conn->async_requests; command_list = &conn->async_requests;
spin_lock(&conn->request_lock); spin_lock(&conn->request_lock);
list_for_each_entry(cancel_work, command_list, list_for_each_entry(iter, command_list,
async_request_entry) { async_request_entry) {
chdr = smb2_get_msg(cancel_work->request_buf); chdr = smb2_get_msg(iter->request_buf);
if (cancel_work->async_id != if (iter->async_id !=
le64_to_cpu(hdr->Id.AsyncId)) le64_to_cpu(hdr->Id.AsyncId))
continue; continue;
...@@ -6641,7 +6640,7 @@ int smb2_cancel(struct ksmbd_work *work) ...@@ -6641,7 +6640,7 @@ int smb2_cancel(struct ksmbd_work *work)
"smb2 with AsyncId %llu cancelled command = 0x%x\n", "smb2 with AsyncId %llu cancelled command = 0x%x\n",
le64_to_cpu(hdr->Id.AsyncId), le64_to_cpu(hdr->Id.AsyncId),
le16_to_cpu(chdr->Command)); le16_to_cpu(chdr->Command));
canceled = 1; cancel_work = iter;
break; break;
} }
spin_unlock(&conn->request_lock); spin_unlock(&conn->request_lock);
...@@ -6649,24 +6648,24 @@ int smb2_cancel(struct ksmbd_work *work) ...@@ -6649,24 +6648,24 @@ int smb2_cancel(struct ksmbd_work *work)
command_list = &conn->requests; command_list = &conn->requests;
spin_lock(&conn->request_lock); spin_lock(&conn->request_lock);
list_for_each_entry(cancel_work, command_list, request_entry) { list_for_each_entry(iter, command_list, request_entry) {
chdr = smb2_get_msg(cancel_work->request_buf); chdr = smb2_get_msg(iter->request_buf);
if (chdr->MessageId != hdr->MessageId || if (chdr->MessageId != hdr->MessageId ||
cancel_work == work) iter == work)
continue; continue;
ksmbd_debug(SMB, ksmbd_debug(SMB,
"smb2 with mid %llu cancelled command = 0x%x\n", "smb2 with mid %llu cancelled command = 0x%x\n",
le64_to_cpu(hdr->MessageId), le64_to_cpu(hdr->MessageId),
le16_to_cpu(chdr->Command)); le16_to_cpu(chdr->Command));
canceled = 1; cancel_work = iter;
break; break;
} }
spin_unlock(&conn->request_lock); spin_unlock(&conn->request_lock);
} }
if (canceled) { if (cancel_work) {
cancel_work->state = KSMBD_WORK_CANCELLED; cancel_work->state = KSMBD_WORK_CANCELLED;
if (cancel_work->cancel_fn) if (cancel_work->cancel_fn)
cancel_work->cancel_fn(cancel_work->cancel_argv); cancel_work->cancel_fn(cancel_work->cancel_argv);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment