Lines Matching full:pll
11 #include "clk-cv18xx-pll.h"
36 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in ipll_recalc_rate() local
39 value = readl(pll->common.base + pll->pll_reg); in ipll_recalc_rate()
91 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in ipll_determine_rate() local
93 return ipll_find_rate(pll->pll_limit, req->best_parent_rate, in ipll_determine_rate()
135 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in ipll_set_rate() local
137 ipll_find_rate(pll->pll_limit, parent_rate, &rate, &detected); in ipll_set_rate()
140 pll->pll_limit, &detected); in ipll_set_rate()
142 spin_lock_irqsave(pll->common.lock, flags); in ipll_set_rate()
144 regval = readl(pll->common.base + pll->pll_reg); in ipll_set_rate()
147 writel(regval, pll->common.base + pll->pll_reg); in ipll_set_rate()
149 spin_unlock_irqrestore(pll->common.lock, flags); in ipll_set_rate()
151 cv1800_clk_wait_for_lock(&pll->common, pll->pll_status.reg, in ipll_set_rate()
152 BIT(pll->pll_status.shift)); in ipll_set_rate()
159 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in pll_enable() local
161 return cv1800_clk_clearbit(&pll->common, &pll->pll_pwd); in pll_enable()
166 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in pll_disable() local
168 cv1800_clk_setbit(&pll->common, &pll->pll_pwd); in pll_disable()
173 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in pll_is_enable() local
175 return cv1800_clk_checkbit(&pll->common, &pll->pll_pwd) == 0; in pll_is_enable()
191 static bool fpll_is_factional_mode(struct cv1800_clk_pll *pll) in fpll_is_factional_mode() argument
193 return cv1800_clk_checkbit(&pll->common, &pll->pll_syn->en); in fpll_is_factional_mode()
223 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in fpll_recalc_rate() local
228 if (!fpll_is_factional_mode(pll)) in fpll_recalc_rate()
231 syn_set = readl(pll->common.base + pll->pll_syn->set); in fpll_recalc_rate()
236 clk_full = cv1800_clk_checkbit(&pll->common, in fpll_recalc_rate()
237 &pll->pll_syn->clk_half); in fpll_recalc_rate()
239 value = readl(pll->common.base + pll->pll_reg); in fpll_recalc_rate()
282 static int fpll_find_rate(struct cv1800_clk_pll *pll, in fpll_find_rate() argument
294 bool clk_full = cv1800_clk_checkbit(&pll->common, in fpll_find_rate()
295 &pll->pll_syn->clk_half); in fpll_find_rate()
329 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in fpll_determine_rate() local
332 if (!fpll_is_factional_mode(pll)) in fpll_determine_rate()
335 fpll_find_rate(pll, &pll->pll_limit[2], req->best_parent_rate, in fpll_determine_rate()
358 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in fpll_set_rate() local
360 if (!fpll_is_factional_mode(pll)) in fpll_set_rate()
363 fpll_find_rate(pll, &pll->pll_limit[2], parent_rate, in fpll_set_rate()
367 pll->pll_limit, &detected); in fpll_set_rate()
369 spin_lock_irqsave(pll->common.lock, flags); in fpll_set_rate()
371 writel(detected_ssc, pll->common.base + pll->pll_syn->set); in fpll_set_rate()
373 regval = readl(pll->common.base + pll->pll_reg); in fpll_set_rate()
376 writel(regval, pll->common.base + pll->pll_reg); in fpll_set_rate()
378 spin_unlock_irqrestore(pll->common.lock, flags); in fpll_set_rate()
380 cv1800_clk_wait_for_lock(&pll->common, pll->pll_status.reg, in fpll_set_rate()
381 BIT(pll->pll_status.shift)); in fpll_set_rate()
388 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in fpll_get_parent() local
390 if (fpll_is_factional_mode(pll)) in fpll_get_parent()
398 struct cv1800_clk_pll *pll = hw_to_cv1800_clk_pll(hw); in fpll_set_parent() local
401 cv1800_clk_setbit(&pll->common, &pll->pll_syn->en); in fpll_set_parent()
403 cv1800_clk_clearbit(&pll->common, &pll->pll_syn->en); in fpll_set_parent()