diff options
author | Tony Lindgren <tony@atomide.com> | 2008-12-10 20:37:17 -0500 |
---|---|---|
committer | Tony Lindgren <tony@atomide.com> | 2008-12-10 20:37:17 -0500 |
commit | 90c62bf08f5823faa097271f3346a9142769b9ac (patch) | |
tree | aa3bf442380815268b03092fd4b9c47924f9c3ee /arch/arm/mach-omap1 | |
parent | d88746652b4d133284d1fdd05b5e999e8f44c998 (diff) |
omap mmc: Add low-level initialization for hsmmc controller
Add low-level initialization for hsmmc controller. Merged into
this patch patch are various improvments and board support by
Grazvydas Ignotas and David Brownell.
Also change wire4 to be wires, as some newer controllers support
8 data lines.
Cc: Pierre Ossman <drzeus-mmc@drzeus.cx>
Signed-off-by: Grazvydas Ignotas <notasas@gmail.com>
Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'arch/arm/mach-omap1')
-rw-r--r-- | arch/arm/mach-omap1/board-innovator.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap1/devices.c | 4 |
2 files changed, 3 insertions, 3 deletions
diff --git a/arch/arm/mach-omap1/board-innovator.c b/arch/arm/mach-omap1/board-innovator.c index 8ffb06fc0f08..af2fb9070083 100644 --- a/arch/arm/mach-omap1/board-innovator.c +++ b/arch/arm/mach-omap1/board-innovator.c | |||
@@ -385,7 +385,7 @@ static struct omap_mmc_platform_data mmc1_data = { | |||
385 | .nr_slots = 1, | 385 | .nr_slots = 1, |
386 | .slots[0] = { | 386 | .slots[0] = { |
387 | .set_power = mmc_set_power, | 387 | .set_power = mmc_set_power, |
388 | .wire4 = 1, | 388 | .wires = 4, |
389 | .name = "mmcblk", | 389 | .name = "mmcblk", |
390 | }, | 390 | }, |
391 | }; | 391 | }; |
diff --git a/arch/arm/mach-omap1/devices.c b/arch/arm/mach-omap1/devices.c index 024dab13d4b4..77382d8b6b2f 100644 --- a/arch/arm/mach-omap1/devices.c +++ b/arch/arm/mach-omap1/devices.c | |||
@@ -116,7 +116,7 @@ static inline void omap1_mmc_mux(struct omap_mmc_platform_data *mmc_controller, | |||
116 | omap_cfg_reg(P19_1710_MMC_CMDDIR); | 116 | omap_cfg_reg(P19_1710_MMC_CMDDIR); |
117 | omap_cfg_reg(P20_1710_MMC_DATDIR0); | 117 | omap_cfg_reg(P20_1710_MMC_DATDIR0); |
118 | } | 118 | } |
119 | if (mmc_controller->slots[0].wire4) { | 119 | if (mmc_controller->slots[0].wires == 4) { |
120 | omap_cfg_reg(MMC_DAT1); | 120 | omap_cfg_reg(MMC_DAT1); |
121 | /* NOTE: DAT2 can be on W10 (here) or M15 */ | 121 | /* NOTE: DAT2 can be on W10 (here) or M15 */ |
122 | if (!mmc_controller->slots[0].nomux) | 122 | if (!mmc_controller->slots[0].nomux) |
@@ -132,7 +132,7 @@ static inline void omap1_mmc_mux(struct omap_mmc_platform_data *mmc_controller, | |||
132 | omap_cfg_reg(Y10_1610_MMC2_CLK); | 132 | omap_cfg_reg(Y10_1610_MMC2_CLK); |
133 | omap_cfg_reg(R18_1610_MMC2_CLKIN); | 133 | omap_cfg_reg(R18_1610_MMC2_CLKIN); |
134 | omap_cfg_reg(W8_1610_MMC2_DAT0); | 134 | omap_cfg_reg(W8_1610_MMC2_DAT0); |
135 | if (mmc_controller->slots[1].wire4) { | 135 | if (mmc_controller->slots[1].wires == 4) { |
136 | omap_cfg_reg(V8_1610_MMC2_DAT1); | 136 | omap_cfg_reg(V8_1610_MMC2_DAT1); |
137 | omap_cfg_reg(W15_1610_MMC2_DAT2); | 137 | omap_cfg_reg(W15_1610_MMC2_DAT2); |
138 | omap_cfg_reg(R10_1610_MMC2_DAT3); | 138 | omap_cfg_reg(R10_1610_MMC2_DAT3); |