Lines Matching +full:comp +full:- +full:int

1 // SPDX-License-Identifier: GPL-2.0-only
7 * Tero Kristo <t-kristo@ti.com>
10 #include <linux/clk-provider.h>
32 return -EINVAL; in ti_composite_round_rate()
35 static int ti_composite_set_rate(struct clk_hw *hw, unsigned long rate, in ti_composite_set_rate()
38 return -EINVAL; in ti_composite_set_rate()
54 int num_parents;
57 int type;
68 static struct device_node *_get_component_node(struct device_node *node, int i) in _get_component_node()
70 int rc; in _get_component_node()
73 rc = of_parse_phandle_with_args(node, "clocks", "#clock-cells", i, in _get_component_node()
83 struct component_clk *comp; in _lookup_component() local
85 list_for_each_entry(comp, &component_clks, link) { in _lookup_component()
86 if (comp->node == node) in _lookup_component()
87 return comp; in _lookup_component()
98 static inline struct clk_hw *_get_hw(struct clk_hw_omap_comp *clk, int idx) in _get_hw()
103 if (!clk->comp_clks[idx]) in _get_hw()
106 return clk->comp_clks[idx]->hw; in _get_hw()
117 struct component_clk *comp; in _register_composite() local
118 int num_parents = 0; in _register_composite()
121 int i; in _register_composite()
122 int ret; in _register_composite()
126 if (!cclk->comp_nodes[i]) in _register_composite()
129 comp = _lookup_component(cclk->comp_nodes[i]); in _register_composite()
130 if (!comp) { in _register_composite()
132 cclk->comp_nodes[i]->name, node); in _register_composite()
139 if (cclk->comp_clks[comp->type] != NULL) { in _register_composite()
141 node, component_clk_types[comp->type]); in _register_composite()
145 cclk->comp_clks[comp->type] = comp; in _register_composite()
148 cclk->comp_nodes[i] = NULL; in _register_composite()
152 for (i = CLK_COMPONENT_TYPE_MAX - 1; i >= 0; i--) { in _register_composite()
153 comp = cclk->comp_clks[i]; in _register_composite()
154 if (!comp) in _register_composite()
156 if (comp->num_parents) { in _register_composite()
157 num_parents = comp->num_parents; in _register_composite()
158 parent_names = comp->parent_names; in _register_composite()
190 if (!cclk->comp_clks[i]) in _register_composite()
192 list_del(&cclk->comp_clks[i]->link); in _register_composite()
193 kfree(cclk->comp_clks[i]->parent_names); in _register_composite()
194 kfree(cclk->comp_clks[i]); in _register_composite()
202 unsigned int num_clks; in of_ti_composite_clk_setup()
203 int i; in of_ti_composite_clk_setup()
220 cclk->comp_nodes[i] = _get_component_node(node, i); in of_ti_composite_clk_setup()
222 _register_composite(&cclk->hw, node); in of_ti_composite_clk_setup()
224 CLK_OF_DECLARE(ti_composite_clock, "ti,composite-clock",
228 * ti_clk_add_component - add a component clock to the pool
236 int __init ti_clk_add_component(struct device_node *node, struct clk_hw *hw, in ti_clk_add_component()
237 int type) in ti_clk_add_component()
239 unsigned int num_parents; in ti_clk_add_component()
246 pr_err("component-clock %pOFn must have parent(s)\n", node); in ti_clk_add_component()
247 return -EINVAL; in ti_clk_add_component()
252 return -ENOMEM; in ti_clk_add_component()
259 return -ENOMEM; in ti_clk_add_component()
262 clk->num_parents = num_parents; in ti_clk_add_component()
263 clk->parent_names = parent_names; in ti_clk_add_component()
264 clk->hw = hw; in ti_clk_add_component()
265 clk->node = node; in ti_clk_add_component()
266 clk->type = type; in ti_clk_add_component()
267 list_add(&clk->link, &component_clks); in ti_clk_add_component()