summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorankishore <ankishore@nvidia.com>2011-03-24 18:09:00 +0530
committerDan Willemsen <dwillemsen@nvidia.com>2011-04-26 15:54:20 -0700
commit98cd2c1792b9e48bf7c5ea71622c177e9099dde7 (patch)
tree710ff25cd0403a888a334f2251d765d71dfdc196
parented54753b24a59ffc27c17347151d24e7314f93f4 (diff)
ARM: tegra: cardhu: Dynamic selection of display drivers
Dynamically selecting the display driver as per the board id Original-Change-Id: I0220e3359c0475e112a5f91d0fb59d390c20b2ec Reviewed-on: http://git-master/r/24129 Reviewed-by: Animesh Kishore <ankishore@nvidia.com> Tested-by: Animesh Kishore <ankishore@nvidia.com> Reviewed-by: Venkata Nageswara Penumarty <vpenumarty@nvidia.com> Reviewed-by: Ramachandrudu Kandhala <rkandhala@nvidia.com> Change-Id: I58811ab1cfdb47d231838228cee9578638a9f665
-rw-r--r--arch/arm/mach-tegra/board-cardhu-panel.c83
-rw-r--r--arch/arm/mach-tegra/board-cardhu.h1
2 files changed, 52 insertions, 32 deletions
diff --git a/arch/arm/mach-tegra/board-cardhu-panel.c b/arch/arm/mach-tegra/board-cardhu-panel.c
index 0d0e54eff009..6a8ebfc25b0e 100644
--- a/arch/arm/mach-tegra/board-cardhu-panel.c
+++ b/arch/arm/mach-tegra/board-cardhu-panel.c
@@ -39,13 +39,11 @@
#include "devices.h"
#include "gpio-names.h"
-#ifdef CONFIG_TEGRA_CARDHU_DSI
/* Select panel to be used. */
#define DSI_PANEL_219 0
#define DSI_PANEL_218 1
#define AVDD_LCD PMU_TCA6416_GPIO_PORT17
#define DSI_PANEL_RESET 1
-#endif
#define cardhu_lvds_shutdown TEGRA_GPIO_PL2
#define cardhu_bl_enb TEGRA_GPIO_PH2
@@ -68,23 +66,30 @@ static struct regulator *cardhu_lvds_reg = NULL;
static struct regulator *cardhu_lvds_vdd_bl = NULL;
static struct regulator *cardhu_lvds_vdd_panel = NULL;
+static struct board_info board_info;
+
static int cardhu_backlight_init(struct device *dev) {
int ret;
#ifndef CONFIG_TEGRA_CARDHU_DSI
- tegra_gpio_disable(cardhu_bl_pwm);
+ if (board_info.board_id != BOARD_PM269) {
+ tegra_gpio_disable(cardhu_bl_pwm);
+
+ ret = gpio_request(cardhu_bl_enb, "backlight_enb");
+ if (ret < 0)
+ return ret;
+
+ ret = gpio_direction_output(cardhu_bl_enb, 1);
+ if (ret < 0)
+ gpio_free(cardhu_bl_enb);
+ else
+ tegra_gpio_enable(cardhu_bl_enb);
- ret = gpio_request(cardhu_bl_enb, "backlight_enb");
- if (ret < 0)
return ret;
+ }
+#endif
- ret = gpio_direction_output(cardhu_bl_enb, 1);
- if (ret < 0)
- gpio_free(cardhu_bl_enb);
- else
- tegra_gpio_enable(cardhu_bl_enb);
-#else
- #if DSI_PANEL_219 || DSI_PANEL_218
+#if DSI_PANEL_219 || DSI_PANEL_218
/* Enable back light for DSIa panel */
printk("cardhu_dsi_backlight_init\n");
ret = gpio_request(cardhu_dsia_bl_enb, "dsia_bl_enable");
@@ -107,21 +112,23 @@ static int cardhu_backlight_init(struct device *dev) {
gpio_free(cardhu_dsib_bl_enb);
else
tegra_gpio_enable(cardhu_dsib_bl_enb);
- #endif
-
#endif
+
return ret;
};
static void cardhu_backlight_exit(struct device *dev) {
#ifndef CONFIG_TEGRA_CARDHU_DSI
- int ret;
- /*ret = gpio_request(cardhu_bl_enb, "backlight_enb");*/
- gpio_set_value(cardhu_bl_enb, 0);
- gpio_free(cardhu_bl_enb);
- tegra_gpio_disable(cardhu_bl_enb);
-#else
- #if DSI_PANEL_219 || DSI_PANEL_218
+ if (board_info.board_id != BOARD_PM269) {
+ /* int ret; */
+ /*ret = gpio_request(cardhu_bl_enb, "backlight_enb");*/
+ gpio_set_value(cardhu_bl_enb, 0);
+ gpio_free(cardhu_bl_enb);
+ tegra_gpio_disable(cardhu_bl_enb);
+ return;
+ }
+#endif
+#if DSI_PANEL_219 || DSI_PANEL_218
/* Disable back light for DSIa panel */
gpio_set_value(cardhu_dsia_bl_enb, 0);
gpio_free(cardhu_dsia_bl_enb);
@@ -134,7 +141,6 @@ static void cardhu_backlight_exit(struct device *dev) {
gpio_set_value(TEGRA_GPIO_PL2, 1);
mdelay(20);
- #endif
#endif
}
@@ -144,18 +150,22 @@ static int cardhu_backlight_notify(struct device *unused, int brightness)
int orig_brightness = brightness;
#ifndef CONFIG_TEGRA_CARDHU_DSI
- /* Set the backlight GPIO pin mode to 'backlight_enable' */
- gpio_request(cardhu_bl_enb, "backlight_enb");
- gpio_set_value(cardhu_bl_enb, !!brightness);
-#else
- #if DSI_PANEL_219 || DSI_PANEL_218
+ if (board_info.board_id != BOARD_PM269) {
+ /* Set the backlight GPIO pin mode to 'backlight_enable' */
+ gpio_request(cardhu_bl_enb, "backlight_enb");
+ gpio_set_value(cardhu_bl_enb, !!brightness);
+ goto final;
+ }
+#endif
+#if DSI_PANEL_219 || DSI_PANEL_218
/* DSIa */
gpio_set_value(cardhu_dsia_bl_enb, !!brightness);
/* DSIb */
gpio_set_value(cardhu_dsib_bl_enb, !!brightness);
- #endif
#endif
+
+final:
/* SD brightness is a percentage, 8-bit value. */
brightness = (brightness * cur_sd_brightness) / 255;
if (cur_sd_brightness != 255) {
@@ -321,7 +331,6 @@ static struct resource cardhu_disp1_resources[] = {
.end = 0, /* Filled in by cardhu_panel_init() */
.flags = IORESOURCE_MEM,
},
-#ifdef CONFIG_TEGRA_CARDHU_DSI
#ifdef CONFIG_TEGRA_DSI_INSTANCE_1
{
.name = "dsi_regs",
@@ -337,7 +346,6 @@ static struct resource cardhu_disp1_resources[] = {
.flags = IORESOURCE_MEM,
},
#endif
-#endif
};
static struct resource cardhu_disp2_resources[] = {
@@ -454,7 +462,6 @@ static struct tegra_dc_platform_data cardhu_disp2_pdata = {
.emc_clk_rate = 300000000,
};
-#ifdef CONFIG_TEGRA_CARDHU_DSI
static int cardhu_dsi_panel_enable(void)
{
static struct regulator *reg = NULL;
@@ -646,7 +653,7 @@ static struct tegra_fb_data cardhu_dsi_fb_data = {
.bits_per_pixel = 32,
#endif
};
-#endif
+
static struct tegra_dc_out cardhu_disp1_out = {
.align = TEGRA_DC_ALIGN_MSB,
@@ -765,6 +772,18 @@ int __init cardhu_panel_init(void)
int err;
struct resource *res;
+ tegra_get_board_info(&board_info);
+
+ if (board_info.board_id == BOARD_PM269) {
+ cardhu_disp1_out.type = TEGRA_DC_OUT_DSI;
+ cardhu_disp1_out.modes = cardhu_dsi_modes;
+ cardhu_disp1_out.n_modes = ARRAY_SIZE(cardhu_dsi_modes);
+ cardhu_disp1_out.dsi = &cardhu_dsi;
+ cardhu_disp1_out.enable = cardhu_dsi_panel_enable;
+ cardhu_disp1_out.disable = cardhu_dsi_panel_disable;
+ cardhu_disp1_pdata.fb = &cardhu_dsi_fb_data;
+ }
+
cardhu_carveouts[1].base = tegra_carveout_start;
cardhu_carveouts[1].size = tegra_carveout_size;
diff --git a/arch/arm/mach-tegra/board-cardhu.h b/arch/arm/mach-tegra/board-cardhu.h
index 270c3b37aedf..b08d96151bad 100644
--- a/arch/arm/mach-tegra/board-cardhu.h
+++ b/arch/arm/mach-tegra/board-cardhu.h
@@ -28,6 +28,7 @@
#define BOARD_E1186 0x0B56
#define BOARD_E1198 0x0B62
#define BOARD_E1291 0x0C5B
+#define BOARD_PM269 0x0245
/* External peripheral act as gpio */
/* TPS6591x GPIOs */