Hi, On Fri, Sep 28, 2012 at 06:23:11PM +0530, Kishon Vijay Abraham I wrote: > Before accessing any register, runtime API's should be invoked to enable > the clocks. runtime API's are added here to prevent abort during register > access. > > Signed-off-by: Kishon Vijay Abraham I <kishon@xxxxxx> > --- > drivers/usb/dwc3/dwc3-omap.c | 10 ++++++++++ > 1 file changed, 10 insertions(+) > > diff --git a/drivers/usb/dwc3/dwc3-omap.c b/drivers/usb/dwc3/dwc3-omap.c > index 34578de..6a0e17f 100644 > --- a/drivers/usb/dwc3/dwc3-omap.c > +++ b/drivers/usb/dwc3/dwc3-omap.c > @@ -43,6 +43,7 @@ > #include <linux/spinlock.h> > #include <linux/platform_device.h> > #include <linux/platform_data/dwc3-omap.h> > +#include <linux/pm_runtime.h> > #include <linux/dma-mapping.h> > #include <linux/ioport.h> > #include <linux/io.h> > @@ -281,6 +282,13 @@ static int __devinit dwc3_omap_probe(struct platform_device *pdev) > omap->irq = irq; > omap->base = base; > > + pm_runtime_enable(dev); > + ret = pm_runtime_get_sync(dev); > + if (ret < 0) { > + dev_err(dev, "get_sync failed with err %d\n", ret); > + goto err1; > + } > + > reg = dwc3_omap_readl(omap->base, USBOTGSS_UTMI_OTG_STATUS); > > utmi_mode = of_get_property(node, "utmi-mode", &size); > @@ -354,6 +362,8 @@ err1: > static int __devexit dwc3_omap_remove(struct platform_device *pdev) > { > device_for_each_child(&pdev->dev, NULL, dwc3_remove_core); > + pm_runtime_put(&pdev->dev); > + pm_runtime_disable(&pdev->dev); You're going to disable pm_runtime here, so it's better to use pm_runtime_put_sync(), I guess ?? -- balbi
Attachment:
signature.asc
Description: Digital signature