[SCSI] hpsa: do not sleep in atomic context in rmmod path.
Don't call kthread_stop with a spin lock held and interrupts disabled because kthread_stop will sleep waiting for the thread to stop. Signed-off-by: Stephen M. Cameron <scameron@beardog.cce.hp.com> Signed-off-by: James Bottomley <JBottomley@Parallels.com>
This commit is contained in:
committed by
James Bottomley
parent
f2d7e40e80
commit
775bf27738
@@ -4271,7 +4271,9 @@ static void stop_controller_lockup_detector(struct ctlr_info *h)
|
|||||||
remove_ctlr_from_lockup_detector_list(h);
|
remove_ctlr_from_lockup_detector_list(h);
|
||||||
/* If the list of ctlr's to monitor is empty, stop the thread */
|
/* If the list of ctlr's to monitor is empty, stop the thread */
|
||||||
if (list_empty(&hpsa_ctlr_list)) {
|
if (list_empty(&hpsa_ctlr_list)) {
|
||||||
|
spin_unlock_irqrestore(&lockup_detector_lock, flags);
|
||||||
kthread_stop(hpsa_lockup_detector);
|
kthread_stop(hpsa_lockup_detector);
|
||||||
|
spin_lock_irqsave(&lockup_detector_lock, flags);
|
||||||
hpsa_lockup_detector = NULL;
|
hpsa_lockup_detector = NULL;
|
||||||
}
|
}
|
||||||
spin_unlock_irqrestore(&lockup_detector_lock, flags);
|
spin_unlock_irqrestore(&lockup_detector_lock, flags);
|
||||||
|
Reference in New Issue
Block a user