[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20210914141939.26410-1-semen.protsenko@linaro.org>
Date: Tue, 14 Sep 2021 17:19:39 +0300
From: Sam Protsenko <semen.protsenko@...aro.org>
To: Michael Turquette <mturquette@...libre.com>,
Stephen Boyd <sboyd@...nel.org>
Cc: linux-clk@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: [PATCH] clk: Add clk_set_parent debugfs node
Useful for testing mux clocks. One can write the index of the parent to
set into clk_set_parent node, starting from 0. Example
# cat clk_possible_parrents
dout_shared0_div4 dout_shared1_div4
# cat clk_parent
dout_shared0_div4
# echo 1 > clk_set_parent
# cat clk_parent
dout_shared1_div4
Define CLOCK_ALLOW_WRITE_DEBUGFS in drivers/clk/clk.c in order to use
this feature.
Signed-off-by: Sam Protsenko <semen.protsenko@...aro.org>
---
drivers/clk/clk.c | 31 ++++++++++++++++++++++++++++++-
1 file changed, 30 insertions(+), 1 deletion(-)
diff --git a/drivers/clk/clk.c b/drivers/clk/clk.c
index 65508eb89ec9..3e5456580db9 100644
--- a/drivers/clk/clk.c
+++ b/drivers/clk/clk.c
@@ -3214,6 +3214,30 @@ static int current_parent_show(struct seq_file *s, void *data)
}
DEFINE_SHOW_ATTRIBUTE(current_parent);
+#ifdef CLOCK_ALLOW_WRITE_DEBUGFS
+static int clk_set_parent_set(void *data, u64 val)
+{
+ struct clk_core *core = data, *parent;
+ int ret;
+
+ if (val >= core->num_parents)
+ return -EINVAL;
+
+ parent = clk_core_get_parent_by_index(core, val);
+ if (IS_ERR_OR_NULL(parent))
+ return PTR_ERR(parent);
+
+ clk_prepare_lock();
+ ret = clk_core_set_parent_nolock(core, parent);
+ clk_prepare_unlock();
+
+ return ret;
+}
+
+DEFINE_DEBUGFS_ATTRIBUTE(clk_set_parent_fops, NULL, clk_set_parent_set,
+ "%llu\n");
+#endif
+
static int clk_duty_cycle_show(struct seq_file *s, void *data)
{
struct clk_core *core = s->private;
@@ -3285,9 +3309,14 @@ static void clk_debug_create_one(struct clk_core *core, struct dentry *pdentry)
debugfs_create_file("clk_parent", 0444, root, core,
¤t_parent_fops);
- if (core->num_parents > 1)
+ if (core->num_parents > 1) {
debugfs_create_file("clk_possible_parents", 0444, root, core,
&possible_parents_fops);
+#ifdef CLOCK_ALLOW_WRITE_DEBUGFS
+ debugfs_create_file("clk_set_parent", 0200, root, core,
+ &clk_set_parent_fops);
+#endif
+ }
if (core->ops->debug_init)
core->ops->debug_init(core->hw, core->dentry);
--
2.30.2
Powered by blists - more mailing lists