]> www.infradead.org Git - users/hch/misc.git/commitdiff
drm/amd/display: track dpia support
authorAusef Yousof <Ausef.Yousof@amd.com>
Wed, 30 Jul 2025 20:08:10 +0000 (16:08 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 27 Aug 2025 17:57:49 +0000 (13:57 -0400)
[why&how]
initialize a flag to track if we previously
supported dpia and write that to boot options

Reviewed-by: Nicholas Kazlauskas <nicholas.kazlauskas@amd.com>
Reviewed-by: Meenakshikumar Somasundaram <meenakshikumar.somasundaram@amd.com>
Signed-off-by: Ausef Yousof <Ausef.Yousof@amd.com>
Signed-off-by: Aurabindo Pillai <aurabindo.pillai@amd.com>
Tested-by: Dan Wheeler <daniel.wheeler@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dmub/dmub_srv.h
drivers/gpu/drm/amd/display/dmub/src/dmub_dcn35.c

index 7abf7d0fd02b1c74af03be67a8693168c26997b4..338fdc651f2cf2520dde21550ff649d04506841d 100644 (file)
@@ -568,6 +568,7 @@ struct dmub_srv {
 
        bool sw_init;
        bool hw_init;
+       bool dpia_supported;
 
        uint64_t fb_base;
        uint64_t fb_offset;
index 2228d62adc7e465c9c317bd1c0fb6024644a13f7..834e5434ccb882ab2c382a4b046bde1249b37824 100644 (file)
@@ -400,13 +400,14 @@ union dmub_fw_boot_options dmub_dcn35_get_fw_boot_option(struct dmub_srv *dmub)
 void dmub_dcn35_enable_dmub_boot_options(struct dmub_srv *dmub, const struct dmub_srv_hw_params *params)
 {
        union dmub_fw_boot_options boot_options = {0};
-       union dmub_fw_boot_options cur_boot_options = {0};
 
-       cur_boot_options = dmub_dcn35_get_fw_boot_option(dmub);
+       if (!dmub->dpia_supported) {
+               dmub->dpia_supported = dmub_dcn35_get_fw_boot_option(dmub).bits.enable_dpia;
+       }
 
        boot_options.bits.z10_disable = params->disable_z10;
        boot_options.bits.dpia_supported = params->dpia_supported;
-       boot_options.bits.enable_dpia = cur_boot_options.bits.enable_dpia && !params->disable_dpia;
+       boot_options.bits.enable_dpia = dmub->dpia_supported && !params->disable_dpia;
        boot_options.bits.usb4_cm_version = params->usb4_cm_version;
        boot_options.bits.dpia_hpd_int_enable_supported = params->dpia_hpd_int_enable_supported;
        boot_options.bits.power_optimization = params->power_optimization;