summaryrefslogtreecommitdiff
path: root/arch/arm/mach-ux500/board-mop500-mcde.c
diff options
context:
space:
mode:
authorPer Persson <per.xb.persson@stericsson.com>2011-05-23 15:11:29 +0200
committersaid m bagheri <ebgheri@steludxu2848.(none)>2011-06-17 13:41:55 +0200
commitc684d2c9a4c4eb5345f3f41151c9c7f3716548f0 (patch)
treece91ae965dcd3afcfc6f00028c6cdc0c94e3bfcd /arch/arm/mach-ux500/board-mop500-mcde.c
parentf5373d7b5e35fc305ce22d1808cfeb11c316640c (diff)
arm: ux500: Correct FB height when triple buffer
When triple buffering is enabled, the correct virtual height shall be used when the frame buffer is dynamicaly created. Dispdev is removed for HDMI case. board-u5500-mcde is updated. ST-Ericsson ID: 341298 ST-Ericsson Linux next: Not tested, ER 282779 ST-Ericsson FOSS-OUT ID: Trivial Change-Id: Id9dac8b436a6013e5bf3a775ef93d99705663fb2 Signed-off-by: Per Persson <per.xb.persson@stericsson.com> Reviewed-on: http://gerrit.lud.stericsson.com/gerrit/23545 Reviewed-by: Jimmy RUBIN <jimmy.rubin@stericsson.com> Reviewed-by: Marcel TUNNISSEN <marcel.tuennissen@stericsson.com>
Diffstat (limited to 'arch/arm/mach-ux500/board-mop500-mcde.c')
-rw-r--r--arch/arm/mach-ux500/board-mop500-mcde.c13
1 files changed, 6 insertions, 7 deletions
diff --git a/arch/arm/mach-ux500/board-mop500-mcde.c b/arch/arm/mach-ux500/board-mop500-mcde.c
index d9b36fcdb81..bf4045f3965 100644
--- a/arch/arm/mach-ux500/board-mop500-mcde.c
+++ b/arch/arm/mach-ux500/board-mop500-mcde.c
@@ -43,7 +43,6 @@ static struct delayed_work work_dispreg_hdmi;
#endif
#define MCDE_NR_OF_DISPLAYS 3
-static struct mcde_display_device *displays[MCDE_NR_OF_DISPLAYS] = { NULL };
static int display_initialized_during_boot;
static int __init startup_graphics_setup(char *str)
@@ -419,7 +418,6 @@ static void delayed_work_dispreg_hdmi(struct work_struct *ptr)
{
if (mcde_display_device_register(&av8100_hdmi))
pr_warning("Failed to register av8100_hdmi\n");
- displays[TERTIARY_DISPLAY_ID] = &av8100_hdmi;
}
#endif /* CONFIG_DISPLAY_AV8100_TERTIARY */
@@ -494,16 +492,20 @@ static int display_postregistered_callback(struct notifier_block *nb,
ddev->default_pixel_format,
rotate);
- if (IS_ERR(fbi))
+ if (IS_ERR(fbi)) {
dev_warn(&ddev->dev,
"Failed to create fb for display %s\n",
ddev->name);
- else
+ goto display_postregistered_callback_err;
+ } else
dev_info(&ddev->dev, "Framebuffer created (%s)\n",
ddev->name);
}
return 0;
+
+display_postregistered_callback_err:
+ return -1;
}
static struct notifier_block display_nb = {
@@ -648,7 +650,6 @@ int __init init_display_devices(void)
ret = mcde_display_device_register(&generic_display0);
if (ret)
pr_warning("Failed to register generic display device 0\n");
- displays[0] = &generic_display0;
#endif
#ifdef CONFIG_DISPLAY_GENERIC_DSI_SECONDARY
@@ -659,7 +660,6 @@ int __init init_display_devices(void)
ret = mcde_display_device_register(&generic_subdisplay);
if (ret)
pr_warning("Failed to register generic sub display device\n");
- displays[1] = &generic_subdisplay;
#endif
#ifdef CONFIG_DISPLAY_AV8100_TERTIARY
@@ -673,7 +673,6 @@ int __init init_display_devices(void)
ret = mcde_display_device_register(&tvout_ab8500_display);
if (ret)
pr_warning("Failed to register ab8500 tvout device\n");
- displays[2] = &tvout_ab8500_display;
#endif
return ret;