Skip to content

Commit

Permalink
mmc: omap: Remove redundant suspend and resume callbacks
Browse files Browse the repository at this point in the history
Suspend and resume of cards are handled by the protocol layer and
consequently the mmc_suspend|resume_host APIs are marked as deprecated.

While moving away from using the deprecated APIs, there are nothing
left to be done for the suspend and resume callbacks, so remove them.

Cc: Jarkko Lavinen <jarkko.lavinen@nokia.com>
Cc: linux-omap@vger.kernel.org
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
Signed-off-by: Chris Ball <cjb@laptop.org>
  • Loading branch information
storulf authored and cjb committed Oct 31, 2013
1 parent ccbd483 commit 3932afd
Show file tree
Hide file tree
Showing 2 changed files with 3 additions and 86 deletions.
53 changes: 0 additions & 53 deletions drivers/mmc/host/omap.c
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,6 @@ struct mmc_omap_slot {

struct mmc_omap_host {
int initialized;
int suspended;
struct mmc_request * mrq;
struct mmc_command * cmd;
struct mmc_data * data;
Expand Down Expand Up @@ -1513,61 +1512,9 @@ static int mmc_omap_remove(struct platform_device *pdev)
return 0;
}

#ifdef CONFIG_PM
static int mmc_omap_suspend(struct platform_device *pdev, pm_message_t mesg)
{
int i, ret = 0;
struct mmc_omap_host *host = platform_get_drvdata(pdev);

if (host == NULL || host->suspended)
return 0;

for (i = 0; i < host->nr_slots; i++) {
struct mmc_omap_slot *slot;

slot = host->slots[i];
ret = mmc_suspend_host(slot->mmc);
if (ret < 0) {
while (--i >= 0) {
slot = host->slots[i];
mmc_resume_host(slot->mmc);
}
return ret;
}
}
host->suspended = 1;
return 0;
}

static int mmc_omap_resume(struct platform_device *pdev)
{
int i, ret = 0;
struct mmc_omap_host *host = platform_get_drvdata(pdev);

if (host == NULL || !host->suspended)
return 0;

for (i = 0; i < host->nr_slots; i++) {
struct mmc_omap_slot *slot;
slot = host->slots[i];
ret = mmc_resume_host(slot->mmc);
if (ret < 0)
return ret;

host->suspended = 0;
}
return 0;
}
#else
#define mmc_omap_suspend NULL
#define mmc_omap_resume NULL
#endif

static struct platform_driver mmc_omap_driver = {
.probe = mmc_omap_probe,
.remove = mmc_omap_remove,
.suspend = mmc_omap_suspend,
.resume = mmc_omap_resume,
.driver = {
.name = DRIVER_NAME,
.owner = THIS_MODULE,
Expand Down
36 changes: 3 additions & 33 deletions drivers/mmc/host/omap_hsmmc.c
Original file line number Diff line number Diff line change
Expand Up @@ -1171,9 +1171,6 @@ static irqreturn_t omap_hsmmc_detect(int irq, void *dev_id)
struct omap_mmc_slot_data *slot = &mmc_slot(host);
int carddetect;

if (host->suspended)
return IRQ_HANDLED;

sysfs_notify(&host->mmc->class_dev.kobj, NULL, "cover_switch");

if (slot->card_detect)
Expand Down Expand Up @@ -1632,11 +1629,6 @@ static int omap_hsmmc_regs_show(struct seq_file *s, void *data)
seq_printf(s, "mmc%d:\n ctx_loss:\t%d\n\nregs:\n",
mmc->index, host->context_loss);

if (host->suspended) {
seq_printf(s, "host suspended, can't read registers\n");
return 0;
}

pm_runtime_get_sync(host->dev);

seq_printf(s, "CON:\t\t0x%08x\n",
Expand Down Expand Up @@ -2101,23 +2093,12 @@ static void omap_hsmmc_complete(struct device *dev)

static int omap_hsmmc_suspend(struct device *dev)
{
int ret = 0;
struct omap_hsmmc_host *host = dev_get_drvdata(dev);

if (!host)
return 0;

if (host && host->suspended)
return 0;

pm_runtime_get_sync(host->dev);
host->suspended = 1;
ret = mmc_suspend_host(host->mmc);

if (ret) {
host->suspended = 0;
goto err;
}

if (!(host->mmc->pm_flags & MMC_PM_KEEP_POWER)) {
omap_hsmmc_disable_irq(host);
Expand All @@ -2127,23 +2108,19 @@ static int omap_hsmmc_suspend(struct device *dev)

if (host->dbclk)
clk_disable_unprepare(host->dbclk);
err:

pm_runtime_put_sync(host->dev);
return ret;
return 0;
}

/* Routine to resume the MMC device */
static int omap_hsmmc_resume(struct device *dev)
{
int ret = 0;
struct omap_hsmmc_host *host = dev_get_drvdata(dev);

if (!host)
return 0;

if (host && !host->suspended)
return 0;

pm_runtime_get_sync(host->dev);

if (host->dbclk)
Expand All @@ -2154,16 +2131,9 @@ static int omap_hsmmc_resume(struct device *dev)

omap_hsmmc_protect_card(host);

/* Notify the core to resume the host */
ret = mmc_resume_host(host->mmc);
if (ret == 0)
host->suspended = 0;

pm_runtime_mark_last_busy(host->dev);
pm_runtime_put_autosuspend(host->dev);

return ret;

return 0;
}

#else
Expand Down

0 comments on commit 3932afd

Please sign in to comment.