]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/amd/display: Refactor DAC load detection, move to HWSS
authorTimur Kristóf <timur.kristof@gmail.com>
Mon, 26 Jan 2026 21:08:28 +0000 (22:08 +0100)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 23 Feb 2026 19:28:32 +0000 (14:28 -0500)
Slightly refactor and simplify DAC load detection.
This prepares the code to be used for also executing DAC
load detection on external DP bridge encoders.

DAC load detection belongs better in the hardware sequencer
code because the implementation is HW dependent and not all
chips support the functionality. The code is cleaner when
link detection probably doesn't call the VBIOS directly.

Signed-off-by: Timur Kristóf <timur.kristof@gmail.com>
Reviewed-by: Alex Hung <alex.hung@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/bios/bios_parser.c
drivers/gpu/drm/amd/display/dc/dc_bios_types.h
drivers/gpu/drm/amd/display/dc/hwss/dce110/dce110_hwseq.c
drivers/gpu/drm/amd/display/dc/hwss/hw_sequencer.h
drivers/gpu/drm/amd/display/dc/link/link_detection.c

index 73e3c45eeeba6b0570f08e6df7601e702444e355..234a7f137cf5ade5b81d3ad35dc4d87bbcb21fc5 100644 (file)
@@ -782,26 +782,17 @@ static enum bp_result bios_parser_encoder_control(
 
 static enum bp_result bios_parser_dac_load_detection(
        struct dc_bios *dcb,
-       enum engine_id engine_id,
-       enum dal_device_type device_type,
-       uint32_t enum_id)
+       enum engine_id engine_id)
 {
        struct bios_parser *bp = BP_FROM_DCB(dcb);
        struct dc_context *ctx = dcb->ctx;
        struct bp_load_detection_parameters bp_params = {0};
-       enum bp_result bp_result;
+       enum bp_result bp_result = BP_RESULT_UNSUPPORTED;
        uint32_t bios_0_scratch;
        uint32_t device_id_mask = 0;
 
-       bp_params.engine_id = engine_id;
-       bp_params.device_id = get_support_mask_for_device_id(device_type, enum_id);
-
-       if (engine_id != ENGINE_ID_DACA &&
-           engine_id != ENGINE_ID_DACB)
-               return BP_RESULT_UNSUPPORTED;
-
-       if (!bp->cmd_tbl.dac_load_detection)
-               return BP_RESULT_UNSUPPORTED;
+       bp_params.device_id = get_support_mask_for_device_id(
+               DEVICE_TYPE_CRT, engine_id == ENGINE_ID_DACB ? 2 : 1);
 
        if (bp_params.device_id == ATOM_DEVICE_CRT1_SUPPORT)
                device_id_mask = ATOM_S0_CRT1_MASK;
@@ -815,7 +806,13 @@ static enum bp_result bios_parser_dac_load_detection(
        bios_0_scratch &= ~device_id_mask;
        dm_write_reg(ctx, bp->base.regs->BIOS_SCRATCH_0, bios_0_scratch);
 
-       bp_result = bp->cmd_tbl.dac_load_detection(bp, &bp_params);
+       if (engine_id == ENGINE_ID_DACA || engine_id == ENGINE_ID_DACB) {
+               if (!bp->cmd_tbl.dac_load_detection)
+                       return BP_RESULT_UNSUPPORTED;
+
+               bp_params.engine_id = engine_id;
+               bp_result = bp->cmd_tbl.dac_load_detection(bp, &bp_params);
+       }
 
        if (bp_result != BP_RESULT_OK)
                return bp_result;
index 40d7a7d83c4065b9b6287e83761c8522ec74c60a..06fdde281a0c3bdc3974ac3eaf450d89eb8b4ef8 100644 (file)
@@ -99,9 +99,7 @@ struct dc_vbios_funcs {
                struct bp_encoder_control *cntl);
        enum bp_result (*dac_load_detection)(
                struct dc_bios *bios,
-               enum engine_id engine_id,
-               enum dal_device_type device_type,
-               uint32_t enum_id);
+               enum engine_id engine_id);
        enum bp_result (*transmitter_control)(
                struct dc_bios *bios,
                struct bp_transmitter_control *cntl);
index 699a756bbc40512aee3bf5d4dec541f2d2c7966d..cbc8c2f1b2ab73cf7f87586c696ce96c60922e81 100644 (file)
@@ -660,6 +660,17 @@ void dce110_update_info_frame(struct pipe_ctx *pipe_ctx)
        }
 }
 
+static bool
+dce110_dac_load_detect(struct dc_link *link)
+{
+       struct dc_bios *bios = link->ctx->dc_bios;
+       struct link_encoder *link_enc = link->link_enc;
+       enum bp_result bp_result;
+
+       bp_result = bios->funcs->dac_load_detection(bios, link_enc->analog_engine);
+       return bp_result == BP_RESULT_OK;
+}
+
 void dce110_enable_stream(struct pipe_ctx *pipe_ctx)
 {
        enum dc_lane_count lane_count =
@@ -3409,6 +3420,7 @@ static const struct hw_sequencer_funcs dce110_funcs = {
        .enable_dp_link_output = dce110_enable_dp_link_output,
        .enable_analog_link_output = dce110_enable_analog_link_output,
        .disable_link_output = dce110_disable_link_output,
+       .dac_load_detect = dce110_dac_load_detect,
 };
 
 static const struct hwseq_private_funcs dce110_private_funcs = {
index 4632a5761b169de842dadf4f2e43242e6897becb..d3d35912349d8f1cd94f87ad674bfff5f0499d1b 100644 (file)
@@ -1189,6 +1189,7 @@ struct hw_sequencer_funcs {
        void (*disable_link_output)(struct dc_link *link,
                        const struct link_resource *link_res,
                        enum signal_type signal);
+       bool (*dac_load_detect)(struct dc_link *link);
 
        void (*get_dcc_en_bits)(struct dc *dc, int *dcc_en_bits);
 
index b2c020071cbfbf33bb3a9604874594aef702b17b..45a0b25c4ccf0dade160aa12d43d0b1eb5790f98 100644 (file)
@@ -932,28 +932,10 @@ static bool link_detect_ddc_probe(struct dc_link *link)
  */
 static bool link_detect_dac_load_detect(struct dc_link *link)
 {
-       struct dc_bios *bios = link->ctx->dc_bios;
-       struct link_encoder *link_enc = link->link_enc;
-       enum engine_id engine_id = link_enc->preferred_engine;
-       enum dal_device_type device_type = DEVICE_TYPE_CRT;
-       enum bp_result bp_result = BP_RESULT_UNSUPPORTED;
-       uint32_t enum_id;
-
-       switch (engine_id) {
-       case ENGINE_ID_DACB:
-               enum_id = 2;
-               break;
-       case ENGINE_ID_DACA:
-       default:
-               engine_id = ENGINE_ID_DACA;
-               enum_id = 1;
-               break;
-       }
-
-       if (bios->funcs->dac_load_detection)
-               bp_result = bios->funcs->dac_load_detection(bios, engine_id, device_type, enum_id);
+       if (!link->dc->hwss.dac_load_detect)
+               return false;
 
-       return bp_result == BP_RESULT_OK;
+       return link->dc->hwss.dac_load_detect(link);
 }
 
 /*