All of lore.kernel.org
 help / color / mirror / Atom feed
From: Sivakumar Thulasimani <sivakumar.thulasimani@intel.com>
To: intel-gfx@lists.freedesktop.org
Subject: Re: [PATCH] drm/i915/skl: Enabling PSR2 SU with frame sync
Date: Mon, 23 Mar 2015 14:10:05 +0530	[thread overview]
Message-ID: <550FD165.1010307@intel.com> (raw)
In-Reply-To: <1426831076-9775-1-git-send-email-sonika.jindal@intel.com>



On 3/20/2015 11:27 AM, Sonika Jindal wrote:
> +#define   EDP_MAX_SU_DISABLE_TIME_MASK	(0x1f<<20)
> +#define   EDP_PSR2_TP2_TIME_500		(0<<8)
> +#define   EDP_PSR2_TP2_TIME_100		(1<<8)
> +#define   EDP_PSR2_TP2_TIME_250		(2<<8)
Better to make all values inline, 500us & 100us should make 2.5ms to 
2500 . please correct it.

> +			uint8_t frame_sync_cap;
> +
> +			dev_priv->psr.sink_support = true;
> +			intel_dp_dpcd_read_wake(&intel_dp->aux,
> +					DP_SINK_DEVICE_AUX_FRAME_SYNC_CAP,
> +					&frame_sync_cap, 1);
> +			/* PSR2 needs frame sync as well */
> +			if (frame_sync_cap) {
> +				DRM_DEBUG_KMS("PSR2 supported on sink");
> +				intel_dp->psr2_support = true;
> +			} else
> +				intel_dp->psr2_support = false;
> +		}
>   	}
>   
>   	/* Training Pattern 3 support, both source and sink */
> diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h
> index 8bb18e5..ed1b0a5 100644
> --- a/drivers/gpu/drm/i915/intel_drv.h
> +++ b/drivers/gpu/drm/i915/intel_drv.h
> @@ -663,6 +663,8 @@ struct intel_dp {
>   	struct intel_dp_mst_encoder *mst_encoders[I915_MAX_PIPES];
>   	struct drm_dp_mst_topology_mgr mst_mgr;
>   
> +	bool psr2_support;
> +
>   	uint32_t (*get_aux_clock_divider)(struct intel_dp *dp, int index);
>   	/*
>   	 * This function returns the value we have to program the AUX_CTL
> diff --git a/drivers/gpu/drm/i915/intel_psr.c b/drivers/gpu/drm/i915/intel_psr.c
> index b9f40c2..99dbc73 100644
> --- a/drivers/gpu/drm/i915/intel_psr.c
> +++ b/drivers/gpu/drm/i915/intel_psr.c
> @@ -117,6 +117,19 @@ static void vlv_psr_setup_vsc(struct intel_dp *intel_dp)
>   	I915_WRITE(VLV_VSCSDP(pipe), val);
>   }
>   
> +static void skl_psr_setup_su_vsc(struct intel_dp *intel_dp)
> +{
> +	struct edp_vsc_psr psr_vsc;
> +
> +	/* Prepare VSC Header for SU as per EDP 1.4 spec, Table 6.11 */
> +	memset(&psr_vsc, 0, sizeof(psr_vsc));
> +	psr_vsc.sdp_header.HB0 = 0;
> +	psr_vsc.sdp_header.HB1 = 0x7;
> +	psr_vsc.sdp_header.HB2 = 0x3;
> +	psr_vsc.sdp_header.HB3 = 0xb;
> +	intel_psr_write_vsc(intel_dp, &psr_vsc);
> +}
> +
>   static void hsw_psr_setup_vsc(struct intel_dp *intel_dp)
>   {
>   	struct edp_vsc_psr psr_vsc;
> @@ -165,6 +178,12 @@ static void hsw_psr_enable_sink(struct intel_dp *intel_dp)
>   		drm_dp_dpcd_writeb(&intel_dp->aux, DP_PSR_EN_CFG,
>   				   DP_PSR_ENABLE & ~DP_PSR_MAIN_LINK_ACTIVE);
>   
> +	/* Enable AUX frame sync at sink */
> +	if (intel_dp->psr2_support)
> +		drm_dp_dpcd_writeb(&intel_dp->aux,
> +				DP_SINK_DEVICE_AUX_FRAME_SYNC_CONF,
> +				DP_AUX_FRAME_SYNC_ENABLE);
> +
>   	aux_data_reg = (INTEL_INFO(dev)->gen >= 9) ?
>   				DPA_AUX_CH_DATA1 : EDP_PSR_AUX_DATA1(dev);
>   	aux_ctl_reg = (INTEL_INFO(dev)->gen >= 9) ?
> @@ -183,8 +202,10 @@ static void hsw_psr_enable_sink(struct intel_dp *intel_dp)
>   		val |= DP_AUX_CH_CTL_TIME_OUT_1600us;
>   		val &= ~DP_AUX_CH_CTL_MESSAGE_SIZE_MASK;
>   		val |= (sizeof(aux_msg) << DP_AUX_CH_CTL_MESSAGE_SIZE_SHIFT);
> -		/* Use hardcoded data values for PSR */
> +		/* Use hardcoded data values for PSR, frame sync and GTC */
>   		val &= ~DP_AUX_CH_CTL_PSR_DATA_AUX_REG_SKL;
> +		val &= ~DP_AUX_CH_CTL_FS_DATA_AUX_REG_SKL;
> +		val &= ~DP_AUX_CH_CTL_GTC_DATA_AUX_REG_SKL;
>   		I915_WRITE(aux_ctl_reg, val);
>   	} else {
>   		I915_WRITE(aux_ctl_reg,
> @@ -255,6 +276,10 @@ static void hsw_psr_enable_source(struct intel_dp *intel_dp)
>   		   max_sleep_time << EDP_PSR_MAX_SLEEP_TIME_SHIFT |
>   		   idle_frames << EDP_PSR_IDLE_FRAME_SHIFT |
>   		   EDP_PSR_ENABLE);
> +
> +	if (intel_dp->psr2_support)
> +		I915_WRITE(EDP_PSR2_CTL, EDP_PSR2_ENABLE |
> +				EDP_SU_TRACK_ENABLE | EDP_PSR2_TP2_TIME_100);
>   }
>   
>   static bool intel_psr_match_conditions(struct intel_dp *intel_dp)
> @@ -364,6 +389,9 @@ void intel_psr_enable(struct intel_dp *intel_dp)
>   	if (HAS_DDI(dev)) {
>   		hsw_psr_setup_vsc(intel_dp);
>   
> +		if (intel_dp->psr2_support)
> +			skl_psr_setup_su_vsc(intel_dp);
> +
>   		/* Avoid continuous PSR exit by masking memup and hpd */
>   		I915_WRITE(EDP_PSR_DEBUG_CTL(dev), EDP_PSR_DEBUG_MASK_MEMUP |
>   			   EDP_PSR_DEBUG_MASK_HPD | EDP_PSR_DEBUG_MASK_LPSP);

_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/intel-gfx

  parent reply	other threads:[~2015-03-23  8:40 UTC|newest]

Thread overview: 21+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-03-20  5:57 [PATCH] drm/i915/skl: Enabling PSR2 SU with frame sync Sonika Jindal
2015-03-20  9:09 ` shuang.he
2015-03-20 21:20 ` Vivi, Rodrigo
2015-03-23  4:38   ` sonika
2015-03-20 23:26 ` Vivi, Rodrigo
2015-03-23  8:48   ` sonika
2015-03-23  9:14   ` Daniel Vetter
2015-03-23 20:00     ` Vivi, Rodrigo
2015-03-26  8:27       ` Sonika Jindal
2015-03-26 11:39         ` R, Durgadoss
2015-03-30 11:34           ` Jindal, Sonika
2015-03-31  5:58             ` Sonika Jindal
2015-03-31  6:33               ` R, Durgadoss
2015-03-31 12:28               ` Daniel Vetter
2015-04-02  5:32                 ` Sonika Jindal
2015-04-02  6:33                   ` shuang.he
2015-04-07  8:07                   ` Daniel Vetter
2015-03-31 12:40               ` shuang.he
2015-03-26 15:01         ` shuang.he
2015-03-23  8:40 ` Sivakumar Thulasimani [this message]
2015-03-24  4:33   ` sonika

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=550FD165.1010307@intel.com \
    --to=sivakumar.thulasimani@intel.com \
    --cc=intel-gfx@lists.freedesktop.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.