UPSTREAM: drm/edid: detect SCDC support in HF-VSDB
authorShashank Sharma <shashank.sharma@intel.com>
Mon, 13 Mar 2017 11:24:01 +0000 (16:54 +0530)
committerJianqun Xu <jay.xu@rock-chips.com>
Tue, 27 Jun 2017 09:10:49 +0000 (17:10 +0800)
This patch does following:
- Adds a new structure (drm_hdmi_info) in drm_display_info.
  This structure will be used to save and indicate if sink
  supports advanced HDMI 2.0 features
- Adds another structure drm_scdc within drm_hdmi_info, to
  reflect scdc support and capabilities in connected HDMI 2.0 sink.
- Checks the HF-VSDB block for presence of SCDC, and marks it
  in scdc structure
- If SCDC is present, checks if sink is capable of generating
  SCDC read request, and marks it in scdc structure.

V2: Addressed review comments
 Thierry:
 - Fix typos in commit message and make abbreviation consistent
   across the commit message.
 - Change structure object name from hdmi_info -> hdmi
 - Fix typos and abbreviations in description of structure drm_hdmi_info
   end the description with a full stop.
 - Create a structure drm_scdc, and keep all information related to SCDC
   register set (supported, read request supported) etc in it.

Ville:
 - Change rr -> read_request
 - Call drm_detect_scrambling function drm_parse_hf_vsdb so that all
   of HF-VSDB parsing can be kept in same function, in incremental
   patches.

V3: Rebase.
V4: Rebase.
V5: Rebase.
V6: Rebase.
V7: Added R-B from Jose.
V8: Rebase.
V9: Rebase.
V10: Rebase.

Change-Id: I93cd26ee5c51c3714eb702e8a1bd1b335385f26e
Signed-off-by: Shashank Sharma <shashank.sharma@intel.com>
Reviewed-by: Thierry Reding <treding@nvidia.com>
Reviewed-by: Jose Abreu <joabreu@synopsys.com>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/1489404244-16608-4-git-send-email-shashank.sharma@intel.com
Signed-off-by: Zheng Yang <zhengyang@rock-chips.com>
(cherry picked from commit afa1c763653e0fd68f2d1e3dca869c9453d8ef06)

drivers/gpu/drm/drm_edid.c
include/drm/drm_crtc.h

index 2041e993902e9ac5d3e6485355fb6c92a14b11ec..cd30f47a5a515cf54fee169980c194e876cbad4b 100644 (file)
@@ -4084,6 +4084,18 @@ bool drm_rgb_quant_range_selectable(struct edid *edid)
 }
 EXPORT_SYMBOL(drm_rgb_quant_range_selectable);
 
+static void drm_parse_hdmi_forum_vsdb(struct drm_connector *connector,
+                                const u8 *hf_vsdb)
+{
+       struct drm_hdmi_info *hdmi = &connector->display_info.hdmi;
+
+       if (hf_vsdb[6] & 0x80) {
+               hdmi->scdc.supported = true;
+               if (hf_vsdb[6] & 0x40)
+                       hdmi->scdc.read_request = true;
+       }
+}
+
 static void drm_parse_hdmi_deep_color_info(struct drm_connector *connector,
                                           const u8 *hdmi)
 {
@@ -4197,6 +4209,8 @@ static void drm_parse_cea_ext(struct drm_connector *connector,
 
                if (cea_db_is_hdmi_vsdb(db))
                        drm_parse_hdmi_vsdb_video(connector, db);
+               if (cea_db_is_hdmi_forum_vsdb(db))
+                       drm_parse_hdmi_forum_vsdb(connector, db);
        }
 }
 
index 8035d0e83f86b16dae6d6db6ff11cc370886a395..3c152ff26301b8b5fbd61cf4cdf0ab4d99098fc4 100644 (file)
@@ -117,6 +117,34 @@ enum subpixel_order {
        SubPixelVerticalRGB,
        SubPixelVerticalBGR,
        SubPixelNone,
+
+};
+
+/*
+ * struct drm_scdc - Information about scdc capabilities of a HDMI 2.0 sink
+ *
+ * Provides SCDC register support and capabilities related information on a
+ * HDMI 2.0 sink. In case of a HDMI 1.4 sink, all parameter must be 0.
+ */
+struct drm_scdc {
+       /**
+        * @supported: status control & data channel present.
+        */
+       bool supported;
+       /**
+        * @read_request: sink is capable of generating scdc read request.
+        */
+       bool read_request;
+};
+
+/**
+ * struct drm_hdmi_info - runtime information about the connected HDMI sink
+ *
+ * Describes if a given display supports advanced HDMI 2.0 features.
+ * This information is available in CEA-861-F extension blocks (like HF-VSDB).
+ */
+struct drm_hdmi_info {
+       struct drm_scdc scdc;
 };
 
 #define DRM_COLOR_FORMAT_RGB444                (1<<0)
@@ -159,6 +187,11 @@ struct drm_display_info {
        u8 edid_hdmi_dc_modes;
 
        u8 cea_rev;
+
+       /**
+        * @hdmi: advance features of a HDMI sink.
+        */
+       struct drm_hdmi_info hdmi;
 };
 
 /* data corresponds to displayid vend/prod/serial */