diff options
-rw-r--r-- | arch/arm/plat-samsung/include/plat/fb.h | 3 | ||||
-rw-r--r-- | drivers/video/s3c-fb.c | 6 |
2 files changed, 6 insertions, 3 deletions
diff --git a/arch/arm/plat-samsung/include/plat/fb.h b/arch/arm/plat-samsung/include/plat/fb.h index 27d3b497b55b..cb3ca3adc685 100644 --- a/arch/arm/plat-samsung/include/plat/fb.h +++ b/arch/arm/plat-samsung/include/plat/fb.h | |||
@@ -42,6 +42,7 @@ struct s3c_fb_pd_win { | |||
42 | * @setup_gpio: Setup the external GPIO pins to the right state to transfer | 42 | * @setup_gpio: Setup the external GPIO pins to the right state to transfer |
43 | * the data from the display system to the connected display | 43 | * the data from the display system to the connected display |
44 | * device. | 44 | * device. |
45 | * @default_win: default window layer number to be used for UI layer. | ||
45 | * @vidcon0: The base vidcon0 values to control the panel data format. | 46 | * @vidcon0: The base vidcon0 values to control the panel data format. |
46 | * @vidcon1: The base vidcon1 values to control the panel data output. | 47 | * @vidcon1: The base vidcon1 values to control the panel data output. |
47 | * @win: The setup data for each hardware window, or NULL for unused. | 48 | * @win: The setup data for each hardware window, or NULL for unused. |
@@ -58,6 +59,8 @@ struct s3c_fb_platdata { | |||
58 | 59 | ||
59 | struct s3c_fb_pd_win *win[S3C_FB_MAX_WIN]; | 60 | struct s3c_fb_pd_win *win[S3C_FB_MAX_WIN]; |
60 | 61 | ||
62 | u32 default_win; | ||
63 | |||
61 | u32 vidcon0; | 64 | u32 vidcon0; |
62 | u32 vidcon1; | 65 | u32 vidcon1; |
63 | }; | 66 | }; |
diff --git a/drivers/video/s3c-fb.c b/drivers/video/s3c-fb.c index 9682ecc60e12..c4639c4e62f2 100644 --- a/drivers/video/s3c-fb.c +++ b/drivers/video/s3c-fb.c | |||
@@ -300,9 +300,9 @@ static int s3c_fb_set_par(struct fb_info *info) | |||
300 | /* disable the window whilst we update it */ | 300 | /* disable the window whilst we update it */ |
301 | writel(0, regs + WINCON(win_no)); | 301 | writel(0, regs + WINCON(win_no)); |
302 | 302 | ||
303 | /* use window 0 as the basis for the lcd output timings */ | 303 | /* use platform specified window as the basis for the lcd timings */ |
304 | 304 | ||
305 | if (win_no == 0) { | 305 | if (win_no == sfb->pdata->default_win) { |
306 | clkdiv = s3c_fb_calc_pixclk(sfb, var->pixclock); | 306 | clkdiv = s3c_fb_calc_pixclk(sfb, var->pixclock); |
307 | 307 | ||
308 | data = sfb->pdata->vidcon0; | 308 | data = sfb->pdata->vidcon0; |
@@ -636,7 +636,7 @@ static int s3c_fb_blank(int blank_mode, struct fb_info *info) | |||
636 | /* we're stuck with this until we can do something about overriding | 636 | /* we're stuck with this until we can do something about overriding |
637 | * the power control using the blanking event for a single fb. | 637 | * the power control using the blanking event for a single fb. |
638 | */ | 638 | */ |
639 | if (index == 0) | 639 | if (index == sfb->pdata->default_win) |
640 | s3c_fb_enable(sfb, blank_mode != FB_BLANK_POWERDOWN ? 1 : 0); | 640 | s3c_fb_enable(sfb, blank_mode != FB_BLANK_POWERDOWN ? 1 : 0); |
641 | 641 | ||
642 | return 0; | 642 | return 0; |