Gitweb:     
http://git.kernel.org/git/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=71a27fecaf836093a30fe538c5ab98ef0b25bfc8
Commit:     71a27fecaf836093a30fe538c5ab98ef0b25bfc8
Parent:     eea820ab0b189d74620dca376817a2e599eb1ab1
Author:     Geert Uytterhoeven <[EMAIL PROTECTED]>
AuthorDate: Tue Oct 16 01:29:41 2007 -0700
Committer:  Linus Torvalds <[EMAIL PROTECTED]>
CommitDate: Tue Oct 16 09:43:20 2007 -0700

    ps3av: use PS3 video mode ids in autodetect code
    
    It doesn't make much sense to use the PS3AV_CMD_VIDEO_VID_* values in the
    autodetection code, just to convert them to PS3 video mode ids afterwards.
    
    Signed-off-by: Geert Uytterhoeven <[EMAIL PROTECTED]>
    Signed-off-by: Antonino Daplas <[EMAIL PROTECTED]>
    Signed-off-by: Andrew Morton <[EMAIL PROTECTED]>
    Signed-off-by: Linus Torvalds <[EMAIL PROTECTED]>
---
 drivers/ps3/ps3av.c         |   90 +++++++++++++++++++------------------------
 include/asm-powerpc/ps3av.h |   11 +++--
 2 files changed, 46 insertions(+), 55 deletions(-)

diff --git a/drivers/ps3/ps3av.c b/drivers/ps3/ps3av.c
index c1bcad6..51feb7e 100644
--- a/drivers/ps3/ps3av.c
+++ b/drivers/ps3/ps3av.c
@@ -585,75 +585,65 @@ static void ps3avd(struct work_struct *work)
        complete(&ps3av->done);
 }
 
-static int ps3av_vid2table_id(int vid)
+static int ps3av_resbit2id(u32 res_50, u32 res_60)
 {
-       int i;
-
-       for (i = 1; i < ARRAY_SIZE(video_mode_table); i++)
-               if (video_mode_table[i].vid == vid)
-                       return i;
-       return -1;
-}
-
-static int ps3av_resbit2vid(u32 res_50, u32 res_60)
-{
-       int vid = -1;
+       int id = 0;
 
        if (res_50 > res_60) {  /* if res_50 == res_60, res_60 will be used */
                if (res_50 & PS3AV_RESBIT_1920x1080P)
-                       vid = PS3AV_CMD_VIDEO_VID_1080P_50HZ;
+                       id = 10;
                else if (res_50 & PS3AV_RESBIT_1920x1080I)
-                       vid = PS3AV_CMD_VIDEO_VID_1080I_50HZ;
+                       id = 9;
                else if (res_50 & PS3AV_RESBIT_1280x720P)
-                       vid = PS3AV_CMD_VIDEO_VID_720P_50HZ;
+                       id = 8;
                else if (res_50 & PS3AV_RESBIT_720x576P)
-                       vid = PS3AV_CMD_VIDEO_VID_576P;
+                       id = 7;
                else
-                       vid = -1;
+                       id = 0;
        } else {
                if (res_60 & PS3AV_RESBIT_1920x1080P)
-                       vid = PS3AV_CMD_VIDEO_VID_1080P_60HZ;
+                       id = 5;
                else if (res_60 & PS3AV_RESBIT_1920x1080I)
-                       vid = PS3AV_CMD_VIDEO_VID_1080I_60HZ;
+                       id = 4;
                else if (res_60 & PS3AV_RESBIT_1280x720P)
-                       vid = PS3AV_CMD_VIDEO_VID_720P_60HZ;
+                       id = 3;
                else if (res_60 & PS3AV_RESBIT_720x480P)
-                       vid = PS3AV_CMD_VIDEO_VID_480P;
+                       id = 2;
                else
-                       vid = -1;
+                       id = 0;
        }
-       return vid;
+       return id;
 }
 
