]> git.baikalelectronics.ru Git - kernel.git/commit
loop: make autoclear operation asynchronous
authorTetsuo Handa <penguin-kernel@i-love.sakura.ne.jp>
Mon, 13 Dec 2021 12:55:27 +0000 (21:55 +0900)
committerJens Axboe <axboe@kernel.dk>
Mon, 13 Dec 2021 18:37:31 +0000 (11:37 -0700)
commit03c173e1159ba9f933b53df704efcaf5b7f3bc06
tree7d80878419583add4b5626aa41c696446814ac48
parent498dc4ba71b353cc252ce4c2f26dd6edbde26093
loop: make autoclear operation asynchronous

syzbot is reporting circular locking problem at __loop_clr_fd() [1], for
commit 5e52177b3cf482be ("loop: use worker per cgroup instead of kworker")
is calling destroy_workqueue() with disk->open_mutex held.

This circular dependency cannot be broken unless we call __loop_clr_fd()
without holding disk->open_mutex. Therefore, defer __loop_clr_fd() from
lo_release() to a WQ context.

Link: https://syzkaller.appspot.com/bug?extid=643e4ce4b6ad1347d372
Reported-by: syzbot <syzbot+643e4ce4b6ad1347d372@syzkaller.appspotmail.com>
Suggested-by: Christoph Hellwig <hch@infradead.org>
Cc: Jan Kara <jack@suse.cz>
Tested-by: syzbot+643e4ce4b6ad1347d372@syzkaller.appspotmail.com
Signed-off-by: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Link: https://lore.kernel.org/r/1ed7df28-ebd6-71fb-70e5-1c2972e05ddb@i-love.sakura.ne.jp
Signed-off-by: Jens Axboe <axboe@kernel.dk>
drivers/block/loop.c
drivers/block/loop.h