]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
clk: samsung: introduce Exynos2200 clock driver
authorIvaylo Ivanov <ivo.ivanov.ivanov1@gmail.com>
Sun, 23 Feb 2025 11:56:00 +0000 (13:56 +0200)
committerKrzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Sat, 1 Mar 2025 14:08:11 +0000 (15:08 +0100)
CMU_TOP is the top level clock management unit which contains PLLs,
muxes, dividers and gates that feed the other clock management units.

CMU_ALIVE provides clocks for SPMI, the new MCT and other clock
management units

CMU_CMGP provides clocks for USI blocks
CMU_HSI0 provides clocks for USB
CMU_PERIC0 provides clocks for USI4 and I3C blocks
CMU_PERIC1 provides clocks for USI blocks
CMU_PERIC2 provides clocks for USI and I3C blocks
CMU_PERIS provides clocks for GIC and the legacy MCT
CMU_UFS provides clocks for UFS
CMU_VTS provides clocks for other clock management units
like CMU_AUD, which will be added in the future.

Signed-off-by: Ivaylo Ivanov <ivo.ivanov.ivanov1@gmail.com>
Link: https://lore.kernel.org/r/20250223115601.723886-4-ivo.ivanov.ivanov1@gmail.com
Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
drivers/clk/samsung/Makefile
drivers/clk/samsung/clk-exynos2200.c [new file with mode: 0644]

index 90e5b114872c5057a9bd43fd1a16c2ad4630cc3f..d4b5b8e7a0fd225ed1eafef84bb46471a5e36bf0 100644 (file)
@@ -17,6 +17,7 @@ obj-$(CONFIG_EXYNOS_ARM64_COMMON_CLK) += clk-exynos5433.o
 obj-$(CONFIG_EXYNOS_AUDSS_CLK_CON) += clk-exynos-audss.o
 obj-$(CONFIG_EXYNOS_CLKOUT)    += clk-exynos-clkout.o
 obj-$(CONFIG_EXYNOS_ARM64_COMMON_CLK)  += clk-exynos-arm64.o
+obj-$(CONFIG_EXYNOS_ARM64_COMMON_CLK)  += clk-exynos2200.o
 obj-$(CONFIG_EXYNOS_ARM64_COMMON_CLK)  += clk-exynos7.o
 obj-$(CONFIG_EXYNOS_ARM64_COMMON_CLK)  += clk-exynos7885.o
 obj-$(CONFIG_EXYNOS_ARM64_COMMON_CLK)  += clk-exynos850.o
