This patch adds MMC1 and MMC2 Controller data for OMAP4430 Board
file.

Signed-off-by: Kishore Kadiyala <kishore.kadiy...@ti.com>
---
 arch/arm/mach-omap2/Makefile        |    3 +-
 arch/arm/mach-omap2/board-4430sdp.c |   39 ++++++++++++++++++++++++++++------
 2 files changed, 34 insertions(+), 8 deletions(-)

diff --git a/arch/arm/mach-omap2/Makefile b/arch/arm/mach-omap2/Makefile
index ffe600a..65d8d11 100644
--- a/arch/arm/mach-omap2/Makefile
+++ b/arch/arm/mach-omap2/Makefile
@@ -140,7 +140,8 @@ obj-$(CONFIG_MACH_IGEP0020)         += board-igep0020.o \
                                           hsmmc.o
 obj-$(CONFIG_MACH_OMAP3_TOUCHBOOK)     += board-omap3touchbook.o \
                                           hsmmc.o
-obj-$(CONFIG_MACH_OMAP_4430SDP)                += board-4430sdp.o
+obj-$(CONFIG_MACH_OMAP_4430SDP)                += board-4430sdp.o \
+                                          hsmmc.o

 obj-$(CONFIG_MACH_OMAP3517EVM)         += board-am3517evm.o

diff --git a/arch/arm/mach-omap2/board-4430sdp.c 
b/arch/arm/mach-omap2/board-4430sdp.c
index f1b9708..c4e61d5 100644
--- a/arch/arm/mach-omap2/board-4430sdp.c
+++ b/arch/arm/mach-omap2/board-4430sdp.c
@@ -33,6 +33,7 @@
 #include <plat/control.h>
 #include <plat/timer-gp.h>
 #include <plat/usb.h>
+#include "hsmmc.h"

 #define ETHERNET_KS8851_IRQ            34
 #define ETHERNET_KS8851_POWER_ENABLE   48
@@ -93,16 +94,27 @@ static struct omap_musb_board_data musb_board_data = {
        .power                  = 100,
 };

-static struct regulator_consumer_supply sdp4430_vmmc_supply[] = {
+static struct omap2_hsmmc_info mmc[] = {
        {
-               .supply = "vmmc",
+               .mmc            = 1,
+               .wires          = 8,
+               /* "mmc0_cd" is not a gpio interrupt
+                * but is a phoenix interrupt
+                */
+               .gpio_cd        = TWL6030_IRQ_BASE + MMCDETECT_INTR_OFFSET,
+               .gpio_wp        = -EINVAL,
        },
        {
-               .supply = "vmmc",
-       },
-       {
-               .supply = "vmmc",
+               .mmc            = 2,
+               .wires          = 8,
+               .gpio_cd        = -EINVAL,
+               .gpio_wp        = -EINVAL,
+               .nonremovable   = true,
        },
+       {}      /* Terminator */
+};
+
+static struct regulator_consumer_supply sdp4430_vmmc_supply[] = {
        {
                .supply = "vmmc",
        },
@@ -111,6 +123,18 @@ static struct regulator_consumer_supply 
sdp4430_vmmc_supply[] = {
        },
 };

+static int __init sdp4430_mmc_init(void)
+{
+       omap2_hsmmc_init(mmc);
+
+       /* link regulators to MMC adapters ... we "know" the
+        * regulators will be set up only *after* we return.
+        */
+       sdp4430_vmmc_supply[0].dev = mmc[0].dev;
+       sdp4430_vmmc_supply[1].dev = mmc[1].dev;
+       return 0;
+}
+
 static struct regulator_init_data sdp4430_vaux1 = {
        .constraints = {
                .min_uV                 = 1000000,
@@ -162,7 +186,7 @@ static struct regulator_init_data sdp4430_vmmc = {
                                        | REGULATOR_CHANGE_MODE
                                        | REGULATOR_CHANGE_STATUS,
        },
-       .num_consumer_supplies  = 5,
+       .num_consumer_supplies  = 2,
        .consumer_supplies      = sdp4430_vmmc_supply,
 };

@@ -281,6 +305,7 @@ static void __init omap_4430sdp_init(void)
        omap4_i2c_init();
        platform_add_devices(sdp4430_devices, ARRAY_SIZE(sdp4430_devices));
        omap_serial_init();
+       sdp4430_mmc_init();
        /* OMAP4 SDP uses internal transceiver so register nop transceiver */
        usb_nop_xceiv_register();
        /* FIXME: allow multi-omap to boot until musb is updated for omap4 */
-- 
1.6.3.3

--
To unsubscribe from this list: send the line "unsubscribe linux-mmc" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to