diff options
| author | Ville Syrjälä <[email protected]> | 2016-04-11 10:22:09 +0300 |
|---|---|---|
| committer | Ville Syrjälä <[email protected]> | 2016-04-12 13:23:42 +0300 |
| commit | eeeebea6cbe0d85817e2fa8eee8a2f5c9d88a44a (patch) | |
| tree | b58f52b9a906f4afc014b8bbf54bfd8ac3b0edc8 | |
| parent | 706778013bc5ee97970de3a2deee80b007e29c25 (diff) | |
drm/i915: Reject panel_type > 0xf from VBT
VBT can only contain 16 panel entries, indexed with the panel_type.
To play it safe we should reject panel_type > 0xf, so that we don't
read past the valid data.
v2: Add debug logging (Jani)
Cc: Jani Nikula <[email protected]>
Cc: Rob Kramer <[email protected]>
Signed-off-by: Ville Syrjälä <[email protected]>
Reviewed-by: Jani Nikula <[email protected]> (v1)
Link: http://patchwork.freedesktop.org/patch/msgid/[email protected]
| -rw-r--r-- | drivers/gpu/drm/i915/intel_bios.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/gpu/drm/i915/intel_bios.c b/drivers/gpu/drm/i915/intel_bios.c index eb756c41d9e1..c8857b5dbfec 100644 --- a/drivers/gpu/drm/i915/intel_bios.c +++ b/drivers/gpu/drm/i915/intel_bios.c @@ -212,8 +212,11 @@ parse_lfp_panel_data(struct drm_i915_private *dev_priv, return; dev_priv->vbt.lvds_dither = lvds_options->pixel_dither; - if (lvds_options->panel_type == 0xff) + if (lvds_options->panel_type > 0xf) { + DRM_DEBUG_KMS("Invalid VBT panel type 0x%x\n", + lvds_options->panel_type); return; + } panel_type = lvds_options->panel_type; |