diff --git a/drivers/clk/samsung/clk-exynos2200.c b/drivers/clk/samsung/clk-exynos2200.c
new file mode 100644 (file)
index 0000000..151bdb3
--- /dev/null
@@ -0,0 +1,3928 @@
+// SPDX-License-Identifier: GPL-2.0-only
+/*
+ * Copyright (C) 2025 Ivaylo Ivanov <ivo.ivanov.ivanov1@gmail.com>
+ * Author: Ivaylo Ivanov <ivo.ivanov.ivanov1@gmail.com>
+ *
+ * Common Clock Framework support for Exynos2200 SoC.
+ */
+
+#include <linux/clk.h>
+#include <linux/clk-provider.h>
+#include <linux/of.h>
+#include <linux/platform_device.h>
+
+#include <dt-bindings/clock/samsung,exynos2200-cmu.h>
+
+#include "clk.h"
+#include "clk-exynos-arm64.h"
+
+/* NOTE: Must be equal to the last clock ID increased by one */
+#define CLKS_NR_TOP                    (CLK_DOUT_TCXO_DIV4 + 1)
+#define CLKS_NR_ALIVE                  (CLK_DOUT_ALIVE_DSP_NOC + 1)
+#define CLKS_NR_PERIS                  (CLK_DOUT_PERIS_DDD_CTRL + 1)
+#define CLKS_NR_CMGP                   (CLK_DOUT_CMGP_USI6 + 1)
+#define CLKS_NR_HSI0                   (CLK_DOUT_DIV_CLK_HSI0_EUSB + 1)
+#define CLKS_NR_PERIC0                 (CLK_DOUT_PERIC0_USI04 + 1)
+#define CLKS_NR_PERIC1                 (CLK_DOUT_PERIC1_USI10 + 1)
+#define CLKS_NR_PERIC2                 (CLK_DOUT_PERIC2_USI11 + 1)
+#define CLKS_NR_UFS                    (CLK_MOUT_UFS_UFS_EMBD_USER + 1)
+#define CLKS_NR_VTS                    (CLK_DOUT_CLKVTS_SERIAL_LIF_CORE + 1)
+
+/* ---- CMU_TOP ------------------------------------------------------------ */
+
+/* Register Offset definitions for CMU_TOP (0x1a320000) */
+#define PLL_LOCKTIME_PLL_MMC                           0x0
+#define PLL_LOCKTIME_PLL_SHARED0                       0x4
+#define PLL_LOCKTIME_PLL_SHARED1                       0x8
+#define PLL_LOCKTIME_PLL_SHARED2                       0xc
+#define PLL_LOCKTIME_PLL_SHARED3                       0x10
+#define PLL_LOCKTIME_PLL_SHARED4                       0x14
+#define PLL_LOCKTIME_PLL_SHARED_MIF                    0x18
+#define PLL_CON3_PLL_MMC                               0x10c
+#define PLL_CON8_PLL_MMC                               0x120
+#define PLL_CON3_PLL_SHARED0                           0x14c
+#define PLL_CON8_PLL_SHARED0                           0x160
+#define PLL_CON3_PLL_SHARED1                           0x18c
+#define PLL_CON8_PLL_SHARED1                           0x1a0
+#define PLL_CON3_PLL_SHARED2                           0x1cc
+#define PLL_CON8_PLL_SHARED2                           0x1e0
+#define PLL_CON3_PLL_SHARED3                           0x20c
+#define PLL_CON8_PLL_SHARED3                           0x220
+#define PLL_CON3_PLL_SHARED4                           0x24c
+#define PLL_CON8_PLL_SHARED4                           0x260
+#define PLL_CON3_PLL_SHARED_MIF                                0x28c
+#define PLL_CON8_PLL_SHARED_MIF                                0x2a0
+#define PLL_CON0_MUX_CP_MPLL_CLK_D2_USER               0x600
+#define PLL_CON1_MUX_CP_MPLL_CLK_D2_USER               0x604
+#define PLL_CON0_MUX_CP_MPLL_CLK_USER                  0x610
+#define PLL_CON1_MUX_CP_MPLL_CLK_USER                  0x614
+#define CLK_CON_MUX_CLKCMU_AUD_AUDIF0                  0x1000
+#define CLK_CON_MUX_CLKCMU_AUD_AUDIF1                  0x1004
+#define CLK_CON_MUX_CLKCMU_AUD_CPU                     0x1008
+#define CLK_CON_MUX_CLKCMU_CPUCL0_DBG_NOC              0x100c
+#define CLK_CON_MUX_CLKCMU_CPUCL0_SWITCH               0x1010
+#define CLK_CON_MUX_CLKCMU_CPUCL1_SWITCH               0x1014
+#define CLK_CON_MUX_CLKCMU_CPUCL2_SWITCH               0x1018
+#define CLK_CON_MUX_CLKCMU_DNC_NOC                     0x101c
+#define CLK_CON_MUX_CLKCMU_DPUB_NOC                    0x1020
+#define CLK_CON_MUX_CLKCMU_DPUF_NOC                    0x1024
+#define CLK_CON_MUX_CLKCMU_DSP_NOC                     0x102c
+#define CLK_CON_MUX_CLKCMU_DSU_SWITCH                  0x1030
+#define CLK_CON_MUX_CLKCMU_G3D_SWITCH                  0x1034
+#define CLK_CON_MUX_CLKCMU_GNPU_NOC                    0x103c
+#define CLK_CON_MUX_CLKCMU_UFS_MMC_CARD                        0x1040
+#define CLK_CON_MUX_CLKCMU_M2M_NOC                     0x1044
+#define CLK_CON_MUX_CLKCMU_NOCL0_NOC                   0x1048
+#define CLK_CON_MUX_CLKCMU_NOCL1A_NOC                  0x104c
+#define CLK_CON_MUX_CLKCMU_NOCL1B_NOC0                 0x1050
+#define CLK_CON_MUX_CLKCMU_NOCL1C_NOC                  0x1054
+#define CLK_CON_MUX_CLKCMU_SDMA_NOC                    0x1058
+#define CLK_CON_MUX_CP_HISPEEDY_CLK                    0x105c
+#define CLK_CON_MUX_CP_SHARED0_CLK                     0x1060
+#define CLK_CON_MUX_CP_SHARED2_CLK                     0x1064
+#define CLK_CON_MUX_MUX_CLKCMU_ALIVE_NOC               0x1068
+#define CLK_CON_MUX_MUX_CLKCMU_AUD_AUDIF0              0x106c
+#define CLK_CON_MUX_MUX_CLKCMU_AUD_AUDIF1              0x1070
+#define CLK_CON_MUX_MUX_CLKCMU_AUD_CPU                 0x1074
+#define CLK_CON_MUX_MUX_CLKCMU_AUD_NOC                 0x1078
+#define CLK_CON_MUX_MUX_CLKCMU_BRP_NOC                 0x107c
+#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK0                        0x1080
+#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK1                        0x1084
+#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK2                        0x1088
+#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK3                        0x108c
+#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK4                        0x1090
+#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK5                        0x1094
+#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK6                        0x1098
+#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK7                        0x109c
+#define CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST               0x10a0
+#define CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_CAM           0x10a4
+#define CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_CPU           0x10a8
+#define CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_MIF           0x10ac
+#define CLK_CON_MUX_MUX_CLKCMU_CPUCL0_DBG_NOC          0x10b0
+#define CLK_CON_MUX_MUX_CLKCMU_CPUCL0_NOCP             0x10b4
+#define CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH           0x10b8
+#define CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH           0x10bc
+#define CLK_CON_MUX_MUX_CLKCMU_CPUCL2_SWITCH           0x10c0
+#define CLK_CON_MUX_MUX_CLKCMU_CSIS_DCPHY              0x10c4
+#define CLK_CON_MUX_MUX_CLKCMU_CSIS_NOC                        0x10c8
+#define CLK_CON_MUX_MUX_CLKCMU_CSIS_OIS_MCU            0x10cc
+#define CLK_CON_MUX_MUX_CLKCMU_CSTAT_NOC               0x10d0
+#define CLK_CON_MUX_MUX_CLKCMU_DNC_NOC                 0x10d4
+#define CLK_CON_MUX_MUX_CLKCMU_DPUB                    0x10d8
+#define CLK_CON_MUX_MUX_CLKCMU_DPUB_ALT                        0x10dc
+#define CLK_CON_MUX_MUX_CLKCMU_DPUB_DSIM               0x10e0
+#define CLK_CON_MUX_MUX_CLKCMU_DPUF                    0x10e4
+#define CLK_CON_MUX_MUX_CLKCMU_DPUF_ALT                        0x10e8
+#define CLK_CON_MUX_MUX_CLKCMU_DSP_NOC                 0x10f8
+#define CLK_CON_MUX_MUX_CLKCMU_DSU_SWITCH              0x10fc
+#define CLK_CON_MUX_MUX_CLKCMU_G3D_NOCP                        0x1100
+#define CLK_CON_MUX_MUX_CLKCMU_G3D_SWITCH              0x1104
+#define CLK_CON_MUX_MUX_CLKCMU_GNPU_NOC                        0x110c
+#define CLK_CON_MUX_MUX_CLKCMU_HSI0_DPGTC              0x1114
+#define CLK_CON_MUX_MUX_CLKCMU_HSI0_DPOSC              0x1118
+#define CLK_CON_MUX_MUX_CLKCMU_HSI0_NOC                        0x111c
+#define CLK_CON_MUX_MUX_CLKCMU_HSI0_USB32DRD           0x1120
+#define CLK_CON_MUX_MUX_CLKCMU_UFS_MMC_CARD            0x1124
+#define CLK_CON_MUX_MUX_CLKCMU_HSI1_NOC                        0x1128
+#define CLK_CON_MUX_MUX_CLKCMU_HSI1_PCIE               0x112c
+#define CLK_CON_MUX_MUX_CLKCMU_UFS_UFS_EMBD            0x1130
+#define CLK_CON_MUX_MUX_CLKCMU_LME_LME                 0x1134
+#define CLK_CON_MUX_MUX_CLKCMU_LME_NOC                 0x1138
+#define CLK_CON_MUX_MUX_CLKCMU_M2M_NOC                 0x1140
+#define CLK_CON_MUX_MUX_CLKCMU_MCSC_MCSC               0x1148
+#define CLK_CON_MUX_MUX_CLKCMU_MCSC_NOC                        0x114c
+#define CLK_CON_MUX_MUX_CLKCMU_MFC0_MFC0               0x1150
+#define CLK_CON_MUX_MUX_CLKCMU_MFC0_WFD                        0x1154
+#define CLK_CON_MUX_MUX_CLKCMU_MFC1_MFC1               0x1158
+#define CLK_CON_MUX_MUX_CLKCMU_MIF_NOCP                        0x115c
+#define CLK_CON_MUX_MUX_CLKCMU_MIF_SWITCH              0x1160
+#define CLK_CON_MUX_MUX_CLKCMU_NOCL0_NOC               0x1164
+#define CLK_CON_MUX_MUX_CLKCMU_NOCL1A_NOC              0x1168
+#define CLK_CON_MUX_MUX_CLKCMU_NOCL1B_NOC0             0x116c
+#define CLK_CON_MUX_MUX_CLKCMU_NOCL1B_NOC1             0x1170
+#define CLK_CON_MUX_MUX_CLKCMU_NOCL1C_NOC              0x1174
+#define CLK_CON_MUX_MUX_CLKCMU_PERIC0_IP0              0x1178
+#define CLK_CON_MUX_MUX_CLKCMU_PERIC0_IP1              0x117c
+#define CLK_CON_MUX_MUX_CLKCMU_PERIC0_NOC              0x1180
+#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_IP0              0x1184
+#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_IP1              0x1188
+#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_NOC              0x118c
+#define CLK_CON_MUX_MUX_CLKCMU_PERIC2_IP0              0x1190
+#define CLK_CON_MUX_MUX_CLKCMU_PERIC2_IP1              0x1194
+#define CLK_CON_MUX_MUX_CLKCMU_PERIC2_NOC              0x1198
+#define CLK_CON_MUX_MUX_CLKCMU_PERIS_GIC               0x119c
+#define CLK_CON_MUX_MUX_CLKCMU_PERIS_NOC               0x11a0
+#define CLK_CON_MUX_MUX_CLKCMU_SDMA_NOC                        0x11a8
+#define CLK_CON_MUX_MUX_CLKCMU_SSP_NOC                 0x11ac
+#define CLK_CON_MUX_MUX_CLKCMU_VTS_DMIC                        0x11b0
+#define CLK_CON_MUX_MUX_CLKCMU_YUVP_NOC                        0x11b4
+#define CLK_CON_MUX_MUX_CMU_CMUREF                     0x11b8
+#define CLK_CON_MUX_MUX_CP_HISPEEDY_CLK                        0x11bc
+#define CLK_CON_MUX_MUX_CP_SHARED0_CLK                 0x11c0
+#define CLK_CON_MUX_MUX_CP_SHARED1_CLK                 0x11c4
+#define CLK_CON_MUX_MUX_CP_SHARED2_CLK                 0x11c8
+#define CLK_CON_MUX_CLKCMU_M2M_FRC                     0x11cc
+#define CLK_CON_MUX_CLKCMU_MCSC_MCSC                   0x11d0
+#define CLK_CON_MUX_CLKCMU_MCSC_NOC                    0x11d4
+#define CLK_CON_MUX_MUX_CLKCMU_M2M_FRC                 0x11d8
+#define CLK_CON_MUX_MUX_CLKCMU_UFS_NOC                 0x11dc
+#define CLK_CON_DIV_CLKCMU_ALIVE_NOC                   0x1800
+#define CLK_CON_DIV_CLKCMU_AUD_NOC                     0x1804
+#define CLK_CON_DIV_CLKCMU_BRP_NOC                     0x1808
+#define CLK_CON_DIV_CLKCMU_CMU_BOOST                   0x180c
+#define CLK_CON_DIV_CLKCMU_CMU_BOOST_CAM               0x1810
+#define CLK_CON_DIV_CLKCMU_CMU_BOOST_CPU               0x1814
+#define CLK_CON_DIV_CLKCMU_CMU_BOOST_MIF               0x1818
+#define CLK_CON_DIV_CLKCMU_CPUCL0_NOCP                 0x181c
+#define CLK_CON_DIV_CLKCMU_CSIS_DCPHY                  0x1820
+#define CLK_CON_DIV_CLKCMU_CSIS_NOC                    0x1824
+#define CLK_CON_DIV_CLKCMU_CSIS_OIS_MCU                        0x1828
+#define CLK_CON_DIV_CLKCMU_CSTAT_NOC                   0x182c
+#define CLK_CON_DIV_CLKCMU_DPUB_DSIM                   0x1830
+#define CLK_CON_DIV_CLKCMU_LME_LME                     0x1834
+#define CLK_CON_DIV_CLKCMU_G3D_NOCP                    0x1838
+#define CLK_CON_DIV_CLKCMU_HSI0_DPGTC                  0x1840
+#define CLK_CON_DIV_CLKCMU_HSI0_DPOSC                  0x1844
+#define CLK_CON_DIV_CLKCMU_HSI0_NOC                    0x1848
+#define CLK_CON_DIV_CLKCMU_HSI0_USB32DRD               0x184c
+#define CLK_CON_DIV_CLKCMU_HSI1_NOC                    0x1850
+#define CLK_CON_DIV_CLKCMU_HSI1_PCIE                   0x1854
+#define CLK_CON_DIV_CLKCMU_UFS_UFS_EMBD                        0x1858
+#define CLK_CON_DIV_CLKCMU_LME_NOC                     0x1860
+#define CLK_CON_DIV_CLKCMU_MFC0_MFC0                   0x1874
+#define CLK_CON_DIV_CLKCMU_MFC0_WFD                    0x1878
+#define CLK_CON_DIV_CLKCMU_MFC1_MFC1                   0x187c
+#define CLK_CON_DIV_CLKCMU_MIF_NOCP                    0x1880
+#define CLK_CON_DIV_CLKCMU_NOCL1B_NOC1                 0x1884
+#define CLK_CON_DIV_CLKCMU_PERIC0_IP0                  0x1888
+#define CLK_CON_DIV_CLKCMU_PERIC0_IP1                  0x188c
+#define CLK_CON_DIV_CLKCMU_PERIC0_NOC                  0x1890
+#define CLK_CON_DIV_CLKCMU_PERIC1_IP0                  0x1894
+#define CLK_CON_DIV_CLKCMU_PERIC1_IP1                  0x1898
+#define CLK_CON_DIV_CLKCMU_PERIC1_NOC                  0x189c
+#define CLK_CON_DIV_CLKCMU_PERIC2_IP0                  0x18a0
+#define CLK_CON_DIV_CLKCMU_PERIC2_IP1                  0x18a4
+#define CLK_CON_DIV_CLKCMU_PERIC2_NOC                  0x18a8
+#define CLK_CON_DIV_CLKCMU_PERIS_GIC                   0x18ac
+#define CLK_CON_DIV_CLKCMU_PERIS_NOC                   0x18b0
+#define CLK_CON_DIV_CLKCMU_SSP_NOC                     0x18b8
+#define CLK_CON_DIV_CLKCMU_VTS_DMIC                    0x18bc
+#define CLK_CON_DIV_CLKCMU_YUVP_NOC                    0x18c0
+#define CLK_CON_DIV_CP_SHARED1_CLK                     0x18c4
+#define CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF0              0x18c8
+#define CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF0_SM           0x18cc
+#define CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF1              0x18d0
+#define CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF1_SM           0x18d4
+#define CLK_CON_DIV_DIV_CLKCMU_AUD_CPU                 0x18d8
+#define CLK_CON_DIV_DIV_CLKCMU_AUD_CPU_SM              0x18dc
+#define CLK_CON_DIV_DIV_CLKCMU_CIS_CLK0                        0x18e0
+#define CLK_CON_DIV_DIV_CLKCMU_CIS_CLK1                        0x18e4
+#define CLK_CON_DIV_DIV_CLKCMU_CIS_CLK2                        0x18e8
+#define CLK_CON_DIV_DIV_CLKCMU_CIS_CLK3                        0x18ec
+#define CLK_CON_DIV_DIV_CLKCMU_CIS_CLK4                        0x18f0
+#define CLK_CON_DIV_DIV_CLKCMU_CIS_CLK5                        0x18f4
+#define CLK_CON_DIV_DIV_CLKCMU_CIS_CLK6                        0x18f8
+#define CLK_CON_DIV_DIV_CLKCMU_CIS_CLK7                        0x18fc
+#define CLK_CON_DIV_DIV_CLKCMU_CPUCL0_DBG_NOC          0x1900
+#define CLK_CON_DIV_DIV_CLKCMU_CPUCL0_DBG_NOC_SM       0x1904
+#define CLK_CON_DIV_DIV_CLKCMU_CPUCL0_SWITCH           0x1908
+#define CLK_CON_DIV_DIV_CLKCMU_CPUCL0_SWITCH_SM                0x190c
+#define CLK_CON_DIV_DIV_CLKCMU_CPUCL1_SWITCH           0x1910
+#define CLK_CON_DIV_DIV_CLKCMU_CPUCL1_SWITCH_SM                0x1914
+#define CLK_CON_DIV_DIV_CLKCMU_CPUCL2_SWITCH           0x1918
+#define CLK_CON_DIV_DIV_CLKCMU_CPUCL2_SWITCH_SM                0x191c
+#define CLK_CON_DIV_DIV_CLKCMU_DNC_NOC                 0x1920
+#define CLK_CON_DIV_DIV_CLKCMU_DNC_NOC_SM              0x1924
+#define CLK_CON_DIV_DIV_CLKCMU_DPUB                    0x1928
+#define CLK_CON_DIV_DIV_CLKCMU_DPUB_ALT                        0x192c
+#define CLK_CON_DIV_DIV_CLKCMU_DPUF                    0x1930
+#define CLK_CON_DIV_DIV_CLKCMU_DPUF_ALT                        0x1934
+#define CLK_CON_DIV_DIV_CLKCMU_DSP_NOC                 0x1940
+#define CLK_CON_DIV_DIV_CLKCMU_DSP_NOC_SM              0x1944
+#define CLK_CON_DIV_DIV_CLKCMU_DSU_SWITCH              0x1948
+#define CLK_CON_DIV_DIV_CLKCMU_DSU_SWITCH_SM           0x194c
+#define CLK_CON_DIV_DIV_CLKCMU_G3D_SWITCH              0x1950
+#define CLK_CON_DIV_DIV_CLKCMU_G3D_SWITCH_SM           0x1954
+#define CLK_CON_DIV_DIV_CLKCMU_GNPU_NOC                        0x1960
+#define CLK_CON_DIV_DIV_CLKCMU_GNPU_NOC_SM             0x1964
+#define CLK_CON_DIV_DIV_CLKCMU_UFS_MMC_CARD            0x1968
+#define CLK_CON_DIV_DIV_CLKCMU_UFS_MMC_CARD_SM         0x196c
+#define CLK_CON_DIV_DIV_CLKCMU_M2M_NOC                 0x1970
+#define CLK_CON_DIV_DIV_CLKCMU_M2M_NOC_SM              0x1974
+#define CLK_CON_DIV_DIV_CLKCMU_NOCL0_NOC               0x1978
+#define CLK_CON_DIV_DIV_CLKCMU_NOCL0_NOC_SM            0x197c
+#define CLK_CON_DIV_DIV_CLKCMU_NOCL1A_NOC              0x1980
+#define CLK_CON_DIV_DIV_CLKCMU_NOCL1A_NOC_SM           0x1984
+#define CLK_CON_DIV_DIV_CLKCMU_NOCL1B_NOC0             0x1988
+#define CLK_CON_DIV_DIV_CLKCMU_NOCL1B_NOC0_SM          0x198c
+#define CLK_CON_DIV_DIV_CLKCMU_NOCL1C_NOC              0x1990
+#define CLK_CON_DIV_DIV_CLKCMU_NOCL1C_NOC_SM           0x1994
+#define CLK_CON_DIV_DIV_CLKCMU_SDMA_NOC                        0x1998
+#define CLK_CON_DIV_DIV_CLKCMU_SDMA_NOC_SM             0x199c
+#define CLK_CON_DIV_DIV_CP_HISPEEDY_CLK                        0x19a0
+#define CLK_CON_DIV_DIV_CP_HISPEEDY_CLK_SM             0x19a4
+#define CLK_CON_DIV_DIV_CP_SHARED0_CLK                 0x19a8
+#define CLK_CON_DIV_DIV_CP_SHARED0_CLK_SM              0x19ac
+#define CLK_CON_DIV_DIV_CP_SHARED2_CLK                 0x19b0
+#define CLK_CON_DIV_DIV_CP_SHARED2_CLK_SM              0x19b4
+#define CLK_CON_DIV_CLKCMU_UFS_NOC                     0x19b8
+#define CLK_CON_DIV_DIV_CLKCMU_M2M_FRC                 0x19bc
+#define CLK_CON_DIV_DIV_CLKCMU_M2M_FRC_SM              0x19c0
+#define CLK_CON_DIV_DIV_CLKCMU_MCSC_MCSC               0x19c4
+#define CLK_CON_DIV_DIV_CLKCMU_MCSC_MCSC_SM            0x19c8
+#define CLK_CON_DIV_DIV_CLKCMU_MCSC_NOC                        0x19cc
+#define CLK_CON_DIV_DIV_CLKCMU_MCSC_NOC_SM             0x19d0
+#define CLK_CON_GAT_CLKCMU_MIF01_SWITCH                        0x2000
+#define CLK_CON_GAT_CLKCMU_MIF23_SWITCH                        0x2004
+#define CLK_CON_GAT_GATE_CLKCMU_ALIVE_NOC              0x200c
+#define CLK_CON_GAT_GATE_CLKCMU_AUD_AUDIF0             0x2010
+#define CLK_CON_GAT_GATE_CLKCMU_AUD_AUDIF0_SM          0x2014
+#define CLK_CON_GAT_GATE_CLKCMU_AUD_AUDIF1             0x2018
+#define CLK_CON_GAT_GATE_CLKCMU_AUD_AUDIF1_SM          0x201c
+#define CLK_CON_GAT_GATE_CLKCMU_AUD_CPU                        0x2020
+#define CLK_CON_GAT_GATE_CLKCMU_AUD_CPU_SM             0x2024
+#define CLK_CON_GAT_GATE_CLKCMU_AUD_NOC                        0x2028
+#define CLK_CON_GAT_GATE_CLKCMU_BRP_NOC                        0x202c
+#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK0               0x2030
+#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK1               0x2034
+#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK2               0x2038
+#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK3               0x203c
+#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK4               0x2040
+#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK5               0x2044
+#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK6               0x2048
+#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK7               0x204c
+#define CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST              0x2050
+#define CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST_CAM          0x2054
+#define CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST_CPU          0x2058
+#define CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST_CPU_MIF      0x205c
+#define CLK_CON_GAT_GATE_CLKCMU_CPUCL0_DBG_NOC         0x2060
+#define CLK_CON_GAT_GATE_CLKCMU_CPUCL0_DBG_NOC_SM      0x2064
+#define CLK_CON_GAT_GATE_CLKCMU_CPUCL0_NOCP            0x2068
+#define CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH          0x206c
+#define CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH_SM       0x2070
+#define CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH          0x2074
+#define CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH_SM       0x2078
+#define CLK_CON_GAT_GATE_CLKCMU_CPUCL2_SWITCH          0x207c
+#define CLK_CON_GAT_GATE_CLKCMU_CPUCL2_SWITCH_SM       0x2080
+#define CLK_CON_GAT_GATE_CLKCMU_CSIS_DCPHY             0x2084
+#define CLK_CON_GAT_GATE_CLKCMU_CSIS_NOC               0x2088
+#define CLK_CON_GAT_GATE_CLKCMU_CSIS_OIS_MCU           0x208c
+#define CLK_CON_GAT_GATE_CLKCMU_CSTAT_NOC              0x2090
+#define CLK_CON_GAT_GATE_CLKCMU_DNC_NOC                        0x2094
+#define CLK_CON_GAT_GATE_CLKCMU_DNC_NOC_SM             0x2098
+#define CLK_CON_GAT_GATE_CLKCMU_DPUB                   0x209c
+#define CLK_CON_GAT_GATE_CLKCMU_DPUB_ALT               0x20a0
+#define CLK_CON_GAT_GATE_CLKCMU_DPUB_DSIM              0x20a4
+#define CLK_CON_GAT_GATE_CLKCMU_DPUF                   0x20a8
+#define CLK_CON_GAT_GATE_CLKCMU_DPUF_ALT               0x20ac
+#define CLK_CON_GAT_GATE_CLKCMU_DSP_NOC                        0x20bc
+#define CLK_CON_GAT_GATE_CLKCMU_DSP_NOC_SM             0x20c0
+#define CLK_CON_GAT_GATE_CLKCMU_DSU_SWITCH             0x20c4
+#define CLK_CON_GAT_GATE_CLKCMU_DSU_SWITCH_SM          0x20c8
+#define CLK_CON_GAT_GATE_CLKCMU_G3D_NOCP               0x20cc
+#define CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH             0x20d0
+#define CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH_SM          0x20d4
+#define CLK_CON_GAT_GATE_CLKCMU_GNPU_NOC               0x20e0
+#define CLK_CON_GAT_GATE_CLKCMU_GNPU_NOC_SM            0x20e4
+#define CLK_CON_GAT_GATE_CLKCMU_HSI0_DPGTC             0x20ec
+#define CLK_CON_GAT_GATE_CLKCMU_HSI0_DPOSC             0x20f0
+#define CLK_CON_GAT_GATE_CLKCMU_HSI0_NOC               0x20f4
+#define CLK_CON_GAT_GATE_CLKCMU_HSI0_USB32DRD          0x20f8
+#define CLK_CON_GAT_GATE_CLKCMU_UFS_MMC_CARD           0x20fc
+#define CLK_CON_GAT_GATE_CLKCMU_UFS_MMC_CARD_SM                0x2100
+#define CLK_CON_GAT_GATE_CLKCMU_HSI1_NOC               0x2104
+#define CLK_CON_GAT_GATE_CLKCMU_HSI1_PCIE              0x2108
+#define CLK_CON_GAT_GATE_CLKCMU_UFS_UFS_EMBD           0x210c
+#define CLK_CON_GAT_GATE_CLKCMU_LME_LME                        0x2110
+#define CLK_CON_GAT_GATE_CLKCMU_LME_NOC                        0x2114
+#define CLK_CON_GAT_GATE_CLKCMU_M2M_NOC                        0x2118
+#define CLK_CON_GAT_GATE_CLKCMU_M2M_NOC_SM             0x211c
+#define CLK_CON_GAT_GATE_CLKCMU_MFC0_MFC0              0x212c
+#define CLK_CON_GAT_GATE_CLKCMU_MFC0_WFD               0x2130
+#define CLK_CON_GAT_GATE_CLKCMU_MFC1_MFC1              0x2134
+#define CLK_CON_GAT_GATE_CLKCMU_MIF_NOCP               0x2138
+#define CLK_CON_GAT_GATE_CLKCMU_NOCL0_NOC              0x213c
+#define CLK_CON_GAT_GATE_CLKCMU_NOCL0_NOC_SM           0x2140
+#define CLK_CON_GAT_GATE_CLKCMU_NOCL1A_NOC             0x2144
+#define CLK_CON_GAT_GATE_CLKCMU_NOCL1A_NOC_SM          0x2148
+#define CLK_CON_GAT_GATE_CLKCMU_NOCL1B_NOC0            0x214c
+#define CLK_CON_GAT_GATE_CLKCMU_NOCL1B_NOC0_SM         0x2150
+#define CLK_CON_GAT_GATE_CLKCMU_NOCL1B_NOC1            0x2154
+#define CLK_CON_GAT_GATE_CLKCMU_NOCL1C_NOC             0x2158
+#define CLK_CON_GAT_GATE_CLKCMU_NOCL1C_NOC_SM          0x215c
+#define CLK_CON_GAT_GATE_CLKCMU_PERIC0_IP0             0x2160
+#define CLK_CON_GAT_GATE_CLKCMU_PERIC0_IP1             0x2164
+#define CLK_CON_GAT_GATE_CLKCMU_PERIC0_NOC             0x2168
+#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_IP0             0x216c
+#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_IP1             0x2170
+#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_NOC             0x2174
+#define CLK_CON_GAT_GATE_CLKCMU_PERIC2_IP0             0x2178
+#define CLK_CON_GAT_GATE_CLKCMU_PERIC2_IP1             0x217c
+#define CLK_CON_GAT_GATE_CLKCMU_PERIC2_NOC             0x2180
+#define CLK_CON_GAT_GATE_CLKCMU_PERIS_GIC              0x2184
+#define CLK_CON_GAT_GATE_CLKCMU_PERIS_NOC              0x2188
+#define CLK_CON_GAT_GATE_CLKCMU_SDMA_NOC               0x2190
+#define CLK_CON_GAT_GATE_CLKCMU_SDMA_NOC_SM            0x2194
+#define CLK_CON_GAT_GATE_CLKCMU_SSP_NOC                        0x2198
+#define CLK_CON_GAT_GATE_CLKCMU_VTS_DMIC               0x219c
+#define CLK_CON_GAT_GATE_CLKCMU_YUVP_NOC               0x21a0
+#define CLK_CON_GAT_GATE_CP_HISPEEDY_CLK               0x21a4
+#define CLK_CON_GAT_GATE_CP_HISPEEDY_CLK_SM            0x21a8
+#define CLK_CON_GAT_GATE_CP_SHARED0_CLK                        0x21ac
+#define CLK_CON_GAT_GATE_CP_SHARED0_CLK_SM             0x21b0
+#define CLK_CON_GAT_GATE_CP_SHARED1_CLK                        0x21b4
+#define CLK_CON_GAT_GATE_CP_SHARED2_CLK                        0x21b8
+#define CLK_CON_GAT_GATE_CP_SHARED2_CLK_SM             0x21bc
+#define CLK_CON_GAT_GATE_CLKCMU_UFS_NOC                        0x21c0
+#define CLK_CON_GAT_GATE_CLKCMU_M2M_FRC                        0x21c4
+#define CLK_CON_GAT_GATE_CLKCMU_M2M_FRC_SM             0x21c8
+#define CLK_CON_GAT_GATE_CLKCMU_MCSC_MCSC              0x21cc
+#define CLK_CON_GAT_GATE_CLKCMU_MCSC_MCSC_SM           0x21d0
+#define CLK_CON_GAT_GATE_CLKCMU_MCSC_NOC               0x21d4
+#define CLK_CON_GAT_GATE_CLKCMU_MCSC_NOC_SM            0x21d8
+
+static const unsigned long top_clk_regs[] __initconst = {
+       PLL_LOCKTIME_PLL_MMC,
+       PLL_LOCKTIME_PLL_SHARED0,
+       PLL_LOCKTIME_PLL_SHARED1,
+       PLL_LOCKTIME_PLL_SHARED2,
+       PLL_LOCKTIME_PLL_SHARED3,
+       PLL_LOCKTIME_PLL_SHARED4,
+       PLL_LOCKTIME_PLL_SHARED_MIF,
+       PLL_CON3_PLL_MMC,
+       PLL_CON8_PLL_MMC,
+       PLL_CON3_PLL_SHARED0,
+       PLL_CON8_PLL_SHARED0,
+       PLL_CON3_PLL_SHARED1,
+       PLL_CON8_PLL_SHARED1,
+       PLL_CON3_PLL_SHARED2,
+       PLL_CON8_PLL_SHARED2,
+       PLL_CON3_PLL_SHARED3,
+       PLL_CON8_PLL_SHARED3,
+       PLL_CON3_PLL_SHARED4,
+       PLL_CON8_PLL_SHARED4,
+       PLL_CON3_PLL_SHARED_MIF,
+       PLL_CON8_PLL_SHARED_MIF,
+       PLL_CON0_MUX_CP_MPLL_CLK_D2_USER,
+       PLL_CON1_MUX_CP_MPLL_CLK_D2_USER,
+       PLL_CON0_MUX_CP_MPLL_CLK_USER,
+       PLL_CON1_MUX_CP_MPLL_CLK_USER,
+       CLK_CON_MUX_CLKCMU_AUD_AUDIF0,
+       CLK_CON_MUX_CLKCMU_AUD_AUDIF1,
+       CLK_CON_MUX_CLKCMU_AUD_CPU,
+       CLK_CON_MUX_CLKCMU_CPUCL0_DBG_NOC,
+       CLK_CON_MUX_CLKCMU_CPUCL0_SWITCH,
+       CLK_CON_MUX_CLKCMU_CPUCL1_SWITCH,
+       CLK_CON_MUX_CLKCMU_CPUCL2_SWITCH,
+       CLK_CON_MUX_CLKCMU_DNC_NOC,
+       CLK_CON_MUX_CLKCMU_DPUB_NOC,
+       CLK_CON_MUX_CLKCMU_DPUF_NOC,
+       CLK_CON_MUX_CLKCMU_DSP_NOC,
+       CLK_CON_MUX_CLKCMU_DSU_SWITCH,
+       CLK_CON_MUX_CLKCMU_G3D_SWITCH,
+       CLK_CON_MUX_CLKCMU_GNPU_NOC,
+       CLK_CON_MUX_CLKCMU_UFS_MMC_CARD,
+       CLK_CON_MUX_CLKCMU_M2M_NOC,
+       CLK_CON_MUX_CLKCMU_NOCL0_NOC,
+       CLK_CON_MUX_CLKCMU_NOCL1A_NOC,
+       CLK_CON_MUX_CLKCMU_NOCL1B_NOC0,
+       CLK_CON_MUX_CLKCMU_NOCL1C_NOC,
+       CLK_CON_MUX_CLKCMU_SDMA_NOC,
+       CLK_CON_MUX_CP_HISPEEDY_CLK,
+       CLK_CON_MUX_CP_SHARED0_CLK,
+       CLK_CON_MUX_CP_SHARED2_CLK,
+       CLK_CON_MUX_MUX_CLKCMU_ALIVE_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_AUD_AUDIF0,
+       CLK_CON_MUX_MUX_CLKCMU_AUD_AUDIF1,
+       CLK_CON_MUX_MUX_CLKCMU_AUD_CPU,
+       CLK_CON_MUX_MUX_CLKCMU_AUD_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_BRP_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_CIS_CLK0,
+       CLK_CON_MUX_MUX_CLKCMU_CIS_CLK1,
+       CLK_CON_MUX_MUX_CLKCMU_CIS_CLK2,
+       CLK_CON_MUX_MUX_CLKCMU_CIS_CLK3,
+       CLK_CON_MUX_MUX_CLKCMU_CIS_CLK4,
+       CLK_CON_MUX_MUX_CLKCMU_CIS_CLK5,
+       CLK_CON_MUX_MUX_CLKCMU_CIS_CLK6,
+       CLK_CON_MUX_MUX_CLKCMU_CIS_CLK7,
+       CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST,
+       CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_CAM,
+       CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_CPU,
+       CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_MIF,
+       CLK_CON_MUX_MUX_CLKCMU_CPUCL0_DBG_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_CPUCL0_NOCP,
+       CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH,
+       CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH,
+       CLK_CON_MUX_MUX_CLKCMU_CPUCL2_SWITCH,
+       CLK_CON_MUX_MUX_CLKCMU_CSIS_DCPHY,
+       CLK_CON_MUX_MUX_CLKCMU_CSIS_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_CSIS_OIS_MCU,
+       CLK_CON_MUX_MUX_CLKCMU_CSTAT_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_DNC_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_DPUB,
+       CLK_CON_MUX_MUX_CLKCMU_DPUB_ALT,
+       CLK_CON_MUX_MUX_CLKCMU_DPUB_DSIM,
+       CLK_CON_MUX_MUX_CLKCMU_DPUF,
+       CLK_CON_MUX_MUX_CLKCMU_DPUF_ALT,
+       CLK_CON_MUX_MUX_CLKCMU_DSP_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_DSU_SWITCH,
+       CLK_CON_MUX_MUX_CLKCMU_G3D_NOCP,
+       CLK_CON_MUX_MUX_CLKCMU_G3D_SWITCH,
+       CLK_CON_MUX_MUX_CLKCMU_GNPU_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_HSI0_DPGTC,
+       CLK_CON_MUX_MUX_CLKCMU_HSI0_DPOSC,
+       CLK_CON_MUX_MUX_CLKCMU_HSI0_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_HSI0_USB32DRD,
+       CLK_CON_MUX_MUX_CLKCMU_UFS_MMC_CARD,
+       CLK_CON_MUX_MUX_CLKCMU_HSI1_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_HSI1_PCIE,
+       CLK_CON_MUX_MUX_CLKCMU_UFS_UFS_EMBD,
+       CLK_CON_MUX_MUX_CLKCMU_LME_LME,
+       CLK_CON_MUX_MUX_CLKCMU_LME_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_M2M_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_MCSC_MCSC,
+       CLK_CON_MUX_MUX_CLKCMU_MCSC_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_MFC0_MFC0,
+       CLK_CON_MUX_MUX_CLKCMU_MFC0_WFD,
+       CLK_CON_MUX_MUX_CLKCMU_MFC1_MFC1,
+       CLK_CON_MUX_MUX_CLKCMU_MIF_NOCP,
+       CLK_CON_MUX_MUX_CLKCMU_MIF_SWITCH,
+       CLK_CON_MUX_MUX_CLKCMU_NOCL0_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_NOCL1A_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_NOCL1B_NOC0,
+       CLK_CON_MUX_MUX_CLKCMU_NOCL1B_NOC1,
+       CLK_CON_MUX_MUX_CLKCMU_NOCL1C_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_PERIC0_IP0,
+       CLK_CON_MUX_MUX_CLKCMU_PERIC0_IP1,
+       CLK_CON_MUX_MUX_CLKCMU_PERIC0_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_PERIC1_IP0,
+       CLK_CON_MUX_MUX_CLKCMU_PERIC1_IP1,
+       CLK_CON_MUX_MUX_CLKCMU_PERIC1_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_PERIC2_IP0,
+       CLK_CON_MUX_MUX_CLKCMU_PERIC2_IP1,
+       CLK_CON_MUX_MUX_CLKCMU_PERIC2_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_PERIS_GIC,
+       CLK_CON_MUX_MUX_CLKCMU_PERIS_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_SDMA_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_SSP_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_VTS_DMIC,
+       CLK_CON_MUX_MUX_CLKCMU_YUVP_NOC,
+       CLK_CON_MUX_MUX_CMU_CMUREF,
+       CLK_CON_MUX_MUX_CP_HISPEEDY_CLK,
+       CLK_CON_MUX_MUX_CP_SHARED0_CLK,
+       CLK_CON_MUX_MUX_CP_SHARED1_CLK,
+       CLK_CON_MUX_MUX_CP_SHARED2_CLK,
+       CLK_CON_MUX_CLKCMU_M2M_FRC,
+       CLK_CON_MUX_CLKCMU_MCSC_MCSC,
+       CLK_CON_MUX_CLKCMU_MCSC_NOC,
+       CLK_CON_MUX_MUX_CLKCMU_M2M_FRC,
+       CLK_CON_MUX_MUX_CLKCMU_UFS_NOC,
+       CLK_CON_DIV_CLKCMU_ALIVE_NOC,
+       CLK_CON_DIV_CLKCMU_AUD_NOC,
+       CLK_CON_DIV_CLKCMU_BRP_NOC,
+       CLK_CON_DIV_CLKCMU_CMU_BOOST,
+       CLK_CON_DIV_CLKCMU_CMU_BOOST_CAM,
+       CLK_CON_DIV_CLKCMU_CMU_BOOST_CPU,
+       CLK_CON_DIV_CLKCMU_CMU_BOOST_MIF,
+       CLK_CON_DIV_CLKCMU_CPUCL0_NOCP,
+       CLK_CON_DIV_CLKCMU_CSIS_DCPHY,
+       CLK_CON_DIV_CLKCMU_CSIS_NOC,
+       CLK_CON_DIV_CLKCMU_CSIS_OIS_MCU,
+       CLK_CON_DIV_CLKCMU_CSTAT_NOC,
+       CLK_CON_DIV_CLKCMU_DPUB_DSIM,
+       CLK_CON_DIV_CLKCMU_LME_LME,
+       CLK_CON_DIV_CLKCMU_G3D_NOCP,
+       CLK_CON_DIV_CLKCMU_HSI0_DPGTC,
+       CLK_CON_DIV_CLKCMU_HSI0_DPOSC,
+       CLK_CON_DIV_CLKCMU_HSI0_NOC,
+       CLK_CON_DIV_CLKCMU_HSI0_USB32DRD,
+       CLK_CON_DIV_CLKCMU_HSI1_NOC,
+       CLK_CON_DIV_CLKCMU_HSI1_PCIE,
+       CLK_CON_DIV_CLKCMU_UFS_UFS_EMBD,
+       CLK_CON_DIV_CLKCMU_LME_NOC,
+       CLK_CON_DIV_CLKCMU_MFC0_MFC0,
+       CLK_CON_DIV_CLKCMU_MFC0_WFD,
+       CLK_CON_DIV_CLKCMU_MFC1_MFC1,
+       CLK_CON_DIV_CLKCMU_MIF_NOCP,
+       CLK_CON_DIV_CLKCMU_NOCL1B_NOC1,
+       CLK_CON_DIV_CLKCMU_PERIC0_IP0,
+       CLK_CON_DIV_CLKCMU_PERIC0_IP1,
+       CLK_CON_DIV_CLKCMU_PERIC0_NOC,
+       CLK_CON_DIV_CLKCMU_PERIC1_IP0,
+       CLK_CON_DIV_CLKCMU_PERIC1_IP1,
+       CLK_CON_DIV_CLKCMU_PERIC1_NOC,
+       CLK_CON_DIV_CLKCMU_PERIC2_IP0,
+       CLK_CON_DIV_CLKCMU_PERIC2_IP1,
+       CLK_CON_DIV_CLKCMU_PERIC2_NOC,
+       CLK_CON_DIV_CLKCMU_PERIS_GIC,
+       CLK_CON_DIV_CLKCMU_PERIS_NOC,
+       CLK_CON_DIV_CLKCMU_SSP_NOC,
+       CLK_CON_DIV_CLKCMU_VTS_DMIC,
+       CLK_CON_DIV_CLKCMU_YUVP_NOC,
+       CLK_CON_DIV_CP_SHARED1_CLK,
+       CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF0,
+       CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF0_SM,
+       CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF1,
+       CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF1_SM,
+       CLK_CON_DIV_DIV_CLKCMU_AUD_CPU,
+       CLK_CON_DIV_DIV_CLKCMU_AUD_CPU_SM,
+       CLK_CON_DIV_DIV_CLKCMU_CIS_CLK0,
+       CLK_CON_DIV_DIV_CLKCMU_CIS_CLK1,
+       CLK_CON_DIV_DIV_CLKCMU_CIS_CLK2,
+       CLK_CON_DIV_DIV_CLKCMU_CIS_CLK3,
+       CLK_CON_DIV_DIV_CLKCMU_CIS_CLK4,
+       CLK_CON_DIV_DIV_CLKCMU_CIS_CLK5,
+       CLK_CON_DIV_DIV_CLKCMU_CIS_CLK6,
+       CLK_CON_DIV_DIV_CLKCMU_CIS_CLK7,
+       CLK_CON_DIV_DIV_CLKCMU_CPUCL0_DBG_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_CPUCL0_DBG_NOC_SM,
+       CLK_CON_DIV_DIV_CLKCMU_CPUCL0_SWITCH,
+       CLK_CON_DIV_DIV_CLKCMU_CPUCL0_SWITCH_SM,
+       CLK_CON_DIV_DIV_CLKCMU_CPUCL1_SWITCH,
+       CLK_CON_DIV_DIV_CLKCMU_CPUCL1_SWITCH_SM,
+       CLK_CON_DIV_DIV_CLKCMU_CPUCL2_SWITCH,
+       CLK_CON_DIV_DIV_CLKCMU_CPUCL2_SWITCH_SM,
+       CLK_CON_DIV_DIV_CLKCMU_DNC_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_DNC_NOC_SM,
+       CLK_CON_DIV_DIV_CLKCMU_DPUB,
+       CLK_CON_DIV_DIV_CLKCMU_DPUB_ALT,
+       CLK_CON_DIV_DIV_CLKCMU_DPUF,
+       CLK_CON_DIV_DIV_CLKCMU_DPUF_ALT,
+       CLK_CON_DIV_DIV_CLKCMU_DSP_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_DSP_NOC_SM,
+       CLK_CON_DIV_DIV_CLKCMU_DSU_SWITCH,
+       CLK_CON_DIV_DIV_CLKCMU_DSU_SWITCH_SM,
+       CLK_CON_DIV_DIV_CLKCMU_G3D_SWITCH,
+       CLK_CON_DIV_DIV_CLKCMU_G3D_SWITCH_SM,
+       CLK_CON_DIV_DIV_CLKCMU_GNPU_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_GNPU_NOC_SM,
+       CLK_CON_DIV_DIV_CLKCMU_UFS_MMC_CARD,
+       CLK_CON_DIV_DIV_CLKCMU_UFS_MMC_CARD_SM,
+       CLK_CON_DIV_DIV_CLKCMU_M2M_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_M2M_NOC_SM,
+       CLK_CON_DIV_DIV_CLKCMU_NOCL0_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_NOCL0_NOC_SM,
+       CLK_CON_DIV_DIV_CLKCMU_NOCL1A_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_NOCL1A_NOC_SM,
+       CLK_CON_DIV_DIV_CLKCMU_NOCL1B_NOC0,
+       CLK_CON_DIV_DIV_CLKCMU_NOCL1B_NOC0_SM,
+       CLK_CON_DIV_DIV_CLKCMU_NOCL1C_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_NOCL1C_NOC_SM,
+       CLK_CON_DIV_DIV_CLKCMU_SDMA_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_SDMA_NOC_SM,
+       CLK_CON_DIV_DIV_CP_HISPEEDY_CLK,
+       CLK_CON_DIV_DIV_CP_HISPEEDY_CLK_SM,
+       CLK_CON_DIV_DIV_CP_SHARED0_CLK,
+       CLK_CON_DIV_DIV_CP_SHARED0_CLK_SM,
+       CLK_CON_DIV_DIV_CP_SHARED2_CLK,
+       CLK_CON_DIV_DIV_CP_SHARED2_CLK_SM,
+       CLK_CON_DIV_CLKCMU_UFS_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_M2M_FRC,
+       CLK_CON_DIV_DIV_CLKCMU_M2M_FRC_SM,
+       CLK_CON_DIV_DIV_CLKCMU_MCSC_MCSC,
+       CLK_CON_DIV_DIV_CLKCMU_MCSC_MCSC_SM,
+       CLK_CON_DIV_DIV_CLKCMU_MCSC_NOC,
+       CLK_CON_DIV_DIV_CLKCMU_MCSC_NOC_SM,
+       CLK_CON_GAT_CLKCMU_MIF01_SWITCH,
+       CLK_CON_GAT_CLKCMU_MIF23_SWITCH,
+       CLK_CON_GAT_GATE_CLKCMU_ALIVE_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_AUD_AUDIF0,
+       CLK_CON_GAT_GATE_CLKCMU_AUD_AUDIF0_SM,
+       CLK_CON_GAT_GATE_CLKCMU_AUD_AUDIF1,
+       CLK_CON_GAT_GATE_CLKCMU_AUD_AUDIF1_SM,
+       CLK_CON_GAT_GATE_CLKCMU_AUD_CPU,
+       CLK_CON_GAT_GATE_CLKCMU_AUD_CPU_SM,
+       CLK_CON_GAT_GATE_CLKCMU_AUD_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_BRP_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_CIS_CLK0,
+       CLK_CON_GAT_GATE_CLKCMU_CIS_CLK1,
+       CLK_CON_GAT_GATE_CLKCMU_CIS_CLK2,
+       CLK_CON_GAT_GATE_CLKCMU_CIS_CLK3,
+       CLK_CON_GAT_GATE_CLKCMU_CIS_CLK4,
+       CLK_CON_GAT_GATE_CLKCMU_CIS_CLK5,
+       CLK_CON_GAT_GATE_CLKCMU_CIS_CLK6,
+       CLK_CON_GAT_GATE_CLKCMU_CIS_CLK7,
+       CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST,
+       CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST_CAM,
+       CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST_CPU,
+       CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST_CPU_MIF,
+       CLK_CON_GAT_GATE_CLKCMU_CPUCL0_DBG_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_CPUCL0_DBG_NOC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_CPUCL0_NOCP,
+       CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH,
+       CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH_SM,
+       CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH,
+       CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH_SM,
+       CLK_CON_GAT_GATE_CLKCMU_CPUCL2_SWITCH,
+       CLK_CON_GAT_GATE_CLKCMU_CPUCL2_SWITCH_SM,
+       CLK_CON_GAT_GATE_CLKCMU_CSIS_DCPHY,
+       CLK_CON_GAT_GATE_CLKCMU_CSIS_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_CSIS_OIS_MCU,
+       CLK_CON_GAT_GATE_CLKCMU_CSTAT_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_DNC_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_DNC_NOC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_DPUB,
+       CLK_CON_GAT_GATE_CLKCMU_DPUB_ALT,
+       CLK_CON_GAT_GATE_CLKCMU_DPUB_DSIM,
+       CLK_CON_GAT_GATE_CLKCMU_DPUF,
+       CLK_CON_GAT_GATE_CLKCMU_DPUF_ALT,
+       CLK_CON_GAT_GATE_CLKCMU_DSP_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_DSP_NOC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_DSU_SWITCH,
+       CLK_CON_GAT_GATE_CLKCMU_DSU_SWITCH_SM,
+       CLK_CON_GAT_GATE_CLKCMU_G3D_NOCP,
+       CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH,
+       CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH_SM,
+       CLK_CON_GAT_GATE_CLKCMU_GNPU_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_GNPU_NOC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_HSI0_DPGTC,
+       CLK_CON_GAT_GATE_CLKCMU_HSI0_DPOSC,
+       CLK_CON_GAT_GATE_CLKCMU_HSI0_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_HSI0_USB32DRD,
+       CLK_CON_GAT_GATE_CLKCMU_UFS_MMC_CARD,
+       CLK_CON_GAT_GATE_CLKCMU_UFS_MMC_CARD_SM,
+       CLK_CON_GAT_GATE_CLKCMU_HSI1_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_HSI1_PCIE,
+       CLK_CON_GAT_GATE_CLKCMU_UFS_UFS_EMBD,
+       CLK_CON_GAT_GATE_CLKCMU_LME_LME,
+       CLK_CON_GAT_GATE_CLKCMU_LME_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_M2M_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_M2M_NOC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_MFC0_MFC0,
+       CLK_CON_GAT_GATE_CLKCMU_MFC0_WFD,
+       CLK_CON_GAT_GATE_CLKCMU_MFC1_MFC1,
+       CLK_CON_GAT_GATE_CLKCMU_MIF_NOCP,
+       CLK_CON_GAT_GATE_CLKCMU_NOCL0_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_NOCL0_NOC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_NOCL1A_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_NOCL1A_NOC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_NOCL1B_NOC0,
+       CLK_CON_GAT_GATE_CLKCMU_NOCL1B_NOC0_SM,
+       CLK_CON_GAT_GATE_CLKCMU_NOCL1B_NOC1,
+       CLK_CON_GAT_GATE_CLKCMU_NOCL1C_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_NOCL1C_NOC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_PERIC0_IP0,
+       CLK_CON_GAT_GATE_CLKCMU_PERIC0_IP1,
+       CLK_CON_GAT_GATE_CLKCMU_PERIC0_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_PERIC1_IP0,
+       CLK_CON_GAT_GATE_CLKCMU_PERIC1_IP1,
+       CLK_CON_GAT_GATE_CLKCMU_PERIC1_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_PERIC2_IP0,
+       CLK_CON_GAT_GATE_CLKCMU_PERIC2_IP1,
+       CLK_CON_GAT_GATE_CLKCMU_PERIC2_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_PERIS_GIC,
+       CLK_CON_GAT_GATE_CLKCMU_PERIS_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_SDMA_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_SDMA_NOC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_SSP_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_VTS_DMIC,
+       CLK_CON_GAT_GATE_CLKCMU_YUVP_NOC,
+       CLK_CON_GAT_GATE_CP_HISPEEDY_CLK,
+       CLK_CON_GAT_GATE_CP_HISPEEDY_CLK_SM,
+       CLK_CON_GAT_GATE_CP_SHARED0_CLK,
+       CLK_CON_GAT_GATE_CP_SHARED0_CLK_SM,
+       CLK_CON_GAT_GATE_CP_SHARED1_CLK,
+       CLK_CON_GAT_GATE_CP_SHARED2_CLK,
+       CLK_CON_GAT_GATE_CP_SHARED2_CLK_SM,
+       CLK_CON_GAT_GATE_CLKCMU_UFS_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_M2M_FRC,
+       CLK_CON_GAT_GATE_CLKCMU_M2M_FRC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_MCSC_MCSC,
+       CLK_CON_GAT_GATE_CLKCMU_MCSC_MCSC_SM,
+       CLK_CON_GAT_GATE_CLKCMU_MCSC_NOC,
+       CLK_CON_GAT_GATE_CLKCMU_MCSC_NOC_SM,
+};
+
+/* List of parent clocks for Muxes in CMU_TOP */
+PNAME(mout_cmu_cp_mpll_clk_d2_user_parents)    = { "oscclk" };
+PNAME(mout_cmu_cp_mpll_clk_user_parents)       = { "oscclk" };
+PNAME(mout_cmu_aud_audif0_p)                   = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "mout_cmu_cp_mpll_clk_d2_user",
+                                                   "oscclk", "oscclk",
+                                                   "oscclk" };
+PNAME(mout_cmu_aud_audif1_p)                   = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "mout_cmu_cp_mpll_clk_d2_user",
+                                                   "oscclk", "oscclk",
+                                                   "oscclk" };
+PNAME(mout_cmu_aud_cpu_p)                      = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "mout_cmu_cp_mpll_clk_d2_user" };
+PNAME(mout_cmu_cpucl0_dbg_noc_p)               = { "dout_shared2_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2" };
+PNAME(mout_cmu_cpucl0_switch_p)                        = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_cpucl1_switch_p)                        = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_cpucl2_switch_p)                        = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_dnc_noc_p)                      = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_dpub_noc_p)                     = { "dout_cmu_div_dpub",
+                                                   "dout_cmu_div_dpub_alt"};
+PNAME(mout_cmu_dpuf_noc_p)                     = { "dout_cmu_div_dpuf",
+                                                   "dout_cmu_div_dpuf_alt" };
+PNAME(mout_cmu_dsp_noc_p)                      = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_dsu_switch_p)                   = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_g3d_switch_p)                   = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_gnpu_noc_p)                     = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_ufs_mmc_card_p)                 = { "oscclk",
+                                                   "dout_shared2_div1",
+                                                   "dout_mmc_div1",
+                                                   "dout_shared0_div2" };
+PNAME(mout_cmu_m2m_noc_p)                      = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_nocl0_noc_p)                    = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "mout_cmu_cp_mpll_clk_d2_user",
+                                                   "dout_shared_mif_div2" };
+PNAME(mout_cmu_nocl1a_noc_p)                   = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_nocl1b_noc0_p)                  = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_nocl1c_noc_p)                   = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_sdma_noc_p)                     = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_cp_hispeedy_clk_p)              = { "dout_shared2_div1",
+                                                   "dout_shared3_div1" };
+PNAME(mout_cmu_cp_shared0_clk_p)               = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1" };
+PNAME(mout_cmu_cp_shared2_clk_p)               = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared1_div2" };
+PNAME(mout_cmu_mux_alive_noc_p)                        = { "dout_shared0_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_aud_audif0_p)               = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "mout_cmu_cp_mpll_clk_d2_user",
+                                                   "oscclk", "oscclk",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_aud_audif1_p)               = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "mout_cmu_cp_mpll_clk_d2_user",
+                                                   "oscclk", "oscclk",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_aud_cpu_p)                  = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "mout_cmu_cp_mpll_clk_d2_user" };
+PNAME(mout_cmu_mux_aud_noc_p)                  = { "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "mout_cmu_cp_mpll_clk_d2_user",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_mux_brp_noc_p)                  = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_cis_clk0_p)                 = { "oscclk",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_cis_clk1_p)                 = { "oscclk",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_cis_clk2_p)                 = { "oscclk",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_cis_clk3_p)                 = { "oscclk",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_cis_clk4_p)                 = { "oscclk",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_cis_clk5_p)                 = { "oscclk",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_cis_clk6_p)                 = { "oscclk",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_cis_clk7_p)                 = { "oscclk",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_cmu_boost_p)                        = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_cmu_boost_cam_p)            = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_cmu_boost_cpu_p)            = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_cmu_boost_mif_p)            = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_cpucl0_dbg_noc_p)           = { "dout_shared2_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2" };
+PNAME(mout_cmu_mux_cpucl0_nocp_p)              = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_cpucl0_switch_p)            = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_mux_cpucl1_switch_p)            = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_mux_cpucl2_switch_p)            = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_mux_csis_dcphy_p)               = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_csis_noc_p)                 = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_csis_ois_mcu_p)             = { "dout_shared0_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_cstat_noc_p)                        = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_dnc_noc_p)                  = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_dpub_p)                     = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_mux_dpub_alt_p)                 = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_mux_dpub_dsim_p)                        = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2" };
+PNAME(mout_cmu_mux_dpuf_p)                     = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_mux_dpuf_alt_p)                 = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_mux_dsp_noc_p)                  = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_dsu_switch_p)               = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "oscclk", "oscclk" };
+PNAME(mout_cmu_mux_g3d_nocp_p)                 = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_g3d_switch_p)               = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_gnpu_noc_p)                 = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_hsi0_dpgtc_p)               = { "oscclk",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_hsi0_dposc_p)               = { "oscclk",
+                                                   "dout_shared2_div1" };
+PNAME(mout_cmu_mux_hsi0_noc_p)                 = { "dout_shared0_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_hsi0_usb32drd_p)            = { "oscclk",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_ufs_mmc_card_p)             = { "oscclk",
+                                                   "dout_shared2_div1",
+                                                   "dout_mmc_div1",
+                                                   "dout_shared0_div2" };
+PNAME(mout_cmu_mux_hsi1_noc_p)                 = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_hsi1_pcie_p)                        = { "oscclk",
+                                                   "dout_shared2_div1" };
+PNAME(mout_cmu_mux_ufs_ufs_embd_p)             = { "oscclk",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_lme_lme_p)                  = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_lme_noc_p)                  = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_m2m_noc_p)                  = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_mcsc_mcsc_p)                        = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_mcsc_noc_p)                 = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_mfc0_mfc0_p)                        = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_mfc0_wfd_p)                 = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "dout_shared4_div2",
+                                                   "oscclk", "oscclk",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_mfc1_mfc1_p)                        = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_mif_nocp_p)                 = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_mif_switch_p)               = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "mout_cmu_cp_mpll_clk_user",
+                                                   "dout_shared_mif_div1" };
+PNAME(mout_cmu_mux_nocl0_noc_p)                        = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "mout_cmu_cp_mpll_clk_d2_user",
+                                                   "dout_shared_mif_div2" };
+PNAME(mout_cmu_mux_nocl1a_noc_p)               = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_nocl1b_noc0_p)              = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_nocl1b_noc1_p)              = { "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_nocl1c_noc_p)               = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_peric0_ip0_p)               = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_peric0_ip1_p)               = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_peric0_noc_p)               = { "dout_shared0_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_peric1_ip0_p)               = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_peric1_ip1_p)               = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_peric1_noc_p)               = { "dout_shared0_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_peric2_ip0_p)               = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_peric2_ip1_p)               = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_peric2_noc_p)               = { "dout_shared0_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_peris_gic_p)                        = { "dout_shared0_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_peris_noc_p)                        = { "dout_shared0_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_sdma_noc_p)                 = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_ssp_noc_p)                  = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+PNAME(mout_cmu_mux_vts_dmic_p)                 = { "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2" };
+PNAME(mout_cmu_mux_yuvp_noc_p)                 = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_cmu_cmuref_p)               = { "oscclk",
+                                                   "dout_cmu_boost" };
+PNAME(mout_cmu_mux_cp_hispeedy_clk_p)          = { "dout_shared2_div1",
+                                                   "dout_shared3_div1" };
+PNAME(mout_cmu_mux_cp_shared0_clk_p)           = { "dout_shared0_div1",
+                                                   "dout_shared1_div1",
+                                                   "dout_shared2_div1",
+                                                   "dout_shared3_div1" };
+PNAME(mout_cmu_mux_cp_shared1_clk_p)           = { "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2" };
+PNAME(mout_cmu_mux_cp_shared2_clk_p)           = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared1_div2" };
+PNAME(mout_cmu_m2m_frc_p)                      = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mcsc_mcsc_p)                    = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mcsc_noc_p)                     = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_m2m_frc_p)                  = { "dout_shared2_div1",
+                                                   "dout_shared3_div1",
+                                                   "dout_shared4_div1",
+                                                   "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared3_div2",
+                                                   "oscclk" };
+PNAME(mout_cmu_mux_ufs_noc_p)                  = { "dout_shared0_div2",
+                                                   "dout_shared1_div2",
+                                                   "dout_shared2_div2",
+                                                   "dout_shared4_div2" };
+
+static const struct samsung_pll_clock top_pll_clks[] __initconst = {
+       PLL(pll_4311, CLK_FOUT_SHARED0_PLL, "fout_shared0_pll", "oscclk",
+           PLL_LOCKTIME_PLL_SHARED0, PLL_CON3_PLL_SHARED0, NULL),
+       PLL(pll_4311, CLK_FOUT_SHARED1_PLL, "fout_shared1_pll", "oscclk",
+           PLL_LOCKTIME_PLL_SHARED1, PLL_CON3_PLL_SHARED1, NULL),
+       PLL(pll_4311, CLK_FOUT_SHARED2_PLL, "fout_shared2_pll", "oscclk",
+           PLL_LOCKTIME_PLL_SHARED2, PLL_CON3_PLL_SHARED2, NULL),
+       PLL(pll_4311, CLK_FOUT_SHARED3_PLL, "fout_shared3_pll", "oscclk",
+           PLL_LOCKTIME_PLL_SHARED3, PLL_CON3_PLL_SHARED3, NULL),
+       PLL(pll_4311, CLK_FOUT_SHARED4_PLL, "fout_shared4_pll", "oscclk",
+           PLL_LOCKTIME_PLL_SHARED4, PLL_CON3_PLL_SHARED4, NULL),
+       PLL(pll_4311, CLK_FOUT_MMC_PLL, "fout_mmc_pll", "oscclk",
+           PLL_LOCKTIME_PLL_MMC, PLL_CON3_PLL_MMC, NULL),
+       PLL(pll_4311, CLK_FOUT_SHARED_MIF_PLL, "fout_shared_mif_pll", "oscclk",
+           PLL_LOCKTIME_PLL_SHARED_MIF, PLL_CON3_PLL_SHARED_MIF, NULL),
+};
+
+static const struct samsung_mux_clock top_mux_clks[] __initconst = {
+       MUX(CLK_MOUT_CMU_CP_MPLL_CLK_D2_USER, "mout_cmu_cp_mpll_clk_d2_user",
+           mout_cmu_cp_mpll_clk_d2_user_parents,
+           PLL_CON0_MUX_CP_MPLL_CLK_D2_USER, 4, 1),
+       MUX(CLK_MOUT_CMU_CP_MPLL_CLK_USER, "mout_cmu_cp_mpll_clk_user",
+           mout_cmu_cp_mpll_clk_user_parents, PLL_CON0_MUX_CP_MPLL_CLK_USER,
+           4, 1),
+       MUX(CLK_MOUT_CMU_AUD_AUDIF0, "mout_cmu_aud_audif0",
+           mout_cmu_aud_audif0_p, CLK_CON_MUX_CLKCMU_AUD_AUDIF0, 0, 3),
+       MUX(CLK_MOUT_CMU_AUD_AUDIF1, "mout_cmu_aud_audif1",
+           mout_cmu_aud_audif1_p, CLK_CON_MUX_CLKCMU_AUD_AUDIF1, 0, 3),
+       MUX(CLK_MOUT_CMU_AUD_CPU, "mout_cmu_aud_cpu", mout_cmu_aud_cpu_p,
+           CLK_CON_MUX_CLKCMU_AUD_CPU, 0, 3),
+       MUX(CLK_MOUT_CMU_CPUCL0_DBG_NOC, "mout_cmu_cpucl0_dbg_noc",
+           mout_cmu_cpucl0_dbg_noc_p, CLK_CON_MUX_CLKCMU_CPUCL0_DBG_NOC,
+           0, 2),
+       MUX(CLK_MOUT_CMU_CPUCL0_SWITCH, "mout_cmu_cpucl0_switch",
+           mout_cmu_cpucl0_switch_p, CLK_CON_MUX_CLKCMU_CPUCL0_SWITCH, 0, 3),
+       MUX(CLK_MOUT_CMU_CPUCL1_SWITCH, "mout_cmu_cpucl1_switch",
+           mout_cmu_cpucl1_switch_p, CLK_CON_MUX_CLKCMU_CPUCL1_SWITCH, 0, 3),
+       MUX(CLK_MOUT_CMU_CPUCL2_SWITCH, "mout_cmu_cpucl2_switch",
+           mout_cmu_cpucl2_switch_p, CLK_CON_MUX_CLKCMU_CPUCL2_SWITCH, 0, 3),
+       MUX(CLK_MOUT_CMU_DNC_NOC, "mout_cmu_dnc_noc", mout_cmu_dnc_noc_p,
+           CLK_CON_MUX_CLKCMU_DNC_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_DPUB_NOC, "mout_cmu_dpub_noc", mout_cmu_dpub_noc_p,
+           CLK_CON_MUX_CLKCMU_DPUB_NOC, 0, 1),
+       MUX(CLK_MOUT_CMU_DPUF_NOC, "mout_cmu_dpuf_noc", mout_cmu_dpuf_noc_p,
+           CLK_CON_MUX_CLKCMU_DPUF_NOC, 0, 1),
+       MUX(CLK_MOUT_CMU_DSP_NOC, "mout_cmu_dsp_noc", mout_cmu_dsp_noc_p,
+           CLK_CON_MUX_CLKCMU_DSP_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_DSU_SWITCH, "mout_cmu_dsu_switch",
+           mout_cmu_dsu_switch_p, CLK_CON_MUX_CLKCMU_DSU_SWITCH, 0, 3),
+       MUX(CLK_MOUT_CMU_G3D_SWITCH, "mout_cmu_g3d_switch",
+           mout_cmu_g3d_switch_p, CLK_CON_MUX_CLKCMU_G3D_SWITCH, 0, 3),
+       MUX(CLK_MOUT_CMU_GNPU_NOC, "mout_cmu_gnpu_noc", mout_cmu_gnpu_noc_p,
+           CLK_CON_MUX_CLKCMU_GNPU_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_UFS_MMC_CARD, "mout_cmu_ufs_mmc_card",
+           mout_cmu_ufs_mmc_card_p, CLK_CON_MUX_CLKCMU_UFS_MMC_CARD, 0, 2),
+       MUX(CLK_MOUT_CMU_M2M_NOC, "mout_cmu_m2m_noc", mout_cmu_m2m_noc_p,
+           CLK_CON_MUX_CLKCMU_M2M_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_NOCL0_NOC, "mout_cmu_nocl0_noc", mout_cmu_nocl0_noc_p,
+           CLK_CON_MUX_CLKCMU_NOCL0_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_NOCL1A_NOC, "mout_cmu_nocl1a_noc",
+           mout_cmu_nocl1a_noc_p, CLK_CON_MUX_CLKCMU_NOCL1A_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_NOCL1B_NOC0, "mout_cmu_nocl1b_noc0",
+           mout_cmu_nocl1b_noc0_p, CLK_CON_MUX_CLKCMU_NOCL1B_NOC0, 0, 3),
+       MUX(CLK_MOUT_CMU_NOCL1C_NOC, "mout_cmu_nocl1c_noc",
+           mout_cmu_nocl1c_noc_p, CLK_CON_MUX_CLKCMU_NOCL1C_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_SDMA_NOC, "mout_cmu_sdma_noc", mout_cmu_sdma_noc_p,
+           CLK_CON_MUX_CLKCMU_SDMA_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_CP_HISPEEDY_CLK, "mout_cmu_cp_hispeedy_clk",
+           mout_cmu_cp_hispeedy_clk_p, CLK_CON_MUX_CP_HISPEEDY_CLK, 0, 1),
+       MUX(CLK_MOUT_CMU_CP_SHARED0_CLK, "mout_cmu_cp_shared0_clk",
+           mout_cmu_cp_shared0_clk_p, CLK_CON_MUX_CP_SHARED0_CLK, 0, 2),
+       MUX(CLK_MOUT_CMU_CP_SHARED2_CLK, "mout_cmu_cp_shared2_clk",
+           mout_cmu_cp_shared2_clk_p, CLK_CON_MUX_CP_SHARED2_CLK, 0, 2),
+       MUX(CLK_MOUT_CMU_MUX_ALIVE_NOC, "mout_cmu_mux_alive_noc",
+           mout_cmu_mux_alive_noc_p, CLK_CON_MUX_MUX_CLKCMU_ALIVE_NOC, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_AUD_AUDIF0, "mout_cmu_mux_aud_audif0",
+           mout_cmu_mux_aud_audif0_p, CLK_CON_MUX_MUX_CLKCMU_AUD_AUDIF0,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_AUD_AUDIF1, "mout_cmu_mux_aud_audif1",
+           mout_cmu_mux_aud_audif1_p, CLK_CON_MUX_MUX_CLKCMU_AUD_AUDIF1,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_AUD_CPU, "mout_cmu_mux_aud_cpu",
+           mout_cmu_mux_aud_cpu_p, CLK_CON_MUX_MUX_CLKCMU_AUD_CPU, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_AUD_NOC, "mout_cmu_mux_aud_noc",
+           mout_cmu_mux_aud_noc_p, CLK_CON_MUX_MUX_CLKCMU_AUD_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_BRP_NOC, "mout_cmu_mux_brp_noc",
+           mout_cmu_mux_brp_noc_p, CLK_CON_MUX_MUX_CLKCMU_BRP_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_CIS_CLK0, "mout_cmu_mux_cis_clk0",
+           mout_cmu_mux_cis_clk0_p, CLK_CON_MUX_MUX_CLKCMU_CIS_CLK0, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CIS_CLK1, "mout_cmu_mux_cis_clk1",
+           mout_cmu_mux_cis_clk1_p, CLK_CON_MUX_MUX_CLKCMU_CIS_CLK1, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CIS_CLK2, "mout_cmu_mux_cis_clk2",
+           mout_cmu_mux_cis_clk2_p, CLK_CON_MUX_MUX_CLKCMU_CIS_CLK2, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CIS_CLK3, "mout_cmu_mux_cis_clk3",
+           mout_cmu_mux_cis_clk3_p, CLK_CON_MUX_MUX_CLKCMU_CIS_CLK3, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CIS_CLK4, "mout_cmu_mux_cis_clk4",
+           mout_cmu_mux_cis_clk4_p, CLK_CON_MUX_MUX_CLKCMU_CIS_CLK4, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CIS_CLK5, "mout_cmu_mux_cis_clk5",
+           mout_cmu_mux_cis_clk5_p, CLK_CON_MUX_MUX_CLKCMU_CIS_CLK5, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CIS_CLK6, "mout_cmu_mux_cis_clk6",
+           mout_cmu_mux_cis_clk6_p, CLK_CON_MUX_MUX_CLKCMU_CIS_CLK6, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CIS_CLK7, "mout_cmu_mux_cis_clk7",
+           mout_cmu_mux_cis_clk7_p, CLK_CON_MUX_MUX_CLKCMU_CIS_CLK7, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CMU_BOOST, "mout_cmu_mux_cmu_boost",
+           mout_cmu_mux_cmu_boost_p, CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST, 0, 2),
+       MUX(CLK_MOUT_CMU_MUX_CMU_BOOST_CAM, "mout_cmu_mux_cmu_boost_cam",
+           mout_cmu_mux_cmu_boost_cam_p, CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_CAM,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_CMU_BOOST_CPU, "mout_cmu_mux_cmu_boost_cpu",
+           mout_cmu_mux_cmu_boost_cpu_p, CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_CPU,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_CMU_BOOST_MIF, "mout_cmu_mux_cmu_boost_mif",
+           mout_cmu_mux_cmu_boost_mif_p, CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_MIF,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_CPUCL0_DBG_NOC, "mout_cmu_mux_cpucl0_dbg_noc",
+           mout_cmu_mux_cpucl0_dbg_noc_p,
+           CLK_CON_MUX_MUX_CLKCMU_CPUCL0_DBG_NOC, 0, 2),
+       MUX(CLK_MOUT_CMU_MUX_CPUCL0_NOCP, "mout_cmu_mux_cpucl0_nocp",
+           mout_cmu_mux_cpucl0_nocp_p, CLK_CON_MUX_MUX_CLKCMU_CPUCL0_NOCP,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_CPUCL0_SWITCH, "mout_cmu_mux_cpucl0_switch",
+           mout_cmu_mux_cpucl0_switch_p, CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_CPUCL1_SWITCH, "mout_cmu_mux_cpucl1_switch",
+           mout_cmu_mux_cpucl1_switch_p, CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_CPUCL2_SWITCH, "mout_cmu_mux_cpucl2_switch",
+           mout_cmu_mux_cpucl2_switch_p, CLK_CON_MUX_MUX_CLKCMU_CPUCL2_SWITCH,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_CSIS_DCPHY, "mout_cmu_mux_csis_dcphy",
+           mout_cmu_mux_csis_dcphy_p, CLK_CON_MUX_MUX_CLKCMU_CSIS_DCPHY,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_CSIS_NOC, "mout_cmu_mux_csis_noc",
+           mout_cmu_mux_csis_noc_p, CLK_CON_MUX_MUX_CLKCMU_CSIS_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_CSIS_OIS_MCU, "mout_cmu_mux_csis_ois_mcu",
+           mout_cmu_mux_csis_ois_mcu_p, CLK_CON_MUX_MUX_CLKCMU_CSIS_OIS_MCU,
+           0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CSTAT_NOC, "mout_cmu_mux_cstat_noc",
+           mout_cmu_mux_cstat_noc_p, CLK_CON_MUX_MUX_CLKCMU_CSTAT_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_DNC_NOC, "mout_cmu_mux_dnc_noc",
+           mout_cmu_mux_dnc_noc_p, CLK_CON_MUX_MUX_CLKCMU_DNC_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_DPUB, "mout_cmu_mux_dpub", mout_cmu_mux_dpub_p,
+           CLK_CON_MUX_MUX_CLKCMU_DPUB, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_DPUB_ALT, "mout_cmu_mux_dpub_alt",
+           mout_cmu_mux_dpub_alt_p, CLK_CON_MUX_MUX_CLKCMU_DPUB_ALT, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_DPUB_DSIM, "mout_cmu_mux_dpub_dsim",
+           mout_cmu_mux_dpub_dsim_p, CLK_CON_MUX_MUX_CLKCMU_DPUB_DSIM, 0, 2),
+       MUX(CLK_MOUT_CMU_MUX_DPUF, "mout_cmu_mux_dpuf", mout_cmu_mux_dpuf_p,
+           CLK_CON_MUX_MUX_CLKCMU_DPUF, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_DPUF_ALT, "mout_cmu_mux_dpuf_alt",
+           mout_cmu_mux_dpuf_alt_p, CLK_CON_MUX_MUX_CLKCMU_DPUF_ALT, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_DSP_NOC, "mout_cmu_mux_dsp_noc",
+           mout_cmu_mux_dsp_noc_p, CLK_CON_MUX_MUX_CLKCMU_DSP_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_DSU_SWITCH, "mout_cmu_mux_dsu_switch",
+           mout_cmu_mux_dsu_switch_p, CLK_CON_MUX_MUX_CLKCMU_DSU_SWITCH,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_G3D_NOCP, "mout_cmu_mux_g3d_nocp",
+           mout_cmu_mux_g3d_nocp_p, CLK_CON_MUX_MUX_CLKCMU_G3D_NOCP, 0, 2),
+       MUX(CLK_MOUT_CMU_MUX_G3D_SWITCH, "mout_cmu_mux_g3d_switch",
+           mout_cmu_mux_g3d_switch_p, CLK_CON_MUX_MUX_CLKCMU_G3D_SWITCH,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_GNPU_NOC, "mout_cmu_mux_gnpu_noc",
+           mout_cmu_mux_gnpu_noc_p, CLK_CON_MUX_MUX_CLKCMU_GNPU_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_HSI0_DPGTC, "mout_cmu_mux_hsi0_dpgtc",
+           mout_cmu_mux_hsi0_dpgtc_p, CLK_CON_MUX_MUX_CLKCMU_HSI0_DPGTC,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_HSI0_DPOSC, "mout_cmu_mux_hsi0_dposc",
+           mout_cmu_mux_hsi0_dposc_p, CLK_CON_MUX_MUX_CLKCMU_HSI0_DPOSC,
+           0, 1),
+       MUX(CLK_MOUT_CMU_MUX_HSI0_NOC, "mout_cmu_mux_hsi0_noc",
+           mout_cmu_mux_hsi0_noc_p, CLK_CON_MUX_MUX_CLKCMU_HSI0_NOC, 0, 2),
+       MUX(CLK_MOUT_CMU_MUX_HSI0_USB32DRD, "mout_cmu_mux_hsi0_usb32drd",
+           mout_cmu_mux_hsi0_usb32drd_p, CLK_CON_MUX_MUX_CLKCMU_HSI0_USB32DRD,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_UFS_MMC_CARD, "mout_cmu_mux_ufs_mmc_card",
+           mout_cmu_mux_ufs_mmc_card_p, CLK_CON_MUX_MUX_CLKCMU_UFS_MMC_CARD,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_HSI1_NOC, "mout_cmu_mux_hsi1_noc",
+           mout_cmu_mux_hsi1_noc_p, CLK_CON_MUX_MUX_CLKCMU_HSI1_NOC, 0, 2),
+       MUX(CLK_MOUT_CMU_MUX_HSI1_PCIE, "mout_cmu_mux_hsi1_pcie",
+           mout_cmu_mux_hsi1_pcie_p, CLK_CON_MUX_MUX_CLKCMU_HSI1_PCIE, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_UFS_UFS_EMBD, "mout_cmu_mux_ufs_ufs_embd",
+           mout_cmu_mux_ufs_ufs_embd_p, CLK_CON_MUX_MUX_CLKCMU_UFS_UFS_EMBD,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_LME_LME, "mout_cmu_mux_lme_lme",
+           mout_cmu_mux_lme_lme_p, CLK_CON_MUX_MUX_CLKCMU_LME_LME, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_LME_NOC, "mout_cmu_mux_lme_noc",
+           mout_cmu_mux_lme_noc_p, CLK_CON_MUX_MUX_CLKCMU_LME_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_M2M_NOC, "mout_cmu_mux_m2m_noc",
+           mout_cmu_mux_m2m_noc_p, CLK_CON_MUX_MUX_CLKCMU_M2M_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_MCSC_MCSC, "mout_cmu_mux_mcsc_mcsc",
+           mout_cmu_mux_mcsc_mcsc_p, CLK_CON_MUX_MUX_CLKCMU_MCSC_MCSC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_MCSC_NOC, "mout_cmu_mux_mcsc_noc",
+           mout_cmu_mux_mcsc_noc_p, CLK_CON_MUX_MUX_CLKCMU_MCSC_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_MFC0_MFC0, "mout_cmu_mux_mfc0_mfc0",
+           mout_cmu_mux_mfc0_mfc0_p, CLK_CON_MUX_MUX_CLKCMU_MFC0_MFC0, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_MFC0_WFD, "mout_cmu_mux_mfc0_wfd",
+           mout_cmu_mux_mfc0_wfd_p, CLK_CON_MUX_MUX_CLKCMU_MFC0_WFD, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_MFC1_MFC1, "mout_cmu_mux_mfc1_mfc1",
+           mout_cmu_mux_mfc1_mfc1_p, CLK_CON_MUX_MUX_CLKCMU_MFC1_MFC1, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_MIF_NOCP, "mout_cmu_mux_mif_nocp",
+           mout_cmu_mux_mif_nocp_p, CLK_CON_MUX_MUX_CLKCMU_MIF_NOCP, 0, 2),
+       MUX(CLK_MOUT_CMU_MUX_MIF_SWITCH, "mout_cmu_mux_mif_switch",
+           mout_cmu_mux_mif_switch_p, CLK_CON_MUX_MUX_CLKCMU_MIF_SWITCH,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_NOCL0_NOC, "mout_cmu_mux_nocl0_noc",
+           mout_cmu_mux_nocl0_noc_p, CLK_CON_MUX_MUX_CLKCMU_NOCL0_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_NOCL1A_NOC, "mout_cmu_mux_nocl1a_noc",
+           mout_cmu_mux_nocl1a_noc_p, CLK_CON_MUX_MUX_CLKCMU_NOCL1A_NOC,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_NOCL1B_NOC0, "mout_cmu_mux_nocl1b_noc0",
+           mout_cmu_mux_nocl1b_noc0_p, CLK_CON_MUX_MUX_CLKCMU_NOCL1B_NOC0,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_NOCL1B_NOC1, "mout_cmu_mux_nocl1b_noc1",
+           mout_cmu_mux_nocl1b_noc1_p, CLK_CON_MUX_MUX_CLKCMU_NOCL1B_NOC1,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_NOCL1C_NOC, "mout_cmu_mux_nocl1c_noc",
+           mout_cmu_mux_nocl1c_noc_p, CLK_CON_MUX_MUX_CLKCMU_NOCL1C_NOC,
+           0, 3),
+       MUX(CLK_MOUT_CMU_MUX_PERIC0_IP0, "mout_cmu_mux_peric0_ip0",
+           mout_cmu_mux_peric0_ip0_p, CLK_CON_MUX_MUX_CLKCMU_PERIC0_IP0,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_PERIC0_IP1, "mout_cmu_mux_peric0_ip1",
+           mout_cmu_mux_peric0_ip1_p, CLK_CON_MUX_MUX_CLKCMU_PERIC0_IP1,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_PERIC0_NOC, "mout_cmu_mux_peric0_noc",
+           mout_cmu_mux_peric0_noc_p, CLK_CON_MUX_MUX_CLKCMU_PERIC0_NOC,
+           0, 1),
+       MUX(CLK_MOUT_CMU_MUX_PERIC1_IP0, "mout_cmu_mux_peric1_ip0",
+           mout_cmu_mux_peric1_ip0_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_IP0,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_PERIC1_IP1, "mout_cmu_mux_peric1_ip1",
+           mout_cmu_mux_peric1_ip1_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_IP1,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_PERIC1_NOC, "mout_cmu_mux_peric1_noc",
+           mout_cmu_mux_peric1_noc_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_NOC,
+           0, 1),
+       MUX(CLK_MOUT_CMU_MUX_PERIC2_IP0, "mout_cmu_mux_peric2_ip0",
+           mout_cmu_mux_peric2_ip0_p, CLK_CON_MUX_MUX_CLKCMU_PERIC2_IP0,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_PERIC2_IP1, "mout_cmu_mux_peric2_ip1",
+           mout_cmu_mux_peric2_ip1_p, CLK_CON_MUX_MUX_CLKCMU_PERIC2_IP1,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_PERIC2_NOC, "mout_cmu_mux_peric2_noc",
+           mout_cmu_mux_peric2_noc_p, CLK_CON_MUX_MUX_CLKCMU_PERIC2_NOC,
+           0, 1),
+       MUX(CLK_MOUT_CMU_MUX_PERIS_GIC, "mout_cmu_mux_peris_gic",
+           mout_cmu_mux_peris_gic_p, CLK_CON_MUX_MUX_CLKCMU_PERIS_GIC, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_PERIS_NOC, "mout_cmu_mux_peris_noc",
+           mout_cmu_mux_peris_noc_p, CLK_CON_MUX_MUX_CLKCMU_PERIS_NOC, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_SDMA_NOC, "mout_cmu_mux_sdma_noc",
+           mout_cmu_mux_sdma_noc_p, CLK_CON_MUX_MUX_CLKCMU_SDMA_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_SSP_NOC, "mout_cmu_mux_ssp_noc",
+           mout_cmu_mux_ssp_noc_p, CLK_CON_MUX_MUX_CLKCMU_SSP_NOC, 0, 2),
+       MUX(CLK_MOUT_CMU_MUX_VTS_DMIC, "mout_cmu_mux_vts_dmic",
+           mout_cmu_mux_vts_dmic_p, CLK_CON_MUX_MUX_CLKCMU_VTS_DMIC, 0, 2),
+       MUX(CLK_MOUT_CMU_MUX_YUVP_NOC, "mout_cmu_mux_yuvp_noc",
+           mout_cmu_mux_yuvp_noc_p, CLK_CON_MUX_MUX_CLKCMU_YUVP_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_CMU_CMUREF, "mout_cmu_mux_cmu_cmuref",
+           mout_cmu_mux_cmu_cmuref_p, CLK_CON_MUX_MUX_CMU_CMUREF, 0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CP_HISPEEDY_CLK, "mout_cmu_mux_cp_hispeedy_clk",
+           mout_cmu_mux_cp_hispeedy_clk_p, CLK_CON_MUX_MUX_CP_HISPEEDY_CLK,
+           0, 1),
+       MUX(CLK_MOUT_CMU_MUX_CP_SHARED0_CLK, "mout_cmu_mux_cp_shared0_clk",
+           mout_cmu_mux_cp_shared0_clk_p, CLK_CON_MUX_MUX_CP_SHARED0_CLK,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_CP_SHARED1_CLK, "mout_cmu_mux_cp_shared1_clk",
+           mout_cmu_mux_cp_shared1_clk_p, CLK_CON_MUX_MUX_CP_SHARED1_CLK,
+           0, 2),
+       MUX(CLK_MOUT_CMU_MUX_CP_SHARED2_CLK, "mout_cmu_mux_cp_shared2_clk",
+           mout_cmu_mux_cp_shared2_clk_p, CLK_CON_MUX_MUX_CP_SHARED2_CLK,
+           0, 2),
+       MUX(CLK_MOUT_CMU_M2M_FRC, "mout_cmu_m2m_frc", mout_cmu_m2m_frc_p,
+           CLK_CON_MUX_CLKCMU_M2M_FRC, 0, 3),
+       MUX(CLK_MOUT_CMU_MCSC_MCSC, "mout_cmu_mcsc_mcsc", mout_cmu_mcsc_mcsc_p,
+           CLK_CON_MUX_CLKCMU_MCSC_MCSC, 0, 3),
+       MUX(CLK_MOUT_CMU_MCSC_NOC, "mout_cmu_mcsc_noc", mout_cmu_mcsc_noc_p,
+           CLK_CON_MUX_CLKCMU_MCSC_NOC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_M2M_FRC, "mout_cmu_mux_m2m_frc",
+           mout_cmu_mux_m2m_frc_p, CLK_CON_MUX_MUX_CLKCMU_M2M_FRC, 0, 3),
+       MUX(CLK_MOUT_CMU_MUX_UFS_NOC, "mout_cmu_mux_ufs_noc",
+           mout_cmu_mux_ufs_noc_p, CLK_CON_MUX_MUX_CLKCMU_UFS_NOC, 0, 2),
+};
+
+static const struct samsung_div_clock top_div_clks[] __initconst = {
+       DIV(CLK_DOUT_CMU_ALIVE_NOC, "dout_cmu_alive_noc",
+           "mout_cmu_mux_alive_noc", CLK_CON_DIV_CLKCMU_ALIVE_NOC, 0, 2),
+       DIV(CLK_DOUT_CMU_AUD_NOC, "dout_cmu_aud_noc", "mout_cmu_mux_aud_noc",
+           CLK_CON_DIV_CLKCMU_AUD_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_BRP_NOC, "dout_cmu_brp_noc", "mout_cmu_mux_brp_noc",
+           CLK_CON_DIV_CLKCMU_BRP_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_CMU_BOOST, "dout_cmu_cmu_boost",
+           "mout_cmu_mux_cmu_boost", CLK_CON_DIV_CLKCMU_CMU_BOOST, 0, 3),
+       DIV(CLK_DOUT_CMU_CMU_BOOST_CAM, "dout_cmu_cmu_boost_cam",
+           "mout_cmu_mux_cmu_boost_cam", CLK_CON_DIV_CLKCMU_CMU_BOOST_CAM,
+           0, 3),
+       DIV(CLK_DOUT_CMU_CMU_BOOST_CPU, "dout_cmu_cmu_boost_cpu",
+           "mout_cmu_mux_cmu_boost_cpu", CLK_CON_DIV_CLKCMU_CMU_BOOST_CPU,
+           0, 3),
+       DIV(CLK_DOUT_CMU_CMU_BOOST_MIF, "dout_cmu_cmu_boost_mif",
+           "mout_cmu_mux_cmu_boost_mif", CLK_CON_DIV_CLKCMU_CMU_BOOST_MIF,
+           0, 3),
+       DIV(CLK_DOUT_CMU_CPUCL0_NOCP, "dout_cmu_cpucl0_nocp",
+           "mout_cmu_mux_cpucl0_nocp", CLK_CON_DIV_CLKCMU_CPUCL0_NOCP, 0, 4),
+       DIV(CLK_DOUT_CMU_CSIS_DCPHY, "dout_cmu_csis_dcphy",
+           "mout_cmu_mux_csis_dcphy", CLK_CON_DIV_CLKCMU_CSIS_DCPHY, 0, 4),
+       DIV(CLK_DOUT_CMU_CSIS_NOC, "dout_cmu_csis_noc",
+           "mout_cmu_mux_csis_noc", CLK_CON_DIV_CLKCMU_CSIS_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_CSIS_OIS_MCU, "dout_cmu_csis_ois_mcu",
+           "mout_cmu_mux_csis_ois_mcu", CLK_CON_DIV_CLKCMU_CSIS_OIS_MCU,
+           0, 4),
+       DIV(CLK_DOUT_CMU_CSTAT_NOC, "dout_cmu_cstat_noc",
+           "mout_cmu_mux_cstat_noc", CLK_CON_DIV_CLKCMU_CSTAT_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_DPUB_DSIM, "dout_cmu_dpub_dsim",
+           "mout_cmu_mux_dpub_dsim", CLK_CON_DIV_CLKCMU_DPUB_DSIM, 0, 4),
+       DIV(CLK_DOUT_CMU_LME_LME, "dout_cmu_lme_lme", "mout_cmu_mux_lme_lme",
+           CLK_CON_DIV_CLKCMU_LME_LME, 0, 4),
+       DIV(CLK_DOUT_CMU_G3D_NOCP, "dout_cmu_g3d_nocp",
+           "mout_cmu_mux_g3d_nocp", CLK_CON_DIV_CLKCMU_G3D_NOCP, 0, 3),
+       DIV(CLK_DOUT_CMU_HSI0_DPGTC, "dout_cmu_hsi0_dpgtc",
+           "mout_cmu_mux_hsi0_dpgtc", CLK_CON_DIV_CLKCMU_HSI0_DPGTC, 0, 3),
+       DIV(CLK_DOUT_CMU_HSI0_DPOSC, "dout_cmu_hsi0_dposc",
+           "mout_cmu_mux_hsi0_dposc", CLK_CON_DIV_CLKCMU_HSI0_DPOSC, 0, 5),
+       DIV(CLK_DOUT_CMU_HSI0_NOC, "dout_cmu_hsi0_noc",
+           "mout_cmu_mux_hsi0_noc", CLK_CON_DIV_CLKCMU_HSI0_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_HSI0_USB32DRD, "dout_cmu_hsi0_usb32drd",
+           "mout_cmu_mux_hsi0_usb32drd", CLK_CON_DIV_CLKCMU_HSI0_USB32DRD,
+           0, 5),
+       DIV(CLK_DOUT_CMU_HSI1_NOC, "dout_cmu_hsi1_noc",
+           "mout_cmu_mux_hsi1_noc", CLK_CON_DIV_CLKCMU_HSI1_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_HSI1_PCIE, "dout_cmu_hsi1_pcie",
+           "mout_cmu_mux_hsi1_pcie", CLK_CON_DIV_CLKCMU_HSI1_PCIE, 0, 8),
+       DIV(CLK_DOUT_CMU_UFS_UFS_EMBD, "dout_cmu_ufs_ufs_embd",
+           "mout_cmu_mux_ufs_ufs_embd", CLK_CON_DIV_CLKCMU_UFS_UFS_EMBD,
+           0, 4),
+       DIV(CLK_DOUT_CMU_LME_NOC, "dout_cmu_lme_noc", "mout_cmu_mux_lme_noc",
+           CLK_CON_DIV_CLKCMU_LME_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_MFC0_MFC0, "dout_cmu_mfc0_mfc0",
+           "mout_cmu_mux_mfc0_mfc0", CLK_CON_DIV_CLKCMU_MFC0_MFC0, 0, 4),
+       DIV(CLK_DOUT_CMU_MFC0_WFD, "dout_cmu_mfc0_wfd",
+           "mout_cmu_mux_mfc0_wfd", CLK_CON_DIV_CLKCMU_MFC0_WFD, 0, 4),
+       DIV(CLK_DOUT_CMU_MFC1_MFC1, "dout_cmu_mfc1_mfc1",
+           "mout_cmu_mux_mfc1_mfc1", CLK_CON_DIV_CLKCMU_MFC1_MFC1, 0, 4),
+       DIV(CLK_DOUT_CMU_MIF_NOCP, "dout_cmu_mif_nocp",
+           "mout_cmu_mux_mif_nocp", CLK_CON_DIV_CLKCMU_MIF_NOCP, 0, 4),
+       DIV(CLK_DOUT_CMU_NOCL1B_NOC1, "dout_cmu_nocl1b_noc1",
+           "mout_cmu_mux_nocl1b_noc1", CLK_CON_DIV_CLKCMU_NOCL1B_NOC1, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIC0_IP0, "dout_cmu_peric0_ip0",
+           "mout_cmu_mux_peric0_ip0", CLK_CON_DIV_CLKCMU_PERIC0_IP0, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIC0_IP1, "dout_cmu_peric0_ip1",
+           "mout_cmu_mux_peric0_ip1", CLK_CON_DIV_CLKCMU_PERIC0_IP1, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIC0_NOC, "dout_cmu_peric0_noc",
+           "mout_cmu_mux_peric0_noc", CLK_CON_DIV_CLKCMU_PERIC0_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIC1_IP0, "dout_cmu_peric1_ip0",
+           "mout_cmu_mux_peric1_ip0", CLK_CON_DIV_CLKCMU_PERIC1_IP0, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIC1_IP1, "dout_cmu_peric1_ip1",
+           "mout_cmu_mux_peric1_ip1", CLK_CON_DIV_CLKCMU_PERIC1_IP1, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIC1_NOC, "dout_cmu_peric1_noc",
+           "mout_cmu_mux_peric1_noc", CLK_CON_DIV_CLKCMU_PERIC1_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIC2_IP0, "dout_cmu_peric2_ip0",
+           "mout_cmu_mux_peric2_ip0", CLK_CON_DIV_CLKCMU_PERIC2_IP0, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIC2_IP1, "dout_cmu_peric2_ip1",
+           "mout_cmu_mux_peric2_ip1", CLK_CON_DIV_CLKCMU_PERIC2_IP1, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIC2_NOC, "dout_cmu_peric2_noc",
+           "mout_cmu_mux_peric2_noc", CLK_CON_DIV_CLKCMU_PERIC2_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIS_GIC, "dout_cmu_peris_gic",
+           "mout_cmu_mux_peris_gic", CLK_CON_DIV_CLKCMU_PERIS_GIC, 0, 4),
+       DIV(CLK_DOUT_CMU_PERIS_NOC, "dout_cmu_peris_noc",
+           "mout_cmu_mux_peris_noc", CLK_CON_DIV_CLKCMU_PERIS_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_SSP_NOC, "dout_cmu_ssp_noc", "mout_cmu_mux_ssp_noc",
+           CLK_CON_DIV_CLKCMU_SSP_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_VTS_DMIC, "dout_cmu_vts_dmic",
+           "mout_cmu_mux_vts_dmic", CLK_CON_DIV_CLKCMU_VTS_DMIC, 0, 6),
+       DIV(CLK_DOUT_CMU_YUVP_NOC, "dout_cmu_yuvp_noc",
+           "mout_cmu_mux_yuvp_noc", CLK_CON_DIV_CLKCMU_YUVP_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_CP_SHARED1_CLK, "dout_cmu_cp_shared1_clk",
+           "mout_cmu_mux_cp_shared1_clk", CLK_CON_DIV_CP_SHARED1_CLK, 0, 3),
+       DIV(CLK_DOUT_CMU_DIV_AUD_AUDIF0, "dout_cmu_div_aud_audif0",
+           "mout_cmu_mux_aud_audif0", CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF0,
+           0, 6),
+       DIV(CLK_DOUT_CMU_DIV_AUD_AUDIF0_SM, "dout_cmu_div_aud_audif0_sm",
+           "mout_cmu_aud_audif0", CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF0_SM, 0, 6),
+       DIV(CLK_DOUT_CMU_DIV_AUD_AUDIF1, "dout_cmu_div_aud_audif1",
+           "mout_cmu_mux_aud_audif1", CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF1,
+           0, 6),
+       DIV(CLK_DOUT_CMU_DIV_AUD_AUDIF1_SM, "dout_cmu_div_aud_audif1_sm",
+           "mout_cmu_aud_audif1", CLK_CON_DIV_DIV_CLKCMU_AUD_AUDIF1_SM, 0, 6),
+       DIV(CLK_DOUT_CMU_DIV_AUD_CPU, "dout_cmu_div_aud_cpu",
+           "mout_cmu_mux_aud_cpu", CLK_CON_DIV_DIV_CLKCMU_AUD_CPU, 0, 3),
+       DIV(CLK_DOUT_CMU_DIV_AUD_CPU_SM, "dout_cmu_div_aud_cpu_sm",
+           "mout_cmu_aud_cpu", CLK_CON_DIV_DIV_CLKCMU_AUD_CPU_SM, 0, 3),
+       DIV(CLK_DOUT_CMU_DIV_CIS_CLK0, "dout_cmu_div_cis_clk0",
+           "mout_cmu_mux_cis_clk0", CLK_CON_DIV_DIV_CLKCMU_CIS_CLK0, 0, 5),
+       DIV(CLK_DOUT_CMU_DIV_CIS_CLK1, "dout_cmu_div_cis_clk1",
+           "mout_cmu_mux_cis_clk1", CLK_CON_DIV_DIV_CLKCMU_CIS_CLK1, 0, 5),
+       DIV(CLK_DOUT_CMU_DIV_CIS_CLK2, "dout_cmu_div_cis_clk2",
+           "mout_cmu_mux_cis_clk2", CLK_CON_DIV_DIV_CLKCMU_CIS_CLK2, 0, 5),
+       DIV(CLK_DOUT_CMU_DIV_CIS_CLK3, "dout_cmu_div_cis_clk3",
+           "mout_cmu_mux_cis_clk3", CLK_CON_DIV_DIV_CLKCMU_CIS_CLK3, 0, 5),
+       DIV(CLK_DOUT_CMU_DIV_CIS_CLK4, "dout_cmu_div_cis_clk4",
+           "mout_cmu_mux_cis_clk4", CLK_CON_DIV_DIV_CLKCMU_CIS_CLK4, 0, 5),
+       DIV(CLK_DOUT_CMU_DIV_CIS_CLK5, "dout_cmu_div_cis_clk5",
+           "mout_cmu_mux_cis_clk5", CLK_CON_DIV_DIV_CLKCMU_CIS_CLK5, 0, 5),
+       DIV(CLK_DOUT_CMU_DIV_CIS_CLK6, "dout_cmu_div_cis_clk6",
+           "mout_cmu_mux_cis_clk6", CLK_CON_DIV_DIV_CLKCMU_CIS_CLK6, 0, 5),
+       DIV(CLK_DOUT_CMU_DIV_CIS_CLK7, "dout_cmu_div_cis_clk7",
+           "mout_cmu_mux_cis_clk7", CLK_CON_DIV_DIV_CLKCMU_CIS_CLK7, 0, 5),
+       DIV(CLK_DOUT_CMU_DIV_CPUCL0_DBG_NOC, "dout_cmu_div_cpucl0_dbg_noc",
+           "mout_cmu_mux_cpucl0_dbg_noc",
+           CLK_CON_DIV_DIV_CLKCMU_CPUCL0_DBG_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_CPUCL0_DBG_NOC_SM,
+           "dout_cmu_div_cpucl0_dbg_noc_sm", "mout_cmu_cpucl0_dbg_noc",
+           CLK_CON_DIV_DIV_CLKCMU_CPUCL0_DBG_NOC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_CPUCL0_SWITCH, "dout_cmu_div_cpucl0_switch",
+           "mout_cmu_mux_cpucl0_switch", CLK_CON_DIV_DIV_CLKCMU_CPUCL0_SWITCH,
+           0, 3),
+       DIV(CLK_DOUT_CMU_DIV_CPUCL0_SWITCH_SM, "dout_cmu_div_cpucl0_switch_sm",
+           "mout_cmu_cpucl0_switch", CLK_CON_DIV_DIV_CLKCMU_CPUCL0_SWITCH_SM,
+           0, 3),
+       DIV(CLK_DOUT_CMU_DIV_CPUCL1_SWITCH, "dout_cmu_div_cpucl1_switch",
+           "mout_cmu_mux_cpucl1_switch", CLK_CON_DIV_DIV_CLKCMU_CPUCL1_SWITCH,
+           0, 3),
+       DIV(CLK_DOUT_CMU_DIV_CPUCL1_SWITCH_SM, "dout_cmu_div_cpucl1_switch_sm",
+           "mout_cmu_cpucl1_switch", CLK_CON_DIV_DIV_CLKCMU_CPUCL1_SWITCH_SM,
+           0, 3),
+       DIV(CLK_DOUT_CMU_DIV_CPUCL2_SWITCH, "dout_cmu_div_cpucl2_switch",
+           "mout_cmu_mux_cpucl2_switch", CLK_CON_DIV_DIV_CLKCMU_CPUCL2_SWITCH,
+           0, 3),
+       DIV(CLK_DOUT_CMU_DIV_CPUCL2_SWITCH_SM, "dout_cmu_div_cpucl2_switch_sm",
+           "mout_cmu_cpucl2_switch", CLK_CON_DIV_DIV_CLKCMU_CPUCL2_SWITCH_SM,
+           0, 3),
+       DIV(CLK_DOUT_CMU_DIV_DNC_NOC, "dout_cmu_div_dnc_noc",
+           "mout_cmu_mux_dnc_noc", CLK_CON_DIV_DIV_CLKCMU_DNC_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_DNC_NOC_SM, "dout_cmu_div_dnc_noc_sm",
+           "mout_cmu_dnc_noc", CLK_CON_DIV_DIV_CLKCMU_DNC_NOC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_DPUB, "dout_cmu_div_dpub", "mout_cmu_mux_dpub",
+           CLK_CON_DIV_DIV_CLKCMU_DPUB, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_DPUB_ALT, "dout_cmu_div_dpub_alt",
+           "mout_cmu_mux_dpub_alt", CLK_CON_DIV_DIV_CLKCMU_DPUB_ALT, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_DPUF, "dout_cmu_div_dpuf", "mout_cmu_mux_dpuf",
+           CLK_CON_DIV_DIV_CLKCMU_DPUF, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_DPUF_ALT, "dout_cmu_div_dpuf_alt",
+           "mout_cmu_mux_dpuf_alt", CLK_CON_DIV_DIV_CLKCMU_DPUF_ALT, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_DSP_NOC, "dout_cmu_div_dsp_noc",
+           "mout_cmu_mux_dsp_noc", CLK_CON_DIV_DIV_CLKCMU_DSP_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_DSP_NOC_SM, "dout_cmu_div_dsp_noc_sm",
+           "mout_cmu_dsp_noc", CLK_CON_DIV_DIV_CLKCMU_DSP_NOC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_DSU_SWITCH, "dout_cmu_div_dsu_switch",
+           "mout_cmu_mux_dsu_switch", CLK_CON_DIV_DIV_CLKCMU_DSU_SWITCH,
+           0, 3),
+       DIV(CLK_DOUT_CMU_DIV_DSU_SWITCH_SM, "dout_cmu_div_dsu_switch_sm",
+           "mout_cmu_dsu_switch", CLK_CON_DIV_DIV_CLKCMU_DSU_SWITCH_SM, 0, 3),
+       DIV(CLK_DOUT_CMU_DIV_G3D_SWITCH, "dout_cmu_div_g3d_switch",
+           "mout_cmu_mux_g3d_switch", CLK_CON_DIV_DIV_CLKCMU_G3D_SWITCH,
+           0, 3),
+       DIV(CLK_DOUT_CMU_DIV_G3D_SWITCH_SM, "dout_cmu_div_g3d_switch_sm",
+           "mout_cmu_g3d_switch", CLK_CON_DIV_DIV_CLKCMU_G3D_SWITCH_SM, 0, 3),
+       DIV(CLK_DOUT_CMU_DIV_GNPU_NOC, "dout_cmu_div_gnpu_noc",
+           "mout_cmu_mux_gnpu_noc", CLK_CON_DIV_DIV_CLKCMU_GNPU_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_GNPU_NOC_SM, "dout_cmu_div_gnpu_noc_sm",
+           "mout_cmu_gnpu_noc", CLK_CON_DIV_DIV_CLKCMU_GNPU_NOC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_UFS_MMC_CARD, "dout_cmu_div_ufs_mmc_card",
+           "mout_cmu_mux_ufs_mmc_card", CLK_CON_DIV_DIV_CLKCMU_UFS_MMC_CARD,
+           0, 9),
+       DIV(CLK_DOUT_CMU_DIV_UFS_MMC_CARD_SM, "dout_cmu_div_ufs_mmc_card_sm",
+           "mout_cmu_ufs_mmc_card", CLK_CON_DIV_DIV_CLKCMU_UFS_MMC_CARD_SM,
+           0, 9),
+       DIV(CLK_DOUT_CMU_DIV_M2M_NOC, "dout_cmu_div_m2m_noc",
+           "mout_cmu_mux_m2m_noc", CLK_CON_DIV_DIV_CLKCMU_M2M_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_M2M_NOC_SM, "dout_cmu_div_m2m_noc_sm",
+           "mout_cmu_m2m_noc", CLK_CON_DIV_DIV_CLKCMU_M2M_NOC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_NOCL0_NOC, "dout_cmu_div_nocl0_noc",
+           "mout_cmu_mux_nocl0_noc", CLK_CON_DIV_DIV_CLKCMU_NOCL0_NOC,
+           0, 4),
+       DIV(CLK_DOUT_CMU_DIV_NOCL0_NOC_SM, "dout_cmu_div_nocl0_noc_sm",
+           "mout_cmu_nocl0_noc", CLK_CON_DIV_DIV_CLKCMU_NOCL0_NOC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_NOCL1A_NOC, "dout_cmu_div_nocl1a_noc",
+           "mout_cmu_mux_nocl1a_noc", CLK_CON_DIV_DIV_CLKCMU_NOCL1A_NOC,
+           0, 4),
+       DIV(CLK_DOUT_CMU_DIV_NOCL1A_NOC_SM, "dout_cmu_div_nocl1a_noc_sm",
+           "mout_cmu_nocl1a_noc", CLK_CON_DIV_DIV_CLKCMU_NOCL1A_NOC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_NOCL1B_NOC0, "dout_cmu_div_nocl1b_noc0",
+           "mout_cmu_mux_nocl1b_noc0", CLK_CON_DIV_DIV_CLKCMU_NOCL1B_NOC0,
+           0, 4),
+       DIV(CLK_DOUT_CMU_DIV_NOCL1B_NOC0_SM, "dout_cmu_div_nocl1b_noc0_sm",
+           "mout_cmu_nocl1b_noc0", CLK_CON_DIV_DIV_CLKCMU_NOCL1B_NOC0_SM,
+           0, 4),
+       DIV(CLK_DOUT_CMU_DIV_NOCL1C_NOC, "dout_cmu_div_nocl1c_noc",
+           "mout_cmu_mux_nocl1c_noc", CLK_CON_DIV_DIV_CLKCMU_NOCL1C_NOC,
+           0, 4),
+       DIV(CLK_DOUT_CMU_DIV_NOCL1C_NOC_SM, "dout_cmu_div_nocl1c_noc_sm",
+           "mout_cmu_nocl1c_noc", CLK_CON_DIV_DIV_CLKCMU_NOCL1C_NOC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_SDMA_NOC, "dout_cmu_div_sdma_noc",
+           "mout_cmu_mux_sdma_noc", CLK_CON_DIV_DIV_CLKCMU_SDMA_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_SDMA_NOC_SM, "dout_cmu_div_sdma_noc_sm",
+           "mout_cmu_sdma_noc", CLK_CON_DIV_DIV_CLKCMU_SDMA_NOC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_CP_HISPEEDY_CLK, "dout_cmu_div_cp_hispeedy_clk",
+           "mout_cmu_mux_cp_hispeedy_clk", CLK_CON_DIV_DIV_CP_HISPEEDY_CLK,
+           0, 4),
+       DIV(CLK_DOUT_CMU_DIV_CP_HISPEEDY_CLK_SM,
+           "dout_cmu_div_cp_hispeedy_clk_sm", "mout_cmu_mux_cp_hispeedy_clk",
+           CLK_CON_DIV_DIV_CP_HISPEEDY_CLK_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_CP_SHARED0_CLK, "dout_cmu_div_cp_shared0_clk",
+           "mout_cmu_mux_cp_shared0_clk", CLK_CON_DIV_DIV_CP_SHARED0_CLK,
+           0, 3),
+       DIV(CLK_DOUT_CMU_DIV_CP_SHARED0_CLK_SM,
+           "dout_cmu_div_cp_shared0_clk_sm", "mout_cmu_cp_shared0_clk",
+           CLK_CON_DIV_DIV_CP_SHARED0_CLK_SM, 0, 3),
+       DIV(CLK_DOUT_CMU_DIV_CP_SHARED2_CLK, "dout_cmu_div_cp_shared2_clk",
+           "mout_cmu_mux_cp_shared2_clk", CLK_CON_DIV_DIV_CP_SHARED2_CLK,
+           0, 3),
+       DIV(CLK_DOUT_CMU_DIV_CP_SHARED2_CLK_SM,
+           "dout_cmu_div_cp_shared2_clk_sm", "mout_cmu_cp_shared2_clk",
+           CLK_CON_DIV_DIV_CP_SHARED2_CLK_SM, 0, 3),
+       DIV(CLK_DOUT_CMU_UFS_NOC, "dout_cmu_ufs_noc", "mout_cmu_mux_ufs_noc",
+           CLK_CON_DIV_CLKCMU_UFS_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_M2M_FRC, "dout_cmu_div_m2m_frc",
+           "mout_cmu_mux_m2m_frc", CLK_CON_DIV_DIV_CLKCMU_M2M_FRC, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_M2M_FRC_SM, "dout_cmu_div_m2m_frc_sm",
+           "mout_cmu_m2m_frc", CLK_CON_DIV_DIV_CLKCMU_M2M_FRC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_MCSC_MCSC, "dout_cmu_div_mcsc_mcsc",
+           "mout_cmu_mux_mcsc_mcsc", CLK_CON_DIV_DIV_CLKCMU_MCSC_MCSC, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_MCSC_MCSC_SM, "dout_cmu_div_mcsc_mcsc_sm",
+           "mout_cmu_mcsc_mcsc", CLK_CON_DIV_DIV_CLKCMU_MCSC_MCSC_SM, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_MCSC_NOC, "dout_cmu_div_mcsc_noc",
+           "mout_cmu_mux_mcsc_noc", CLK_CON_DIV_DIV_CLKCMU_MCSC_NOC, 0, 4),
+       DIV(CLK_DOUT_CMU_DIV_MCSC_NOC_SM, "dout_cmu_div_mcsc_noc_sm",
+           "mout_cmu_mcsc_noc", CLK_CON_DIV_DIV_CLKCMU_MCSC_NOC_SM, 0, 4),
+};
+
+static const struct samsung_fixed_factor_clock top_fixed_factor_clks[] __initconst = {
+       FFACTOR(CLK_DOUT_SHARED0_DIV1, "dout_shared0_div1",
+               "fout_shared0_pll", 1, 1, 0),
+       FFACTOR(CLK_DOUT_SHARED0_DIV2, "dout_shared0_div2",
+               "fout_shared0_pll", 1, 2, 0),
+       FFACTOR(CLK_DOUT_SHARED0_DIV4, "dout_shared0_div4",
+               "fout_shared0_pll", 1, 4, 0),
+       FFACTOR(CLK_DOUT_SHARED1_DIV1, "dout_shared1_div1",
+               "fout_shared1_pll", 1, 1, 0),
+       FFACTOR(CLK_DOUT_SHARED1_DIV2, "dout_shared1_div2",
+               "fout_shared1_pll", 1, 2, 0),
+       FFACTOR(CLK_DOUT_SHARED1_DIV4, "dout_shared1_div4",
+               "fout_shared1_pll", 1, 4, 0),
+       FFACTOR(CLK_DOUT_SHARED2_DIV1, "dout_shared2_div1",
+               "fout_shared2_pll", 1, 1, 0),
+       FFACTOR(CLK_DOUT_SHARED2_DIV2, "dout_shared2_div2",
+               "fout_shared2_pll", 1, 2, 0),
+       FFACTOR(CLK_DOUT_SHARED2_DIV4, "dout_shared2_div4",
+               "fout_shared2_pll", 1, 4, 0),
+       FFACTOR(CLK_DOUT_SHARED3_DIV1, "dout_shared3_div1",
+               "fout_shared3_pll", 1, 1, 0),
+       FFACTOR(CLK_DOUT_SHARED3_DIV2, "dout_shared3_div2",
+               "fout_shared3_pll", 1, 2, 0),
+       FFACTOR(CLK_DOUT_SHARED3_DIV4, "dout_shared3_div4",
+               "fout_shared3_pll", 1, 4, 0),
+       FFACTOR(CLK_DOUT_SHARED4_DIV1, "dout_shared4_div1",
+               "fout_shared4_pll", 1, 1, 0),
+       FFACTOR(CLK_DOUT_SHARED4_DIV2, "dout_shared4_div2",
+               "fout_shared4_pll", 1, 2, 0),
+       FFACTOR(CLK_DOUT_SHARED4_DIV4, "dout_shared4_div4",
+               "fout_shared4_pll", 1, 4, 0),
+       FFACTOR(CLK_DOUT_SHARED_MIF_DIV1, "dout_shared_mif_div1",
+               "fout_shared_mif_pll", 1, 1, 0),
+       FFACTOR(CLK_DOUT_SHARED_MIF_DIV2, "dout_shared_mif_div2",
+               "fout_shared_mif_pll", 1, 2, 0),
+       FFACTOR(CLK_DOUT_SHARED_MIF_DIV4, "dout_shared_mif_div4",
+               "fout_shared_mif_pll", 1, 4, 0),
+       FFACTOR(CLK_DOUT_SHARED_MIF_DIV4, "dout_mmc_div1",
+               "fout_mmc_pll", 1, 1, 0),
+       FFACTOR(CLK_DOUT_SHARED_MIF_DIV4, "dout_mmc_div2",
+               "fout_mmc_pll", 1, 2, 0),
+       FFACTOR(CLK_DOUT_SHARED_MIF_DIV4, "dout_mmc_div4",
+               "fout_mmc_pll", 1, 4, 0),
+       FFACTOR(CLK_DOUT_TCXO_DIV3, "dout_tcxo_div3",
+               "oscclk", 1, 3, 0),
+       FFACTOR(CLK_DOUT_TCXO_DIV4, "dout_tcxo_div4",
+               "oscclk", 1, 4, 0),
+};
+
+static const struct samsung_cmu_info top_cmu_info __initconst = {
+       .pll_clks               = top_pll_clks,
+       .nr_pll_clks            = ARRAY_SIZE(top_pll_clks),
+       .mux_clks               = top_mux_clks,
+       .nr_mux_clks            = ARRAY_SIZE(top_mux_clks),
+       .div_clks               = top_div_clks,
+       .nr_div_clks            = ARRAY_SIZE(top_div_clks),
+       .fixed_factor_clks      = top_fixed_factor_clks,
+       .nr_fixed_factor_clks   = ARRAY_SIZE(top_fixed_factor_clks),
+       .nr_clk_ids             = CLKS_NR_TOP,
+       .clk_regs               = top_clk_regs,
+       .nr_clk_regs            = ARRAY_SIZE(top_clk_regs),
+};
+
+static void __init exynos2200_cmu_top_init(struct device_node *np)
+{
+       exynos_arm64_register_cmu(NULL, np, &top_cmu_info);
+}
+
+/* Register CMU_TOP early, as it's a dependency for other early domains */
+CLK_OF_DECLARE(exynos2200_cmu_top, "samsung,exynos2200-cmu-top",
+              exynos2200_cmu_top_init);
+
+/* ---- CMU_ALIVE ---------------------------------------------------------- */
+
+/* Register Offset definitions for CMU_ALIVE (0x15800000) */
+#define PLL_CON0_MUX_CLKCMU_ALIVE_NOC_USER                                             0x600
+#define PLL_CON1_MUX_CLKCMU_ALIVE_NOC_USER                                             0x604
+#define PLL_CON0_MUX_CLKMUX_ALIVE_RCO_SPMI_USER                                                0x610
+#define PLL_CON1_MUX_CLKMUX_ALIVE_RCO_SPMI_USER                                                0x614
+#define PLL_CON0_MUX_CLK_RCO_ALIVE_USER                                                        0x620
+#define PLL_CON1_MUX_CLK_RCO_ALIVE_USER                                                        0x624
+#define CLK_CON_MUX_MUX_CLKALIVE_CHUB_PERI                                             0x1004
+#define CLK_CON_MUX_MUX_CLKALIVE_CMGP_NOC                                              0x1008
+#define CLK_CON_MUX_MUX_CLKALIVE_CMGP_PERI                                             0x100c
+#define CLK_CON_MUX_MUX_CLKALIVE_DBGCORE_NOC                                           0x1010
+#define CLK_CON_MUX_MUX_CLKALIVE_DNC_NOC                                               0x1014
+#define CLK_CON_MUX_MUX_CLKALIVE_CHUBVTS_NOC                                           0x1018
+#define CLK_CON_MUX_MUX_CLKALIVE_GNPU_NOC                                              0x101c
+#define CLK_CON_MUX_MUX_CLKALIVE_GNSS_NOC                                              0x1020
+#define CLK_CON_MUX_MUX_CLKALIVE_SDMA_NOC                                              0x1024
+#define CLK_CON_MUX_MUX_CLKALIVE_UFD_NOC                                               0x1028
+#define CLK_CON_MUX_MUX_CLK_ALIVE_DBGCORE_UART                                         0x1030
+#define CLK_CON_MUX_MUX_CLK_ALIVE_NOC                                                  0x1034
+#define CLK_CON_MUX_MUX_CLK_ALIVE_PMU_SUB                                              0x1038
+#define CLK_CON_MUX_MUX_CLK_ALIVE_SPMI                                                 0x103c
+#define CLK_CON_MUX_MUX_CLK_ALIVE_TIMER                                                        0x1040
+#define CLK_CON_MUX_MUX_CLKALIVE_CSIS_NOC                                              0x1044
+#define CLK_CON_MUX_MUX_CLKALIVE_DSP_NOC                                               0x1048
+#define CLK_CON_DIV_CLKALIVE_CHUB_PERI                                                 0x1804
+#define CLK_CON_DIV_CLKALIVE_CMGP_NOC                                                  0x1808
+#define CLK_CON_DIV_CLKALIVE_CMGP_PERI                                                 0x180c
+#define CLK_CON_DIV_CLKALIVE_DBGCORE_NOC                                               0x1810
+#define CLK_CON_DIV_CLKALIVE_DNC_NOC                                                   0x1814
+#define CLK_CON_DIV_CLKALIVE_CHUBVTS_NOC                                               0x1818
+#define CLK_CON_DIV_CLKALIVE_GNPU_NOC                                                  0x181c
+#define CLK_CON_DIV_CLKALIVE_SDMA_NOC                                                  0x1820
+#define CLK_CON_DIV_CLKALIVE_UFD_NOC                                                   0x1824
+#define CLK_CON_DIV_DIV_CLK_ALIVE_DBGCORE_UART                                         0x182c
+#define CLK_CON_DIV_DIV_CLK_ALIVE_NOC                                                  0x1830
+#define CLK_CON_DIV_DIV_CLK_ALIVE_PMU_SUB                                              0x1834
+#define CLK_CON_DIV_DIV_CLK_ALIVE_SPMI                                                 0x1838
+#define CLK_CON_DIV_CLKALIVE_CSIS_NOC                                                  0x183c
+#define CLK_CON_DIV_CLKALIVE_DSP_NOC                                                   0x1840
+#define CLK_CON_GAT_CLKALIVE_CHUBVTS_RCO                                               0x2000
+#define CLK_CON_GAT_CLKALIVE_DNC_RCO                                                   0x2004
+#define CLK_CON_GAT_CLKALIVE_CSIS_RCO                                                  0x2008
+#define CLK_CON_GAT_CLKALIVE_GNPU_RCO                                                  0x200c
+#define CLK_CON_GAT_CLKALIVE_GNSS_NOC                                                  0x2010
+#define CLK_CON_GAT_CLKALIVE_SDMA_RCO                                                  0x2014
+#define CLK_CON_GAT_CLKALIVE_UFD_RCO                                                   0x2018
+#define CLK_CON_GAT_CLKALIVE_DSP_RCO                                                   0x201c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_ALIVE_CMU_ALIVE_IPCLKPORT_PCLK                   0x2020
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_APBIF_GPIO_ALIVE_IPCLKPORT_PCLK                  0x2024
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_APBIF_INTCOMB_VGPIO2APM_IPCLKPORT_PCLK           0x2028
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_APBIF_INTCOMB_VGPIO2AP_IPCLKPORT_PCLK            0x202c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_APBIF_INTCOMB_VGPIO2PMU_IPCLKPORT_PCLK           0x2030
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_APBIF_PMU_ALIVE_IPCLKPORT_PCLK                   0x2034
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_APM_DMA_IPCLKPORT_PCLK                           0x2038
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_CHUB_RTC_IPCLKPORT_OSCCLK                                0x203c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_CHUB_RTC_IPCLKPORT_PCLK                          0x2040
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_CLKMON_IPCLKPORT_PCLK                            0x2044
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_DBGCORE_UART_IPCLKPORT_IPCLK                     0x2048
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_DBGCORE_UART_IPCLKPORT_PCLK                      0x204c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_BLK_ALIVE_FRC_OTP_DESERIAL_IPCLKPORT_I_CLK       0x2050
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_DTZPC_ALIVE_IPCLKPORT_PCLK                       0x2054
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_GREBEINTEGRATION_IPCLKPORT_HCLK                  0x2058
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_HW_SCANDUMP_CLKSTOP_CTRL_IPCLKPORT_ACLK          0x205c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_INTMEM_IPCLKPORT_I_ACLK                          0x2060
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_INTMEM_IPCLKPORT_I_PCLK                          0x2064
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_LH_AXI_SI_D_APM_IPCLKPORT_I_CLK                  0x2068
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_AP_IPCLKPORT_PCLK                    0x206c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_CHUB_IPCLKPORT_PCLK                  0x2070
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_CP_IPCLKPORT_PCLK                    0x2074
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_GNSS_IPCLKPORT_PCLK                  0x2078
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_VTS_IPCLKPORT_PCLK                   0x207c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_AP_CHUB_IPCLKPORT_PCLK                   0x2080
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_AP_CP_IPCLKPORT_PCLK                     0x2084
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_AP_CP_S_IPCLKPORT_PCLK                   0x2088
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_AP_DBGCORE_IPCLKPORT_PCLK                        0x208c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_AP_GNSS_IPCLKPORT_PCLK                   0x2090
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_CP_CHUB_IPCLKPORT_PCLK                   0x2094
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_CP_GNSS_IPCLKPORT_PCLK                   0x2098
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_GNSS_CHUB_IPCLKPORT_PCLK                 0x209c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_SHARED_SRAM_IPCLKPORT_PCLK               0x20a0
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_AUD_IPCLKPORT_PCLK                   0x20a4
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MCT_ALIVE_IPCLKPORT_I_PCLK                       0x20a8
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_PMU_INTR_GEN_IPCLKPORT_PCLK                      0x20ac
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_PMU_IPCLKPORT_ACLK                               0x20b0
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_PMU_IPCLKPORT_CLKIN_PMU_SUB                      0x20b4
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_CP_1_IPCLKPORT_PCLK                  0x20b8
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_OTP_DESERIAL_ALIVE_IPCLKPORT_I_CLK               0x20bc
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_SR_CLK_ALIVE_DBGCORE_UART_IPCLKPORT_CLK 0x20c0
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_FREE_OSCCLK_IPCLKPORT_CLK     0x20c4
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_GREBE_IPCLKPORT_CLK           0x20c8
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_NOC_IPCLKPORT_CLK             0x20cc
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_OSCCLK_RCO_IPCLKPORT_CLK      0x20d0
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_SPMI_IPCLKPORT_CLK            0x20d4
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_TIMER_IPCLKPORT_CLK           0x20d8
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_SR_CLK_ALIVE_NOC_IPCLKPORT_CLK          0x20dc
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RTC_IPCLKPORT_PCLK                               0x20e0
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_OTP_HCU_DESERIAL_IPCLKPORT_I_CLK                 0x20e4
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_MI_LD_GNSS_IPCLKPORT_I_CLK               0x20e8
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_MI_LP_MODEM_IPCLKPORT_I_CLK              0x20ec
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_MI_LD_CHUBVTS_IPCLKPORT_I_CLK            0x20f0
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_MI_ID_DBGCORE_IPCLKPORT_I_CLK            0x20f4
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_MI_P_APM_IPCLKPORT_I_CLK                 0x20f8
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_SI_LP_CMGP_IPCLKPORT_I_CLK               0x20fc
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_SI_IP_APM_IPCLKPORT_I_CLK                        0x2100
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_SR_CLK_ALIVE_FREE_OSCCLK_IPCLKPORT_CLK  0x2104
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_SI_LP_CHUBVTS_IPCLKPORT_I_CLK            0x2108
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_SI_LP_PPU_IPCLKPORT_I_CLK                        0x210c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_SI_LP_ALIVEDNC_IPCLKPORT_I_CLK           0x2110
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SPC_ALIVE_IPCLKPORT_PCLK                         0x2114
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SPMI_MASTER_PMIC_IPCLKPORT_I_IPCLK               0x2118
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SPMI_MASTER_PMIC_IPCLKPORT_I_PCLK                        0x211c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SWEEPER_P_ALIVE_IPCLKPORT_ACLK                   0x2120
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_SYSREG_ALIVE_IPCLKPORT_PCLK                      0x2124
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_TOP_RTC_IPCLKPORT_OSCCLK                         0x2128
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_TOP_RTC_IPCLKPORT_PCLK                           0x212c
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_VGEN_LITE_ALIVE_IPCLKPORT_CLK                    0x2130
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_WDT_ALIVE_IPCLKPORT_PCLK                         0x2134
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_XIU_DP_ALIVE_IPCLKPORT_ACLK                      0x2138
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_SR_CLK_ALIVE_OSCCLK_RCO_IPCLKPORT_CLK   0x213c
+#define CLK_CON_GAT_GATE_CLKALIVE_CHUB_PERI                                            0x2140
+#define CLK_CON_GAT_GATE_CLKALIVE_CMGP_NOC                                             0x2144
+#define CLK_CON_GAT_GATE_CLKALIVE_CMGP_PERI                                            0x2148
+#define CLK_CON_GAT_GATE_CLKALIVE_DBGCORE_NOC                                          0x214c
+#define CLK_CON_GAT_GATE_CLKALIVE_DNC_NOC                                              0x2150
+#define CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_SR_CLK_ALIVE_SPMI_IPCLKPORT_CLK         0x2154
+#define CLK_CON_GAT_GATE_CLKALIVE_GNPU_NOC                                             0x2158
+#define CLK_CON_GAT_GATE_CLKALIVE_SDMA_NOC                                             0x215c
+#define CLK_CON_GAT_GATE_CLKALIVE_UFD_NOC                                              0x2160
+#define CLK_CON_GAT_GATE_CLKALIVE_CHUBVTS_NOC                                          0x2164
+#define CLK_CON_GAT_GATE_CLKALIVE_CSIS_NOC                                             0x2168
+#define CLK_CON_GAT_GATE_CLKALIVE_DSP_NOC                                              0x216c
+
+static const unsigned long alive_clk_regs[] __initconst = {
+       PLL_CON0_MUX_CLKCMU_ALIVE_NOC_USER,
+       PLL_CON1_MUX_CLKCMU_ALIVE_NOC_USER,
+       PLL_CON0_MUX_CLKMUX_ALIVE_RCO_SPMI_USER,
+       PLL_CON1_MUX_CLKMUX_ALIVE_RCO_SPMI_USER,
+       PLL_CON0_MUX_CLK_RCO_ALIVE_USER,
+       PLL_CON1_MUX_CLK_RCO_ALIVE_USER,
+       CLK_CON_MUX_MUX_CLKALIVE_CHUB_PERI,
+       CLK_CON_MUX_MUX_CLKALIVE_CMGP_NOC,
+       CLK_CON_MUX_MUX_CLKALIVE_CMGP_PERI,
+       CLK_CON_MUX_MUX_CLKALIVE_DBGCORE_NOC,
+       CLK_CON_MUX_MUX_CLKALIVE_DNC_NOC,
+       CLK_CON_MUX_MUX_CLKALIVE_CHUBVTS_NOC,
+       CLK_CON_MUX_MUX_CLKALIVE_GNPU_NOC,
+       CLK_CON_MUX_MUX_CLKALIVE_GNSS_NOC,
+       CLK_CON_MUX_MUX_CLKALIVE_SDMA_NOC,
+       CLK_CON_MUX_MUX_CLKALIVE_UFD_NOC,
+       CLK_CON_MUX_MUX_CLK_ALIVE_DBGCORE_UART,
+       CLK_CON_MUX_MUX_CLK_ALIVE_NOC,
+       CLK_CON_MUX_MUX_CLK_ALIVE_PMU_SUB,
+       CLK_CON_MUX_MUX_CLK_ALIVE_SPMI,
+       CLK_CON_MUX_MUX_CLK_ALIVE_TIMER,
+       CLK_CON_MUX_MUX_CLKALIVE_CSIS_NOC,
+       CLK_CON_MUX_MUX_CLKALIVE_DSP_NOC,
+       CLK_CON_DIV_CLKALIVE_CHUB_PERI,
+       CLK_CON_DIV_CLKALIVE_CMGP_NOC,
+       CLK_CON_DIV_CLKALIVE_CMGP_PERI,
+       CLK_CON_DIV_CLKALIVE_DBGCORE_NOC,
+       CLK_CON_DIV_CLKALIVE_DNC_NOC,
+       CLK_CON_DIV_CLKALIVE_CHUBVTS_NOC,
+       CLK_CON_DIV_CLKALIVE_GNPU_NOC,
+       CLK_CON_DIV_CLKALIVE_SDMA_NOC,
+       CLK_CON_DIV_CLKALIVE_UFD_NOC,
+       CLK_CON_DIV_DIV_CLK_ALIVE_DBGCORE_UART,
+       CLK_CON_DIV_DIV_CLK_ALIVE_NOC,
+       CLK_CON_DIV_DIV_CLK_ALIVE_PMU_SUB,
+       CLK_CON_DIV_DIV_CLK_ALIVE_SPMI,
+       CLK_CON_DIV_CLKALIVE_CSIS_NOC,
+       CLK_CON_DIV_CLKALIVE_DSP_NOC,
+       CLK_CON_GAT_CLKALIVE_CHUBVTS_RCO,
+       CLK_CON_GAT_CLKALIVE_DNC_RCO,
+       CLK_CON_GAT_CLKALIVE_CSIS_RCO,
+       CLK_CON_GAT_CLKALIVE_GNPU_RCO,
+       CLK_CON_GAT_CLKALIVE_GNSS_NOC,
+       CLK_CON_GAT_CLKALIVE_SDMA_RCO,
+       CLK_CON_GAT_CLKALIVE_UFD_RCO,
+       CLK_CON_GAT_CLKALIVE_DSP_RCO,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_ALIVE_CMU_ALIVE_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_APBIF_GPIO_ALIVE_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_APBIF_INTCOMB_VGPIO2APM_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_APBIF_INTCOMB_VGPIO2AP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_APBIF_INTCOMB_VGPIO2PMU_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_APBIF_PMU_ALIVE_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_APM_DMA_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_CHUB_RTC_IPCLKPORT_OSCCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_CHUB_RTC_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_CLKMON_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_DBGCORE_UART_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_DBGCORE_UART_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_BLK_ALIVE_FRC_OTP_DESERIAL_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_DTZPC_ALIVE_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_GREBEINTEGRATION_IPCLKPORT_HCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_HW_SCANDUMP_CLKSTOP_CTRL_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_INTMEM_IPCLKPORT_I_ACLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_INTMEM_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_LH_AXI_SI_D_APM_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_AP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_CHUB_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_CP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_GNSS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_VTS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_AP_CHUB_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_AP_CP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_AP_CP_S_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_AP_DBGCORE_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_AP_GNSS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_CP_CHUB_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_CP_GNSS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_GNSS_CHUB_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_SHARED_SRAM_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_AUD_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MCT_ALIVE_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_PMU_INTR_GEN_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_PMU_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_PMU_IPCLKPORT_CLKIN_PMU_SUB,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_MAILBOX_APM_CP_1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_OTP_DESERIAL_ALIVE_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_SR_CLK_ALIVE_DBGCORE_UART_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_GREBE_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_NOC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_OSCCLK_RCO_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_SPMI_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_CLK_ALIVE_TIMER_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_SR_CLK_ALIVE_NOC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RTC_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_OTP_HCU_DESERIAL_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_MI_LD_GNSS_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_MI_LP_MODEM_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_MI_LD_CHUBVTS_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_MI_ID_DBGCORE_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_MI_P_APM_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_SI_LP_CMGP_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_SI_IP_APM_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_SR_CLK_ALIVE_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_SI_LP_CHUBVTS_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_SI_LP_PPU_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SLH_AXI_SI_LP_ALIVEDNC_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SPC_ALIVE_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SPMI_MASTER_PMIC_IPCLKPORT_I_IPCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SPMI_MASTER_PMIC_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SWEEPER_P_ALIVE_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_SYSREG_ALIVE_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_TOP_RTC_IPCLKPORT_OSCCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_TOP_RTC_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_VGEN_LITE_ALIVE_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_WDT_ALIVE_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_XIU_DP_ALIVE_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_SR_CLK_ALIVE_OSCCLK_RCO_IPCLKPORT_CLK,
+       CLK_CON_GAT_GATE_CLKALIVE_CHUB_PERI,
+       CLK_CON_GAT_GATE_CLKALIVE_CMGP_NOC,
+       CLK_CON_GAT_GATE_CLKALIVE_CMGP_PERI,
+       CLK_CON_GAT_GATE_CLKALIVE_DBGCORE_NOC,
+       CLK_CON_GAT_GATE_CLKALIVE_DNC_NOC,
+       CLK_CON_GAT_CLK_BLK_ALIVE_UID_RSTNSYNC_SR_CLK_ALIVE_SPMI_IPCLKPORT_CLK,
+       CLK_CON_GAT_GATE_CLKALIVE_GNPU_NOC,
+       CLK_CON_GAT_GATE_CLKALIVE_SDMA_NOC,
+       CLK_CON_GAT_GATE_CLKALIVE_UFD_NOC,
+       CLK_CON_GAT_GATE_CLKALIVE_CHUBVTS_NOC,
+       CLK_CON_GAT_GATE_CLKALIVE_CSIS_NOC,
+       CLK_CON_GAT_GATE_CLKALIVE_DSP_NOC,
+};
+
+PNAME(mout_alive_noc_user_p)           = { "oscclk", "dout_cmu_alive_noc" };
+PNAME(mout_alive_rco_spmi_user_p)      = { "oscclk", "rco_i3c_pmic" };
+PNAME(mout_rco_alive_user_p)           = { "oscclk", "rco_alive" };
+PNAME(mout_alive_chub_peri_p)          = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_cmgp_noc_p)           = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_cmgp_peri_p)          = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_dbgcore_noc_p)                = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_dnc_noc_p)            = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_chubvts_noc_p)                = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_gnpu_noc_p)           = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_gnss_noc_p)           = { "rco_400", "mout_alive_noc_user" };
+PNAME(mout_alive_sdma_noc_p)           = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_ufd_noc_p)            = { "mout_rco_alive_user",
+                                           "rco_400",
+                                           "mout_alive_noc_user",
+                                           "oscclk" };
+PNAME(mout_alive_dbgcore_uart_p)       = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_noc_p)                        = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_pmu_sub_p)            = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_spmi_p)               = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_rco_spmi_user",
+                                           "oscclk" };
+PNAME(mout_alive_timer_p)              = { "oscclk", "oscclk" };
+PNAME(mout_alive_csis_noc_p)           = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+PNAME(mout_alive_dsp_noc_p)            = { "mout_rco_alive_user", "rco_400",
+                                           "mout_alive_noc_user", "oscclk" };
+
+static const struct samsung_mux_clock alive_mux_clks[] __initconst = {
+       MUX(CLK_MOUT_ALIVE_NOC_USER, "mout_alive_noc_user",
+           mout_alive_noc_user_p, PLL_CON0_MUX_CLKCMU_ALIVE_NOC_USER, 4, 1),
+       MUX(CLK_MOUT_ALIVE_RCO_SPMI_USER, "mout_alive_rco_spmi_user",
+           mout_alive_rco_spmi_user_p,
+           PLL_CON0_MUX_CLKMUX_ALIVE_RCO_SPMI_USER, 4, 1),
+       MUX(CLK_MOUT_RCO_ALIVE_USER, "mout_rco_alive_user",
+           mout_rco_alive_user_p, PLL_CON0_MUX_CLK_RCO_ALIVE_USER, 4, 1),
+       MUX(CLK_MOUT_ALIVE_CHUB_PERI, "mout_alive_chub_peri",
+           mout_alive_chub_peri_p, CLK_CON_MUX_MUX_CLKALIVE_CHUB_PERI, 0, 2),
+       MUX(CLK_MOUT_ALIVE_CMGP_NOC, "mout_alive_cmgp_noc",
+           mout_alive_cmgp_noc_p, CLK_CON_MUX_MUX_CLKALIVE_CMGP_NOC, 0, 2),
+       MUX(CLK_MOUT_ALIVE_CMGP_PERI, "mout_alive_cmgp_peri",
+           mout_alive_cmgp_peri_p, CLK_CON_MUX_MUX_CLKALIVE_CMGP_PERI, 0, 2),
+       MUX(CLK_MOUT_ALIVE_DBGCORE_NOC, "mout_alive_dbgcore_noc",
+           mout_alive_dbgcore_noc_p, CLK_CON_MUX_MUX_CLKALIVE_DBGCORE_NOC,
+           0, 2),
+       MUX(CLK_MOUT_ALIVE_DNC_NOC, "mout_alive_dnc_noc", mout_alive_dnc_noc_p,
+           CLK_CON_MUX_MUX_CLKALIVE_DNC_NOC, 0, 2),
+       MUX(CLK_MOUT_ALIVE_CHUBVTS_NOC, "mout_alive_chubvts_noc",
+           mout_alive_chubvts_noc_p, CLK_CON_MUX_MUX_CLKALIVE_CHUBVTS_NOC,
+           0, 2),
+       MUX(CLK_MOUT_ALIVE_GNPU_NOC, "mout_alive_gnpu_noc",
+           mout_alive_gnpu_noc_p, CLK_CON_MUX_MUX_CLKALIVE_GNPU_NOC, 0, 2),
+       MUX(CLK_MOUT_ALIVE_GNSS_NOC, "mout_alive_gnss_noc",
+           mout_alive_gnss_noc_p, CLK_CON_MUX_MUX_CLKALIVE_GNSS_NOC, 0, 1),
+       MUX(CLK_MOUT_ALIVE_SDMA_NOC, "mout_alive_sdma_noc",
+           mout_alive_sdma_noc_p, CLK_CON_MUX_MUX_CLKALIVE_SDMA_NOC, 0, 2),
+       MUX(CLK_MOUT_ALIVE_UFD_NOC, "mout_alive_ufd_noc", mout_alive_ufd_noc_p,
+           CLK_CON_MUX_MUX_CLKALIVE_UFD_NOC, 0, 2),
+       MUX(CLK_MOUT_ALIVE_DBGCORE_UART, "mout_alive_dbgcore_uart",
+           mout_alive_dbgcore_uart_p, CLK_CON_MUX_MUX_CLK_ALIVE_DBGCORE_UART,
+           0, 2),
+       MUX(CLK_MOUT_ALIVE_NOC, "mout_alive_noc", mout_alive_noc_p,
+           CLK_CON_MUX_MUX_CLK_ALIVE_NOC, 0, 2),
+       MUX(CLK_MOUT_ALIVE_PMU_SUB, "mout_alive_pmu_sub", mout_alive_pmu_sub_p,
+           CLK_CON_MUX_MUX_CLK_ALIVE_PMU_SUB, 0, 2),
+       MUX(CLK_MOUT_ALIVE_SPMI, "mout_alive_spmi", mout_alive_spmi_p,
+           CLK_CON_MUX_MUX_CLK_ALIVE_SPMI, 0, 2),
+       MUX(CLK_MOUT_ALIVE_TIMER, "mout_alive_timer", mout_alive_timer_p,
+           CLK_CON_MUX_MUX_CLK_ALIVE_TIMER, 0, 1),
+       MUX(CLK_MOUT_ALIVE_CSIS_NOC, "mout_alive_csis_noc",
+           mout_alive_csis_noc_p, CLK_CON_MUX_MUX_CLKALIVE_CSIS_NOC, 0, 2),
+       MUX(CLK_MOUT_ALIVE_DSP_NOC, "mout_alive_dsp_noc", mout_alive_dsp_noc_p,
+           CLK_CON_MUX_MUX_CLKALIVE_DSP_NOC, 0, 2),
+};
+
+static const struct samsung_div_clock alive_div_clks[] __initconst = {
+       DIV(CLK_DOUT_ALIVE_CHUB_PERI, "dout_alive_chub_peri",
+           "mout_alive_chub_peri", CLK_CON_DIV_CLKALIVE_CHUB_PERI, 0, 3),
+       DIV(CLK_DOUT_ALIVE_CMGP_NOC, "dout_alive_cmgp_noc",
+           "mout_alive_cmgp_noc", CLK_CON_DIV_CLKALIVE_CMGP_NOC, 0, 3),
+       DIV(CLK_DOUT_ALIVE_CMGP_PERI, "dout_alive_cmgp_peri",
+           "mout_alive_cmgp_peri", CLK_CON_DIV_CLKALIVE_CMGP_PERI, 0, 3),
+       DIV(CLK_DOUT_ALIVE_DBGCORE_NOC, "dout_alive_dbgcore_noc",
+           "mout_alive_dbgcore_noc", CLK_CON_DIV_CLKALIVE_DBGCORE_NOC, 0, 3),
+       DIV(CLK_DOUT_ALIVE_DNC_NOC, "dout_alive_dnc_noc", "mout_alive_dnc_noc",
+           CLK_CON_DIV_CLKALIVE_DNC_NOC, 0, 3),
+       DIV(CLK_DOUT_ALIVE_CHUBVTS_NOC, "dout_alive_chubvts_noc",
+           "mout_alive_chubvts_noc", CLK_CON_DIV_CLKALIVE_CHUBVTS_NOC, 0, 3),
+       DIV(CLK_DOUT_ALIVE_GNPU_NOC, "dout_alive_gnpu_noc",
+           "mout_alive_gnpu_noc", CLK_CON_DIV_CLKALIVE_GNPU_NOC, 0, 3),
+       DIV(CLK_DOUT_ALIVE_SDMA_NOC, "dout_alive_sdma_noc",
+           "mout_alive_sdma_noc", CLK_CON_DIV_CLKALIVE_SDMA_NOC, 0, 3),
+       DIV(CLK_DOUT_ALIVE_UFD_NOC, "dout_alive_ufd_noc", "mout_alive_ufd_noc",
+           CLK_CON_DIV_CLKALIVE_UFD_NOC, 0, 3),
+       DIV(CLK_DOUT_ALIVE_DBGCORE_UART, "dout_alive_dbgcore_uart",
+           "mout_alive_dbgcore_uart", CLK_CON_DIV_DIV_CLK_ALIVE_DBGCORE_UART,
+           0, 4),
+       DIV(CLK_DOUT_ALIVE_NOC, "dout_alive_noc", "mout_alive_noc",
+           CLK_CON_DIV_DIV_CLK_ALIVE_NOC, 0, 3),
+       DIV(CLK_DOUT_ALIVE_PMU_SUB, "dout_alive_pmu_sub", "mout_alive_pmu_sub",
+           CLK_CON_DIV_DIV_CLK_ALIVE_PMU_SUB, 0, 3),
+       DIV(CLK_DOUT_ALIVE_SPMI, "dout_alive_spmi", "mout_alive_spmi",
+           CLK_CON_DIV_DIV_CLK_ALIVE_SPMI, 0, 5),
+       DIV(CLK_DOUT_ALIVE_CSIS_NOC, "dout_alive_csis_noc",
+           "mout_alive_csis_noc", CLK_CON_DIV_CLKALIVE_CSIS_NOC, 0, 3),
+       DIV(CLK_DOUT_ALIVE_DSP_NOC, "dout_alive_dsp_noc",
+           "mout_alive_dsp_noc", CLK_CON_DIV_CLKALIVE_DSP_NOC, 0, 3),
+};
+
+static const struct samsung_fixed_rate_clock alive_fixed_clks[] __initconst = {
+       FRATE(0, "rco_i3c_pmic", NULL, 0, 49152000),
+       FRATE(0, "rco_alive", NULL, 0, 49152000),
+       FRATE(0, "rco_400", NULL, 0, 393216000),
+};
+
+static const struct samsung_cmu_info alive_cmu_info __initconst = {
+       .mux_clks               = alive_mux_clks,
+       .nr_mux_clks            = ARRAY_SIZE(alive_mux_clks),
+       .div_clks               = alive_div_clks,
+       .nr_div_clks            = ARRAY_SIZE(alive_div_clks),
+       .fixed_clks             = alive_fixed_clks,
+       .nr_fixed_clks          = ARRAY_SIZE(alive_fixed_clks),
+       .nr_clk_ids             = CLKS_NR_ALIVE,
+       .clk_regs               = alive_clk_regs,
+       .nr_clk_regs            = ARRAY_SIZE(alive_clk_regs),
+       .clk_name               = "noc",
+};
+
+static void __init exynos2200_cmu_alive_init(struct device_node *np)
+{
+       exynos_arm64_register_cmu(NULL, np, &alive_cmu_info);
+}
+
+/* Register CMU_ALIVE early, as it's a dependency for other early domains */
+CLK_OF_DECLARE(exynos2200_cmu_alive, "samsung,exynos2200-cmu-alive",
+              exynos2200_cmu_alive_init);
+
+/* ---- CMU_PERIS ---------------------------------------------------------- */
+
+/* Register Offset definitions for CMU_PERIS (0x10020000) */
+#define PLL_CON0_MUX_CLKCMU_PERIS_GIC_USER                                             0x600
+#define PLL_CON1_MUX_CLKCMU_PERIS_GIC_USER                                             0x604
+#define PLL_CON0_MUX_CLKCMU_PERIS_NOC_USER                                             0x610
+#define PLL_CON1_MUX_CLKCMU_PERIS_NOC_USER                                             0x614
+#define CLK_CON_MUX_MUX_CLK_PERIS_GIC                                                  0x1000
+#define CLK_CON_DIV_CLKCMU_OTP                                                         0x1800
+#define CLK_CON_DIV_DIV_CLK_PERIS_DDD_CTRL                                             0x1804
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_BUSIF_DDD_PERIS_IPCLKPORT_ATCLK                  0x2000
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_BUSIF_DDD_PERIS_IPCLKPORT_PCLK                   0x2004
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_DDD_PERIS_IPCLKPORT_CK_IN                                0x2008
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_D_TZPC_PERIS_IPCLKPORT_PCLK                      0x200c
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_GIC_IPCLKPORT_GICCLK                             0x2010
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_LH_AST_MI_LD_ICC_CPUGIC_CLUSTER0_IPCLKPORT_I_CLK 0x2014
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_LH_AST_SI_LD_IRI_GICCPU_CLUSTER0_IPCLKPORT_I_CLK 0x2018
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_MCT_IPCLKPORT_PCLK                               0x201c
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_OTP_CON_BIRA_IPCLKPORT_I_OSCCLK                  0x2020
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_OTP_CON_BIRA_IPCLKPORT_PCLK                      0x2024
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_OTP_CON_TOP_IPCLKPORT_I_OSCCLK                   0x2028
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_OTP_CON_TOP_IPCLKPORT_PCLK                       0x202c
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_PERIS_CMU_PERIS_IPCLKPORT_PCLK                   0x2030
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_CLK_PERIS_FREE_OSCCLK_IPCLKPORT_CLK     0x2038
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_CLK_PERIS_GIC_IPCLKPORT_CLK             0x203c
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_CLK_PERIS_NOCP_IPCLKPORT_CLK            0x2040
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_SLH_AXI_MI_P_PERISGIC_IPCLKPORT_I_CLK            0x2044
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_SLH_AXI_MI_P_PERIS_IPCLKPORT_I_CLK               0x2048
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_SYSREG_PERIS_IPCLKPORT_PCLK                      0x204c
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_TMU_SUB_IPCLKPORT_PCLK                           0x2050
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_TMU_TOP_IPCLKPORT_PCLK                           0x2054
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_WDT0_IPCLKPORT_PCLK                              0x2058
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_WDT1_IPCLKPORT_PCLK                              0x205c
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_SR_CLK_PERIS_DDD_CTRL_IPCLKPORT_CLK     0x2060
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_SR_CLK_PERIS_FREE_OSCCLK_IPCLKPORT_CLK  0x2064
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_SR_CLK_PERIS_GIC_IPCLKPORT_CLK          0x2068
+#define CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_SR_CLK_PERIS_NOCP_IPCLKPORT_CLK         0x206c
+
+static const unsigned long peris_clk_regs[] __initconst = {
+       PLL_CON0_MUX_CLKCMU_PERIS_GIC_USER,
+       PLL_CON1_MUX_CLKCMU_PERIS_GIC_USER,
+       PLL_CON0_MUX_CLKCMU_PERIS_NOC_USER,
+       PLL_CON1_MUX_CLKCMU_PERIS_NOC_USER,
+       CLK_CON_MUX_MUX_CLK_PERIS_GIC,
+       CLK_CON_DIV_CLKCMU_OTP,
+       CLK_CON_DIV_DIV_CLK_PERIS_DDD_CTRL,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_BUSIF_DDD_PERIS_IPCLKPORT_ATCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_BUSIF_DDD_PERIS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_DDD_PERIS_IPCLKPORT_CK_IN,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_D_TZPC_PERIS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_GIC_IPCLKPORT_GICCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_LH_AST_MI_LD_ICC_CPUGIC_CLUSTER0_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_LH_AST_SI_LD_IRI_GICCPU_CLUSTER0_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_MCT_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_OTP_CON_BIRA_IPCLKPORT_I_OSCCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_OTP_CON_BIRA_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_OTP_CON_TOP_IPCLKPORT_I_OSCCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_OTP_CON_TOP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_PERIS_CMU_PERIS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_CLK_PERIS_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_CLK_PERIS_GIC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_CLK_PERIS_NOCP_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_SLH_AXI_MI_P_PERISGIC_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_SLH_AXI_MI_P_PERIS_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_SYSREG_PERIS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_TMU_SUB_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_TMU_TOP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_WDT0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_WDT1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_SR_CLK_PERIS_DDD_CTRL_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_SR_CLK_PERIS_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_SR_CLK_PERIS_GIC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIS_UID_RSTNSYNC_SR_CLK_PERIS_NOCP_IPCLKPORT_CLK,
+};
+
+PNAME(mout_peris_gic_user_p)   = { "dout_tcxo_div3",
+                                   "dout_cmu_peris_gic" };
+PNAME(mout_peris_noc_user_p)   = { "dout_tcxo_div3",
+                                   "dout_cmu_peris_noc" };
+PNAME(mout_peris_gic_p)                = { "mout_peris_gic_user", "dout_tcxo_div3" };
+
+static const struct samsung_mux_clock peris_mux_clks[] __initconst = {
+       MUX(CLK_MOUT_PERIS_GIC_USER, "mout_peris_gic_user",
+           mout_peris_gic_user_p, PLL_CON0_MUX_CLKCMU_PERIS_GIC_USER, 4, 1),
+       MUX(CLK_MOUT_PERIS_NOC_USER, "mout_peris_noc_user",
+           mout_peris_noc_user_p, PLL_CON0_MUX_CLKCMU_PERIS_NOC_USER, 4, 1),
+       MUX(CLK_MOUT_PERIS_GIC, "mout_peris_gic", mout_peris_gic_p,
+           CLK_CON_MUX_MUX_CLK_PERIS_GIC, 0, 0),
+};
+
+static const struct samsung_fixed_factor_clock peris_fixed_factor_clks[] __initconst = {
+       FFACTOR(CLK_DOUT_PERIS_OTP, "dout_peris_otp",
+               "dout_tcxo_div3", 1, 8, 0),
+       FFACTOR(CLK_DOUT_PERIS_DDD_CTRL, "dout_peris_ddd_ctrl",
+               "mout_peris_gic", 1, 4, 0),
+};
+
+static const struct samsung_cmu_info peris_cmu_info __initconst = {
+       .mux_clks               = peris_mux_clks,
+       .nr_mux_clks            = ARRAY_SIZE(peris_mux_clks),
+       .fixed_factor_clks      = peris_fixed_factor_clks,
+       .nr_fixed_factor_clks   = ARRAY_SIZE(peris_fixed_factor_clks),
+       .nr_clk_ids             = CLKS_NR_PERIS,
+       .clk_regs               = peris_clk_regs,
+       .nr_clk_regs            = ARRAY_SIZE(peris_clk_regs),
+       .clk_name               = "noc",
+};
+
+static void __init exynos2200_cmu_peris_init(struct device_node *np)
+{
+       exynos_arm64_register_cmu(NULL, np, &peris_cmu_info);
+}
+
+/* Register CMU_PERIS early, as it's a dependency for GIC and MCT */
+CLK_OF_DECLARE(exynos2200_cmu_peris, "samsung,exynos2200-cmu-peris",
+              exynos2200_cmu_peris_init);
+
+/* ---- CMU_CMGP ----------------------------------------------------------- */
+
+/* Register Offset definitions for CMU_CMGP (0x14e00000) */
+#define PLL_CON0_MUX_CLKALIVE_CMGP_NOC_USER                                            0x610
+#define PLL_CON1_MUX_CLKALIVE_CMGP_NOC_USER                                            0x614
+#define PLL_CON0_MUX_CLKALIVE_CMGP_PERI_USER                                           0x620
+#define PLL_CON1_MUX_CLKALIVE_CMGP_PERI_USER                                           0x624
+#define CLK_CON_MUX_MUX_CLK_CMGP_I2C                                                   0x1000
+#define CLK_CON_MUX_MUX_CLK_CMGP_SPI_I2C0                                              0x1008
+#define CLK_CON_MUX_MUX_CLK_CMGP_SPI_I2C1                                              0x100c
+#define CLK_CON_MUX_MUX_CLK_CMGP_SPI_MS_CTRL                                           0x1010
+#define CLK_CON_MUX_MUX_CLK_CMGP_USI0                                                  0x1014
+#define CLK_CON_MUX_MUX_CLK_CMGP_USI1                                                  0x1018
+#define CLK_CON_MUX_MUX_CLK_CMGP_USI2                                                  0x101c
+#define CLK_CON_MUX_MUX_CLK_CMGP_USI3                                                  0x1020
+#define CLK_CON_MUX_MUX_CLK_CMGP_USI4                                                  0x1024
+#define CLK_CON_MUX_MUX_CLK_CMGP_USI5                                                  0x1028
+#define CLK_CON_MUX_MUX_CLK_CMGP_USI6                                                  0x102c
+#define CLK_CON_DIV_DIV_CLK_CMGP_I2C                                                   0x1800
+#define CLK_CON_DIV_DIV_CLK_CMGP_SPI_I2C0                                              0x1808
+#define CLK_CON_DIV_DIV_CLK_CMGP_SPI_I2C1                                              0x180c
+#define CLK_CON_DIV_DIV_CLK_CMGP_SPI_MS_CTRL                                           0x1810
+#define CLK_CON_DIV_DIV_CLK_CMGP_USI0                                                  0x1814
+#define CLK_CON_DIV_DIV_CLK_CMGP_USI1                                                  0x1818
+#define CLK_CON_DIV_DIV_CLK_CMGP_USI2                                                  0x181c
+#define CLK_CON_DIV_DIV_CLK_CMGP_USI3                                                  0x1820
+#define CLK_CON_DIV_DIV_CLK_CMGP_USI4                                                  0x1824
+#define CLK_CON_DIV_DIV_CLK_CMGP_USI5                                                  0x1828
+#define CLK_CON_DIV_DIV_CLK_CMGP_USI6                                                  0x182c
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_APBIF_GPIO_CMGP_IPCLKPORT_PCLK                    0x2000
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_CMGP_CMU_CMGP_IPCLKPORT_PCLK                      0x2004
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_CMGP_I2C_IPCLKPORT_IPCLK                          0x2008
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_CMGP_I2C_IPCLKPORT_PCLK                           0x200c
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_D_TZPC_CMGP_IPCLKPORT_PCLK                                0x2010
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP2_IPCLKPORT_IPCLK                         0x2014
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP2_IPCLKPORT_PCLK                          0x2018
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP3_IPCLKPORT_IPCLK                         0x201c
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP3_IPCLKPORT_PCLK                          0x2020
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP4_IPCLKPORT_IPCLK                         0x2024
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP4_IPCLKPORT_PCLK                          0x2028
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP5_IPCLKPORT_IPCLK                         0x202c
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP5_IPCLKPORT_PCLK                          0x2030
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP6_IPCLKPORT_IPCLK                         0x2034
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP6_IPCLKPORT_PCLK                          0x2038
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_NOC_IPCLKPORT_CLK            0x2040
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_CLK_CMGP_FREE_OSCCLK_IPCLKPORT_CLK       0x2044
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_I2C_IPCLKPORT_CLK            0x2048
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_CLK_CMGP_NOC_IPCLKPORT_CLK               0x2050
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_SPI_I2C0_IPCLKPORT_CLK       0x2054
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_SPI_I2C1_IPCLKPORT_CLK       0x2058
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI0_IPCLKPORT_CLK           0x205c
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI1_IPCLKPORT_CLK           0x2060
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI2_IPCLKPORT_CLK           0x2064
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI3_IPCLKPORT_CLK           0x2068
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI4_IPCLKPORT_CLK           0x206c
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI5_IPCLKPORT_CLK           0x2070
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI6_IPCLKPORT_CLK           0x2074
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_SPI_MS_CTRL_IPCLKPORT_CLK    0x2078
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SLH_AXI_MI_LP_CMGP_IPCLKPORT_I_CLK                        0x207c
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SLH_AXI_SI_LP_CMGPUFD_IPCLKPORT_I_CLK             0x2080
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SPI_I2C_CMGP0_IPCLKPORT_IPCLK                     0x2084
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SPI_I2C_CMGP0_IPCLKPORT_PCLK                      0x2088
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SPI_I2C_CMGP1_IPCLKPORT_IPCLK                     0x208c
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SPI_I2C_CMGP1_IPCLKPORT_PCLK                      0x2090
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SPI_MULTI_SLV_Q_CTRL_CMGP_IPCLKPORT_CLK           0x2094
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP2APM_IPCLKPORT_PCLK                    0x2098
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP2CHUB_IPCLKPORT_PCLK                   0x209c
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP2CP_IPCLKPORT_PCLK                     0x20a0
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP2GNSS_IPCLKPORT_PCLK                   0x20a4
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP2PMU_AP_IPCLKPORT_PCLK                 0x20a8
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP_IPCLKPORT_PCLK                                0x20ac
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP0_IPCLKPORT_IPCLK                         0x20b0
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP0_IPCLKPORT_PCLK                          0x20b4
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP1_IPCLKPORT_IPCLK                         0x20b8
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP1_IPCLKPORT_PCLK                          0x20bc
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP2_IPCLKPORT_IPCLK                         0x20c0
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP2_IPCLKPORT_PCLK                          0x20c4
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP3_IPCLKPORT_IPCLK                         0x20c8
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP3_IPCLKPORT_PCLK                          0x20cc
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP4_IPCLKPORT_IPCLK                         0x20d0
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP4_IPCLKPORT_PCLK                          0x20d4
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP5_IPCLKPORT_IPCLK                         0x20d8
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP5_IPCLKPORT_PCLK                          0x20dc
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP6_IPCLKPORT_IPCLK                         0x20e0
+#define CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP6_IPCLKPORT_PCLK                          0x20e4
+
+static const unsigned long cmgp_clk_regs[] __initconst = {
+       PLL_CON0_MUX_CLKALIVE_CMGP_NOC_USER,
+       PLL_CON1_MUX_CLKALIVE_CMGP_NOC_USER,
+       PLL_CON0_MUX_CLKALIVE_CMGP_PERI_USER,
+       PLL_CON1_MUX_CLKALIVE_CMGP_PERI_USER,
+       CLK_CON_MUX_MUX_CLK_CMGP_I2C,
+       CLK_CON_MUX_MUX_CLK_CMGP_SPI_I2C0,
+       CLK_CON_MUX_MUX_CLK_CMGP_SPI_I2C1,
+       CLK_CON_MUX_MUX_CLK_CMGP_SPI_MS_CTRL,
+       CLK_CON_MUX_MUX_CLK_CMGP_USI0,
+       CLK_CON_MUX_MUX_CLK_CMGP_USI1,
+       CLK_CON_MUX_MUX_CLK_CMGP_USI2,
+       CLK_CON_MUX_MUX_CLK_CMGP_USI3,
+       CLK_CON_MUX_MUX_CLK_CMGP_USI4,
+       CLK_CON_MUX_MUX_CLK_CMGP_USI5,
+       CLK_CON_MUX_MUX_CLK_CMGP_USI6,
+       CLK_CON_DIV_DIV_CLK_CMGP_I2C,
+       CLK_CON_DIV_DIV_CLK_CMGP_SPI_I2C0,
+       CLK_CON_DIV_DIV_CLK_CMGP_SPI_I2C1,
+       CLK_CON_DIV_DIV_CLK_CMGP_SPI_MS_CTRL,
+       CLK_CON_DIV_DIV_CLK_CMGP_USI0,
+       CLK_CON_DIV_DIV_CLK_CMGP_USI1,
+       CLK_CON_DIV_DIV_CLK_CMGP_USI2,
+       CLK_CON_DIV_DIV_CLK_CMGP_USI3,
+       CLK_CON_DIV_DIV_CLK_CMGP_USI4,
+       CLK_CON_DIV_DIV_CLK_CMGP_USI5,
+       CLK_CON_DIV_DIV_CLK_CMGP_USI6,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_APBIF_GPIO_CMGP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_CMGP_CMU_CMGP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_CMGP_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_CMGP_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_D_TZPC_CMGP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP2_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP2_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP3_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP3_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP4_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP4_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP5_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP5_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP6_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_I2C_CMGP6_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_NOC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_CLK_CMGP_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_I2C_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_CLK_CMGP_NOC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_SPI_I2C0_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_SPI_I2C1_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI0_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI1_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI2_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI3_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI4_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI5_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_USI6_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_RSTNSYNC_SR_CLK_CMGP_SPI_MS_CTRL_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SLH_AXI_MI_LP_CMGP_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SLH_AXI_SI_LP_CMGPUFD_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SPI_I2C_CMGP0_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SPI_I2C_CMGP0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SPI_I2C_CMGP1_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SPI_I2C_CMGP1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SPI_MULTI_SLV_Q_CTRL_CMGP_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP2APM_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP2CHUB_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP2CP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP2GNSS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP2PMU_AP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_SYSREG_CMGP_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP0_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP1_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP2_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP2_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP3_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP3_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP4_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP4_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP5_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP5_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP6_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_CMGP_UID_USI_CMGP6_IPCLKPORT_PCLK,
+};
+
+PNAME(mout_cmgp_clkalive_noc_user_p)   = { "oscclk", "dout_alive_cmgp_noc" };
+PNAME(mout_cmgp_clkalive_peri_user_p)  = { "oscclk", "dout_alive_cmgp_peri" };
+PNAME(mout_cmgp_i2c_p)                 = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+PNAME(mout_cmgp_spi_i2c0_p)            = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+PNAME(mout_cmgp_spi_i2c1_p)            = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+PNAME(mout_cmgp_spi_ms_ctrl_p)         = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+PNAME(mout_cmgp_usi0_p)                        = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+PNAME(mout_cmgp_usi1_p)                        = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+PNAME(mout_cmgp_usi2_p)                        = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+PNAME(mout_cmgp_usi3_p)                        = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+PNAME(mout_cmgp_usi4_p)                        = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+PNAME(mout_cmgp_usi5_p)                        = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+PNAME(mout_cmgp_usi6_p)                        = { "oscclk",
+                                           "mout_cmgp_clkalive_peri_user" };
+
+static const struct samsung_mux_clock cmgp_mux_clks[] __initconst = {
+       MUX(CLK_MOUT_CMGP_CLKALIVE_NOC_USER, "mout_cmgp_clkalive_noc_user",
+           mout_cmgp_clkalive_noc_user_p, PLL_CON0_MUX_CLKALIVE_CMGP_NOC_USER,
+           4, 1),
+       MUX(CLK_MOUT_CMGP_CLKALIVE_PERI_USER, "mout_cmgp_clkalive_peri_user",
+           mout_cmgp_clkalive_peri_user_p,
+           PLL_CON0_MUX_CLKALIVE_CMGP_PERI_USER, 4, 1),
+       MUX(CLK_MOUT_CMGP_I2C, "mout_cmgp_i2c", mout_cmgp_i2c_p,
+           CLK_CON_MUX_MUX_CLK_CMGP_I2C, 0, 1),
+       MUX(CLK_MOUT_CMGP_SPI_I2C0, "mout_cmgp_spi_i2c0", mout_cmgp_spi_i2c0_p,
+           CLK_CON_MUX_MUX_CLK_CMGP_SPI_I2C0, 0, 1),
+       MUX(CLK_MOUT_CMGP_SPI_I2C1, "mout_cmgp_spi_i2c1", mout_cmgp_spi_i2c1_p,
+           CLK_CON_MUX_MUX_CLK_CMGP_SPI_I2C1, 0, 1),
+       MUX(CLK_MOUT_CMGP_SPI_MS_CTRL, "mout_cmgp_spi_ms_ctrl",
+           mout_cmgp_spi_ms_ctrl_p, CLK_CON_MUX_MUX_CLK_CMGP_SPI_MS_CTRL,
+           0, 1),
+       MUX(CLK_MOUT_CMGP_USI0, "mout_cmgp_usi0", mout_cmgp_usi0_p,
+           CLK_CON_MUX_MUX_CLK_CMGP_USI0, 0, 1),
+       MUX(CLK_MOUT_CMGP_USI1, "mout_cmgp_usi1", mout_cmgp_usi1_p,
+           CLK_CON_MUX_MUX_CLK_CMGP_USI1, 0, 1),
+       MUX(CLK_MOUT_CMGP_USI2, "mout_cmgp_usi2", mout_cmgp_usi2_p,
+           CLK_CON_MUX_MUX_CLK_CMGP_USI2, 0, 1),
+       MUX(CLK_MOUT_CMGP_USI3, "mout_cmgp_usi3", mout_cmgp_usi3_p,
+           CLK_CON_MUX_MUX_CLK_CMGP_USI3, 0, 1),
+       MUX(CLK_MOUT_CMGP_USI4, "mout_cmgp_usi4", mout_cmgp_usi4_p,
+           CLK_CON_MUX_MUX_CLK_CMGP_USI4, 0, 1),
+       MUX(CLK_MOUT_CMGP_USI5, "mout_cmgp_usi5", mout_cmgp_usi5_p,
+           CLK_CON_MUX_MUX_CLK_CMGP_USI5, 0, 1),
+       MUX(CLK_MOUT_CMGP_USI6, "mout_cmgp_usi6", mout_cmgp_usi6_p,
+           CLK_CON_MUX_MUX_CLK_CMGP_USI6, 0, 1),
+};
+
+static const struct samsung_div_clock cmgp_div_clks[] __initconst = {
+       DIV(CLK_DOUT_CMGP_I2C, "dout_cmgp_i2c", "mout_cmgp_i2c",
+           CLK_CON_DIV_DIV_CLK_CMGP_I2C, 0, 4),
+       DIV(CLK_DOUT_CMGP_SPI_I2C0, "dout_cmgp_spi_i2c0", "mout_cmgp_spi_i2c0",
+           CLK_CON_DIV_DIV_CLK_CMGP_SPI_I2C0, 0, 4),
+       DIV(CLK_DOUT_CMGP_SPI_I2C1, "dout_cmgp_spi_i2c1", "mout_cmgp_spi_i2c1",
+           CLK_CON_DIV_DIV_CLK_CMGP_SPI_I2C1, 0, 4),
+       DIV(CLK_DOUT_CMGP_SPI_MS_CTRL, "dout_cmgp_spi_ms_ctrl",
+           "mout_cmgp_spi_ms_ctrl", CLK_CON_DIV_DIV_CLK_CMGP_SPI_MS_CTRL,
+           0, 4),
+       DIV(CLK_DOUT_CMGP_USI0, "dout_cmgp_usi0", "mout_cmgp_usi0",
+           CLK_CON_DIV_DIV_CLK_CMGP_USI0, 0, 4),
+       DIV(CLK_DOUT_CMGP_USI1, "dout_cmgp_usi1", "mout_cmgp_usi1",
+           CLK_CON_DIV_DIV_CLK_CMGP_USI1, 0, 4),
+       DIV(CLK_DOUT_CMGP_USI2, "dout_cmgp_usi2", "mout_cmgp_usi2",
+           CLK_CON_DIV_DIV_CLK_CMGP_USI2, 0, 4),
+       DIV(CLK_DOUT_CMGP_USI3, "dout_cmgp_usi3", "mout_cmgp_usi3",
+           CLK_CON_DIV_DIV_CLK_CMGP_USI3, 0, 4),
+       DIV(CLK_DOUT_CMGP_USI4, "dout_cmgp_usi4", "mout_cmgp_usi4",
+           CLK_CON_DIV_DIV_CLK_CMGP_USI4, 0, 4),
+       DIV(CLK_DOUT_CMGP_USI5, "dout_cmgp_usi5", "mout_cmgp_usi5",
+           CLK_CON_DIV_DIV_CLK_CMGP_USI5, 0, 4),
+       DIV(CLK_DOUT_CMGP_USI6, "dout_cmgp_usi6", "mout_cmgp_usi6",
+           CLK_CON_DIV_DIV_CLK_CMGP_USI6, 0, 4),
+};
+
+static const struct samsung_cmu_info cmgp_cmu_info __initconst = {
+       .mux_clks               = cmgp_mux_clks,
+       .nr_mux_clks            = ARRAY_SIZE(cmgp_mux_clks),
+       .div_clks               = cmgp_div_clks,
+       .nr_div_clks            = ARRAY_SIZE(cmgp_div_clks),
+       .nr_clk_ids             = CLKS_NR_CMGP,
+       .clk_regs               = cmgp_clk_regs,
+       .nr_clk_regs            = ARRAY_SIZE(cmgp_clk_regs),
+       .clk_name               = "noc",
+};
+
+/* ---- CMU_HSI0 ----------------------------------------------------------- */
+
+/* Register Offset definitions for CMU_HSI0 (0x10a00000) */
+#define PLL_CON0_MUX_CLKAUD_HSI0_NOC_USER                                              0x600
+#define PLL_CON1_MUX_CLKAUD_HSI0_NOC_USER                                              0x604
+#define PLL_CON0_MUX_CLKCMU_HSI0_DPGTC_USER                                            0x610
+#define PLL_CON1_MUX_CLKCMU_HSI0_DPGTC_USER                                            0x614
+#define PLL_CON0_MUX_CLKCMU_HSI0_DPOSC_USER                                            0x620
+#define PLL_CON1_MUX_CLKCMU_HSI0_DPOSC_USER                                            0x624
+#define PLL_CON0_MUX_CLKCMU_HSI0_NOC_USER                                              0x630
+#define PLL_CON1_MUX_CLKCMU_HSI0_NOC_USER                                              0x634
+#define PLL_CON0_MUX_CLKCMU_HSI0_USB32DRD_USER                                         0x640
+#define PLL_CON1_MUX_CLKCMU_HSI0_USB32DRD_USER                                         0x644
+#define CLK_CON_MUX_MUX_CLK_HSI0_NOC                                                   0x1000
+#define CLK_CON_MUX_MUX_CLK_HSI0_RTCCLK                                                        0x1004
+#define CLK_CON_MUX_MUX_CLK_HSI0_USB32DRD                                              0x1008
+#define CLK_CON_DIV_DIV_CLK_HSI0_EUSB                                                  0x1800
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_AS_APB_EUSBPHY_HSI0_IPCLKPORT_PCLKM               0x2000
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_DP_GTC_CLK                    0x2004
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_DP_OSC_CLK                    0x2008
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_PCLK                          0x200c
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_D_TZPC_HSI0_IPCLKPORT_PCLK                                0x2010
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_HSI0_CMU_HSI0_IPCLKPORT_PCLK                      0x2014
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_PPMU_HSI0_BUS1_IPCLKPORT_ACLK                     0x2018
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_PPMU_HSI0_BUS1_IPCLKPORT_PCLK                     0x201c
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_RSTNSYNC_CLK_HSI0_EUSB_IPCLKPORT_CLK              0x2020
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_RSTNSYNC_CLK_HSI0_NOC_IPCLKPORT_CLK               0x2024
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_SLH_ACEL_SI_D_HSI0_IPCLKPORT_I_CLK                        0x2028
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_SLH_AST_SI_G_PPMU_HSI0_IPCLKPORT_I_CLK            0x202c
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_SLH_AXI_MI_LD_AUDHSI0_IPCLKPORT_I_CLK             0x2030
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_SLH_AXI_MI_P_HSI0_IPCLKPORT_I_CLK                 0x2034
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_SLH_AXI_SI_LD_HSI0AUD_IPCLKPORT_I_CLK             0x2038
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_BLK_HSI0_FRC_OTP_DESERIAL_IPCLKPORT_I_CLK         0x203c
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_SYSMMU_D_HSI0_IPCLKPORT_CLK_S2                    0x2040
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_SYSREG_HSI0_IPCLKPORT_PCLK                                0x2044
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_URAM_IPCLKPORT_ACLK                               0x2048
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_EUSB_APB_CLK                 0x204c
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_EUSB_CTRL_PCLK               0x2050
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_USB32DRD_REF_CLK_40          0x2054
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_USBDPPHY_CTRL_PCLK           0x2058
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_USBDPPHY_TCA_APB_CLK         0x205c
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_USBLINK_ACLK                 0x2060
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_USBSUBCTL_APB_PCLK           0x2064
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_VGEN_LITE_HSI0_IPCLKPORT_CLK                      0x2068
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_XIU_D_HSI0_IPCLKPORT_ACLK                         0x206c
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_XIU_P0_HSI0_IPCLKPORT_ACLK                                0x2070
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_OTP_DESERIAL_DPLINK_HDCP_IPCLKPORT_I_CLK          0x2074
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_RSTNSYNC_SR_CLK_HSI0_FREE_OSCCLK_IPCLKPORT_CLK    0x2078
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_RSTNSYNC_SR_CLK_HSI0_NOC_IPCLKPORT_CLK            0x207c
+#define CLK_CON_GAT_CLK_BLK_HSI0_UID_SPC_HSI0_IPCLKPORT_PCLK                           0x2080
+
+static const unsigned long hsi0_clk_regs[] __initconst = {
+       PLL_CON0_MUX_CLKAUD_HSI0_NOC_USER,
+       PLL_CON1_MUX_CLKAUD_HSI0_NOC_USER,
+       PLL_CON0_MUX_CLKCMU_HSI0_DPGTC_USER,
+       PLL_CON1_MUX_CLKCMU_HSI0_DPGTC_USER,
+       PLL_CON0_MUX_CLKCMU_HSI0_DPOSC_USER,
+       PLL_CON1_MUX_CLKCMU_HSI0_DPOSC_USER,
+       PLL_CON0_MUX_CLKCMU_HSI0_NOC_USER,
+       PLL_CON1_MUX_CLKCMU_HSI0_NOC_USER,
+       PLL_CON0_MUX_CLKCMU_HSI0_USB32DRD_USER,
+       PLL_CON1_MUX_CLKCMU_HSI0_USB32DRD_USER,
+       CLK_CON_MUX_MUX_CLK_HSI0_NOC,
+       CLK_CON_MUX_MUX_CLK_HSI0_RTCCLK,
+       CLK_CON_MUX_MUX_CLK_HSI0_USB32DRD,
+       CLK_CON_DIV_DIV_CLK_HSI0_EUSB,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_AS_APB_EUSBPHY_HSI0_IPCLKPORT_PCLKM,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_DP_GTC_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_DP_OSC_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_D_TZPC_HSI0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_HSI0_CMU_HSI0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_PPMU_HSI0_BUS1_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_PPMU_HSI0_BUS1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_RSTNSYNC_CLK_HSI0_EUSB_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_RSTNSYNC_CLK_HSI0_NOC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_SLH_ACEL_SI_D_HSI0_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_SLH_AST_SI_G_PPMU_HSI0_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_SLH_AXI_MI_LD_AUDHSI0_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_SLH_AXI_MI_P_HSI0_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_SLH_AXI_SI_LD_HSI0AUD_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_BLK_HSI0_FRC_OTP_DESERIAL_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_SYSMMU_D_HSI0_IPCLKPORT_CLK_S2,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_SYSREG_HSI0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_URAM_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_EUSB_APB_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_EUSB_CTRL_PCLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_USB32DRD_REF_CLK_40,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_USBDPPHY_CTRL_PCLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_USBDPPHY_TCA_APB_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_USBLINK_ACLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_USB32DRD_IPCLKPORT_I_USBSUBCTL_APB_PCLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_VGEN_LITE_HSI0_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_XIU_D_HSI0_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_XIU_P0_HSI0_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_OTP_DESERIAL_DPLINK_HDCP_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_RSTNSYNC_SR_CLK_HSI0_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_RSTNSYNC_SR_CLK_HSI0_NOC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_HSI0_UID_SPC_HSI0_IPCLKPORT_PCLK,
+};
+
+PNAME(mout_clkcmu_hsi0_dpgtc_user_p)   = { "oscclk", "dout_cmu_hsi0_dpgtc" };
+PNAME(mout_clkcmu_hsi0_dposc_user_p)   = { "oscclk", "dout_cmu_hsi0_dposc" };
+PNAME(mout_clkcmu_hsi0_noc_user_p)     = { "oscclk", "dout_cmu_hsi0_noc" };
+PNAME(mout_clkcmu_hsi0_usb32drd_user_p)        = { "oscclk",
+                                           "dout_cmu_hsi0_usb32drd" };
+PNAME(mout_mux_clk_hsi0_noc_p)         = { "mout_clkcmu_hsi0_noc_user" };
+PNAME(mout_mux_clk_hsi0_rtcclk_p)      = { "rtcclk", "oscclk" };
+PNAME(mout_mux_clk_hsi0_usb32drd_p)    = { "dout_tcxo_div4",
+                                           "mout_clkcmu_hsi0_usb32drd_user" };
+
+static const struct samsung_mux_clock hsi0_mux_clks[] __initconst = {
+       MUX(CLK_MOUT_CLKCMU_HSI0_DPGTC_USER, "mout_clkcmu_hsi0_dpgtc_user",
+           mout_clkcmu_hsi0_dpgtc_user_p, PLL_CON0_MUX_CLKCMU_HSI0_DPGTC_USER,
+           4, 1),
+       MUX(CLK_MOUT_CLKCMU_HSI0_DPOSC_USER, "mout_clkcmu_hsi0_dposc_user",
+           mout_clkcmu_hsi0_dposc_user_p, PLL_CON0_MUX_CLKCMU_HSI0_DPOSC_USER,
+           4, 1),
+       MUX(CLK_MOUT_CLKCMU_HSI0_NOC_USER, "mout_clkcmu_hsi0_noc_user",
+           mout_clkcmu_hsi0_noc_user_p, PLL_CON0_MUX_CLKCMU_HSI0_NOC_USER,
+           4, 1),
+       MUX(CLK_MOUT_CLKCMU_HSI0_USB32DRD_USER,
+           "mout_clkcmu_hsi0_usb32drd_user", mout_clkcmu_hsi0_usb32drd_user_p,
+           PLL_CON0_MUX_CLKCMU_HSI0_USB32DRD_USER, 4, 1),
+       MUX(CLK_MOUT_HSI0_NOC, "mout_hsi0_noc", mout_mux_clk_hsi0_noc_p,
+           CLK_CON_MUX_MUX_CLK_HSI0_NOC, 0, 1),
+       MUX(CLK_MOUT_HSI0_RTCCLK, "mout_hsi0_rtcclk",
+           mout_mux_clk_hsi0_rtcclk_p, CLK_CON_MUX_MUX_CLK_HSI0_RTCCLK, 0, 1),
+       MUX(CLK_MOUT_HSI0_USB32DRD, "mout_hsi0_usb32drd",
+           mout_mux_clk_hsi0_usb32drd_p, CLK_CON_MUX_MUX_CLK_HSI0_USB32DRD,
+           0, 1),
+};
+
+static const struct samsung_div_clock hsi0_div_clks[] __initconst = {
+       DIV(CLK_DOUT_DIV_CLK_HSI0_EUSB, "dout_div_clk_hsi0_eusb",
+           "mout_hsi0_noc", CLK_CON_DIV_DIV_CLK_HSI0_EUSB, 0, 2),
+};
+
+static const struct samsung_cmu_info hsi0_cmu_info __initconst = {
+       .mux_clks               = hsi0_mux_clks,
+       .nr_mux_clks            = ARRAY_SIZE(hsi0_mux_clks),
+       .div_clks               = hsi0_div_clks,
+       .nr_div_clks            = ARRAY_SIZE(hsi0_div_clks),
+       .nr_clk_ids             = CLKS_NR_HSI0,
+       .clk_regs               = hsi0_clk_regs,
+       .nr_clk_regs            = ARRAY_SIZE(hsi0_clk_regs),
+       .clk_name               = "noc",
+};
+
+/* ---- CMU_PERIC0 --------------------------------------------------------- */
+
+/* Register Offset definitions for CMU_PERIC0 (0x10400000) */
+#define PLL_CON0_MUX_CLKCMU_PERIC0_IP0_USER                                            0x600
+#define PLL_CON1_MUX_CLKCMU_PERIC0_IP0_USER                                            0x604
+#define PLL_CON0_MUX_CLKCMU_PERIC0_IP1_USER                                            0x610
+#define PLL_CON1_MUX_CLKCMU_PERIC0_IP1_USER                                            0x614
+#define PLL_CON0_MUX_CLKCMU_PERIC0_NOC_USER                                            0x620
+#define PLL_CON1_MUX_CLKCMU_PERIC0_NOC_USER                                            0x624
+#define CLK_CON_MUX_MUX_CLK_PERIC0_I2C                                                 0x1000
+#define CLK_CON_MUX_MUX_CLK_PERIC0_USI04                                               0x1010
+#define CLK_CON_DIV_DIV_CLK_PERIC0_I2C                                                 0x1800
+#define CLK_CON_DIV_DIV_CLK_PERIC0_USI04                                               0x1810
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_D_TZPC_PERIC0_IPCLKPORT_PCLK                    0x2000
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_GPIO_PERIC0_IPCLKPORT_PCLK                      0x2004
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_PERIC0_CMU_PERIC0_IPCLKPORT_PCLK                        0x2008
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_FREE_OSCCLK_IPCLKPORT_CLK   0x200c
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_I2C_IPCLKPORT_CLK           0x2010
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_NOCP_IPCLKPORT_CLK          0x2014
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_SR_CLK_PERIC0_USI04_IPCLKPORT_CLK      0x2018
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_SLH_AXI_MI_P_PERIC0_IPCLKPORT_I_CLK             0x201c
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_SYSREG_PERIC0_IPCLKPORT_PCLK                    0x2020
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_USI04_I2C_IPCLKPORT_IPCLK                       0x2024
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_USI04_I2C_IPCLKPORT_PCLK                                0x2028
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_USI04_USI_IPCLKPORT_IPCLK                       0x202c
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_USI04_USI_IPCLKPORT_PCLK                                0x2030
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C00_IPCLKPORT_I_PCLK                          0x2034
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C00_IPCLKPORT_I_SCLK                          0x2038
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C01_IPCLKPORT_I_PCLK                          0x203c
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C01_IPCLKPORT_I_SCLK                          0x2040
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C02_IPCLKPORT_I_PCLK                          0x2044
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C02_IPCLKPORT_I_SCLK                          0x2048
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_SR_CLK_PERIC0_I2C_IPCLKPORT_CLK                0x204c
+#define CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_SR_CLK_PERIC0_NOCP_IPCLKPORT_CLK       0x2050
+
+static const unsigned long peric0_clk_regs[] __initconst = {
+       PLL_CON0_MUX_CLKCMU_PERIC0_IP0_USER,
+       PLL_CON1_MUX_CLKCMU_PERIC0_IP0_USER,
+       PLL_CON0_MUX_CLKCMU_PERIC0_IP1_USER,
+       PLL_CON1_MUX_CLKCMU_PERIC0_IP1_USER,
+       PLL_CON0_MUX_CLKCMU_PERIC0_NOC_USER,
+       PLL_CON1_MUX_CLKCMU_PERIC0_NOC_USER,
+       CLK_CON_MUX_MUX_CLK_PERIC0_I2C,
+       CLK_CON_MUX_MUX_CLK_PERIC0_USI04,
+       CLK_CON_DIV_DIV_CLK_PERIC0_I2C,
+       CLK_CON_DIV_DIV_CLK_PERIC0_USI04,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_D_TZPC_PERIC0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_GPIO_PERIC0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_PERIC0_CMU_PERIC0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_I2C_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_NOCP_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_SR_CLK_PERIC0_USI04_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_SLH_AXI_MI_P_PERIC0_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_SYSREG_PERIC0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_USI04_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_USI04_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_USI04_USI_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_USI04_USI_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C00_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C00_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C01_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C01_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C02_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_I3C02_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_SR_CLK_PERIC0_I2C_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_SR_CLK_PERIC0_NOCP_IPCLKPORT_CLK,
+};
+
+PNAME(mout_peric0_ip0_user_p)  = { "oscclk", "dout_cmu_peric0_ip0" };
+PNAME(mout_peric0_ip1_user_p)  = { "oscclk", "dout_cmu_peric0_ip1" };
+PNAME(mout_peric0_noc_user_p)  = { "oscclk", "dout_cmu_peric0_noc" };
+PNAME(mout_peric0_i2c_p)       = { "oscclk", "mout_peric0_ip0_user",
+                                   "mout_peric0_ip0_user", "oscclk" };
+PNAME(mout_peric0_usi04_p)     = { "oscclk", "mout_peric0_ip0_user",
+                                   "mout_peric0_ip0_user", "oscclk" };
+
+static const struct samsung_mux_clock peric0_mux_clks[] __initconst = {
+       MUX(CLK_MOUT_PERIC0_IP0_USER, "mout_peric0_ip0_user",
+           mout_peric0_ip0_user_p, PLL_CON0_MUX_CLKCMU_PERIC0_IP0_USER, 4, 1),
+       MUX(CLK_MOUT_PERIC0_IP1_USER, "mout_peric0_ip1_user",
+           mout_peric0_ip1_user_p, PLL_CON0_MUX_CLKCMU_PERIC0_IP1_USER, 4, 1),
+       MUX(CLK_MOUT_PERIC0_NOC_USER, "mout_peric0_noc_user",
+           mout_peric0_noc_user_p, PLL_CON0_MUX_CLKCMU_PERIC0_NOC_USER, 4, 1),
+       MUX(CLK_MOUT_PERIC0_I2C, "mout_peric0_i2c", mout_peric0_i2c_p,
+           CLK_CON_MUX_MUX_CLK_PERIC0_I2C, 0, 2),
+       MUX(CLK_MOUT_PERIC0_USI04, "mout_peric0_usi04", mout_peric0_usi04_p,
+           CLK_CON_MUX_MUX_CLK_PERIC0_USI04, 0, 2),
+};
+
+static const struct samsung_div_clock peric0_div_clks[] __initconst = {
+       DIV(CLK_DOUT_PERIC0_I2C, "dout_peric0_i2c", "mout_peric0_i2c",
+           CLK_CON_DIV_DIV_CLK_PERIC0_I2C, 0, 4),
+       DIV(CLK_DOUT_PERIC0_USI04, "dout_peric0_usi04", "mout_peric0_usi04",
+           CLK_CON_DIV_DIV_CLK_PERIC0_USI04, 0, 7),
+};
+
+static const struct samsung_cmu_info peric0_cmu_info __initconst = {
+       .mux_clks               = peric0_mux_clks,
+       .nr_mux_clks            = ARRAY_SIZE(peric0_mux_clks),
+       .div_clks               = peric0_div_clks,
+       .nr_div_clks            = ARRAY_SIZE(peric0_div_clks),
+       .nr_clk_ids             = CLKS_NR_PERIC0,
+       .clk_regs               = peric0_clk_regs,
+       .nr_clk_regs            = ARRAY_SIZE(peric0_clk_regs),
+       .clk_name               = "noc",
+};
+
+/* ---- CMU_PERIC1 --------------------------------------------------------- */
+
+/* Register Offset definitions for CMU_PERIC1 (0x10700000) */
+#define PLL_CON0_MUX_CLKCMU_PERIC1_IP0_USER                                                    0x600
+#define PLL_CON1_MUX_CLKCMU_PERIC1_IP0_USER                                                    0x604
+#define PLL_CON0_MUX_CLKCMU_PERIC1_IP1_USER                                                    0x610
+#define PLL_CON1_MUX_CLKCMU_PERIC1_IP1_USER                                                    0x614
+#define PLL_CON0_MUX_CLKCMU_PERIC1_NOC_USER                                                    0x620
+#define PLL_CON1_MUX_CLKCMU_PERIC1_NOC_USER                                                    0x624
+#define CLK_CON_MUX_MUX_CLK_PERIC1_I2C                                                         0x1000
+#define CLK_CON_MUX_MUX_CLK_PERIC1_SPI_MS_CTRL                                                 0x1004
+#define CLK_CON_MUX_MUX_CLK_PERIC1_UART_BT                                                     0x1008
+#define CLK_CON_MUX_MUX_CLK_PERIC1_USI07                                                       0x100c
+#define CLK_CON_MUX_MUX_CLK_PERIC1_USI07_SPI_I2C                                               0x1010
+#define CLK_CON_MUX_MUX_CLK_PERIC1_USI08                                                       0x1014
+#define CLK_CON_MUX_MUX_CLK_PERIC1_USI08_SPI_I2C                                               0x1018
+#define CLK_CON_MUX_MUX_CLK_PERIC1_USI09                                                       0x101c
+#define CLK_CON_MUX_MUX_CLK_PERIC1_USI10                                                       0x1020
+#define CLK_CON_DIV_DIV_CLK_PERIC1_I2C                                                         0x1800
+#define CLK_CON_DIV_DIV_CLK_PERIC1_SPI_MS_CTRL                                                 0x1804
+#define CLK_CON_DIV_DIV_CLK_PERIC1_UART_BT                                                     0x1808
+#define CLK_CON_DIV_DIV_CLK_PERIC1_USI07                                                       0x180c
+#define CLK_CON_DIV_DIV_CLK_PERIC1_USI07_SPI_I2C                                               0x1810
+#define CLK_CON_DIV_DIV_CLK_PERIC1_USI08                                                       0x1814
+#define CLK_CON_DIV_DIV_CLK_PERIC1_USI08_SPI_I2C                                               0x1818
+#define CLK_CON_DIV_DIV_CLK_PERIC1_USI09                                                       0x181c
+#define CLK_CON_DIV_DIV_CLK_PERIC1_USI10                                                       0x1820
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_BT_UART_IPCLKPORT_IPCLK                                 0x2000
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_BT_UART_IPCLKPORT_PCLK                                  0x2004
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_D_TZPC_PERIC1_IPCLKPORT_PCLK                            0x2008
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_GPIO_PERIC1_IPCLKPORT_PCLK                              0x200c
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_I2C_IPCLKPORT_CLK                        0x2010
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_NOCP_IPCLKPORT_CLK               0x2014
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_PERIC1_CMU_PERIC1_IPCLKPORT_PCLK                                0x2028
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_FREE_OSCCLK_IPCLKPORT_CLK           0x202c
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_NOCP_IPCLKPORT_CLK                  0x2034
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_UART_BT_IPCLKPORT_CLK            0x2038
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI07_IPCLKPORT_CLK              0x203c
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI07_SPI_I2C_IPCLKPORT_CLK      0x2040
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI08_IPCLKPORT_CLK              0x2044
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI08_SPI_I2C_IPCLKPORT_CLK      0x2048
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI09_IPCLKPORT_CLK              0x204c
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI10_IPCLKPORT_CLK              0x2050
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_SPI_MS_CTRL_IPCLKPORT_CLK                0x2054
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_SLH_AXI_MI_P_PERIC1_IPCLKPORT_I_CLK                     0x205c
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_SPI_MULTI_SLV_Q_CTRL_PERIC1_IPCLKPORT_CLK               0x2060
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_SYSREG_PERIC1_IPCLKPORT_PCLK                            0x2064
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI07_SPI_I2C_IPCLKPORT_IPCLK                           0x2068
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI07_SPI_I2C_IPCLKPORT_PCLK                            0x206c
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI07_USI_IPCLKPORT_IPCLK                               0x2070
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI07_USI_IPCLKPORT_PCLK                                        0x2074
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI08_SPI_I2C_IPCLKPORT_IPCLK                           0x2078
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI08_SPI_I2C_IPCLKPORT_PCLK                            0x207c
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI08_USI_IPCLKPORT_IPCLK                               0x2080
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI08_USI_IPCLKPORT_PCLK                                        0x2084
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI09_I2C_IPCLKPORT_IPCLK                               0x2088
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI09_I2C_IPCLKPORT_PCLK                                        0x208c
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI09_USI_IPCLKPORT_IPCLK                               0x2090
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI09_USI_IPCLKPORT_PCLK                                        0x2094
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI10_I2C_IPCLKPORT_IPCLK                               0x2098
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI10_I2C_IPCLKPORT_PCLK                                        0x209c
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI10_USI_IPCLKPORT_IPCLK                               0x20a0
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI10_USI_IPCLKPORT_PCLK                                        0x20a4
+#define CLK_CON_GAT_CLK_BLK_PERIC1_UID_XIU_P_PERIC1_IPCLKPORT_ACLK                             0x20a8
+
+static const unsigned long peric1_clk_regs[] __initconst = {
+       PLL_CON0_MUX_CLKCMU_PERIC1_IP0_USER,
+       PLL_CON1_MUX_CLKCMU_PERIC1_IP0_USER,
+       PLL_CON0_MUX_CLKCMU_PERIC1_IP1_USER,
+       PLL_CON1_MUX_CLKCMU_PERIC1_IP1_USER,
+       PLL_CON0_MUX_CLKCMU_PERIC1_NOC_USER,
+       PLL_CON1_MUX_CLKCMU_PERIC1_NOC_USER,
+       CLK_CON_MUX_MUX_CLK_PERIC1_I2C,
+       CLK_CON_MUX_MUX_CLK_PERIC1_SPI_MS_CTRL,
+       CLK_CON_MUX_MUX_CLK_PERIC1_UART_BT,
+       CLK_CON_MUX_MUX_CLK_PERIC1_USI07,
+       CLK_CON_MUX_MUX_CLK_PERIC1_USI07_SPI_I2C,
+       CLK_CON_MUX_MUX_CLK_PERIC1_USI08,
+       CLK_CON_MUX_MUX_CLK_PERIC1_USI08_SPI_I2C,
+       CLK_CON_MUX_MUX_CLK_PERIC1_USI09,
+       CLK_CON_MUX_MUX_CLK_PERIC1_USI10,
+       CLK_CON_DIV_DIV_CLK_PERIC1_I2C,
+       CLK_CON_DIV_DIV_CLK_PERIC1_SPI_MS_CTRL,
+       CLK_CON_DIV_DIV_CLK_PERIC1_UART_BT,
+       CLK_CON_DIV_DIV_CLK_PERIC1_USI07,
+       CLK_CON_DIV_DIV_CLK_PERIC1_USI07_SPI_I2C,
+       CLK_CON_DIV_DIV_CLK_PERIC1_USI08,
+       CLK_CON_DIV_DIV_CLK_PERIC1_USI08_SPI_I2C,
+       CLK_CON_DIV_DIV_CLK_PERIC1_USI09,
+       CLK_CON_DIV_DIV_CLK_PERIC1_USI10,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_BT_UART_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_BT_UART_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_D_TZPC_PERIC1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_GPIO_PERIC1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_I2C_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_NOCP_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_PERIC1_CMU_PERIC1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_NOCP_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_UART_BT_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI07_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI07_SPI_I2C_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI08_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI08_SPI_I2C_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI09_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_USI10_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_SR_CLK_PERIC1_SPI_MS_CTRL_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_SLH_AXI_MI_P_PERIC1_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_SPI_MULTI_SLV_Q_CTRL_PERIC1_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_SYSREG_PERIC1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI07_SPI_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI07_SPI_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI07_USI_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI07_USI_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI08_SPI_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI08_SPI_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI08_USI_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI08_USI_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI09_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI09_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI09_USI_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI09_USI_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI10_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI10_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI10_USI_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_USI10_USI_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC1_UID_XIU_P_PERIC1_IPCLKPORT_ACLK,
+};
+
+PNAME(mout_peric1_ip0_user_p)          = { "oscclk", "dout_cmu_peric1_ip0" };
+PNAME(mout_peric1_ip1_user_p)          = { "oscclk", "dout_cmu_peric1_ip1" };
+PNAME(mout_peric1_noc_user_p)          = { "oscclk", "dout_cmu_peric1_noc" };
+PNAME(mout_peric1_i2c_p)               = { "oscclk", "mout_peric1_ip0_user",
+                                           "mout_peric1_ip1_user", "oscclk" };
+PNAME(mout_peric1_spi_ms_ctrl_p)       = { "oscclk", "mout_peric1_ip0_user",
+                                           "mout_peric1_ip1_user", "oscclk" };
+PNAME(mout_peric1_uart_bt_p)           = { "oscclk", "mout_peric1_ip0_user",
+                                           "mout_peric1_ip1_user", "oscclk" };
+PNAME(mout_peric1_usi07_p)             = { "oscclk", "mout_peric1_ip0_user",
+                                           "mout_peric1_ip1_user", "oscclk" };
+PNAME(mout_peric1_usi07_spi_i2c_p)     = { "oscclk", "mout_peric1_ip0_user",
+                                           "mout_peric1_ip1_user", "oscclk" };
+PNAME(mout_peric1_usi08_p)             = { "oscclk", "mout_peric1_ip0_user",
+                                           "mout_peric1_ip1_user", "oscclk" };
+PNAME(mout_peric1_usi08_spi_i2c_p)     = { "oscclk", "mout_peric1_ip0_user",
+                                           "mout_peric1_ip1_user", "oscclk" };
+PNAME(mout_peric1_usi09_p)             = { "oscclk", "mout_peric1_ip0_user",
+                                           "mout_peric1_ip1_user", "oscclk" };
+PNAME(mout_peric1_usi10_p)             = { "oscclk", "mout_peric1_ip0_user",
+                                           "mout_peric1_ip1_user", "oscclk" };
+
+static const struct samsung_mux_clock peric1_mux_clks[] __initconst = {
+       MUX(CLK_MOUT_PERIC1_IP0_USER, "mout_peric1_ip0_user",
+           mout_peric1_ip0_user_p, PLL_CON0_MUX_CLKCMU_PERIC1_IP0_USER, 4, 1),
+       MUX(CLK_MOUT_PERIC1_IP1_USER, "mout_peric1_ip1_user",
+           mout_peric1_ip1_user_p, PLL_CON0_MUX_CLKCMU_PERIC1_IP1_USER, 4, 1),
+       MUX(CLK_MOUT_PERIC1_NOC_USER, "mout_peric1_noc_user",
+           mout_peric1_noc_user_p, PLL_CON0_MUX_CLKCMU_PERIC1_NOC_USER, 4, 1),
+       MUX(CLK_MOUT_PERIC1_I2C, "mout_peric1_i2c", mout_peric1_i2c_p,
+           CLK_CON_MUX_MUX_CLK_PERIC1_I2C, 0, 2),
+       MUX(CLK_MOUT_PERIC1_SPI_MS_CTRL, "mout_peric1_spi_ms_ctrl",
+           mout_peric1_spi_ms_ctrl_p, CLK_CON_MUX_MUX_CLK_PERIC1_SPI_MS_CTRL,
+           0, 2),
+       MUX(CLK_MOUT_PERIC1_UART_BT, "mout_peric1_uart_bt",
+           mout_peric1_uart_bt_p, CLK_CON_MUX_MUX_CLK_PERIC1_UART_BT, 0, 2),
+       MUX(CLK_MOUT_PERIC1_USI07, "mout_peric1_usi07", mout_peric1_usi07_p,
+           CLK_CON_MUX_MUX_CLK_PERIC1_USI07, 0, 2),
+       MUX(CLK_MOUT_PERIC1_USI07_SPI_I2C, "mout_peric1_usi07_spi_i2c",
+           mout_peric1_usi07_spi_i2c_p,
+           CLK_CON_MUX_MUX_CLK_PERIC1_USI07_SPI_I2C, 0, 2),
+       MUX(CLK_MOUT_PERIC1_USI08, "mout_peric1_usi08", mout_peric1_usi08_p,
+           CLK_CON_MUX_MUX_CLK_PERIC1_USI08, 0, 2),
+       MUX(CLK_MOUT_PERIC1_USI08_SPI_I2C, "mout_peric1_usi08_spi_i2c",
+           mout_peric1_usi08_spi_i2c_p,
+           CLK_CON_MUX_MUX_CLK_PERIC1_USI08_SPI_I2C, 0, 2),
+       MUX(CLK_MOUT_PERIC1_USI09, "mout_peric1_usi09", mout_peric1_usi09_p,
+           CLK_CON_MUX_MUX_CLK_PERIC1_USI09, 0, 2),
+       MUX(CLK_MOUT_PERIC1_USI10, "mout_peric1_usi10", mout_peric1_usi10_p,
+           CLK_CON_MUX_MUX_CLK_PERIC1_USI10, 0, 2),
+};
+
+static const struct samsung_div_clock peric1_div_clks[] __initconst = {
+       DIV(CLK_DOUT_PERIC1_I2C, "dout_peric1_i2c", "mout_peric1_i2c",
+           CLK_CON_DIV_DIV_CLK_PERIC1_I2C, 0, 4),
+       DIV(CLK_DOUT_PERIC1_SPI_MS_CTRL, "dout_peric1_spi_ms_ctrl",
+           "mout_peric1_spi_ms_ctrl", CLK_CON_DIV_DIV_CLK_PERIC1_SPI_MS_CTRL,
+           0, 7),
+       DIV(CLK_DOUT_PERIC1_UART_BT, "dout_peric1_uart_bt",
+           "mout_peric1_uart_bt", CLK_CON_DIV_DIV_CLK_PERIC1_UART_BT, 0, 4),
+       DIV(CLK_DOUT_PERIC1_USI07, "dout_peric1_usi07", "mout_peric1_usi07",
+           CLK_CON_DIV_DIV_CLK_PERIC1_USI07, 0, 7),
+       DIV(CLK_DOUT_PERIC1_USI07_SPI_I2C, "dout_peric1_usi07_spi_i2c",
+           "mout_peric1_usi07_spi_i2c",
+           CLK_CON_DIV_DIV_CLK_PERIC1_USI07_SPI_I2C, 0, 4),
+       DIV(CLK_DOUT_PERIC1_USI08, "dout_peric1_usi08", "mout_peric1_usi08",
+           CLK_CON_DIV_DIV_CLK_PERIC1_USI08, 0, 7),
+       DIV(CLK_DOUT_PERIC1_USI08_SPI_I2C, "dout_peric1_usi08_spi_i2c",
+           "mout_peric1_usi08_spi_i2c",
+           CLK_CON_DIV_DIV_CLK_PERIC1_USI08_SPI_I2C, 0, 4),
+       DIV(CLK_DOUT_PERIC1_USI09, "dout_peric1_usi09", "mout_peric1_usi09",
+           CLK_CON_DIV_DIV_CLK_PERIC1_USI09, 0, 7),
+       DIV(CLK_DOUT_PERIC1_USI10, "dout_peric1_usi10", "mout_peric1_usi10",
+           CLK_CON_DIV_DIV_CLK_PERIC1_USI10, 0, 7),
+};
+
+static const struct samsung_cmu_info peric1_cmu_info __initconst = {
+       .mux_clks               = peric1_mux_clks,
+       .nr_mux_clks            = ARRAY_SIZE(peric1_mux_clks),
+       .div_clks               = peric1_div_clks,
+       .nr_div_clks            = ARRAY_SIZE(peric1_div_clks),
+       .nr_clk_ids             = CLKS_NR_PERIC1,
+       .clk_regs               = peric1_clk_regs,
+       .nr_clk_regs            = ARRAY_SIZE(peric1_clk_regs),
+       .clk_name               = "noc",
+};
+
+/* ---- CMU_PERIC2 --------------------------------------------------------- */
+
+/* Register Offset definitions for CMU_PERIC2 (0x11c00000) */
+#define PLL_CON0_MUX_CLKCMU_PERIC2_IP0_USER                                                    0x600
+#define PLL_CON1_MUX_CLKCMU_PERIC2_IP0_USER                                                    0x604
+#define PLL_CON0_MUX_CLKCMU_PERIC2_IP1_USER                                                    0x610
+#define PLL_CON1_MUX_CLKCMU_PERIC2_IP1_USER                                                    0x614
+#define PLL_CON0_MUX_CLKCMU_PERIC2_NOC_USER                                                    0x620
+#define PLL_CON1_MUX_CLKCMU_PERIC2_NOC_USER                                                    0x624
+#define CLK_CON_MUX_MUX_CLK_PERIC2_I2C                                                         0x1000
+#define CLK_CON_MUX_MUX_CLK_PERIC2_SPI_MS_CTRL                                                 0x1004
+#define CLK_CON_MUX_MUX_CLK_PERIC2_UART_DBG                                                    0x1008
+#define CLK_CON_MUX_MUX_CLK_PERIC2_USI00                                                       0x100c
+#define CLK_CON_MUX_MUX_CLK_PERIC2_USI00_SPI_I2C                                               0x1010
+#define CLK_CON_MUX_MUX_CLK_PERIC2_USI01                                                       0x1014
+#define CLK_CON_MUX_MUX_CLK_PERIC2_USI01_SPI_I2C                                               0x1018
+#define CLK_CON_MUX_MUX_CLK_PERIC2_USI02                                                       0x101c
+#define CLK_CON_MUX_MUX_CLK_PERIC2_USI03                                                       0x1020
+#define CLK_CON_MUX_MUX_CLK_PERIC2_USI05                                                       0x1024
+#define CLK_CON_MUX_MUX_CLK_PERIC2_USI06                                                       0x1028
+#define CLK_CON_MUX_MUX_CLK_PERIC2_USI11                                                       0x102c
+#define CLK_CON_DIV_DIV_CLK_PERIC2_I2C                                                         0x1800
+#define CLK_CON_DIV_DIV_CLK_PERIC2_SPI_MS_CTRL                                                 0x1804
+#define CLK_CON_DIV_DIV_CLK_PERIC2_UART_DBG                                                    0x1808
+#define CLK_CON_DIV_DIV_CLK_PERIC2_USI00                                                       0x180c
+#define CLK_CON_DIV_DIV_CLK_PERIC2_USI00_SPI_I2C                                               0x1810
+#define CLK_CON_DIV_DIV_CLK_PERIC2_USI01                                                       0x1814
+#define CLK_CON_DIV_DIV_CLK_PERIC2_USI01_SPI_I2C                                               0x1818
+#define CLK_CON_DIV_DIV_CLK_PERIC2_USI02                                                       0x181c
+#define CLK_CON_DIV_DIV_CLK_PERIC2_USI03                                                       0x1820
+#define CLK_CON_DIV_DIV_CLK_PERIC2_USI05                                                       0x1824
+#define CLK_CON_DIV_DIV_CLK_PERIC2_USI06                                                       0x1828
+#define CLK_CON_DIV_DIV_CLK_PERIC2_USI11                                                       0x182c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_DBG_UART_IPCLKPORT_IPCLK                                        0x2000
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_DBG_UART_IPCLKPORT_PCLK                                 0x2004
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_D_TZPC_PERIC2_IPCLKPORT_PCLK                            0x2008
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_GPIO_PERIC2_IPCLKPORT_PCLK                              0x200c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C03_OIS_IPCLKPORT_I_PCLK                              0x2010
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C03_OIS_IPCLKPORT_I_SCLK                              0x2014
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C04_IPCLKPORT_I_PCLK                                  0x2018
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C04_IPCLKPORT_I_SCLK                                  0x201c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C05_IPCLKPORT_I_PCLK                                  0x2020
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C05_IPCLKPORT_I_SCLK                                  0x2024
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C06_IPCLKPORT_I_PCLK                                  0x2028
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C06_IPCLKPORT_I_SCLK                                  0x202c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C07_IPCLKPORT_I_PCLK                                  0x2030
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C07_IPCLKPORT_I_SCLK                                  0x2034
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C08_IPCLKPORT_I_PCLK                                  0x2038
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C08_IPCLKPORT_I_SCLK                                  0x203c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C09_IPCLKPORT_I_PCLK                                  0x2040
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C09_IPCLKPORT_I_SCLK                                  0x2044
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C10_IPCLKPORT_I_PCLK                                  0x2048
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C10_IPCLKPORT_I_SCLK                                  0x204c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C11_IPCLKPORT_I_PCLK                                  0x2050
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C11_IPCLKPORT_I_SCLK                                  0x2054
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_PERIC2_CMU_PERIC2_IPCLKPORT_PCLK                                0x2058
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_PWM_IPCLKPORT_I_PCLK_S0                                 0x205c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_CLK_PERIC2_FREE_OSCCLK_IPCLKPORT_CLK           0x2060
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_CLK_PERIC2_I2C_IPCLKPORT_CLK                   0x2064
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_CLK_PERIC2_NOCP_IPCLKPORT_CLK                  0x2068
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_UART_DBG_IPCLKPORT_CLK           0x206c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI00_IPCLKPORT_CLK              0x2070
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI00_SPI_I2C_IPCLKPORT_CLK      0x2074
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI01_IPCLKPORT_CLK              0x2078
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI01_SPI_I2C_IPCLKPORT_CLK      0x207c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI02_IPCLKPORT_CLK              0x2080
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI03_IPCLKPORT_CLK              0x2084
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI05_IPCLKPORT_CLK              0x2088
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI06_IPCLKPORT_CLK              0x208c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI11_IPCLKPORT_CLK              0x2090
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_SPI_MS_CTRL_IPCLKPORT_CLK                0x2094
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_SLH_AXI_MI_P_PERIC2_IPCLKPORT_I_CLK                     0x2098
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_SPI_MULTI_SLV_Q_CTRL_PERIC2_IPCLKPORT_CLK               0x209c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_SYSREG_PERIC2_IPCLKPORT_PCLK                            0x20a0
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI00_SPI_I2C_IPCLKPORT_IPCLK                           0x20a4
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI00_SPI_I2C_IPCLKPORT_PCLK                            0x20a8
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI00_USI_IPCLKPORT_IPCLK                               0x20ac
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI00_USI_IPCLKPORT_PCLK                                        0x20b0
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI01_SPI_I2C_IPCLKPORT_IPCLK                           0x20b4
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI01_SPI_I2C_IPCLKPORT_PCLK                            0x20b8
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI01_USI_IPCLKPORT_IPCLK                               0x20bc
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI01_USI_IPCLKPORT_PCLK                                        0x20c0
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI02_I2C_IPCLKPORT_IPCLK                               0x20c4
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI02_I2C_IPCLKPORT_PCLK                                        0x20c8
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI02_USI_IPCLKPORT_IPCLK                               0x20cc
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI02_USI_IPCLKPORT_PCLK                                        0x20d0
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI03_I2C_IPCLKPORT_IPCLK                               0x20d4
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI03_I2C_IPCLKPORT_PCLK                                        0x20d8
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI03_USI_IPCLKPORT_IPCLK                               0x20dc
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI03_USI_IPCLKPORT_PCLK                                        0x20e0
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI05_I2C_IPCLKPORT_IPCLK                               0x20e4
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI05_I2C_IPCLKPORT_PCLK                                        0x20e8
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI05_USI_OIS_IPCLKPORT_IPCLK                           0x20ec
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI05_USI_OIS_IPCLKPORT_PCLK                            0x20f0
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI06_I2C_IPCLKPORT_IPCLK                               0x20f4
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI06_I2C_IPCLKPORT_PCLK                                        0x20f8
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI06_USI_OIS_IPCLKPORT_IPCLK                           0x20fc
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI06_USI_OIS_IPCLKPORT_PCLK                            0x2100
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI11_I2C_IPCLKPORT_IPCLK                               0x2104
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI11_I2C_IPCLKPORT_PCLK                                        0x2108
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI11_USI_IPCLKPORT_IPCLK                               0x210c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI11_USI_IPCLKPORT_PCLK                                        0x2110
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_I2C_IPCLKPORT_CLK                        0x2114
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_NOCP_IPCLKPORT_CLK               0x2118
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_SLH_AXI_MI_LP_CSISPERIC2_IPCLKPORT_I_CLK                        0x211c
+#define CLK_CON_GAT_CLK_BLK_PERIC2_UID_XIU_P_PERIC2_IPCLKPORT_ACLK                             0x2120
+
+static const unsigned long peric2_clk_regs[] __initconst = {
+       PLL_CON0_MUX_CLKCMU_PERIC2_IP0_USER,
+       PLL_CON1_MUX_CLKCMU_PERIC2_IP0_USER,
+       PLL_CON0_MUX_CLKCMU_PERIC2_IP1_USER,
+       PLL_CON1_MUX_CLKCMU_PERIC2_IP1_USER,
+       PLL_CON0_MUX_CLKCMU_PERIC2_NOC_USER,
+       PLL_CON1_MUX_CLKCMU_PERIC2_NOC_USER,
+       CLK_CON_MUX_MUX_CLK_PERIC2_I2C,
+       CLK_CON_MUX_MUX_CLK_PERIC2_SPI_MS_CTRL,
+       CLK_CON_MUX_MUX_CLK_PERIC2_UART_DBG,
+       CLK_CON_MUX_MUX_CLK_PERIC2_USI00,
+       CLK_CON_MUX_MUX_CLK_PERIC2_USI00_SPI_I2C,
+       CLK_CON_MUX_MUX_CLK_PERIC2_USI01,
+       CLK_CON_MUX_MUX_CLK_PERIC2_USI01_SPI_I2C,
+       CLK_CON_MUX_MUX_CLK_PERIC2_USI02,
+       CLK_CON_MUX_MUX_CLK_PERIC2_USI03,
+       CLK_CON_MUX_MUX_CLK_PERIC2_USI05,
+       CLK_CON_MUX_MUX_CLK_PERIC2_USI06,
+       CLK_CON_MUX_MUX_CLK_PERIC2_USI11,
+       CLK_CON_DIV_DIV_CLK_PERIC2_I2C,
+       CLK_CON_DIV_DIV_CLK_PERIC2_SPI_MS_CTRL,
+       CLK_CON_DIV_DIV_CLK_PERIC2_UART_DBG,
+       CLK_CON_DIV_DIV_CLK_PERIC2_USI00,
+       CLK_CON_DIV_DIV_CLK_PERIC2_USI00_SPI_I2C,
+       CLK_CON_DIV_DIV_CLK_PERIC2_USI01,
+       CLK_CON_DIV_DIV_CLK_PERIC2_USI01_SPI_I2C,
+       CLK_CON_DIV_DIV_CLK_PERIC2_USI02,
+       CLK_CON_DIV_DIV_CLK_PERIC2_USI03,
+       CLK_CON_DIV_DIV_CLK_PERIC2_USI05,
+       CLK_CON_DIV_DIV_CLK_PERIC2_USI06,
+       CLK_CON_DIV_DIV_CLK_PERIC2_USI11,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_DBG_UART_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_DBG_UART_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_D_TZPC_PERIC2_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_GPIO_PERIC2_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C03_OIS_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C03_OIS_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C04_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C04_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C05_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C05_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C06_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C06_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C07_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C07_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C08_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C08_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C09_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C09_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C10_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C10_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C11_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_I3C11_IPCLKPORT_I_SCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_PERIC2_CMU_PERIC2_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_PWM_IPCLKPORT_I_PCLK_S0,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_CLK_PERIC2_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_CLK_PERIC2_I2C_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_CLK_PERIC2_NOCP_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_UART_DBG_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI00_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI00_SPI_I2C_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI01_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI01_SPI_I2C_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI02_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI03_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI05_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI06_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_USI11_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_SPI_MS_CTRL_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_SLH_AXI_MI_P_PERIC2_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_SPI_MULTI_SLV_Q_CTRL_PERIC2_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_SYSREG_PERIC2_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI00_SPI_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI00_SPI_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI00_USI_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI00_USI_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI01_SPI_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI01_SPI_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI01_USI_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI01_USI_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI02_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI02_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI02_USI_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI02_USI_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI03_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI03_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI03_USI_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI03_USI_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI05_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI05_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI05_USI_OIS_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI05_USI_OIS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI06_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI06_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI06_USI_OIS_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI06_USI_OIS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI11_I2C_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI11_I2C_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI11_USI_IPCLKPORT_IPCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_USI11_USI_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_I2C_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_RSTNSYNC_SR_CLK_PERIC2_NOCP_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_SLH_AXI_MI_LP_CSISPERIC2_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_PERIC2_UID_XIU_P_PERIC2_IPCLKPORT_ACLK,
+};
+
+PNAME(mout_peric2_ip0_user_p)                  = { "oscclk",
+                                                   "dout_cmu_peric2_ip0" };
+PNAME(mout_peric2_ip1_user_p)                  = { "oscclk",
+                                                   "dout_cmu_peric2_ip1" };
+PNAME(mout_peric2_noc_user_p)                  = { "oscclk",
+                                                   "dout_cmu_peric2_noc" };
+PNAME(mout_peric2_i2c_p)                       = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_spi_ms_ctrl_p)               = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_uart_dbg_p)                  = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_usi00_p)                     = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_usi00_spi_i2c_p)             = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_usi01_p)                     = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_usi01_spi_i2c_p)             = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_usi02_p)                     = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_usi03_p)                     = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_usi05_p)                     = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_usi06_p)                     = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+PNAME(mout_peric2_usi11_p)                     = { "oscclk",
+                                                   "mout_peric2_ip0_user",
+                                                   "mout_peric2_ip1_user",
+                                                   "oscclk" };
+
+static const struct samsung_mux_clock peric2_mux_clks[] __initconst = {
+       MUX(CLK_MOUT_PERIC2_IP0_USER, "mout_peric2_ip0_user",
+           mout_peric2_ip0_user_p, PLL_CON0_MUX_CLKCMU_PERIC2_IP0_USER, 4, 1),
+       MUX(CLK_MOUT_PERIC2_IP1_USER, "mout_peric2_ip1_user",
+           mout_peric2_ip1_user_p, PLL_CON0_MUX_CLKCMU_PERIC2_IP1_USER, 4, 1),
+       MUX(CLK_MOUT_PERIC2_NOC_USER, "mout_peric2_noc_user",
+           mout_peric2_noc_user_p, PLL_CON0_MUX_CLKCMU_PERIC2_NOC_USER, 4, 1),
+       MUX(CLK_MOUT_PERIC2_I2C, "mout_peric2_i2c", mout_peric2_i2c_p,
+           CLK_CON_MUX_MUX_CLK_PERIC2_I2C, 0, 2),
+       MUX(CLK_MOUT_PERIC2_SPI_MS_CTRL, "mout_peric2_spi_ms_ctrl",
+           mout_peric2_spi_ms_ctrl_p,
+           CLK_CON_MUX_MUX_CLK_PERIC2_SPI_MS_CTRL, 0, 2),
+       MUX(CLK_MOUT_PERIC2_UART_DBG, "mout_peric2_uart_dbg",
+           mout_peric2_uart_dbg_p, CLK_CON_MUX_MUX_CLK_PERIC2_UART_DBG, 0, 2),
+       MUX(CLK_MOUT_PERIC2_USI00, "mout_peric2_usi00", mout_peric2_usi00_p,
+           CLK_CON_MUX_MUX_CLK_PERIC2_USI00, 0, 2),
+       MUX(CLK_MOUT_PERIC2_USI00_SPI_I2C, "mout_peric2_usi00_spi_i2c",
+           mout_peric2_usi00_spi_i2c_p, CLK_CON_MUX_MUX_CLK_PERIC2_USI00_SPI_I2C,
+           0, 2),
+       MUX(CLK_MOUT_PERIC2_USI01, "mout_peric2_usi01", mout_peric2_usi01_p,
+           CLK_CON_MUX_MUX_CLK_PERIC2_USI01, 0, 2),
+       MUX(CLK_MOUT_PERIC2_USI01_SPI_I2C, "mout_peric2_usi01_spi_i2c",
+           mout_peric2_usi01_spi_i2c_p,
+           CLK_CON_MUX_MUX_CLK_PERIC2_USI01_SPI_I2C, 0, 2),
+       MUX(CLK_MOUT_PERIC2_USI02, "mout_peric2_usi02", mout_peric2_usi02_p,
+           CLK_CON_MUX_MUX_CLK_PERIC2_USI02, 0, 2),
+       MUX(CLK_MOUT_PERIC2_USI03, "mout_peric2_usi03", mout_peric2_usi03_p,
+           CLK_CON_MUX_MUX_CLK_PERIC2_USI03, 0, 2),
+       MUX(CLK_MOUT_PERIC2_USI05, "mout_peric2_usi05", mout_peric2_usi05_p,
+           CLK_CON_MUX_MUX_CLK_PERIC2_USI05, 0, 2),
+       MUX(CLK_MOUT_PERIC2_USI06, "mout_peric2_usi06", mout_peric2_usi06_p,
+           CLK_CON_MUX_MUX_CLK_PERIC2_USI06, 0, 2),
+       MUX(CLK_MOUT_PERIC2_USI11, "mout_peric2_usi11", mout_peric2_usi11_p,
+           CLK_CON_MUX_MUX_CLK_PERIC2_USI11, 0, 2),
+};
+
+static const struct samsung_div_clock peric2_div_clks[] __initconst = {
+       DIV(CLK_DOUT_PERIC2_I2C, "dout_peric2_i2c", "mout_peric2_i2c",
+           CLK_CON_DIV_DIV_CLK_PERIC2_I2C, 0, 4),
+       DIV(CLK_DOUT_PERIC2_SPI_MS_CTRL, "dout_peric2_spi_ms_ctrl",
+           "mout_peric2_spi_ms_ctrl", CLK_CON_DIV_DIV_CLK_PERIC2_SPI_MS_CTRL,
+           0, 7),
+       DIV(CLK_DOUT_PERIC2_UART_DBG, "dout_peric2_uart_dbg",
+           "mout_peric2_uart_dbg", CLK_CON_DIV_DIV_CLK_PERIC2_UART_DBG, 0, 4),
+       DIV(CLK_DOUT_PERIC2_USI00, "dout_peric2_usi00", "mout_peric2_usi00",
+           CLK_CON_DIV_DIV_CLK_PERIC2_USI00, 0, 7),
+       DIV(CLK_DOUT_PERIC2_USI00_SPI_I2C, "dout_peric2_usi00_spi_i2c",
+           "mout_peric2_usi00_spi_i2c",
+           CLK_CON_DIV_DIV_CLK_PERIC2_USI00_SPI_I2C, 0, 4),
+       DIV(CLK_DOUT_PERIC2_USI01, "dout_peric2_usi01", "mout_peric2_usi01",
+           CLK_CON_DIV_DIV_CLK_PERIC2_USI01, 0, 7),
+       DIV(CLK_DOUT_PERIC2_USI01_SPI_I2C, "dout_peric2_usi01_spi_i2c",
+           "mout_peric2_usi01_spi_i2c",
+           CLK_CON_DIV_DIV_CLK_PERIC2_USI01_SPI_I2C, 0, 4),
+       DIV(CLK_DOUT_PERIC2_USI02, "dout_peric2_usi02", "mout_peric2_usi02",
+           CLK_CON_DIV_DIV_CLK_PERIC2_USI02, 0, 7),
+       DIV(CLK_DOUT_PERIC2_USI03, "dout_peric2_usi03", "mout_peric2_usi03",
+           CLK_CON_DIV_DIV_CLK_PERIC2_USI03, 0, 7),
+       DIV(CLK_DOUT_PERIC2_USI05, "dout_peric2_usi05", "mout_peric2_usi05",
+           CLK_CON_DIV_DIV_CLK_PERIC2_USI05, 0, 7),
+       DIV(CLK_DOUT_PERIC2_USI06, "dout_peric2_usi06", "mout_peric2_usi06",
+           CLK_CON_DIV_DIV_CLK_PERIC2_USI06, 0, 7),
+       DIV(CLK_DOUT_PERIC2_USI11, "dout_peric2_usi11", "mout_peric2_usi11",
+           CLK_CON_DIV_DIV_CLK_PERIC2_USI11, 0, 7),
+};
+
+static const struct samsung_cmu_info peric2_cmu_info __initconst = {
+       .mux_clks               = peric2_mux_clks,
+       .nr_mux_clks            = ARRAY_SIZE(peric2_mux_clks),
+       .div_clks               = peric2_div_clks,
+       .nr_div_clks            = ARRAY_SIZE(peric2_div_clks),
+       .nr_clk_ids             = CLKS_NR_PERIC2,
+       .clk_regs               = peric2_clk_regs,
+       .nr_clk_regs            = ARRAY_SIZE(peric2_clk_regs),
+       .clk_name               = "noc",
+};
+
+/* ---- CMU_UFS ------------------------------------------------------------ */
+
+/* Register Offset definitions for CMU_UFS(0x11000000) */
+#define PLL_CON0_MUX_CLKCMU_UFS_MMC_CARD_USER                                          0x600
+#define PLL_CON1_MUX_CLKCMU_UFS_MMC_CARD_USER                                          0x604
+#define PLL_CON0_MUX_CLKCMU_UFS_NOC_USER                                               0x610
+#define PLL_CON1_MUX_CLKCMU_UFS_NOC_USER                                               0x614
+#define PLL_CON0_MUX_CLKCMU_UFS_UFS_EMBD_USER                                          0x620
+#define PLL_CON1_MUX_CLKCMU_UFS_UFS_EMBD_USER                                          0x624
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_BLK_UFS_FRC_OTP_DESERIAL_IPCLKPORT_I_CLK           0x2000
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_D_TZPC_UFS_IPCLKPORT_PCLK                          0x2004
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_GPIO_HSI1UFS_IPCLKPORT_PCLK                                0x2008
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_GPIO_UFS_IPCLKPORT_PCLK                            0x200c
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_LH_ACEL_SI_D_UFS_IPCLKPORT_I_CLK                   0x2010
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_MMC_CARD_IPCLKPORT_I_ACLK                          0x2014
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_MMC_CARD_IPCLKPORT_SDCLKIN                         0x2018
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_OTP_DESERIAL_UFS_EMBD_FMP_IPCLKPORT_I_CLK          0x201c
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_PPMU_UFS_IPCLKPORT_ACLK                            0x2024
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_PPMU_UFS_IPCLKPORT_PCLK                            0x2028
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_CLK_UFS_FREE_OSCCLK_IPCLKPORT_CLK         0x202c
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_CLK_UFS_MMC_CARD_IPCLKPORT_CLK            0x2030
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_CLK_UFS_NOC_IPCLKPORT_CLK                 0x2034
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_CLK_UFS_UFS_EMBD_IPCLKPORT_CLK            0x2038
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_SR_CLK_UFS_FREE_OSCCLK_IPCLKPORT_CLK      0x203c
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_SR_CLK_UFS_NOC_IPCLKPORT_CLK              0x2040
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_SLH_AST_SI_G_PPMU_UFS_IPCLKPORT_I_CLK              0x2044
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_SLH_AXI_MI_P_UFS_IPCLKPORT_I_CLK                   0x2048
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_SPC_UFS_IPCLKPORT_PCLK                             0x204c
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_SYSMMU_UFS_IPCLKPORT_CLK_S2                                0x2050
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_SYSREG_UFS_IPCLKPORT_PCLK                          0x2054
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_UFS_CMU_UFS_IPCLKPORT_PCLK                         0x2058
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_UFS_EMBD_IPCLKPORT_I_ACLK                          0x205c
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_UFS_EMBD_IPCLKPORT_I_CLK_UNIPRO                    0x2060
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_UFS_EMBD_IPCLKPORT_I_FMP_CLK                       0x2064
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_VGEN_LITE_UFS_IPCLKPORT_CLK                                0x2068
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_XIU_D_UFS_IPCLKPORT_ACLK                           0x206c
+#define CLK_CON_GAT_CLK_BLK_UFS_UID_XIU_P_UFS_IPCLKPORT_ACLK                           0x2070
+
+static const unsigned long ufs_clk_regs[] __initconst = {
+       PLL_CON0_MUX_CLKCMU_UFS_MMC_CARD_USER,
+       PLL_CON1_MUX_CLKCMU_UFS_MMC_CARD_USER,
+       PLL_CON0_MUX_CLKCMU_UFS_NOC_USER,
+       PLL_CON1_MUX_CLKCMU_UFS_NOC_USER,
+       PLL_CON0_MUX_CLKCMU_UFS_UFS_EMBD_USER,
+       PLL_CON1_MUX_CLKCMU_UFS_UFS_EMBD_USER,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_BLK_UFS_FRC_OTP_DESERIAL_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_D_TZPC_UFS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_GPIO_HSI1UFS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_GPIO_UFS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_LH_ACEL_SI_D_UFS_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_MMC_CARD_IPCLKPORT_I_ACLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_MMC_CARD_IPCLKPORT_SDCLKIN,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_OTP_DESERIAL_UFS_EMBD_FMP_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_PPMU_UFS_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_PPMU_UFS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_CLK_UFS_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_CLK_UFS_MMC_CARD_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_CLK_UFS_NOC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_CLK_UFS_UFS_EMBD_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_SR_CLK_UFS_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_RSTNSYNC_SR_CLK_UFS_NOC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_SLH_AST_SI_G_PPMU_UFS_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_SLH_AXI_MI_P_UFS_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_SPC_UFS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_SYSMMU_UFS_IPCLKPORT_CLK_S2,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_SYSREG_UFS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_UFS_CMU_UFS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_UFS_EMBD_IPCLKPORT_I_ACLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_UFS_EMBD_IPCLKPORT_I_CLK_UNIPRO,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_UFS_EMBD_IPCLKPORT_I_FMP_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_VGEN_LITE_UFS_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_XIU_D_UFS_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_UFS_UID_XIU_P_UFS_IPCLKPORT_ACLK,
+};
+
+PNAME(mout_clkcmu_ufs_mmc_card_user_p) = { "oscclk",
+                                           "mout_cmu_ufs_mmc_card" };
+PNAME(mout_clkcmu_ufs_noc_user_p)      = { "oscclk", "dout_cmu_ufs_noc" };
+PNAME(mout_clkcmu_ufs_ufs_embd_user_p) = { "oscclk",
+                                           "dout_cmu_ufs_ufs_embd" };
+
+static const struct samsung_mux_clock ufs_mux_clks[] __initconst = {
+       MUX(CLK_MOUT_UFS_MMC_CARD_USER, "mout_ufs_mmc_card_user",
+           mout_clkcmu_ufs_mmc_card_user_p,
+           PLL_CON0_MUX_CLKCMU_UFS_MMC_CARD_USER, 4, 1),
+       MUX(CLK_MOUT_UFS_NOC_USER, "mout_ufs_noc_user",
+           mout_clkcmu_ufs_noc_user_p,
+           PLL_CON0_MUX_CLKCMU_UFS_NOC_USER, 4, 1),
+       MUX(CLK_MOUT_UFS_UFS_EMBD_USER, "mout_ufs_ufs_embd_user",
+           mout_clkcmu_ufs_ufs_embd_user_p,
+           PLL_CON0_MUX_CLKCMU_UFS_UFS_EMBD_USER, 4, 1),
+};
+
+static const struct samsung_cmu_info ufs_cmu_info __initconst = {
+       .mux_clks               = ufs_mux_clks,
+       .nr_mux_clks            = ARRAY_SIZE(ufs_mux_clks),
+       .nr_clk_ids             = CLKS_NR_UFS,
+       .clk_regs               = ufs_clk_regs,
+       .nr_clk_regs            = ARRAY_SIZE(ufs_clk_regs),
+       .clk_name               = "noc",
+};
+
+/* ---- CMU_VTS ------------------------------------------------------------ */
+
+/* Register Offset definitions for CMU_VTS (0x15300000) */
+#define PLL_CON0_MUX_CLKALIVE_VTS_NOC_USER                                             0x600
+#define PLL_CON1_MUX_CLKALIVE_VTS_NOC_USER                                             0x604
+#define PLL_CON0_MUX_CLKALIVE_VTS_RCO_USER                                             0x610
+#define PLL_CON1_MUX_CLKALIVE_VTS_RCO_USER                                             0x614
+#define PLL_CON0_MUX_CLKCMU_VTS_DMIC_USER                                              0x620
+#define PLL_CON1_MUX_CLKCMU_VTS_DMIC_USER                                              0x624
+#define CLK_CON_MUX_MUX_CLKVTS_AUD_DMIC1                                               0x1000
+#define CLK_CON_MUX_MUX_CLK_VTS_NOC                                                    0x1004
+#define CLK_CON_MUX_MUX_CLK_VTS_DMIC_PAD                                               0x100c
+#define CLK_CON_DIV_DIV_CLKVTS_AUD_DMIC0                                               0x1800
+#define CLK_CON_DIV_DIV_CLKVTS_AUD_DMIC1                                               0x1804
+#define CLK_CON_DIV_DIV_CLK_VTS_CPU                                                    0x1808
+#define CLK_CON_DIV_DIV_CLK_VTS_DMIC_IF                                                        0x1814
+#define CLK_CON_DIV_DIV_CLK_VTS_DMIC_IF_DIV2                                           0x1818
+#define CLK_CON_DIV_DIV_CLK_VTS_NOC                                                    0x181c
+#define CLK_CON_DIV_DIV_CLK_VTS_SERIAL_LIF                                             0x1820
+#define CLK_CON_DIV_DIV_CLK_VTS_SERIAL_LIF_CORE                                                0x1824
+#define CLK_CON_GAT_CLKVTS_AUD_DMIC0                                                   0x2000
+#define CLK_CON_GAT_CLKVTS_AUD_DMIC1                                                   0x2004
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_BAAW_VTS_IPCLKPORT_I_PCLK                          0x2008
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_LH_AXI_MI_IP_VC2VTS_IPCLKPORT_I_CLK                        0x200c
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_LH_AXI_SI_ID_VTS2VC_IPCLKPORT_I_CLK                        0x2010
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_CLK_VTS_FREE_OSCCLK_IPCLKPORT_CLK         0x2014
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_SR_CLK_VTS_DMIC_IF_IPCLKPORT_CLK          0x2018
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_SR_CLK_VTS_SERIAL_LIF_CORE_IPCLKPORT_CLK  0x2020
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_SR_CLK_VTS_SERIAL_LIF_IPCLKPORT_CLK       0x2024
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_SR_CLK_VTS_YAMIN_IPCLKPORT_CLK            0x2028
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SERIAL_LIF_VT_IPCLKPORT_ACLK                       0x202c
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_FRC_OTP_DESERIAL_IPCLKPORT_I_CLK            0x2030
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_ASYNCINTERRUPT_VTS_IPCLKPORT_CLK                   0x2034
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF0_IPCLKPORT_DMIC_IF_CLK                     0x2068
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF0_IPCLKPORT_DMIC_IF_DIV2_CLK                        0x206c
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF0_IPCLKPORT_PCLK                            0x2070
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF1_IPCLKPORT_DMIC_IF_CLK                     0x2074
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF1_IPCLKPORT_DMIC_IF_DIV2_CLK                        0x2078
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF1_IPCLKPORT_PCLK                            0x207c
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF2_IPCLKPORT_DMIC_IF_CLK                     0x2080
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF2_IPCLKPORT_DMIC_IF_DIV2_CLK                        0x2084
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF2_IPCLKPORT_PCLK                            0x2088
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_GPIO_VTS_IPCLKPORT_PCLK                            0x2090
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_CODE_IPCLKPORT_I_ACLK                       0x20ac
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_CODE_IPCLKPORT_I_PCLK                       0x20b0
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_DATA0_IPCLKPORT_I_ACLK                      0x20b4
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_DATA0_IPCLKPORT_I_PCLK                      0x20b8
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_DATA1_IPCLKPORT_I_ACLK                      0x20bc
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_DATA1_IPCLKPORT_I_PCLK                      0x20c0
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_PCM_IPCLKPORT_I_ACLK                                0x20c4
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_PCM_IPCLKPORT_I_PCLK                                0x20c8
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_MAILBOX_ABOX_VTS_IPCLKPORT_PCLK                    0x20cc
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_MAILBOX_AP_VTS_IPCLKPORT_PCLK                      0x20d0
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_MAILBOX_DNC_VTS_IPCLKPORT_PCLK                     0x20d4
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_CLK_VTS_NOC_IPCLKPORT_CLK                 0x20ec
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_CLK_VTS_YAMIN_IPCLKPORT_CLK               0x20f8
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_SR_CLK_VTS_NOC_IPCLKPORT_CLK              0x20fc
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SERIAL_LIF_VT_IPCLKPORT_BCLK                       0x2104
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SERIAL_LIF_VT_IPCLKPORT_CCLK                       0x2108
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SERIAL_LIF_VT_IPCLKPORT_PCLK                       0x210c
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_GLUE_IPCLKPORT_ACLK_CPU                     0x2124
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_GLUE_IPCLKPORT_DMIC_AUD_DIV2_CLK            0x2128
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_GLUE_IPCLKPORT_DMIC_IF_PAD_CLK0             0x212c
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_GLUE_IPCLKPORT_DMIC_IF_PAD_CLK1             0x2130
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_GLUE_IPCLKPORT_DMIC_IF_PAD_CLK2             0x2134
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_SYSREG_VTS_IPCLKPORT_PCLK                          0x213c
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_TIMER1_IPCLKPORT_PCLK                              0x2140
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_TIMER2_IPCLKPORT_PCLK                              0x2144
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_TIMER_IPCLKPORT_PCLK                               0x2148
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_VTS_CMU_VTS_IPCLKPORT_PCLK                         0x2150
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_WDT_VTS_IPCLKPORT_PCLK                             0x2154
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_XIU_DP0_VTS_IPCLKPORT_ACLK                         0x2158
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_YAMIN_MCU_VTS_IPCLKPORT_CLKIN                      0x215c
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_YAMIN_MCU_VTS_IPCLKPORT_DBGCLK                     0x2160
+#define CLK_CON_GAT_CLK_BLK_VTS_UID_YAMIN_MCU_VTS_IPCLKPORT_IWICCLK                    0x2164
+
+static const unsigned long vts_clk_regs[] __initconst = {
+       PLL_CON0_MUX_CLKALIVE_VTS_NOC_USER,
+       PLL_CON1_MUX_CLKALIVE_VTS_NOC_USER,
+       PLL_CON0_MUX_CLKALIVE_VTS_RCO_USER,
+       PLL_CON1_MUX_CLKALIVE_VTS_RCO_USER,
+       PLL_CON0_MUX_CLKCMU_VTS_DMIC_USER,
+       PLL_CON1_MUX_CLKCMU_VTS_DMIC_USER,
+       CLK_CON_MUX_MUX_CLKVTS_AUD_DMIC1,
+       CLK_CON_MUX_MUX_CLK_VTS_NOC,
+       CLK_CON_MUX_MUX_CLK_VTS_DMIC_PAD,
+       CLK_CON_DIV_DIV_CLKVTS_AUD_DMIC0,
+       CLK_CON_DIV_DIV_CLKVTS_AUD_DMIC1,
+       CLK_CON_DIV_DIV_CLK_VTS_CPU,
+       CLK_CON_DIV_DIV_CLK_VTS_DMIC_IF,
+       CLK_CON_DIV_DIV_CLK_VTS_DMIC_IF_DIV2,
+       CLK_CON_DIV_DIV_CLK_VTS_NOC,
+       CLK_CON_DIV_DIV_CLK_VTS_SERIAL_LIF,
+       CLK_CON_DIV_DIV_CLK_VTS_SERIAL_LIF_CORE,
+       CLK_CON_GAT_CLKVTS_AUD_DMIC0,
+       CLK_CON_GAT_CLKVTS_AUD_DMIC1,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_BAAW_VTS_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_LH_AXI_MI_IP_VC2VTS_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_LH_AXI_SI_ID_VTS2VC_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_CLK_VTS_FREE_OSCCLK_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_SR_CLK_VTS_DMIC_IF_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_SR_CLK_VTS_SERIAL_LIF_CORE_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_SR_CLK_VTS_SERIAL_LIF_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_SR_CLK_VTS_YAMIN_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SERIAL_LIF_VT_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_FRC_OTP_DESERIAL_IPCLKPORT_I_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_ASYNCINTERRUPT_VTS_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF0_IPCLKPORT_DMIC_IF_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF0_IPCLKPORT_DMIC_IF_DIV2_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF0_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF1_IPCLKPORT_DMIC_IF_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF1_IPCLKPORT_DMIC_IF_DIV2_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF2_IPCLKPORT_DMIC_IF_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF2_IPCLKPORT_DMIC_IF_DIV2_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_DMIC_IF2_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_GPIO_VTS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_CODE_IPCLKPORT_I_ACLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_CODE_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_DATA0_IPCLKPORT_I_ACLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_DATA0_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_DATA1_IPCLKPORT_I_ACLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_DATA1_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_PCM_IPCLKPORT_I_ACLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_INTMEM_PCM_IPCLKPORT_I_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_MAILBOX_ABOX_VTS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_MAILBOX_AP_VTS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_MAILBOX_DNC_VTS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_CLK_VTS_NOC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_CLK_VTS_YAMIN_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_RSTNSYNC_SR_CLK_VTS_NOC_IPCLKPORT_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SERIAL_LIF_VT_IPCLKPORT_BCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SERIAL_LIF_VT_IPCLKPORT_CCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SERIAL_LIF_VT_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_GLUE_IPCLKPORT_ACLK_CPU,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_GLUE_IPCLKPORT_DMIC_AUD_DIV2_CLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_GLUE_IPCLKPORT_DMIC_IF_PAD_CLK0,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_GLUE_IPCLKPORT_DMIC_IF_PAD_CLK1,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SS_VTS_GLUE_IPCLKPORT_DMIC_IF_PAD_CLK2,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_SYSREG_VTS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_TIMER1_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_TIMER2_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_TIMER_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_VTS_CMU_VTS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_WDT_VTS_IPCLKPORT_PCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_XIU_DP0_VTS_IPCLKPORT_ACLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_YAMIN_MCU_VTS_IPCLKPORT_CLKIN,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_YAMIN_MCU_VTS_IPCLKPORT_DBGCLK,
+       CLK_CON_GAT_CLK_BLK_VTS_UID_YAMIN_MCU_VTS_IPCLKPORT_IWICCLK,
+};
+
+PNAME(mout_clkalive_vts_noc_user_p)    = { "oscclk" };
+PNAME(mout_clkalive_vts_rco_user_p)    = { "oscclk" };
+PNAME(mout_clkcmu_vts_dmic_user_p)     = { "oscclk", "dout_cmu_vts_dmic" };
+PNAME(mout_clkvts_aud_dmic1_p)         = { "dout_clkvts_aud_dmic1",
+                                           "dout_clkvts_dmic_if_div2",
+                                           "dmic_clk0_in", "dmic_clk1_in",
+                                           "dmic_clk2_in", "oscclk", "oscclk",
+                                           "oscclk" };
+PNAME(mout_clkvts_noc_p)               = { "mout_clkalive_vts_noc_user",
+                                           "mout_clkalive_vts_rco_user" };
+PNAME(mout_clkvts_dmic_pad_p)          = { "mout_clkalive_vts_rco_user",
+                                           "mout_clkcmu_vts_dmic_user" };
+
+static const struct samsung_mux_clock vts_mux_clks[] __initconst = {
+       MUX(CLK_MOUT_CLKALIVE_VTS_NOC_USER, "mout_clkalive_vts_noc_user",
+           mout_clkalive_vts_noc_user_p, PLL_CON0_MUX_CLKALIVE_VTS_NOC_USER,
+           4, 1),
+       MUX(CLK_MOUT_CLKALIVE_VTS_RCO_USER, "mout_clkalive_vts_rco_user",
+           mout_clkalive_vts_rco_user_p, PLL_CON0_MUX_CLKALIVE_VTS_RCO_USER,
+           4, 1),
+       MUX(CLK_MOUT_CLKCMU_VTS_DMIC_USER, "mout_clkcmu_vts_dmic_user",
+           mout_clkcmu_vts_dmic_user_p, PLL_CON0_MUX_CLKCMU_VTS_DMIC_USER,
+           4, 1),
+       MUX(CLK_MOUT_CLKVTS_AUD_DMIC1, "mout_clkvts_aud_dmic1",
+           mout_clkvts_aud_dmic1_p, CLK_CON_MUX_MUX_CLKVTS_AUD_DMIC1, 0, 3),
+       MUX(CLK_MOUT_CLKVTS_NOC, "mout_clkvts_noc", mout_clkvts_noc_p,
+           CLK_CON_MUX_MUX_CLK_VTS_NOC, 0, 1),
+       MUX(CLK_MOUT_CLKVTS_DMIC_PAD, "mout_clkvts_dmic_pad",
+           mout_clkvts_dmic_pad_p, CLK_CON_MUX_MUX_CLK_VTS_DMIC_PAD, 0, 1),
+};
+
+static const struct samsung_div_clock vts_div_clks[] __initconst = {
+       DIV(CLK_DOUT_CLKVTS_AUD_DMIC0, "dout_clkvts_aud_dmic0",
+           "mout_clkvts_dmic_pad", CLK_CON_DIV_DIV_CLKVTS_AUD_DMIC0, 0, 5),
+       DIV(CLK_DOUT_CLKVTS_AUD_DMIC1, "dout_clkvts_aud_dmic1",
+           "dout_clkvts_aud_dmic0", CLK_CON_DIV_DIV_CLKVTS_AUD_DMIC1, 0, 4),
+       DIV(CLK_DOUT_CLKVTS_CPU, "dout_clkvts_cpu", "mout_clkvts_noc",
+           CLK_CON_DIV_DIV_CLK_VTS_CPU, 0, 3),
+       DIV(CLK_DOUT_CLKVTS_DMIC_IF, "dout_clkvts_dmic_if",
+           "dout_clkvts_aud_dmic0", CLK_CON_DIV_DIV_CLK_VTS_DMIC_IF, 0, 7),
+       DIV(CLK_DOUT_CLKVTS_DMIC_IF_DIV2, "dout_clkvts_dmic_if_div2",
+           "dout_clkvts_dmic_if", CLK_CON_DIV_DIV_CLK_VTS_DMIC_IF_DIV2, 0, 4),
+       DIV(CLK_DOUT_CLKVTS_NOC, "dout_clkvts_noc", "dout_clkvts_cpu",
+           CLK_CON_DIV_DIV_CLK_VTS_NOC, 0, 3),
+       DIV(CLK_DOUT_CLKVTS_SERIAL_LIF, "dout_clkvts_serial_lif",
+           "mout_clkalive_vts_rco_user", CLK_CON_DIV_DIV_CLK_VTS_SERIAL_LIF,
+           0, 7),
+       DIV(CLK_DOUT_CLKVTS_SERIAL_LIF_CORE, "dout_clkvts_serial_lif_core",
+           "mout_clkalive_vts_rco_user",
+           CLK_CON_DIV_DIV_CLK_VTS_SERIAL_LIF_CORE, 0, 7),
+};
+
+static const struct samsung_fixed_rate_clock vts_fixed_clks[] __initconst = {
+       FRATE(0, "dmic_clk0_in", NULL, 0, 100000000),
+       FRATE(0, "dmic_clk1_in", NULL, 0, 100000000),
+       FRATE(0, "dmic_clk2_in", NULL, 0, 100000000),
+};
+
+static const struct samsung_cmu_info vts_cmu_info __initconst = {
+       .mux_clks               = vts_mux_clks,
+       .nr_mux_clks            = ARRAY_SIZE(vts_mux_clks),
+       .div_clks               = vts_div_clks,
+       .nr_div_clks            = ARRAY_SIZE(vts_div_clks),
+       .fixed_clks             = vts_fixed_clks,
+       .nr_fixed_clks          = ARRAY_SIZE(vts_fixed_clks),
+       .nr_clk_ids             = CLKS_NR_VTS,
+       .clk_regs               = vts_clk_regs,
+       .nr_clk_regs            = ARRAY_SIZE(vts_clk_regs),
+       .clk_name               = "dmic",
+};
+
+static int __init exynos2200_cmu_probe(struct platform_device *pdev)
+{
+       const struct samsung_cmu_info *info;
+       struct device *dev = &pdev->dev;
+
+       info = of_device_get_match_data(dev);
+       exynos_arm64_register_cmu(dev, dev->of_node, info);
+
+       return 0;
+}
+
+static const struct of_device_id exynos2200_cmu_of_match[] = {
+       {
+               .compatible = "samsung,exynos2200-cmu-cmgp",
+               .data = &cmgp_cmu_info,
+       }, {
+               .compatible = "samsung,exynos2200-cmu-hsi0",
+               .data = &hsi0_cmu_info,
+       }, {
+               .compatible = "samsung,exynos2200-cmu-peric0",
+               .data = &peric0_cmu_info,
+       }, {
+               .compatible = "samsung,exynos2200-cmu-peric1",
+               .data = &peric1_cmu_info,
+       }, {
+               .compatible = "samsung,exynos2200-cmu-peric2",
+               .data = &peric2_cmu_info,
+       }, {
+               .compatible = "samsung,exynos2200-cmu-ufs",
+               .data = &ufs_cmu_info,
+       }, {
+               .compatible = "samsung,exynos2200-cmu-vts",
+               .data = &vts_cmu_info,
+       }, { }
+};
+
+static struct platform_driver exynos2200_cmu_driver __refdata = {
+       .driver = {
+               .name = "exynos2200-cmu",
+               .of_match_table = exynos2200_cmu_of_match,
+               .suppress_bind_attrs = true,
+       },
+       .probe = exynos2200_cmu_probe,
+};
+
+static int __init exynos2200_cmu_init(void)
+{
+       return platform_driver_register(&exynos2200_cmu_driver);
+}
+core_initcall(exynos2200_cmu_init);