diff options
author | Mark Kettenis <kettenis@cvs.openbsd.org> | 2019-09-20 20:45:29 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@cvs.openbsd.org> | 2019-09-20 20:45:29 +0000 |
commit | d49388566c20ea9ffaab9ef75ae3d7c49c4ea4fe (patch) | |
tree | cb9fcea892e5c01e6c11d8f8a7581b6a274376bd /sys/dev/fdt | |
parent | ad29646a44551da926992fdc9480b5d929694781 (diff) |
Start using the generic clock code on RK3288 as well by switching over the
SDMMC clock.
Diffstat (limited to 'sys/dev/fdt')
-rw-r--r-- | sys/dev/fdt/rkclock.c | 39 | ||||
-rw-r--r-- | sys/dev/fdt/rkclock_clocks.h | 2 |
2 files changed, 19 insertions, 22 deletions
diff --git a/sys/dev/fdt/rkclock.c b/sys/dev/fdt/rkclock.c index d17cfeeaf2c..4bb6361d529 100644 --- a/sys/dev/fdt/rkclock.c +++ b/sys/dev/fdt/rkclock.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rkclock.c,v 1.45 2019/09/20 19:58:43 kettenis Exp $ */ +/* $OpenBSD: rkclock.c,v 1.46 2019/09/20 20:45:28 kettenis Exp $ */ /* * Copyright (c) 2017, 2018 Mark Kettenis <kettenis@openbsd.org> * @@ -485,6 +485,14 @@ rkclock_set_parent(struct rkclock_softc *sc, uint32_t idx, uint32_t parent) * Rockchip RK3288 */ +struct rkclock rk3288_clocks[] = { + { + RK3288_CLK_SDMMC, RK3288_CRU_CLKSEL_CON(11), + SEL(7, 6), DIV(5, 0), + { RK3288_PLL_CPLL, RK3288_PLL_GPLL, RK3288_XIN24M } + } +}; + void rk3288_init(struct rkclock_softc *sc) { @@ -507,6 +515,8 @@ rk3288_init(struct rkclock_softc *sc) idx = RK3288_ARMCLK; rk3288_set_frequency(sc, &idx, 1200000000); } + + sc->sc_clocks = rk3288_clocks; } uint32_t @@ -628,23 +638,8 @@ rk3288_get_frequency(void *cookie, uint32_t *cells) div_con = (reg >> 8) & 0x1f; idx = (mux == 0) ? RK3288_PLL_APLL : RK3288_PLL_GPLL; return rk3288_get_frequency(sc, &idx) / (div_con + 1); - case RK3288_CLK_SDMMC: - reg = HREAD4(sc, RK3288_CRU_CLKSEL_CON(11)); - mux = (reg >> 6) & 0x3; - div_con = reg & 0x3f; - switch (mux) { - case 0: - idx = RK3288_PLL_CPLL; - break; - case 1: - idx = RK3288_PLL_GPLL; - break; - case 2: - return 24000000 / (div_con + 1); - default: - return 0; - } - return rk3288_get_frequency(sc, &idx) / (div_con + 1); + case RK3288_XIN24M: + return 24000000; case RK3288_CLK_UART0: reg = HREAD4(sc, RK3288_CRU_CLKSEL_CON(13)); mux = (reg >> 8) & 0x3; @@ -731,8 +726,7 @@ rk3288_get_frequency(void *cookie, uint32_t *cells) break; } - printf("%s: 0x%08x\n", __func__, idx); - return 0; + return rkclock_get_frequency(sc, idx); } int @@ -753,10 +747,11 @@ rk3288_set_frequency(void *cookie, uint32_t *cells, uint32_t freq) ((1 << 15) | (0x1f << 8)) << 16); } return error; + default: + break; } - printf("%s: 0x%08x\n", __func__, idx); - return -1; + return rkclock_set_frequency(sc, idx, freq); } void diff --git a/sys/dev/fdt/rkclock_clocks.h b/sys/dev/fdt/rkclock_clocks.h index 9b84f33c625..23057cddaaf 100644 --- a/sys/dev/fdt/rkclock_clocks.h +++ b/sys/dev/fdt/rkclock_clocks.h @@ -37,6 +37,8 @@ #define RK3288_HCLK_HOST0 450 #define RK3288_HCLK_SDMMC 456 +#define RK3288_XIN24M 1023 + /* * RK3328 clocks. */ |