diff options
Diffstat (limited to 'target/linux/brcm2708/patches-3.10/0099-mmc-Report-3.3V-support-in-caps.patch')
-rw-r--r-- | target/linux/brcm2708/patches-3.10/0099-mmc-Report-3.3V-support-in-caps.patch | 323 |
1 files changed, 0 insertions, 323 deletions
diff --git a/target/linux/brcm2708/patches-3.10/0099-mmc-Report-3.3V-support-in-caps.patch b/target/linux/brcm2708/patches-3.10/0099-mmc-Report-3.3V-support-in-caps.patch deleted file mode 100644 index 50113ae..0000000 --- a/target/linux/brcm2708/patches-3.10/0099-mmc-Report-3.3V-support-in-caps.patch +++ /dev/null @@ -1,323 +0,0 @@ -From f88d56e9c6976ebd217993062e0e53d65877685b Mon Sep 17 00:00:00 2001 -From: popcornmix <popcornmix@gmail.com> -Date: Sat, 9 Nov 2013 17:42:58 +0000 -Subject: [PATCH 099/196] mmc: Report 3.3V support in caps - -sdhci: Use macros for out spin lock/unlock functions to reduce diffs with upstream code ---- - drivers/mmc/host/sdhci-bcm2708.c | 2 + - drivers/mmc/host/sdhci.c | 82 ++++++++++++++++++++++------------------ - 2 files changed, 47 insertions(+), 37 deletions(-) - -diff --git a/drivers/mmc/host/sdhci-bcm2708.c b/drivers/mmc/host/sdhci-bcm2708.c -index 4770680..7fdd815 100644 ---- a/drivers/mmc/host/sdhci-bcm2708.c -+++ b/drivers/mmc/host/sdhci-bcm2708.c -@@ -1282,6 +1282,8 @@ static int sdhci_bcm2708_probe(struct platform_device *pdev) - host_priv->dma_chan, host_priv->dma_chan_base, - host_priv->dma_irq); - -+ // we support 3.3V -+ host->caps |= SDHCI_CAN_VDD_330; - if (allow_highspeed) - host->mmc->caps |= MMC_CAP_SD_HIGHSPEED | MMC_CAP_MMC_HIGHSPEED; - -diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c -index 470860b..13e4e11 100644 ---- a/drivers/mmc/host/sdhci.c -+++ b/drivers/mmc/host/sdhci.c -@@ -210,6 +210,14 @@ static void sdhci_spin_disable_schedule(struct sdhci_host *host) - #endif - } - -+ -+#undef spin_lock_irqsave -+#define spin_lock_irqsave(host_lock, flags) sdhci_spin_lock_irqsave(container_of(host_lock, struct sdhci_host, lock), &flags) -+#define spin_unlock_irqrestore(host_lock, flags) sdhci_spin_unlock_irqrestore(container_of(host_lock, struct sdhci_host, lock), flags) -+ -+#define spin_lock(host_lock) sdhci_spin_lock(container_of(host_lock, struct sdhci_host, lock)) -+#define spin_unlock(host_lock) sdhci_spin_unlock(container_of(host_lock, struct sdhci_host, lock)) -+ - static void sdhci_clear_set_irqs(struct sdhci_host *host, u32 clear, u32 set) - { - u32 ier; -@@ -374,7 +382,7 @@ static void sdhci_led_control(struct led_classdev *led, - struct sdhci_host *host = container_of(led, struct sdhci_host, led); - unsigned long flags; - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - if (host->runtime_suspended) - goto out; -@@ -384,7 +392,7 @@ static void sdhci_led_control(struct led_classdev *led, - else - sdhci_activate_led(host); - out: -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - } - #endif - -@@ -1419,7 +1427,7 @@ static void sdhci_request(struct mmc_host *mmc, struct mmc_request *mrq) - - sdhci_runtime_pm_get(host); - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - WARN_ON(host->mrq != NULL); - -@@ -1477,9 +1485,9 @@ static void sdhci_request(struct mmc_host *mmc, struct mmc_request *mrq) - mmc->card->type == MMC_TYPE_MMC ? - MMC_SEND_TUNING_BLOCK_HS200 : - MMC_SEND_TUNING_BLOCK; -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - sdhci_execute_tuning(mmc, tuning_opcode); -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - /* Restore original mmc_request structure */ - host->mrq = mrq; -@@ -1493,7 +1501,7 @@ static void sdhci_request(struct mmc_host *mmc, struct mmc_request *mrq) - } - - mmiowb(); -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - } - - static void sdhci_do_set_ios(struct sdhci_host *host, struct mmc_ios *ios) -@@ -1502,10 +1510,10 @@ static void sdhci_do_set_ios(struct sdhci_host *host, struct mmc_ios *ios) - int vdd_bit = -1; - u8 ctrl; - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - if (host->flags & SDHCI_DEVICE_DEAD) { -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - if (host->vmmc && ios->power_mode == MMC_POWER_OFF) - mmc_regulator_set_ocr(host->mmc, host->vmmc, 0); - return; -@@ -1532,9 +1540,9 @@ static void sdhci_do_set_ios(struct sdhci_host *host, struct mmc_ios *ios) - vdd_bit = sdhci_set_power(host, ios->vdd); - - if (host->vmmc && vdd_bit != -1) { -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - mmc_regulator_set_ocr(host->mmc, host->vmmc, vdd_bit); -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - } - - if (host->ops->platform_send_init_74_clocks) -@@ -1672,7 +1680,7 @@ static void sdhci_do_set_ios(struct sdhci_host *host, struct mmc_ios *ios) - sdhci_reset(host, SDHCI_RESET_CMD | SDHCI_RESET_DATA); - - mmiowb(); -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - } - - static void sdhci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios) -@@ -1720,7 +1728,7 @@ static int sdhci_check_ro(struct sdhci_host *host) - unsigned long flags; - int is_readonly; - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - if (host->flags & SDHCI_DEVICE_DEAD) - is_readonly = 0; -@@ -1730,7 +1738,7 @@ static int sdhci_check_ro(struct sdhci_host *host) - is_readonly = !(sdhci_readl(host, SDHCI_PRESENT_STATE) - & SDHCI_WRITE_PROTECT); - -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - - /* This quirk needs to be replaced by a callback-function later */ - return host->quirks & SDHCI_QUIRK_INVERTED_WRITE_PROTECT ? -@@ -1803,9 +1811,9 @@ static void sdhci_enable_sdio_irq(struct mmc_host *mmc, int enable) - struct sdhci_host *host = mmc_priv(mmc); - unsigned long flags; - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - sdhci_enable_sdio_irq_nolock(host, enable); -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - } - - static int sdhci_do_start_signal_voltage_switch(struct sdhci_host *host, -@@ -2149,7 +2157,7 @@ static void sdhci_card_event(struct mmc_host *mmc) - struct sdhci_host *host = mmc_priv(mmc); - unsigned long flags; - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - /* Check host->mrq first in case we are runtime suspended */ - if (host->mrq && -@@ -2166,7 +2174,7 @@ static void sdhci_card_event(struct mmc_host *mmc) - tasklet_schedule(&host->finish_tasklet); - } - -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - } - - static const struct mmc_host_ops sdhci_ops = { -@@ -2205,14 +2213,14 @@ static void sdhci_tasklet_finish(unsigned long param) - - host = (struct sdhci_host*)param; - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - /* - * If this tasklet gets rescheduled while running, it will - * be run again afterwards but without any active request. - */ - if (!host->mrq) { -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - return; - } - -@@ -2250,7 +2258,7 @@ static void sdhci_tasklet_finish(unsigned long param) - #endif - - mmiowb(); -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - - mmc_request_done(host->mmc, mrq); - sdhci_runtime_pm_put(host); -@@ -2263,7 +2271,7 @@ static void sdhci_timeout_timer(unsigned long data) - - host = (struct sdhci_host*)data; - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - if (host->mrq) { - pr_err("%s: Timeout waiting for hardware " -@@ -2284,7 +2292,7 @@ static void sdhci_timeout_timer(unsigned long data) - } - - mmiowb(); -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - } - - static void sdhci_tuning_timer(unsigned long data) -@@ -2294,11 +2302,11 @@ static void sdhci_tuning_timer(unsigned long data) - - host = (struct sdhci_host *)data; - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - host->flags |= SDHCI_NEEDS_RETUNING; - -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - } - - /*****************************************************************************\ -@@ -2522,10 +2530,10 @@ static irqreturn_t sdhci_irq(int irq, void *dev_id) - u32 intmask, unexpected = 0; - int cardint = 0, max_loops = 16; - -- sdhci_spin_lock(host); -+ spin_lock(&host->lock); - - if (host->runtime_suspended) { -- sdhci_spin_unlock(host); -+ spin_unlock(&host->lock); - pr_warning("%s: got irq while runtime suspended\n", - mmc_hostname(host->mmc)); - return IRQ_HANDLED; -@@ -2629,7 +2637,7 @@ again: - if (intmask && --max_loops) - goto again; - out: -- sdhci_spin_unlock(host); -+ spin_unlock(&host->lock); - - if (unexpected) { - pr_err("%s: Unexpected interrupt 0x%08x.\n", -@@ -2791,15 +2799,15 @@ int sdhci_runtime_suspend_host(struct sdhci_host *host) - host->flags &= ~SDHCI_NEEDS_RETUNING; - } - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - sdhci_mask_irqs(host, SDHCI_INT_ALL_MASK); -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - - synchronize_irq(host->irq); - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - host->runtime_suspended = true; -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - - return ret; - } -@@ -2825,16 +2833,16 @@ int sdhci_runtime_resume_host(struct sdhci_host *host) - sdhci_do_start_signal_voltage_switch(host, &host->mmc->ios); - if ((host_flags & SDHCI_PV_ENABLED) && - !(host->quirks2 & SDHCI_QUIRK2_PRESET_VALUE_BROKEN)) { -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - sdhci_enable_preset_value(host, true); -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - } - - /* Set the re-tuning expiration flag */ - if (host->flags & SDHCI_USING_RETUNING_TIMER) - host->flags |= SDHCI_NEEDS_RETUNING; - -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - host->runtime_suspended = false; - -@@ -2845,7 +2853,7 @@ int sdhci_runtime_resume_host(struct sdhci_host *host) - /* Enable Card Detection */ - sdhci_enable_card_detection(host); - -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - - return ret; - } -@@ -3401,7 +3409,7 @@ void sdhci_remove_host(struct sdhci_host *host, int dead) - unsigned long flags; - - if (dead) { -- sdhci_spin_lock_irqsave(host, &flags); -+ spin_lock_irqsave(&host->lock, flags); - - host->flags |= SDHCI_DEVICE_DEAD; - -@@ -3413,7 +3421,7 @@ void sdhci_remove_host(struct sdhci_host *host, int dead) - tasklet_schedule(&host->finish_tasklet); - } - -- sdhci_spin_unlock_irqrestore(host, flags); -+ spin_unlock_irqrestore(&host->lock, flags); - } - - sdhci_disable_card_detection(host); --- -1.9.1 - |