On 11.04.20 00:34, Song Liu wrote:
On Apr 9, 2020, at 5:32 PM, Song Liu <songliubraving@xxxxxx> wrote:
On Apr 9, 2020, at 2:47 PM, Guoqing Jiang <guoqing.jiang@xxxxxxxxxxxxxxx> wrote:
On 09.04.20 09:25, Song Liu wrote:
Thanks for the fix!
On Sat, Apr 4, 2020 at 3:01 PM Guoqing Jiang
<guoqing.jiang@xxxxxxxxxxxxxxx> wrote:
Hi,
After LOCKDEP is enabled, we can see some deadlock issues, this patchset
makes workqueue is flushed only necessary, and the last patch is a cleanup.
Thanks,
Guoqing
Guoqing Jiang (5):
md: add checkings before flush md_misc_wq
md: add new workqueue for delete rdev
md: don't flush workqueue unconditionally in md_open
md: flush md_rdev_misc_wq for HOT_ADD_DISK case
md: remove the extra line for ->hot_add_disk
I think we will need a new workqueue (2/5). But I am not sure about
whether we should
do 1/5 and 3/5. It feels like we are hiding errors from lock_dep. With
some quick grep,
I didn't find code pattern like
if (work_pending(XXX))
flush_workqueue(XXX);
Maybe the way that md uses workqueue is quite different from other subsystems ...
Because, this is the safest way to address the issue. Otherwise I suppose we have to
rearrange the lock order or introduce new lock, either of them is tricky and could
cause regression.
Or maybe it is possible to flush workqueue in md_check_recovery, but I would prefer
to make less change to avoid any potential risk.
After reading it a little more, I guess this might be the best solution for now.
I will keep it in a local branch for more tests.
Thanks for your effort, if there is any issue then just let me know.
Regards,
Guoqing