aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorMurthy, Raghuveer <raghuveer.murthy@ti.com>2011-03-14 08:52:25 -0400
committerTomi Valkeinen <tomi.valkeinen@ti.com>2011-03-18 00:07:56 -0400
commitb295d6e593e02168fdafc5db11464b6d51cf239d (patch)
treebec061b83f141b13f30e1bd322fac2c7520bdc9b /arch
parent2de110868f455b74e91111801ce63a3c9d06f091 (diff)
OMAP4: PandaBoard: Adding DVI support
Adding DVI support to OMAP4 PandaBoard. PandaBoard uses TFP410 DVI Framer chip http://focus.ti.com/lit/ds/symlink/tfp410.pdf The TFP410 gets its power enable and display data over GPIO lines muxed in from OMAP4430. PandaBoard supports other LCD displays through expansion connectors, following board rework. This will disable the DVI interface. However, the existing mux settings remain the same PandaBoard additionally supports display over HDMI interface. It is mutually exclusive to display over DVI. Hence the mux settings need to be configured seperately, as and when HDMI is enabled Also, I2C3 bus used for reading EDID data from DVI Monitors is registered here. Since the design is similar to BeagleBoard, the code for the same is taken from the kernel.org commit e3333f48dd5cb21 (omap: Adding beagle i2c eeprom driver to read EDID) Reviewed-by: Manjunath G Kondaiah <manjugk@ti.com> Reviewed-by: Anand Gadiyar <gadiyar@ti.com> Reviewed-by: Nishanth Menon <nm@ti.com> Reviewed-by: Sumit Semwal <sumit.semwal@ti.com> Signed-off-by: Raghuveer Murthy <raghuveer.murthy@ti.com> [tomi.valkeinen@ti.com: fixed conflicts with HDMI] Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Diffstat (limited to 'arch')
-rw-r--r--arch/arm/mach-omap2/board-omap4panda.c131
1 files changed, 129 insertions, 2 deletions
diff --git a/arch/arm/mach-omap2/board-omap4panda.c b/arch/arm/mach-omap2/board-omap4panda.c
index 795ffc461522..e2b912f376cc 100644
--- a/arch/arm/mach-omap2/board-omap4panda.c
+++ b/arch/arm/mach-omap2/board-omap4panda.c
@@ -40,6 +40,7 @@
40#include <plat/common.h> 40#include <plat/common.h>
41#include <plat/usb.h> 41#include <plat/usb.h>
42#include <plat/mmc.h> 42#include <plat/mmc.h>
43#include <plat/panel-generic-dpi.h>
43#include "timer-gp.h" 44#include "timer-gp.h"
44 45
45#include "hsmmc.h" 46#include "hsmmc.h"
@@ -435,6 +436,17 @@ static struct i2c_board_info __initdata omap4_panda_i2c_boardinfo[] = {
435 .platform_data = &omap4_panda_twldata, 436 .platform_data = &omap4_panda_twldata,
436 }, 437 },
437}; 438};
439
440/*
441 * Display monitor features are burnt in their EEPROM as EDID data. The EEPROM
442 * is connected as I2C slave device, and can be accessed at address 0x50
443 */
444static struct i2c_board_info __initdata panda_i2c_eeprom[] = {
445 {
446 I2C_BOARD_INFO("eeprom", 0x50),
447 },
448};
449
438static int __init omap4_panda_i2c_init(void) 450static int __init omap4_panda_i2c_init(void)
439{ 451{
440 /* 452 /*
@@ -444,7 +456,12 @@ static int __init omap4_panda_i2c_init(void)
444 omap_register_i2c_bus(1, 400, omap4_panda_i2c_boardinfo, 456 omap_register_i2c_bus(1, 400, omap4_panda_i2c_boardinfo,
445 ARRAY_SIZE(omap4_panda_i2c_boardinfo)); 457 ARRAY_SIZE(omap4_panda_i2c_boardinfo));
446 omap_register_i2c_bus(2, 400, NULL, 0); 458 omap_register_i2c_bus(2, 400, NULL, 0);
447 omap_register_i2c_bus(3, 400, NULL, 0); 459 /*
460 * Bus 3 is attached to the DVI port where devices like the pico DLP
461 * projector don't work reliably with 400kHz
462 */
463 omap_register_i2c_bus(3, 100, panda_i2c_eeprom,
464 ARRAY_SIZE(panda_i2c_eeprom));
448 omap_register_i2c_bus(4, 400, NULL, 0); 465 omap_register_i2c_bus(4, 400, NULL, 0);
449 return 0; 466 return 0;
450} 467}
@@ -464,12 +481,115 @@ static struct omap_board_mux board_mux[] __initdata = {
464 OMAP4_MUX(SDMMC5_DAT1, OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLUP), 481 OMAP4_MUX(SDMMC5_DAT1, OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLUP),
465 OMAP4_MUX(SDMMC5_DAT2, OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLUP), 482 OMAP4_MUX(SDMMC5_DAT2, OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLUP),
466 OMAP4_MUX(SDMMC5_DAT3, OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLUP), 483 OMAP4_MUX(SDMMC5_DAT3, OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLUP),
484 /* gpio 0 - TFP410 PD */
485 OMAP4_MUX(KPD_COL1, OMAP_PIN_OUTPUT | OMAP_MUX_MODE3),
486 /* dispc2_data23 */
487 OMAP4_MUX(USBB2_ULPITLL_STP, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
488 /* dispc2_data22 */
489 OMAP4_MUX(USBB2_ULPITLL_DIR, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
490 /* dispc2_data21 */
491 OMAP4_MUX(USBB2_ULPITLL_NXT, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
492 /* dispc2_data20 */
493 OMAP4_MUX(USBB2_ULPITLL_DAT0, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
494 /* dispc2_data19 */
495 OMAP4_MUX(USBB2_ULPITLL_DAT1, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
496 /* dispc2_data18 */
497 OMAP4_MUX(USBB2_ULPITLL_DAT2, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
498 /* dispc2_data15 */
499 OMAP4_MUX(USBB2_ULPITLL_DAT3, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
500 /* dispc2_data14 */
501 OMAP4_MUX(USBB2_ULPITLL_DAT4, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
502 /* dispc2_data13 */
503 OMAP4_MUX(USBB2_ULPITLL_DAT5, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
504 /* dispc2_data12 */
505 OMAP4_MUX(USBB2_ULPITLL_DAT6, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
506 /* dispc2_data11 */
507 OMAP4_MUX(USBB2_ULPITLL_DAT7, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
508 /* dispc2_data10 */
509 OMAP4_MUX(DPM_EMU3, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
510 /* dispc2_data9 */
511 OMAP4_MUX(DPM_EMU4, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
512 /* dispc2_data16 */
513 OMAP4_MUX(DPM_EMU5, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
514 /* dispc2_data17 */
515 OMAP4_MUX(DPM_EMU6, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
516 /* dispc2_hsync */
517 OMAP4_MUX(DPM_EMU7, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
518 /* dispc2_pclk */
519 OMAP4_MUX(DPM_EMU8, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
520 /* dispc2_vsync */
521 OMAP4_MUX(DPM_EMU9, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
522 /* dispc2_de */
523 OMAP4_MUX(DPM_EMU10, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
524 /* dispc2_data8 */
525 OMAP4_MUX(DPM_EMU11, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
526 /* dispc2_data7 */
527 OMAP4_MUX(DPM_EMU12, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
528 /* dispc2_data6 */
529 OMAP4_MUX(DPM_EMU13, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
530 /* dispc2_data5 */
531 OMAP4_MUX(DPM_EMU14, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
532 /* dispc2_data4 */
533 OMAP4_MUX(DPM_EMU15, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
534 /* dispc2_data3 */
535 OMAP4_MUX(DPM_EMU16, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
536 /* dispc2_data2 */
537 OMAP4_MUX(DPM_EMU17, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
538 /* dispc2_data1 */
539 OMAP4_MUX(DPM_EMU18, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
540 /* dispc2_data0 */
541 OMAP4_MUX(DPM_EMU19, OMAP_PIN_OUTPUT | OMAP_MUX_MODE5),
467 { .reg_offset = OMAP_MUX_TERMINATOR }, 542 { .reg_offset = OMAP_MUX_TERMINATOR },
468}; 543};
469#else 544#else
470#define board_mux NULL 545#define board_mux NULL
471#endif 546#endif
472 547
548/* Display DVI */
549#define PANDA_DVI_TFP410_POWER_DOWN_GPIO 0
550
551static int omap4_panda_enable_dvi(struct omap_dss_device *dssdev)
552{
553 gpio_set_value(dssdev->reset_gpio, 1);
554 return 0;
555}
556
557static void omap4_panda_disable_dvi(struct omap_dss_device *dssdev)
558{
559 gpio_set_value(dssdev->reset_gpio, 0);
560}
561
562/* Using generic display panel */
563static struct panel_generic_dpi_data omap4_dvi_panel = {
564 .name = "generic",
565 .platform_enable = omap4_panda_enable_dvi,
566 .platform_disable = omap4_panda_disable_dvi,
567};
568
569struct omap_dss_device omap4_panda_dvi_device = {
570 .type = OMAP_DISPLAY_TYPE_DPI,
571 .name = "dvi",
572 .driver_name = "generic_dpi_panel",
573 .data = &omap4_dvi_panel,
574 .phy.dpi.data_lines = 24,
575 .reset_gpio = PANDA_DVI_TFP410_POWER_DOWN_GPIO,
576 .channel = OMAP_DSS_CHANNEL_LCD2,
577};
578
579int __init omap4_panda_dvi_init(void)
580{
581 int r;
582
583 /* Requesting TFP410 DVI GPIO and disabling it, at bootup */
584 r = gpio_request_one(omap4_panda_dvi_device.reset_gpio,
585 GPIOF_OUT_INIT_LOW, "DVI PD");
586 if (r)
587 pr_err("Failed to get DVI powerdown GPIO\n");
588
589 return r;
590}
591
592
473static void omap4_panda_hdmi_mux_init(void) 593static void omap4_panda_hdmi_mux_init(void)
474{ 594{
475 /* PAD0_HDMI_HPD_PAD1_HDMI_CEC */ 595 /* PAD0_HDMI_HPD_PAD1_HDMI_CEC */
@@ -525,17 +645,24 @@ static struct omap_dss_device omap4_panda_hdmi_device = {
525}; 645};
526 646
527static struct omap_dss_device *omap4_panda_dss_devices[] = { 647static struct omap_dss_device *omap4_panda_dss_devices[] = {
648 &omap4_panda_dvi_device,
528 &omap4_panda_hdmi_device, 649 &omap4_panda_hdmi_device,
529}; 650};
530 651
531static struct omap_dss_board_info omap4_panda_dss_data = { 652static struct omap_dss_board_info omap4_panda_dss_data = {
532 .num_devices = ARRAY_SIZE(omap4_panda_dss_devices), 653 .num_devices = ARRAY_SIZE(omap4_panda_dss_devices),
533 .devices = omap4_panda_dss_devices, 654 .devices = omap4_panda_dss_devices,
534 .default_device = &omap4_panda_hdmi_device, 655 .default_device = &omap4_panda_dvi_device,
535}; 656};
536 657
537void omap4_panda_display_init(void) 658void omap4_panda_display_init(void)
538{ 659{
660 int r;
661
662 r = omap4_panda_dvi_init();
663 if (r)
664 pr_err("error initializing panda DVI\n");
665
539 omap4_panda_hdmi_mux_init(); 666 omap4_panda_hdmi_mux_init();
540 omap_display_init(&omap4_panda_dss_data); 667 omap_display_init(&omap4_panda_dss_data);
541} 668}