1
2
3
4
5
6
7#define LOG_CATEGORY UCLASS_CLK
8
9#include <common.h>
10#include <clk.h>
11#include <clk-uclass.h>
12#include <log.h>
13#include <dm/device.h>
14#include <dm/uclass.h>
15#include <dm/lists.h>
16#include <dm/device-internal.h>
17
18int clk_register(struct clk *clk, const char *drv_name,
19 const char *name, const char *parent_name)
20{
21 struct udevice *parent;
22 struct driver *drv;
23 int ret;
24
25 ret = uclass_get_device_by_name(UCLASS_CLK, parent_name, &parent);
26 if (ret) {
27 log_err("%s: failed to get %s device (parent of %s)\n",
28 __func__, parent_name, name);
29 } else {
30 log_debug("%s: name: %s parent: %s [0x%p]\n", __func__, name,
31 parent->name, parent);
32 }
33
34 drv = lists_driver_lookup_name(drv_name);
35 if (!drv) {
36 log_err("%s: %s is not a valid driver name\n",
37 __func__, drv_name);
38 return -ENOENT;
39 }
40
41 ret = device_bind(parent, drv, name, NULL, ofnode_null(), &clk->dev);
42 if (ret) {
43 log_err("%s: CLK: %s driver bind error [%d]!\n", __func__, name,
44 ret);
45 return ret;
46 }
47
48 clk->enable_count = 0;
49
50
51
52 dev_set_uclass_priv(clk->dev, clk);
53
54 return 0;
55}
56
57ulong clk_generic_get_rate(struct clk *clk)
58{
59 return clk_get_parent_rate(clk);
60}
61
62const char *clk_hw_get_name(const struct clk *hw)
63{
64 assert(hw);
65 assert(hw->dev);
66
67 return hw->dev->name;
68}
69
70bool clk_dev_binded(struct clk *clk)
71{
72 if (clk->dev && (dev_get_flags(clk->dev) & DM_FLAG_BOUND))
73 return true;
74
75 return false;
76}
77