[PATCH] nvme-auth: use workqueue dedicated to authentication works

Daniel Wagner dwagner at suse.de
Wed Feb 1 00:04:36 PST 2023


On Tue, Jan 31, 2023 at 06:26:44PM +0900, Shin'ichiro Kawasaki wrote:
> NVMe In-Band authentication uses two kinds of works: chap->auth_work and
> ctrl->dhchap_auth_work. The latter work flushes or cancels the former
> work. However, the both works are queued to the same workqueue nvme-wq.
> It results in the lockdep WARNING as follows:
> 
>  WARNING: possible recursive locking detected
>  6.2.0-rc4+ #1 Not tainted
>  --------------------------------------------
>  kworker/u16:7/69 is trying to acquire lock:
>  ffff902d52e65548 ((wq_completion)nvme-wq){+.+.}-{0:0}, at: start_flush_work+0x2c5/0x380
> 
>  but task is already holding lock:
>  ffff902d52e65548 ((wq_completion)nvme-wq){+.+.}-{0:0}, at: process_one_work+0x210/0x410
> 
> To avoid the WARNING, introduce a new workqueue nvme-auth-wq dedicated
> to chap->auth_work.
> 
> Reported-by: Daniel Wagner <dwagner at suse.de>
> Link: https://lore.kernel.org/linux-nvme/20230130110802.paafkiipmitwtnwr@carbon.lan/
> Fixes: f50fff73d620 ("nvme: implement In-Band authentication")
> Signed-off-by: Shin'ichiro Kawasaki <shinichiro.kawasaki at wdc.com>

Thanks! This patches fixes the lockdep warning.

Tested-by: Daniel Wagner <dwagner at suse.de>



More information about the Linux-nvme mailing list