public inbox for drm-ai-reviews@public-inbox.freedesktop.org
 help / color / mirror / Atom feed
From: Arun R Murthy <arun.r.murthy@intel.com>
To: Simona Vetter <simona@ffwll.ch>,
	Jani Nikula <jani.nikula@linux.intel.com>,
	ville.syrjala@linux.intel.com, suraj.kandpal@intel.com,
	imre.deak@intel.com
Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org,
	intel-gfx@lists.freedesktop.org, intel-xe@lists.freedesktop.org,
	Arun R Murthy <arun.r.murthy@intel.com>
Subject: [PATCH RFC 3/3] drm/i915/dp: Configure PORT_AUX_CTL and then trigger the tx
Date: Mon, 09 Mar 2026 12:59:26 +0530	[thread overview]
Message-ID: <20260309-dp_aux_timeout-v1-3-08c610a63a84@intel.com> (raw)
In-Reply-To: <20260309-dp_aux_timeout-v1-0-08c610a63a84@intel.com>

Use re_rmw and update the required bits for PORT_AUX_CTL and drop the
bit configurations that are not required(AUX Power Request setting of
bit 19). Also break writing to PORT_AUX_CTL into 2 steps with first step
for doing the configuration/settings and then second write to trigger
the AUX transaction.

Signed-off-by: Arun R Murthy <arun.r.murthy@intel.com>
---
 drivers/gpu/drm/i915/display/intel_display_types.h |  6 +-
 drivers/gpu/drm/i915/display/intel_dp_aux.c        | 83 ++++++++++++++--------
 drivers/gpu/drm/i915/display/intel_psr.c           | 29 +++++---
 3 files changed, 76 insertions(+), 42 deletions(-)

diff --git a/drivers/gpu/drm/i915/display/intel_display_types.h b/drivers/gpu/drm/i915/display/intel_display_types.h
index e189f8c39ccb440f99cd642de177b18f3b605753..341749452579acfc3e08715d2f0b211bf6489dd9 100644
--- a/drivers/gpu/drm/i915/display/intel_display_types.h
+++ b/drivers/gpu/drm/i915/display/intel_display_types.h
@@ -1882,10 +1882,10 @@ struct intel_dp {
 
 	u32 (*get_aux_clock_divider)(struct intel_dp *dp, int index);
 	/*
-	 * This function returns the value we have to program the AUX_CTL
-	 * register with to kick off an AUX transaction.
+	 * This function programs the configuration/settings for the AUX_CTL
+	 * register but dont kick off an AUX transaction.
 	 */
-	u32 (*get_aux_send_ctl)(struct intel_dp *dp, int send_bytes,
+	void (*get_aux_send_ctl)(struct intel_dp *dp, int send_bytes,
 				u32 aux_clock_divider);
 
 	i915_reg_t (*aux_ch_ctl_reg)(struct intel_dp *dp);
diff --git a/drivers/gpu/drm/i915/display/intel_dp_aux.c b/drivers/gpu/drm/i915/display/intel_dp_aux.c
index 0a9e2d6cdbc5d9e0d17b2db60a32cf20a3bad6b6..4fef378e0a8fbf79211fd98913e507e90b2b48ea 100644
--- a/drivers/gpu/drm/i915/display/intel_dp_aux.c
+++ b/drivers/gpu/drm/i915/display/intel_dp_aux.c
@@ -175,12 +175,13 @@ static int g4x_dp_aux_precharge_len(void)
 		precharge_min - preamble) / 2;
 }
 
