Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys Add basic clock device infrastructure.



details:   https://anonhg.NetBSD.org/src/rev/f54500e719ad
branches:  trunk
changeset: 812226:f54500e719ad
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Sat Dec 05 13:31:07 2015 +0000

description:
Add basic clock device infrastructure.

diffstat:

 sys/conf/files            |    7 ++-
 sys/dev/clk/clk.c         |  105 ++++++++++++++++++++++++++++++++++++++++++++++
 sys/dev/clk/clk.h         |   43 ++++++++++++++++++
 sys/dev/clk/clk_backend.h |   54 +++++++++++++++++++++++
 sys/dev/clk/files.clk     |    4 +
 5 files changed, 212 insertions(+), 1 deletions(-)

diffs (240 lines):

diff -r 221794af70ef -r f54500e719ad sys/conf/files
--- a/sys/conf/files    Sat Dec 05 08:11:42 2015 +0000
+++ b/sys/conf/files    Sat Dec 05 13:31:07 2015 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: files,v 1.1150 2015/09/04 06:10:47 uebayasi Exp $
+#      $NetBSD: files,v 1.1151 2015/12/05 13:31:07 jmcneill Exp $
 #      @(#)files.newconf       7.5 (Berkeley) 5/10/93
 
 version        20150846
@@ -1565,3 +1565,8 @@
 # athn
 #
 include "dev/ic/files.athn"
+
+#
+# MI clk api
+#
+include "dev/clk/files.clk"
diff -r 221794af70ef -r f54500e719ad sys/dev/clk/clk.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/dev/clk/clk.c Sat Dec 05 13:31:07 2015 +0000
@@ -0,0 +1,105 @@
+/* $NetBSD: clk.c,v 1.1 2015/12/05 13:31:07 jmcneill Exp $ */
+
+/*-
+ * Copyright (c) 2015 Jared D. McNeill <jmcneill%invisible.ca@localhost>
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__KERNEL_RCSID(0, "$NetBSD: clk.c,v 1.1 2015/12/05 13:31:07 jmcneill Exp $");
+
+#include <sys/param.h>
+
+#include <dev/clk/clk.h>
+#include <dev/clk/clk_backend.h>
+
+static const char *clk_backend = NULL;
+static const struct clk_funcs *clk_funcs = NULL;
+static void *clk_priv = NULL;
+
+int
+clk_backend_register(const char *name, const struct clk_funcs *funcs, void *priv)
+{
+       KASSERT(clk_funcs == NULL);
+
+       clk_backend = name;
+       clk_funcs = funcs;
+       clk_priv = priv;
+
+       return 0;
+}
+
+struct clk *
+clk_get(const char *name)
+{
+       if (clk_funcs == NULL)
+               return NULL;
+       return clk_funcs->get(clk_priv, name);
+}
+
+void
+clk_put(struct clk *clk)
+{
+       return clk_funcs->put(clk_priv, clk);
+}
+
+u_int
+clk_get_rate(struct clk *clk)
+{
+       return clk_funcs->get_rate(clk_priv, clk);
+}
+
+int
+clk_set_rate(struct clk *clk, u_int rate)
+{
+       if (clk->flags & CLK_SET_RATE_PARENT) {
+               return clk_set_rate(clk_get_parent(clk), rate);
+       } else {
+               return clk_funcs->set_rate(clk_priv, clk, rate);
+       }
+}
+
+int
+clk_enable(struct clk *clk)
+{
+       return clk_funcs->enable(clk_priv, clk);
+}
+
+int
+clk_disable(struct clk *clk)
+{
+       return clk_funcs->disable(clk_priv, clk);
+}
+
+int
+clk_set_parent(struct clk *clk, struct clk *parent_clk)
+{
+       return clk_funcs->set_parent(clk_priv, clk, parent_clk);
+}
+
+struct clk *
+clk_get_parent(struct clk *clk)
+{
+       return clk_funcs->get_parent(clk_priv, clk);
+}
diff -r 221794af70ef -r f54500e719ad sys/dev/clk/clk.h
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/dev/clk/clk.h Sat Dec 05 13:31:07 2015 +0000
@@ -0,0 +1,43 @@
+/* $NetBSD: clk.h,v 1.1 2015/12/05 13:31:07 jmcneill Exp $ */
+
+/*-
+ * Copyright (c) 2015 Jared D. McNeill <jmcneill%invisible.ca@localhost>
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#ifndef _DEV_CLK_CLK_H
+#define _DEV_CLK_CLK_H
+
+struct clk;
+
+struct clk *   clk_get(const char *);
+void           clk_put(struct clk *);
+u_int          clk_get_rate(struct clk *);
+int            clk_set_rate(struct clk *, u_int);
+int            clk_enable(struct clk *);
+int            clk_disable(struct clk *);
+int            clk_set_parent(struct clk *, struct clk *);
+struct clk *   clk_get_parent(struct clk *);
+
+#endif /* _DEV_CLK_CLK_H */
diff -r 221794af70ef -r f54500e719ad sys/dev/clk/clk_backend.h
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/dev/clk/clk_backend.h Sat Dec 05 13:31:07 2015 +0000
@@ -0,0 +1,54 @@
+/* $NetBSD: clk_backend.h,v 1.1 2015/12/05 13:31:07 jmcneill Exp $ */
+
+/*-
+ * Copyright (c) 2015 Jared D. McNeill <jmcneill%invisible.ca@localhost>
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#ifndef _DEV_CLK_CLK_BACKEND_H
+#define _DEV_CLK_CLK_BACKEND_H
+
+#include <dev/clk/clk.h>
+
+struct clk {
+        const char *name;
+        u_int flags;
+#define CLK_SET_RATE_PARENT     0x01
+};
+
+struct clk_funcs {
+       struct clk *(*get)(void *, const char *);
+       void (*put)(void *, struct clk *);
+
+       u_int (*get_rate)(void *, struct clk *);
+       int (*set_rate)(void *, struct clk *, u_int);
+       int (*enable)(void *, struct clk *);
+       int (*disable)(void *, struct clk *);
+       int (*set_parent)(void *, struct clk *, struct clk *);
+       struct clk *(*get_parent)(void *, struct clk *);
+};
+
+int    clk_backend_register(const char *, const struct clk_funcs *, void *);
+
+#endif /* _DEV_CLK_CLK_BACKEND_H */
diff -r 221794af70ef -r f54500e719ad sys/dev/clk/files.clk
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/dev/clk/files.clk     Sat Dec 05 13:31:07 2015 +0000
@@ -0,0 +1,4 @@
+# $NetBSD: files.clk,v 1.1 2015/12/05 13:31:07 jmcneill Exp $
+
+define clk
+file   dev/clk/clk.c                   clk



Home | Main Index | Thread Index | Old Index