|
|
@@ -79,8 +79,22 @@ static int scsi_dev_type_resume(struct device *dev,
|
|
|
|
|
|
if (err == 0) {
|
|
|
pm_runtime_disable(dev);
|
|
|
- pm_runtime_set_active(dev);
|
|
|
+ err = pm_runtime_set_active(dev);
|
|
|
pm_runtime_enable(dev);
|
|
|
+
|
|
|
+ /*
|
|
|
+ * Forcibly set runtime PM status of request queue to "active"
|
|
|
+ * to make sure we can again get requests from the queue
|
|
|
+ * (see also blk_pm_peek_request()).
|
|
|
+ *
|
|
|
+ * The resume hook will correct runtime PM status of the disk.
|
|
|
+ */
|
|
|
+ if (!err && scsi_is_sdev_device(dev)) {
|
|
|
+ struct scsi_device *sdev = to_scsi_device(dev);
|
|
|
+
|
|
|
+ if (sdev->request_queue->dev)
|
|
|
+ blk_set_runtime_active(sdev->request_queue);
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
return err;
|
|
|
@@ -139,16 +153,6 @@ static int scsi_bus_resume_common(struct device *dev,
|
|
|
else
|
|
|
fn = NULL;
|
|
|
|
|
|
- /*
|
|
|
- * Forcibly set runtime PM status of request queue to "active" to
|
|
|
- * make sure we can again get requests from the queue (see also
|
|
|
- * blk_pm_peek_request()).
|
|
|
- *
|
|
|
- * The resume hook will correct runtime PM status of the disk.
|
|
|
- */
|
|
|
- if (scsi_is_sdev_device(dev) && pm_runtime_suspended(dev))
|
|
|
- blk_set_runtime_active(to_scsi_device(dev)->request_queue);
|
|
|
-
|
|
|
if (fn) {
|
|
|
async_schedule_domain(fn, dev, &scsi_sd_pm_domain);
|
|
|
|