OMAP: DSS2: HDMI: implement read_edid()
authorTomi Valkeinen <tomi.valkeinen@ti.com>
Thu, 25 Aug 2011 14:12:56 +0000 (17:12 +0300)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Fri, 30 Sep 2011 13:16:45 +0000 (16:16 +0300)
Implement read_edid() for HDMI by implementing necessary functions to
hdmi.c and to hdmi_omap4_panel.c.

Cc: Mythri P K <mythripk@ti.com>
Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
drivers/video/omap2/dss/dss.h
drivers/video/omap2/dss/hdmi.c
drivers/video/omap2/dss/hdmi_panel.c
drivers/video/omap2/dss/ti_hdmi_4xxx_ip.c

index 48bba53de0abb3d524311aa8db87253628e6fd75..2e7799c82960ea42c9019da377b57533582a026e 100644 (file)
@@ -494,6 +494,7 @@ void omapdss_hdmi_display_disable(struct omap_dss_device *dssdev);
 void omapdss_hdmi_display_set_timing(struct omap_dss_device *dssdev);
 int omapdss_hdmi_display_check_timing(struct omap_dss_device *dssdev,
                                        struct omap_video_timings *timings);
+int omapdss_hdmi_read_edid(u8 *buf, int len);
 int hdmi_panel_init(void);
 void hdmi_panel_exit(void);
 
index f503aa495b2f5ddad59deef9208a7db8791d16b4..8a04ee18d58f7c182677000e2f4fef4eaf5a210e 100644 (file)
@@ -372,7 +372,7 @@ static void hdmi_read_edid(struct omap_video_timings *dp)
        if (!hdmi.edid_set)
                ret = hdmi.ip_data.ops->read_edid(&hdmi.ip_data, hdmi.edid,
                                                HDMI_EDID_MAX_LENGTH);
-       if (!ret) {
+       if (ret > 0) {
                if (!memcmp(hdmi.edid, edid_header, sizeof(edid_header))) {
                        /* search for timings of default resolution */
                        get_edid_timing_data(hdmi.edid);
@@ -587,6 +587,23 @@ void omapdss_hdmi_display_set_timing(struct omap_dss_device *dssdev)
        }
 }
 
+int omapdss_hdmi_read_edid(u8 *buf, int len)
+{
+       int r;
+
+       mutex_lock(&hdmi.lock);
+
+       r = hdmi_runtime_get();
+       BUG_ON(r);
+
+       r = hdmi.ip_data.ops->read_edid(&hdmi.ip_data, buf, len);
+
+       hdmi_runtime_put();
+       mutex_unlock(&hdmi.lock);
+
+       return r;
+}
+
 int omapdss_hdmi_display_enable(struct omap_dss_device *dssdev)
 {
        int r = 0;
index 8c851e624ee645ea4596d0971b9642e0d6bdee85..624f170a5e92748444285814addc5eaecbb42ea6 100644 (file)
@@ -185,6 +185,29 @@ err:
        return r;
 }
 
+static int hdmi_read_edid(struct omap_dss_device *dssdev, u8 *buf, int len)
+{
+       int r;
+
+       mutex_lock(&hdmi.hdmi_lock);
+
+       if (dssdev->state != OMAP_DSS_DISPLAY_ACTIVE) {
+               r = omapdss_hdmi_display_enable(dssdev);
+               if (r)
+                       goto err;
+       }
+
+       r = omapdss_hdmi_read_edid(buf, len);
+
+       if (dssdev->state == OMAP_DSS_DISPLAY_DISABLED ||
+                       dssdev->state == OMAP_DSS_DISPLAY_SUSPENDED)
+               omapdss_hdmi_display_disable(dssdev);
+err:
+       mutex_unlock(&hdmi.hdmi_lock);
+
+       return r;
+}
+
 static struct omap_dss_driver hdmi_driver = {
        .probe          = hdmi_panel_probe,
        .remove         = hdmi_panel_remove,
@@ -195,6 +218,7 @@ static struct omap_dss_driver hdmi_driver = {
        .get_timings    = hdmi_get_timings,
        .set_timings    = hdmi_set_timings,
        .check_timings  = hdmi_check_timings,
+       .read_edid      = hdmi_read_edid,
        .driver                 = {
                .name   = "hdmi_panel",
                .owner  = THIS_MODULE,
index 403c662414778a295732888dcffeffff88ef8398..d4cdfc2e6c5ece6246c4f04643787aa29993f548 100644 (file)
@@ -370,29 +370,32 @@ int ti_hdmi_4xxx_read_edid(struct hdmi_ip_data *ip_data,
 {
        int r = 0, n = 0, i = 0;
        int max_ext_blocks = (max_length / 128) - 1;
+       int len;
 
        r = hdmi_core_ddc_edid(ip_data, pedid, 0);
-       if (r) {
+       if (r)
                return r;
-       } else {
-               n = pedid[0x7e];
 
-               /*
-                * README: need to comply with max_length set by the caller.
-                * Better implementation should be to allocate necessary
-                * memory to store EDID according to nb_block field found
-                * in first block
-                */
-               if (n > max_ext_blocks)
-                       n = max_ext_blocks;
+       len = 128;
+       n = pedid[0x7e];
 
-               for (i = 1; i <= n; i++) {
-                       r = hdmi_core_ddc_edid(ip_data, pedid, i);
-                       if (r)
-                               return r;
-               }
+       /*
+        * README: need to comply with max_length set by the caller.
+        * Better implementation should be to allocate necessary
+        * memory to store EDID according to nb_block field found
+        * in first block
+        */
+       if (n > max_ext_blocks)
+               n = max_ext_blocks;
+
+       for (i = 1; i <= n; i++) {
+               r = hdmi_core_ddc_edid(ip_data, pedid, i);
+               if (r)
+                       return r;
+               len += 128;
        }
-       return 0;
+
+       return len;
 }
 
 static void hdmi_core_init(struct hdmi_core_video_config *video_cfg,