/* 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);