diff options
author | Tony Lindgren <tony@atomide.com> | 2012-02-20 12:43:29 -0500 |
---|---|---|
committer | Tony Lindgren <tony@atomide.com> | 2012-02-20 13:00:39 -0500 |
commit | 3b972bf06c22f5abfa6586a8baf50321cd825965 (patch) | |
tree | 666fd47675069dae78337f648670a550c4f9f85b /arch/arm/mach-omap2/board-omap3evm.c | |
parent | 993e4fbd7822cdf874fcf9f1b054a323d67ccf97 (diff) |
ARM: OMAP2+: Split omap2_hsmmc_init() to properly support I2C GPIO pins
Otherwise omap_device_build() and omap_mux related functions
can't be marked as __init when twl is build as a module.
If a board is using GPIO pins or regulators configured by an
external chip, such as TWL PMIC on I2C bus, the board must
mark those MMC controllers as deferred. Additionally both
omap_hsmmc_init() and omap_hsmmc_late_init() must be called
by the board.
For MMC controllers using internal GPIO pins for card
detect and regulators the slots don't need to be marked
deferred. In this case calling omap_hsmmc_init() is sufficient.
Only mark the MMC slots using gpio_cd or gpio_wd as deferred
as noted by Igor Grinberg <grinberg@compulab.co.il>.
Note that this patch does not change the behaviour for
board-4430sdp.c board-omap4panda.c. These boards wrongly
rely on the omap_hsmmc.c init function callback to configure
the PMIC GPIO interrupt lines on external chip. If the PMIC
interrupt lines are not configured during init, they will
fail.
Reported-by: Russell King <rmk+kernel@arm.linux.org.uk>
Signed-off-by: Rajendra Nayak <rnayak@ti.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'arch/arm/mach-omap2/board-omap3evm.c')
-rw-r--r-- | arch/arm/mach-omap2/board-omap3evm.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/arch/arm/mach-omap2/board-omap3evm.c b/arch/arm/mach-omap2/board-omap3evm.c index c775bead1497..3d585b81669a 100644 --- a/arch/arm/mach-omap2/board-omap3evm.c +++ b/arch/arm/mach-omap2/board-omap3evm.c | |||
@@ -317,6 +317,7 @@ static struct omap2_hsmmc_info mmc[] = { | |||
317 | .caps = MMC_CAP_4_BIT_DATA, | 317 | .caps = MMC_CAP_4_BIT_DATA, |
318 | .gpio_cd = -EINVAL, | 318 | .gpio_cd = -EINVAL, |
319 | .gpio_wp = 63, | 319 | .gpio_wp = 63, |
320 | .deferred = true, | ||
320 | }, | 321 | }, |
321 | #ifdef CONFIG_WL12XX_PLATFORM_DATA | 322 | #ifdef CONFIG_WL12XX_PLATFORM_DATA |
322 | { | 323 | { |
@@ -363,7 +364,7 @@ static int omap3evm_twl_gpio_setup(struct device *dev, | |||
363 | /* gpio + 0 is "mmc0_cd" (input/IRQ) */ | 364 | /* gpio + 0 is "mmc0_cd" (input/IRQ) */ |
364 | omap_mux_init_gpio(63, OMAP_PIN_INPUT); | 365 | omap_mux_init_gpio(63, OMAP_PIN_INPUT); |
365 | mmc[0].gpio_cd = gpio + 0; | 366 | mmc[0].gpio_cd = gpio + 0; |
366 | omap2_hsmmc_init(mmc); | 367 | omap_hsmmc_late_init(mmc); |
367 | 368 | ||
368 | /* | 369 | /* |
369 | * Most GPIOs are for USB OTG. Some are mostly sent to | 370 | * Most GPIOs are for USB OTG. Some are mostly sent to |
@@ -644,6 +645,7 @@ static void __init omap3_evm_init(void) | |||
644 | omap_board_config = omap3_evm_config; | 645 | omap_board_config = omap3_evm_config; |
645 | omap_board_config_size = ARRAY_SIZE(omap3_evm_config); | 646 | omap_board_config_size = ARRAY_SIZE(omap3_evm_config); |
646 | 647 | ||
648 | omap_hsmmc_init(mmc); | ||
647 | omap3_evm_i2c_init(); | 649 | omap3_evm_i2c_init(); |
648 | 650 | ||
649 | omap_display_init(&omap3_evm_dss_data); | 651 | omap_display_init(&omap3_evm_dss_data); |