drm/amd/display: Add minimum Z8 residency debug option
authorjsg <jsg@openbsd.org>
Tue, 13 Jun 2023 03:54:06 +0000 (03:54 +0000)
committerjsg <jsg@openbsd.org>
Tue, 13 Jun 2023 03:54:06 +0000 (03:54 +0000)
From Nicholas Kazlauskas
25f603624246062fd473812e6ebda98e3c387017 in linux-6.1.y/6.1.29
0db13eae41fcc67f408dbb3dfda59633c4fa03fb in mainline linux

sys/dev/pci/drm/amd/display/dc/dc.h
sys/dev/pci/drm/amd/display/dc/dcn314/dcn314_resource.c
sys/dev/pci/drm/amd/display/dc/dml/dcn20/dcn20_fpu.c

index d57761c..9245c90 100644 (file)
@@ -781,6 +781,7 @@ struct dc_debug_options {
        unsigned int force_odm_combine; //bit vector based on otg inst
        unsigned int seamless_boot_odm_combine;
        unsigned int force_odm_combine_4to1; //bit vector based on otg inst
+       int minimum_z8_residency_time;
        bool disable_z9_mpc;
        unsigned int force_fclk_khz;
        bool enable_tri_buf;
index 58931df..67c892b 100644 (file)
@@ -884,6 +884,7 @@ static const struct dc_plane_cap plane_cap = {
 static const struct dc_debug_options debug_defaults_drv = {
        .disable_z10 = false,
        .enable_z9_disable_interface = true,
+       .minimum_z8_residency_time = 1000,
        .psr_skip_crtc_disable = true,
        .disable_dmcu = true,
        .force_abm_enable = false,
index 6a7bcba..186538e 100644 (file)
@@ -973,7 +973,8 @@ static enum dcn_zstate_support_state  decide_zstate_support(struct dc *dc, struc
        else if (context->stream_count == 1 &&  context->streams[0]->signal == SIGNAL_TYPE_EDP) {
                struct dc_link *link = context->streams[0]->sink->link;
                struct dc_stream_status *stream_status = &context->stream_status[0];
-               bool allow_z8 = context->bw_ctx.dml.vba.StutterPeriod > 1000.0;
+               int minmum_z8_residency = dc->debug.minimum_z8_residency_time > 0 ? dc->debug.minimum_z8_residency_time : 1000;
+               bool allow_z8 = context->bw_ctx.dml.vba.StutterPeriod > (double)minmum_z8_residency;
                bool is_pwrseq0 = link->link_index == 0;
 
                if (dc_extended_blank_supported(dc)) {