| From 00e7394f71082ea6359da0cea8cbd461bfaf0bb3 Mon Sep 17 00:00:00 2001 |
| From: Jani Nikula <jani.nikula@intel.com> |
| Date: Tue, 28 May 2013 12:35:02 +0300 |
| Subject: drm/i915: document why dvo/sdvo/crt need a special dpms function |
| |
| In the cloned case, changing just one output but keeping the other, the |
| pipe state won't change and intel_crtc_update_dpms will be a nop, but we |
| still need to update the dpms state of the output being changed. |
| |
| Only dvo, sdvo and crt are cloneable, so only those three have special |
| dpms functions. |
| |
| Signed-off-by: Jani Nikula <jani.nikula@intel.com> |
| Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> |
| (cherry picked from commit 6b1c087ba5789aceb25a2170b217055ce2476f67) |
| Signed-off-by: Darren Hart <dvhart@linux.intel.com> |
| --- |
| drivers/gpu/drm/i915/intel_crt.c | 4 +++- |
| drivers/gpu/drm/i915/intel_dvo.c | 3 +++ |
| drivers/gpu/drm/i915/intel_sdvo.c | 3 +++ |
| 3 files changed, 9 insertions(+), 1 deletion(-) |
| |
| diff --git a/drivers/gpu/drm/i915/intel_crt.c b/drivers/gpu/drm/i915/intel_crt.c |
| index 5e9f93e53255..3acec8c48166 100644 |
| --- a/drivers/gpu/drm/i915/intel_crt.c |
| +++ b/drivers/gpu/drm/i915/intel_crt.c |
| @@ -149,7 +149,7 @@ static void intel_enable_crt(struct intel_encoder *encoder) |
| intel_crt_set_dpms(encoder, crt->connector->base.dpms); |
| } |
| |
| - |
| +/* Special dpms function to support cloning between dvo/sdvo/crt. */ |
| static void intel_crt_dpms(struct drm_connector *connector, int mode) |
| { |
| struct drm_device *dev = connector->dev; |
| @@ -180,6 +180,8 @@ static void intel_crt_dpms(struct drm_connector *connector, int mode) |
| else |
| encoder->connectors_active = true; |
| |
| + /* We call connector dpms manually below in case pipe dpms doesn't |
| + * change due to cloning. */ |
| if (mode < old_dpms) { |
| /* From off to on, enable the pipe first. */ |
| intel_crtc_update_dpms(crtc); |
| diff --git a/drivers/gpu/drm/i915/intel_dvo.c b/drivers/gpu/drm/i915/intel_dvo.c |
| index 9e80d487b5cb..eb2020eb2b7e 100644 |
| --- a/drivers/gpu/drm/i915/intel_dvo.c |
| +++ b/drivers/gpu/drm/i915/intel_dvo.c |
| @@ -180,6 +180,7 @@ static void intel_enable_dvo(struct intel_encoder *encoder) |
| intel_dvo->dev.dev_ops->dpms(&intel_dvo->dev, true); |
| } |
| |
| +/* Special dpms function to support cloning between dvo/sdvo/crt. */ |
| static void intel_dvo_dpms(struct drm_connector *connector, int mode) |
| { |
| struct intel_dvo *intel_dvo = intel_attached_dvo(connector); |
| @@ -201,6 +202,8 @@ static void intel_dvo_dpms(struct drm_connector *connector, int mode) |
| return; |
| } |
| |
| + /* We call connector dpms manually below in case pipe dpms doesn't |
| + * change due to cloning. */ |
| if (mode == DRM_MODE_DPMS_ON) { |
| intel_dvo->base.connectors_active = true; |
| |
| diff --git a/drivers/gpu/drm/i915/intel_sdvo.c b/drivers/gpu/drm/i915/intel_sdvo.c |
| index f8ad93bd7d9b..c55841937705 100644 |
| --- a/drivers/gpu/drm/i915/intel_sdvo.c |
| +++ b/drivers/gpu/drm/i915/intel_sdvo.c |
| @@ -1416,6 +1416,7 @@ static void intel_enable_sdvo(struct intel_encoder *encoder) |
| intel_sdvo_set_active_outputs(intel_sdvo, intel_sdvo->attached_output); |
| } |
| |
| +/* Special dpms function to support cloning between dvo/sdvo/crt. */ |
| static void intel_sdvo_dpms(struct drm_connector *connector, int mode) |
| { |
| struct drm_crtc *crtc; |
| @@ -1437,6 +1438,8 @@ static void intel_sdvo_dpms(struct drm_connector *connector, int mode) |
| return; |
| } |
| |
| + /* We set active outputs manually below in case pipe dpms doesn't change |
| + * due to cloning. */ |
| if (mode != DRM_MODE_DPMS_ON) { |
| intel_sdvo_set_active_outputs(intel_sdvo, 0); |
| if (0) |
| -- |
| 1.8.5.rc3 |
| |