Commit d061a1bd authored by Sagi Grimberg's avatar Sagi Grimberg Committed by Christoph Hellwig

nvme-auth: have dhchap_auth_work wait for queues auth to complete

It triggered the queue authentication work elements in parallel, but
the ctrl authentication work itself completes when all of them
completes. Hence wait for queues auth completions.

This also makes nvme_auth_stop simply a sync cancel of ctrl
dhchap_auth_work.
Signed-off-by: default avatarSagi Grimberg <sagi@grimberg.me>
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
parent a2a00d2a
...@@ -926,6 +926,12 @@ static void nvme_ctrl_auth_work(struct work_struct *work) ...@@ -926,6 +926,12 @@ static void nvme_ctrl_auth_work(struct work_struct *work)
* Failure is a soft-state; credentials remain valid until * Failure is a soft-state; credentials remain valid until
* the controller terminates the connection. * the controller terminates the connection.
*/ */
for (q = 1; q < ctrl->queue_count; q++) {
ret = nvme_auth_wait(ctrl, q);
if (ret)
dev_warn(ctrl->device,
"qid %d: authentication failed\n", q);
}
} }
int nvme_auth_init_ctrl(struct nvme_ctrl *ctrl) int nvme_auth_init_ctrl(struct nvme_ctrl *ctrl)
...@@ -976,14 +982,7 @@ EXPORT_SYMBOL_GPL(nvme_auth_init_ctrl); ...@@ -976,14 +982,7 @@ EXPORT_SYMBOL_GPL(nvme_auth_init_ctrl);
void nvme_auth_stop(struct nvme_ctrl *ctrl) void nvme_auth_stop(struct nvme_ctrl *ctrl)
{ {
struct nvme_dhchap_queue_context *chap;
int i;
cancel_work_sync(&ctrl->dhchap_auth_work); cancel_work_sync(&ctrl->dhchap_auth_work);
for (i = 0; i < ctrl_max_dhchaps(ctrl); i++) {
chap = &ctrl->dhchap_ctxs[i];
cancel_work_sync(&chap->auth_work);
}
} }
EXPORT_SYMBOL_GPL(nvme_auth_stop); EXPORT_SYMBOL_GPL(nvme_auth_stop);
......
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