提交 fa180eb4 编写于 作者: U Ulf Hansson 提交者: Greg Kroah-Hartman

PM / Runtime: Idle devices asynchronously after probe|release

Putting devices into idle|suspend in a synchronous manner means we are
waiting for each device to become idle|suspended before the probe|release
is fully done.

This patch switch to use the asynchronous runtime PM API:s instead and
thus improves the parallelism since we can move on and handle the next
device in queue in an earlier phase.
Signed-off-by: NUlf Hansson <ulf.hansson@linaro.org>
Acked-by: NKevin Hilman <khilman@linaro.org>
Acked-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
Cc: Alan Stern <stern@rowland.harvard.edu>
Acked-by: NLinus Walleij <linus.walleij@linaro.org>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 4e4098a3
...@@ -380,7 +380,7 @@ int driver_probe_device(struct device_driver *drv, struct device *dev) ...@@ -380,7 +380,7 @@ int driver_probe_device(struct device_driver *drv, struct device *dev)
pm_runtime_barrier(dev); pm_runtime_barrier(dev);
ret = really_probe(dev, drv); ret = really_probe(dev, drv);
pm_runtime_idle(dev); pm_request_idle(dev);
return ret; return ret;
} }
...@@ -428,7 +428,7 @@ int device_attach(struct device *dev) ...@@ -428,7 +428,7 @@ int device_attach(struct device *dev)
} }
} else { } else {
ret = bus_for_each_drv(dev->bus, NULL, dev, __device_attach); ret = bus_for_each_drv(dev->bus, NULL, dev, __device_attach);
pm_runtime_idle(dev); pm_request_idle(dev);
} }
out_unlock: out_unlock:
device_unlock(dev); device_unlock(dev);
...@@ -499,7 +499,7 @@ static void __device_release_driver(struct device *dev) ...@@ -499,7 +499,7 @@ static void __device_release_driver(struct device *dev)
BUS_NOTIFY_UNBIND_DRIVER, BUS_NOTIFY_UNBIND_DRIVER,
dev); dev);
pm_runtime_put_sync(dev); pm_runtime_put(dev);
if (dev->bus && dev->bus->remove) if (dev->bus && dev->bus->remove)
dev->bus->remove(dev); dev->bus->remove(dev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册