From b6b87eb7233dc225149af78f139565b045899db5 Mon Sep 17 00:00:00 2001 From: Aaron Lu Date: Fri, 9 Nov 2012 15:27:52 +0800 Subject: [PATCH] --- yaml --- r: 343733 b: refs/heads/master c: 63347905dbc105bf4921c5e24e128b5819b74c9f h: refs/heads/master i: 343731: 9ee71a8290afb9229a23403ccb3dbb86a2c9eab8 v: v3 --- [refs] | 2 +- trunk/drivers/scsi/scsi_pm.c | 23 +++++++++++------------ 2 files changed, 12 insertions(+), 13 deletions(-) diff --git a/[refs] b/[refs] index 5522a7768521..6fd75cf41bbd 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: a01475637c70a4a484dd315a90bf2df518f07705 +refs/heads/master: 63347905dbc105bf4921c5e24e128b5819b74c9f diff --git a/trunk/drivers/scsi/scsi_pm.c b/trunk/drivers/scsi/scsi_pm.c index dc0ad85853e2..d4201ded3b22 100644 --- a/trunk/drivers/scsi/scsi_pm.c +++ b/trunk/drivers/scsi/scsi_pm.c @@ -76,24 +76,23 @@ static int scsi_bus_resume_common(struct device *dev) { int err = 0; - /* - * Parent device may have runtime suspended as soon as - * it is woken up during the system resume. - * - * Resume it on behalf of child. - */ - pm_runtime_get_sync(dev->parent); - - if (scsi_is_sdev_device(dev)) + if (scsi_is_sdev_device(dev)) { + /* + * Parent device may have runtime suspended as soon as + * it is woken up during the system resume. + * + * Resume it on behalf of child. + */ + pm_runtime_get_sync(dev->parent); err = scsi_dev_type_resume(dev); + pm_runtime_put_sync(dev->parent); + } + if (err == 0) { pm_runtime_disable(dev); pm_runtime_set_active(dev); pm_runtime_enable(dev); } - - pm_runtime_put_sync(dev->parent); - return err; }