[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <1248115882-20221-2-git-send-email-manuel.lauss@gmail.com>
Date: Mon, 20 Jul 2009 20:51:22 +0200
From: Manuel Lauss <manuel.lauss@...glemail.com>
To: linux-kernel@...r.kernel.org
Cc: linux-mips@...ux-mips.org, Manuel Lauss <manuel.lauss@...il.com>
Subject: [PATCH] au1xmmc: allow platforms to disable certain host capabilities
Although the hardware supports a 4/8bit SD interface and the driver
unconditionally advertises all hardware caps to the MMC core, not all
datalines may actually be wired up. This patch introduces another
field to au1xmmc platform data allowing platforms to disable certain
advanced host controller features.
Signed-off-by: Manuel Lauss <manuel.lauss@...il.com>
---
arch/mips/include/asm/mach-au1x00/au1100_mmc.h | 1 +
drivers/mmc/host/au1xmmc.c | 3 +++
2 files changed, 4 insertions(+), 0 deletions(-)
diff --git a/arch/mips/include/asm/mach-au1x00/au1100_mmc.h b/arch/mips/include/asm/mach-au1x00/au1100_mmc.h
index c35e209..a674643 100644
--- a/arch/mips/include/asm/mach-au1x00/au1100_mmc.h
+++ b/arch/mips/include/asm/mach-au1x00/au1100_mmc.h
@@ -46,6 +46,7 @@ struct au1xmmc_platform_data {
int(*card_readonly)(void *mmc_host);
void(*set_power)(void *mmc_host, int state);
struct led_classdev *led;
+ unsigned long mask_host_caps;
};
#define SD0_BASE 0xB0600000
diff --git a/drivers/mmc/host/au1xmmc.c b/drivers/mmc/host/au1xmmc.c
index 70509c9..d50e7ea 100644
--- a/drivers/mmc/host/au1xmmc.c
+++ b/drivers/mmc/host/au1xmmc.c
@@ -1005,6 +1005,9 @@ static int __devinit au1xmmc_probe(struct platform_device *pdev)
mmc->ocr_avail = AU1XMMC_OCR;
mmc->caps = MMC_CAP_4_BIT_DATA | MMC_CAP_SDIO_IRQ;
+ /* platform may not be able to use 4/8 bit datapath */
+ mmc->caps &= ~(host->platdata->mask_host_caps);
+
host->status = HOST_S_IDLE;
/* board-specific carddetect setup, if any */
--
1.6.3.3
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists