From d1d8ab3d1e9858d5f20aeba383625ca65d79df4c Mon Sep 17 00:00:00 2001 From: Mark Kettenis Date: Thu, 27 Apr 2023 08:56:00 +0000 Subject: Add some RK3588 PCIe related clocks. Also add some RK3588 resets. Whoever reviewed the bindings on Linux gave the brilliant advice that clock IDs and reset IDs should not in any way have a sane mapping to the hardware registers, even though that is the case on all older Rockchip SoCs and greatly simplifies the driver. So now we need to implement pointless lookup code. ok patrick@, dlg@ --- sys/dev/fdt/rkclock.c | 42 ++++++++++++++++++++++++++++++++++++++++-- sys/dev/fdt/rkclock_clocks.h | 7 +++++++ 2 files changed, 47 insertions(+), 2 deletions(-) (limited to 'sys/dev/fdt') diff --git a/sys/dev/fdt/rkclock.c b/sys/dev/fdt/rkclock.c index 7780c6c57ba..dfa79af90df 100644 --- a/sys/dev/fdt/rkclock.c +++ b/sys/dev/fdt/rkclock.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rkclock.c,v 1.75 2023/04/18 05:28:41 dlg Exp $ */ +/* $OpenBSD: rkclock.c,v 1.76 2023/04/27 08:55:59 kettenis Exp $ */ /* * Copyright (c) 2017, 2018 Mark Kettenis * @@ -210,8 +210,10 @@ #define RK3588_CRU_CLKSEL_CON(i) (0x00300 + (i) * 4) #define RK3588_CRU_GATE_CON(i) (0x00800 + (i) * 4) +#define RK3588_CRU_SOFTRST_CON(i) (0x00a00 + (i) * 4) #define RK3588_PHPTOPCRU_PPLL_CON(i) (0x08200 + (i) * 4) +#define RK3588_PHPTOPCRU_SOFTRST_CON(i) (0x08a00 + (i) * 4) #define RK3588_PMUCRU_CLKSEL_CON(i) (0x30300 + (i) * 4) #include "rkclock_clocks.h" @@ -4115,6 +4117,21 @@ const struct rkclock rk3588_clocks[] = { RK3588_SCLK_UART0, 0, 0, 0, { RK3588_CLK_UART0 } }, + { + RK3588_CLK_REF_PIPE_PHY0_OSC_SRC, 0, 0, 0, + { RK3588_XIN24M } + }, + { + RK3588_CLK_REF_PIPE_PHY0_PLL_SRC, RK3588_CRU_CLKSEL_CON(176), + 0, DIV(5, 0), + { RK3588_PLL_PPLL } + }, + { + RK3588_CLK_REF_PIPE_PHY0, RK3588_CRU_CLKSEL_CON(177), + SEL(6, 6), 0, + { RK3588_CLK_REF_PIPE_PHY0_OSC_SRC, + RK3588_CLK_REF_PIPE_PHY0_PLL_SRC }, + }, { /* Sentinel */ } @@ -4315,7 +4332,28 @@ rk3588_enable(void *cookie, uint32_t *cells, int on) void rk3588_reset(void *cookie, uint32_t *cells, int on) { + struct rkclock_softc *sc = cookie; uint32_t idx = cells[0]; + uint32_t bit, mask, reg; - printf("%s: 0x%08x\n", __func__, idx); + switch (idx) { + case RK3588_SRST_PCIE4_POWER_UP: + reg = RK3588_CRU_SOFTRST_CON(33); + bit = 1; + break; + case RK3588_SRST_REF_PIPE_PHY0: + reg = RK3588_CRU_SOFTRST_CON(77); + bit = 6; + break; + case RK3588_SRST_P_PCIE2_PHY0: + reg = RK3588_PHPTOPCRU_SOFTRST_CON(0); + bit = 5; + break; + default: + printf("%s: 0x%08x\n", __func__, idx); + return; + } + + mask = (1 << bit); + HWRITE4(sc, reg, mask << 16 | (on ? mask : 0)); } diff --git a/sys/dev/fdt/rkclock_clocks.h b/sys/dev/fdt/rkclock_clocks.h index 50769f112de..94faf47b504 100644 --- a/sys/dev/fdt/rkclock_clocks.h +++ b/sys/dev/fdt/rkclock_clocks.h @@ -460,6 +460,13 @@ #define RK3588_CLK_UART0_FRAC 665 #define RK3588_CLK_UART0 666 #define RK3588_SCLK_UART0 667 +#define RK3588_CLK_REF_PIPE_PHY0_OSC_SRC 674 +#define RK3588_CLK_REF_PIPE_PHY0_PLL_SRC 677 +#define RK3588_CLK_REF_PIPE_PHY0 680 #define RK3588_PLL_SPLL 1022 #define RK3588_XIN24M 1023 + +#define RK3588_SRST_PCIE4_POWER_UP 298 +#define RK3588_SRST_REF_PIPE_PHY0 572 +#define RK3588_SRST_P_PCIE2_PHY0 579 -- cgit v1.2.3