]> git.itanic.dy.fi Git - linux-stable/commitdiff
scsi: qla2xxx: Avoid flush_scheduled_work() usage
authorTetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
Sun, 21 Aug 2022 03:59:44 +0000 (12:59 +0900)
committerMartin K. Petersen <martin.petersen@oracle.com>
Thu, 1 Sep 2022 03:39:59 +0000 (23:39 -0400)
Although qla2xxx driver is calling schedule_{,delayed}_work() from 10
locations, I assume that flush_scheduled_work() from qlt_stop_phase1()
needs to flush only works scheduled by qlt_sched_sess_work(), for this loop
continues while "struct qla_tgt"->sess_works_list is not empty.

Link: https://lore.kernel.org/r/133c6723-90b6-5c8b-72b4-cc01eeb3a8c0@I-love.SAKURA.ne.jp
Tested-by: Himanshu Madhani <himanshu.madhani@oracle.com>
Reviewed-by: Himanshu Madhani <himanshu.madhani@oracle.com>
Signed-off-by: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/scsi/qla2xxx/qla_target.c

index 9013c162d4aa6cc3837c746b9c065eaa7b9f41ec..b0cb463cf032a32f8cc758cfaf371af6c63ba85c 100644 (file)
@@ -1559,7 +1559,7 @@ int qlt_stop_phase1(struct qla_tgt *tgt)
        spin_lock_irqsave(&tgt->sess_work_lock, flags);
        do {
                spin_unlock_irqrestore(&tgt->sess_work_lock, flags);
-               flush_scheduled_work();
+               flush_work(&tgt->sess_work);
                spin_lock_irqsave(&tgt->sess_work_lock, flags);
        } while (!list_empty(&tgt->sess_works_list));
        spin_unlock_irqrestore(&tgt->sess_work_lock, flags);