Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/arm/rockchip Use syscon API.



details:   https://anonhg.NetBSD.org/src/rev/f4b98d6bbdbc
branches:  trunk
changeset: 323782:f4b98d6bbdbc
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Sat Jun 30 17:54:07 2018 +0000

description:
Use syscon API.

diffstat:

 sys/arch/arm/rockchip/rk_cru.c     |  20 +++++---------------
 sys/arch/arm/rockchip/rk_cru.h     |  12 ++++--------
 sys/arch/arm/rockchip/rk_cru_mux.c |  26 +++++++++++++++++---------
 sys/arch/arm/rockchip/rk_cru_pll.c |   9 ++++++---
 4 files changed, 32 insertions(+), 35 deletions(-)

diffs (171 lines):

diff -r 3a7d1ab2317c -r f4b98d6bbdbc sys/arch/arm/rockchip/rk_cru.c
--- a/sys/arch/arm/rockchip/rk_cru.c    Sat Jun 30 17:30:37 2018 +0000
+++ b/sys/arch/arm/rockchip/rk_cru.c    Sat Jun 30 17:54:07 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rk_cru.c,v 1.3 2018/06/26 17:44:04 jmcneill Exp $ */
+/* $NetBSD: rk_cru.c,v 1.4 2018/06/30 17:54:07 jmcneill Exp $ */
 
 /*-
  * Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -30,7 +30,7 @@
 #include "opt_fdt_arm.h"
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rk_cru.c,v 1.3 2018/06/26 17:44:04 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rk_cru.c,v 1.4 2018/06/30 17:54:07 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -300,19 +300,9 @@
        int i;
 
        if (of_hasprop(sc->sc_phandle, "rockchip,grf")) {
-               const int grf_phandle = fdtbus_get_phandle(sc->sc_phandle, "rockchip,grf");
-               if (grf_phandle == -1) {
-                       aprint_error(": couldn't get grf phandle\n");
-                       return ENXIO;
-               }
-
-               if (fdtbus_get_reg(grf_phandle, 0, &addr, &size) != 0) {
-                       aprint_error(": couldn't get grf registers\n");
-                       return ENXIO;
-               }
-
-               if (bus_space_map(sc->sc_bst, addr, size, 0, &sc->sc_bsh_grf) != 0) {
-                       aprint_error(": couldn't map registers\n");
+               sc->sc_grf = fdtbus_syscon_acquire(sc->sc_phandle, "rockchip,grf");
+               if (sc->sc_grf == NULL) {
+                       aprint_error(": couldn't get grf syscon\n");
                        return ENXIO;
                }
        }
diff -r 3a7d1ab2317c -r f4b98d6bbdbc sys/arch/arm/rockchip/rk_cru.h
--- a/sys/arch/arm/rockchip/rk_cru.h    Sat Jun 30 17:30:37 2018 +0000
+++ b/sys/arch/arm/rockchip/rk_cru.h    Sat Jun 30 17:54:07 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rk_cru.h,v 1.1 2018/06/16 00:19:04 jmcneill Exp $ */
+/* $NetBSD: rk_cru.h,v 1.2 2018/06/30 17:54:07 jmcneill Exp $ */
 
 /*-
  * Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -30,6 +30,7 @@
 #define _ARM_RK_CRU_H
 
 #include <dev/clk/clk_backend.h>
+#include <dev/fdt/syscon.h>
 
 struct rk_cru_softc;
 struct rk_cru_clk;
@@ -293,7 +294,7 @@
        int                     sc_phandle;
        bus_space_tag_t         sc_bst;
        bus_space_handle_t      sc_bsh;
-       bus_space_handle_t      sc_bsh_grf;
+       struct syscon           *sc_grf;
 
        struct clk_domain       sc_clkdom;
 
@@ -311,11 +312,6 @@
 #define CRU_WRITE(sc, reg, val)        \
        bus_space_write_4((sc)->sc_bst, (sc)->sc_bsh, (reg), (val))
 
-#define        GRF_READ(sc, reg)       \
-       bus_space_read_4((sc)->sc_bst, (sc)->sc_bsh_grf, (reg))
-#define GRF_WRITE(sc, reg, val)        \
-       bus_space_write_4((sc)->sc_bst, (sc)->sc_bsh_grf, (reg), (val))
-
-#define        HAS_GRF(sc)     ((sc)->sc_bsh_grf != 0)
+#define        HAS_GRF(sc)     ((sc)->sc_grf != NULL)
 
 #endif /* _ARM_RK_CRU_H */
