drm/amd/display: add per pipe dppclk
authorDmytro Laktyushkin <Dmytro.Laktyushkin@amd.com>
Mon, 12 Feb 2018 20:19:20 +0000 (15:19 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 5 Mar 2018 20:34:33 +0000 (15:34 -0500)
v2: Fix commit title

Signed-off-by: Dmytro Laktyushkin <Dmytro.Laktyushkin@amd.com>
Reviewed-by: Tony Cheng <Tony.Cheng@amd.com>
Acked-by: Harry Wentland <harry.wentland@amd.com>
Acked-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/calcs/dcn_calcs.c
drivers/gpu/drm/amd/display/dc/core/dc_debug.c
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_dpp.c
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hw_sequencer.c
drivers/gpu/drm/amd/display/dc/inc/core_types.h

index c9aa686d16b9285ea3758fd05bc6fd079519f933..e4d8a8dbc5efcc3010d42e2804407a9dffa373ec 100644 (file)
@@ -996,7 +996,7 @@ bool dcn_validate_bandwidth(
                                        dc->debug.min_disp_clk_khz;
                }
 
-               context->bw.dcn.calc_clk.dppclk_div = (int)(v->dispclk_dppclk_ratio) == 2;
+               context->bw.dcn.calc_clk.max_dppclk_khz = (int)(v->dppclk * 1000);
 
                for (i = 0, input_idx = 0; i < pool->pipe_count; i++) {
                        struct pipe_ctx *pipe = &context->res_ctx.pipe_ctx[i];
index 1babac07bcc9eaee38651e179099d30f660996b4..c15565092ca8ab0023b92344e25845ec2755c45e 100644 (file)
@@ -361,21 +361,22 @@ void context_clock_trace(
        struct dc  *core_dc = dc;
        struct dal_logger *logger =  core_dc->ctx->logger;
 
-       CLOCK_TRACE("Current: dispclk_khz:%d  dppclk_div:%d  dcfclk_khz:%d\n"
-                       "dcfclk_deep_sleep_khz:%d  fclk_khz:%d\n"
+       CLOCK_TRACE("Current: dispclk_khz:%d  max_dppclk_khz:%d  dcfclk_khz:%d\n"
+                       "dcfclk_deep_sleep_khz:%d  fclk_khz:%d  socclk_khz:%d\n"
                        "dram_ccm_us:%d  min_active_dram_ccm_us:%d\n",
                        context->bw.dcn.calc_clk.dispclk_khz,
-                       context->bw.dcn.calc_clk.dppclk_div,
+                       context->bw.dcn.calc_clk.max_dppclk_khz,
                        context->bw.dcn.calc_clk.dcfclk_khz,
                        context->bw.dcn.calc_clk.dcfclk_deep_sleep_khz,
                        context->bw.dcn.calc_clk.fclk_khz,
+                       context->bw.dcn.calc_clk.socclk_khz,
                        context->bw.dcn.calc_clk.dram_ccm_us,
                        context->bw.dcn.calc_clk.min_active_dram_ccm_us);
-       CLOCK_TRACE("Calculated: dispclk_khz:%d  dppclk_div:%d  dcfclk_khz:%d\n"
-                       "dcfclk_deep_sleep_khz:%d  fclk_khz:%d\n"
+       CLOCK_TRACE("Calculated: dispclk_khz:%d  max_dppclk_khz:%d  dcfclk_khz:%d\n"
+                       "dcfclk_deep_sleep_khz:%d  fclk_khz:%d  socclk_khz:%d\n"
                        "dram_ccm_us:%d  min_active_dram_ccm_us:%d\n",
                        context->bw.dcn.calc_clk.dispclk_khz,
-                       context->bw.dcn.calc_clk.dppclk_div,
+                       context->bw.dcn.calc_clk.max_dppclk_khz,
                        context->bw.dcn.calc_clk.dcfclk_khz,
                        context->bw.dcn.calc_clk.dcfclk_deep_sleep_khz,
                        context->bw.dcn.calc_clk.fclk_khz,
index 8725cab9ec001db25a37ee899bfad51cd55ff377..f0b798930b515ece1210b7529a2594355ce42fd7 100644 (file)
@@ -432,14 +432,12 @@ void dpp1_dppclk_control(
        struct dcn10_dpp *dpp = TO_DCN10_DPP(dpp_base);
 
        if (enable) {
-               if (dpp->tf_mask->DPPCLK_RATE_CONTROL) {
+               if (dpp->tf_mask->DPPCLK_RATE_CONTROL)
                        REG_UPDATE_2(DPP_CONTROL,
                                DPPCLK_RATE_CONTROL, dppclk_div,
                                DPP_CLOCK_ENABLE, 1);
-               } else {
-                       ASSERT(dppclk_div == false);
+               else
                        REG_UPDATE(DPP_CONTROL, DPP_CLOCK_ENABLE, 1);
-               }
        } else
                REG_UPDATE(DPP_CONTROL, DPP_CLOCK_ENABLE, 0);
 }
index 7a1b2deaf3d76fb7dcbf54cab8428c80c1f27be6..759e925439cee762b9a6580e4a6e3971fb8b27a3 100644 (file)
@@ -1684,12 +1684,13 @@ static void update_dchubp_dpp(
        if (plane_state->update_flags.bits.full_update) {
                dpp->funcs->dpp_dppclk_control(
                                dpp,
-                               context->bw.dcn.calc_clk.dppclk_div,
+                               context->bw.dcn.calc_clk.max_dppclk_khz <
+                                               context->bw.dcn.calc_clk.dispclk_khz,
                                true);
 
-               dc->current_state->bw.dcn.cur_clk.dppclk_div =
-                               context->bw.dcn.calc_clk.dppclk_div;
-               context->bw.dcn.cur_clk.dppclk_div = context->bw.dcn.calc_clk.dppclk_div;
+               dc->current_state->bw.dcn.cur_clk.max_dppclk_khz =
+                               context->bw.dcn.calc_clk.max_dppclk_khz;
+               context->bw.dcn.cur_clk.max_dppclk_khz = context->bw.dcn.calc_clk.max_dppclk_khz;
        }
 
        /* TODO: Need input parameter to tell current DCHUB pipe tie to which OTG
index 5509e13e7edfa8272005663eca98cb00bffbdcfd..a9b21a4a0c170a5ee51d5c2896f715f24bb9ac55 100644 (file)
@@ -177,6 +177,15 @@ struct resource_pool {
        const struct resource_caps *res_cap;
 };
 
+struct dcn_fe_clocks {
+       int dppclk_khz;
+};
+
+struct dcn_fe_bandwidth {
+       struct dcn_fe_clocks calc;
+       struct dcn_fe_clocks cur;
+};
+
 struct stream_resource {
        struct output_pixel_processor *opp;
        struct timing_generator *tg;
@@ -195,6 +204,8 @@ struct plane_resource {
        struct transform *xfm;
        struct dpp *dpp;
        uint8_t mpcc_inst;
+
+       struct dcn_fe_bandwidth bw;
 };
 
 struct pipe_ctx {
@@ -247,9 +258,9 @@ struct dce_bw_output {
 
 struct dcn_bw_clocks {
        int dispclk_khz;
-       int dppclk_khz;
-       bool dppclk_div;
+       int max_dppclk_khz;
        int dcfclk_khz;
+       int socclk_khz;
        int dcfclk_deep_sleep_khz;
        int fclk_khz;
        int dram_ccm_us;