>-----Original Message-----
>From: Intel-gfx [mailto:intel-gfx-boun...@lists.freedesktop.org] On Behalf Of 
>Rodrigo Vivi
>Sent: Monday, January 12, 2015 11:45 PM
>To: intel-gfx@lists.freedesktop.org
>Cc: Vivi, Rodrigo
>Subject: [Intel-gfx] [PATCH 7/9] drm/i915: PSR VLV/CHV: let's respect 
>link_standby here as well.
>
>Let's respect vbt and panel for link_standby/on x link_disabled
>
>Signed-off-by: Rodrigo Vivi <rodrigo.v...@intel.com>
>---
> drivers/gpu/drm/i915/intel_psr.c | 16 +++++++++++++---
> 1 file changed, 13 insertions(+), 3 deletions(-)
>
>diff --git a/drivers/gpu/drm/i915/intel_psr.c 
>b/drivers/gpu/drm/i915/intel_psr.c
>index 5ae193e..313347a 100644
>--- a/drivers/gpu/drm/i915/intel_psr.c
>+++ b/drivers/gpu/drm/i915/intel_psr.c
>@@ -132,8 +132,17 @@ static void hsw_psr_setup_vsc(struct intel_dp *intel_dp)
>
> static void vlv_psr_enable_sink(struct intel_dp *intel_dp)
> {
>-      drm_dp_dpcd_writeb(&intel_dp->aux, DP_PSR_EN_CFG,
>-                         DP_PSR_ENABLE);
>+      struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp);
>+      struct drm_device *dev = dig_port->base.base.dev;
>+      struct drm_i915_private *dev_priv = dev->dev_private;
>+
>+      /* Enable PSR in sink */
>+      if (dev_priv->psr.link_standby)
>+              drm_dp_dpcd_writeb(&intel_dp->aux, DP_PSR_EN_CFG,
>+                                 DP_PSR_ENABLE | DP_PSR_MAIN_LINK_ACTIVE);
>+      else
>+              drm_dp_dpcd_writeb(&intel_dp->aux, DP_PSR_EN_CFG,
>+                                 DP_PSR_ENABLE & ~DP_PSR_MAIN_LINK_ACTIVE);
> }
>
> static void hsw_psr_enable_sink(struct intel_dp *intel_dp)
>@@ -183,11 +192,12 @@ static void vlv_psr_enable_source(struct intel_dp 
>*intel_dp)
>       struct drm_i915_private *dev_priv = dev->dev_private;
>       struct drm_crtc *crtc = dig_port->base.base.crtc;
>       enum pipe pipe = to_intel_crtc(crtc)->pipe;
>+      bool standby = dev_priv->psr.link_standby;
>
>       /* Transition from PSR_state 0 to PSR_state 1, i.e. PSR Inactive */
>       I915_WRITE(VLV_PSRCTL(pipe),
>                  VLV_EDP_PSR_MODE_SW_TIMER |
>-                 VLV_EDP_PSR_SRC_TRANSMITTER_STATE |
>+                 standby ? VLV_EDP_PSR_SRC_TRANSMITTER_STATE : 0 |

Apart from VBT, this also depends on the Panel DPCD 71h.
If bit 0 of 71h is 0, we may need Link training to exit PSR,
If main link is off.

So, unless we try it out on various panels and
are confident about it, I suggest we keep this
TRANSMITTER_STATE to 1.

Thanks,
Durga

>                  VLV_EDP_PSR_ENABLE);
> }
>
>--
>2.1.0
>
>_______________________________________________
>Intel-gfx mailing list
>Intel-gfx@lists.freedesktop.org
>http://lists.freedesktop.org/mailman/listinfo/intel-gfx
_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to