aboutsummaryrefslogtreecommitdiffstats
path: root/roms/u-boot/drivers/clk/clk_fixed_rate.c
diff options
context:
space:
mode:
authorAngelos Mouzakitis <a.mouzakitis@virtualopensystems.com>2023-10-10 14:33:42 +0000
committerAngelos Mouzakitis <a.mouzakitis@virtualopensystems.com>2023-10-10 14:33:42 +0000
commitaf1a266670d040d2f4083ff309d732d648afba2a (patch)
tree2fc46203448ddcc6f81546d379abfaeb323575e9 /roms/u-boot/drivers/clk/clk_fixed_rate.c
parente02cda008591317b1625707ff8e115a4841aa889 (diff)
Add submodule dependency filesHEADmaster
Change-Id: Iaf8d18082d3991dec7c0ebbea540f092188eb4ec
Diffstat (limited to 'roms/u-boot/drivers/clk/clk_fixed_rate.c')
-rw-r--r--roms/u-boot/drivers/clk/clk_fixed_rate.c65
1 files changed, 65 insertions, 0 deletions
diff --git a/roms/u-boot/drivers/clk/clk_fixed_rate.c b/roms/u-boot/drivers/clk/clk_fixed_rate.c
new file mode 100644
index 000000000..09f9ef26a
--- /dev/null
+++ b/roms/u-boot/drivers/clk/clk_fixed_rate.c
@@ -0,0 +1,65 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright (C) 2016 Masahiro Yamada <yamada.masahiro@socionext.com>
+ */
+
+#include <common.h>
+#include <clk-uclass.h>
+#include <dm.h>
+#include <dm/device-internal.h>
+#include <linux/clk-provider.h>
+
+static ulong clk_fixed_rate_get_rate(struct clk *clk)
+{
+ return to_clk_fixed_rate(clk->dev)->fixed_rate;
+}
+
+/* avoid clk_enable() return -ENOSYS */
+static int dummy_enable(struct clk *clk)
+{
+ return 0;
+}
+
+const struct clk_ops clk_fixed_rate_ops = {
+ .get_rate = clk_fixed_rate_get_rate,
+ .enable = dummy_enable,
+};
+
+void clk_fixed_rate_ofdata_to_plat_(struct udevice *dev,
+ struct clk_fixed_rate *plat)
+{
+ struct clk *clk = &plat->clk;
+#if !CONFIG_IS_ENABLED(OF_PLATDATA)
+ plat->fixed_rate = dev_read_u32_default(dev, "clock-frequency", 0);
+#endif
+ /* Make fixed rate clock accessible from higher level struct clk */
+ /* FIXME: This is not allowed */
+ dev_set_uclass_priv(dev, clk);
+
+ clk->dev = dev;
+ clk->enable_count = 0;
+}
+
+static int clk_fixed_rate_of_to_plat(struct udevice *dev)
+{
+ clk_fixed_rate_ofdata_to_plat_(dev, to_clk_fixed_rate(dev));
+
+ return 0;
+}
+
+static const struct udevice_id clk_fixed_rate_match[] = {
+ {
+ .compatible = "fixed-clock",
+ },
+ { /* sentinel */ }
+};
+
+U_BOOT_DRIVER(fixed_clock) = {
+ .name = "fixed_clock",
+ .id = UCLASS_CLK,
+ .of_match = clk_fixed_rate_match,
+ .of_to_plat = clk_fixed_rate_of_to_plat,
+ .plat_auto = sizeof(struct clk_fixed_rate),
+ .ops = &clk_fixed_rate_ops,
+ .flags = DM_FLAG_PRE_RELOC,
+};