summaryrefslogtreecommitdiff
path: root/target/linux/s3c24xx/patches-2.6.24/1292-fix-glamo-mci-slow-clock-until-first-bulk.patch.patch
diff options
context:
space:
mode:
Diffstat (limited to 'target/linux/s3c24xx/patches-2.6.24/1292-fix-glamo-mci-slow-clock-until-first-bulk.patch.patch')
-rw-r--r--target/linux/s3c24xx/patches-2.6.24/1292-fix-glamo-mci-slow-clock-until-first-bulk.patch.patch261
1 files changed, 0 insertions, 261 deletions
diff --git a/target/linux/s3c24xx/patches-2.6.24/1292-fix-glamo-mci-slow-clock-until-first-bulk.patch.patch b/target/linux/s3c24xx/patches-2.6.24/1292-fix-glamo-mci-slow-clock-until-first-bulk.patch.patch
deleted file mode 100644
index 642f545..0000000
--- a/target/linux/s3c24xx/patches-2.6.24/1292-fix-glamo-mci-slow-clock-until-first-bulk.patch.patch
+++ /dev/null
@@ -1,261 +0,0 @@
-From 9e7ba57b104e9293f746342b7450b10d5fa0c4cd Mon Sep 17 00:00:00 2001
-From: Andy Green <andy@openmoko.com>
-Date: Mon, 22 Sep 2008 22:38:03 +0100
-Subject: [PATCH] fix-glamo-mci-slow-clock-until-first-bulk.patch
-
-This patch adds another module parameter to glamo-mci which sets the
-SD Card clock rate used inbetween powering the card and the completion of
-the first bulk transfer. You can set it from kernel commandline like this.
-
-glamo_mci.sd_post_power_clock=1000000
-
-The period between changing the power state and the first bulk transfer
-completion is critical because larger SDHC cards take longer to initialize
-before they can service the bulk transfer, and the Glamo MMC unit has a
-fixed timeout length of a maximum of 4095 x 16 x SD Card clocks. Large
-cards like 8GB Sandisk SDHC are not ready before this timeout is used up
-at default 16MHz.
-
-Subsequently, the card can handle 16MHz SD Clock and timeout durations
-okay.
-
-By default this patch operates the SD Clock at only 1MHz until the first
-bulk transfer is completed after each powerup action from the MCI stack. It
-also keeps the SD Clock running during this time, and disables the SD Clock
-if the card is not present and the MCI stack removes power.
-
-Signed-off-by: Andy Green <andy@openmoko.com>
----
- drivers/mfd/glamo/glamo-mci.c | 108 +++++++++++++++++++++++++----------------
- drivers/mfd/glamo/glamo-mci.h | 2 +
- 2 files changed, 68 insertions(+), 42 deletions(-)
-
-diff --git a/drivers/mfd/glamo/glamo-mci.c b/drivers/mfd/glamo/glamo-mci.c
-index 3eece08..cff43db 100644
---- a/drivers/mfd/glamo/glamo-mci.c
-+++ b/drivers/mfd/glamo/glamo-mci.c
-@@ -74,6 +74,23 @@ static int sd_slow_ratio = 8;
- module_param(sd_slow_ratio, int, 0644);
-
- /*
-+ * Post-power SD clock rate
-+ *
-+ * you can override this on kernel commandline using
-+ *
-+ * glamo_mci.sd_post_power_clock=1000000
-+ *
-+ * for example
-+ *
-+ * After changing power to card, clock is held at this rate until first bulk
-+ * transfer completes
-+ */
-+
-+static int sd_post_power_clock = 1000000;
-+module_param(sd_post_power_clock, int, 0644);
-+
-+
-+/*
- * SD Signal drive strength
- *
- * you can override this on kernel commandline using
-@@ -240,21 +257,35 @@ static void __glamo_mci_fix_card_div(struct glamo_mci_host *host, int div)
- writew(readw(glamo_mci_def_pdata.pglamo->base +
- GLAMO_REG_CLOCK_GEN5_1) & (~GLAMO_CLOCK_GEN51_EN_DIV_TCLK),
- glamo_mci_def_pdata.pglamo->base + GLAMO_REG_CLOCK_GEN5_1);
-- } else {
-- /* set the nearest prescaler factor
-- *
-- * register shared with SCLK divisor -- no chance of race because
-- * we don't use sensor interface
-- */
-- writew_dly((readw(glamo_mci_def_pdata.pglamo->base +
-- GLAMO_REG_CLOCK_GEN8) & 0xff00) | div,
-- glamo_mci_def_pdata.pglamo->base + GLAMO_REG_CLOCK_GEN8);
-- /* enable clock to divider input */
-- writew_dly(readw(glamo_mci_def_pdata.pglamo->base +
-- GLAMO_REG_CLOCK_GEN5_1) | GLAMO_CLOCK_GEN51_EN_DIV_TCLK,
-- glamo_mci_def_pdata.pglamo->base + GLAMO_REG_CLOCK_GEN5_1);
-+
-+ goto done;
- }
-
-+ if (host->force_slow_during_powerup)
-+ div = host->clk_rate / sd_post_power_clock;
-+ else
-+ if (host->pdata->glamo_mci_use_slow)
-+ if ((host->pdata->glamo_mci_use_slow)())
-+ div = div * sd_slow_ratio;
-+
-+ if (div > 255)
-+ div = 255;
-+
-+ /*
-+ * set the nearest prescaler factor
-+ *
-+ * register shared with SCLK divisor -- no chance of race because
-+ * we don't use sensor interface
-+ */
-+ writew_dly((readw(glamo_mci_def_pdata.pglamo->base +
-+ GLAMO_REG_CLOCK_GEN8) & 0xff00) | div,
-+ glamo_mci_def_pdata.pglamo->base + GLAMO_REG_CLOCK_GEN8);
-+ /* enable clock to divider input */
-+ writew_dly(readw(glamo_mci_def_pdata.pglamo->base +
-+ GLAMO_REG_CLOCK_GEN5_1) | GLAMO_CLOCK_GEN51_EN_DIV_TCLK,
-+ glamo_mci_def_pdata.pglamo->base + GLAMO_REG_CLOCK_GEN5_1);
-+
-+done:
- spin_unlock_irqrestore(&clock_lock, flags);
- }
-
-@@ -284,7 +315,7 @@ static int __glamo_mci_set_card_clock(struct glamo_mci_host *host, int freq,
- if (division)
- *division = 0xff;
-
-- if (!sd_idleclk)
-+ if (!sd_idleclk && !host->force_slow_during_powerup)
- /* clock off */
- __glamo_mci_fix_card_div(host, -1);
- }
-@@ -327,6 +358,10 @@ static void glamo_mci_irq(unsigned int irq, struct irq_desc *desc)
- goto done;
- }
-
-+ /* disable the initial slow start after first bulk transfer */
-+ if (host->force_slow_during_powerup)
-+ host->force_slow_during_powerup--;
-+
- if (host->pio_active == XFER_READ)
- do_pio_read(host);
-
-@@ -341,7 +376,7 @@ static void glamo_mci_irq(unsigned int irq, struct irq_desc *desc)
- host->cmd_is_stop = 0;
- }
-
-- if (!sd_idleclk)
-+ if (!sd_idleclk && !host->force_slow_during_powerup)
- /* clock off */
- __glamo_mci_fix_card_div(host, -1);
-
-@@ -357,7 +392,6 @@ static int glamo_mci_send_command(struct glamo_mci_host *host,
- {
- u8 u8a[6];
- u16 fire = 0;
-- u16 timeout = 0xfff; /* max glamo MMC timeout, in units of 16 clocks */
-
- /* if we can't do it, reject as busy */
- if (!readw_dly(host->base + GLAMO_REG_MMC_RB_STAT1) &
-@@ -467,15 +501,9 @@ static int glamo_mci_send_command(struct glamo_mci_host *host,
- fire |= GLAMO_FIRE_MMC_CC_BASIC; /* "basic command" */
- break;
- }
-- /* enforce timeout, clipping at default 65520 clocks if larger */
-- if (cmd->data)
-- /* so long as there is one... */
-- if (cmd->data->timeout_clks &&
-- /* ... and it is not longer than we can handle */
-- (cmd->data->timeout_clks <= 0xffff))
-- timeout = cmd->data->timeout_clks >> 4; /* / 16 clks */
-
-- writew(timeout, host->base + GLAMO_REG_MMC_TIMEOUT);
-+ /* always largest timeout */
-+ writew(0xfff, host->base + GLAMO_REG_MMC_TIMEOUT);
-
- /* Generate interrupt on txfer */
- writew_dly((readw_dly(host->base + GLAMO_REG_MMC_BASIC) & 0x3e) |
-@@ -576,14 +604,7 @@ static void glamo_mci_send_request(struct mmc_host *mmc)
- /* resume requested clock rate
- * scale it down by sd_slow_ratio if platform requests it
- */
-- if (host->pdata->glamo_mci_use_slow)
-- if ((host->pdata->glamo_mci_use_slow)())
-- __glamo_mci_fix_card_div(host, host->clk_div *
-- sd_slow_ratio);
-- else
-- __glamo_mci_fix_card_div(host, host->clk_div);
-- else
-- __glamo_mci_fix_card_div(host, host->clk_div);
-+ __glamo_mci_fix_card_div(host, host->clk_div);
-
- if (glamo_mci_send_command(host, cmd))
- goto bail;
-@@ -633,6 +654,7 @@ static void glamo_mci_send_request(struct mmc_host *mmc)
- goto done;
- if (!(cmd->data->flags & (MMC_DATA_READ | MMC_DATA_WRITE)))
- goto done;
-+
- /*
- * Otherwise can can use the interrupt as async completion --
- * if there is read data coming, or we wait for write data to complete,
-@@ -676,7 +698,7 @@ done:
- host->mrq = NULL;
- mmc_request_done(host->mmc, cmd->mrq);
- bail:
-- if (!sd_idleclk)
-+ if (!sd_idleclk && !host->force_slow_during_powerup)
- /* stop the clock to card */
- __glamo_mci_fix_card_div(host, -1);
- }
-@@ -718,6 +740,12 @@ static void glamo_mci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
- switch(ios->power_mode) {
- case MMC_POWER_ON:
- case MMC_POWER_UP:
-+ /*
-+ * we should use very slow clock until first bulk
-+ * transfer completes OK
-+ */
-+ host->force_slow_during_powerup = 1;
-+
- if (host->vdd_current != ios->vdd) {
- host->pdata->glamo_set_mci_power(ios->power_mode,
- ios->vdd);
-@@ -734,6 +762,9 @@ static void glamo_mci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
- default:
- if (host->power_mode_current == MMC_POWER_OFF)
- break;
-+ /* never want clocking with dead card */
-+ __glamo_mci_fix_card_div(host, -1);
-+
- glamo_engine_disable(glamo_mci_def_pdata.pglamo,
- GLAMO_ENGINE_MMC);
- host->pdata->glamo_set_mci_power(MMC_POWER_OFF, 0);
-@@ -751,7 +782,7 @@ static void glamo_mci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
- if (powering)
- msleep(1);
-
-- if (!sd_idleclk)
-+ if (!sd_idleclk && !host->force_slow_during_powerup)
- /* stop the clock to card, because we are idle until transfer */
- __glamo_mci_fix_card_div(host, -1);
-
-@@ -954,14 +985,7 @@ static int glamo_mci_suspend(struct platform_device *dev, pm_message_t state)
- * make sure the clock was running during suspend and consequently
- * resume
- */
-- if (host->pdata->glamo_mci_use_slow)
-- if ((host->pdata->glamo_mci_use_slow)())
-- __glamo_mci_fix_card_div(host, host->clk_div *
-- sd_slow_ratio);
-- else
-- __glamo_mci_fix_card_div(host, host->clk_div);
-- else
-- __glamo_mci_fix_card_div(host, host->clk_div);
-+ __glamo_mci_fix_card_div(host, host->clk_div);
-
- /* we are going to do more commands to override this in
- * mmc_suspend_host(), so we need to change sd_idleclk for the
-diff --git a/drivers/mfd/glamo/glamo-mci.h b/drivers/mfd/glamo/glamo-mci.h
-index f3f170e..38f6376 100644
---- a/drivers/mfd/glamo/glamo-mci.h
-+++ b/drivers/mfd/glamo/glamo-mci.h
-@@ -44,6 +44,8 @@ struct glamo_mci_host {
- unsigned long real_rate;
- u8 prescaler;
-
-+ int force_slow_during_powerup;
-+
- unsigned sdiimsk;
- int dodma;
-
---
-1.5.6.5
-