mutex_unlock(&genpd->lock);
 
-       /*
-        * Even if the PM domain is powered off at this point, we can't expect
-        * it to remain in that state during the entire system PM suspend
-        * phase. Any subsystem/driver for a device in the PM domain, may still
-        * need to serve a request which may require the device to be runtime
-        * resumed and its PM domain to be powered.
-        *
-        * As we are disabling runtime PM at this point, we are preventing the
-        * subsystem/driver to decide themselves. For that reason, we need to
-        * make sure the device is operational as it may be required in some
-        * cases.
-        */
-       pm_runtime_resume(dev);
-       __pm_runtime_disable(dev, false);
-
        ret = pm_generic_prepare(dev);
        if (ret) {
                mutex_lock(&genpd->lock);
                genpd->prepared_count--;
 
                mutex_unlock(&genpd->lock);
-               pm_runtime_enable(dev);
        }
 
        return ret;
        if (dev->power.wakeup_path && genpd_dev_active_wakeup(genpd, dev))
                return 0;
 
-       genpd_stop_dev(genpd, dev);
-
        /*
         * Since all of the "noirq" callbacks are executed sequentially, it is
         * guaranteed that this function will never run twice in parallel for
        pm_genpd_sync_poweron(genpd, true);
        genpd->suspended_count--;
 
-       return genpd_start_dev(genpd, dev);
+       return 0;
 }
 
 /**
        if (IS_ERR(genpd))
                return -EINVAL;
 
-       return genpd_stop_dev(genpd, dev);
+       return 0;
 }
 
 /**
        if (IS_ERR(genpd))
                return -EINVAL;
 
-       return genpd_start_dev(genpd, dev);
+       return 0;
 }
 
 /**
 
        pm_genpd_sync_poweron(genpd, true);
 
-       return genpd_start_dev(genpd, dev);
+       return 0;
 }
 
 /**
        if (IS_ERR(genpd))
                return;
 
+       pm_generic_complete(dev);
+
        mutex_lock(&genpd->lock);
 
        genpd->prepared_count--;
+       if (!genpd->prepared_count)
+               genpd_queue_power_off_work(genpd);
 
        mutex_unlock(&genpd->lock);
-
-       pm_generic_complete(dev);
-       pm_runtime_set_active(dev);
-       pm_runtime_enable(dev);
 }
 
 /**