Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 102163
b: refs/heads/master
c: 619ef4b
h: refs/heads/master
i:
  102161: 050f54f
  102159: e2d4f29
v: v3
  • Loading branch information
Anton Vorontsov authored and Pierre Ossman committed Jul 15, 2008
1 parent be9011f commit eed9210
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 3 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 28f52482b41edc88cdf575aa6ed414c6e116ce10
refs/heads/master: 619ef4b42128709de4d89d209b2c874f560deecd
19 changes: 17 additions & 2 deletions trunk/drivers/mmc/host/mmc_spi.c
Original file line number Diff line number Diff line change
Expand Up @@ -1131,11 +1131,20 @@ static int mmc_spi_get_ro(struct mmc_host *mmc)
return 0;
}

static int mmc_spi_get_cd(struct mmc_host *mmc)
{
struct mmc_spi_host *host = mmc_priv(mmc);

if (host->pdata && host->pdata->get_cd)
return !!host->pdata->get_cd(mmc->parent);
return -ENOSYS;
}

static const struct mmc_host_ops mmc_spi_ops = {
.request = mmc_spi_request,
.set_ios = mmc_spi_set_ios,
.get_ro = mmc_spi_get_ro,
.get_cd = mmc_spi_get_cd,
};


Expand Down Expand Up @@ -1319,17 +1328,23 @@ static int mmc_spi_probe(struct spi_device *spi)
goto fail_glue_init;
}

/* pass platform capabilities, if any */
if (host->pdata)
mmc->caps |= host->pdata->caps;

status = mmc_add_host(mmc);
if (status != 0)
goto fail_add_host;

dev_info(&spi->dev, "SD/MMC host %s%s%s%s\n",
dev_info(&spi->dev, "SD/MMC host %s%s%s%s%s\n",
mmc->class_dev.bus_id,
host->dma_dev ? "" : ", no DMA",
(host->pdata && host->pdata->get_ro)
? "" : ", no WP",
(host->pdata && host->pdata->setpower)
? "" : ", no poweroff");
? "" : ", no poweroff",
(mmc->caps & MMC_CAP_NEEDS_POLL)
? ", cd polling" : "");
return 0;

fail_add_host:
Expand Down
9 changes: 9 additions & 0 deletions trunk/include/linux/spi/mmc_spi.h
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,15 @@ struct mmc_spi_platform_data {
/* sense switch on sd cards */
int (*get_ro)(struct device *);

/*
* If board does not use CD interrupts, driver can optimize polling
* using this function.
*/
int (*get_cd)(struct device *);

/* Capabilities to pass into mmc core (e.g. MMC_CAP_NEEDS_POLL). */
unsigned long caps;

/* how long to debounce card detect, in msecs */
u16 detect_delay;

Expand Down

0 comments on commit eed9210

Please sign in to comment.