1 From 6ec7d69f08cfb772fdf5d7c55ed9da2273677a4d Mon Sep 17 00:00:00 2001
2 From: Andy Green <andy@openmoko.com>
3 Date: Sun, 20 Jul 2008 18:43:15 +0100
4 Subject: [PATCH] fix-scard-stop-on-resume.patch
5 Reported-by: Ville-Pekka Vainio <vpivaini@cs.helsinki.fi>
7 The reporter noticed SD Card clock is running again after resume. After
8 looking at the code I saw I missed two tricks, this will force it off
9 after resume and will do better generally depending on what the last SD Card
12 Since bulk read packet is normally last action (which set the clock off even
13 without this) the old patch worked for normal cases. But after resume, the last
14 packet on the wire was not a bulk transfer and we didn't take care about the
17 Signed-off-by: Andy Green <andy@openmoko.com>
19 drivers/mfd/glamo/glamo-mci.c | 6 +++---
20 1 files changed, 3 insertions(+), 3 deletions(-)
22 diff --git a/drivers/mfd/glamo/glamo-mci.c b/drivers/mfd/glamo/glamo-mci.c
23 index 6729244..2318e6f 100644
24 --- a/drivers/mfd/glamo/glamo-mci.c
25 +++ b/drivers/mfd/glamo/glamo-mci.c
26 @@ -619,12 +619,9 @@ done:
27 host->complete_what = COMPLETION_NONE;
29 mmc_request_done(host->mmc, cmd->mrq);
33 /* stop the clock to card */
34 __glamo_mci_fix_card_div(host, -1);
38 static void glamo_mci_request(struct mmc_host *mmc, struct mmc_request *mrq)
39 @@ -690,6 +687,9 @@ static void glamo_mci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
40 host->real_rate = __glamo_mci_set_card_clock(host, ios->clock, &div);
43 + /* stop the clock to card, because we are idle until transfer */
44 + __glamo_mci_fix_card_div(host, -1);
46 if ((ios->power_mode == MMC_POWER_ON) ||
47 (ios->power_mode == MMC_POWER_UP)) {
48 dev_info(&host->pdev->dev,