]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
drm/amd/display: Add function to set pixels per cycle
authorEric Bernstein <eric.bernstein@amd.com>
Fri, 1 Apr 2022 17:49:45 +0000 (13:49 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 5 Jul 2022 20:11:00 +0000 (16:11 -0400)
Add function to set pixels per cycle in DIG stream encoder

Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com>
Signed-off-by: Eric Bernstein <eric.bernstein@amd.com>
Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_stream_encoder.h
drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hwseq.c
drivers/gpu/drm/amd/display/dc/dcn32/dcn32_dio_stream_encoder.c
drivers/gpu/drm/amd/display/dc/dcn32/dcn32_dio_stream_encoder.h
drivers/gpu/drm/amd/display/dc/dcn32/dcn32_hwseq.c
drivers/gpu/drm/amd/display/dc/dcn32/dcn32_hwseq.h
drivers/gpu/drm/amd/display/dc/dcn32/dcn32_init.c
drivers/gpu/drm/amd/display/dc/inc/hw_sequencer_private.h

index f8d22ba6a6e4052bf7062fb7cfa31a301a52c10a..aa4f41745be42923ce08c58fee030fe04708f6b0 100644 (file)
@@ -577,6 +577,7 @@ struct dcn10_stream_enc_registers {
 
 #define SE_REG_FIELD_LIST_DCN3_2(type) \
        type DIG_FIFO_OUTPUT_PIXEL_MODE;\
+       type DP_PIXEL_PER_CYCLE_PROCESSING_MODE;\
        type DIG_SYMCLK_FE_ON;\
        type DIG_FIFO_READ_START_LEVEL;\
        type DIG_FIFO_ENABLE;\
index 9f07c1b170c932449ee9b85521e1ec8e44428d7c..2286cc34e9cc456ecf880fc2c9828d68fffc5586 100644 (file)
@@ -2535,9 +2535,8 @@ void dcn20_enable_stream(struct pipe_ctx *pipe_ctx)
 
        tg->funcs->set_early_control(tg, early_control);
 
-       if (pipe_ctx->stream_res.stream_enc->funcs->set_input_mode)
-               pipe_ctx->stream_res.stream_enc->funcs->set_input_mode(pipe_ctx->stream_res.stream_enc,
-                       timing->pixel_encoding == PIXEL_ENCODING_YCBCR420 ? 2 : 1);
+       if (dc->hwseq->funcs.set_pixels_per_cycle)
+               dc->hwseq->funcs.set_pixels_per_cycle(pipe_ctx);
 
        /* enable audio only within mode set */
        if (pipe_ctx->stream_res.audio != NULL) {
index 4d7588f2ee793d27abb35395d0cec5848923930c..f16c4fcdf9e9c4791da8ce5ba04b05b20b952a91 100644 (file)
@@ -54,9 +54,9 @@ static void enc32_dp_set_odm_combine(
        struct stream_encoder *enc,
        bool odm_combine)
 {
-       //struct dcn10_stream_encoder *enc1 = DCN10STRENC_FROM_STRENC(enc);
+       struct dcn10_stream_encoder *enc1 = DCN10STRENC_FROM_STRENC(enc);
 
-       //TODO: REG_UPDATE(DP_PIXEL_FORMAT, DP_PIXEL_COMBINE, odm_combine);
+       REG_UPDATE(DP_PIXEL_FORMAT, DP_PIXEL_PER_CYCLE_PROCESSING_MODE, odm_combine ? 1 : 0);
 }
 
 /* setup stream encoder in dvi mode */
index 042bc9aca944f5ab2e6a6dc6336aa14412cb37a0..250d9a341cf661e3ab91e7c89d83baaaaed27a79 100644 (file)
@@ -96,6 +96,7 @@
 #define SE_COMMON_MASK_SH_LIST_DCN32_BASE(mask_sh)\
        SE_SF(DP0_DP_PIXEL_FORMAT, DP_PIXEL_ENCODING, mask_sh),\
        SE_SF(DP0_DP_PIXEL_FORMAT, DP_COMPONENT_DEPTH, mask_sh),\
+       SE_SF(DP0_DP_PIXEL_FORMAT, DP_PIXEL_PER_CYCLE_PROCESSING_MODE, mask_sh),\
        SE_SF(DIG0_HDMI_CONTROL, HDMI_PACKET_GEN_VERSION, mask_sh),\
        SE_SF(DIG0_HDMI_CONTROL, HDMI_KEEPOUT_MODE, mask_sh),\
        SE_SF(DIG0_HDMI_CONTROL, HDMI_DEEP_COLOR_ENABLE, mask_sh),\
index e8108249e97835745941722a8f9b2e09dc2e9d5f..aa9eb229199b923dfbc3654e203d489b37da0d83 100644 (file)
@@ -1114,3 +1114,20 @@ unsigned int dcn32_calculate_dccg_k1_k2_values(struct pipe_ctx *pipe_ctx, unsign
 
        return odm_combine_factor;
 }
+
+void dcn32_set_pixels_per_cycle(struct pipe_ctx *pipe_ctx)
+{
+       uint32_t pix_per_cycle = 1;
+       uint32_t odm_combine_factor = 1;
+
+       if (!pipe_ctx || !pipe_ctx->stream || !pipe_ctx->stream_res.stream_enc)
+               return;
+
+       odm_combine_factor = get_odm_config(pipe_ctx, NULL);
+       if (optc2_is_two_pixels_per_containter(&pipe_ctx->stream->timing) || odm_combine_factor > 1)
+               pix_per_cycle = 2;
+
+       if (pipe_ctx->stream_res.stream_enc->funcs->set_input_mode)
+               pipe_ctx->stream_res.stream_enc->funcs->set_input_mode(pipe_ctx->stream_res.stream_enc,
+                               pix_per_cycle);
+}
index 494cb3a47435bc0a4c7bac60ddc45f37500d904d..18227d58c51d255a1b57657a51eebdba36ae8092 100644 (file)
@@ -70,6 +70,8 @@ void dcn32_update_odm(struct dc *dc, struct dc_state *context, struct pipe_ctx *
 
 unsigned int dcn32_calculate_dccg_k1_k2_values(struct pipe_ctx *pipe_ctx, unsigned int *k1_div, unsigned int *k2_div);
 
+void dcn32_set_pixels_per_cycle(struct pipe_ctx *pipe_ctx);
+
 void dcn32_subvp_pipe_control_lock(struct dc *dc,
                struct dc_state *context,
                bool lock,
index fb965d31e8ddb8f37720fbfab7c7c1563adff027..19d8a30b3358a3f23e735d86f0ede8f10ad9c2a4 100644 (file)
@@ -142,6 +142,7 @@ static const struct hwseq_private_funcs dcn32_private_funcs = {
        .subvp_update_force_pstate = dcn32_subvp_update_force_pstate,
        .update_mall_sel = dcn32_update_mall_sel,
        .calculate_dccg_k1_k2_values = dcn32_calculate_dccg_k1_k2_values,
+       .set_pixels_per_cycle = dcn32_set_pixels_per_cycle,
 };
 
 void dcn32_hw_sequencer_init_functions(struct dc *dc)
index ded45f8f4b8215d545f8b8ea6fc4734d0fc3e1cd..2b2e5b8089629788fb3386766af1a8cd6d675e4c 100644 (file)
@@ -153,6 +153,7 @@ struct hwseq_private_funcs {
        unsigned int (*calculate_dccg_k1_k2_values)(struct pipe_ctx *pipe_ctx,
                        unsigned int *k1_div,
                        unsigned int *k2_div);
+       void (*set_pixels_per_cycle)(struct pipe_ctx *pipe_ctx);
 #endif
 };