Lines Matching +full:pll +full:- +full:mode

1 // SPDX-License-Identifier: GPL-2.0
3 * Zynq UltraScale+ MPSoC PLL driver
5 * Copyright (C) 2016-2018 Xilinx
9 #include <linux/clk-provider.h>
11 #include "clk-zynqmp.h"
14 * struct zynqmp_pll - PLL clock
15 * @hw: Handle between common and hardware-specific interfaces
16 * @clk_id: PLL clock ID
44 * zynqmp_pll_get_mode() - Get mode of PLL
45 * @hw: Handle between common and hardware-specific interfaces
47 * Return: Mode of PLL
52 u32 clk_id = clk->clk_id; in zynqmp_pll_get_mode()
59 pr_debug("%s() PLL get frac mode failed for %s, ret = %d\n", in zynqmp_pll_get_mode()
68 * zynqmp_pll_set_mode() - Set the PLL mode
69 * @hw: Handle between common and hardware-specific interfaces
70 * @on: Flag to determine the mode
75 u32 clk_id = clk->clk_id; in zynqmp_pll_set_mode()
78 u32 mode; in zynqmp_pll_set_mode() local
81 mode = PLL_MODE_FRAC; in zynqmp_pll_set_mode()
83 mode = PLL_MODE_INT; in zynqmp_pll_set_mode()
85 ret = zynqmp_pm_set_pll_frac_mode(clk_id, mode); in zynqmp_pll_set_mode()
87 pr_debug("%s() PLL set frac mode failed for %s, ret = %d\n", in zynqmp_pll_set_mode()
90 clk->set_pll_mode = true; in zynqmp_pll_set_mode()
94 * zynqmp_pll_round_rate() - Round a clock frequency
95 * @hw: Handle between common and hardware-specific interfaces
127 * zynqmp_pll_recalc_rate() - Recalculate clock frequency
128 * @hw: Handle between common and hardware-specific interfaces
137 u32 clk_id = clk->clk_id; in zynqmp_pll_recalc_rate()
143 enum pll_mode mode; in zynqmp_pll_recalc_rate() local
152 mode = zynqmp_pll_get_mode(hw); in zynqmp_pll_recalc_rate()
153 if (mode == PLL_MODE_ERROR) in zynqmp_pll_recalc_rate()
157 if (mode == PLL_MODE_FRAC) { in zynqmp_pll_recalc_rate()
168 * zynqmp_pll_set_rate() - Set rate of PLL
169 * @hw: Handle between common and hardware-specific interfaces
173 * Set PLL divider to set desired rate.
181 u32 clk_id = clk->clk_id; in zynqmp_pll_set_rate()
198 if (ret == -EUSERS) in zynqmp_pll_set_rate()
220 * zynqmp_pll_is_enabled() - Check if a clock is enabled
221 * @hw: Handle between common and hardware-specific interfaces
229 u32 clk_id = clk->clk_id; in zynqmp_pll_is_enabled()
237 return -EIO; in zynqmp_pll_is_enabled()
244 * zynqmp_pll_enable() - Enable clock
245 * @hw: Handle between common and hardware-specific interfaces
253 u32 clk_id = clk->clk_id; in zynqmp_pll_enable()
260 if (zynqmp_pll_is_enabled(hw) && (!clk->set_pll_mode)) in zynqmp_pll_enable()
263 clk->set_pll_mode = false; in zynqmp_pll_enable()
274 * zynqmp_pll_disable() - Disable clock
275 * @hw: Handle between common and hardware-specific interfaces
281 u32 clk_id = clk->clk_id; in zynqmp_pll_disable()
303 * zynqmp_clk_register_pll() - Register PLL with the clock framework
304 * @name: PLL name
317 struct zynqmp_pll *pll; in zynqmp_clk_register_pll() local
325 init.flags = zynqmp_clk_map_common_ccf_flags(nodes->flag); in zynqmp_clk_register_pll()
330 pll = kzalloc(sizeof(*pll), GFP_KERNEL); in zynqmp_clk_register_pll()
331 if (!pll) in zynqmp_clk_register_pll()
332 return ERR_PTR(-ENOMEM); in zynqmp_clk_register_pll()
334 pll->hw.init = &init; in zynqmp_clk_register_pll()
335 pll->clk_id = clk_id; in zynqmp_clk_register_pll()
337 hw = &pll->hw; in zynqmp_clk_register_pll()
340 kfree(pll); in zynqmp_clk_register_pll()