summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorTony Lin <tony.lin@freescale.com>2011-12-26 13:44:20 +0800
committerJason Liu <r64343@freescale.com>2012-01-09 21:12:41 +0800
commit6fcf6b174efd11b8c41a61393abd1507f5f69d96 (patch)
tree7fcb6d91b70516e9d857ef413f1b4019b0a61c9a /drivers
parent6084919b45a2ad80b8684e99ada2f43371074f0e (diff)
ENGR00170929 [MX6Q MMC]might sleep in atomic context
call clk_enable/clk_disable in atomic is forbidden. move all the calls out of atomic context. Signed-off-by: Tony Lin <tony.lin@freescale.com>
Diffstat (limited to 'drivers')
-rwxr-xr-xdrivers/mmc/host/sdhci.c24
1 files changed, 12 insertions, 12 deletions
diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c
index 0e2c706a0d12..9e78f0a5064b 100755
--- a/drivers/mmc/host/sdhci.c
+++ b/drivers/mmc/host/sdhci.c
@@ -57,10 +57,8 @@ static void sdhci_clk_worker(struct work_struct *work)
struct sdhci_host *host =
container_of(work, struct sdhci_host, clk_worker.work);
- spin_lock_irqsave(&host->lock, flags);
if (host->ops->platform_clk_ctrl && host->clk_status)
host->ops->platform_clk_ctrl(host, false);
- spin_unlock_irqrestore(&host->lock, flags);
}
static inline bool sdhci_is_sdio_attached(struct sdhci_host *host)
@@ -292,16 +290,16 @@ static void sdhci_led_control(struct led_classdev *led,
struct sdhci_host *host = container_of(led, struct sdhci_host, led);
unsigned long flags;
- spin_lock_irqsave(&host->lock, flags);
sdhci_enable_clk(host);
+ spin_lock_irqsave(&host->lock, flags);
if (brightness == LED_OFF)
sdhci_deactivate_led(host);
else
sdhci_activate_led(host);
- sdhci_disable_clk(host, CLK_TIMEOUT);
spin_unlock_irqrestore(&host->lock, flags);
+ sdhci_disable_clk(host, CLK_TIMEOUT);
}
#endif
@@ -1256,6 +1254,7 @@ static void sdhci_request(struct mmc_host *mmc, struct mmc_request *mrq)
host = mmc_priv(mmc);
+ sdhci_enable_clk(host);
spin_lock_irqsave(&host->lock, flags);
WARN_ON(host->mrq != NULL);
@@ -1276,7 +1275,6 @@ static void sdhci_request(struct mmc_host *mmc, struct mmc_request *mrq)
}
host->mrq = mrq;
- sdhci_enable_clk(host);
/* If polling, assume that the card is always present. */
if (host->quirks & SDHCI_QUIRK_BROKEN_CARD_DETECTION)
@@ -1325,8 +1323,8 @@ static void sdhci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
host = mmc_priv(mmc);
- spin_lock_irqsave(&host->lock, flags);
sdhci_enable_clk(host);
+ spin_lock_irqsave(&host->lock, flags);
if (host->flags & SDHCI_DEVICE_DEAD)
goto out;
@@ -1478,10 +1476,10 @@ static void sdhci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
out:
mmiowb();
+ spin_unlock_irqrestore(&host->lock, flags);
+
if (ios->power_mode == MMC_POWER_OFF)
sdhci_disable_clk(host, 0);
-
- spin_unlock_irqrestore(&host->lock, flags);
}
static int check_ro(struct sdhci_host *host)
@@ -1489,8 +1487,8 @@ static int check_ro(struct sdhci_host *host)
unsigned long flags;
int is_readonly;
- spin_lock_irqsave(&host->lock, flags);
sdhci_enable_clk(host);
+ spin_lock_irqsave(&host->lock, flags);
if (host->flags & SDHCI_DEVICE_DEAD)
is_readonly = 0;
@@ -1501,6 +1499,7 @@ static int check_ro(struct sdhci_host *host)
& SDHCI_WRITE_PROTECT);
spin_unlock_irqrestore(&host->lock, flags);
+ sdhci_disable_clk(host, CLK_TIMEOUT);
/* This quirk needs to be replaced by a callback-function later */
return host->quirks & SDHCI_QUIRK_INVERTED_WRITE_PROTECT ?
@@ -1537,8 +1536,8 @@ static void sdhci_enable_sdio_irq(struct mmc_host *mmc, int enable)
host = mmc_priv(mmc);
- spin_lock_irqsave(&host->lock, flags);
sdhci_enable_clk(host);
+ spin_lock_irqsave(&host->lock, flags);
if (host->flags & SDHCI_DEVICE_DEAD)
goto out;
@@ -1965,8 +1964,8 @@ static void sdhci_tasklet_finish(unsigned long param)
#endif
mmiowb();
- sdhci_disable_clk(host, CLK_TIMEOUT);
spin_unlock_irqrestore(&host->lock, flags);
+ sdhci_disable_clk(host, CLK_TIMEOUT);
mmc_request_done(host->mmc, mrq);
}
@@ -2867,6 +2866,8 @@ void sdhci_remove_host(struct sdhci_host *host, int dead)
{
unsigned long flags;
+ sdhci_enable_clk(host);
+
if (dead) {
spin_lock_irqsave(&host->lock, flags);
@@ -2877,7 +2878,6 @@ void sdhci_remove_host(struct sdhci_host *host, int dead)
" transfer!\n", mmc_hostname(host->mmc));
host->mrq->cmd->error = -ENOMEDIUM;
- sdhci_enable_clk(host);
tasklet_schedule(&host->finish_tasklet);
}