[Intel-gfx] [PATCH 2/7] drm/i915/psr: Try to program link training times correctly

Daniel Vetter daniel at ffwll.ch
Fri May 20 07:33:03 UTC 2016


On Thu, May 19, 2016 at 04:20:02PM +0530, Jindal, Sonika wrote:
> 
> 
> On 5/18/2016 10:17 PM, Daniel Vetter wrote:
> >Oops. Hw default for programming these fields to 0 is "skip link
> >training". Display won't take that too well usually.
> But we were defaulting it to value 0, which means 500us for both TP1 and TP2
> or TP3 time.
> I dont think it means skip link training. This is just to set the time for
> the patterns.
> Skip aux handshake can happen if bit 12 of SRD_CTL is set.
> 
> Does this solution help in fixing the bug mentioned here?

See the other thread, I misread and yes it does help.
-Daniel

> 
> >
> >v2: Unbotch the math a bit.
> >
> >v3: Drop debug hunk.
> >
> >Tested-by: Lyude <cpaul at redhat.com>
> >Cc: Lyude <cpaul at redhat.com>
> >Cc: stable at vger.kernel.org
> >Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=95176
> >Cc: Rodrigo Vivi <rodrigo.vivi at intel.com>
> >Cc: Sonika Jindal <sonika.jindal at intel.com>
> >Cc: Durgadoss R <durgadoss.r at intel.com>
> >Cc: "Pandiyan, Dhinakaran" <dhinakaran.pandiyan at intel.com>
> >Signed-off-by: Daniel Vetter <daniel.vetter at intel.com>
> >---
> >  drivers/gpu/drm/i915/intel_psr.c | 55 ++++++++++++++++++++++++++++++++++------
> >  1 file changed, 47 insertions(+), 8 deletions(-)
> >
> >diff --git a/drivers/gpu/drm/i915/intel_psr.c b/drivers/gpu/drm/i915/intel_psr.c
> >index c3abae4bc596..a788d1e9589b 100644
> >--- a/drivers/gpu/drm/i915/intel_psr.c
> >+++ b/drivers/gpu/drm/i915/intel_psr.c
> >@@ -280,7 +280,10 @@ static void hsw_psr_enable_source(struct intel_dp *intel_dp)
> >  	 * with the 5 or 6 idle patterns.
> >  	 */
> >  	uint32_t idle_frames = max(6, dev_priv->vbt.psr.idle_frames);
> >-	uint32_t val = 0x0;
> >+	uint32_t val = EDP_PSR_ENABLE;
> >+
> >+	val |= max_sleep_time << EDP_PSR_MAX_SLEEP_TIME_SHIFT;
> >+	val |= idle_frames << EDP_PSR_IDLE_FRAME_SHIFT;
> >  	if (IS_HASWELL(dev))
> >  		val |= EDP_PSR_MIN_LINK_ENTRY_TIME_8_LINES;
> >@@ -288,14 +291,50 @@ static void hsw_psr_enable_source(struct intel_dp *intel_dp)
> >  	if (dev_priv->psr.link_standby)
> >  		val |= EDP_PSR_LINK_STANDBY;
> >-	I915_WRITE(EDP_PSR_CTL, val |
> >-		   max_sleep_time << EDP_PSR_MAX_SLEEP_TIME_SHIFT |
> >-		   idle_frames << EDP_PSR_IDLE_FRAME_SHIFT |
> >-		   EDP_PSR_ENABLE);
> >+	if (dev_priv->vbt.psr.tp1_wakeup_time > 5)
> >+		val |= EDP_PSR_TP1_TIME_2500us;
> >+	else if (dev_priv->vbt.psr.tp1_wakeup_time > 1)
> >+		val |= EDP_PSR_TP1_TIME_500us;
> >+	else if (dev_priv->vbt.psr.tp1_wakeup_time > 0)
> >+		val |= EDP_PSR_TP1_TIME_100us;
> >+	else
> >+		val |= EDP_PSR_TP1_TIME_0us;
> >+
> >+	if (dev_priv->vbt.psr.tp2_tp3_wakeup_time > 5)
> >+		val |= EDP_PSR_TP2_TP3_TIME_2500us;
> >+	else if (dev_priv->vbt.psr.tp2_tp3_wakeup_time > 1)
> >+		val |= EDP_PSR_TP2_TP3_TIME_500us;
> >+	else if (dev_priv->vbt.psr.tp2_tp3_wakeup_time > 0)
> >+		val |= EDP_PSR_TP2_TP3_TIME_100us;
> >+	else
> >+		val |= EDP_PSR_TP2_TP3_TIME_0us;
> >+
> >+	if (intel_dp_source_supports_hbr2(intel_dp) &&
> >+	    drm_dp_tps3_supported(intel_dp->dpcd))
> >+		val |= EDP_PSR_TP1_TP3_SEL;
> >+	else
> >+		val |= EDP_PSR_TP1_TP2_SEL;
> >+
> >+	I915_WRITE(EDP_PSR_CTL, val);
> >+
> >+	if (!dev_priv->psr.psr2_support)
> >+		return;
> >+
> >+	/* FIXME: selective update is probably totally broken because it doesn't
> >+	 * mesh at all with our frontbuffer tracking. And the hw alone isn't
> >+	 * good enough. */
> >+	val = EDP_PSR2_ENABLE | EDP_SU_TRACK_ENABLE;
> >+
> >+	if (dev_priv->vbt.psr.tp2_tp3_wakeup_time > 5)
> >+		val |= EDP_PSR2_TP2_TIME_2500;
> >+	else if (dev_priv->vbt.psr.tp2_tp3_wakeup_time > 1)
> >+		val |= EDP_PSR2_TP2_TIME_500;
> >+	else if (dev_priv->vbt.psr.tp2_tp3_wakeup_time > 0)
> >+		val |= EDP_PSR2_TP2_TIME_100;
> >+	else
> >+		val |= EDP_PSR2_TP2_TIME_50;
> >-	if (dev_priv->psr.psr2_support)
> >-		I915_WRITE(EDP_PSR2_CTL, EDP_PSR2_ENABLE |
> >-				EDP_SU_TRACK_ENABLE | EDP_PSR2_TP2_TIME_100);
> >+	I915_WRITE(EDP_PSR2_CTL, val);
> >  }
> >  static bool intel_psr_match_conditions(struct intel_dp *intel_dp)
> 

-- 
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch


More information about the Intel-gfx mailing list