* [PATCH 1/2] usb: xhci: plat: Enable runtime PM
@ 2016-07-25 18:47 robert.foss
2016-07-25 18:47 ` [PATCH 2/2] usb: xhci: plat: Enable async suspend/resume robert.foss
2016-07-25 18:54 ` [PATCH 1/2] usb: xhci: plat: Enable runtime PM Greg KH
0 siblings, 2 replies; 3+ messages in thread
From: robert.foss @ 2016-07-25 18:47 UTC (permalink / raw)
To: mathias.nyman, gregkh, linux-usb, linux-kernel, abrestic
From: Andrew Bresticker <abrestic@chromium.org>
Enable runtime PM for the xhci-plat device so that the parent device
may implement runtime PM.
Signed-off-by: Andrew Bresticker <abrestic@chromium.org>
---
drivers/usb/host/xhci-plat.c | 19 +++++++++++++++++--
1 file changed, 17 insertions(+), 2 deletions(-)
diff --git a/drivers/usb/host/xhci-plat.c b/drivers/usb/host/xhci-plat.c
index 05647e6..1927950 100644
--- a/drivers/usb/host/xhci-plat.c
+++ b/drivers/usb/host/xhci-plat.c
@@ -182,6 +182,9 @@ static int xhci_plat_probe(struct platform_device *pdev)
if (ret)
goto dealloc_usb2_hcd;
+ pm_runtime_set_active(&pdev->dev);
+ pm_runtime_enable(&pdev->dev);
+
return 0;
@@ -210,6 +213,8 @@ static int xhci_plat_remove(struct platform_device *dev)
struct xhci_hcd *xhci = hcd_to_xhci(hcd);
struct clk *clk = xhci->clk;
+ pm_runtime_disable(&dev->dev);
+
usb_remove_hcd(xhci->shared_hcd);
usb_phy_shutdown(hcd->usb_phy);
@@ -228,7 +233,9 @@ static int xhci_plat_suspend(struct device *dev)
{
struct usb_hcd *hcd = dev_get_drvdata(dev);
struct xhci_hcd *xhci = hcd_to_xhci(hcd);
+ int ret;
+ pm_runtime_get_sync(dev);
/*
* xhci_suspend() needs `do_wakeup` to know whether host is allowed
* to do wakeup during suspend. Since xhci_plat_suspend is currently
@@ -237,15 +244,23 @@ static int xhci_plat_suspend(struct device *dev)
* reconsider this when xhci_plat_suspend enlarges its scope, e.g.,
* also applies to runtime suspend.
*/
- return xhci_suspend(xhci, device_may_wakeup(dev));
+ ret = xhci_suspend(xhci, device_may_wakeup(dev));
+ pm_runtime_put(dev);
+
+ return ret;
}
static int xhci_plat_resume(struct device *dev)
{
struct usb_hcd *hcd = dev_get_drvdata(dev);
struct xhci_hcd *xhci = hcd_to_xhci(hcd);
+ int ret;
- return xhci_resume(xhci, 0);
+ pm_runtime_get_sync(dev);
+ ret = xhci_resume(xhci, 0);
+ pm_runtime_put(dev);
+
+ return ret;
}
static const struct dev_pm_ops xhci_plat_pm_ops = {
--
2.7.4
^ permalink raw reply related [flat|nested] 3+ messages in thread
* [PATCH 2/2] usb: xhci: plat: Enable async suspend/resume
2016-07-25 18:47 [PATCH 1/2] usb: xhci: plat: Enable runtime PM robert.foss
@ 2016-07-25 18:47 ` robert.foss
2016-07-25 18:54 ` [PATCH 1/2] usb: xhci: plat: Enable runtime PM Greg KH
1 sibling, 0 replies; 3+ messages in thread
From: robert.foss @ 2016-07-25 18:47 UTC (permalink / raw)
To: mathias.nyman, gregkh, linux-usb, linux-kernel, abrestic
From: Andrew Bresticker <abrestic@chromium.org>
USB host controllers can take a significant amount of time to suspend
and resume, adding several hundred miliseconds to the kernel resume
time. Since the XHCI controller has no outside dependencies (other than
clocks, which are suspended late/resumed early), allow it to suspend and
resume asynchronously.
Signed-off-by: Andrew Bresticker <abrestic@chromium.org>
---
drivers/usb/host/xhci-plat.c | 1 +
1 file changed, 1 insertion(+)
diff --git a/drivers/usb/host/xhci-plat.c b/drivers/usb/host/xhci-plat.c
index 1927950..40d43c8 100644
--- a/drivers/usb/host/xhci-plat.c
+++ b/drivers/usb/host/xhci-plat.c
@@ -184,6 +184,7 @@ static int xhci_plat_probe(struct platform_device *pdev)
pm_runtime_set_active(&pdev->dev);
pm_runtime_enable(&pdev->dev);
+ device_enable_async_suspend(&pdev->dev);
return 0;
--
2.7.4
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH 1/2] usb: xhci: plat: Enable runtime PM
2016-07-25 18:47 [PATCH 1/2] usb: xhci: plat: Enable runtime PM robert.foss
2016-07-25 18:47 ` [PATCH 2/2] usb: xhci: plat: Enable async suspend/resume robert.foss
@ 2016-07-25 18:54 ` Greg KH
1 sibling, 0 replies; 3+ messages in thread
From: Greg KH @ 2016-07-25 18:54 UTC (permalink / raw)
To: robert.foss; +Cc: mathias.nyman, linux-usb, linux-kernel, abrestic
On Mon, Jul 25, 2016 at 02:47:53PM -0400, robert.foss@collabora.com wrote:
> From: Andrew Bresticker <abrestic@chromium.org>
>
> Enable runtime PM for the xhci-plat device so that the parent device
> may implement runtime PM.
>
> Signed-off-by: Andrew Bresticker <abrestic@chromium.org>
Why are you forwarding on patches without adding your signed-off-by to
them? Sorry, I can't take them without that...
greg k-h
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2016-07-25 18:54 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-07-25 18:47 [PATCH 1/2] usb: xhci: plat: Enable runtime PM robert.foss
2016-07-25 18:47 ` [PATCH 2/2] usb: xhci: plat: Enable async suspend/resume robert.foss
2016-07-25 18:54 ` [PATCH 1/2] usb: xhci: plat: Enable runtime PM Greg KH
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox