1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright (C) 2013 Xilinx, Inc.
8 #if defined(CONFIG_DM) && defined(CONFIG_CLK)
10 #include <dm/device.h>
12 #include <dm/device-internal.h>
13 #include <linux/clk-provider.h>
16 #if defined(CONFIG_DM) && defined(CONFIG_CLK)
17 static void show_clks(struct udevice *dev, int depth, int last_flag)
20 struct udevice *child;
21 struct clk *clkp, *parent;
24 clkp = dev_get_clk_ptr(dev);
26 parent = clk_get_parent(clkp);
27 if (!IS_ERR(parent) && depth == -1)
30 rate = clk_get_rate(clkp);
32 printf(" %-12u %8d ", rate, clkp->enable_count);
34 for (i = depth; i >= 0; i--) {
35 is_last = (last_flag >> i) & 1;
49 printf("%s\n", dev->name);
52 device_foreach_child_probe(child, dev) {
53 if (device_get_uclass_id(child) != UCLASS_CLK)
57 is_last = list_is_last(&child->sibling_node, &dev->child_head);
58 show_clks(child, depth, (last_flag << 1) | is_last);
62 static int soc_clk_dump(void)
65 const struct clk_ops *ops;
67 printf(" Rate Usecnt Name\n");
68 printf("------------------------------------------\n");
70 uclass_foreach_dev_probe(UCLASS_CLK, dev)
71 show_clks(dev, -1, 0);
73 uclass_foreach_dev_probe(UCLASS_CLK, dev) {
74 ops = dev_get_driver_ops(dev);
75 if (ops && ops->dump) {
76 printf("\n%s %s:\n", dev->driver->name, dev->name);
84 static int soc_clk_dump(void)
86 puts("Not implemented\n");
91 static int do_clk_dump(struct cmd_tbl *cmdtp, int flag, int argc,
98 printf("Clock dump error %d\n", ret);
99 ret = CMD_RET_FAILURE;
105 #if CONFIG_IS_ENABLED(DM) && CONFIG_IS_ENABLED(CLK)
106 static int do_clk_setfreq(struct cmd_tbl *cmdtp, int flag, int argc,
109 struct clk *clk = NULL;
114 return CMD_RET_USAGE;
116 freq = dectoul(argv[2], NULL);
118 if (!uclass_get_device_by_name(UCLASS_CLK, argv[1], &dev))
119 clk = dev_get_clk_ptr(dev);
122 printf("clock '%s' not found.\n", argv[1]);
123 return CMD_RET_FAILURE;
126 freq = clk_set_rate(clk, freq);
128 printf("set_rate failed: %d\n", freq);
129 return CMD_RET_FAILURE;
132 printf("set_rate returns %u\n", freq);
137 static struct cmd_tbl cmd_clk_sub[] = {
138 U_BOOT_CMD_MKENT(dump, 1, 1, do_clk_dump, "", ""),
139 #if CONFIG_IS_ENABLED(DM) && CONFIG_IS_ENABLED(CLK)
140 U_BOOT_CMD_MKENT(setfreq, 3, 1, do_clk_setfreq, "", ""),
144 static int do_clk(struct cmd_tbl *cmdtp, int flag, int argc,
150 return CMD_RET_USAGE;
152 /* Strip off leading 'clk' command argument */
156 c = find_cmd_tbl(argv[0], &cmd_clk_sub[0], ARRAY_SIZE(cmd_clk_sub));
159 return c->cmd(cmdtp, flag, argc, argv);
161 return CMD_RET_USAGE;
165 "dump - Print clock frequencies\n"
166 "clk setfreq [clk] [freq] - Set clock frequency");
168 U_BOOT_CMD(clk, 4, 1, do_clk, "CLK sub-system", clk_help_text);