diff -r 3a7d1ab2317c -r f4b98d6bbdbc sys/arch/arm/rockchip/rk_cru_mux.c
--- a/sys/arch/arm/rockchip/rk_cru_mux.c        Sat Jun 30 17:30:37 2018 +0000
+++ b/sys/arch/arm/rockchip/rk_cru_mux.c        Sat Jun 30 17:54:07 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rk_cru_mux.c,v 1.1 2018/06/16 00:19:04 jmcneill Exp $ */
+/* $NetBSD: rk_cru_mux.c,v 1.2 2018/06/30 17:54:07 jmcneill Exp $ */
 
 /*-
  * Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rk_cru_mux.c,v 1.1 2018/06/16 00:19:04 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rk_cru_mux.c,v 1.2 2018/06/30 17:54:07 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -42,13 +42,19 @@
 {
        struct rk_cru_mux *mux = &clk->u.mux;
        const bool mux_grf = (mux->flags & RK_MUX_GRF) != 0;
+       uint32_t val;
 
        KASSERT(clk->type == RK_CRU_MUX);
 
-       if (mux_grf && !HAS_GRF(sc))
-               return NULL;
-
-       const uint32_t val = mux_grf ? GRF_READ(sc, mux->reg) : CRU_READ(sc, mux->reg);
+       if (mux_grf) {
+               if (!HAS_GRF(sc))
+                       return NULL;
+               syscon_lock(sc->sc_grf);
+               val = syscon_read_4(sc->sc_grf, mux->reg);
+               syscon_unlock(sc->sc_grf);
+       } else {
+               val = CRU_READ(sc, mux->reg);
+       }
        const u_int index = __SHIFTOUT(val, mux->mask);
 
        return mux->parents[index];
@@ -71,9 +77,11 @@
                        const uint32_t write_mask = mux->mask << 16;
                        const uint32_t write_val = __SHIFTIN(index, mux->mask);
 
-                       if (mux_grf)
-                               GRF_WRITE(sc, mux->reg, write_mask | write_val);
-                       else
+                       if (mux_grf) {
+                               syscon_lock(sc->sc_grf);
+                               syscon_write_4(sc->sc_grf, mux->reg, write_mask | write_val);
+                               syscon_unlock(sc->sc_grf);
+                       } else
                                CRU_WRITE(sc, mux->reg, write_mask | write_val);
 
                        return 0;
diff -r 3a7d1ab2317c -r f4b98d6bbdbc sys/arch/arm/rockchip/rk_cru_pll.c
--- a/sys/arch/arm/rockchip/rk_cru_pll.c        Sat Jun 30 17:30:37 2018 +0000
+++ b/sys/arch/arm/rockchip/rk_cru_pll.c        Sat Jun 30 17:54:07 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rk_cru_pll.c,v 1.2 2018/06/16 13:24:04 jmcneill Exp $ */
+/* $NetBSD: rk_cru_pll.c,v 1.3 2018/06/30 17:54:07 jmcneill Exp $ */
 
 /*-
  * Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rk_cru_pll.c,v 1.2 2018/06/16 13:24:04 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rk_cru_pll.c,v 1.3 2018/06/30 17:54:07 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -146,11 +146,14 @@
        const uint32_t write_val = pll->mode_mask;
        CRU_WRITE(sc, pll->mode_reg, write_mask | write_val);
 
+       syscon_lock(sc->sc_grf);
        for (retry = 1000; retry > 0; retry--) {
-               if (GRF_READ(sc, GRF_SOC_STATUS0) & pll->lock_mask)
+               if (syscon_read_4(sc->sc_grf, GRF_SOC_STATUS0) & pll->lock_mask)
                        break;
                delay(1);
        }
+       syscon_unlock(sc->sc_grf);
+
        if (retry == 0)
                device_printf(sc->sc_dev, "WARNING: %s failed to lock\n",
                    clk->base.name);



Home | Main Index | Thread Index | Old Index