Commit b07971d4 authored by Dmytro Laktyushkin's avatar Dmytro Laktyushkin Committed by Alex Deucher

drm/amd/display: stop using switch for different CS revisions

Clock sources currently have support for asic specific
function pointers. But actual separation into functions
was never performed, leaving us with giant functions that
rely on switch.

This change creates separate functions, removing switch use.
Signed-off-by: default avatarDmytro Laktyushkin <Dmytro.Laktyushkin@amd.com>
Reviewed-by: default avatarTony Cheng <Tony.Cheng@amd.com>
Acked-by: default avatarLeo Li <sunpeng.li@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent d77f778e
...@@ -584,34 +584,42 @@ static uint32_t dce110_get_pix_clk_dividers( ...@@ -584,34 +584,42 @@ static uint32_t dce110_get_pix_clk_dividers(
return 0; return 0;
} }
switch (cs->ctx->dce_version) { pll_calc_error = dce110_get_pix_clk_dividers_helper(clk_src,
case DCE_VERSION_8_0:
case DCE_VERSION_8_1:
case DCE_VERSION_8_3:
case DCE_VERSION_10_0:
case DCE_VERSION_11_0:
pll_calc_error =
dce110_get_pix_clk_dividers_helper(clk_src,
pll_settings, pix_clk_params); pll_settings, pix_clk_params);
break;
case DCE_VERSION_11_2:
case DCE_VERSION_11_22:
case DCE_VERSION_12_0:
#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
case DCN_VERSION_1_0:
#endif
#if defined(CONFIG_DRM_AMD_DC_DCN1_01) return pll_calc_error;
case DCN_VERSION_1_01: }
#endif
static uint32_t dce112_get_pix_clk_dividers(
struct clock_source *cs,
struct pixel_clk_params *pix_clk_params,
struct pll_settings *pll_settings)
{
struct dce110_clk_src *clk_src = TO_DCE110_CLK_SRC(cs);
DC_LOGGER_INIT();
if (pix_clk_params == NULL || pll_settings == NULL
|| pix_clk_params->requested_pix_clk == 0) {
DC_LOG_ERROR(
"%s: Invalid parameters!!\n", __func__);
return -1;
}
memset(pll_settings, 0, sizeof(*pll_settings));
if (cs->id == CLOCK_SOURCE_ID_DP_DTO ||
cs->id == CLOCK_SOURCE_ID_EXTERNAL) {
pll_settings->adjusted_pix_clk = clk_src->ext_clk_khz;
pll_settings->calculated_pix_clk = clk_src->ext_clk_khz;
pll_settings->actual_pix_clk =
pix_clk_params->requested_pix_clk;
return -1;
}
dce112_get_pix_clk_dividers_helper(clk_src, dce112_get_pix_clk_dividers_helper(clk_src,
pll_settings, pix_clk_params); pll_settings, pix_clk_params);
break;
default:
break;
}
return pll_calc_error; return 0;
} }
static bool disable_spread_spectrum(struct dce110_clk_src *clk_src) static bool disable_spread_spectrum(struct dce110_clk_src *clk_src)
...@@ -833,21 +841,6 @@ static bool dce110_program_pix_clk( ...@@ -833,21 +841,6 @@ static bool dce110_program_pix_clk(
struct dce110_clk_src *clk_src = TO_DCE110_CLK_SRC(clock_source); struct dce110_clk_src *clk_src = TO_DCE110_CLK_SRC(clock_source);
struct bp_pixel_clock_parameters bp_pc_params = {0}; struct bp_pixel_clock_parameters bp_pc_params = {0};
#if defined(CONFIG_DRM_AMD_DC_DCN1_0)
if (IS_FPGA_MAXIMUS_DC(clock_source->ctx->dce_environment)) {
unsigned int inst = pix_clk_params->controller_id - CONTROLLER_ID_D0;
unsigned dp_dto_ref_kHz = 700000;
unsigned clock_kHz = pll_settings->actual_pix_clk;
/* Set DTO values: phase = target clock, modulo = reference clock */
REG_WRITE(PHASE[inst], clock_kHz);
REG_WRITE(MODULO[inst], dp_dto_ref_kHz);
/* Enable DTO */
REG_UPDATE(PIXEL_RATE_CNTL[inst], DP_DTO0_ENABLE, 1);
return true;
}
#endif
/* First disable SS /* First disable SS
* ATOMBIOS will enable by default SS on PLL for DP, * ATOMBIOS will enable by default SS on PLL for DP,
* do not disable it here * do not disable it here
...@@ -864,12 +857,6 @@ static bool dce110_program_pix_clk( ...@@ -864,12 +857,6 @@ static bool dce110_program_pix_clk(
bp_pc_params.encoder_object_id = pix_clk_params->encoder_object_id; bp_pc_params.encoder_object_id = pix_clk_params->encoder_object_id;
bp_pc_params.signal_type = pix_clk_params->signal_type; bp_pc_params.signal_type = pix_clk_params->signal_type;
switch (clock_source->ctx->dce_version) {
case DCE_VERSION_8_0:
case DCE_VERSION_8_1:
case DCE_VERSION_8_3:
case DCE_VERSION_10_0:
case DCE_VERSION_11_0:
bp_pc_params.reference_divider = pll_settings->reference_divider; bp_pc_params.reference_divider = pll_settings->reference_divider;
bp_pc_params.feedback_divider = pll_settings->feedback_divider; bp_pc_params.feedback_divider = pll_settings->feedback_divider;
bp_pc_params.fractional_feedback_divider = bp_pc_params.fractional_feedback_divider =
...@@ -902,17 +889,47 @@ static bool dce110_program_pix_clk( ...@@ -902,17 +889,47 @@ static bool dce110_program_pix_clk(
pix_clk_params->color_depth); pix_clk_params->color_depth);
} }
break; return true;
case DCE_VERSION_11_2: }
case DCE_VERSION_11_22:
case DCE_VERSION_12_0: static bool dce112_program_pix_clk(
struct clock_source *clock_source,
struct pixel_clk_params *pix_clk_params,
struct pll_settings *pll_settings)
{
struct dce110_clk_src *clk_src = TO_DCE110_CLK_SRC(clock_source);
struct bp_pixel_clock_parameters bp_pc_params = {0};
#if defined(CONFIG_DRM_AMD_DC_DCN1_0) #if defined(CONFIG_DRM_AMD_DC_DCN1_0)
case DCN_VERSION_1_0: if (IS_FPGA_MAXIMUS_DC(clock_source->ctx->dce_environment)) {
#endif unsigned int inst = pix_clk_params->controller_id - CONTROLLER_ID_D0;
unsigned dp_dto_ref_kHz = 700000;
unsigned clock_kHz = pll_settings->actual_pix_clk;
/* Set DTO values: phase = target clock, modulo = reference clock */
REG_WRITE(PHASE[inst], clock_kHz);
REG_WRITE(MODULO[inst], dp_dto_ref_kHz);
#if defined(CONFIG_DRM_AMD_DC_DCN1_01) /* Enable DTO */
case DCN_VERSION_1_01: REG_UPDATE(PIXEL_RATE_CNTL[inst], DP_DTO0_ENABLE, 1);
return true;
}
#endif #endif
/* First disable SS
* ATOMBIOS will enable by default SS on PLL for DP,
* do not disable it here
*/
if (clock_source->id != CLOCK_SOURCE_ID_EXTERNAL &&
!dc_is_dp_signal(pix_clk_params->signal_type) &&
clock_source->ctx->dce_version <= DCE_VERSION_11_0)
disable_spread_spectrum(clk_src);
/*ATOMBIOS expects pixel rate adjusted by deep color ratio)*/
bp_pc_params.controller_id = pix_clk_params->controller_id;
bp_pc_params.pll_id = clock_source->id;
bp_pc_params.target_pixel_clock = pll_settings->actual_pix_clk;
bp_pc_params.encoder_object_id = pix_clk_params->encoder_object_id;
bp_pc_params.signal_type = pix_clk_params->signal_type;
if (clock_source->id != CLOCK_SOURCE_ID_DP_DTO) { if (clock_source->id != CLOCK_SOURCE_ID_DP_DTO) {
bp_pc_params.flags.SET_GENLOCK_REF_DIV_SRC = bp_pc_params.flags.SET_GENLOCK_REF_DIV_SRC =
...@@ -932,14 +949,11 @@ static bool dce110_program_pix_clk( ...@@ -932,14 +949,11 @@ static bool dce110_program_pix_clk(
pix_clk_params->signal_type, pix_clk_params->signal_type,
pix_clk_params->color_depth, pix_clk_params->color_depth,
pix_clk_params->flags.SUPPORT_YCBCR420); pix_clk_params->flags.SUPPORT_YCBCR420);
break;
default:
break;
}
return true; return true;
} }
static bool dce110_clock_source_power_down( static bool dce110_clock_source_power_down(
struct clock_source *clk_src) struct clock_source *clk_src)
{ {
...@@ -966,12 +980,19 @@ static bool dce110_clock_source_power_down( ...@@ -966,12 +980,19 @@ static bool dce110_clock_source_power_down(
/*****************************************/ /*****************************************/
/* Constructor */ /* Constructor */
/*****************************************/ /*****************************************/
static const struct clock_source_funcs dce112_clk_src_funcs = {
.cs_power_down = dce110_clock_source_power_down,
.program_pix_clk = dce112_program_pix_clk,
.get_pix_clk_dividers = dce112_get_pix_clk_dividers
};
static const struct clock_source_funcs dce110_clk_src_funcs = { static const struct clock_source_funcs dce110_clk_src_funcs = {
.cs_power_down = dce110_clock_source_power_down, .cs_power_down = dce110_clock_source_power_down,
.program_pix_clk = dce110_program_pix_clk, .program_pix_clk = dce110_program_pix_clk,
.get_pix_clk_dividers = dce110_get_pix_clk_dividers .get_pix_clk_dividers = dce110_get_pix_clk_dividers
}; };
static void get_ss_info_from_atombios( static void get_ss_info_from_atombios(
struct dce110_clk_src *clk_src, struct dce110_clk_src *clk_src,
enum as_signal_type as_signal, enum as_signal_type as_signal,
...@@ -1227,13 +1248,6 @@ bool dce110_clk_src_construct( ...@@ -1227,13 +1248,6 @@ bool dce110_clk_src_construct(
clk_src->ext_clk_khz = clk_src->ext_clk_khz =
fw_info.external_clock_source_frequency_for_dp; fw_info.external_clock_source_frequency_for_dp;
switch (clk_src->base.ctx->dce_version) {
case DCE_VERSION_8_0:
case DCE_VERSION_8_1:
case DCE_VERSION_8_3:
case DCE_VERSION_10_0:
case DCE_VERSION_11_0:
/* structure normally used with PLL ranges from ATOMBIOS; DS on by default */ /* structure normally used with PLL ranges from ATOMBIOS; DS on by default */
calc_pll_cs_init_data.bp = bios; calc_pll_cs_init_data.bp = bios;
calc_pll_cs_init_data.min_pix_clk_pll_post_divider = 1; calc_pll_cs_init_data.min_pix_clk_pll_post_divider = 1;
...@@ -1299,10 +1313,6 @@ bool dce110_clk_src_construct( ...@@ -1299,10 +1313,6 @@ bool dce110_clk_src_construct(
ASSERT_CRITICAL(false); ASSERT_CRITICAL(false);
goto unexpected_failure; goto unexpected_failure;
} }
break;
default:
break;
}
return true; return true;
...@@ -1310,3 +1320,34 @@ bool dce110_clk_src_construct( ...@@ -1310,3 +1320,34 @@ bool dce110_clk_src_construct(
return false; return false;
} }
bool dce112_clk_src_construct(
struct dce110_clk_src *clk_src,
struct dc_context *ctx,
struct dc_bios *bios,
enum clock_source_id id,
const struct dce110_clk_src_regs *regs,
const struct dce110_clk_src_shift *cs_shift,
const struct dce110_clk_src_mask *cs_mask)
{
struct dc_firmware_info fw_info = { { 0 } };
clk_src->base.ctx = ctx;
clk_src->bios = bios;
clk_src->base.id = id;
clk_src->base.funcs = &dce112_clk_src_funcs;
clk_src->regs = regs;
clk_src->cs_shift = cs_shift;
clk_src->cs_mask = cs_mask;
if (clk_src->bios->funcs->get_firmware_info(
clk_src->bios, &fw_info) != BP_RESULT_OK) {
ASSERT_CRITICAL(false);
return false;
}
clk_src->ext_clk_khz = fw_info.external_clock_source_frequency_for_dp;
return true;
}
...@@ -144,4 +144,13 @@ bool dce110_clk_src_construct( ...@@ -144,4 +144,13 @@ bool dce110_clk_src_construct(
const struct dce110_clk_src_shift *cs_shift, const struct dce110_clk_src_shift *cs_shift,
const struct dce110_clk_src_mask *cs_mask); const struct dce110_clk_src_mask *cs_mask);
bool dce112_clk_src_construct(
struct dce110_clk_src *clk_src,
struct dc_context *ctx,
struct dc_bios *bios,
enum clock_source_id id,
const struct dce110_clk_src_regs *regs,
const struct dce110_clk_src_shift *cs_shift,
const struct dce110_clk_src_mask *cs_mask);
#endif #endif
...@@ -670,7 +670,7 @@ struct clock_source *dce112_clock_source_create( ...@@ -670,7 +670,7 @@ struct clock_source *dce112_clock_source_create(
if (!clk_src) if (!clk_src)
return NULL; return NULL;
if (dce110_clk_src_construct(clk_src, ctx, bios, id, if (dce112_clk_src_construct(clk_src, ctx, bios, id,
regs, &cs_shift, &cs_mask)) { regs, &cs_shift, &cs_mask)) {
clk_src->base.dp_clk_src = dp_clk_src; clk_src->base.dp_clk_src = dp_clk_src;
return &clk_src->base; return &clk_src->base;
......
...@@ -456,7 +456,7 @@ struct clock_source *dce120_clock_source_create( ...@@ -456,7 +456,7 @@ struct clock_source *dce120_clock_source_create(
if (!clk_src) if (!clk_src)
return NULL; return NULL;
if (dce110_clk_src_construct(clk_src, ctx, bios, id, if (dce112_clk_src_construct(clk_src, ctx, bios, id,
regs, &cs_shift, &cs_mask)) { regs, &cs_shift, &cs_mask)) {
clk_src->base.dp_clk_src = dp_clk_src; clk_src->base.dp_clk_src = dp_clk_src;
return &clk_src->base; return &clk_src->base;
......
...@@ -749,7 +749,7 @@ struct clock_source *dcn10_clock_source_create( ...@@ -749,7 +749,7 @@ struct clock_source *dcn10_clock_source_create(
if (!clk_src) if (!clk_src)
return NULL; return NULL;
if (dce110_clk_src_construct(clk_src, ctx, bios, id, if (dce112_clk_src_construct(clk_src, ctx, bios, id,
regs, &cs_shift, &cs_mask)) { regs, &cs_shift, &cs_mask)) {
clk_src->base.dp_clk_src = dp_clk_src; clk_src->base.dp_clk_src = dp_clk_src;
return &clk_src->base; return &clk_src->base;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment