aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMika Kahola <mika.kahola@intel.com>2016-02-02 08:16:39 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2016-02-11 04:15:31 -0500
commit587bf496d6186332ff863abffcf314b374c569e1 (patch)
tree938d184045f62fe31c24410fe24348dcbb1a7f79
parent799487f51d7419e33736d81b0b9087b2aaa593af (diff)
drm/i915: HDMI pixel clock check
It is possible the we request to have a mode that has higher pixel clock than our HW can support. This patch checks if requested pixel clock is lower than the one supported by the HW. The requested mode is discarded if we cannot support the requested pixel clock. This patch applies to HDMI. V2: - removed computation for max dot clock V3: - cleanup by removing unnecessary lines V4: - max_pixclk variable renamed as max_dotclk - check for stereo mode added Signed-off-by: Mika Kahola <mika.kahola@intel.com> Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> Link: http://patchwork.freedesktop.org/patch/msgid/1454419003-6001-3-git-send-email-mika.kahola@intel.com
-rw-r--r--drivers/gpu/drm/i915/intel_hdmi.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/intel_hdmi.c b/drivers/gpu/drm/i915/intel_hdmi.c
index 8698a643d027..edb7e901ba4a 100644
--- a/drivers/gpu/drm/i915/intel_hdmi.c
+++ b/drivers/gpu/drm/i915/intel_hdmi.c
@@ -1202,11 +1202,19 @@ intel_hdmi_mode_valid(struct drm_connector *connector,
1202 struct drm_device *dev = intel_hdmi_to_dev(hdmi); 1202 struct drm_device *dev = intel_hdmi_to_dev(hdmi);
1203 enum drm_mode_status status; 1203 enum drm_mode_status status;
1204 int clock; 1204 int clock;
1205 int max_dotclk = to_i915(connector->dev)->max_dotclk_freq;
1205 1206
1206 if (mode->flags & DRM_MODE_FLAG_DBLSCAN) 1207 if (mode->flags & DRM_MODE_FLAG_DBLSCAN)
1207 return MODE_NO_DBLESCAN; 1208 return MODE_NO_DBLESCAN;
1208 1209
1209 clock = mode->clock; 1210 clock = mode->clock;
1211
1212 if ((mode->flags & DRM_MODE_FLAG_3D_MASK) == DRM_MODE_FLAG_3D_FRAME_PACKING)
1213 clock *= 2;
1214
1215 if (clock > max_dotclk)
1216 return MODE_CLOCK_HIGH;
1217
1210 if (mode->flags & DRM_MODE_FLAG_DBLCLK) 1218 if (mode->flags & DRM_MODE_FLAG_DBLCLK)
1211 clock *= 2; 1219 clock *= 2;
1212 1220