[PATCH v1 5/6] display/psr: Add latency for PSR
Mitul Golani
mitulkumar.ajitkumar.golani at intel.com
Wed Sep 18 14:07:07 UTC 2024
Count and add latency accounter for PSR enablement.
Signed-off-by: Mitul Golani <mitulkumar.ajitkumar.golani at intel.com>
---
drivers/gpu/drm/i915/display/intel_psr.c | 17 +++++++++++++++++
drivers/gpu/drm/i915/display/intel_psr.h | 1 +
2 files changed, 18 insertions(+)
diff --git a/drivers/gpu/drm/i915/display/intel_psr.c b/drivers/gpu/drm/i915/display/intel_psr.c
index 4f29ac32ff85..62970192b96e 100644
--- a/drivers/gpu/drm/i915/display/intel_psr.c
+++ b/drivers/gpu/drm/i915/display/intel_psr.c
@@ -241,6 +241,23 @@ static bool psr_global_enabled(struct intel_dp *intel_dp)
}
}
+int calc_psr_latency(struct intel_crtc_state *crtc_state)
+{
+ int val, enabled, linetime, io_wake_lines;
+ struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
+ struct drm_i915_private *i915 = to_i915(crtc->base.dev);
+
+ linetime = DIV_ROUND_UP(crtc_state->hw.adjusted_mode.htotal * 1000,
+ intel_crtc_dotclock(crtc_state));
+ val = intel_de_read(i915,
+ EDP_PSR2_CTL(i915, crtc_state->cpu_transcoder));
+ enabled = val & EDP_PSR2_ENABLE;
+ io_wake_lines = LNL_EDP_PSR2_IO_BUFFER_WAKE_MASK & val;
+
+ return intel_usecs_to_scanlines(&crtc_state->hw.adjusted_mode,
+ enabled * io_wake_lines * linetime);
+}
+
static bool psr2_global_enabled(struct intel_dp *intel_dp)
{
struct intel_display *display = to_intel_display(intel_dp);
diff --git a/drivers/gpu/drm/i915/display/intel_psr.h b/drivers/gpu/drm/i915/display/intel_psr.h
index 6eb5f15f674f..d7606622f7cd 100644
--- a/drivers/gpu/drm/i915/display/intel_psr.h
+++ b/drivers/gpu/drm/i915/display/intel_psr.h
@@ -24,6 +24,7 @@ struct intel_plane_state;
#define CAN_PANEL_REPLAY(intel_dp) ((intel_dp)->psr.sink_panel_replay_support && \
(intel_dp)->psr.source_panel_replay_support)
+int calc_psr_latency(struct intel_crtc_state *crtc_state);
bool intel_encoder_can_psr(struct intel_encoder *encoder);
bool intel_psr_needs_aux_io_power(struct intel_encoder *encoder,
const struct intel_crtc_state *crtc_state);
--
2.46.0
More information about the Intel-gfx-trybot
mailing list