diff options
| -rw-r--r-- | drivers/video/s3c-fb.c | 31 |
1 files changed, 28 insertions, 3 deletions
diff --git a/drivers/video/s3c-fb.c b/drivers/video/s3c-fb.c index d3a568e6b169..53bca288e836 100644 --- a/drivers/video/s3c-fb.c +++ b/drivers/video/s3c-fb.c | |||
| @@ -358,9 +358,16 @@ static int s3c_fb_set_par(struct fb_info *info) | |||
| 358 | writel(data, regs + VIDOSD_B(win_no)); | 358 | writel(data, regs + VIDOSD_B(win_no)); |
| 359 | 359 | ||
| 360 | data = var->xres * var->yres; | 360 | data = var->xres * var->yres; |
| 361 | |||
| 362 | u32 osdc_data = 0; | ||
| 363 | |||
| 364 | osdc_data = VIDISD14C_ALPHA1_R(0xf) | | ||
| 365 | VIDISD14C_ALPHA1_G(0xf) | | ||
| 366 | VIDISD14C_ALPHA1_B(0xf); | ||
| 367 | |||
| 361 | if (s3c_fb_has_osd_d(win_no)) { | 368 | if (s3c_fb_has_osd_d(win_no)) { |
| 362 | writel(data, regs + VIDOSD_D(win_no)); | 369 | writel(data, regs + VIDOSD_D(win_no)); |
| 363 | writel(0, regs + VIDOSD_C(win_no)); | 370 | writel(osdc_data, regs + VIDOSD_C(win_no)); |
| 364 | } else | 371 | } else |
| 365 | writel(data, regs + VIDOSD_C(win_no)); | 372 | writel(data, regs + VIDOSD_C(win_no)); |
| 366 | 373 | ||
| @@ -409,8 +416,12 @@ static int s3c_fb_set_par(struct fb_info *info) | |||
| 409 | data |= WINCON1_BPPMODE_19BPP_A1666; | 416 | data |= WINCON1_BPPMODE_19BPP_A1666; |
| 410 | else | 417 | else |
| 411 | data |= WINCON1_BPPMODE_18BPP_666; | 418 | data |= WINCON1_BPPMODE_18BPP_666; |
| 412 | } else if (var->transp.length != 0) | 419 | } else if (var->transp.length == 1) |
| 413 | data |= WINCON1_BPPMODE_25BPP_A1888; | 420 | data |= WINCON1_BPPMODE_25BPP_A1888 |
| 421 | | WINCON1_BLD_PIX; | ||
| 422 | else if (var->transp.length == 4) | ||
| 423 | data |= WINCON1_BPPMODE_28BPP_A4888 | ||
| 424 | | WINCON1_BLD_PIX | WINCON1_ALPHA_SEL; | ||
| 414 | else | 425 | else |
| 415 | data |= WINCON0_BPPMODE_24BPP_888; | 426 | data |= WINCON0_BPPMODE_24BPP_888; |
| 416 | 427 | ||
| @@ -418,6 +429,20 @@ static int s3c_fb_set_par(struct fb_info *info) | |||
| 418 | break; | 429 | break; |
| 419 | } | 430 | } |
| 420 | 431 | ||
| 432 | /* It has no color key control register for window0 */ | ||
| 433 | if (win_no > 0) { | ||
| 434 | u32 keycon0_data = 0, keycon1_data = 0; | ||
| 435 | |||
| 436 | keycon0_data = ~(WxKEYCON0_KEYBL_EN | | ||
| 437 | WxKEYCON0_KEYEN_F | | ||
| 438 | WxKEYCON0_DIRCON) | WxKEYCON0_COMPKEY(0); | ||
| 439 | |||
| 440 | keycon1_data = WxKEYCON1_COLVAL(0xffffff); | ||
| 441 | |||
| 442 | writel(keycon0_data, regs + WxKEYCONy(win_no-1, 0)); | ||
| 443 | writel(keycon1_data, regs + WxKEYCONy(win_no-1, 1)); | ||
| 444 | } | ||
| 445 | |||
| 421 | writel(data, regs + WINCON(win_no)); | 446 | writel(data, regs + WINCON(win_no)); |
| 422 | writel(0x0, regs + WINxMAP(win_no)); | 447 | writel(0x0, regs + WINxMAP(win_no)); |
| 423 | 448 | ||
