提交 5e2ea617 编写于 作者: A Adrian Hunter 提交者: Linus Torvalds

omap_hsmmc: make use of new enable/disable interface

For the moment enable / disable just turns the fclk on and off.
Signed-off-by: NAdrian Hunter <adrian.hunter@nokia.com>
Acked-by: NMatt Fleming <matt@console-pimps.org>
Cc: Ian Molton <ian@mnementh.co.uk>
Cc: "Roberto A. Foglietta" <roberto.foglietta@gmail.com>
Cc: Jarkko Lavinen <jarkko.lavinen@nokia.com>
Cc: Denis Karpov <ext-denis.2.karpov@nokia.com>
Cc: Pierre Ossman <pierre@ossman.eu>
Cc: Philip Langdale <philipl@overt.org>
Cc: "Madhusudhan" <madhu.cr@ti.com>
Cc: <linux-mmc@vger.kernel.org>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 d900f712
...@@ -605,7 +605,9 @@ static void mmc_omap_detect(struct work_struct *work) ...@@ -605,7 +605,9 @@ static void mmc_omap_detect(struct work_struct *work)
if (host->carddetect) { if (host->carddetect) {
mmc_detect_change(host->mmc, (HZ * 200) / 1000); mmc_detect_change(host->mmc, (HZ * 200) / 1000);
} else { } else {
mmc_host_enable(host->mmc);
mmc_omap_reset_controller_fsm(host, SRD); mmc_omap_reset_controller_fsm(host, SRD);
mmc_host_lazy_disable(host->mmc);
mmc_detect_change(host->mmc, (HZ * 50) / 1000); mmc_detect_change(host->mmc, (HZ * 50) / 1000);
} }
} }
...@@ -818,6 +820,27 @@ mmc_omap_prepare_data(struct mmc_omap_host *host, struct mmc_request *req) ...@@ -818,6 +820,27 @@ mmc_omap_prepare_data(struct mmc_omap_host *host, struct mmc_request *req)
return 0; return 0;
} }
static int omap_mmc_enable(struct mmc_host *mmc)
{
struct mmc_omap_host *host = mmc_priv(mmc);
int err;
err = clk_enable(host->fclk);
if (err)
return err;
dev_dbg(mmc_dev(host->mmc), "mmc_fclk: enabled\n");
return 0;
}
static int omap_mmc_disable(struct mmc_host *mmc, int lazy)
{
struct mmc_omap_host *host = mmc_priv(mmc);
clk_disable(host->fclk);
dev_dbg(mmc_dev(host->mmc), "mmc_fclk: disabled\n");
return 0;
}
/* /*
* Request function. for read/write operation * Request function. for read/write operation
*/ */
...@@ -841,6 +864,8 @@ static void omap_mmc_set_ios(struct mmc_host *mmc, struct mmc_ios *ios) ...@@ -841,6 +864,8 @@ static void omap_mmc_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
unsigned long timeout; unsigned long timeout;
u32 con; u32 con;
mmc_host_enable(host->mmc);
switch (ios->power_mode) { switch (ios->power_mode) {
case MMC_POWER_OFF: case MMC_POWER_OFF:
mmc_slot(host).set_power(host->dev, host->slot_id, 0, 0); mmc_slot(host).set_power(host->dev, host->slot_id, 0, 0);
...@@ -919,6 +944,8 @@ static void omap_mmc_set_ios(struct mmc_host *mmc, struct mmc_ios *ios) ...@@ -919,6 +944,8 @@ static void omap_mmc_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
if (ios->bus_mode == MMC_BUSMODE_OPENDRAIN) if (ios->bus_mode == MMC_BUSMODE_OPENDRAIN)
OMAP_HSMMC_WRITE(host->base, CON, OMAP_HSMMC_WRITE(host->base, CON,
OMAP_HSMMC_READ(host->base, CON) | OD); OMAP_HSMMC_READ(host->base, CON) | OD);
mmc_host_lazy_disable(host->mmc);
} }
static int omap_hsmmc_get_cd(struct mmc_host *mmc) static int omap_hsmmc_get_cd(struct mmc_host *mmc)
...@@ -969,6 +996,8 @@ static void omap_hsmmc_init(struct mmc_omap_host *host) ...@@ -969,6 +996,8 @@ static void omap_hsmmc_init(struct mmc_omap_host *host)
} }
static struct mmc_host_ops mmc_omap_ops = { static struct mmc_host_ops mmc_omap_ops = {
.enable = omap_mmc_enable,
.disable = omap_mmc_disable,
.request = omap_mmc_request, .request = omap_mmc_request,
.set_ios = omap_mmc_set_ios, .set_ios = omap_mmc_set_ios,
.get_cd = omap_hsmmc_get_cd, .get_cd = omap_hsmmc_get_cd,
...@@ -983,7 +1012,16 @@ static int mmc_regs_show(struct seq_file *s, void *data) ...@@ -983,7 +1012,16 @@ static int mmc_regs_show(struct seq_file *s, void *data)
struct mmc_host *mmc = s->private; struct mmc_host *mmc = s->private;
struct mmc_omap_host *host = mmc_priv(mmc); struct mmc_omap_host *host = mmc_priv(mmc);
seq_printf(s, "mmc%d regs:\n", mmc->index); seq_printf(s, "mmc%d:\n"
" enabled:\t%d\n"
" nesting_cnt:\t%d\n"
"\nregs:\n",
mmc->index, mmc->enabled ? 1 : 0, mmc->nesting_cnt);
if (clk_enable(host->fclk) != 0) {
seq_printf(s, "can't read the regs\n");
goto err;
}
seq_printf(s, "SYSCONFIG:\t0x%08x\n", seq_printf(s, "SYSCONFIG:\t0x%08x\n",
OMAP_HSMMC_READ(host->base, SYSCONFIG)); OMAP_HSMMC_READ(host->base, SYSCONFIG));
...@@ -999,6 +1037,9 @@ static int mmc_regs_show(struct seq_file *s, void *data) ...@@ -999,6 +1037,9 @@ static int mmc_regs_show(struct seq_file *s, void *data)
OMAP_HSMMC_READ(host->base, ISE)); OMAP_HSMMC_READ(host->base, ISE));
seq_printf(s, "CAPA:\t\t0x%08x\n", seq_printf(s, "CAPA:\t\t0x%08x\n",
OMAP_HSMMC_READ(host->base, CAPA)); OMAP_HSMMC_READ(host->base, CAPA));
clk_disable(host->fclk);
err:
return 0; return 0;
} }
...@@ -1099,14 +1140,16 @@ static int __init omap_mmc_probe(struct platform_device *pdev) ...@@ -1099,14 +1140,16 @@ static int __init omap_mmc_probe(struct platform_device *pdev)
goto err1; goto err1;
} }
if (clk_enable(host->fclk) != 0) { mmc->caps |= MMC_CAP_DISABLE;
mmc_set_disable_delay(mmc, 100);
if (mmc_host_enable(host->mmc) != 0) {
clk_put(host->iclk); clk_put(host->iclk);
clk_put(host->fclk); clk_put(host->fclk);
goto err1; goto err1;
} }
if (clk_enable(host->iclk) != 0) { if (clk_enable(host->iclk) != 0) {
clk_disable(host->fclk); mmc_host_disable(host->mmc);
clk_put(host->iclk); clk_put(host->iclk);
clk_put(host->fclk); clk_put(host->fclk);
goto err1; goto err1;
...@@ -1197,6 +1240,8 @@ static int __init omap_mmc_probe(struct platform_device *pdev) ...@@ -1197,6 +1240,8 @@ static int __init omap_mmc_probe(struct platform_device *pdev)
OMAP_HSMMC_WRITE(host->base, ISE, INT_EN_MASK); OMAP_HSMMC_WRITE(host->base, ISE, INT_EN_MASK);
OMAP_HSMMC_WRITE(host->base, IE, INT_EN_MASK); OMAP_HSMMC_WRITE(host->base, IE, INT_EN_MASK);
mmc_host_lazy_disable(host->mmc);
mmc_add_host(mmc); mmc_add_host(mmc);
if (host->pdata->slots[host->slot_id].name != NULL) { if (host->pdata->slots[host->slot_id].name != NULL) {
...@@ -1225,7 +1270,7 @@ static int __init omap_mmc_probe(struct platform_device *pdev) ...@@ -1225,7 +1270,7 @@ static int __init omap_mmc_probe(struct platform_device *pdev)
err_irq_cd_init: err_irq_cd_init:
free_irq(host->irq, host); free_irq(host->irq, host);
err_irq: err_irq:
clk_disable(host->fclk); mmc_host_disable(host->mmc);
clk_disable(host->iclk); clk_disable(host->iclk);
clk_put(host->fclk); clk_put(host->fclk);
clk_put(host->iclk); clk_put(host->iclk);
...@@ -1250,6 +1295,7 @@ static int omap_mmc_remove(struct platform_device *pdev) ...@@ -1250,6 +1295,7 @@ static int omap_mmc_remove(struct platform_device *pdev)
struct resource *res; struct resource *res;
if (host) { if (host) {
mmc_host_enable(host->mmc);
mmc_remove_host(host->mmc); mmc_remove_host(host->mmc);
if (host->pdata->cleanup) if (host->pdata->cleanup)
host->pdata->cleanup(&pdev->dev); host->pdata->cleanup(&pdev->dev);
...@@ -1258,7 +1304,7 @@ static int omap_mmc_remove(struct platform_device *pdev) ...@@ -1258,7 +1304,7 @@ static int omap_mmc_remove(struct platform_device *pdev)
free_irq(mmc_slot(host).card_detect_irq, host); free_irq(mmc_slot(host).card_detect_irq, host);
flush_scheduled_work(); flush_scheduled_work();
clk_disable(host->fclk); mmc_host_disable(host->mmc);
clk_disable(host->iclk); clk_disable(host->iclk);
clk_put(host->fclk); clk_put(host->fclk);
clk_put(host->iclk); clk_put(host->iclk);
...@@ -1289,6 +1335,7 @@ static int omap_mmc_suspend(struct platform_device *pdev, pm_message_t state) ...@@ -1289,6 +1335,7 @@ static int omap_mmc_suspend(struct platform_device *pdev, pm_message_t state)
return 0; return 0;
if (host) { if (host) {
mmc_host_enable(host->mmc);
ret = mmc_suspend_host(host->mmc, state); ret = mmc_suspend_host(host->mmc, state);
if (ret == 0) { if (ret == 0) {
host->suspended = 1; host->suspended = 1;
...@@ -1307,10 +1354,11 @@ static int omap_mmc_suspend(struct platform_device *pdev, pm_message_t state) ...@@ -1307,10 +1354,11 @@ static int omap_mmc_suspend(struct platform_device *pdev, pm_message_t state)
OMAP_HSMMC_WRITE(host->base, HCTL, OMAP_HSMMC_WRITE(host->base, HCTL,
OMAP_HSMMC_READ(host->base, HCTL) & ~SDBP); OMAP_HSMMC_READ(host->base, HCTL) & ~SDBP);
clk_disable(host->fclk); mmc_host_disable(host->mmc);
clk_disable(host->iclk); clk_disable(host->iclk);
clk_disable(host->dbclk); clk_disable(host->dbclk);
} } else
mmc_host_disable(host->mmc);
} }
return ret; return ret;
...@@ -1327,13 +1375,12 @@ static int omap_mmc_resume(struct platform_device *pdev) ...@@ -1327,13 +1375,12 @@ static int omap_mmc_resume(struct platform_device *pdev)
if (host) { if (host) {
ret = clk_enable(host->fclk); if (mmc_host_enable(host->mmc) != 0)
if (ret)
goto clk_en_err; goto clk_en_err;
ret = clk_enable(host->iclk); ret = clk_enable(host->iclk);
if (ret) { if (ret) {
clk_disable(host->fclk); mmc_host_disable(host->mmc);
clk_put(host->fclk); clk_put(host->fclk);
goto clk_en_err; goto clk_en_err;
} }
...@@ -1355,6 +1402,7 @@ static int omap_mmc_resume(struct platform_device *pdev) ...@@ -1355,6 +1402,7 @@ static int omap_mmc_resume(struct platform_device *pdev)
ret = mmc_resume_host(host->mmc); ret = mmc_resume_host(host->mmc);
if (ret == 0) if (ret == 0)
host->suspended = 0; host->suspended = 0;
mmc_host_lazy_disable(host->mmc);
} }
return ret; return ret;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册