From: Tomas Bzatek Date: Sun, 1 May 2016 13:02:45 +0000 (+0200) Subject: UPSTREAM: drm/displayid: Iterate over all DisplayID blocks X-Git-Tag: release-20171130_firefly~4^2~364 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=0a15bdaf493e853136df32eb52af9482bb413ba6;p=firefly-linux-kernel-4.4.55.git UPSTREAM: drm/displayid: Iterate over all DisplayID blocks This will iterate over all DisplayID blocks found in the buffer. Previously only the first block was parsed. https://bugs.freedesktop.org/show_bug.cgi?id=95207 Change-Id: I952ea2442e8b7c31d8ca882cff8211f008cdd073 Signed-off-by: Tomas Bzatek Reviewed-by: Jani Nikula Signed-off-by: Dave Airlie Signed-off-by: Zheng Yang (cherry picked from commit 3a4a2ea39f86c581054794c0a727597745f1084b) --- diff --git a/drivers/gpu/drm/drm_edid.c b/drivers/gpu/drm/drm_edid.c index 36c7d66fb9df..200aa3997bc6 100644 --- a/drivers/gpu/drm/drm_edid.c +++ b/drivers/gpu/drm/drm_edid.c @@ -4621,19 +4621,25 @@ static int drm_parse_display_id(struct drm_connector *connector, return -EINVAL; } - block = (struct displayid_block *)&displayid[idx + 4]; - DRM_DEBUG_KMS("block id %d, rev %d, len %d\n", - block->tag, block->rev, block->num_bytes); - - switch (block->tag) { - case DATA_BLOCK_TILED_DISPLAY: - ret = drm_parse_tiled_block(connector, block); - if (ret) - return ret; - break; - default: - printk("unknown displayid tag %d\n", block->tag); - break; + idx += sizeof(struct displayid_hdr); + while (block = (struct displayid_block *)&displayid[idx], + idx + sizeof(struct displayid_block) <= length && + idx + sizeof(struct displayid_block) + block->num_bytes <= length && + block->num_bytes > 0) { + idx += block->num_bytes + sizeof(struct displayid_block); + DRM_DEBUG_KMS("block id 0x%x, rev %d, len %d\n", + block->tag, block->rev, block->num_bytes); + + switch (block->tag) { + case DATA_BLOCK_TILED_DISPLAY: + ret = drm_parse_tiled_block(connector, block); + if (ret) + return ret; + break; + default: + DRM_DEBUG_KMS("found DisplayID tag 0x%x, unhandled\n", block->tag); + break; + } } return 0; }