[PATCH v2] drm/i915/display: Implement wa_14024400148
Nautiyal, Ankit K
ankit.k.nautiyal at intel.com
Fri May 2 11:40:24 UTC 2025
On 4/22/2025 9:02 PM, Kahola, Mika wrote:
>> -----Original Message-----
>> From: Garg, Nemesa <nemesa.garg at intel.com>
>> Sent: Wednesday, 16 April 2025 18.21
>> To: intel-gfx at lists.freedesktop.org; intel-xe at lists.freedesktop.org; Kahola, Mika
>> <mika.kahola at intel.com>
>> Cc: Garg, Nemesa <nemesa.garg at intel.com>
>> Subject: [PATCH v2] drm/i915/display: Implement wa_14024400148
>>
>> Workaround recommend use polling method
>> for pm_demand to finish as to avoid timeout.
>>
>> v2: Add polling method within pmdemand_wait.
>> Update error message[Jani]
>>
>> Signed-off-by: Nemesa Garg <nemesa.garg at intel.com>
>> ---
>> drivers/gpu/drm/i915/display/intel_pmdemand.c | 31 ++++++++++++++++---
>> 1 file changed, 26 insertions(+), 5 deletions(-)
>>
>> diff --git a/drivers/gpu/drm/i915/display/intel_pmdemand.c
>> b/drivers/gpu/drm/i915/display/intel_pmdemand.c
>> index d22b5469672d..1253376c7654 100644
>> --- a/drivers/gpu/drm/i915/display/intel_pmdemand.c
>> +++ b/drivers/gpu/drm/i915/display/intel_pmdemand.c
>> @@ -478,13 +478,34 @@ static bool intel_pmdemand_req_complete(struct
>> intel_display *display)
>> XELPDP_PMDEMAND_REQ_ENABLE);
>> }
>>
>> -static void intel_pmdemand_wait(struct intel_display *display)
>> +static void intel_pmdemand_poll(struct intel_display *display)
>> {
>> - if (!wait_event_timeout(display->pmdemand.waitqueue,
>> - intel_pmdemand_req_complete(display),
>> - msecs_to_jiffies_timeout(10)))
>> + const unsigned int timeout_ms = 10;
>> + u32 status;
>> + int ret;
>> +
>> + ret = intel_de_wait_custom(display,
>> XELPDP_INITIATE_PMDEMAND_REQUEST(1),
>> + XELPDP_PMDEMAND_REQ_ENABLE, 0,
>> + 50, timeout_ms, &status);
>> +
>> + if (ret == -ETIMEDOUT)
>> drm_err(display->drm,
>> - "timed out waiting for Punit PM Demand Response\n");
>> + "timed out waiting for Punit PM Demand Response
>> within %ums (status 0x%08x)\n",
>> + timeout_ms, status);
>> +}
>> +
>> +static void intel_pmdemand_wait(struct intel_display *display) {
>> + /* Wa_14024400148 For lnl use polling method */
>> + if (DISPLAY_VER(display) == 20) {
>> + intel_pmdemand_poll(display);
>> + } else {
> Maybe this else branch could be written as its own function as with if branch. Anyway, this might be a topic for follow up patch.
>
> Reviewed-by: Mika Kahola <mika.kahola at intel.com>
Thanks for the patch and review. Pushed to drm-intel-next.
Regards,
Ankit
>
>> + if (!wait_event_timeout(display->pmdemand.waitqueue,
>> +
>> intel_pmdemand_req_complete(display),
>> + msecs_to_jiffies_timeout(10)))
>> + drm_err(display->drm,
>> + "timed out waiting for Punit PM Demand
>> Response\n");
>> + }
>> }
>>
>> /* Required to be programmed during Display Init Sequences. */
>> --
>> 2.25.1
More information about the Intel-xe
mailing list