• Home
  • Raw
  • Download

Lines Matching +full:fixed +full:- +full:clock

1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (C) 2010-2011 Canonical Ltd <jeremy.kerr@canonical.com>
4 * Copyright (C) 2011-2012 Mike Turquette, Linaro Ltd <mturquette@linaro.org>
6 * Fixed rate clock implementation
9 #include <linux/clk-provider.h>
18 * DOC: basic fixed-rate clock that cannot gate
20 * Traits of this clock:
21 * prepare - clk_(un)prepare only ensures parents are prepared
22 * enable - clk_enable only ensures parents are enabled
23 * rate - rate is always a fixed value. No clk_set_rate support
24 * parent - fixed parent. No clk_set_parent support
32 return to_clk_fixed_rate(hw)->fixed_rate; in clk_fixed_rate_recalc_rate()
38 struct clk_fixed_rate *fixed = to_clk_fixed_rate(hw); in clk_fixed_rate_recalc_accuracy() local
40 if (fixed->flags & CLK_FIXED_RATE_PARENT_ACCURACY) in clk_fixed_rate_recalc_accuracy()
43 return fixed->fixed_accuracy; in clk_fixed_rate_recalc_accuracy()
59 struct clk_fixed_rate *fixed; in __clk_hw_register_fixed_rate() local
62 int ret = -EINVAL; in __clk_hw_register_fixed_rate()
64 /* allocate fixed-rate clock */ in __clk_hw_register_fixed_rate()
65 fixed = kzalloc(sizeof(*fixed), GFP_KERNEL); in __clk_hw_register_fixed_rate()
66 if (!fixed) in __clk_hw_register_fixed_rate()
67 return ERR_PTR(-ENOMEM); in __clk_hw_register_fixed_rate()
81 fixed->flags = clk_fixed_flags; in __clk_hw_register_fixed_rate()
82 fixed->fixed_rate = fixed_rate; in __clk_hw_register_fixed_rate()
83 fixed->fixed_accuracy = fixed_accuracy; in __clk_hw_register_fixed_rate()
84 fixed->hw.init = &init; in __clk_hw_register_fixed_rate()
86 /* register the clock */ in __clk_hw_register_fixed_rate()
87 hw = &fixed->hw; in __clk_hw_register_fixed_rate()
93 kfree(fixed); in __clk_hw_register_fixed_rate()
111 return hw->clk; in clk_register_fixed_rate()
130 struct clk_fixed_rate *fixed; in clk_hw_unregister_fixed_rate() local
132 fixed = to_clk_fixed_rate(hw); in clk_hw_unregister_fixed_rate()
135 kfree(fixed); in clk_hw_unregister_fixed_rate()
143 const char *clk_name = node->name; in _of_fixed_clk_setup()
148 if (of_property_read_u32(node, "clock-frequency", &rate)) in _of_fixed_clk_setup()
149 return ERR_PTR(-EIO); in _of_fixed_clk_setup()
151 of_property_read_u32(node, "clock-accuracy", &accuracy); in _of_fixed_clk_setup()
153 of_property_read_string(node, "clock-output-names", &clk_name); in _of_fixed_clk_setup()
170 * of_fixed_clk_setup() - Setup function for simple fixed rate clock
171 * @node: device node for the clock
177 CLK_OF_DECLARE(fixed_clk, "fixed-clock", of_fixed_clk_setup);
183 of_clk_del_provider(pdev->dev.of_node); in of_fixed_clk_remove()
197 hw = _of_fixed_clk_setup(pdev->dev.of_node); in of_fixed_clk_probe()
207 { .compatible = "fixed-clock" },