From: "Ville Syrjälä" <ville.syrjala@linux.intel.com>
To: "Michał Grzelak" <michal.grzelak@intel.com>
Cc: intel-gfx@lists.freedesktop.org, intel-xe@lists.freedesktop.org
Subject: Re: [RESEND] drm/i915/aux: use polling when irqs are unavailable
Date: Tue, 19 May 2026 16:20:31 +0300 [thread overview]
Message-ID: <agxjn1P9K7DGA8QO@intel.com> (raw)
In-Reply-To: <20260416163744.288107-1-michal.grzelak@intel.com>
On Thu, Apr 16, 2026 at 06:37:44PM +0200, Michał Grzelak wrote:
> PTL with physically disconnected display was observed to have 40s longer
> execution time when testing xe_fault_injection@xe_guc_mmio_send_recv.
> The issue has not been seen when reverting commit 40a9f77a28fa ("Revert
> "drm/i915/dp: change aux_ctl reg read to polling read"").
>
> Apparently the configuration suffers from not having AUX enabled when
> using interrupts. One probable cause can be xe enabling interrupts too
> late: interrupts need memory allocations which currently can't be done
> before the display FB takeover is done.
>
> As for now, use polling for AUX in case interrupts are unavailable.
>
> Fixes: 40a9f77a28fa ("Revert "drm/i915/dp: change aux_ctl reg read to polling read"")
> Suggested-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
> Signed-off-by: Michał Grzelak <michal.grzelak@intel.com>
Pushed to drm-intel-next. Thanks.
> ---
> drivers/gpu/drm/i915/display/intel_dp_aux.c | 20 ++++++++++++++++----
> 1 file changed, 16 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/display/intel_dp_aux.c b/drivers/gpu/drm/i915/display/intel_dp_aux.c
> index b20ec3e589fad..9c9b6410366d5 100644
> --- a/drivers/gpu/drm/i915/display/intel_dp_aux.c
> +++ b/drivers/gpu/drm/i915/display/intel_dp_aux.c
> @@ -12,6 +12,7 @@
> #include "intel_dp.h"
> #include "intel_dp_aux.h"
> #include "intel_dp_aux_regs.h"
> +#include "intel_parent.h"
> #include "intel_pps.h"
> #include "intel_quirks.h"
> #include "intel_tc.h"
> @@ -60,18 +61,29 @@ intel_dp_aux_wait_done(struct intel_dp *intel_dp)
> struct intel_display *display = to_intel_display(intel_dp);
> i915_reg_t ch_ctl = intel_dp->aux_ch_ctl_reg(intel_dp);
> const unsigned int timeout_ms = 10;
> + bool done = true;
> u32 status;
> - bool done;
> + int ret;
>
> + if (intel_parent_irq_enabled(display)) {
> #define C (((status = intel_de_read_notrace(display, ch_ctl)) & DP_AUX_CH_CTL_SEND_BUSY) == 0)
> - done = wait_event_timeout(display->gmbus.wait_queue, C,
> - msecs_to_jiffies_timeout(timeout_ms));
> + done = wait_event_timeout(display->gmbus.wait_queue, C,
> + msecs_to_jiffies_timeout(timeout_ms));
> +
> +#undef C
> + } else {
> + ret = intel_de_wait_ms(display, ch_ctl,
> + DP_AUX_CH_CTL_SEND_BUSY, 0,
> + timeout_ms, &status);
> +
> + if (ret == -ETIMEDOUT)
> + done = false;
> + }
>
> if (!done)
> drm_err(display->drm,
> "%s: did not complete or timeout within %ums (status 0x%08x)\n",
> intel_dp->aux.name, timeout_ms, status);
> -#undef C
>
> return status;
> }
> --
> 2.45.2
--
Ville Syrjälä
Intel
prev parent reply other threads:[~2026-05-19 13:20 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-04-16 16:37 [RESEND] drm/i915/aux: use polling when irqs are unavailable Michał Grzelak
2026-04-16 16:45 ` ✓ CI.KUnit: success for drm/i915/aux: use polling when irqs are unavailable (rev3) Patchwork
2026-04-16 17:25 ` ✓ i915.CI.BAT: " Patchwork
2026-04-16 17:41 ` ✓ Xe.CI.BAT: " Patchwork
2026-04-16 19:29 ` ✓ Xe.CI.FULL: " Patchwork
2026-04-20 13:29 ` ✓ i915.CI.Full: " Patchwork
2026-05-19 13:20 ` Ville Syrjälä [this message]
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=agxjn1P9K7DGA8QO@intel.com \
--to=ville.syrjala@linux.intel.com \
--cc=intel-gfx@lists.freedesktop.org \
--cc=intel-xe@lists.freedesktop.org \
--cc=michal.grzelak@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 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.