aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_dp.c
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2013-04-22 11:07:23 -0400
committerDaniel Vetter <daniel.vetter@ffwll.ch>2013-04-23 07:52:57 -0400
commitae4edb8089df67d25fbd9386012a335a64aca287 (patch)
treee220d7ae390df3f2e0726cf109b38f8628ebbcf6 /drivers/gpu/drm/i915/intel_dp.c
parente4bfff54ed3f5de88f5358504c78c2cb037813aa (diff)
drm/i915: avoid full modeset when changing the color range properties
Automatic color range selection was added in commit 55bc60db5988c8366751d3d04dd690698a53412c Author: Ville Syrjälä <ville.syrjala@linux.intel.com> Date: Thu Jan 17 16:31:29 2013 +0200 drm/i915: Add "Automatic" mode for the "Broadcast RGB" property but that removed the check to avoid a full modeset if the value is unchanged. Unfortunately X sets all properties with their current value at start-up, resulting in some ugly flickering which shouldn't be there. v2: Change old_range from bool to uint32_t, spotted by Ville. v3: Actually git add everything ;-) Cc: Ville Syrjälä <ville.syrjala@linux.intel.com> Cc: Paulo Zanoni <paulo.r.zanoni@intel.com> Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_dp.c')
-rw-r--r--drivers/gpu/drm/i915/intel_dp.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/intel_dp.c b/drivers/gpu/drm/i915/intel_dp.c
index 89f89b727900..fc3bd9b4037c 100644
--- a/drivers/gpu/drm/i915/intel_dp.c
+++ b/drivers/gpu/drm/i915/intel_dp.c
@@ -2428,6 +2428,9 @@ intel_dp_set_property(struct drm_connector *connector,
2428 } 2428 }
2429 2429
2430 if (property == dev_priv->broadcast_rgb_property) { 2430 if (property == dev_priv->broadcast_rgb_property) {
2431 bool old_auto = intel_dp->color_range_auto;
2432 uint32_t old_range = intel_dp->color_range;
2433
2431 switch (val) { 2434 switch (val) {
2432 case INTEL_BROADCAST_RGB_AUTO: 2435 case INTEL_BROADCAST_RGB_AUTO:
2433 intel_dp->color_range_auto = true; 2436 intel_dp->color_range_auto = true;
@@ -2443,6 +2446,11 @@ intel_dp_set_property(struct drm_connector *connector,
2443 default: 2446 default:
2444 return -EINVAL; 2447 return -EINVAL;
2445 } 2448 }
2449
2450 if (old_auto == intel_dp->color_range_auto &&
2451 old_range == intel_dp->color_range)
2452 return 0;
2453
2446 goto done; 2454 goto done;
2447 } 2455 }
2448 2456