[PATCH v1 3/6] drm/mediatek: mtk_dpi: Use an array for pixclk factor calculation
CK Hu (胡俊光)
ck.hu at mediatek.com
Thu Nov 21 19:54:24 PST 2024
Hi, Angelo:
On Wed, 2024-11-20 at 13:44 +0100, AngeloGioacchino Del Regno wrote:
> External email : Please do not click links or open attachments until you have verified the sender or the content.
>
>
> Setting the TVD PLL clock requires to multiply the target pixel
> clock by a specific constant factor to achieve the target PLL
> frequency, and this is done to reduce jitter to acceptable levels.
>
> On all MediaTek SoCs, the factor is not retrieved by any real kind
> of calculation but rather by checking if the target pixel clock
> is less than a specified frequency, hence assigning a function
> pointer for just a bunch of if branches does enlarge the code
> size for little reason.
>
> Remove all SoC-specific functions, add a structure `mtk_dpi_factor`
> that holds a clock frequency and corresponding PLL factor, and
> declare the constraints for each SoC in form of an array of said
> structure.
> Instead of function pointers, this structure (and its size) is then
> assigned to each SoC's platform data.
>
> The "calculation" is then performed with a new static function
> mtk_dpi_calculate_factor(dpi, mode_clk) that iterates through all
> of the entries of the aforementioned array and returns the right
> factor.
>
> If no factor is found, the lowest possible factor is returned,
> mimicking the same flow as all of the old per-SoC calculation
> functions.
>
> This commit brings no functional change.
Reviewed-by: CK Hu <ck.hu at mediatek.com>
>
> Signed-off-by: AngeloGioacchino Del Regno <angelogioacchino.delregno at collabora.com>
> ---
> drivers/gpu/drm/mediatek/mtk_dpi.c | 103 +++++++++++++++--------------
> 1 file changed, 52 insertions(+), 51 deletions(-)
>
> diff --git a/drivers/gpu/drm/mediatek/mtk_dpi.c b/drivers/gpu/drm/mediatek/mtk_dpi.c
> index c7143184e5de..9f59ee679ce1 100644
> --- a/drivers/gpu/drm/mediatek/mtk_dpi.c
> +++ b/drivers/gpu/drm/mediatek/mtk_dpi.c
> @@ -117,9 +117,15 @@ struct mtk_dpi_yc_limit {
> u16 c_bottom;
> };
>
> +struct mtk_dpi_factor {
> + u32 clock;
> + u8 factor;
> +};
> +
> /**
> * struct mtk_dpi_conf - Configuration of mediatek dpi.
> - * @cal_factor: Callback function to calculate factor value.
> + * @dpi_factor: SoC-specific pixel clock PLL factor values.
> + * @num_dpi_factor: Number of pixel clock PLL factor values.
> * @reg_h_fre_con: Register address of frequency control.
> * @max_clock_khz: Max clock frequency supported for this SoCs in khz units.
> * @edge_sel_en: Enable of edge selection.
> @@ -140,7 +146,8 @@ struct mtk_dpi_yc_limit {
> * @edge_cfg_in_mmsys: If the edge configuration for DPI's output needs to be set in MMSYS.
> */
> struct mtk_dpi_conf {
> - unsigned int (*cal_factor)(int clock);
> + const struct mtk_dpi_factor *dpi_factor;
> + const u8 num_dpi_factor;
> u32 reg_h_fre_con;
> u32 max_clock_khz;
> bool edge_sel_en;
> @@ -515,6 +522,20 @@ static int mtk_dpi_power_on(struct mtk_dpi *dpi)
> return ret;
> }
>
> +static unsigned int mtk_dpi_calculate_factor(struct mtk_dpi *dpi, int mode_clk)
> +{
> + const struct mtk_dpi_factor *dpi_factor = dpi->conf->dpi_factor;
> + int i;
> +
> + for (i = 0; i < dpi->conf->num_dpi_factor; i++) {
> + if (mode_clk <= dpi_factor[i].clock)
> + return dpi_factor[i].factor;
> + }
> +
> + /* If no match try the lowest possible factor */
> + return dpi_factor[dpi->conf->num_dpi_factor - 1].factor;
> +}
> +
> static int mtk_dpi_set_display_mode(struct mtk_dpi *dpi,
> struct drm_display_mode *mode)
> {
> @@ -529,7 +550,7 @@ static int mtk_dpi_set_display_mode(struct mtk_dpi *dpi,
> unsigned int factor;
>
> /* let pll_rate can fix the valid range of tvdpll (1G~2GHz) */
> - factor = dpi->conf->cal_factor(mode->clock);
> + factor = mtk_dpi_calculate_factor(dpi, mode_clk);
> drm_display_mode_to_videomode(mode, &vm);
> pll_rate = vm.pixelclock * factor;
>
> @@ -964,48 +985,6 @@ static const struct component_ops mtk_dpi_component_ops = {
> .unbind = mtk_dpi_unbind,
> };
>
> -static unsigned int mt8173_calculate_factor(int clock)
> -{
> - if (clock <= 27000)
> - return 3 << 4;
> - else if (clock <= 84000)
> - return 3 << 3;
> - else if (clock <= 167000)
> - return 3 << 2;
> - else
> - return 3 << 1;
> -}
> -
> -static unsigned int mt2701_calculate_factor(int clock)
> -{
> - if (clock <= 64000)
> - return 4;
> - else if (clock <= 128000)
> - return 2;
> - else
> - return 1;
> -}
> -
> -static unsigned int mt8183_calculate_factor(int clock)
> -{
> - if (clock <= 27000)
> - return 8;
> - else if (clock <= 167000)
> - return 4;
> - else
> - return 2;
> -}
> -
> -static unsigned int mt8195_dpintf_calculate_factor(int clock)
> -{
> - if (clock < 70000)
> - return 4;
> - else if (clock < 200000)
> - return 2;
> - else
> - return 1;
> -}
> -
> static const u32 mt8173_output_fmts[] = {
> MEDIA_BUS_FMT_RGB888_1X24,
> };
> @@ -1020,8 +999,25 @@ static const u32 mt8195_output_fmts[] = {
> MEDIA_BUS_FMT_YUYV8_1X16,
> };
>
> +static const struct mtk_dpi_factor dpi_factor_mt2701[] = {
> + { 64000, 4 }, { 128000, 2 }, { U32_MAX, 1 }
> +};
> +
> +static const struct mtk_dpi_factor dpi_factor_mt8173[] = {
> + { 27000, 48 }, { 84000, 24 }, { 167000, 12 }, { U32_MAX, 6 }
> +};
> +
> +static const struct mtk_dpi_factor dpi_factor_mt8183[] = {
> + { 27000, 8 }, { 167000, 4 }, { U32_MAX, 2 }
> +};
> +
> +static const struct mtk_dpi_factor dpi_factor_mt8195_dp_intf[] = {
> + { 70000 - 1, 4 }, { 200000 - 1, 2 }, { U32_MAX, 1 }
> +};
> +
> static const struct mtk_dpi_conf mt8173_conf = {
> - .cal_factor = mt8173_calculate_factor,
> + .dpi_factor = dpi_factor_mt8173,
> + .num_dpi_factor = ARRAY_SIZE(dpi_factor_mt8173),
> .reg_h_fre_con = 0xe0,
> .max_clock_khz = 300000,
> .output_fmts = mt8173_output_fmts,
> @@ -1038,7 +1034,8 @@ static const struct mtk_dpi_conf mt8173_conf = {
> };
>
> static const struct mtk_dpi_conf mt2701_conf = {
> - .cal_factor = mt2701_calculate_factor,
> + .dpi_factor = dpi_factor_mt2701,
> + .num_dpi_factor = ARRAY_SIZE(dpi_factor_mt2701),
> .reg_h_fre_con = 0xb0,
> .edge_sel_en = true,
> .max_clock_khz = 150000,
> @@ -1056,7 +1053,8 @@ static const struct mtk_dpi_conf mt2701_conf = {
> };
>
> static const struct mtk_dpi_conf mt8183_conf = {
> - .cal_factor = mt8183_calculate_factor,
> + .dpi_factor = dpi_factor_mt8183,
> + .num_dpi_factor = ARRAY_SIZE(dpi_factor_mt8183),
> .reg_h_fre_con = 0xe0,
> .max_clock_khz = 100000,
> .output_fmts = mt8183_output_fmts,
> @@ -1073,7 +1071,8 @@ static const struct mtk_dpi_conf mt8183_conf = {
> };
>
> static const struct mtk_dpi_conf mt8186_conf = {
> - .cal_factor = mt8183_calculate_factor,
> + .dpi_factor = dpi_factor_mt8183,
> + .num_dpi_factor = ARRAY_SIZE(dpi_factor_mt8183),
> .reg_h_fre_con = 0xe0,
> .max_clock_khz = 150000,
> .output_fmts = mt8183_output_fmts,
> @@ -1091,7 +1090,8 @@ static const struct mtk_dpi_conf mt8186_conf = {
> };
>
> static const struct mtk_dpi_conf mt8192_conf = {
> - .cal_factor = mt8183_calculate_factor,
> + .dpi_factor = dpi_factor_mt8183,
> + .num_dpi_factor = ARRAY_SIZE(dpi_factor_mt8183),
> .reg_h_fre_con = 0xe0,
> .max_clock_khz = 150000,
> .output_fmts = mt8183_output_fmts,
> @@ -1108,7 +1108,8 @@ static const struct mtk_dpi_conf mt8192_conf = {
> };
>
> static const struct mtk_dpi_conf mt8195_dpintf_conf = {
> - .cal_factor = mt8195_dpintf_calculate_factor,
> + .dpi_factor = dpi_factor_mt8195_dp_intf,
> + .num_dpi_factor = ARRAY_SIZE(dpi_factor_mt8195_dp_intf),
> .max_clock_khz = 600000,
> .output_fmts = mt8195_output_fmts,
> .num_output_fmts = ARRAY_SIZE(mt8195_output_fmts),
> --
> 2.47.0
>
More information about the Linux-mediatek
mailing list