diff options
Diffstat (limited to 'drivers/ps3/ps3av.c')
-rw-r--r-- | drivers/ps3/ps3av.c | 90 |
1 files changed, 40 insertions, 50 deletions
diff --git a/drivers/ps3/ps3av.c b/drivers/ps3/ps3av.c index c1bcad66ce75..51feb7e46b0e 100644 --- a/drivers/ps3/ps3av.c +++ b/drivers/ps3/ps3av.c | |||
@@ -585,75 +585,65 @@ static void ps3avd(struct work_struct *work) | |||
585 | complete(&ps3av->done); | 585 | complete(&ps3av->done); |
586 | } | 586 | } |
587 | 587 | ||
588 | static int ps3av_vid2table_id(int vid) | 588 | static int ps3av_resbit2id(u32 res_50, u32 res_60) |
589 | { | 589 | { |
590 | int i; | 590 | int id = 0; |
591 | |||
592 | for (i = 1; i < ARRAY_SIZE(video_mode_table); i++) | ||
593 | if (video_mode_table[i].vid == vid) | ||
594 | return i; | ||
595 | return -1; | ||
596 | } | ||
597 | |||
598 | static int ps3av_resbit2vid(u32 res_50, u32 res_60) | ||
599 | { | ||
600 | int vid = -1; | ||
601 | 591 | ||
602 | if (res_50 > res_60) { /* if res_50 == res_60, res_60 will be used */ | 592 | if (res_50 > res_60) { /* if res_50 == res_60, res_60 will be used */ |
603 | if (res_50 & PS3AV_RESBIT_1920x1080P) | 593 | if (res_50 & PS3AV_RESBIT_1920x1080P) |
604 | vid = PS3AV_CMD_VIDEO_VID_1080P_50HZ; | 594 | id = 10; |
605 | else if (res_50 & PS3AV_RESBIT_1920x1080I) | 595 | else if (res_50 & PS3AV_RESBIT_1920x1080I) |
606 | vid = PS3AV_CMD_VIDEO_VID_1080I_50HZ; | 596 | id = 9; |
607 | else if (res_50 & PS3AV_RESBIT_1280x720P) | 597 | else if (res_50 & PS3AV_RESBIT_1280x720P) |
608 | vid = PS3AV_CMD_VIDEO_VID_720P_50HZ; | 598 | id = 8; |
609 | else if (res_50 & PS3AV_RESBIT_720x576P) | 599 | else if (res_50 & PS3AV_RESBIT_720x576P) |
610 | vid = PS3AV_CMD_VIDEO_VID_576P; | 600 | id = 7; |
611 | else | 601 | else |
612 | vid = -1; | 602 | id = 0; |
613 | } else { | 603 | } else { |
614 | if (res_60 & PS3AV_RESBIT_1920x1080P) | 604 | if (res_60 & PS3AV_RESBIT_1920x1080P) |
615 | vid = PS3AV_CMD_VIDEO_VID_1080P_60HZ; | 605 | id = 5; |
616 | else if (res_60 & PS3AV_RESBIT_1920x1080I) | 606 | else if (res_60 & PS3AV_RESBIT_1920x1080I) |
617 | vid = PS3AV_CMD_VIDEO_VID_1080I_60HZ; | 607 | id = 4; |
618 | else if (res_60 & PS3AV_RESBIT_1280x720P) | 608 | else if (res_60 & PS3AV_RESBIT_1280x720P) |
619 | vid = PS3AV_CMD_VIDEO_VID_720P_60HZ; | 609 | id = 3; |
620 | else if (res_60 & PS3AV_RESBIT_720x480P) | 610 | else if (res_60 & PS3AV_RESBIT_720x480P) |
621 | vid = PS3AV_CMD_VIDEO_VID_480P; | 611 | id = 2; |
622 | else | 612 | else |
623 | vid = -1; | 613 | id = 0; |
624 | } | 614 | } |
625 | return vid; | 615 | return id; |
626 | } | 616 | } |
627 | 617 | ||
628 | static int ps3av_hdmi_get_vid(struct ps3av_info_monitor *info) | 618 | static int ps3av_hdmi_get_id(struct ps3av_info_monitor *info) |
629 | { | 619 | { |
630 | u32 res_50, res_60; | 620 | u32 res_50, res_60; |
631 | int vid = -1; | 621 | int id; |
632 | 622 | ||
633 | if (info->monitor_type != PS3AV_MONITOR_TYPE_HDMI) | 623 | if (info->monitor_type != PS3AV_MONITOR_TYPE_HDMI) |
634 | return -1; | 624 | return 0; |
635 | 625 | ||
636 | /* check native resolution */ | 626 | /* check native resolution */ |
637 | res_50 = info->res_50.native & PS3AV_RES_MASK_50; | 627 | res_50 = info->res_50.native & PS3AV_RES_MASK_50; |
638 | res_60 = info->res_60.native & PS3AV_RES_MASK_60; | 628 | res_60 = info->res_60.native & PS3AV_RES_MASK_60; |
639 | if (res_50 || res_60) { | 629 | if (res_50 || res_60) { |
640 | vid = ps3av_resbit2vid(res_50, res_60); | 630 | id = ps3av_resbit2id(res_50, res_60); |
641 | return vid; | 631 | return id; |
642 | } | 632 | } |
643 | 633 | ||
644 | /* check resolution */ | 634 | /* check resolution */ |
645 | res_50 = info->res_50.res_bits & PS3AV_RES_MASK_50; | 635 | res_50 = info->res_50.res_bits & PS3AV_RES_MASK_50; |
646 | res_60 = info->res_60.res_bits & PS3AV_RES_MASK_60; | 636 | res_60 = info->res_60.res_bits & PS3AV_RES_MASK_60; |
647 | if (res_50 || res_60) { | 637 | if (res_50 || res_60) { |
648 | vid = ps3av_resbit2vid(res_50, res_60); | 638 | id = ps3av_resbit2id(res_50, res_60); |
649 | return vid; | 639 | return id; |
650 | } | 640 | } |
651 | 641 | ||
652 | if (ps3av->region & PS3AV_REGION_60) | 642 | if (ps3av->region & PS3AV_REGION_60) |
653 | vid = PS3AV_DEFAULT_HDMI_VID_REG_60; | 643 | id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_60; |
654 | else | 644 | else |
655 | vid = PS3AV_DEFAULT_HDMI_VID_REG_50; | 645 | id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_50; |
656 | return vid; | 646 | return id; |
657 | } | 647 | } |
658 | 648 | ||
659 | static void ps3av_monitor_info_dump(const struct ps3av_pkt_av_get_monitor_info *monitor_info) | 649 | static void ps3av_monitor_info_dump(const struct ps3av_pkt_av_get_monitor_info *monitor_info) |
@@ -717,11 +707,11 @@ static void ps3av_monitor_info_dump(const struct ps3av_pkt_av_get_monitor_info * | |||
717 | static int ps3av_auto_videomode(struct ps3av_pkt_av_get_hw_conf *av_hw_conf, | 707 | static int ps3av_auto_videomode(struct ps3av_pkt_av_get_hw_conf *av_hw_conf, |
718 | int boot) | 708 | int boot) |
719 | { | 709 | { |
720 | int i, res, vid = -1, dvi = 0, rgb = 0; | 710 | int i, res, id = 0, dvi = 0, rgb = 0; |
721 | struct ps3av_pkt_av_get_monitor_info monitor_info; | 711 | struct ps3av_pkt_av_get_monitor_info monitor_info; |
722 | struct ps3av_info_monitor *info; | 712 | struct ps3av_info_monitor *info; |
723 | 713 | ||
724 | /* get vid for hdmi */ | 714 | /* get mode id for hdmi */ |
725 | for (i = 0; i < av_hw_conf->num_of_hdmi; i++) { | 715 | for (i = 0; i < av_hw_conf->num_of_hdmi; i++) { |
726 | res = ps3av_cmd_video_get_monitor_info(&monitor_info, | 716 | res = ps3av_cmd_video_get_monitor_info(&monitor_info, |
727 | PS3AV_CMD_AVPORT_HDMI_0 + | 717 | PS3AV_CMD_AVPORT_HDMI_0 + |
@@ -737,49 +727,49 @@ static int ps3av_auto_videomode(struct ps3av_pkt_av_get_hw_conf *av_hw_conf, | |||
737 | break; | 727 | break; |
738 | } | 728 | } |
739 | /* check HDMI */ | 729 | /* check HDMI */ |
740 | vid = ps3av_hdmi_get_vid(info); | 730 | id = ps3av_hdmi_get_id(info); |
741 | if (vid != -1) { | 731 | if (id) { |
742 | /* got valid vid */ | 732 | /* got valid mode id */ |
743 | break; | 733 | break; |
744 | } | 734 | } |
745 | } | 735 | } |
746 | 736 | ||
747 | if (dvi) { | 737 | if (dvi) { |
748 | /* DVI mode */ | 738 | /* DVI mode */ |
749 | vid = PS3AV_DEFAULT_DVI_VID; | 739 | id = PS3AV_DEFAULT_DVI_MODE_ID; |
750 | } else if (vid == -1) { | 740 | } else if (!id) { |
751 | /* no HDMI interface or HDMI is off */ | 741 | /* no HDMI interface or HDMI is off */ |
752 | if (ps3av->region & PS3AV_REGION_60) | 742 | if (ps3av->region & PS3AV_REGION_60) |
753 | vid = PS3AV_DEFAULT_AVMULTI_VID_REG_60; | 743 | id = PS3AV_DEFAULT_AVMULTI_MODE_ID_REG_60; |
754 | else | 744 | else |
755 | vid = PS3AV_DEFAULT_AVMULTI_VID_REG_50; | 745 | id = PS3AV_DEFAULT_AVMULTI_MODE_ID_REG_50; |
756 | if (ps3av->region & PS3AV_REGION_RGB) | 746 | if (ps3av->region & PS3AV_REGION_RGB) |
757 | rgb = PS3AV_MODE_RGB; | 747 | rgb = PS3AV_MODE_RGB; |
758 | } else if (boot) { | 748 | } else if (boot) { |
759 | /* HDMI: using DEFAULT HDMI_VID while booting up */ | 749 | /* HDMI: using DEFAULT HDMI_MODE_ID while booting up */ |
760 | info = &monitor_info.info; | 750 | info = &monitor_info.info; |
761 | if (ps3av->region & PS3AV_REGION_60) { | 751 | if (ps3av->region & PS3AV_REGION_60) { |
762 | if (info->res_60.res_bits & PS3AV_RESBIT_720x480P) | 752 | if (info->res_60.res_bits & PS3AV_RESBIT_720x480P) |
763 | vid = PS3AV_DEFAULT_HDMI_VID_REG_60; | 753 | id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_60; |
764 | else if (info->res_50.res_bits & PS3AV_RESBIT_720x576P) | 754 | else if (info->res_50.res_bits & PS3AV_RESBIT_720x576P) |
765 | vid = PS3AV_DEFAULT_HDMI_VID_REG_50; | 755 | id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_50; |
766 | else { | 756 | else { |
767 | /* default */ | 757 | /* default */ |
768 | vid = PS3AV_DEFAULT_HDMI_VID_REG_60; | 758 | id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_60; |
769 | } | 759 | } |
770 | } else { | 760 | } else { |
771 | if (info->res_50.res_bits & PS3AV_RESBIT_720x576P) | 761 | if (info->res_50.res_bits & PS3AV_RESBIT_720x576P) |
772 | vid = PS3AV_DEFAULT_HDMI_VID_REG_50; | 762 | id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_50; |
773 | else if (info->res_60.res_bits & PS3AV_RESBIT_720x480P) | 763 | else if (info->res_60.res_bits & PS3AV_RESBIT_720x480P) |
774 | vid = PS3AV_DEFAULT_HDMI_VID_REG_60; | 764 | id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_60; |
775 | else { | 765 | else { |
776 | /* default */ | 766 | /* default */ |
777 | vid = PS3AV_DEFAULT_HDMI_VID_REG_50; | 767 | id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_50; |
778 | } | 768 | } |
779 | } | 769 | } |
780 | } | 770 | } |
781 | 771 | ||
782 | return (ps3av_vid2table_id(vid) | dvi | rgb); | 772 | return id | dvi | rgb; |
783 | } | 773 | } |
784 | 774 | ||
785 | static int ps3av_get_hw_conf(struct ps3av *ps3av) | 775 | static int ps3av_get_hw_conf(struct ps3av *ps3av) |