]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
media: ccs-pll: Correct the upper limit of maximum op_pre_pll_clk_div
authorSakari Ailus <sakari.ailus@linux.intel.com>
Wed, 19 Feb 2025 13:06:11 +0000 (15:06 +0200)
committerHans Verkuil <hverkuil@xs4all.nl>
Fri, 25 Apr 2025 08:15:15 +0000 (10:15 +0200)
The PLL calculator does a search of the PLL configuration space for all
valid OP pre-PLL clock dividers. The maximum did not take into account the
CCS PLL flag CCS_PLL_FLAG_EXT_IP_PLL_DIVIDER in which case also odd PLL
dividers (other than 1) are valid. Do that now.

Fixes: 4e1e8d240dff ("media: ccs-pll: Add support for extended input PLL clock divider")
Cc: stable@vger.kernel.org
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: Hans Verkuil <hverkuil@xs4all.nl>
drivers/media/i2c/ccs-pll.c

index 266fcd160da6ef127451d0eb981736951753aa7b..d985686b0a36bdfe15102a4ccb25c9cf85137603 100644 (file)
@@ -799,7 +799,7 @@ int ccs_pll_calculate(struct device *dev, const struct ccs_pll_limits *lim,
                op_lim_fr->min_pre_pll_clk_div, op_lim_fr->max_pre_pll_clk_div);
        max_op_pre_pll_clk_div =
                min_t(u16, op_lim_fr->max_pre_pll_clk_div,
-                     clk_div_even(pll->ext_clk_freq_hz /
+                     DIV_ROUND_UP(pll->ext_clk_freq_hz,
                                   op_lim_fr->min_pll_ip_clk_freq_hz));
        min_op_pre_pll_clk_div =
                max_t(u16, op_lim_fr->min_pre_pll_clk_div,