drm/edid: take HF-EEODB extension count into account
authorJani Nikula <jani.nikula@intel.com>
Wed, 29 Jun 2022 09:27:55 +0000 (12:27 +0300)
committerJani Nikula <jani.nikula@intel.com>
Thu, 30 Jun 2022 07:51:12 +0000 (10:51 +0300)
Take the HF-EEODB extension count override into account.

Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/c31b5796feb05c3ebac067600be2e88e098d7592.1656494768.git.jani.nikula@intel.com
drivers/gpu/drm/drm_edid.c

index fa3a3e294560283a5141c21988ae8241c5674811..bbc25e3b7220a2ffe68b8288d2af56279b1ae208 100644 (file)
@@ -1629,6 +1629,19 @@ static int drm_edid_block_count(const struct drm_edid *drm_edid)
        /* Starting point */
        num_blocks = edid_block_count(drm_edid->edid);
 
+       /* HF-EEODB override */
+       if (drm_edid->size >= edid_size_by_blocks(2)) {
+               int eeodb;
+
+               /*
+                * Note: HF-EEODB may specify a smaller extension count than the
+                * regular one. Unlike in buffer allocation, here we can use it.
+                */
+               eeodb = edid_hfeeodb_block_count(drm_edid->edid);
+               if (eeodb)
+                       num_blocks = eeodb;
+       }
+
        /* Limit by allocated size */
        num_blocks = min(num_blocks, (int)drm_edid->size / EDID_LENGTH);