Lines Matching refs:provider

57 	struct sci_clk_provider *provider;  member
79 return clk->provider->ops->get_clock(clk->provider->sci, clk->dev_id, in sci_clk_prepare()
96 ret = clk->provider->ops->put_clock(clk->provider->sci, clk->dev_id, in sci_clk_unprepare()
99 dev_err(clk->provider->dev, in sci_clk_unprepare()
117 ret = clk->provider->ops->is_on(clk->provider->sci, clk->dev_id, in sci_clk_is_prepared()
121 dev_err(clk->provider->dev, in sci_clk_is_prepared()
145 ret = clk->provider->ops->get_freq(clk->provider->sci, clk->dev_id, in sci_clk_recalc_rate()
148 dev_err(clk->provider->dev, in sci_clk_recalc_rate()
179 ret = clk->provider->ops->get_best_match_freq(clk->provider->sci, in sci_clk_determine_rate()
187 dev_err(clk->provider->dev, in sci_clk_determine_rate()
215 return clk->provider->ops->set_freq(clk->provider->sci, clk->dev_id, in sci_clk_set_rate()
232 ret = clk->provider->ops->get_parent(clk->provider->sci, clk->dev_id, in sci_clk_get_parent()
235 dev_err(clk->provider->dev, in sci_clk_get_parent()
259 return clk->provider->ops->set_parent(clk->provider->sci, clk->dev_id, in sci_clk_set_parent()
286 static int _sci_clk_build(struct sci_clk_provider *provider, in _sci_clk_build() argument
337 ret = devm_clk_hw_register(provider->dev, &sci_clk->hw); in _sci_clk_build()
339 dev_err(provider->dev, "failed clk register with %d\n", ret); in _sci_clk_build()
379 struct sci_clk_provider *provider = data; in sci_clk_get() local
389 clk = bsearch(&key, provider->clocks, provider->num_clocks, in sci_clk_get()
419 static int ti_sci_scan_clocks_from_fw(struct sci_clk_provider *provider) in ti_sci_scan_clocks_from_fw() argument
431 struct device *dev = provider->dev; in ti_sci_scan_clocks_from_fw()
434 ret = provider->ops->get_num_parents(provider->sci, dev_id, in ti_sci_scan_clocks_from_fw()
473 sci_clk->provider = provider; in ti_sci_scan_clocks_from_fw()
482 provider->clocks = devm_kmalloc_array(dev, num_clks, sizeof(sci_clk), in ti_sci_scan_clocks_from_fw()
484 if (!provider->clocks) in ti_sci_scan_clocks_from_fw()
487 memcpy(provider->clocks, clks, num_clks * sizeof(sci_clk)); in ti_sci_scan_clocks_from_fw()
489 provider->num_clocks = num_clks; in ti_sci_scan_clocks_from_fw()
507 static int ti_sci_scan_clocks_from_dt(struct sci_clk_provider *provider) in ti_sci_scan_clocks_from_dt() argument
509 struct device *dev = provider->dev; in ti_sci_scan_clocks_from_dt()
555 sci_clk->provider = provider; in ti_sci_scan_clocks_from_dt()
556 provider->ops->get_num_parents(provider->sci, in ti_sci_scan_clocks_from_dt()
595 sci_clk->provider = provider; in ti_sci_scan_clocks_from_dt()
608 provider->clocks = devm_kmalloc_array(dev, num_clks, sizeof(sci_clk), in ti_sci_scan_clocks_from_dt()
610 if (!provider->clocks) in ti_sci_scan_clocks_from_dt()
621 provider->clocks[num_clks++] = sci_clk; in ti_sci_scan_clocks_from_dt()
625 provider->num_clocks = num_clks; in ti_sci_scan_clocks_from_dt()
645 struct sci_clk_provider *provider; in ti_sci_clk_probe() local
653 provider = devm_kzalloc(dev, sizeof(*provider), GFP_KERNEL); in ti_sci_clk_probe()
654 if (!provider) in ti_sci_clk_probe()
657 provider->sci = handle; in ti_sci_clk_probe()
658 provider->ops = &handle->ops.clk_ops; in ti_sci_clk_probe()
659 provider->dev = dev; in ti_sci_clk_probe()
662 ret = ti_sci_scan_clocks_from_fw(provider); in ti_sci_clk_probe()
668 ret = ti_sci_scan_clocks_from_dt(provider); in ti_sci_clk_probe()
675 ret = ti_sci_init_clocks(provider); in ti_sci_clk_probe()
681 return of_clk_add_hw_provider(np, sci_clk_get, provider); in ti_sci_clk_probe()