Commit 884924be authored by Thomas Abraham's avatar Thomas Abraham Committed by Florian Tobias Schandinat

ARM: s3c64xx: Decouple lcd type from display controller window data

The display controller window data should contain window configuration data
for only one type of lcd panel. So, for real6410 and mini6410 boards, split
the existing display controller window data, which contains window
configuration data for two different types of lcd panels, into two seperate
instances and register one of them depending on the type of the lcd panel
detected at runtime.

This is a prerequisite change for a subsequent commit that reorders the
platform data of display controller by moving video interface timing out
of window setup data.

Cc: Darius Augulis <augulis.darius@gmail.com>
Acked-by: default avatarJingoo Han <jg1.han@samsung.com>
Signed-off-by: default avatarThomas Abraham <thomas.abraham@linaro.org>
Signed-off-by: default avatarFlorian Tobias Schandinat <FlorianSchandinat@gmx.de>
parent 3c582647
...@@ -151,41 +151,49 @@ static struct s3c2410_platform_nand mini6410_nand_info = { ...@@ -151,41 +151,49 @@ static struct s3c2410_platform_nand mini6410_nand_info = {
.sets = mini6410_nand_sets, .sets = mini6410_nand_sets,
}; };
static struct s3c_fb_pd_win mini6410_fb_win[] = { static struct s3c_fb_pd_win mini6410_lcd_type0_fb_win = {
{ .win_mode = { /* 4.3" 480x272 */
.win_mode = { /* 4.3" 480x272 */ .left_margin = 3,
.left_margin = 3, .right_margin = 2,
.right_margin = 2, .upper_margin = 1,
.upper_margin = 1, .lower_margin = 1,
.lower_margin = 1, .hsync_len = 40,
.hsync_len = 40, .vsync_len = 1,
.vsync_len = 1, .xres = 480,
.xres = 480, .yres = 272,
.yres = 272,
},
.max_bpp = 32,
.default_bpp = 16,
}, {
.win_mode = { /* 7.0" 800x480 */
.left_margin = 8,
.right_margin = 13,
.upper_margin = 7,
.lower_margin = 5,
.hsync_len = 3,
.vsync_len = 1,
.xres = 800,
.yres = 480,
},
.max_bpp = 32,
.default_bpp = 16,
}, },
.max_bpp = 32,
.default_bpp = 16,
}; };
static struct s3c_fb_platdata mini6410_lcd_pdata __initdata = { static struct s3c_fb_pd_win mini6410_lcd_type1_fb_win = {
.setup_gpio = s3c64xx_fb_gpio_setup_24bpp, .win_mode = { /* 7.0" 800x480 */
.win[0] = &mini6410_fb_win[0], .left_margin = 8,
.vidcon0 = VIDCON0_VIDOUT_RGB | VIDCON0_PNRMODE_RGB, .right_margin = 13,
.vidcon1 = VIDCON1_INV_HSYNC | VIDCON1_INV_VSYNC, .upper_margin = 7,
.lower_margin = 5,
.hsync_len = 3,
.vsync_len = 1,
.xres = 800,
.yres = 480,
},
.max_bpp = 32,
.default_bpp = 16,
};
static struct s3c_fb_platdata mini6410_lcd_pdata[] __initdata = {
{
.setup_gpio = s3c64xx_fb_gpio_setup_24bpp,
.win[0] = &mini6410_lcd_type0_fb_win,
.vidcon0 = VIDCON0_VIDOUT_RGB | VIDCON0_PNRMODE_RGB,
.vidcon1 = VIDCON1_INV_HSYNC | VIDCON1_INV_VSYNC,
}, {
.setup_gpio = s3c64xx_fb_gpio_setup_24bpp,
.win[0] = &mini6410_lcd_type1_fb_win,
.vidcon0 = VIDCON0_VIDOUT_RGB | VIDCON0_PNRMODE_RGB,
.vidcon1 = VIDCON1_INV_HSYNC | VIDCON1_INV_VSYNC,
},
{ },
}; };
static void mini6410_lcd_power_set(struct plat_lcd_data *pd, static void mini6410_lcd_power_set(struct plat_lcd_data *pd,
...@@ -283,7 +291,7 @@ static void mini6410_parse_features( ...@@ -283,7 +291,7 @@ static void mini6410_parse_features(
"screen type already set\n", f); "screen type already set\n", f);
} else { } else {
int li = f - '0'; int li = f - '0';
if (li >= ARRAY_SIZE(mini6410_fb_win)) if (li >= ARRAY_SIZE(mini6410_lcd_pdata))
printk(KERN_INFO "MINI6410: '%c' out " printk(KERN_INFO "MINI6410: '%c' out "
"of range LCD mode\n", f); "of range LCD mode\n", f);
else { else {
...@@ -307,14 +315,12 @@ static void __init mini6410_machine_init(void) ...@@ -307,14 +315,12 @@ static void __init mini6410_machine_init(void)
/* Parse the feature string */ /* Parse the feature string */
mini6410_parse_features(&features, mini6410_features_str); mini6410_parse_features(&features, mini6410_features_str);
mini6410_lcd_pdata.win[0] = &mini6410_fb_win[features.lcd_index];
printk(KERN_INFO "MINI6410: selected LCD display is %dx%d\n", printk(KERN_INFO "MINI6410: selected LCD display is %dx%d\n",
mini6410_lcd_pdata.win[0]->win_mode.xres, mini6410_lcd_pdata[features.lcd_index].win[0]->win_mode.xres,
mini6410_lcd_pdata.win[0]->win_mode.yres); mini6410_lcd_pdata[features.lcd_index].win[0]->win_mode.yres);
s3c_nand_set_platdata(&mini6410_nand_info); s3c_nand_set_platdata(&mini6410_nand_info);
s3c_fb_set_platdata(&mini6410_lcd_pdata); s3c_fb_set_platdata(&mini6410_lcd_pdata[features.lcd_index]);
s3c24xx_ts_set_platdata(NULL); s3c24xx_ts_set_platdata(NULL);
/* configure nCS1 width to 16 bits */ /* configure nCS1 width to 16 bits */
......
...@@ -117,41 +117,49 @@ static struct platform_device real6410_device_eth = { ...@@ -117,41 +117,49 @@ static struct platform_device real6410_device_eth = {
}, },
}; };
static struct s3c_fb_pd_win real6410_fb_win[] = { static struct s3c_fb_pd_win real6410_lcd_type0_fb_win = {
{ .win_mode = { /* 4.3" 480x272 */
.win_mode = { /* 4.3" 480x272 */ .left_margin = 3,
.left_margin = 3, .right_margin = 2,
.right_margin = 2, .upper_margin = 1,
.upper_margin = 1, .lower_margin = 1,
.lower_margin = 1, .hsync_len = 40,
.hsync_len = 40, .vsync_len = 1,
.vsync_len = 1, .xres = 480,
.xres = 480, .yres = 272,
.yres = 272,
},
.max_bpp = 32,
.default_bpp = 16,
}, {
.win_mode = { /* 7.0" 800x480 */
.left_margin = 8,
.right_margin = 13,
.upper_margin = 7,
.lower_margin = 5,
.hsync_len = 3,
.vsync_len = 1,
.xres = 800,
.yres = 480,
},
.max_bpp = 32,
.default_bpp = 16,
}, },
.max_bpp = 32,
.default_bpp = 16,
}; };
static struct s3c_fb_platdata real6410_lcd_pdata __initdata = { static struct s3c_fb_pd_win real6410_lcd_type1_fb_win = {
.setup_gpio = s3c64xx_fb_gpio_setup_24bpp, .win_mode = { /* 7.0" 800x480 */
.win[0] = &real6410_fb_win[0], .left_margin = 8,
.vidcon0 = VIDCON0_VIDOUT_RGB | VIDCON0_PNRMODE_RGB, .right_margin = 13,
.vidcon1 = VIDCON1_INV_HSYNC | VIDCON1_INV_VSYNC, .upper_margin = 7,
.lower_margin = 5,
.hsync_len = 3,
.vsync_len = 1,
.xres = 800,
.yres = 480,
},
.max_bpp = 32,
.default_bpp = 16,
};
static struct s3c_fb_platdata real6410_lcd_pdata[] __initdata = {
{
.setup_gpio = s3c64xx_fb_gpio_setup_24bpp,
.win[0] = &real6410_lcd_type0_fb_win,
.vidcon0 = VIDCON0_VIDOUT_RGB | VIDCON0_PNRMODE_RGB,
.vidcon1 = VIDCON1_INV_HSYNC | VIDCON1_INV_VSYNC,
}, {
.setup_gpio = s3c64xx_fb_gpio_setup_24bpp,
.win[0] = &real6410_lcd_type1_fb_win,
.vidcon0 = VIDCON0_VIDOUT_RGB | VIDCON0_PNRMODE_RGB,
.vidcon1 = VIDCON1_INV_HSYNC | VIDCON1_INV_VSYNC,
},
{ },
}; };
static struct mtd_partition real6410_nand_part[] = { static struct mtd_partition real6410_nand_part[] = {
...@@ -264,7 +272,7 @@ static void real6410_parse_features( ...@@ -264,7 +272,7 @@ static void real6410_parse_features(
"screen type already set\n", f); "screen type already set\n", f);
} else { } else {
int li = f - '0'; int li = f - '0';
if (li >= ARRAY_SIZE(real6410_fb_win)) if (li >= ARRAY_SIZE(real6410_lcd_pdata))
printk(KERN_INFO "REAL6410: '%c' out " printk(KERN_INFO "REAL6410: '%c' out "
"of range LCD mode\n", f); "of range LCD mode\n", f);
else { else {
...@@ -288,13 +296,11 @@ static void __init real6410_machine_init(void) ...@@ -288,13 +296,11 @@ static void __init real6410_machine_init(void)
/* Parse the feature string */ /* Parse the feature string */
real6410_parse_features(&features, real6410_features_str); real6410_parse_features(&features, real6410_features_str);
real6410_lcd_pdata.win[0] = &real6410_fb_win[features.lcd_index];
printk(KERN_INFO "REAL6410: selected LCD display is %dx%d\n", printk(KERN_INFO "REAL6410: selected LCD display is %dx%d\n",
real6410_lcd_pdata.win[0]->win_mode.xres, real6410_lcd_pdata[features.lcd_index].win[0]->win_mode.xres,
real6410_lcd_pdata.win[0]->win_mode.yres); real6410_lcd_pdata[features.lcd_index].win[0]->win_mode.yres);
s3c_fb_set_platdata(&real6410_lcd_pdata); s3c_fb_set_platdata(&real6410_lcd_pdata[features.lcd_index]);
s3c_nand_set_platdata(&real6410_nand_info); s3c_nand_set_platdata(&real6410_nand_info);
s3c24xx_ts_set_platdata(NULL); s3c24xx_ts_set_platdata(NULL);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment