clk: ti: dpll: add support for specifying max rate for DPLLs

DPLLs typically have a maximum rate they can support, and this varies
from DPLL to DPLL. Add support of the maximum rate value to the DPLL
data struct, and also add check for this in the DPLL round_rate function.

Signed-off-by: Tero Kristo <t-kristo@ti.com>
Reviewed-by: Nishanth Menon <nm@ti.com>
Cc: Tomi Valkeinen <tomi.valkeinen@ti.com>
Cc: Lokesh Vutla <lokeshvutla@ti.com>
Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
This commit is contained in:
Tero Kristo 2016-03-16 21:54:55 +02:00 committed by Stephen Boyd
parent fefe0535b7
commit c5cc2a0bc9
2 changed files with 5 additions and 0 deletions

View File

@ -301,6 +301,9 @@ long omap2_dpll_round_rate(struct clk_hw *hw, unsigned long target_rate,
dd = clk->dpll_data; dd = clk->dpll_data;
if (dd->max_rate && target_rate > dd->max_rate)
target_rate = dd->max_rate;
ref_rate = clk_hw_get_rate(dd->clk_ref); ref_rate = clk_hw_get_rate(dd->clk_ref);
clk_name = clk_hw_get_name(hw); clk_name = clk_hw_get_name(hw);
pr_debug("clock: %s: starting DPLL round_rate, target rate %lu\n", pr_debug("clock: %s: starting DPLL round_rate, target rate %lu\n",

View File

@ -37,6 +37,7 @@
* @last_rounded_n: cache of the last N result of omap2_dpll_round_rate() * @last_rounded_n: cache of the last N result of omap2_dpll_round_rate()
* @min_divider: minimum valid non-bypass divider value (actual) * @min_divider: minimum valid non-bypass divider value (actual)
* @max_divider: maximum valid non-bypass divider value (actual) * @max_divider: maximum valid non-bypass divider value (actual)
* @max_rate: maximum clock rate for the DPLL
* @modes: possible values of @enable_mask * @modes: possible values of @enable_mask
* @autoidle_reg: register containing the DPLL autoidle mode bitfield * @autoidle_reg: register containing the DPLL autoidle mode bitfield
* @idlest_reg: register containing the DPLL idle status bitfield * @idlest_reg: register containing the DPLL idle status bitfield
@ -81,6 +82,7 @@ struct dpll_data {
u8 last_rounded_n; u8 last_rounded_n;
u8 min_divider; u8 min_divider;
u16 max_divider; u16 max_divider;
unsigned long max_rate;
u8 modes; u8 modes;
void __iomem *autoidle_reg; void __iomem *autoidle_reg;
void __iomem *idlest_reg; void __iomem *idlest_reg;