From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.12]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id D07EB261B71 for ; Fri, 29 May 2026 10:42:24 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=198.175.65.12 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780051346; cv=none; b=Hi2ab3JfV9qkRTDI/ndubzoPsoLuQSsmXwR2RmHGlUOv+l7OCNs1xMnPYdv8OAVcvHWlZ0Via2uGqA/KnvhVIG3ZMF74f5BguG59ELG1SaxVuDgAZ/Xse3IJMFDD8hKMHgksFkNKm37EgZoHoSGzwx2Eqpz7zL614l6Pp2eshmk= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780051346; c=relaxed/simple; bh=nhiGTZV7kwxtAmstGwsZ21tvm4gRMd51iWB8DgbgR+o=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=nIEZq8ZwdIlJ7ywYpAf3GJUejKuoh9kLMQP500p4eIwDwhMuUocYJWYbGLqzFxAtXtGJUlRgsPTLbHd9KjX3jEGzgu6I5HR8yQVOaxtw+rzqkGu3RgPC47nxKoN3cB45nGNY9v2begeO3703xS3x5cuPhXS3rQmtJzUJVWopY64= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com; spf=pass smtp.mailfrom=intel.com; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b=hGn2PofR; arc=none smtp.client-ip=198.175.65.12 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=intel.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="hGn2PofR" DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1780051345; x=1811587345; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=nhiGTZV7kwxtAmstGwsZ21tvm4gRMd51iWB8DgbgR+o=; b=hGn2PofRDLDTF1l7Bp7/ITxGltrXOCHDODGpmIkyS3p9RWm6uRNK1QKj 7ZJ0HHSi8uQyJCmlz0xCuslUb0yqs8SFXqq4GbhL+GAI1OiAVSEPdl1vX tLTbXTWdEftJ5jsdO4e2ldJh1BHe0ZI5W1VtqZlGvOUGvQFMKXGP6sp88 1fWIk4y4JOsbzuwiTnJLbu3ptQiZnj4/bNk9wwQrdRN5/EpuM25kJYHRg o0nkMvJ+SbXSGmtNi44uWqmgmwApxW4boyHL9M4tPK3IOzABKVZmWoW3h GUOrtzcHznaaiu2IjNpRDEqpXVBFFHcD9GEz6XCKJzRArJsTaKj+qx0hY Q==; X-CSE-ConnectionGUID: H1KNXAKqR8qj/pgzT/6BGA== X-CSE-MsgGUID: u7RDgSdATxijtSNxwxQQbw== X-IronPort-AV: E=McAfee;i="6800,10657,11800"; a="92376499" X-IronPort-AV: E=Sophos;i="6.24,175,1774335600"; d="scan'208";a="92376499" Received: from fmviesa010.fm.intel.com ([10.60.135.150]) by orvoesa104.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 29 May 2026 03:42:25 -0700 X-CSE-ConnectionGUID: yAfTr2HuQ4qbVNmBmb5E9g== X-CSE-MsgGUID: L1XZVqp3SO6NeHHt3knHRg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.24,175,1774335600"; d="scan'208";a="238625167" Received: from mjarzebo-mobl1.ger.corp.intel.com (HELO jhogande-mobl3.intel.com) ([10.245.246.54]) by fmviesa010-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 29 May 2026 03:42:23 -0700 From: =?UTF-8?q?Jouni=20H=C3=B6gander?= To: stable@vger.kernel.org Cc: =?UTF-8?q?Jouni=20H=C3=B6gander?= , Suraj Kandpal , Tvrtko Ursulin Subject: [PATCH 6.12.y 4/4] drm/i915/psr: Apply Intel DPCD workaround when SDP on prior line used Date: Fri, 29 May 2026 13:42:06 +0300 Message-ID: <20260529104206.758103-4-jouni.hogander@intel.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260529104206.758103-1-jouni.hogander@intel.com> References: <2026052816-harvest-stinking-041d@gregkh> <20260529104206.758103-1-jouni.hogander@intel.com> Precedence: bulk X-Mailing-List: stable@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Organization: Intel Finland Oy - BIC 0357606-4 - Westendinkatu 7, 02160 Espoo Content-Transfer-Encoding: 8bit commit 4703049f768fc1c1caac754134118bee1a3af189 upstream. There is Intel specific workaround DPCD address containing workaround for case where SDP is on prior line. Apply this workaround according to values in the offset. Fixes: 61e887329e33 ("drm/i915/xelpd: Handle PSR2 SDP indication in the prior scanline") Cc: # v5.15+ Signed-off-by: Jouni Högander Reviewed-by: Suraj Kandpal Link: https://patch.msgid.link/20260515095756.2799483-4-jouni.hogander@intel.com (cherry picked from commit c3fe899fbeac86ea4a5ca9dd845b2cbc0da46249) Signed-off-by: Tvrtko Ursulin Signed-off-by: Jouni Högander --- drivers/gpu/drm/i915/display/intel_psr.c | 27 +++++++++++++++++++++++- 1 file changed, 26 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/i915/display/intel_psr.c b/drivers/gpu/drm/i915/display/intel_psr.c index 9c38b9577016..5173f5759ce8 100644 --- a/drivers/gpu/drm/i915/display/intel_psr.c +++ b/drivers/gpu/drm/i915/display/intel_psr.c @@ -1303,6 +1303,30 @@ static bool psr2_granularity_check(struct intel_dp *intel_dp, return true; } +static bool apply_scanline_indication_wa(struct intel_dp *intel_dp, + struct intel_crtc_state *crtc_state) +{ + u8 early_scanline_support = intel_dp->intel_wa_dpcd & + INTEL_DPCD_INTEL_WA_REGISTER_CAPS_PSR2_EARLYSCANLINE_SDP_SUPPORT_MASK; + + if (intel_dp->edp_dpcd[0] >= DP_EDP_15) + return true; + + switch (early_scanline_support) { + case INTEL_DPCD_INTEL_WA_REGISTER_CAPS_FALL_BACK_TO_PSR1: + crtc_state->req_psr2_sdp_prior_scanline = false; + return false; + case INTEL_DPCD_INTEL_WA_REGISTER_CAPS_PSR2_WITH_EARLY_SCANLINE: + return true; + case INTEL_DPCD_INTEL_WA_REGISTER_CAPS_PSR2_WITHOUT_EARLY_SCANLINE: + crtc_state->req_psr2_sdp_prior_scanline = false; + return true; + default: + MISSING_CASE(early_scanline_support); + return false; + } +} + static bool _compute_psr2_sdp_prior_scanline_indication(struct intel_dp *intel_dp, struct intel_crtc_state *crtc_state) { @@ -1324,7 +1348,8 @@ static bool _compute_psr2_sdp_prior_scanline_indication(struct intel_dp *intel_d return false; crtc_state->req_psr2_sdp_prior_scanline = true; - return true; + + return apply_scanline_indication_wa(intel_dp, crtc_state); } static int intel_psr_entry_setup_frames(struct intel_dp *intel_dp, -- 2.43.0