diff options
author | Magnus Damm <damm@opensource.se> | 2009-11-27 05:31:27 +0100 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2009-11-30 04:01:24 +0100 |
commit | be9cd7b6f84fd0cc59c8770771073b5c66f958ac (patch) | |
tree | 6ecc43a8424b87828131c4ed2a4a45ca812db847 /drivers | |
parent | sh: mach-ecovec24: modify address map (diff) | |
download | linux-be9cd7b6f84fd0cc59c8770771073b5c66f958ac.tar.xz linux-be9cd7b6f84fd0cc59c8770771073b5c66f958ac.zip |
mfd: Add power control platform data to SDHI driver
This patch adds platform data with a function for power
control to the SDHI driver. The idea is that board specific
code can provide their own functions so power can be enabled
and disabled for the sd-cards.
Signed-off-by: Magnus Damm <damm@opensource.se>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/mfd/sh_mobile_sdhi.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/drivers/mfd/sh_mobile_sdhi.c b/drivers/mfd/sh_mobile_sdhi.c index 56f72cc1d569..03efae8041ab 100644 --- a/drivers/mfd/sh_mobile_sdhi.c +++ b/drivers/mfd/sh_mobile_sdhi.c @@ -24,6 +24,7 @@ #include <linux/mfd/core.h> #include <linux/mfd/tmio.h> +#include <linux/mfd/sh_mobile_sdhi.h> struct sh_mobile_sdhi { struct clk *clk; @@ -50,6 +51,15 @@ static struct mfd_cell sh_mobile_sdhi_cell = { .resources = sh_mobile_sdhi_resources, }; +static void sh_mobile_sdhi_set_pwr(struct platform_device *tmio, int state) +{ + struct platform_device *pdev = to_platform_device(tmio->dev.parent); + struct sh_mobile_sdhi_info *p = pdev->dev.platform_data; + + if (p && p->set_pwr) + p->set_pwr(pdev, state); +} + static int __init sh_mobile_sdhi_probe(struct platform_device *pdev) { struct sh_mobile_sdhi *priv; @@ -87,6 +97,7 @@ static int __init sh_mobile_sdhi_probe(struct platform_device *pdev) /* FIXME: silly const unsigned int hclk */ *(unsigned int *)&priv->mmc_data.hclk = clk_get_rate(priv->clk); + priv->mmc_data.set_pwr = sh_mobile_sdhi_set_pwr; memcpy(&priv->cell_mmc, &sh_mobile_sdhi_cell, sizeof(priv->cell_mmc)); priv->cell_mmc.driver_data = &priv->mmc_data; |