* Tony Lindgren <tony@xxxxxxxxxxx> [130716 02:12]: > > As discussed earlier, the pinctrl support for changing some of the > consumer device pins during runtime needs some improvment. > > Here are the patches to do that, I'll also post a minimal sample > patch as a reply to this thread on how to do the muxing for > runtime PM. Here's a patch showing the suggested usage remuxing SDIO IRQ to GPIO mode for runtime PM. Note that this patch depends on three other patches for the hsmmc driver, I'll post that series separately. Regards, Tony From: Tony Lindgren <tony@xxxxxxxxxxx> Date: Mon, 15 Jul 2013 07:39:39 -0700 Subject: [PATCH] mmc: omap_hsmmc: Remux pins to support SDIO interrupt and PM runtime On some omaps we need to remux MMC pins for PM, and for some omaps we need to remux the SDIO IRQ pin. Based on an earlier patch by Andreas Fenkart <afenkart@xxxxxxxxx>. Cc: Andreas Fenkart <afenkart@xxxxxxxxx> Cc: Balaji T K <balajitk@xxxxxx> Cc: Linus Walleij <linus.walleij@xxxxxxxxxx> Signed-off-by: Tony Lindgren <tony@xxxxxxxxxxx> --- a/drivers/mmc/host/omap_hsmmc.c +++ b/drivers/mmc/host/omap_hsmmc.c @@ -1869,7 +1869,6 @@ static int omap_hsmmc_probe(struct platform_device *pdev) const struct of_device_id *match; dma_cap_mask_t mask; unsigned tx_req, rx_req; - struct pinctrl *pinctrl; match = of_match_device(of_match_ptr(omap_mmc_of_match), &pdev->dev); if (match) { @@ -2114,21 +2113,19 @@ static int omap_hsmmc_probe(struct platform_device *pdev) omap_hsmmc_disable_irq(host); - pinctrl = devm_pinctrl_get_select_default(&pdev->dev); - if (IS_ERR(pinctrl)) - dev_warn(&pdev->dev, - "pins are not configured from the driver\n"); - /* - * For now, only support SDIO interrupt if we are doing - * muxing of dat1 when booted with DT. This is because the + * For now, only support SDIO interrupt if we are doing dynamic + * remuxing of dat1 when booted with DT. This is because the * supposedly the wake-up events for CTPL don't work from deeper * idle states. And we don't want to add new legacy mux platform * init code callbacks any longer as we are moving to DT based * booting anyways. */ if (match) { - if (!IS_ERR(pinctrl) && mmc_slot(host).sdio_irq) + struct device *dev = &pdev->dev; + + if (!pinctrl_pm_check_idle_state(dev) && + mmc_slot(host).sdio_irq) mmc->caps |= MMC_CAP_SDIO_IRQ; } @@ -2348,6 +2345,10 @@ static int omap_hsmmc_runtime_suspend(struct device *dev) OMAP_HSMMC_WRITE(host->base, STAT, STAT_CLEAR); spin_unlock_irqrestore(&host->irq_lock, flags); + ret = pinctrl_pm_select_idle_state(dev); + if (ret < 0) + dev_err(dev, "Unable to select idle pinmux\n"); + if (mmc_slot(host).sdio_irq) enable_irq(mmc_slot(host).sdio_irq); } @@ -2371,6 +2372,10 @@ static int omap_hsmmc_runtime_resume(struct device *dev) if (mmc_slot(host).sdio_irq) disable_irq(mmc_slot(host).sdio_irq); + ret = pinctrl_pm_select_active_state(dev); + if (ret < 0) + dev_err(dev, "Unable to select active pinmux\n"); + spin_lock_irqsave(&host->irq_lock, flags); host->active_pinmux = true; -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html