aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/s390/block/dasd.c
diff options
context:
space:
mode:
authorStefan Haberland <stefan.haberland@de.ibm.com>2011-01-05 06:48:05 -0500
committerMartin Schwidefsky <sky@mschwide.boeblingen.de.ibm.com>2011-01-05 06:47:30 -0500
commit6f272b9cec285a9610a2acf101f694bc58bed37e (patch)
tree5c333d47bfaefa34ccd827744f35381133f4444b /drivers/s390/block/dasd.c
parent5a27e60dec59a95bd7f8ae9a19ae2ede4f76395b (diff)
[S390] dasd: Prevent deadlock during suspend/resume.
The freeze callback may set a stop bit so that a worker thread could not start I/O. The discipline specific freeze function waits for the worker to be completed. Set the stop_bit after the discipline specific freeze function has returned and no worker is running. Signed-off-by: Stefan Haberland <stefan.haberland@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'drivers/s390/block/dasd.c')
-rw-r--r--drivers/s390/block/dasd.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/s390/block/dasd.c b/drivers/s390/block/dasd.c
index f16afe74464f..82d9ce36bd0b 100644
--- a/drivers/s390/block/dasd.c
+++ b/drivers/s390/block/dasd.c
@@ -2769,6 +2769,10 @@ int dasd_generic_pm_freeze(struct ccw_device *cdev)
2769 2769
2770 if (IS_ERR(device)) 2770 if (IS_ERR(device))
2771 return PTR_ERR(device); 2771 return PTR_ERR(device);
2772
2773 if (device->discipline->freeze)
2774 rc = device->discipline->freeze(device);
2775
2772 /* disallow new I/O */ 2776 /* disallow new I/O */
2773 dasd_device_set_stop_bits(device, DASD_STOPPED_PM); 2777 dasd_device_set_stop_bits(device, DASD_STOPPED_PM);
2774 /* clear active requests */ 2778 /* clear active requests */
@@ -2805,9 +2809,6 @@ int dasd_generic_pm_freeze(struct ccw_device *cdev)
2805 list_splice_tail(&freeze_queue, &device->ccw_queue); 2809 list_splice_tail(&freeze_queue, &device->ccw_queue);
2806 spin_unlock_irq(get_ccwdev_lock(cdev)); 2810 spin_unlock_irq(get_ccwdev_lock(cdev));
2807 2811
2808 if (device->discipline->freeze)
2809 rc = device->discipline->freeze(device);
2810
2811 dasd_put_device(device); 2812 dasd_put_device(device);
2812 return rc; 2813 return rc;
2813} 2814}