From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934807Ab3FSOGc (ORCPT ); Wed, 19 Jun 2013 10:06:32 -0400 Received: from devils.ext.ti.com ([198.47.26.153]:59616 "EHLO devils.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933853Ab3FSOG2 (ORCPT ); Wed, 19 Jun 2013 10:06:28 -0400 From: Roger Quadros To: , CC: , , , , , , Roger Quadros , Samuel Ortiz Subject: [RFC PATCH 2/6] mfd: omap-usb-host: Put pins in IDLE state on suspend Date: Wed, 19 Jun 2013 17:05:49 +0300 Message-ID: <1371650753-11452-3-git-send-email-rogerq@ti.com> X-Mailer: git-send-email 1.7.4.1 In-Reply-To: <1371650753-11452-1-git-send-email-rogerq@ti.com> References: <1371650753-11452-1-git-send-email-rogerq@ti.com> MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In order to support wake up from suspend use the pinctrl framework to put the USB host pins in IDLE state during suspend. CC: Samuel Ortiz Signed-off-by: Roger Quadros --- drivers/mfd/omap-usb-host.c | 46 +++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 46 insertions(+), 0 deletions(-) diff --git a/drivers/mfd/omap-usb-host.c b/drivers/mfd/omap-usb-host.c index 6601a49..171cc3b 100644 --- a/drivers/mfd/omap-usb-host.c +++ b/drivers/mfd/omap-usb-host.c @@ -31,6 +31,7 @@ #include #include #include +#include #include "omap-usb.h" @@ -111,6 +112,10 @@ struct usbhs_hcd_omap { struct usbhs_omap_platform_data *pdata; u32 usbhs_rev; + + struct pinctrl *pinctrl; + struct pinctrl_state *pins_default; + struct pinctrl_state *pins_idle; }; /*-------------------------------------------------------------------------*/ @@ -325,6 +330,10 @@ static int usbhs_runtime_resume(struct device *dev) dev_dbg(dev, "usbhs_runtime_resume\n"); + if (!IS_ERR(omap->pins_default)) + if (pinctrl_select_state(omap->pinctrl, omap->pins_default)) + dev_err(dev, "Could not select DEFAULT pin state\n"); + omap_tll_enable(pdata); if (!IS_ERR(omap->ehci_logic_fck)) @@ -402,6 +411,10 @@ static int usbhs_runtime_suspend(struct device *dev) omap_tll_disable(pdata); + if (!IS_ERR(omap->pins_idle)) + if (pinctrl_select_state(omap->pinctrl, omap->pins_idle)) + dev_err(dev, "Could not select IDLE pin state\n"); + return 0; } @@ -608,6 +621,30 @@ static int usbhs_omap_probe(struct platform_device *pdev) return -ENOMEM; } + omap->pinctrl = devm_pinctrl_get(dev); + if (!IS_ERR(omap->pinctrl)) { + omap->pins_default = pinctrl_lookup_state(omap->pinctrl, + PINCTRL_STATE_DEFAULT); + if (IS_ERR(omap->pins_default)) + dev_err(dev, "Could not get DEFAULT state pins\n"); + + omap->pins_idle = pinctrl_lookup_state(omap->pinctrl, + PINCTRL_STATE_IDLE); + if (IS_ERR(omap->pins_idle)) + dev_err(dev, "Could not get IDLE state pins\n"); + + } else { + dev_info(dev, "pinctrl_get error\n"); + if (PTR_ERR(omap->pinctrl) == -EPROBE_DEFER) { + dev_info(dev, "defer\n"); + return -EPROBE_DEFER; + } + + omap->pins_default = omap->pins_idle = ERR_PTR(-EINVAL); + dev_dbg(dev, "Proceeding without pinctrl: %ld\n", + PTR_ERR(omap->pinctrl)); + } + res = platform_get_resource(pdev, IORESOURCE_MEM, 0); omap->uhh_base = devm_ioremap_resource(dev, res); if (IS_ERR(omap->uhh_base)) @@ -796,6 +833,10 @@ static int usbhs_omap_probe(struct platform_device *pdev) } } + if (!IS_ERR(omap->pins_default)) + if (pinctrl_select_state(omap->pinctrl, omap->pins_default)) + dev_err(dev, "Could not select DEFAULT pin state\n"); + return 0; err_alloc: @@ -872,6 +913,11 @@ static int usbhs_omap_remove(struct platform_device *pdev) /* remove children */ device_for_each_child(&pdev->dev, NULL, usbhs_omap_remove_child); + + if (!IS_ERR(omap->pins_idle)) + if (pinctrl_select_state(omap->pinctrl, omap->pins_idle)) + dev_err(&pdev->dev, "Could not select IDLE pin state\n"); + return 0; } -- 1.7.4.1