diff options
| author | Masashi Kimoto <Masashi_Kimoto@hq.scei.sony.co.jp> | 2007-10-16 04:29:22 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-16 12:43:19 -0400 |
| commit | 8ca0bf750b7d9b7e859f2f40516b914827e7afd8 (patch) | |
| tree | 9df4e1d0b017aebb2a8e41b8e5a599a7579b25fb /drivers/ps3 | |
| parent | 779121e9f17525769c04a00475fd85600c8c04eb (diff) | |
ps3: Fix black and white stripes
Fix the black and white stripes issue with WUXGA monitor via HDMI.
It seems that when we use a VESA resolution from boot up, the AV settings
driver could not be initialized correctly. In that case we need a dummy
packet before VESA setting.
[Geert] Refactored to reduce code duplication.
Signed-off-by: Geert Uytterhoeven <Geert.Uytterhoeven@sonycom.com>
CC: Geoff Levand <geoffrey.levand@am.sony.com>
Signed-off-by: Antonino Daplas <adaplas@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/ps3')
| -rw-r--r-- | drivers/ps3/ps3av.c | 58 |
1 files changed, 38 insertions, 20 deletions
diff --git a/drivers/ps3/ps3av.c b/drivers/ps3/ps3av.c index 85e21614f868..a1f63cb849d2 100644 --- a/drivers/ps3/ps3av.c +++ b/drivers/ps3/ps3av.c | |||
| @@ -491,10 +491,10 @@ static int ps3av_set_videomode(void) | |||
| 491 | return 0; | 491 | return 0; |
| 492 | } | 492 | } |
| 493 | 493 | ||
| 494 | static void ps3av_set_videomode_cont(u32 id, u32 old_id) | 494 | static void ps3av_set_videomode_packet(u32 id) |
| 495 | { | 495 | { |
| 496 | struct ps3av_pkt_avb_param avb_param; | 496 | struct ps3av_pkt_avb_param avb_param; |
| 497 | int i; | 497 | unsigned int i; |
| 498 | u32 len = 0, av_video_cs; | 498 | u32 len = 0, av_video_cs; |
| 499 | const struct avset_video_mode *video_mode; | 499 | const struct avset_video_mode *video_mode; |
| 500 | int res; | 500 | int res; |
| @@ -507,24 +507,6 @@ static void ps3av_set_videomode_cont(u32 id, u32 old_id) | |||
| 507 | ps3av->av_hw_conf.num_of_avmulti; | 507 | ps3av->av_hw_conf.num_of_avmulti; |
| 508 | avb_param.num_of_av_audio_pkt = 0; | 508 | avb_param.num_of_av_audio_pkt = 0; |
| 509 | 509 | ||
| 510 | /* video signal off */ | ||
| 511 | ps3av_set_video_disable_sig(); | ||
| 512 | |||
| 513 | /* Retail PS3 product doesn't support this */ | ||
| 514 | if (id & PS3AV_MODE_HDCP_OFF) { | ||
| 515 | res = ps3av_cmd_av_hdmi_mode(PS3AV_CMD_AV_HDMI_HDCP_OFF); | ||
| 516 | if (res == PS3AV_STATUS_UNSUPPORTED_HDMI_MODE) | ||
| 517 | dev_dbg(&ps3av->dev->core, "Not supported\n"); | ||
| 518 | else if (res) | ||
| 519 | dev_dbg(&ps3av->dev->core, | ||
| 520 | "ps3av_cmd_av_hdmi_mode failed\n"); | ||
| 521 | } else if (old_id & PS3AV_MODE_HDCP_OFF) { | ||
| 522 | res = ps3av_cmd_av_hdmi_mode(PS3AV_CMD_AV_HDMI_MODE_NORMAL); | ||
| 523 | if (res < 0 && res != PS3AV_STATUS_UNSUPPORTED_HDMI_MODE) | ||
| 524 | dev_dbg(&ps3av->dev->core, | ||
| 525 | "ps3av_cmd_av_hdmi_mode failed\n"); | ||
| 526 | } | ||
| 527 | |||
| 528 | /* video_pkt */ | 510 | /* video_pkt */ |
| 529 | for (i = 0; i < avb_param.num_of_video_pkt; i++) | 511 | for (i = 0; i < avb_param.num_of_video_pkt; i++) |
| 530 | len += ps3av_cmd_set_video_mode(&avb_param.buf[len], | 512 | len += ps3av_cmd_set_video_mode(&avb_param.buf[len], |
| @@ -555,6 +537,42 @@ static void ps3av_set_videomode_cont(u32 id, u32 old_id) | |||
| 555 | __func__); | 537 | __func__); |
| 556 | else if (res) | 538 | else if (res) |
| 557 | dev_dbg(&ps3av->dev->core, "ps3av_cmd_avb_param failed\n"); | 539 | dev_dbg(&ps3av->dev->core, "ps3av_cmd_avb_param failed\n"); |
| 540 | } | ||
| 541 | |||
| 542 | static void ps3av_set_videomode_cont(u32 id, u32 old_id) | ||
| 543 | { | ||
| 544 | static int vesa = 0; | ||
| 545 | int res; | ||
| 546 | |||
| 547 | /* video signal off */ | ||
| 548 | ps3av_set_video_disable_sig(); | ||
| 549 | |||
| 550 | /* | ||
| 551 | * AV backend needs non-VESA mode setting at least one time | ||
| 552 | * when VESA mode is used. | ||
| 553 | */ | ||
| 554 | if (vesa == 0 && (id & PS3AV_MODE_MASK) >= 11) { | ||
| 555 | /* vesa mode */ | ||
| 556 | ps3av_set_videomode_packet(2); /* 480P */ | ||
| 557 | } | ||
| 558 | vesa = 1; | ||
| 559 | |||
| 560 | /* Retail PS3 product doesn't support this */ | ||
| 561 | if (id & PS3AV_MODE_HDCP_OFF) { | ||
| 562 | res = ps3av_cmd_av_hdmi_mode(PS3AV_CMD_AV_HDMI_HDCP_OFF); | ||
| 563 | if (res == PS3AV_STATUS_UNSUPPORTED_HDMI_MODE) | ||
| 564 | dev_dbg(&ps3av->dev->core, "Not supported\n"); | ||
| 565 | else if (res) | ||
| 566 | dev_dbg(&ps3av->dev->core, | ||
| 567 | "ps3av_cmd_av_hdmi_mode failed\n"); | ||
| 568 | } else if (old_id & PS3AV_MODE_HDCP_OFF) { | ||
| 569 | res = ps3av_cmd_av_hdmi_mode(PS3AV_CMD_AV_HDMI_MODE_NORMAL); | ||
| 570 | if (res < 0 && res != PS3AV_STATUS_UNSUPPORTED_HDMI_MODE) | ||
| 571 | dev_dbg(&ps3av->dev->core, | ||
| 572 | "ps3av_cmd_av_hdmi_mode failed\n"); | ||
| 573 | } | ||
| 574 | |||
| 575 | ps3av_set_videomode_packet(id); | ||
| 558 | 576 | ||
| 559 | msleep(1500); | 577 | msleep(1500); |
| 560 | /* av video mute */ | 578 | /* av video mute */ |
