diff options
author | Sascha Hauer <s.hauer@pengutronix.de> | 2011-08-08 02:22:41 -0400 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2011-08-08 02:22:41 -0400 |
commit | 1a43f2012455a977397deffe35912fd3f3ce17b9 (patch) | |
tree | 5189f337df44e7a495fbd097cd476b0380babd8c /arch/arm/mach-omap2/board-igep0020.c | |
parent | e1b96ada659431669efaf3defa997abf5db68130 (diff) | |
parent | 322a8b034003c0d46d39af85bf24fee27b902f48 (diff) |
Merge commit 'v3.1-rc1' into imx-fixes
Diffstat (limited to 'arch/arm/mach-omap2/board-igep0020.c')
-rw-r--r-- | arch/arm/mach-omap2/board-igep0020.c | 79 |
1 files changed, 26 insertions, 53 deletions
diff --git a/arch/arm/mach-omap2/board-igep0020.c b/arch/arm/mach-omap2/board-igep0020.c index 0c1bfca3f731..35be778caf1b 100644 --- a/arch/arm/mach-omap2/board-igep0020.c +++ b/arch/arm/mach-omap2/board-igep0020.c | |||
@@ -222,8 +222,9 @@ static inline void __init igep2_init_smsc911x(void) | |||
222 | static inline void __init igep2_init_smsc911x(void) { } | 222 | static inline void __init igep2_init_smsc911x(void) { } |
223 | #endif | 223 | #endif |
224 | 224 | ||
225 | static struct regulator_consumer_supply igep_vmmc1_supply = | 225 | static struct regulator_consumer_supply igep_vmmc1_supply[] = { |
226 | REGULATOR_SUPPLY("vmmc", "omap_hsmmc.0"); | 226 | REGULATOR_SUPPLY("vmmc", "omap_hsmmc.0"), |
227 | }; | ||
227 | 228 | ||
228 | /* VMMC1 for OMAP VDD_MMC1 (i/o) and MMC1 card */ | 229 | /* VMMC1 for OMAP VDD_MMC1 (i/o) and MMC1 card */ |
229 | static struct regulator_init_data igep_vmmc1 = { | 230 | static struct regulator_init_data igep_vmmc1 = { |
@@ -236,12 +237,13 @@ static struct regulator_init_data igep_vmmc1 = { | |||
236 | | REGULATOR_CHANGE_MODE | 237 | | REGULATOR_CHANGE_MODE |
237 | | REGULATOR_CHANGE_STATUS, | 238 | | REGULATOR_CHANGE_STATUS, |
238 | }, | 239 | }, |
239 | .num_consumer_supplies = 1, | 240 | .num_consumer_supplies = ARRAY_SIZE(igep_vmmc1_supply), |
240 | .consumer_supplies = &igep_vmmc1_supply, | 241 | .consumer_supplies = igep_vmmc1_supply, |
241 | }; | 242 | }; |
242 | 243 | ||
243 | static struct regulator_consumer_supply igep_vio_supply = | 244 | static struct regulator_consumer_supply igep_vio_supply[] = { |
244 | REGULATOR_SUPPLY("vmmc_aux", "omap_hsmmc.1"); | 245 | REGULATOR_SUPPLY("vmmc_aux", "omap_hsmmc.1"), |
246 | }; | ||
245 | 247 | ||
246 | static struct regulator_init_data igep_vio = { | 248 | static struct regulator_init_data igep_vio = { |
247 | .constraints = { | 249 | .constraints = { |
@@ -254,20 +256,21 @@ static struct regulator_init_data igep_vio = { | |||
254 | | REGULATOR_CHANGE_MODE | 256 | | REGULATOR_CHANGE_MODE |
255 | | REGULATOR_CHANGE_STATUS, | 257 | | REGULATOR_CHANGE_STATUS, |
256 | }, | 258 | }, |
257 | .num_consumer_supplies = 1, | 259 | .num_consumer_supplies = ARRAY_SIZE(igep_vio_supply), |
258 | .consumer_supplies = &igep_vio_supply, | 260 | .consumer_supplies = igep_vio_supply, |
259 | }; | 261 | }; |
260 | 262 | ||
261 | static struct regulator_consumer_supply igep_vmmc2_supply = | 263 | static struct regulator_consumer_supply igep_vmmc2_supply[] = { |
262 | REGULATOR_SUPPLY("vmmc", "omap_hsmmc.1"); | 264 | REGULATOR_SUPPLY("vmmc", "omap_hsmmc.1"), |
265 | }; | ||
263 | 266 | ||
264 | static struct regulator_init_data igep_vmmc2 = { | 267 | static struct regulator_init_data igep_vmmc2 = { |
265 | .constraints = { | 268 | .constraints = { |
266 | .valid_modes_mask = REGULATOR_MODE_NORMAL, | 269 | .valid_modes_mask = REGULATOR_MODE_NORMAL, |
267 | .always_on = 1, | 270 | .always_on = 1, |
268 | }, | 271 | }, |
269 | .num_consumer_supplies = 1, | 272 | .num_consumer_supplies = ARRAY_SIZE(igep_vmmc2_supply), |
270 | .consumer_supplies = &igep_vmmc2_supply, | 273 | .consumer_supplies = igep_vmmc2_supply, |
271 | }; | 274 | }; |
272 | 275 | ||
273 | static struct fixed_voltage_config igep_vwlan = { | 276 | static struct fixed_voltage_config igep_vwlan = { |
@@ -440,10 +443,6 @@ static struct twl4030_gpio_platform_data igep_twl4030_gpio_pdata = { | |||
440 | .setup = igep_twl_gpio_setup, | 443 | .setup = igep_twl_gpio_setup, |
441 | }; | 444 | }; |
442 | 445 | ||
443 | static struct twl4030_usb_data igep_usb_data = { | ||
444 | .usb_mode = T2_USB_MODE_ULPI, | ||
445 | }; | ||
446 | |||
447 | static int igep2_enable_dvi(struct omap_dss_device *dssdev) | 446 | static int igep2_enable_dvi(struct omap_dss_device *dssdev) |
448 | { | 447 | { |
449 | gpio_direction_output(IGEP2_GPIO_DVI_PUP, 1); | 448 | gpio_direction_output(IGEP2_GPIO_DVI_PUP, 1); |
@@ -480,26 +479,6 @@ static struct omap_dss_board_info igep2_dss_data = { | |||
480 | .default_device = &igep2_dvi_device, | 479 | .default_device = &igep2_dvi_device, |
481 | }; | 480 | }; |
482 | 481 | ||
483 | static struct regulator_consumer_supply igep2_vpll2_supplies[] = { | ||
484 | REGULATOR_SUPPLY("vdds_dsi", "omapdss"), | ||
485 | REGULATOR_SUPPLY("vdds_dsi", "omapdss_dsi1"), | ||
486 | }; | ||
487 | |||
488 | static struct regulator_init_data igep2_vpll2 = { | ||
489 | .constraints = { | ||
490 | .name = "VDVI", | ||
491 | .min_uV = 1800000, | ||
492 | .max_uV = 1800000, | ||
493 | .apply_uV = true, | ||
494 | .valid_modes_mask = REGULATOR_MODE_NORMAL | ||
495 | | REGULATOR_MODE_STANDBY, | ||
496 | .valid_ops_mask = REGULATOR_CHANGE_MODE | ||
497 | | REGULATOR_CHANGE_STATUS, | ||
498 | }, | ||
499 | .num_consumer_supplies = ARRAY_SIZE(igep2_vpll2_supplies), | ||
500 | .consumer_supplies = igep2_vpll2_supplies, | ||
501 | }; | ||
502 | |||
503 | static void __init igep2_display_init(void) | 482 | static void __init igep2_display_init(void) |
504 | { | 483 | { |
505 | int err = gpio_request_one(IGEP2_GPIO_DVI_PUP, GPIOF_OUT_INIT_HIGH, | 484 | int err = gpio_request_one(IGEP2_GPIO_DVI_PUP, GPIOF_OUT_INIT_HIGH, |
@@ -519,13 +498,6 @@ static void __init igep_init_early(void) | |||
519 | m65kxxxxam_sdrc_params); | 498 | m65kxxxxam_sdrc_params); |
520 | } | 499 | } |
521 | 500 | ||
522 | static struct twl4030_codec_audio_data igep2_audio_data; | ||
523 | |||
524 | static struct twl4030_codec_data igep2_codec_data = { | ||
525 | .audio_mclk = 26000000, | ||
526 | .audio = &igep2_audio_data, | ||
527 | }; | ||
528 | |||
529 | static int igep2_keymap[] = { | 501 | static int igep2_keymap[] = { |
530 | KEY(0, 0, KEY_LEFT), | 502 | KEY(0, 0, KEY_LEFT), |
531 | KEY(0, 1, KEY_RIGHT), | 503 | KEY(0, 1, KEY_RIGHT), |
@@ -558,11 +530,7 @@ static struct twl4030_keypad_data igep2_keypad_pdata = { | |||
558 | }; | 530 | }; |
559 | 531 | ||
560 | static struct twl4030_platform_data igep_twldata = { | 532 | static struct twl4030_platform_data igep_twldata = { |
561 | .irq_base = TWL4030_IRQ_BASE, | ||
562 | .irq_end = TWL4030_IRQ_END, | ||
563 | |||
564 | /* platform_data for children goes here */ | 533 | /* platform_data for children goes here */ |
565 | .usb = &igep_usb_data, | ||
566 | .gpio = &igep_twl4030_gpio_pdata, | 534 | .gpio = &igep_twl4030_gpio_pdata, |
567 | .vmmc1 = &igep_vmmc1, | 535 | .vmmc1 = &igep_vmmc1, |
568 | .vio = &igep_vio, | 536 | .vio = &igep_vio, |
@@ -578,6 +546,8 @@ static void __init igep_i2c_init(void) | |||
578 | { | 546 | { |
579 | int ret; | 547 | int ret; |
580 | 548 | ||
549 | omap3_pmic_get_config(&igep_twldata, TWL_COMMON_PDATA_USB, 0); | ||
550 | |||
581 | if (machine_is_igep0020()) { | 551 | if (machine_is_igep0020()) { |
582 | /* | 552 | /* |
583 | * Bus 3 is attached to the DVI port where devices like the | 553 | * Bus 3 is attached to the DVI port where devices like the |
@@ -588,9 +558,12 @@ static void __init igep_i2c_init(void) | |||
588 | if (ret) | 558 | if (ret) |
589 | pr_warning("IGEP2: Could not register I2C3 bus (%d)\n", ret); | 559 | pr_warning("IGEP2: Could not register I2C3 bus (%d)\n", ret); |
590 | 560 | ||
591 | igep_twldata.codec = &igep2_codec_data; | ||
592 | igep_twldata.keypad = &igep2_keypad_pdata; | 561 | igep_twldata.keypad = &igep2_keypad_pdata; |
593 | igep_twldata.vpll2 = &igep2_vpll2; | 562 | /* Get common pmic data */ |
563 | omap3_pmic_get_config(&igep_twldata, TWL_COMMON_PDATA_AUDIO, | ||
564 | TWL_COMMON_REGULATOR_VPLL2); | ||
565 | igep_twldata.vpll2->constraints.apply_uV = true; | ||
566 | igep_twldata.vpll2->constraints.name = "VDVI"; | ||
594 | } | 567 | } |
595 | 568 | ||
596 | omap3_pmic_init("twl4030", &igep_twldata); | 569 | omap3_pmic_init("twl4030", &igep_twldata); |
@@ -703,9 +676,9 @@ MACHINE_START(IGEP0020, "IGEP v2 board") | |||
703 | .reserve = omap_reserve, | 676 | .reserve = omap_reserve, |
704 | .map_io = omap3_map_io, | 677 | .map_io = omap3_map_io, |
705 | .init_early = igep_init_early, | 678 | .init_early = igep_init_early, |
706 | .init_irq = omap_init_irq, | 679 | .init_irq = omap3_init_irq, |
707 | .init_machine = igep_init, | 680 | .init_machine = igep_init, |
708 | .timer = &omap_timer, | 681 | .timer = &omap3_timer, |
709 | MACHINE_END | 682 | MACHINE_END |
710 | 683 | ||
711 | MACHINE_START(IGEP0030, "IGEP OMAP3 module") | 684 | MACHINE_START(IGEP0030, "IGEP OMAP3 module") |
@@ -713,7 +686,7 @@ MACHINE_START(IGEP0030, "IGEP OMAP3 module") | |||
713 | .reserve = omap_reserve, | 686 | .reserve = omap_reserve, |
714 | .map_io = omap3_map_io, | 687 | .map_io = omap3_map_io, |
715 | .init_early = igep_init_early, | 688 | .init_early = igep_init_early, |
716 | .init_irq = omap_init_irq, | 689 | .init_irq = omap3_init_irq, |
717 | .init_machine = igep_init, | 690 | .init_machine = igep_init, |
718 | .timer = &omap_timer, | 691 | .timer = &omap3_timer, |
719 | MACHINE_END | 692 | MACHINE_END |