aboutsummaryrefslogtreecommitdiffstats
path: root/rust/helpers/clk.c
diff options
context:
space:
mode:
authorsaturneric <[email protected]>2025-06-11 23:38:21 +0000
committersaturneric <[email protected]>2025-06-11 23:38:21 +0000
commit0e99f621a88db810f7f95ccb917cf00924cb6e39 (patch)
tree21f3653194dcc5e81bfb0205155a152f727f4cf3 /rust/helpers/clk.c
parentMerge tag 'v6.15' (diff)
parentLinux 6.16-rc1 (diff)
downloadkernel-0e99f621a88db810f7f95ccb917cf00924cb6e39.tar.gz
kernel-0e99f621a88db810f7f95ccb917cf00924cb6e39.zip
Merge tag 'v6.16-rc1'
Linux 6.16-rc1
Diffstat (limited to 'rust/helpers/clk.c')
-rw-r--r--rust/helpers/clk.c66
1 files changed, 66 insertions, 0 deletions
diff --git a/rust/helpers/clk.c b/rust/helpers/clk.c
new file mode 100644
index 000000000000..6d04372c9f3b
--- /dev/null
+++ b/rust/helpers/clk.c
@@ -0,0 +1,66 @@
+// SPDX-License-Identifier: GPL-2.0
+
+#include <linux/clk.h>
+
+/*
+ * The "inline" implementation of below helpers are only available when
+ * CONFIG_HAVE_CLK or CONFIG_HAVE_CLK_PREPARE aren't set.
+ */
+#ifndef CONFIG_HAVE_CLK
+struct clk *rust_helper_clk_get(struct device *dev, const char *id)
+{
+ return clk_get(dev, id);
+}
+
+void rust_helper_clk_put(struct clk *clk)
+{
+ clk_put(clk);
+}
+
+int rust_helper_clk_enable(struct clk *clk)
+{
+ return clk_enable(clk);
+}
+
+void rust_helper_clk_disable(struct clk *clk)
+{
+ clk_disable(clk);
+}
+
+unsigned long rust_helper_clk_get_rate(struct clk *clk)
+{
+ return clk_get_rate(clk);
+}
+
+int rust_helper_clk_set_rate(struct clk *clk, unsigned long rate)
+{
+ return clk_set_rate(clk, rate);
+}
+#endif
+
+#ifndef CONFIG_HAVE_CLK_PREPARE
+int rust_helper_clk_prepare(struct clk *clk)
+{
+ return clk_prepare(clk);
+}
+
+void rust_helper_clk_unprepare(struct clk *clk)
+{
+ clk_unprepare(clk);
+}
+#endif
+
+struct clk *rust_helper_clk_get_optional(struct device *dev, const char *id)
+{
+ return clk_get_optional(dev, id);
+}
+
+int rust_helper_clk_prepare_enable(struct clk *clk)
+{
+ return clk_prepare_enable(clk);
+}
+
+void rust_helper_clk_disable_unprepare(struct clk *clk)
+{
+ clk_disable_unprepare(clk);
+}