diff options
author | Tony Lin <tony.lin@freescale.com> | 2011-12-26 13:44:20 +0800 |
---|---|---|
committer | Jason Liu <r64343@freescale.com> | 2012-01-09 21:12:41 +0800 |
commit | 6fcf6b174efd11b8c41a61393abd1507f5f69d96 (patch) | |
tree | 7fcb6d91b70516e9d857ef413f1b4019b0a61c9a /drivers | |
parent | 6084919b45a2ad80b8684e99ada2f43371074f0e (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-x | drivers/mmc/host/sdhci.c | 24 |
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); } |