-static int ps3av_hdmi_get_vid(struct ps3av_info_monitor *info)
+static int ps3av_hdmi_get_id(struct ps3av_info_monitor *info)
 {
        u32 res_50, res_60;
-       int vid = -1;
+       int id;
 
        if (info->monitor_type != PS3AV_MONITOR_TYPE_HDMI)
-               return -1;
+               return 0;
 
        /* check native resolution */
        res_50 = info->res_50.native & PS3AV_RES_MASK_50;
        res_60 = info->res_60.native & PS3AV_RES_MASK_60;
        if (res_50 || res_60) {
-               vid = ps3av_resbit2vid(res_50, res_60);
-               return vid;
+               id = ps3av_resbit2id(res_50, res_60);
+               return id;
        }
 
        /* check resolution */
        res_50 = info->res_50.res_bits & PS3AV_RES_MASK_50;
        res_60 = info->res_60.res_bits & PS3AV_RES_MASK_60;
        if (res_50 || res_60) {
-               vid = ps3av_resbit2vid(res_50, res_60);
-               return vid;
+               id = ps3av_resbit2id(res_50, res_60);
+               return id;
        }
 
        if (ps3av->region & PS3AV_REGION_60)
-               vid = PS3AV_DEFAULT_HDMI_VID_REG_60;
+               id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_60;
        else
-               vid = PS3AV_DEFAULT_HDMI_VID_REG_50;
-       return vid;
+               id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_50;
+       return id;
 }
 
 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 *
 static int ps3av_auto_videomode(struct ps3av_pkt_av_get_hw_conf *av_hw_conf,
                                int boot)
 {
-       int i, res, vid = -1, dvi = 0, rgb = 0;
+       int i, res, id = 0, dvi = 0, rgb = 0;
        struct ps3av_pkt_av_get_monitor_info monitor_info;
        struct ps3av_info_monitor *info;
 
-       /* get vid for hdmi */
+       /* get mode id for hdmi */
        for (i = 0; i < av_hw_conf->num_of_hdmi; i++) {
                res = ps3av_cmd_video_get_monitor_info(&monitor_info,
                                                       PS3AV_CMD_AVPORT_HDMI_0 +
@@ -737,49 +727,49 @@ static int ps3av_auto_videomode(struct 
ps3av_pkt_av_get_hw_conf *av_hw_conf,
                        break;
                }
                /* check HDMI */
-               vid = ps3av_hdmi_get_vid(info);
-               if (vid != -1) {
-                       /* got valid vid */
+               id = ps3av_hdmi_get_id(info);
+               if (id) {
+                       /* got valid mode id */
                        break;
                }
        }
 
        if (dvi) {
                /* DVI mode */
-               vid = PS3AV_DEFAULT_DVI_VID;
-       } else if (vid == -1) {
+               id = PS3AV_DEFAULT_DVI_MODE_ID;
+       } else if (!id) {
                /* no HDMI interface or HDMI is off */
                if (ps3av->region & PS3AV_REGION_60)
-                       vid = PS3AV_DEFAULT_AVMULTI_VID_REG_60;
+                       id = PS3AV_DEFAULT_AVMULTI_MODE_ID_REG_60;
                else
-                       vid = PS3AV_DEFAULT_AVMULTI_VID_REG_50;
+                       id = PS3AV_DEFAULT_AVMULTI_MODE_ID_REG_50;
                if (ps3av->region & PS3AV_REGION_RGB)
                        rgb = PS3AV_MODE_RGB;
        } else if (boot) {
-               /* HDMI: using DEFAULT HDMI_VID while booting up */
+               /* HDMI: using DEFAULT HDMI_MODE_ID while booting up */
                info = &monitor_info.info;
                if (ps3av->region & PS3AV_REGION_60) {
                        if (info->res_60.res_bits & PS3AV_RESBIT_720x480P)
-                               vid = PS3AV_DEFAULT_HDMI_VID_REG_60;
+                               id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_60;
                        else if (info->res_50.res_bits & PS3AV_RESBIT_720x576P)
-                               vid = PS3AV_DEFAULT_HDMI_VID_REG_50;
+                               id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_50;
                        else {
                                /* default */
-                               vid = PS3AV_DEFAULT_HDMI_VID_REG_60;
+                               id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_60;
                        }
                } else {
                        if (info->res_50.res_bits & PS3AV_RESBIT_720x576P)
-                               vid = PS3AV_DEFAULT_HDMI_VID_REG_50;
+                               id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_50;
                        else if (info->res_60.res_bits & PS3AV_RESBIT_720x480P)
-                               vid = PS3AV_DEFAULT_HDMI_VID_REG_60;
+                               id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_60;
                        else {
                                /* default */
-                               vid = PS3AV_DEFAULT_HDMI_VID_REG_50;
+                               id = PS3AV_DEFAULT_HDMI_MODE_ID_REG_50;
                        }
                }
        }
 
-       return (ps3av_vid2table_id(vid) | dvi | rgb);
+       return id | dvi | rgb;
 }
 
 static int ps3av_get_hw_conf(struct ps3av *ps3av)
diff --git a/include/asm-powerpc/ps3av.h b/include/asm-powerpc/ps3av.h
index 4ac93a2..c023c5d 100644
--- a/include/asm-powerpc/ps3av.h
+++ b/include/asm-powerpc/ps3av.h
@@ -300,11 +300,12 @@
 
 #define PS3AV_MONITOR_TYPE_HDMI                        1       /* HDMI */
 #define PS3AV_MONITOR_TYPE_DVI                 2       /* DVI */
-#define PS3AV_DEFAULT_HDMI_VID_REG_60          PS3AV_CMD_VIDEO_VID_480P
-#define PS3AV_DEFAULT_AVMULTI_VID_REG_60       PS3AV_CMD_VIDEO_VID_480I
-#define PS3AV_DEFAULT_HDMI_VID_REG_50          PS3AV_CMD_VIDEO_VID_576P
-#define PS3AV_DEFAULT_AVMULTI_VID_REG_50       PS3AV_CMD_VIDEO_VID_576I
-#define PS3AV_DEFAULT_DVI_VID                  PS3AV_CMD_VIDEO_VID_480P
+
+#define PS3AV_DEFAULT_HDMI_MODE_ID_REG_60      2       /* 480p */
+#define PS3AV_DEFAULT_AVMULTI_MODE_ID_REG_60   1       /* 480i */
+#define PS3AV_DEFAULT_HDMI_MODE_ID_REG_50      7       /* 576p */
+#define PS3AV_DEFAULT_AVMULTI_MODE_ID_REG_50   6       /* 576i */
+#define PS3AV_DEFAULT_DVI_MODE_ID              2       /* 480p */
 
 #define PS3AV_REGION_60                                0x01
 #define PS3AV_REGION_50                                0x02
-
To unsubscribe from this list: send the line "unsubscribe git-commits-head" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to