-static u32 g4x_get_aux_send_ctl(struct intel_dp *intel_dp,
-				int send_bytes,
-				u32 aux_clock_divider)
+static void g4x_get_aux_send_ctl(struct intel_dp *intel_dp,
+				 int send_bytes,
+				 u32 aux_clock_divider)
 {
 	struct intel_display *display = to_intel_display(intel_dp);
-	u32 timeout;
+	i915_reg_t ch_ctl = intel_dp->aux_ch_ctl_reg(intel_dp);
+	u32 timeout, value;
 
 	/* Max timeout value on G4x-BDW: 1.6ms */
 	if (display->platform.broadwell)
@@ -188,8 +189,7 @@ static u32 g4x_get_aux_send_ctl(struct intel_dp *intel_dp,
 	else
 		timeout = DP_AUX_CH_CTL_TIME_OUT_400us;
 
-	return DP_AUX_CH_CTL_SEND_BUSY |
-		DP_AUX_CH_CTL_DONE |
+	value = DP_AUX_CH_CTL_DONE |
 		DP_AUX_CH_CTL_INTERRUPT |
 		DP_AUX_CH_CTL_TIME_OUT_ERROR |
 		timeout |
@@ -197,23 +197,35 @@ static u32 g4x_get_aux_send_ctl(struct intel_dp *intel_dp,
 		DP_AUX_CH_CTL_MESSAGE_SIZE(send_bytes) |
 		DP_AUX_CH_CTL_PRECHARGE_2US(g4x_dp_aux_precharge_len()) |
 		DP_AUX_CH_CTL_BIT_CLOCK_2X(aux_clock_divider);
+
+	intel_de_rmw(display, ch_ctl,
+		     (DP_AUX_CH_CTL_DONE |
+		      DP_AUX_CH_CTL_INTERRUPT |
+		      DP_AUX_CH_CTL_TIME_OUT_ERROR |
+		      DP_AUX_CH_CTL_TIME_OUT_MASK |
+		      DP_AUX_CH_CTL_RECEIVE_ERROR |
+		      DP_AUX_CH_CTL_MESSAGE_SIZE_MASK |
+		      DP_AUX_CH_CTL_PRECHARGE_2US_MASK |
+		      DP_AUX_CH_CTL_BIT_CLOCK_2X_MASK),
+		     value);
+	return;
 }
 
-static u32 skl_get_aux_send_ctl(struct intel_dp *intel_dp,
-				int send_bytes,
-				u32 unused)
+static void skl_get_aux_send_ctl(struct intel_dp *intel_dp,
+				 int send_bytes,
+				 u32 unused)
 {
 	struct intel_display *display = to_intel_display(intel_dp);
 	struct intel_digital_port *dig_port = dp_to_dig_port(intel_dp);
-	u32 ret;
+	i915_reg_t ch_ctl = intel_dp->aux_ch_ctl_reg(intel_dp);
+	u32 value;
 
 	/*
 	 * Max timeout values:
 	 * SKL-GLK: 1.6ms
 	 * ICL+: 4ms
 	 */
-	ret = DP_AUX_CH_CTL_SEND_BUSY |
-		DP_AUX_CH_CTL_DONE |
+	value = DP_AUX_CH_CTL_DONE |
 		DP_AUX_CH_CTL_INTERRUPT |
 		DP_AUX_CH_CTL_TIME_OUT_ERROR |
 		DP_AUX_CH_CTL_TIME_OUT_MAX |
@@ -222,17 +234,22 @@ static u32 skl_get_aux_send_ctl(struct intel_dp *intel_dp,
 		DP_AUX_CH_CTL_FW_SYNC_PULSE_SKL(intel_dp_aux_fw_sync_len(intel_dp)) |
 		DP_AUX_CH_CTL_SYNC_PULSE_SKL(intel_dp_aux_sync_len());
 
-	if (intel_tc_port_in_tbt_alt_mode(dig_port))
-		ret |= DP_AUX_CH_CTL_TBT_IO;
+	intel_de_rmw(display, ch_ctl,
+		     (DP_AUX_CH_CTL_DONE |
+		      DP_AUX_CH_CTL_INTERRUPT |
+		      DP_AUX_CH_CTL_TIME_OUT_ERROR |
+		      DP_AUX_CH_CTL_TIME_OUT_MASK |
+		      DP_AUX_CH_CTL_RECEIVE_ERROR |
+		      DP_AUX_CH_CTL_MESSAGE_SIZE_MASK |
+		      DP_AUX_CH_CTL_FW_SYNC_PULSE_SKL_MASK |
+		      DP_AUX_CH_CTL_SYNC_PULSE_SKL_MASK),
+		     value);
 
-	/*
-	 * Power request bit is already set during aux power well enable.
-	 * Preserve the bit across aux transactions.
-	 */
-	if (DISPLAY_VER(display) >= 14)
-		ret |= XELPDP_DP_AUX_CH_CTL_POWER_REQUEST;
+	if (intel_tc_port_in_tbt_alt_mode(dig_port))
+		intel_de_rmw(display, ch_ctl, DP_AUX_CH_CTL_TBT_IO,
+			     DP_AUX_CH_CTL_TBT_IO);
 
-	return ret;
+	return;
 }
 
 static int
@@ -341,11 +358,12 @@ intel_dp_aux_xfer(struct intel_dp *intel_dp,
 	}
 
 	while ((aux_clock_divider = intel_dp->get_aux_clock_divider(intel_dp, clock++))) {
-		u32 send_ctl = intel_dp->get_aux_send_ctl(intel_dp,
-							  send_bytes,
-							  aux_clock_divider);
+		intel_dp->get_aux_send_ctl(intel_dp, send_bytes,
+					   aux_clock_divider);
 
-		send_ctl |= aux_send_ctl_flags;
+		/* Update the flags */
+		intel_de_rmw(display, ch_ctl, DP_AUX_CH_CTL_AUX_AKSV_SELECT,
+			     aux_send_ctl_flags);
 
 		/* Must try at least 3 times according to DP spec */
 		for (try = 0; try < 5; try++) {
@@ -356,15 +374,20 @@ intel_dp_aux_xfer(struct intel_dp *intel_dp,
 								 send_bytes - i));
 
 			/* Send the command and wait for it to complete */
-			intel_de_write(display, ch_ctl, send_ctl);
+			intel_de_rmw(display, ch_ctl,
+				     DP_AUX_CH_CTL_SEND_BUSY,
+				     DP_AUX_CH_CTL_SEND_BUSY);
 
 			status = intel_dp_aux_wait_done(intel_dp);
 
 			/* Clear done status and any errors */
-			intel_de_write(display, ch_ctl,
-				       status | DP_AUX_CH_CTL_DONE |
-				       DP_AUX_CH_CTL_TIME_OUT_ERROR |
-				       DP_AUX_CH_CTL_RECEIVE_ERROR);
+			intel_de_rmw(display, ch_ctl,
+				     (DP_AUX_CH_CTL_DONE |
+				      DP_AUX_CH_CTL_TIME_OUT_ERROR |
+				      DP_AUX_CH_CTL_RECEIVE_ERROR),
+				     (DP_AUX_CH_CTL_DONE |
+				      DP_AUX_CH_CTL_TIME_OUT_ERROR |
+				      DP_AUX_CH_CTL_RECEIVE_ERROR));
 
 			/*
 			 * DP CTS 1.2 Core Rev 1.1, 4.2.1.1 & 4.2.1.2
diff --git a/drivers/gpu/drm/i915/display/intel_psr.c b/drivers/gpu/drm/i915/display/intel_psr.c
index 9296ca3a4ff468a6e61babd81217e4ba19b15062..e06e04f20355d511e5c58fc28866aa763fd65a4b 100644
--- a/drivers/gpu/drm/i915/display/intel_psr.c
+++ b/drivers/gpu/drm/i915/display/intel_psr.c
@@ -722,7 +722,9 @@ static void hsw_psr_setup_aux(struct intel_dp *intel_dp)
 {
 	struct intel_display *display = to_intel_display(intel_dp);
 	enum transcoder cpu_transcoder = intel_dp->psr.transcoder;
+	i915_reg_t ch_ctl = psr_aux_ctl_reg(display, cpu_transcoder);
 	u32 aux_clock_divider, aux_ctl;
+
 	/* write DP_SET_POWER=D0 */
 	static const u8 aux_msg[] = {
 		[0] = (DP_AUX_NATIVE_WRITE << 4) | ((DP_SET_POWER >> 16) & 0xf),
@@ -742,17 +744,26 @@ static void hsw_psr_setup_aux(struct intel_dp *intel_dp)
 	aux_clock_divider = intel_dp->get_aux_clock_divider(intel_dp, 0);
 
 	/* Start with bits set for DDI_AUX_CTL register */
-	aux_ctl = intel_dp->get_aux_send_ctl(intel_dp, sizeof(aux_msg),
-					     aux_clock_divider);
+	intel_dp->get_aux_send_ctl(intel_dp, sizeof(aux_msg),
+				   aux_clock_divider);
 
 	/* Select only valid bits for SRD_AUX_CTL */
-	aux_ctl &= EDP_PSR_AUX_CTL_TIME_OUT_MASK |
-		EDP_PSR_AUX_CTL_MESSAGE_SIZE_MASK |
-		EDP_PSR_AUX_CTL_PRECHARGE_2US_MASK |
-		EDP_PSR_AUX_CTL_BIT_CLOCK_2X_MASK;
-
-	intel_de_write(display, psr_aux_ctl_reg(display, cpu_transcoder),
-		       aux_ctl);
+	aux_ctl = EDP_PSR_AUX_CTL_TIME_OUT_MASK |
+		  EDP_PSR_AUX_CTL_MESSAGE_SIZE_MASK |
+		  EDP_PSR_AUX_CTL_PRECHARGE_2US_MASK |
+		  EDP_PSR_AUX_CTL_BIT_CLOCK_2X_MASK;
+
+	intel_de_rmw(display, ch_ctl,
+		     (EDP_PSR_AUX_CTL_TIME_OUT_MASK |
+		      EDP_PSR_AUX_CTL_MESSAGE_SIZE_MASK |
+		      EDP_PSR_AUX_CTL_PRECHARGE_2US_MASK |
+		      EDP_PSR_AUX_CTL_BIT_CLOCK_2X_MASK),
+		     aux_ctl);
+
+	/* Send the command or intitate the AUX transaction */
+	intel_de_rmw(display, ch_ctl,
+		     DP_AUX_CH_CTL_SEND_BUSY,
+		     DP_AUX_CH_CTL_SEND_BUSY);
 }
 
 static bool psr2_su_region_et_valid(struct intel_connector *connector, bool panel_replay)

-- 
2.25.1


  parent reply	other threads:[~2026-03-09  7:32 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-03-09  7:29 [PATCH RFC 0/3] Some updates over DP AUX Transactions Arun R Murthy
2026-03-09  7:29 ` [PATCH RFC 1/3] drm/display/dp: Export function to wake the sink AUX_CH Arun R Murthy
2026-03-10  2:41   ` Claude review: " Claude Code Review Bot
2026-03-09  7:29 ` [PATCH RFC 2/3] drm/i915/dp: On AUX_CH tx timeout, wake up the sink Arun R Murthy
2026-03-10  2:41   ` Claude review: " Claude Code Review Bot
2026-03-09  7:29 ` Arun R Murthy [this message]
2026-03-09 13:09   ` [PATCH RFC 3/3] drm/i915/dp: Configure PORT_AUX_CTL and then trigger the tx Jani Nikula
2026-03-09 13:20     ` Murthy, Arun R
2026-03-10  2:41   ` Claude review: " Claude Code Review Bot
2026-03-10  2:41 ` Claude review: Some updates over DP AUX Transactions Claude Code Review Bot

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=20260309-dp_aux_timeout-v1-3-08c610a63a84@intel.com \
    --to=arun.r.murthy@intel.com \
    --cc=dri-devel@lists.freedesktop.org \
    --cc=imre.deak@intel.com \
    --cc=intel-gfx@lists.freedesktop.org \
    --cc=intel-xe@lists.freedesktop.org \
    --cc=jani.nikula@linux.intel.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=simona@ffwll.ch \
    --cc=suraj.kandpal@intel.com \
    --cc=ville.syrjala@linux.intel.com \
    /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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox