Commit 777271d0 authored by Arnd Hannemann's avatar Arnd Hannemann Committed by Samuel Ortiz

mmc: Allow the platform to specify the sh_mmcif get_cd handler

In some platforms (e.g. AP4EVB) the card detect pin of a slot is not
directly connected to the sh_mmcif controller, so that polling needs
to be used. To overcome the overhead induced by querying the controller
on each poll cycle, card detection can be handled in the platform code
more efficiently.
This patch exposes a get_cd hook for that purpose.
Signed-off-by: default avatarArnd Hannemann <arnd@arndnet.de>
Tested-by: default avatarYusuke Goda <yusuke.goda.sx@renesas.com>
Signed-off-by: default avatarSamuel Ortiz <sameo@linux.intel.com>
parent 998283e2
...@@ -710,9 +710,21 @@ static void sh_mmcif_set_ios(struct mmc_host *mmc, struct mmc_ios *ios) ...@@ -710,9 +710,21 @@ static void sh_mmcif_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
host->bus_width = ios->bus_width; host->bus_width = ios->bus_width;
} }
static int sh_mmcif_get_cd(struct mmc_host *mmc)
{
struct sh_mmcif_host *host = mmc_priv(mmc);
struct sh_mmcif_plat_data *p = host->pd->dev.platform_data;
if (!p->get_cd)
return -ENOSYS;
else
return p->get_cd(host->pd);
}
static struct mmc_host_ops sh_mmcif_ops = { static struct mmc_host_ops sh_mmcif_ops = {
.request = sh_mmcif_request, .request = sh_mmcif_request,
.set_ios = sh_mmcif_set_ios, .set_ios = sh_mmcif_set_ios,
.get_cd = sh_mmcif_get_cd,
}; };
static void sh_mmcif_detect(struct mmc_host *mmc) static void sh_mmcif_detect(struct mmc_host *mmc)
......
...@@ -34,6 +34,7 @@ ...@@ -34,6 +34,7 @@
struct sh_mmcif_plat_data { struct sh_mmcif_plat_data {
void (*set_pwr)(struct platform_device *pdev, int state); void (*set_pwr)(struct platform_device *pdev, int state);
void (*down_pwr)(struct platform_device *pdev); void (*down_pwr)(struct platform_device *pdev);
int (*get_cd)(struct platform_device *pdef);
u8 sup_pclk; /* 1 :SH7757, 0: SH7724/SH7372 */ u8 sup_pclk; /* 1 :SH7757, 0: SH7724/SH7372 */
unsigned long caps; unsigned long caps;
u32 ocr; u32 ocr;
......
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