Commit 4edf6f70 authored by Ulf Hansson's avatar Ulf Hansson

Merge branch 'mmc_pinctrl' into next

Merge an immutable pinctrl branch from Linus Walleij's tree, which enables
pinctrl code consolidations for mmc.
Signed-off-by: default avatarUlf Hansson <ulf.hansson@linaro.org>
parents 7e0b2c32 8e9a9936
...@@ -2645,7 +2645,7 @@ static int atmci_runtime_resume(struct device *dev) ...@@ -2645,7 +2645,7 @@ static int atmci_runtime_resume(struct device *dev)
{ {
struct atmel_mci *host = dev_get_drvdata(dev); struct atmel_mci *host = dev_get_drvdata(dev);
pinctrl_pm_select_default_state(dev); pinctrl_select_default_state(dev);
return clk_prepare_enable(host->mck); return clk_prepare_enable(host->mck);
} }
......
...@@ -1108,7 +1108,7 @@ static int jz4740_mmc_suspend(struct device *dev) ...@@ -1108,7 +1108,7 @@ static int jz4740_mmc_suspend(struct device *dev)
static int jz4740_mmc_resume(struct device *dev) static int jz4740_mmc_resume(struct device *dev)
{ {
return pinctrl_pm_select_default_state(dev); return pinctrl_select_default_state(dev);
} }
static SIMPLE_DEV_PM_OPS(jz4740_mmc_pm_ops, jz4740_mmc_suspend, static SIMPLE_DEV_PM_OPS(jz4740_mmc_pm_ops, jz4740_mmc_suspend,
......
...@@ -161,7 +161,6 @@ struct meson_host { ...@@ -161,7 +161,6 @@ struct meson_host {
bool dram_access_quirk; bool dram_access_quirk;
struct pinctrl *pinctrl; struct pinctrl *pinctrl;
struct pinctrl_state *pins_default;
struct pinctrl_state *pins_clk_gate; struct pinctrl_state *pins_clk_gate;
unsigned int bounce_buf_size; unsigned int bounce_buf_size;
...@@ -327,7 +326,7 @@ static void meson_mmc_clk_ungate(struct meson_host *host) ...@@ -327,7 +326,7 @@ static void meson_mmc_clk_ungate(struct meson_host *host)
u32 cfg; u32 cfg;
if (host->pins_clk_gate) if (host->pins_clk_gate)
pinctrl_select_state(host->pinctrl, host->pins_default); pinctrl_select_default_state(host->dev);
/* Make sure the clock is not stopped in the controller */ /* Make sure the clock is not stopped in the controller */
cfg = readl(host->regs + SD_EMMC_CFG); cfg = readl(host->regs + SD_EMMC_CFG);
...@@ -1101,13 +1100,6 @@ static int meson_mmc_probe(struct platform_device *pdev) ...@@ -1101,13 +1100,6 @@ static int meson_mmc_probe(struct platform_device *pdev)
goto free_host; goto free_host;
} }
host->pins_default = pinctrl_lookup_state(host->pinctrl,
PINCTRL_STATE_DEFAULT);
if (IS_ERR(host->pins_default)) {
ret = PTR_ERR(host->pins_default);
goto free_host;
}
host->pins_clk_gate = pinctrl_lookup_state(host->pinctrl, host->pins_clk_gate = pinctrl_lookup_state(host->pinctrl,
"clk-gate"); "clk-gate");
if (IS_ERR(host->pins_clk_gate)) { if (IS_ERR(host->pins_clk_gate)) {
......
...@@ -1704,7 +1704,7 @@ static void mmci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios) ...@@ -1704,7 +1704,7 @@ static void mmci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
if (ios->bus_mode == MMC_BUSMODE_OPENDRAIN) if (ios->bus_mode == MMC_BUSMODE_OPENDRAIN)
pinctrl_select_state(host->pinctrl, host->pins_opendrain); pinctrl_select_state(host->pinctrl, host->pins_opendrain);
else else
pinctrl_select_state(host->pinctrl, host->pins_default); pinctrl_select_default_state(mmc_dev(mmc));
} }
/* /*
...@@ -1877,14 +1877,6 @@ static int mmci_probe(struct amba_device *dev, ...@@ -1877,14 +1877,6 @@ static int mmci_probe(struct amba_device *dev,
goto host_free; goto host_free;
} }
host->pins_default = pinctrl_lookup_state(host->pinctrl,
PINCTRL_STATE_DEFAULT);
if (IS_ERR(host->pins_default)) {
dev_err(mmc_dev(mmc), "Can't select default pins\n");
ret = PTR_ERR(host->pins_default);
goto host_free;
}
host->pins_opendrain = pinctrl_lookup_state(host->pinctrl, host->pins_opendrain = pinctrl_lookup_state(host->pinctrl,
MMCI_PINCTRL_STATE_OPENDRAIN); MMCI_PINCTRL_STATE_OPENDRAIN);
if (IS_ERR(host->pins_opendrain)) { if (IS_ERR(host->pins_opendrain)) {
...@@ -2203,7 +2195,7 @@ static int mmci_runtime_resume(struct device *dev) ...@@ -2203,7 +2195,7 @@ static int mmci_runtime_resume(struct device *dev)
struct mmci_host *host = mmc_priv(mmc); struct mmci_host *host = mmc_priv(mmc);
clk_prepare_enable(host->clk); clk_prepare_enable(host->clk);
mmci_restore(host); mmci_restore(host);
pinctrl_pm_select_default_state(dev); pinctrl_select_default_state(dev);
} }
return 0; return 0;
......
...@@ -404,7 +404,6 @@ struct mmci_host { ...@@ -404,7 +404,6 @@ struct mmci_host {
struct mmci_host_ops *ops; struct mmci_host_ops *ops;
struct variant_data *variant; struct variant_data *variant;
struct pinctrl *pinctrl; struct pinctrl *pinctrl;
struct pinctrl_state *pins_default;
struct pinctrl_state *pins_opendrain; struct pinctrl_state *pins_opendrain;
u8 hw_designer; u8 hw_designer;
......
...@@ -1605,12 +1605,6 @@ static int omap_hsmmc_configure_wake_irq(struct omap_hsmmc_host *host) ...@@ -1605,12 +1605,6 @@ static int omap_hsmmc_configure_wake_irq(struct omap_hsmmc_host *host)
ret = PTR_ERR(p); ret = PTR_ERR(p);
goto err_free_irq; goto err_free_irq;
} }
if (IS_ERR(pinctrl_lookup_state(p, PINCTRL_STATE_DEFAULT))) {
dev_info(host->dev, "missing default pinctrl state\n");
devm_pinctrl_put(p);
ret = -EINVAL;
goto err_free_irq;
}
if (IS_ERR(pinctrl_lookup_state(p, PINCTRL_STATE_IDLE))) { if (IS_ERR(pinctrl_lookup_state(p, PINCTRL_STATE_IDLE))) {
dev_info(host->dev, "missing idle pinctrl state\n"); dev_info(host->dev, "missing idle pinctrl state\n");
...@@ -2153,14 +2147,14 @@ static int omap_hsmmc_runtime_resume(struct device *dev) ...@@ -2153,14 +2147,14 @@ static int omap_hsmmc_runtime_resume(struct device *dev)
if ((host->mmc->caps & MMC_CAP_SDIO_IRQ) && if ((host->mmc->caps & MMC_CAP_SDIO_IRQ) &&
(host->flags & HSMMC_SDIO_IRQ_ENABLED)) { (host->flags & HSMMC_SDIO_IRQ_ENABLED)) {
pinctrl_pm_select_default_state(host->dev); pinctrl_select_default_state(host->dev);
/* irq lost, if pinmux incorrect */ /* irq lost, if pinmux incorrect */
OMAP_HSMMC_WRITE(host->base, STAT, STAT_CLEAR); OMAP_HSMMC_WRITE(host->base, STAT, STAT_CLEAR);
OMAP_HSMMC_WRITE(host->base, ISE, CIRQ_EN); OMAP_HSMMC_WRITE(host->base, ISE, CIRQ_EN);
OMAP_HSMMC_WRITE(host->base, IE, CIRQ_EN); OMAP_HSMMC_WRITE(host->base, IE, CIRQ_EN);
} else { } else {
pinctrl_pm_select_default_state(host->dev); pinctrl_select_default_state(host->dev);
} }
spin_unlock_irqrestore(&host->irq_lock, flags); spin_unlock_irqrestore(&host->irq_lock, flags);
return 0; return 0;
......
...@@ -224,7 +224,6 @@ static struct esdhc_soc_data usdhc_imx8qxp_data = { ...@@ -224,7 +224,6 @@ static struct esdhc_soc_data usdhc_imx8qxp_data = {
struct pltfm_imx_data { struct pltfm_imx_data {
u32 scratchpad; u32 scratchpad;
struct pinctrl *pinctrl; struct pinctrl *pinctrl;
struct pinctrl_state *pins_default;
struct pinctrl_state *pins_100mhz; struct pinctrl_state *pins_100mhz;
struct pinctrl_state *pins_200mhz; struct pinctrl_state *pins_200mhz;
const struct esdhc_soc_data *socdata; const struct esdhc_soc_data *socdata;
...@@ -951,7 +950,6 @@ static int esdhc_change_pinstate(struct sdhci_host *host, ...@@ -951,7 +950,6 @@ static int esdhc_change_pinstate(struct sdhci_host *host,
dev_dbg(mmc_dev(host->mmc), "change pinctrl state for uhs %d\n", uhs); dev_dbg(mmc_dev(host->mmc), "change pinctrl state for uhs %d\n", uhs);
if (IS_ERR(imx_data->pinctrl) || if (IS_ERR(imx_data->pinctrl) ||
IS_ERR(imx_data->pins_default) ||
IS_ERR(imx_data->pins_100mhz) || IS_ERR(imx_data->pins_100mhz) ||
IS_ERR(imx_data->pins_200mhz)) IS_ERR(imx_data->pins_200mhz))
return -EINVAL; return -EINVAL;
...@@ -968,7 +966,7 @@ static int esdhc_change_pinstate(struct sdhci_host *host, ...@@ -968,7 +966,7 @@ static int esdhc_change_pinstate(struct sdhci_host *host,
break; break;
default: default:
/* back to default state for other legacy timing */ /* back to default state for other legacy timing */
pinctrl = imx_data->pins_default; return pinctrl_select_default_state(mmc_dev(host->mmc));
} }
return pinctrl_select_state(imx_data->pinctrl, pinctrl); return pinctrl_select_state(imx_data->pinctrl, pinctrl);
...@@ -1338,7 +1336,7 @@ sdhci_esdhc_imx_probe_dt(struct platform_device *pdev, ...@@ -1338,7 +1336,7 @@ sdhci_esdhc_imx_probe_dt(struct platform_device *pdev,
mmc_of_parse_voltage(np, &host->ocr_mask); mmc_of_parse_voltage(np, &host->ocr_mask);
if (esdhc_is_usdhc(imx_data) && !IS_ERR(imx_data->pins_default)) { if (esdhc_is_usdhc(imx_data)) {
imx_data->pins_100mhz = pinctrl_lookup_state(imx_data->pinctrl, imx_data->pins_100mhz = pinctrl_lookup_state(imx_data->pinctrl,
ESDHC_PINCTRL_STATE_100MHZ); ESDHC_PINCTRL_STATE_100MHZ);
imx_data->pins_200mhz = pinctrl_lookup_state(imx_data->pinctrl, imx_data->pins_200mhz = pinctrl_lookup_state(imx_data->pinctrl,
...@@ -1492,11 +1490,6 @@ static int sdhci_esdhc_imx_probe(struct platform_device *pdev) ...@@ -1492,11 +1490,6 @@ static int sdhci_esdhc_imx_probe(struct platform_device *pdev)
goto disable_ahb_clk; goto disable_ahb_clk;
} }
imx_data->pins_default = pinctrl_lookup_state(imx_data->pinctrl,
PINCTRL_STATE_DEFAULT);
if (IS_ERR(imx_data->pins_default))
dev_warn(mmc_dev(host->mmc), "could not get default state\n");
if (esdhc_is_usdhc(imx_data)) { if (esdhc_is_usdhc(imx_data)) {
host->quirks2 |= SDHCI_QUIRK2_PRESET_VALUE_BROKEN; host->quirks2 |= SDHCI_QUIRK2_PRESET_VALUE_BROKEN;
host->mmc->caps |= MMC_CAP_1_8V_DDR | MMC_CAP_3_3V_DDR; host->mmc->caps |= MMC_CAP_1_8V_DDR | MMC_CAP_3_3V_DDR;
......
...@@ -59,7 +59,6 @@ ...@@ -59,7 +59,6 @@
struct uniphier_sd_priv { struct uniphier_sd_priv {
struct tmio_mmc_data tmio_data; struct tmio_mmc_data tmio_data;
struct pinctrl *pinctrl; struct pinctrl *pinctrl;
struct pinctrl_state *pinstate_default;
struct pinctrl_state *pinstate_uhs; struct pinctrl_state *pinstate_uhs;
struct clk *clk; struct clk *clk;
struct reset_control *rst; struct reset_control *rst;
...@@ -500,13 +499,12 @@ static int uniphier_sd_start_signal_voltage_switch(struct mmc_host *mmc, ...@@ -500,13 +499,12 @@ static int uniphier_sd_start_signal_voltage_switch(struct mmc_host *mmc,
{ {
struct tmio_mmc_host *host = mmc_priv(mmc); struct tmio_mmc_host *host = mmc_priv(mmc);
struct uniphier_sd_priv *priv = uniphier_sd_priv(host); struct uniphier_sd_priv *priv = uniphier_sd_priv(host);
struct pinctrl_state *pinstate; struct pinctrl_state *pinstate = NULL;
u32 val, tmp; u32 val, tmp;
switch (ios->signal_voltage) { switch (ios->signal_voltage) {
case MMC_SIGNAL_VOLTAGE_330: case MMC_SIGNAL_VOLTAGE_330:
val = UNIPHIER_SD_VOLT_330; val = UNIPHIER_SD_VOLT_330;
pinstate = priv->pinstate_default;
break; break;
case MMC_SIGNAL_VOLTAGE_180: case MMC_SIGNAL_VOLTAGE_180:
val = UNIPHIER_SD_VOLT_180; val = UNIPHIER_SD_VOLT_180;
...@@ -521,7 +519,10 @@ static int uniphier_sd_start_signal_voltage_switch(struct mmc_host *mmc, ...@@ -521,7 +519,10 @@ static int uniphier_sd_start_signal_voltage_switch(struct mmc_host *mmc,
tmp |= FIELD_PREP(UNIPHIER_SD_VOLT_MASK, val); tmp |= FIELD_PREP(UNIPHIER_SD_VOLT_MASK, val);
writel(tmp, host->ctl + UNIPHIER_SD_VOLT); writel(tmp, host->ctl + UNIPHIER_SD_VOLT);
if (pinstate)
pinctrl_select_state(priv->pinctrl, pinstate); pinctrl_select_state(priv->pinctrl, pinstate);
else
pinctrl_select_default_state(mmc_dev(mmc));
return 0; return 0;
} }
...@@ -533,11 +534,6 @@ static int uniphier_sd_uhs_init(struct tmio_mmc_host *host, ...@@ -533,11 +534,6 @@ static int uniphier_sd_uhs_init(struct tmio_mmc_host *host,
if (IS_ERR(priv->pinctrl)) if (IS_ERR(priv->pinctrl))
return PTR_ERR(priv->pinctrl); return PTR_ERR(priv->pinctrl);
priv->pinstate_default = pinctrl_lookup_state(priv->pinctrl,
PINCTRL_STATE_DEFAULT);
if (IS_ERR(priv->pinstate_default))
return PTR_ERR(priv->pinstate_default);
priv->pinstate_uhs = pinctrl_lookup_state(priv->pinctrl, "uhs"); priv->pinstate_uhs = pinctrl_lookup_state(priv->pinctrl, "uhs");
if (IS_ERR(priv->pinstate_uhs)) if (IS_ERR(priv->pinstate_uhs))
return PTR_ERR(priv->pinstate_uhs); return PTR_ERR(priv->pinstate_uhs);
......
...@@ -199,7 +199,6 @@ struct usdhi6_host { ...@@ -199,7 +199,6 @@ struct usdhi6_host {
/* Pin control */ /* Pin control */
struct pinctrl *pinctrl; struct pinctrl *pinctrl;
struct pinctrl_state *pins_default;
struct pinctrl_state *pins_uhs; struct pinctrl_state *pins_uhs;
}; };
...@@ -1162,8 +1161,7 @@ static int usdhi6_set_pinstates(struct usdhi6_host *host, int voltage) ...@@ -1162,8 +1161,7 @@ static int usdhi6_set_pinstates(struct usdhi6_host *host, int voltage)
host->pins_uhs); host->pins_uhs);
default: default:
return pinctrl_select_state(host->pinctrl, return pinctrl_select_default_state(mmc_dev(host->mmc));
host->pins_default);
} }
} }
...@@ -1770,17 +1768,6 @@ static int usdhi6_probe(struct platform_device *pdev) ...@@ -1770,17 +1768,6 @@ static int usdhi6_probe(struct platform_device *pdev)
} }
host->pins_uhs = pinctrl_lookup_state(host->pinctrl, "state_uhs"); host->pins_uhs = pinctrl_lookup_state(host->pinctrl, "state_uhs");
if (!IS_ERR(host->pins_uhs)) {
host->pins_default = pinctrl_lookup_state(host->pinctrl,
PINCTRL_STATE_DEFAULT);
if (IS_ERR(host->pins_default)) {
dev_err(dev,
"UHS pinctrl requires a default pin state.\n");
ret = PTR_ERR(host->pins_default);
goto e_free_mmc;
}
}
res = platform_get_resource(pdev, IORESOURCE_MEM, 0); res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
host->base = devm_ioremap_resource(dev, res); host->base = devm_ioremap_resource(dev, res);
......
...@@ -1535,14 +1535,7 @@ int pinctrl_init_done(struct device *dev) ...@@ -1535,14 +1535,7 @@ int pinctrl_init_done(struct device *dev)
return ret; return ret;
} }
#ifdef CONFIG_PM static int pinctrl_select_bound_state(struct device *dev,
/**
* pinctrl_pm_select_state() - select pinctrl state for PM
* @dev: device to select default state for
* @state: state to set
*/
static int pinctrl_pm_select_state(struct device *dev,
struct pinctrl_state *state) struct pinctrl_state *state)
{ {
struct dev_pin_info *pins = dev->pins; struct dev_pin_info *pins = dev->pins;
...@@ -1558,15 +1551,27 @@ static int pinctrl_pm_select_state(struct device *dev, ...@@ -1558,15 +1551,27 @@ static int pinctrl_pm_select_state(struct device *dev,
} }
/** /**
* pinctrl_pm_select_default_state() - select default pinctrl state for PM * pinctrl_select_default_state() - select default pinctrl state
* @dev: device to select default state for * @dev: device to select default state for
*/ */
int pinctrl_pm_select_default_state(struct device *dev) int pinctrl_select_default_state(struct device *dev)
{ {
if (!dev->pins) if (!dev->pins)
return 0; return 0;
return pinctrl_pm_select_state(dev, dev->pins->default_state); return pinctrl_select_bound_state(dev, dev->pins->default_state);
}
EXPORT_SYMBOL_GPL(pinctrl_select_default_state);
#ifdef CONFIG_PM
/**
* pinctrl_pm_select_default_state() - select default pinctrl state for PM
* @dev: device to select default state for
*/
int pinctrl_pm_select_default_state(struct device *dev)
{
return pinctrl_select_default_state(dev);
} }
EXPORT_SYMBOL_GPL(pinctrl_pm_select_default_state); EXPORT_SYMBOL_GPL(pinctrl_pm_select_default_state);
...@@ -1579,7 +1584,7 @@ int pinctrl_pm_select_sleep_state(struct device *dev) ...@@ -1579,7 +1584,7 @@ int pinctrl_pm_select_sleep_state(struct device *dev)
if (!dev->pins) if (!dev->pins)
return 0; return 0;
return pinctrl_pm_select_state(dev, dev->pins->sleep_state); return pinctrl_select_bound_state(dev, dev->pins->sleep_state);
} }
EXPORT_SYMBOL_GPL(pinctrl_pm_select_sleep_state); EXPORT_SYMBOL_GPL(pinctrl_pm_select_sleep_state);
...@@ -1592,7 +1597,7 @@ int pinctrl_pm_select_idle_state(struct device *dev) ...@@ -1592,7 +1597,7 @@ int pinctrl_pm_select_idle_state(struct device *dev)
if (!dev->pins) if (!dev->pins)
return 0; return 0;
return pinctrl_pm_select_state(dev, dev->pins->idle_state); return pinctrl_select_bound_state(dev, dev->pins->idle_state);
} }
EXPORT_SYMBOL_GPL(pinctrl_pm_select_idle_state); EXPORT_SYMBOL_GPL(pinctrl_pm_select_idle_state);
#endif #endif
......
...@@ -40,6 +40,7 @@ extern int pinctrl_select_state(struct pinctrl *p, struct pinctrl_state *s); ...@@ -40,6 +40,7 @@ extern int pinctrl_select_state(struct pinctrl *p, struct pinctrl_state *s);
extern struct pinctrl * __must_check devm_pinctrl_get(struct device *dev); extern struct pinctrl * __must_check devm_pinctrl_get(struct device *dev);
extern void devm_pinctrl_put(struct pinctrl *p); extern void devm_pinctrl_put(struct pinctrl *p);
extern int pinctrl_select_default_state(struct device *dev);
#ifdef CONFIG_PM #ifdef CONFIG_PM
extern int pinctrl_pm_select_default_state(struct device *dev); extern int pinctrl_pm_select_default_state(struct device *dev);
...@@ -122,6 +123,11 @@ static inline void devm_pinctrl_put(struct pinctrl *p) ...@@ -122,6 +123,11 @@ static inline void devm_pinctrl_put(struct pinctrl *p)
{ {
} }
static inline int pinctrl_select_default_state(struct device *dev)
{
return 0;
}
static inline int pinctrl_pm_select_default_state(struct device *dev) static inline int pinctrl_pm_select_default_state(struct device *dev)
{ {
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment