1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * Copyright (C) 2023 Linaro Ltd. 4 * Author: Peter Griffin <peter.griffin@linaro.org> 5 * 6 * Common Clock Framework support for GS101. 7 */ 8 9 #include <linux/clk.h> 10 #include <linux/clk-provider.h> 11 #include <linux/of.h> 12 #include <linux/platform_device.h> 13 14 #include <dt-bindings/clock/google,gs101.h> 15 16 #include "clk.h" 17 #include "clk-exynos-arm64.h" 18 #include "clk-pll.h" 19 20 /* NOTE: Must be equal to the last clock ID increased by one */ 21 #define CLKS_NR_TOP (CLK_GOUT_CMU_TPU_UART + 1) 22 #define CLKS_NR_APM (CLK_APM_PLL_DIV16_APM + 1) 23 #define CLKS_NR_HSI0 (CLK_GOUT_HSI0_XIU_P_HSI0_ACLK + 1) 24 #define CLKS_NR_HSI2 (CLK_GOUT_HSI2_XIU_P_HSI2_ACLK + 1) 25 #define CLKS_NR_MISC (CLK_GOUT_MISC_XIU_D_MISC_ACLK + 1) 26 #define CLKS_NR_PERIC0 (CLK_GOUT_PERIC0_SYSREG_PERIC0_PCLK + 1) 27 #define CLKS_NR_PERIC1 (CLK_GOUT_PERIC1_SYSREG_PERIC1_PCLK + 1) 28 29 /* ---- CMU_TOP ------------------------------------------------------------- */ 30 31 /* Register Offset definitions for CMU_TOP (0x1e080000) */ 32 #define PLL_LOCKTIME_PLL_SHARED0 0x0000 33 #define PLL_LOCKTIME_PLL_SHARED1 0x0004 34 #define PLL_LOCKTIME_PLL_SHARED2 0x0008 35 #define PLL_LOCKTIME_PLL_SHARED3 0x000c 36 #define PLL_LOCKTIME_PLL_SPARE 0x0010 37 #define PLL_CON0_PLL_SHARED0 0x0100 38 #define PLL_CON1_PLL_SHARED0 0x0104 39 #define PLL_CON2_PLL_SHARED0 0x0108 40 #define PLL_CON3_PLL_SHARED0 0x010c 41 #define PLL_CON4_PLL_SHARED0 0x0110 42 #define PLL_CON0_PLL_SHARED1 0x0140 43 #define PLL_CON1_PLL_SHARED1 0x0144 44 #define PLL_CON2_PLL_SHARED1 0x0148 45 #define PLL_CON3_PLL_SHARED1 0x014c 46 #define PLL_CON4_PLL_SHARED1 0x0150 47 #define PLL_CON0_PLL_SHARED2 0x0180 48 #define PLL_CON1_PLL_SHARED2 0x0184 49 #define PLL_CON2_PLL_SHARED2 0x0188 50 #define PLL_CON3_PLL_SHARED2 0x018c 51 #define PLL_CON4_PLL_SHARED2 0x0190 52 #define PLL_CON0_PLL_SHARED3 0x01c0 53 #define PLL_CON1_PLL_SHARED3 0x01c4 54 #define PLL_CON2_PLL_SHARED3 0x01c8 55 #define PLL_CON3_PLL_SHARED3 0x01cc 56 #define PLL_CON4_PLL_SHARED3 0x01d0 57 #define PLL_CON0_PLL_SPARE 0x0200 58 #define PLL_CON1_PLL_SPARE 0x0204 59 #define PLL_CON2_PLL_SPARE 0x0208 60 #define PLL_CON3_PLL_SPARE 0x020c 61 #define PLL_CON4_PLL_SPARE 0x0210 62 #define CMU_CMU_TOP_CONTROLLER_OPTION 0x0800 63 #define CLKOUT_CON_BLK_CMU_CMU_TOP_CLKOUT0 0x0810 64 #define CMU_HCHGEN_CLKMUX_CMU_BOOST 0x0840 65 #define CMU_HCHGEN_CLKMUX_TOP_BOOST 0x0844 66 #define CMU_HCHGEN_CLKMUX 0x0850 67 #define POWER_FAIL_DETECT_PLL 0x0864 68 #define EARLY_WAKEUP_FORCED_0_ENABLE 0x0870 69 #define EARLY_WAKEUP_FORCED_1_ENABLE 0x0874 70 #define EARLY_WAKEUP_APM_CTRL 0x0878 71 #define EARLY_WAKEUP_CLUSTER0_CTRL 0x087c 72 #define EARLY_WAKEUP_DPU_CTRL 0x0880 73 #define EARLY_WAKEUP_CSIS_CTRL 0x0884 74 #define EARLY_WAKEUP_APM_DEST 0x0890 75 #define EARLY_WAKEUP_CLUSTER0_DEST 0x0894 76 #define EARLY_WAKEUP_DPU_DEST 0x0898 77 #define EARLY_WAKEUP_CSIS_DEST 0x089c 78 #define EARLY_WAKEUP_SW_TRIG_APM 0x08c0 79 #define EARLY_WAKEUP_SW_TRIG_APM_SET 0x08c4 80 #define EARLY_WAKEUP_SW_TRIG_APM_CLEAR 0x08c8 81 #define EARLY_WAKEUP_SW_TRIG_CLUSTER0 0x08d0 82 #define EARLY_WAKEUP_SW_TRIG_CLUSTER0_SET 0x08d4 83 #define EARLY_WAKEUP_SW_TRIG_CLUSTER0_CLEAR 0x08d8 84 #define EARLY_WAKEUP_SW_TRIG_DPU 0x08e0 85 #define EARLY_WAKEUP_SW_TRIG_DPU_SET 0x08e4 86 #define EARLY_WAKEUP_SW_TRIG_DPU_CLEAR 0x08e8 87 #define EARLY_WAKEUP_SW_TRIG_CSIS 0x08f0 88 #define EARLY_WAKEUP_SW_TRIG_CSIS_SET 0x08f4 89 #define EARLY_WAKEUP_SW_TRIG_CSIS_CLEAR 0x08f8 90 #define CLK_CON_MUX_MUX_CLKCMU_BO_BUS 0x1000 91 #define CLK_CON_MUX_MUX_CLKCMU_BUS0_BUS 0x1004 92 #define CLK_CON_MUX_MUX_CLKCMU_BUS1_BUS 0x1008 93 #define CLK_CON_MUX_MUX_CLKCMU_BUS2_BUS 0x100c 94 #define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK0 0x1010 95 #define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK1 0x1014 96 #define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK2 0x1018 97 #define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK3 0x101c 98 #define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK4 0x1020 99 #define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK5 0x1024 100 #define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK6 0x1028 101 #define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK7 0x102c 102 #define CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST 0x1030 103 #define CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_OPTION1 0x1034 104 #define CLK_CON_MUX_MUX_CLKCMU_CORE_BUS 0x1038 105 #define CLK_CON_MUX_MUX_CLKCMU_CPUCL0_DBG 0x103c 106 #define CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH 0x1040 107 #define CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH 0x1044 108 #define CLK_CON_MUX_MUX_CLKCMU_CPUCL2_SWITCH 0x1048 109 #define CLK_CON_MUX_MUX_CLKCMU_CSIS_BUS 0x104c 110 #define CLK_CON_MUX_MUX_CLKCMU_DISP_BUS 0x1050 111 #define CLK_CON_MUX_MUX_CLKCMU_DNS_BUS 0x1054 112 #define CLK_CON_MUX_MUX_CLKCMU_DPU_BUS 0x1058 113 #define CLK_CON_MUX_MUX_CLKCMU_EH_BUS 0x105c 114 #define CLK_CON_MUX_MUX_CLKCMU_G2D_G2D 0x1060 115 #define CLK_CON_MUX_MUX_CLKCMU_G2D_MSCL 0x1064 116 #define CLK_CON_MUX_MUX_CLKCMU_G3AA_G3AA 0x1068 117 #define CLK_CON_MUX_MUX_CLKCMU_G3D_BUSD 0x106c 118 #define CLK_CON_MUX_MUX_CLKCMU_G3D_GLB 0x1070 119 #define CLK_CON_MUX_MUX_CLKCMU_G3D_SWITCH 0x1074 120 #define CLK_CON_MUX_MUX_CLKCMU_GDC_GDC0 0x1078 121 #define CLK_CON_MUX_MUX_CLKCMU_GDC_GDC1 0x107c 122 #define CLK_CON_MUX_MUX_CLKCMU_GDC_SCSC 0x1080 123 #define CLK_CON_MUX_MUX_CLKCMU_HPM 0x1084 124 #define CLK_CON_MUX_MUX_CLKCMU_HSI0_BUS 0x1088 125 #define CLK_CON_MUX_MUX_CLKCMU_HSI0_DPGTC 0x108c 126 #define CLK_CON_MUX_MUX_CLKCMU_HSI0_USB31DRD 0x1090 127 #define CLK_CON_MUX_MUX_CLKCMU_HSI0_USBDPDBG 0x1094 128 #define CLK_CON_MUX_MUX_CLKCMU_HSI1_BUS 0x1098 129 #define CLK_CON_MUX_MUX_CLKCMU_HSI1_PCIE 0x109c 130 #define CLK_CON_MUX_MUX_CLKCMU_HSI2_BUS 0x10a0 131 #define CLK_CON_MUX_MUX_CLKCMU_HSI2_MMC_CARD 0x10a4 132 #define CLK_CON_MUX_MUX_CLKCMU_HSI2_PCIE 0x10a8 133 #define CLK_CON_MUX_MUX_CLKCMU_HSI2_UFS_EMBD 0x10ac 134 #define CLK_CON_MUX_MUX_CLKCMU_IPP_BUS 0x10b0 135 #define CLK_CON_MUX_MUX_CLKCMU_ITP_BUS 0x10b4 136 #define CLK_CON_MUX_MUX_CLKCMU_MCSC_ITSC 0x10b8 137 #define CLK_CON_MUX_MUX_CLKCMU_MCSC_MCSC 0x10bc 138 #define CLK_CON_MUX_MUX_CLKCMU_MFC_MFC 0x10c0 139 #define CLK_CON_MUX_MUX_CLKCMU_MIF_BUSP 0x10c4 140 #define CLK_CON_MUX_MUX_CLKCMU_MIF_SWITCH 0x10c8 141 #define CLK_CON_MUX_MUX_CLKCMU_MISC_BUS 0x10cc 142 #define CLK_CON_MUX_MUX_CLKCMU_MISC_SSS 0x10d0 143 #define CLK_CON_MUX_MUX_CLKCMU_PDP_BUS 0x10d4 144 #define CLK_CON_MUX_MUX_CLKCMU_PDP_VRA 0x10d8 145 #define CLK_CON_MUX_MUX_CLKCMU_PERIC0_BUS 0x10dc 146 #define CLK_CON_MUX_MUX_CLKCMU_PERIC0_IP 0x10e0 147 #define CLK_CON_MUX_MUX_CLKCMU_PERIC1_BUS 0x10e4 148 #define CLK_CON_MUX_MUX_CLKCMU_PERIC1_IP 0x10e8 149 #define CLK_CON_MUX_MUX_CLKCMU_TNR_BUS 0x10ec 150 #define CLK_CON_MUX_MUX_CLKCMU_TOP_BOOST_OPTION1 0x10f0 151 #define CLK_CON_MUX_MUX_CLKCMU_TOP_CMUREF 0x10f4 152 #define CLK_CON_MUX_MUX_CLKCMU_TPU_BUS 0x10f8 153 #define CLK_CON_MUX_MUX_CLKCMU_TPU_TPU 0x10fc 154 #define CLK_CON_MUX_MUX_CLKCMU_TPU_TPUCTL 0x1100 155 #define CLK_CON_MUX_MUX_CLKCMU_TPU_UART 0x1104 156 #define CLK_CON_MUX_MUX_CMU_CMUREF 0x1108 157 #define CLK_CON_DIV_CLKCMU_BO_BUS 0x1800 158 #define CLK_CON_DIV_CLKCMU_BUS0_BUS 0x1804 159 #define CLK_CON_DIV_CLKCMU_BUS1_BUS 0x1808 160 #define CLK_CON_DIV_CLKCMU_BUS2_BUS 0x180c 161 #define CLK_CON_DIV_CLKCMU_CIS_CLK0 0x1810 162 #define CLK_CON_DIV_CLKCMU_CIS_CLK1 0x1814 163 #define CLK_CON_DIV_CLKCMU_CIS_CLK2 0x1818 164 #define CLK_CON_DIV_CLKCMU_CIS_CLK3 0x181c 165 #define CLK_CON_DIV_CLKCMU_CIS_CLK4 0x1820 166 #define CLK_CON_DIV_CLKCMU_CIS_CLK5 0x1824 167 #define CLK_CON_DIV_CLKCMU_CIS_CLK6 0x1828 168 #define CLK_CON_DIV_CLKCMU_CIS_CLK7 0x182c 169 #define CLK_CON_DIV_CLKCMU_CORE_BUS 0x1830 170 #define CLK_CON_DIV_CLKCMU_CPUCL0_DBG 0x1834 171 #define CLK_CON_DIV_CLKCMU_CPUCL0_SWITCH 0x1838 172 #define CLK_CON_DIV_CLKCMU_CPUCL1_SWITCH 0x183c 173 #define CLK_CON_DIV_CLKCMU_CPUCL2_SWITCH 0x1840 174 #define CLK_CON_DIV_CLKCMU_CSIS_BUS 0x1844 175 #define CLK_CON_DIV_CLKCMU_DISP_BUS 0x1848 176 #define CLK_CON_DIV_CLKCMU_DNS_BUS 0x184c 177 #define CLK_CON_DIV_CLKCMU_DPU_BUS 0x1850 178 #define CLK_CON_DIV_CLKCMU_EH_BUS 0x1854 179 #define CLK_CON_DIV_CLKCMU_G2D_G2D 0x1858 180 #define CLK_CON_DIV_CLKCMU_G2D_MSCL 0x185c 181 #define CLK_CON_DIV_CLKCMU_G3AA_G3AA 0x1860 182 #define CLK_CON_DIV_CLKCMU_G3D_BUSD 0x1864 183 #define CLK_CON_DIV_CLKCMU_G3D_GLB 0x1868 184 #define CLK_CON_DIV_CLKCMU_G3D_SWITCH 0x186c 185 #define CLK_CON_DIV_CLKCMU_GDC_GDC0 0x1870 186 #define CLK_CON_DIV_CLKCMU_GDC_GDC1 0x1874 187 #define CLK_CON_DIV_CLKCMU_GDC_SCSC 0x1878 188 #define CLK_CON_DIV_CLKCMU_HPM 0x187c 189 #define CLK_CON_DIV_CLKCMU_HSI0_BUS 0x1880 190 #define CLK_CON_DIV_CLKCMU_HSI0_DPGTC 0x1884 191 #define CLK_CON_DIV_CLKCMU_HSI0_USB31DRD 0x1888 192 #define CLK_CON_DIV_CLKCMU_HSI0_USBDPDBG 0x188c 193 #define CLK_CON_DIV_CLKCMU_HSI1_BUS 0x1890 194 #define CLK_CON_DIV_CLKCMU_HSI1_PCIE 0x1894 195 #define CLK_CON_DIV_CLKCMU_HSI2_BUS 0x1898 196 #define CLK_CON_DIV_CLKCMU_HSI2_MMC_CARD 0x189c 197 #define CLK_CON_DIV_CLKCMU_HSI2_PCIE 0x18a0 198 #define CLK_CON_DIV_CLKCMU_HSI2_UFS_EMBD 0x18a4 199 #define CLK_CON_DIV_CLKCMU_IPP_BUS 0x18a8 200 #define CLK_CON_DIV_CLKCMU_ITP_BUS 0x18ac 201 #define CLK_CON_DIV_CLKCMU_MCSC_ITSC 0x18b0 202 #define CLK_CON_DIV_CLKCMU_MCSC_MCSC 0x18b4 203 #define CLK_CON_DIV_CLKCMU_MFC_MFC 0x18b8 204 #define CLK_CON_DIV_CLKCMU_MIF_BUSP 0x18bc 205 #define CLK_CON_DIV_CLKCMU_MISC_BUS 0x18c0 206 #define CLK_CON_DIV_CLKCMU_MISC_SSS 0x18c4 207 #define CLK_CON_DIV_CLKCMU_OTP 0x18c8 208 #define CLK_CON_DIV_CLKCMU_PDP_BUS 0x18cc 209 #define CLK_CON_DIV_CLKCMU_PDP_VRA 0x18d0 210 #define CLK_CON_DIV_CLKCMU_PERIC0_BUS 0x18d4 211 #define CLK_CON_DIV_CLKCMU_PERIC0_IP 0x18d8 212 #define CLK_CON_DIV_CLKCMU_PERIC1_BUS 0x18dc 213 #define CLK_CON_DIV_CLKCMU_PERIC1_IP 0x18e0 214 #define CLK_CON_DIV_CLKCMU_TNR_BUS 0x18e4 215 #define CLK_CON_DIV_CLKCMU_TPU_BUS 0x18e8 216 #define CLK_CON_DIV_CLKCMU_TPU_TPU 0x18ec 217 #define CLK_CON_DIV_CLKCMU_TPU_TPUCTL 0x18f0 218 #define CLK_CON_DIV_CLKCMU_TPU_UART 0x18f4 219 #define CLK_CON_DIV_DIV_CLKCMU_CMU_BOOST 0x18f8 220 #define CLK_CON_DIV_DIV_CLK_CMU_CMUREF 0x18fc 221 #define CLK_CON_DIV_PLL_SHARED0_DIV2 0x1900 222 #define CLK_CON_DIV_PLL_SHARED0_DIV3 0x1904 223 #define CLK_CON_DIV_PLL_SHARED0_DIV4 0x1908 224 #define CLK_CON_DIV_PLL_SHARED0_DIV5 0x190c 225 #define CLK_CON_DIV_PLL_SHARED1_DIV2 0x1910 226 #define CLK_CON_DIV_PLL_SHARED1_DIV3 0x1914 227 #define CLK_CON_DIV_PLL_SHARED1_DIV4 0x1918 228 #define CLK_CON_DIV_PLL_SHARED2_DIV2 0x191c 229 #define CLK_CON_DIV_PLL_SHARED3_DIV2 0x1920 230 #define CLK_CON_GAT_CLKCMU_BUS0_BOOST 0x2000 231 #define CLK_CON_GAT_CLKCMU_BUS1_BOOST 0x2004 232 #define CLK_CON_GAT_CLKCMU_BUS2_BOOST 0x2008 233 #define CLK_CON_GAT_CLKCMU_CORE_BOOST 0x200c 234 #define CLK_CON_GAT_CLKCMU_CPUCL0_BOOST 0x2010 235 #define CLK_CON_GAT_CLKCMU_CPUCL1_BOOST 0x2014 236 #define CLK_CON_GAT_CLKCMU_CPUCL2_BOOST 0x2018 237 #define CLK_CON_GAT_CLKCMU_MIF_BOOST 0x201c 238 #define CLK_CON_GAT_CLKCMU_MIF_SWITCH 0x2020 239 #define CLK_CON_GAT_GATE_CLKCMU_BO_BUS 0x2024 240 #define CLK_CON_GAT_GATE_CLKCMU_BUS0_BUS 0x2028 241 #define CLK_CON_GAT_GATE_CLKCMU_BUS1_BUS 0x202c 242 #define CLK_CON_GAT_GATE_CLKCMU_BUS2_BUS 0x2030 243 #define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK0 0x2034 244 #define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK1 0x2038 245 #define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK2 0x203c 246 #define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK3 0x2040 247 #define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK4 0x2044 248 #define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK5 0x2048 249 #define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK6 0x204c 250 #define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK7 0x2050 251 #define CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST 0x2054 252 #define CLK_CON_GAT_GATE_CLKCMU_CORE_BUS 0x2058 253 #define CLK_CON_GAT_GATE_CLKCMU_CPUCL0_DBG_BUS 0x205c 254 #define CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH 0x2060 255 #define CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH 0x2064 256 #define CLK_CON_GAT_GATE_CLKCMU_CPUCL2_SWITCH 0x2068 257 #define CLK_CON_GAT_GATE_CLKCMU_CSIS_BUS 0x206c 258 #define CLK_CON_GAT_GATE_CLKCMU_DISP_BUS 0x2070 259 #define CLK_CON_GAT_GATE_CLKCMU_DNS_BUS 0x2074 260 #define CLK_CON_GAT_GATE_CLKCMU_DPU_BUS 0x2078 261 #define CLK_CON_GAT_GATE_CLKCMU_EH_BUS 0x207c 262 #define CLK_CON_GAT_GATE_CLKCMU_G2D_G2D 0x2080 263 #define CLK_CON_GAT_GATE_CLKCMU_G2D_MSCL 0x2084 264 #define CLK_CON_GAT_GATE_CLKCMU_G3AA_G3AA 0x2088 265 #define CLK_CON_GAT_GATE_CLKCMU_G3D_BUSD 0x208c 266 #define CLK_CON_GAT_GATE_CLKCMU_G3D_GLB 0x2090 267 #define CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH 0x2094 268 #define CLK_CON_GAT_GATE_CLKCMU_GDC_GDC0 0x2098 269 #define CLK_CON_GAT_GATE_CLKCMU_GDC_GDC1 0x209c 270 #define CLK_CON_GAT_GATE_CLKCMU_GDC_SCSC 0x20a0 271 #define CLK_CON_GAT_GATE_CLKCMU_HPM 0x20a4 272 #define CLK_CON_GAT_GATE_CLKCMU_HSI0_BUS 0x20a8 273 #define CLK_CON_GAT_GATE_CLKCMU_HSI0_DPGTC 0x20ac 274 #define CLK_CON_GAT_GATE_CLKCMU_HSI0_USB31DRD 0x20b0 275 #define CLK_CON_GAT_GATE_CLKCMU_HSI0_USBDPDBG 0x20b4 276 #define CLK_CON_GAT_GATE_CLKCMU_HSI1_BUS 0x20b8 277 #define CLK_CON_GAT_GATE_CLKCMU_HSI1_PCIE 0x20bc 278 #define CLK_CON_GAT_GATE_CLKCMU_HSI2_BUS 0x20c0 279 #define CLK_CON_GAT_GATE_CLKCMU_HSI2_MMCCARD 0x20c4 280 #define CLK_CON_GAT_GATE_CLKCMU_HSI2_PCIE 0x20c8 281 #define CLK_CON_GAT_GATE_CLKCMU_HSI2_UFS_EMBD 0x20cc 282 #define CLK_CON_GAT_GATE_CLKCMU_IPP_BUS 0x20d0 283 #define CLK_CON_GAT_GATE_CLKCMU_ITP_BUS 0x20d4 284 #define CLK_CON_GAT_GATE_CLKCMU_MCSC_ITSC 0x20d8 285 #define CLK_CON_GAT_GATE_CLKCMU_MCSC_MCSC 0x20dc 286 #define CLK_CON_GAT_GATE_CLKCMU_MFC_MFC 0x20e0 287 #define CLK_CON_GAT_GATE_CLKCMU_MIF_BUSP 0x20e4 288 #define CLK_CON_GAT_GATE_CLKCMU_MISC_BUS 0x20e8 289 #define CLK_CON_GAT_GATE_CLKCMU_MISC_SSS 0x20ec 290 #define CLK_CON_GAT_GATE_CLKCMU_PDP_BUS 0x20f0 291 #define CLK_CON_GAT_GATE_CLKCMU_PDP_VRA 0x20f4 292 #define CLK_CON_GAT_GATE_CLKCMU_PERIC0_BUS 0x20f8 293 #define CLK_CON_GAT_GATE_CLKCMU_PERIC0_IP 0x20fc 294 #define CLK_CON_GAT_GATE_CLKCMU_PERIC1_BUS 0x2100 295 #define CLK_CON_GAT_GATE_CLKCMU_PERIC1_IP 0x2104 296 #define CLK_CON_GAT_GATE_CLKCMU_TNR_BUS 0x2108 297 #define CLK_CON_GAT_GATE_CLKCMU_TOP_CMUREF 0x210c 298 #define CLK_CON_GAT_GATE_CLKCMU_TPU_BUS 0x2110 299 #define CLK_CON_GAT_GATE_CLKCMU_TPU_TPU 0x2114 300 #define CLK_CON_GAT_GATE_CLKCMU_TPU_TPUCTL 0x2118 301 #define CLK_CON_GAT_GATE_CLKCMU_TPU_UART 0x211c 302 #define DMYQCH_CON_CMU_TOP_CMUREF_QCH 0x3000 303 #define DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK0 0x3004 304 #define DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK1 0x3008 305 #define DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK2 0x300c 306 #define DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK3 0x3010 307 #define DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK4 0x3014 308 #define DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK5 0x3018 309 #define DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK6 0x301c 310 #define DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK7 0x3020 311 #define DMYQCH_CON_OTP_QCH 0x3024 312 #define QUEUE_CTRL_REG_BLK_CMU_CMU_TOP 0x3c00 313 #define QUEUE_ENTRY0_BLK_CMU_CMU_TOP 0x3c10 314 #define QUEUE_ENTRY1_BLK_CMU_CMU_TOP 0x3c14 315 #define QUEUE_ENTRY2_BLK_CMU_CMU_TOP 0x3c18 316 #define QUEUE_ENTRY3_BLK_CMU_CMU_TOP 0x3c1c 317 #define QUEUE_ENTRY4_BLK_CMU_CMU_TOP 0x3c20 318 #define QUEUE_ENTRY5_BLK_CMU_CMU_TOP 0x3c24 319 #define QUEUE_ENTRY6_BLK_CMU_CMU_TOP 0x3c28 320 #define QUEUE_ENTRY7_BLK_CMU_CMU_TOP 0x3c2c 321 #define MIFMIRROR_QUEUE_CTRL_REG 0x3e00 322 #define MIFMIRROR_QUEUE_ENTRY0 0x3e10 323 #define MIFMIRROR_QUEUE_ENTRY1 0x3e14 324 #define MIFMIRROR_QUEUE_ENTRY2 0x3e18 325 #define MIFMIRROR_QUEUE_ENTRY3 0x3e1c 326 #define MIFMIRROR_QUEUE_ENTRY4 0x3e20 327 #define MIFMIRROR_QUEUE_ENTRY5 0x3e24 328 #define MIFMIRROR_QUEUE_ENTRY6 0x3e28 329 #define MIFMIRROR_QUEUE_ENTRY7 0x3e2c 330 #define MIFMIRROR_QUEUE_BUSY 0x3e30 331 #define GENERALIO_ACD_CHANNEL_0 0x3f00 332 #define GENERALIO_ACD_CHANNEL_1 0x3f04 333 #define GENERALIO_ACD_CHANNEL_2 0x3f08 334 #define GENERALIO_ACD_CHANNEL_3 0x3f0c 335 #define GENERALIO_ACD_MASK 0x3f14 336 337 static const unsigned long cmu_top_clk_regs[] __initconst = { 338 PLL_LOCKTIME_PLL_SHARED0, 339 PLL_LOCKTIME_PLL_SHARED1, 340 PLL_LOCKTIME_PLL_SHARED2, 341 PLL_LOCKTIME_PLL_SHARED3, 342 PLL_LOCKTIME_PLL_SPARE, 343 PLL_CON0_PLL_SHARED0, 344 PLL_CON1_PLL_SHARED0, 345 PLL_CON2_PLL_SHARED0, 346 PLL_CON3_PLL_SHARED0, 347 PLL_CON4_PLL_SHARED0, 348 PLL_CON0_PLL_SHARED1, 349 PLL_CON1_PLL_SHARED1, 350 PLL_CON2_PLL_SHARED1, 351 PLL_CON3_PLL_SHARED1, 352 PLL_CON4_PLL_SHARED1, 353 PLL_CON0_PLL_SHARED2, 354 PLL_CON1_PLL_SHARED2, 355 PLL_CON2_PLL_SHARED2, 356 PLL_CON3_PLL_SHARED2, 357 PLL_CON4_PLL_SHARED2, 358 PLL_CON0_PLL_SHARED3, 359 PLL_CON1_PLL_SHARED3, 360 PLL_CON2_PLL_SHARED3, 361 PLL_CON3_PLL_SHARED3, 362 PLL_CON4_PLL_SHARED3, 363 PLL_CON0_PLL_SPARE, 364 PLL_CON1_PLL_SPARE, 365 PLL_CON2_PLL_SPARE, 366 PLL_CON3_PLL_SPARE, 367 PLL_CON4_PLL_SPARE, 368 CMU_CMU_TOP_CONTROLLER_OPTION, 369 CLKOUT_CON_BLK_CMU_CMU_TOP_CLKOUT0, 370 CMU_HCHGEN_CLKMUX_CMU_BOOST, 371 CMU_HCHGEN_CLKMUX_TOP_BOOST, 372 CMU_HCHGEN_CLKMUX, 373 POWER_FAIL_DETECT_PLL, 374 EARLY_WAKEUP_FORCED_0_ENABLE, 375 EARLY_WAKEUP_FORCED_1_ENABLE, 376 EARLY_WAKEUP_APM_CTRL, 377 EARLY_WAKEUP_CLUSTER0_CTRL, 378 EARLY_WAKEUP_DPU_CTRL, 379 EARLY_WAKEUP_CSIS_CTRL, 380 EARLY_WAKEUP_APM_DEST, 381 EARLY_WAKEUP_CLUSTER0_DEST, 382 EARLY_WAKEUP_DPU_DEST, 383 EARLY_WAKEUP_CSIS_DEST, 384 EARLY_WAKEUP_SW_TRIG_APM, 385 EARLY_WAKEUP_SW_TRIG_APM_SET, 386 EARLY_WAKEUP_SW_TRIG_APM_CLEAR, 387 EARLY_WAKEUP_SW_TRIG_CLUSTER0, 388 EARLY_WAKEUP_SW_TRIG_CLUSTER0_SET, 389 EARLY_WAKEUP_SW_TRIG_CLUSTER0_CLEAR, 390 EARLY_WAKEUP_SW_TRIG_DPU, 391 EARLY_WAKEUP_SW_TRIG_DPU_SET, 392 EARLY_WAKEUP_SW_TRIG_DPU_CLEAR, 393 EARLY_WAKEUP_SW_TRIG_CSIS, 394 EARLY_WAKEUP_SW_TRIG_CSIS_SET, 395 EARLY_WAKEUP_SW_TRIG_CSIS_CLEAR, 396 CLK_CON_MUX_MUX_CLKCMU_BO_BUS, 397 CLK_CON_MUX_MUX_CLKCMU_BUS0_BUS, 398 CLK_CON_MUX_MUX_CLKCMU_BUS1_BUS, 399 CLK_CON_MUX_MUX_CLKCMU_BUS2_BUS, 400 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK0, 401 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK1, 402 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK2, 403 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK3, 404 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK4, 405 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK5, 406 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK6, 407 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK7, 408 CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST, 409 CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_OPTION1, 410 CLK_CON_MUX_MUX_CLKCMU_CORE_BUS, 411 CLK_CON_MUX_MUX_CLKCMU_CPUCL0_DBG, 412 CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH, 413 CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH, 414 CLK_CON_MUX_MUX_CLKCMU_CPUCL2_SWITCH, 415 CLK_CON_MUX_MUX_CLKCMU_CSIS_BUS, 416 CLK_CON_MUX_MUX_CLKCMU_DISP_BUS, 417 CLK_CON_MUX_MUX_CLKCMU_DNS_BUS, 418 CLK_CON_MUX_MUX_CLKCMU_DPU_BUS, 419 CLK_CON_MUX_MUX_CLKCMU_EH_BUS, 420 CLK_CON_MUX_MUX_CLKCMU_G2D_G2D, 421 CLK_CON_MUX_MUX_CLKCMU_G2D_MSCL, 422 CLK_CON_MUX_MUX_CLKCMU_G3AA_G3AA, 423 CLK_CON_MUX_MUX_CLKCMU_G3D_BUSD, 424 CLK_CON_MUX_MUX_CLKCMU_G3D_GLB, 425 CLK_CON_MUX_MUX_CLKCMU_G3D_SWITCH, 426 CLK_CON_MUX_MUX_CLKCMU_GDC_GDC0, 427 CLK_CON_MUX_MUX_CLKCMU_GDC_GDC1, 428 CLK_CON_MUX_MUX_CLKCMU_GDC_SCSC, 429 CLK_CON_MUX_MUX_CLKCMU_HPM, 430 CLK_CON_MUX_MUX_CLKCMU_HSI0_BUS, 431 CLK_CON_MUX_MUX_CLKCMU_HSI0_DPGTC, 432 CLK_CON_MUX_MUX_CLKCMU_HSI0_USB31DRD, 433 CLK_CON_MUX_MUX_CLKCMU_HSI0_USBDPDBG, 434 CLK_CON_MUX_MUX_CLKCMU_HSI1_BUS, 435 CLK_CON_MUX_MUX_CLKCMU_HSI1_PCIE, 436 CLK_CON_MUX_MUX_CLKCMU_HSI2_BUS, 437 CLK_CON_MUX_MUX_CLKCMU_HSI2_MMC_CARD, 438 CLK_CON_MUX_MUX_CLKCMU_HSI2_PCIE, 439 CLK_CON_MUX_MUX_CLKCMU_HSI2_UFS_EMBD, 440 CLK_CON_MUX_MUX_CLKCMU_IPP_BUS, 441 CLK_CON_MUX_MUX_CLKCMU_ITP_BUS, 442 CLK_CON_MUX_MUX_CLKCMU_MCSC_ITSC, 443 CLK_CON_MUX_MUX_CLKCMU_MCSC_MCSC, 444 CLK_CON_MUX_MUX_CLKCMU_MFC_MFC, 445 CLK_CON_MUX_MUX_CLKCMU_MIF_BUSP, 446 CLK_CON_MUX_MUX_CLKCMU_MIF_SWITCH, 447 CLK_CON_MUX_MUX_CLKCMU_MISC_BUS, 448 CLK_CON_MUX_MUX_CLKCMU_MISC_SSS, 449 CLK_CON_MUX_MUX_CLKCMU_PDP_BUS, 450 CLK_CON_MUX_MUX_CLKCMU_PDP_VRA, 451 CLK_CON_MUX_MUX_CLKCMU_PERIC0_BUS, 452 CLK_CON_MUX_MUX_CLKCMU_PERIC0_IP, 453 CLK_CON_MUX_MUX_CLKCMU_PERIC1_BUS, 454 CLK_CON_MUX_MUX_CLKCMU_PERIC1_IP, 455 CLK_CON_MUX_MUX_CLKCMU_TNR_BUS, 456 CLK_CON_MUX_MUX_CLKCMU_TOP_BOOST_OPTION1, 457 CLK_CON_MUX_MUX_CLKCMU_TOP_CMUREF, 458 CLK_CON_MUX_MUX_CLKCMU_TPU_BUS, 459 CLK_CON_MUX_MUX_CLKCMU_TPU_TPU, 460 CLK_CON_MUX_MUX_CLKCMU_TPU_TPUCTL, 461 CLK_CON_MUX_MUX_CLKCMU_TPU_UART, 462 CLK_CON_MUX_MUX_CMU_CMUREF, 463 CLK_CON_DIV_CLKCMU_BO_BUS, 464 CLK_CON_DIV_CLKCMU_BUS0_BUS, 465 CLK_CON_DIV_CLKCMU_BUS1_BUS, 466 CLK_CON_DIV_CLKCMU_BUS2_BUS, 467 CLK_CON_DIV_CLKCMU_CIS_CLK0, 468 CLK_CON_DIV_CLKCMU_CIS_CLK1, 469 CLK_CON_DIV_CLKCMU_CIS_CLK2, 470 CLK_CON_DIV_CLKCMU_CIS_CLK3, 471 CLK_CON_DIV_CLKCMU_CIS_CLK4, 472 CLK_CON_DIV_CLKCMU_CIS_CLK5, 473 CLK_CON_DIV_CLKCMU_CIS_CLK6, 474 CLK_CON_DIV_CLKCMU_CIS_CLK7, 475 CLK_CON_DIV_CLKCMU_CORE_BUS, 476 CLK_CON_DIV_CLKCMU_CPUCL0_DBG, 477 CLK_CON_DIV_CLKCMU_CPUCL0_SWITCH, 478 CLK_CON_DIV_CLKCMU_CPUCL1_SWITCH, 479 CLK_CON_DIV_CLKCMU_CPUCL2_SWITCH, 480 CLK_CON_DIV_CLKCMU_CSIS_BUS, 481 CLK_CON_DIV_CLKCMU_DISP_BUS, 482 CLK_CON_DIV_CLKCMU_DNS_BUS, 483 CLK_CON_DIV_CLKCMU_DPU_BUS, 484 CLK_CON_DIV_CLKCMU_EH_BUS, 485 CLK_CON_DIV_CLKCMU_G2D_G2D, 486 CLK_CON_DIV_CLKCMU_G2D_MSCL, 487 CLK_CON_DIV_CLKCMU_G3AA_G3AA, 488 CLK_CON_DIV_CLKCMU_G3D_BUSD, 489 CLK_CON_DIV_CLKCMU_G3D_GLB, 490 CLK_CON_DIV_CLKCMU_G3D_SWITCH, 491 CLK_CON_DIV_CLKCMU_GDC_GDC0, 492 CLK_CON_DIV_CLKCMU_GDC_GDC1, 493 CLK_CON_DIV_CLKCMU_GDC_SCSC, 494 CLK_CON_DIV_CLKCMU_HPM, 495 CLK_CON_DIV_CLKCMU_HSI0_BUS, 496 CLK_CON_DIV_CLKCMU_HSI0_DPGTC, 497 CLK_CON_DIV_CLKCMU_HSI0_USB31DRD, 498 CLK_CON_DIV_CLKCMU_HSI0_USBDPDBG, 499 CLK_CON_DIV_CLKCMU_HSI1_BUS, 500 CLK_CON_DIV_CLKCMU_HSI1_PCIE, 501 CLK_CON_DIV_CLKCMU_HSI2_BUS, 502 CLK_CON_DIV_CLKCMU_HSI2_MMC_CARD, 503 CLK_CON_DIV_CLKCMU_HSI2_PCIE, 504 CLK_CON_DIV_CLKCMU_HSI2_UFS_EMBD, 505 CLK_CON_DIV_CLKCMU_IPP_BUS, 506 CLK_CON_DIV_CLKCMU_ITP_BUS, 507 CLK_CON_DIV_CLKCMU_MCSC_ITSC, 508 CLK_CON_DIV_CLKCMU_MCSC_MCSC, 509 CLK_CON_DIV_CLKCMU_MFC_MFC, 510 CLK_CON_DIV_CLKCMU_MIF_BUSP, 511 CLK_CON_DIV_CLKCMU_MISC_BUS, 512 CLK_CON_DIV_CLKCMU_MISC_SSS, 513 CLK_CON_DIV_CLKCMU_OTP, 514 CLK_CON_DIV_CLKCMU_PDP_BUS, 515 CLK_CON_DIV_CLKCMU_PDP_VRA, 516 CLK_CON_DIV_CLKCMU_PERIC0_BUS, 517 CLK_CON_DIV_CLKCMU_PERIC0_IP, 518 CLK_CON_DIV_CLKCMU_PERIC1_BUS, 519 CLK_CON_DIV_CLKCMU_PERIC1_IP, 520 CLK_CON_DIV_CLKCMU_TNR_BUS, 521 CLK_CON_DIV_CLKCMU_TPU_BUS, 522 CLK_CON_DIV_CLKCMU_TPU_TPU, 523 CLK_CON_DIV_CLKCMU_TPU_TPUCTL, 524 CLK_CON_DIV_CLKCMU_TPU_UART, 525 CLK_CON_DIV_DIV_CLKCMU_CMU_BOOST, 526 CLK_CON_DIV_DIV_CLK_CMU_CMUREF, 527 CLK_CON_DIV_PLL_SHARED0_DIV2, 528 CLK_CON_DIV_PLL_SHARED0_DIV3, 529 CLK_CON_DIV_PLL_SHARED0_DIV4, 530 CLK_CON_DIV_PLL_SHARED0_DIV5, 531 CLK_CON_DIV_PLL_SHARED1_DIV2, 532 CLK_CON_DIV_PLL_SHARED1_DIV3, 533 CLK_CON_DIV_PLL_SHARED1_DIV4, 534 CLK_CON_DIV_PLL_SHARED2_DIV2, 535 CLK_CON_DIV_PLL_SHARED3_DIV2, 536 CLK_CON_GAT_CLKCMU_BUS0_BOOST, 537 CLK_CON_GAT_CLKCMU_BUS1_BOOST, 538 CLK_CON_GAT_CLKCMU_BUS2_BOOST, 539 CLK_CON_GAT_CLKCMU_CORE_BOOST, 540 CLK_CON_GAT_CLKCMU_CPUCL0_BOOST, 541 CLK_CON_GAT_CLKCMU_CPUCL1_BOOST, 542 CLK_CON_GAT_CLKCMU_CPUCL2_BOOST, 543 CLK_CON_GAT_CLKCMU_MIF_BOOST, 544 CLK_CON_GAT_CLKCMU_MIF_SWITCH, 545 CLK_CON_GAT_GATE_CLKCMU_BO_BUS, 546 CLK_CON_GAT_GATE_CLKCMU_BUS0_BUS, 547 CLK_CON_GAT_GATE_CLKCMU_BUS1_BUS, 548 CLK_CON_GAT_GATE_CLKCMU_BUS2_BUS, 549 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK0, 550 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK1, 551 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK2, 552 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK3, 553 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK4, 554 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK5, 555 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK6, 556 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK7, 557 CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST, 558 CLK_CON_GAT_GATE_CLKCMU_CORE_BUS, 559 CLK_CON_GAT_GATE_CLKCMU_CPUCL0_DBG_BUS, 560 CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH, 561 CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH, 562 CLK_CON_GAT_GATE_CLKCMU_CPUCL2_SWITCH, 563 CLK_CON_GAT_GATE_CLKCMU_CSIS_BUS, 564 CLK_CON_GAT_GATE_CLKCMU_DISP_BUS, 565 CLK_CON_GAT_GATE_CLKCMU_DNS_BUS, 566 CLK_CON_GAT_GATE_CLKCMU_DPU_BUS, 567 CLK_CON_GAT_GATE_CLKCMU_EH_BUS, 568 CLK_CON_GAT_GATE_CLKCMU_G2D_G2D, 569 CLK_CON_GAT_GATE_CLKCMU_G2D_MSCL, 570 CLK_CON_GAT_GATE_CLKCMU_G3AA_G3AA, 571 CLK_CON_GAT_GATE_CLKCMU_G3D_BUSD, 572 CLK_CON_GAT_GATE_CLKCMU_G3D_GLB, 573 CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH, 574 CLK_CON_GAT_GATE_CLKCMU_GDC_GDC0, 575 CLK_CON_GAT_GATE_CLKCMU_GDC_GDC1, 576 CLK_CON_GAT_GATE_CLKCMU_GDC_SCSC, 577 CLK_CON_GAT_GATE_CLKCMU_HPM, 578 CLK_CON_GAT_GATE_CLKCMU_HSI0_BUS, 579 CLK_CON_GAT_GATE_CLKCMU_HSI0_DPGTC, 580 CLK_CON_GAT_GATE_CLKCMU_HSI0_USB31DRD, 581 CLK_CON_GAT_GATE_CLKCMU_HSI0_USBDPDBG, 582 CLK_CON_GAT_GATE_CLKCMU_HSI1_BUS, 583 CLK_CON_GAT_GATE_CLKCMU_HSI1_PCIE, 584 CLK_CON_GAT_GATE_CLKCMU_HSI2_BUS, 585 CLK_CON_GAT_GATE_CLKCMU_HSI2_MMCCARD, 586 CLK_CON_GAT_GATE_CLKCMU_HSI2_PCIE, 587 CLK_CON_GAT_GATE_CLKCMU_HSI2_UFS_EMBD, 588 CLK_CON_GAT_GATE_CLKCMU_IPP_BUS, 589 CLK_CON_GAT_GATE_CLKCMU_ITP_BUS, 590 CLK_CON_GAT_GATE_CLKCMU_MCSC_ITSC, 591 CLK_CON_GAT_GATE_CLKCMU_MCSC_MCSC, 592 CLK_CON_GAT_GATE_CLKCMU_MFC_MFC, 593 CLK_CON_GAT_GATE_CLKCMU_MIF_BUSP, 594 CLK_CON_GAT_GATE_CLKCMU_MISC_BUS, 595 CLK_CON_GAT_GATE_CLKCMU_MISC_SSS, 596 CLK_CON_GAT_GATE_CLKCMU_PDP_BUS, 597 CLK_CON_GAT_GATE_CLKCMU_PDP_VRA, 598 CLK_CON_GAT_GATE_CLKCMU_PERIC0_BUS, 599 CLK_CON_GAT_GATE_CLKCMU_PERIC0_IP, 600 CLK_CON_GAT_GATE_CLKCMU_PERIC1_BUS, 601 CLK_CON_GAT_GATE_CLKCMU_PERIC1_IP, 602 CLK_CON_GAT_GATE_CLKCMU_TNR_BUS, 603 CLK_CON_GAT_GATE_CLKCMU_TOP_CMUREF, 604 CLK_CON_GAT_GATE_CLKCMU_TPU_BUS, 605 CLK_CON_GAT_GATE_CLKCMU_TPU_TPU, 606 CLK_CON_GAT_GATE_CLKCMU_TPU_TPUCTL, 607 CLK_CON_GAT_GATE_CLKCMU_TPU_UART, 608 DMYQCH_CON_CMU_TOP_CMUREF_QCH, 609 DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK0, 610 DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK1, 611 DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK2, 612 DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK3, 613 DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK4, 614 DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK5, 615 DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK6, 616 DMYQCH_CON_DFTMUX_CMU_QCH_CIS_CLK7, 617 DMYQCH_CON_OTP_QCH, 618 QUEUE_CTRL_REG_BLK_CMU_CMU_TOP, 619 QUEUE_ENTRY0_BLK_CMU_CMU_TOP, 620 QUEUE_ENTRY1_BLK_CMU_CMU_TOP, 621 QUEUE_ENTRY2_BLK_CMU_CMU_TOP, 622 QUEUE_ENTRY3_BLK_CMU_CMU_TOP, 623 QUEUE_ENTRY4_BLK_CMU_CMU_TOP, 624 QUEUE_ENTRY5_BLK_CMU_CMU_TOP, 625 QUEUE_ENTRY6_BLK_CMU_CMU_TOP, 626 QUEUE_ENTRY7_BLK_CMU_CMU_TOP, 627 MIFMIRROR_QUEUE_CTRL_REG, 628 MIFMIRROR_QUEUE_ENTRY0, 629 MIFMIRROR_QUEUE_ENTRY1, 630 MIFMIRROR_QUEUE_ENTRY2, 631 MIFMIRROR_QUEUE_ENTRY3, 632 MIFMIRROR_QUEUE_ENTRY4, 633 MIFMIRROR_QUEUE_ENTRY5, 634 MIFMIRROR_QUEUE_ENTRY6, 635 MIFMIRROR_QUEUE_ENTRY7, 636 MIFMIRROR_QUEUE_BUSY, 637 GENERALIO_ACD_CHANNEL_0, 638 GENERALIO_ACD_CHANNEL_1, 639 GENERALIO_ACD_CHANNEL_2, 640 GENERALIO_ACD_CHANNEL_3, 641 GENERALIO_ACD_MASK, 642 }; 643 644 static const struct samsung_pll_clock cmu_top_pll_clks[] __initconst = { 645 /* CMU_TOP_PURECLKCOMP */ 646 PLL(pll_0517x, CLK_FOUT_SHARED0_PLL, "fout_shared0_pll", "oscclk", 647 PLL_LOCKTIME_PLL_SHARED0, PLL_CON3_PLL_SHARED0, 648 NULL), 649 PLL(pll_0517x, CLK_FOUT_SHARED1_PLL, "fout_shared1_pll", "oscclk", 650 PLL_LOCKTIME_PLL_SHARED1, PLL_CON3_PLL_SHARED1, 651 NULL), 652 PLL(pll_0518x, CLK_FOUT_SHARED2_PLL, "fout_shared2_pll", "oscclk", 653 PLL_LOCKTIME_PLL_SHARED2, PLL_CON3_PLL_SHARED2, 654 NULL), 655 PLL(pll_0518x, CLK_FOUT_SHARED3_PLL, "fout_shared3_pll", "oscclk", 656 PLL_LOCKTIME_PLL_SHARED3, PLL_CON3_PLL_SHARED3, 657 NULL), 658 PLL(pll_0518x, CLK_FOUT_SPARE_PLL, "fout_spare_pll", "oscclk", 659 PLL_LOCKTIME_PLL_SPARE, PLL_CON3_PLL_SPARE, 660 NULL), 661 }; 662 663 /* List of parent clocks for Muxes in CMU_TOP */ 664 PNAME(mout_pll_shared0_p) = { "oscclk", "fout_shared0_pll" }; 665 PNAME(mout_pll_shared1_p) = { "oscclk", "fout_shared1_pll" }; 666 PNAME(mout_pll_shared2_p) = { "oscclk", "fout_shared2_pll" }; 667 PNAME(mout_pll_shared3_p) = { "oscclk", "fout_shared3_pll" }; 668 PNAME(mout_pll_spare_p) = { "oscclk", "fout_spare_pll" }; 669 PNAME(mout_cmu_bo_bus_p) = { "fout_shared2_pll", "dout_cmu_shared0_div3", 670 "fout_shared3_pll", "dout_cmu_shared1_div3", 671 "dout_cmu_shared0_div4", 672 "dout_cmu_shared1_div4", 673 "fout_spare_pll", "oscclk" }; 674 PNAME(mout_cmu_bus0_bus_p) = { "dout_cmu_shared0_div4", 675 "dout_cmu_shared1_div4", 676 "dout_cmu_shared2_div2", 677 "dout_cmu_shared3_div2", 678 "fout_spare_pll", "oscclk", 679 "oscclk", "oscclk" }; 680 PNAME(mout_cmu_bus1_bus_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 681 "dout_cmu_shared1_div3", 682 "dout_cmu_shared0_div4", 683 "dout_cmu_shared1_div4", 684 "dout_cmu_shared2_div2", 685 "fout_spare_pll", "oscclk" }; 686 PNAME(mout_cmu_bus2_bus_p) = { "dout_cmu_shared0_div2", 687 "dout_cmu_shared1_div2", 688 "fout_shared2_pll", "fout_shared3_pll", 689 "dout_cmu_shared0_div3", 690 "dout_cmu_shared1_div3", 691 "dout_cmu_shared0_div5", "fout_spare_pll" }; 692 PNAME(mout_cmu_cis_clk0_7_p) = { "oscclk", "dout_cmu_shared0_div3", 693 "dout_cmu_shared1_div3", 694 "dout_cmu_shared2_div2", 695 "dout_cmu_shared3_div2", "fout_spare_pll", 696 "oscclk", "oscclk" }; 697 PNAME(mout_cmu_cmu_boost_p) = { "dout_cmu_shared0_div4", 698 "dout_cmu_shared1_div4", 699 "dout_cmu_shared2_div2", 700 "dout_cmu_shared3_div2" }; 701 PNAME(mout_cmu_cmu_boost_option1_p) = { "dout_cmu_cmu_boost", 702 "gout_cmu_boost_option1" }; 703 PNAME(mout_cmu_core_bus_p) = { "dout_cmu_shared0_div2", 704 "dout_cmu_shared1_div2", 705 "fout_shared2_pll", "fout_shared3_pll", 706 "dout_cmu_shared0_div3", 707 "dout_cmu_shared1_div3", 708 "dout_cmu_shared0_div5", "fout_spare_pll" }; 709 PNAME(mout_cmu_cpucl0_dbg_p) = { "fout_shared2_pll", "fout_shared3_pll", 710 "dout_cmu_shared0_div4", 711 "dout_cmu_shared1_div4", 712 "dout_cmu_shared2_div2", "fout_spare_pll", 713 "oscclk", "oscclk" }; 714 PNAME(mout_cmu_cpucl0_switch_p) = { "fout_shared1_pll", "dout_cmu_shared0_div2", 715 "dout_cmu_shared1_div2", "fout_shared2_pll", 716 "fout_shared3_pll", "dout_cmu_shared0_div3", 717 "dout_cmu_shared1_div3", "fout_spare_pll" }; 718 PNAME(mout_cmu_cpucl1_switch_p) = { "fout_shared1_pll", "dout_cmu_shared0_div2", 719 "dout_cmu_shared1_div2", "fout_shared2_pll", 720 "fout_shared3_pll", "dout_cmu_shared0_div3", 721 "dout_cmu_shared1_div3", "fout_spare_pll" }; 722 PNAME(mout_cmu_cpucl2_switch_p) = { "fout_shared1_pll", "dout_cmu_shared0_div2", 723 "dout_cmu_shared1_div2", "fout_shared2_pll", 724 "fout_shared3_pll", "dout_cmu_shared0_div3", 725 "dout_cmu_shared1_div3", "fout_spare_pll" }; 726 PNAME(mout_cmu_csis_bus_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 727 "dout_cmu_shared1_div3", 728 "dout_cmu_shared0_div4", 729 "dout_cmu_shared1_div4", 730 "dout_cmu_shared2_div2", 731 "fout_spare_pll", "oscclk" }; 732 PNAME(mout_cmu_disp_bus_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 733 "dout_cmu_shared1_div3", 734 "dout_cmu_shared0_div4", 735 "dout_cmu_shared1_div4", 736 "dout_cmu_shared2_div2", 737 "fout_spare_pll", "oscclk" }; 738 PNAME(mout_cmu_dns_bus_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 739 "dout_cmu_shared1_div3", 740 "dout_cmu_shared0_div4", 741 "dout_cmu_shared1_div4", 742 "dout_cmu_shared2_div2", 743 "fout_spare_pll", "oscclk" }; 744 PNAME(mout_cmu_dpu_p) = { "dout_cmu_shared0_div3", 745 "fout_shared3_pll", 746 "dout_cmu_shared1_div3", 747 "dout_cmu_shared0_div4", 748 "dout_cmu_shared1_div4", 749 "dout_cmu_shared2_div2", 750 "fout_spare_pll", "oscclk" }; 751 PNAME(mout_cmu_eh_bus_p) = { "dout_cmu_shared0_div2", 752 "dout_cmu_shared1_div2", 753 "fout_shared2_pll", "fout_shared3_pll", 754 "dout_cmu_shared0_div3", 755 "dout_cmu_shared1_div3", 756 "dout_cmu_shared0_div5", "fout_spare_pll" }; 757 PNAME(mout_cmu_g2d_g2d_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 758 "dout_cmu_shared1_div3", 759 "dout_cmu_shared0_div4", 760 "dout_cmu_shared1_div4", 761 "dout_cmu_shared2_div2", 762 "fout_spare_pll", "oscclk" }; 763 PNAME(mout_cmu_g2d_mscl_p) = { "dout_cmu_shared0_div4", 764 "dout_cmu_shared1_div4", 765 "dout_cmu_shared2_div2", 766 "dout_cmu_shared3_div2", 767 "fout_spare_pll", "oscclk", 768 "oscclk", "oscclk" }; 769 PNAME(mout_cmu_g3aa_g3aa_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 770 "dout_cmu_shared1_div3", 771 "dout_cmu_shared0_div4", 772 "dout_cmu_shared1_div4", 773 "dout_cmu_shared2_div2", 774 "fout_spare_pll", "oscclk" }; 775 PNAME(mout_cmu_g3d_busd_p) = { "dout_cmu_shared0_div2", 776 "dout_cmu_shared1_div2", 777 "fout_shared2_pll", "fout_shared3_pll", 778 "dout_cmu_shared0_div3", 779 "dout_cmu_shared1_div3", 780 "dout_cmu_shared0_div4", "fout_spare_pll" }; 781 PNAME(mout_cmu_g3d_glb_p) = { "dout_cmu_shared0_div2", 782 "dout_cmu_shared1_div2", 783 "fout_shared2_pll", "fout_shared3_pll", 784 "dout_cmu_shared0_div3", 785 "dout_cmu_shared1_div3", 786 "dout_cmu_shared0_div4", "fout_spare_pll" }; 787 PNAME(mout_cmu_g3d_switch_p) = { "fout_shared2_pll", "dout_cmu_shared0_div3", 788 "fout_shared3_pll", "dout_cmu_shared1_div3", 789 "dout_cmu_shared0_div4", 790 "dout_cmu_shared1_div4", 791 "fout_spare_pll", "fout_spare_pll"}; 792 PNAME(mout_cmu_gdc_gdc0_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 793 "dout_cmu_shared1_div3", 794 "dout_cmu_shared0_div4", 795 "dout_cmu_shared1_div4", 796 "dout_cmu_shared2_div2", 797 "fout_spare_pll", "oscclk" }; 798 PNAME(mout_cmu_gdc_gdc1_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 799 "dout_cmu_shared1_div3", 800 "dout_cmu_shared0_div4", 801 "dout_cmu_shared1_div4", 802 "dout_cmu_shared2_div2", 803 "fout_spare_pll", "oscclk" }; 804 PNAME(mout_cmu_gdc_scsc_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 805 "dout_cmu_shared1_div3", 806 "dout_cmu_shared0_div4", 807 "dout_cmu_shared1_div4", 808 "dout_cmu_shared2_div2", 809 "fout_spare_pll", "oscclk" }; 810 PNAME(mout_cmu_hpm_p) = { "oscclk", "dout_cmu_shared1_div3", 811 "dout_cmu_shared0_div4", 812 "dout_cmu_shared2_div2" }; 813 PNAME(mout_cmu_hsi0_bus_p) = { "dout_cmu_shared0_div4", 814 "dout_cmu_shared1_div4", 815 "dout_cmu_shared2_div2", 816 "dout_cmu_shared3_div2", 817 "fout_spare_pll", "oscclk", 818 "oscclk", "oscclk" }; 819 PNAME(mout_cmu_hsi0_dpgtc_p) = { "oscclk", "dout_cmu_shared0_div4", 820 "dout_cmu_shared2_div2", "fout_spare_pll" }; 821 PNAME(mout_cmu_hsi0_usb31drd_p) = { "oscclk", "dout_cmu_shared2_div2" }; 822 PNAME(mout_cmu_hsi0_usbdpdbg_p) = { "oscclk", "dout_cmu_shared2_div2" }; 823 PNAME(mout_cmu_hsi1_bus_p) = { "dout_cmu_shared0_div4", 824 "dout_cmu_shared1_div4", 825 "dout_cmu_shared2_div2", 826 "dout_cmu_shared3_div2", 827 "fout_spare_pll" }; 828 PNAME(mout_cmu_hsi1_pcie_p) = { "oscclk", "dout_cmu_shared2_div2" }; 829 PNAME(mout_cmu_hsi2_bus_p) = { "dout_cmu_shared0_div4", 830 "dout_cmu_shared1_div4", 831 "dout_cmu_shared2_div2", 832 "dout_cmu_shared3_div2", 833 "fout_spare_pll", "oscclk", 834 "oscclk", "oscclk" }; 835 PNAME(mout_cmu_hsi2_mmc_card_p) = { "fout_shared2_pll", "fout_shared3_pll", 836 "dout_cmu_shared0_div4", "fout_spare_pll" }; 837 PNAME(mout_cmu_hsi2_pcie0_p) = { "oscclk", "dout_cmu_shared2_div2" }; 838 PNAME(mout_cmu_hsi2_ufs_embd_p) = { "oscclk", "dout_cmu_shared0_div4", 839 "dout_cmu_shared2_div2", "fout_spare_pll" }; 840 PNAME(mout_cmu_ipp_bus_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 841 "dout_cmu_shared1_div3", 842 "dout_cmu_shared0_div4", 843 "dout_cmu_shared1_div4", 844 "dout_cmu_shared2_div2", 845 "fout_spare_pll", "oscclk" }; 846 PNAME(mout_cmu_itp_bus_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 847 "dout_cmu_shared1_div3", 848 "dout_cmu_shared0_div4", 849 "dout_cmu_shared1_div4", 850 "dout_cmu_shared2_div2", 851 "fout_spare_pll", "oscclk" }; 852 PNAME(mout_cmu_mcsc_itsc_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 853 "dout_cmu_shared1_div3", 854 "dout_cmu_shared0_div4", 855 "dout_cmu_shared1_div4", 856 "dout_cmu_shared2_div2", 857 "fout_spare_pll", "oscclk" }; 858 PNAME(mout_cmu_mcsc_mcsc_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 859 "dout_cmu_shared1_div3", 860 "dout_cmu_shared0_div4", 861 "dout_cmu_shared1_div4", 862 "dout_cmu_shared2_div2", 863 "fout_spare_pll", "oscclk" }; 864 PNAME(mout_cmu_mfc_mfc_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 865 "dout_cmu_shared0_div4", 866 "dout_cmu_shared1_div4", 867 "dout_cmu_shared2_div2", "fout_spare_pll", 868 "oscclk", "oscclk" }; 869 PNAME(mout_cmu_mif_busp_p) = { "dout_cmu_shared0_div4", 870 "dout_cmu_shared1_div4", 871 "dout_cmu_shared0_div5", "fout_spare_pll" }; 872 PNAME(mout_cmu_mif_switch_p) = { "fout_shared0_pll", "fout_shared1_pll", 873 "dout_cmu_shared0_div2", 874 "dout_cmu_shared1_div2", 875 "fout_shared2_pll", "dout_cmu_shared0_div3", 876 "fout_shared3_pll", "fout_spare_pll" }; 877 PNAME(mout_cmu_misc_bus_p) = { "dout_cmu_shared0_div4", 878 "dout_cmu_shared2_div2", 879 "dout_cmu_shared3_div2", "fout_spare_pll" }; 880 PNAME(mout_cmu_misc_sss_p) = { "dout_cmu_shared0_div4", 881 "dout_cmu_shared2_div2", 882 "dout_cmu_shared3_div2", "fout_spare_pll" }; 883 PNAME(mout_cmu_pdp_bus_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 884 "dout_cmu_shared1_div3", 885 "dout_cmu_shared0_div4", 886 "dout_cmu_shared1_div4", 887 "dout_cmu_shared2_div2", 888 "fout_spare_pll", "oscclk" }; 889 PNAME(mout_cmu_pdp_vra_p) = { "fout_shared2_pll", "dout_cmu_shared0_div3", 890 "fout_shared3_pll", "dout_cmu_shared1_div3", 891 "dout_cmu_shared0_div4", 892 "dout_cmu_shared1_div4", 893 "fout_spare_pll", "oscclk" }; 894 PNAME(mout_cmu_peric0_bus_p) = { "dout_cmu_shared0_div4", 895 "dout_cmu_shared2_div2", 896 "dout_cmu_shared3_div2", "fout_spare_pll" }; 897 PNAME(mout_cmu_peric0_ip_p) = { "dout_cmu_shared0_div4", 898 "dout_cmu_shared2_div2", 899 "dout_cmu_shared3_div2", "fout_spare_pll" }; 900 PNAME(mout_cmu_peric1_bus_p) = { "dout_cmu_shared0_div4", 901 "dout_cmu_shared2_div2", 902 "dout_cmu_shared3_div2", "fout_spare_pll" }; 903 PNAME(mout_cmu_peric1_ip_p) = { "dout_cmu_shared0_div4", 904 "dout_cmu_shared2_div2", 905 "dout_cmu_shared3_div2", "fout_spare_pll" }; 906 PNAME(mout_cmu_tnr_bus_p) = { "dout_cmu_shared0_div3", "fout_shared3_pll", 907 "dout_cmu_shared1_div3", 908 "dout_cmu_shared0_div4", 909 "dout_cmu_shared1_div4", 910 "dout_cmu_shared2_div2", 911 "fout_spare_pll", "oscclk" }; 912 PNAME(mout_cmu_top_boost_option1_p) = { "oscclk", 913 "gout_cmu_boost_option1" }; 914 PNAME(mout_cmu_top_cmuref_p) = { "dout_cmu_shared0_div4", 915 "dout_cmu_shared1_div4", 916 "dout_cmu_shared2_div2", 917 "dout_cmu_shared3_div2" }; 918 PNAME(mout_cmu_tpu_bus_p) = { "dout_cmu_shared0_div2", 919 "dout_cmu_shared1_div2", 920 "fout_shared2_pll", 921 "fout_shared3_pll", 922 "dout_cmu_shared0_div3", 923 "dout_cmu_shared1_div3", 924 "dout_cmu_shared0_div4", 925 "fout_spare_pll" }; 926 PNAME(mout_cmu_tpu_tpu_p) = { "dout_cmu_shared0_div2", 927 "dout_cmu_shared1_div2", 928 "fout_shared2_pll", 929 "fout_shared3_pll", 930 "dout_cmu_shared0_div3", 931 "dout_cmu_shared1_div3", 932 "dout_cmu_shared0_div4", "fout_spare_pll" }; 933 PNAME(mout_cmu_tpu_tpuctl_p) = { "dout_cmu_shared0_div2", 934 "dout_cmu_shared1_div2", 935 "fout_shared2_pll", "fout_shared3_pll", 936 "dout_cmu_shared0_div3", 937 "dout_cmu_shared1_div3", 938 "dout_cmu_shared0_div4", "fout_spare_pll" }; 939 PNAME(mout_cmu_tpu_uart_p) = { "dout_cmu_shared0_div4", 940 "dout_cmu_shared2_div2", 941 "dout_cmu_shared3_div2", "fout_spare_pll" }; 942 PNAME(mout_cmu_cmuref_p) = { "mout_cmu_top_boost_option1", 943 "dout_cmu_cmuref" }; 944 945 /* 946 * Register name to clock name mangling strategy used in this file 947 * 948 * Replace PLL_CON0_PLL with CLK_MOUT_PLL and mout_pll 949 * Replace CLK_CON_MUX_MUX_CLKCMU with CLK_MOUT_CMU and mout_cmu 950 * Replace CLK_CON_DIV_CLKCMU with CLK_DOUT_CMU and dout_cmu 951 * Replace CLK_CON_DIV_DIV_CLKCMU with CLK_DOUT_CMU and dout_cmu 952 * Replace CLK_CON_GAT_CLKCMU with CLK_GOUT_CMU and gout_cmu 953 * Replace CLK_CON_GAT_GATE_CLKCMU with CLK_GOUT_CMU and gout_cmu 954 * 955 * For gates remove _UID _BLK _IPCLKPORT and _RSTNSYNC 956 */ 957 958 static const struct samsung_mux_clock cmu_top_mux_clks[] __initconst = { 959 MUX(CLK_MOUT_PLL_SHARED0, "mout_pll_shared0", mout_pll_shared0_p, 960 PLL_CON0_PLL_SHARED0, 4, 1), 961 MUX(CLK_MOUT_PLL_SHARED1, "mout_pll_shared1", mout_pll_shared1_p, 962 PLL_CON0_PLL_SHARED1, 4, 1), 963 MUX(CLK_MOUT_PLL_SHARED2, "mout_pll_shared2", mout_pll_shared2_p, 964 PLL_CON0_PLL_SHARED2, 4, 1), 965 MUX(CLK_MOUT_PLL_SHARED3, "mout_pll_shared3", mout_pll_shared3_p, 966 PLL_CON0_PLL_SHARED3, 4, 1), 967 MUX(CLK_MOUT_PLL_SPARE, "mout_pll_spare", mout_pll_spare_p, 968 PLL_CON0_PLL_SPARE, 4, 1), 969 MUX(CLK_MOUT_CMU_BO_BUS, "mout_cmu_bo_bus", mout_cmu_bo_bus_p, 970 CLK_CON_MUX_MUX_CLKCMU_BO_BUS, 0, 3), 971 MUX(CLK_MOUT_CMU_BUS0_BUS, "mout_cmu_bus0_bus", mout_cmu_bus0_bus_p, 972 CLK_CON_MUX_MUX_CLKCMU_BUS0_BUS, 0, 3), 973 MUX(CLK_MOUT_CMU_BUS1_BUS, "mout_cmu_bus1_bus", mout_cmu_bus1_bus_p, 974 CLK_CON_MUX_MUX_CLKCMU_BUS1_BUS, 0, 3), 975 MUX(CLK_MOUT_CMU_BUS2_BUS, "mout_cmu_bus2_bus", mout_cmu_bus2_bus_p, 976 CLK_CON_MUX_MUX_CLKCMU_BUS2_BUS, 0, 3), 977 MUX(CLK_MOUT_CMU_CIS_CLK0, "mout_cmu_cis_clk0", mout_cmu_cis_clk0_7_p, 978 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK0, 0, 3), 979 MUX(CLK_MOUT_CMU_CIS_CLK1, "mout_cmu_cis_clk1", mout_cmu_cis_clk0_7_p, 980 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK1, 0, 3), 981 MUX(CLK_MOUT_CMU_CIS_CLK2, "mout_cmu_cis_clk2", mout_cmu_cis_clk0_7_p, 982 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK2, 0, 3), 983 MUX(CLK_MOUT_CMU_CIS_CLK3, "mout_cmu_cis_clk3", mout_cmu_cis_clk0_7_p, 984 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK3, 0, 3), 985 MUX(CLK_MOUT_CMU_CIS_CLK4, "mout_cmu_cis_clk4", mout_cmu_cis_clk0_7_p, 986 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK4, 0, 3), 987 MUX(CLK_MOUT_CMU_CIS_CLK5, "mout_cmu_cis_clk5", mout_cmu_cis_clk0_7_p, 988 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK5, 0, 3), 989 MUX(CLK_MOUT_CMU_CIS_CLK6, "mout_cmu_cis_clk6", mout_cmu_cis_clk0_7_p, 990 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK6, 0, 3), 991 MUX(CLK_MOUT_CMU_CIS_CLK7, "mout_cmu_cis_clk7", mout_cmu_cis_clk0_7_p, 992 CLK_CON_MUX_MUX_CLKCMU_CIS_CLK7, 0, 3), 993 MUX(CLK_MOUT_CMU_CMU_BOOST, "mout_cmu_cmu_boost", mout_cmu_cmu_boost_p, 994 CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST, 0, 2), 995 MUX(CLK_MOUT_CMU_BOOST_OPTION1, "mout_cmu_boost_option1", 996 mout_cmu_cmu_boost_option1_p, 997 CLK_CON_MUX_MUX_CLKCMU_CMU_BOOST_OPTION1, 0, 1), 998 MUX(CLK_MOUT_CMU_CORE_BUS, "mout_cmu_core_bus", mout_cmu_core_bus_p, 999 CLK_CON_MUX_MUX_CLKCMU_CORE_BUS, 0, 3), 1000 MUX(CLK_MOUT_CMU_CPUCL0_DBG, "mout_cmu_cpucl0_dbg", 1001 mout_cmu_cpucl0_dbg_p, CLK_CON_DIV_CLKCMU_CPUCL0_DBG, 0, 3), 1002 MUX(CLK_MOUT_CMU_CPUCL0_SWITCH, "mout_cmu_cpucl0_switch", 1003 mout_cmu_cpucl0_switch_p, CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH, 1004 0, 3), 1005 MUX(CLK_MOUT_CMU_CPUCL1_SWITCH, "mout_cmu_cpucl1_switch", 1006 mout_cmu_cpucl1_switch_p, CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH, 1007 0, 3), 1008 MUX(CLK_MOUT_CMU_CPUCL2_SWITCH, "mout_cmu_cpucl2_switch", 1009 mout_cmu_cpucl2_switch_p, CLK_CON_MUX_MUX_CLKCMU_CPUCL2_SWITCH, 1010 0, 3), 1011 MUX(CLK_MOUT_CMU_CSIS_BUS, "mout_cmu_csis_bus", mout_cmu_csis_bus_p, 1012 CLK_CON_MUX_MUX_CLKCMU_CSIS_BUS, 0, 3), 1013 MUX(CLK_MOUT_CMU_DISP_BUS, "mout_cmu_disp_bus", mout_cmu_disp_bus_p, 1014 CLK_CON_MUX_MUX_CLKCMU_DISP_BUS, 0, 3), 1015 MUX(CLK_MOUT_CMU_DNS_BUS, "mout_cmu_dns_bus", mout_cmu_dns_bus_p, 1016 CLK_CON_MUX_MUX_CLKCMU_DNS_BUS, 0, 3), 1017 MUX(CLK_MOUT_CMU_DPU_BUS, "mout_cmu_dpu_bus", mout_cmu_dpu_p, 1018 CLK_CON_MUX_MUX_CLKCMU_DPU_BUS, 0, 3), 1019 MUX(CLK_MOUT_CMU_EH_BUS, "mout_cmu_eh_bus", mout_cmu_eh_bus_p, 1020 CLK_CON_MUX_MUX_CLKCMU_EH_BUS, 0, 3), 1021 MUX(CLK_MOUT_CMU_G2D_G2D, "mout_cmu_g2d_g2d", mout_cmu_g2d_g2d_p, 1022 CLK_CON_MUX_MUX_CLKCMU_G2D_G2D, 0, 3), 1023 MUX(CLK_MOUT_CMU_G2D_MSCL, "mout_cmu_g2d_mscl", mout_cmu_g2d_mscl_p, 1024 CLK_CON_MUX_MUX_CLKCMU_G2D_MSCL, 0, 3), 1025 MUX(CLK_MOUT_CMU_G3AA_G3AA, "mout_cmu_g3aa_g3aa", mout_cmu_g3aa_g3aa_p, 1026 CLK_CON_MUX_MUX_CLKCMU_G3AA_G3AA, 0, 3), 1027 MUX(CLK_MOUT_CMU_G3D_BUSD, "mout_cmu_g3d_busd", mout_cmu_g3d_busd_p, 1028 CLK_CON_MUX_MUX_CLKCMU_G3D_BUSD, 0, 3), 1029 MUX(CLK_MOUT_CMU_G3D_GLB, "mout_cmu_g3d_glb", mout_cmu_g3d_glb_p, 1030 CLK_CON_MUX_MUX_CLKCMU_G3D_GLB, 0, 3), 1031 MUX(CLK_MOUT_CMU_G3D_SWITCH, "mout_cmu_g3d_switch", 1032 mout_cmu_g3d_switch_p, CLK_CON_MUX_MUX_CLKCMU_G3D_SWITCH, 0, 3), 1033 MUX(CLK_MOUT_CMU_GDC_GDC0, "mout_cmu_gdc_gdc0", mout_cmu_gdc_gdc0_p, 1034 CLK_CON_MUX_MUX_CLKCMU_GDC_GDC0, 0, 3), 1035 MUX(CLK_MOUT_CMU_GDC_GDC1, "mout_cmu_gdc_gdc1", mout_cmu_gdc_gdc1_p, 1036 CLK_CON_MUX_MUX_CLKCMU_GDC_GDC1, 0, 3), 1037 MUX(CLK_MOUT_CMU_GDC_SCSC, "mout_cmu_gdc_scsc", mout_cmu_gdc_scsc_p, 1038 CLK_CON_MUX_MUX_CLKCMU_GDC_SCSC, 0, 3), 1039 MUX(CLK_MOUT_CMU_HPM, "mout_cmu_hpm", mout_cmu_hpm_p, 1040 CLK_CON_MUX_MUX_CLKCMU_HPM, 0, 2), 1041 MUX(CLK_MOUT_CMU_HSI0_BUS, "mout_cmu_hsi0_bus", mout_cmu_hsi0_bus_p, 1042 CLK_CON_MUX_MUX_CLKCMU_HSI0_BUS, 0, 3), 1043 MUX(CLK_MOUT_CMU_HSI0_DPGTC, "mout_cmu_hsi0_dpgtc", 1044 mout_cmu_hsi0_dpgtc_p, CLK_CON_MUX_MUX_CLKCMU_HSI0_DPGTC, 0, 2), 1045 MUX(CLK_MOUT_CMU_HSI0_USB31DRD, "mout_cmu_hsi0_usb31drd", 1046 mout_cmu_hsi0_usb31drd_p, CLK_CON_MUX_MUX_CLKCMU_HSI0_USB31DRD, 1047 0, 1), 1048 MUX(CLK_MOUT_CMU_HSI0_USBDPDBG, "mout_cmu_hsi0_usbdpdbg", 1049 mout_cmu_hsi0_usbdpdbg_p, CLK_CON_MUX_MUX_CLKCMU_HSI0_USBDPDBG, 1050 0, 1), 1051 MUX(CLK_MOUT_CMU_HSI1_BUS, "mout_cmu_hsi1_bus", mout_cmu_hsi1_bus_p, 1052 CLK_CON_MUX_MUX_CLKCMU_HSI1_BUS, 0, 3), 1053 MUX(CLK_MOUT_CMU_HSI1_PCIE, "mout_cmu_hsi1_pcie", mout_cmu_hsi1_pcie_p, 1054 CLK_CON_MUX_MUX_CLKCMU_HSI1_PCIE, 0, 1), 1055 MUX(CLK_MOUT_CMU_HSI2_BUS, "mout_cmu_hsi2_bus", mout_cmu_hsi2_bus_p, 1056 CLK_CON_MUX_MUX_CLKCMU_HSI2_BUS, 0, 3), 1057 MUX(CLK_MOUT_CMU_HSI2_MMC_CARD, "mout_cmu_hsi2_mmc_card", 1058 mout_cmu_hsi2_mmc_card_p, CLK_CON_MUX_MUX_CLKCMU_HSI2_MMC_CARD, 1059 0, 2), 1060 MUX(CLK_MOUT_CMU_HSI2_PCIE, "mout_cmu_hsi2_pcie", mout_cmu_hsi2_pcie0_p, 1061 CLK_CON_MUX_MUX_CLKCMU_HSI2_PCIE, 0, 1), 1062 MUX(CLK_MOUT_CMU_HSI2_UFS_EMBD, "mout_cmu_hsi2_ufs_embd", 1063 mout_cmu_hsi2_ufs_embd_p, CLK_CON_MUX_MUX_CLKCMU_HSI2_UFS_EMBD, 1064 0, 2), 1065 MUX(CLK_MOUT_CMU_IPP_BUS, "mout_cmu_ipp_bus", mout_cmu_ipp_bus_p, 1066 CLK_CON_MUX_MUX_CLKCMU_IPP_BUS, 0, 3), 1067 MUX(CLK_MOUT_CMU_ITP_BUS, "mout_cmu_itp_bus", mout_cmu_itp_bus_p, 1068 CLK_CON_MUX_MUX_CLKCMU_ITP_BUS, 0, 3), 1069 MUX(CLK_MOUT_CMU_MCSC_ITSC, "mout_cmu_mcsc_itsc", mout_cmu_mcsc_itsc_p, 1070 CLK_CON_MUX_MUX_CLKCMU_MCSC_ITSC, 0, 3), 1071 MUX(CLK_MOUT_CMU_MCSC_MCSC, "mout_cmu_mcsc_mcsc", mout_cmu_mcsc_mcsc_p, 1072 CLK_CON_MUX_MUX_CLKCMU_MCSC_MCSC, 0, 3), 1073 MUX(CLK_MOUT_CMU_MFC_MFC, "mout_cmu_mfc_mfc", mout_cmu_mfc_mfc_p, 1074 CLK_CON_MUX_MUX_CLKCMU_MFC_MFC, 0, 3), 1075 MUX(CLK_MOUT_CMU_MIF_BUSP, "mout_cmu_mif_busp", mout_cmu_mif_busp_p, 1076 CLK_CON_MUX_MUX_CLKCMU_MIF_BUSP, 0, 2), 1077 MUX(CLK_MOUT_CMU_MIF_SWITCH, "mout_cmu_mif_switch", 1078 mout_cmu_mif_switch_p, CLK_CON_MUX_MUX_CLKCMU_MIF_SWITCH, 0, 3), 1079 MUX(CLK_MOUT_CMU_MISC_BUS, "mout_cmu_misc_bus", mout_cmu_misc_bus_p, 1080 CLK_CON_MUX_MUX_CLKCMU_MISC_BUS, 0, 2), 1081 MUX(CLK_MOUT_CMU_MISC_SSS, "mout_cmu_misc_sss", mout_cmu_misc_sss_p, 1082 CLK_CON_MUX_MUX_CLKCMU_MISC_SSS, 0, 2), 1083 MUX(CLK_MOUT_CMU_PDP_BUS, "mout_cmu_pdp_bus", mout_cmu_pdp_bus_p, 1084 CLK_CON_MUX_MUX_CLKCMU_PDP_BUS, 0, 3), 1085 MUX(CLK_MOUT_CMU_PDP_VRA, "mout_cmu_pdp_vra", mout_cmu_pdp_vra_p, 1086 CLK_CON_MUX_MUX_CLKCMU_PDP_VRA, 0, 3), 1087 MUX(CLK_MOUT_CMU_PERIC0_BUS, "mout_cmu_peric0_bus", 1088 mout_cmu_peric0_bus_p, CLK_CON_MUX_MUX_CLKCMU_PERIC0_BUS, 0, 2), 1089 MUX(CLK_MOUT_CMU_PERIC0_IP, "mout_cmu_peric0_ip", mout_cmu_peric0_ip_p, 1090 CLK_CON_MUX_MUX_CLKCMU_PERIC0_IP, 0, 2), 1091 MUX(CLK_MOUT_CMU_PERIC1_BUS, "mout_cmu_peric1_bus", 1092 mout_cmu_peric1_bus_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_BUS, 0, 2), 1093 MUX(CLK_MOUT_CMU_PERIC1_IP, "mout_cmu_peric1_ip", mout_cmu_peric1_ip_p, 1094 CLK_CON_MUX_MUX_CLKCMU_PERIC1_IP, 0, 2), 1095 MUX(CLK_MOUT_CMU_TNR_BUS, "mout_cmu_tnr_bus", mout_cmu_tnr_bus_p, 1096 CLK_CON_MUX_MUX_CLKCMU_TNR_BUS, 0, 3), 1097 MUX(CLK_MOUT_CMU_TOP_BOOST_OPTION1, "mout_cmu_top_boost_option1", 1098 mout_cmu_top_boost_option1_p, 1099 CLK_CON_MUX_MUX_CLKCMU_TOP_BOOST_OPTION1, 0, 1), 1100 MUX(CLK_MOUT_CMU_TOP_CMUREF, "mout_cmu_top_cmuref", 1101 mout_cmu_top_cmuref_p, CLK_CON_MUX_MUX_CLKCMU_TOP_CMUREF, 0, 2), 1102 MUX(CLK_MOUT_CMU_TPU_BUS, "mout_cmu_tpu_bus", mout_cmu_tpu_bus_p, 1103 CLK_CON_MUX_MUX_CLKCMU_TPU_BUS, 0, 3), 1104 MUX(CLK_MOUT_CMU_TPU_TPU, "mout_cmu_tpu_tpu", mout_cmu_tpu_tpu_p, 1105 CLK_CON_MUX_MUX_CLKCMU_TPU_TPU, 0, 3), 1106 MUX(CLK_MOUT_CMU_TPU_TPUCTL, "mout_cmu_tpu_tpuctl", 1107 mout_cmu_tpu_tpuctl_p, CLK_CON_MUX_MUX_CLKCMU_TPU_TPUCTL, 0, 3), 1108 MUX(CLK_MOUT_CMU_TPU_UART, "mout_cmu_tpu_uart", mout_cmu_tpu_uart_p, 1109 CLK_CON_MUX_MUX_CLKCMU_TPU_UART, 0, 2), 1110 MUX(CLK_MOUT_CMU_CMUREF, "mout_cmu_cmuref", mout_cmu_cmuref_p, 1111 CLK_CON_MUX_MUX_CMU_CMUREF, 0, 1), 1112 }; 1113 1114 static const struct samsung_div_clock cmu_top_div_clks[] __initconst = { 1115 DIV(CLK_DOUT_CMU_BO_BUS, "dout_cmu_bo_bus", "gout_cmu_bo_bus", 1116 CLK_CON_DIV_CLKCMU_BO_BUS, 0, 4), 1117 DIV(CLK_DOUT_CMU_BUS0_BUS, "dout_cmu_bus0_bus", "gout_cmu_bus0_bus", 1118 CLK_CON_DIV_CLKCMU_BUS0_BUS, 0, 4), 1119 DIV(CLK_DOUT_CMU_BUS1_BUS, "dout_cmu_bus1_bus", "gout_cmu_bus1_bus", 1120 CLK_CON_DIV_CLKCMU_BUS1_BUS, 0, 4), 1121 DIV(CLK_DOUT_CMU_BUS2_BUS, "dout_cmu_bus2_bus", "gout_cmu_bus2_bus", 1122 CLK_CON_DIV_CLKCMU_BUS2_BUS, 0, 4), 1123 DIV(CLK_DOUT_CMU_CIS_CLK0, "dout_cmu_cis_clk0", "gout_cmu_cis_clk0", 1124 CLK_CON_DIV_CLKCMU_CIS_CLK0, 0, 5), 1125 DIV(CLK_DOUT_CMU_CIS_CLK1, "dout_cmu_cis_clk1", "gout_cmu_cis_clk1", 1126 CLK_CON_DIV_CLKCMU_CIS_CLK1, 0, 5), 1127 DIV(CLK_DOUT_CMU_CIS_CLK2, "dout_cmu_cis_clk2", "gout_cmu_cis_clk2", 1128 CLK_CON_DIV_CLKCMU_CIS_CLK2, 0, 5), 1129 DIV(CLK_DOUT_CMU_CIS_CLK3, "dout_cmu_cis_clk3", "gout_cmu_cis_clk3", 1130 CLK_CON_DIV_CLKCMU_CIS_CLK3, 0, 5), 1131 DIV(CLK_DOUT_CMU_CIS_CLK4, "dout_cmu_cis_clk4", "gout_cmu_cis_clk4", 1132 CLK_CON_DIV_CLKCMU_CIS_CLK4, 0, 5), 1133 DIV(CLK_DOUT_CMU_CIS_CLK5, "dout_cmu_cis_clk5", "gout_cmu_cis_clk5", 1134 CLK_CON_DIV_CLKCMU_CIS_CLK5, 0, 5), 1135 DIV(CLK_DOUT_CMU_CIS_CLK6, "dout_cmu_cis_clk6", "gout_cmu_cis_clk6", 1136 CLK_CON_DIV_CLKCMU_CIS_CLK6, 0, 5), 1137 DIV(CLK_DOUT_CMU_CIS_CLK7, "dout_cmu_cis_clk7", "gout_cmu_cis_clk7", 1138 CLK_CON_DIV_CLKCMU_CIS_CLK7, 0, 5), 1139 DIV(CLK_DOUT_CMU_CORE_BUS, "dout_cmu_core_bus", "gout_cmu_core_bus", 1140 CLK_CON_DIV_CLKCMU_CORE_BUS, 0, 4), 1141 DIV(CLK_DOUT_CMU_CPUCL0_DBG, "dout_cmu_cpucl0_dbg", 1142 "gout_cmu_cpucl0_dbg", CLK_CON_DIV_CLKCMU_CPUCL0_DBG, 0, 4), 1143 DIV(CLK_DOUT_CMU_CPUCL0_SWITCH, "dout_cmu_cpucl0_switch", 1144 "gout_cmu_cpucl0_switch", CLK_CON_DIV_CLKCMU_CPUCL0_SWITCH, 0, 3), 1145 DIV(CLK_DOUT_CMU_CPUCL1_SWITCH, "dout_cmu_cpucl1_switch", 1146 "gout_cmu_cpucl1_switch", CLK_CON_DIV_CLKCMU_CPUCL1_SWITCH, 0, 3), 1147 DIV(CLK_DOUT_CMU_CPUCL2_SWITCH, "dout_cmu_cpucl2_switch", 1148 "gout_cmu_cpucl2_switch", CLK_CON_DIV_CLKCMU_CPUCL2_SWITCH, 0, 3), 1149 DIV(CLK_DOUT_CMU_CSIS_BUS, "dout_cmu_csis_bus", "gout_cmu_csis_bus", 1150 CLK_CON_DIV_CLKCMU_CSIS_BUS, 0, 4), 1151 DIV(CLK_DOUT_CMU_DISP_BUS, "dout_cmu_disp_bus", "gout_cmu_disp_bus", 1152 CLK_CON_DIV_CLKCMU_DISP_BUS, 0, 4), 1153 DIV(CLK_DOUT_CMU_DNS_BUS, "dout_cmu_dns_bus", "gout_cmu_dns_bus", 1154 CLK_CON_DIV_CLKCMU_DNS_BUS, 0, 4), 1155 DIV(CLK_DOUT_CMU_DPU_BUS, "dout_cmu_dpu_bus", "gout_cmu_dpu_bus", 1156 CLK_CON_DIV_CLKCMU_DPU_BUS, 0, 4), 1157 DIV(CLK_DOUT_CMU_EH_BUS, "dout_cmu_eh_bus", "gout_cmu_eh_bus", 1158 CLK_CON_DIV_CLKCMU_EH_BUS, 0, 4), 1159 DIV(CLK_DOUT_CMU_G2D_G2D, "dout_cmu_g2d_g2d", "gout_cmu_g2d_g2d", 1160 CLK_CON_DIV_CLKCMU_G2D_G2D, 0, 4), 1161 DIV(CLK_DOUT_CMU_G2D_MSCL, "dout_cmu_g2d_mscl", "gout_cmu_g2d_mscl", 1162 CLK_CON_DIV_CLKCMU_G2D_MSCL, 0, 4), 1163 DIV(CLK_DOUT_CMU_G3AA_G3AA, "dout_cmu_g3aa_g3aa", "gout_cmu_g3aa_g3aa", 1164 CLK_CON_DIV_CLKCMU_G3AA_G3AA, 0, 4), 1165 DIV(CLK_DOUT_CMU_G3D_SWITCH, "dout_cmu_g3d_busd", "gout_cmu_g3d_busd", 1166 CLK_CON_DIV_CLKCMU_G3D_BUSD, 0, 4), 1167 DIV(CLK_DOUT_CMU_G3D_GLB, "dout_cmu_g3d_glb", "gout_cmu_g3d_glb", 1168 CLK_CON_DIV_CLKCMU_G3D_GLB, 0, 4), 1169 DIV(CLK_DOUT_CMU_G3D_SWITCH, "dout_cmu_g3d_switch", 1170 "gout_cmu_g3d_switch", CLK_CON_DIV_CLKCMU_G3D_SWITCH, 0, 3), 1171 DIV(CLK_DOUT_CMU_GDC_GDC0, "dout_cmu_gdc_gdc0", "gout_cmu_gdc_gdc0", 1172 CLK_CON_DIV_CLKCMU_GDC_GDC0, 0, 4), 1173 DIV(CLK_DOUT_CMU_GDC_GDC1, "dout_cmu_gdc_gdc1", "gout_cmu_gdc_gdc1", 1174 CLK_CON_DIV_CLKCMU_GDC_GDC1, 0, 4), 1175 DIV(CLK_DOUT_CMU_GDC_SCSC, "dout_cmu_gdc_scsc", "gout_cmu_gdc_scsc", 1176 CLK_CON_DIV_CLKCMU_GDC_SCSC, 0, 4), 1177 DIV(CLK_DOUT_CMU_CMU_HPM, "dout_cmu_hpm", "gout_cmu_hpm", 1178 CLK_CON_DIV_CLKCMU_HPM, 0, 2), 1179 DIV(CLK_DOUT_CMU_HSI0_BUS, "dout_cmu_hsi0_bus", "gout_cmu_hsi0_bus", 1180 CLK_CON_DIV_CLKCMU_HSI0_BUS, 0, 4), 1181 DIV(CLK_DOUT_CMU_HSI0_DPGTC, "dout_cmu_hsi0_dpgtc", 1182 "gout_cmu_hsi0_dpgtc", CLK_CON_DIV_CLKCMU_HSI0_DPGTC, 0, 4), 1183 DIV(CLK_DOUT_CMU_HSI0_USB31DRD, "dout_cmu_hsi0_usb31drd", 1184 "gout_cmu_hsi0_usb31drd", CLK_CON_DIV_CLKCMU_HSI0_USB31DRD, 0, 5), 1185 DIV(CLK_DOUT_CMU_HSI1_BUS, "dout_cmu_hsi1_bus", "gout_cmu_hsi1_bus", 1186 CLK_CON_DIV_CLKCMU_HSI1_BUS, 0, 4), 1187 DIV(CLK_DOUT_CMU_HSI1_PCIE, "dout_cmu_hsi1_pcie", "gout_cmu_hsi1_pcie", 1188 CLK_CON_DIV_CLKCMU_HSI1_PCIE, 0, 3), 1189 DIV(CLK_DOUT_CMU_HSI2_BUS, "dout_cmu_hsi2_bus", "gout_cmu_hsi2_bus", 1190 CLK_CON_DIV_CLKCMU_HSI2_BUS, 0, 4), 1191 DIV(CLK_DOUT_CMU_HSI2_MMC_CARD, "dout_cmu_hsi2_mmc_card", 1192 "gout_cmu_hsi2_mmc_card", CLK_CON_DIV_CLKCMU_HSI2_MMC_CARD, 0, 9), 1193 DIV(CLK_DOUT_CMU_HSI2_PCIE, "dout_cmu_hsi2_pcie", "gout_cmu_hsi2_pcie", 1194 CLK_CON_DIV_CLKCMU_HSI2_PCIE, 0, 3), 1195 DIV(CLK_DOUT_CMU_HSI2_UFS_EMBD, "dout_cmu_hsi2_ufs_embd", 1196 "gout_cmu_hsi2_ufs_embd", CLK_CON_DIV_CLKCMU_HSI2_UFS_EMBD, 0, 4), 1197 DIV(CLK_DOUT_CMU_IPP_BUS, "dout_cmu_ipp_bus", "gout_cmu_ipp_bus", 1198 CLK_CON_DIV_CLKCMU_IPP_BUS, 0, 4), 1199 DIV(CLK_DOUT_CMU_ITP_BUS, "dout_cmu_itp_bus", "gout_cmu_itp_bus", 1200 CLK_CON_DIV_CLKCMU_ITP_BUS, 0, 4), 1201 DIV(CLK_DOUT_CMU_MCSC_ITSC, "dout_cmu_mcsc_itsc", "gout_cmu_mcsc_itsc", 1202 CLK_CON_DIV_CLKCMU_MCSC_ITSC, 0, 4), 1203 DIV(CLK_DOUT_CMU_MCSC_MCSC, "dout_cmu_mcsc_mcsc", "gout_cmu_mcsc_mcsc", 1204 CLK_CON_DIV_CLKCMU_MCSC_MCSC, 0, 4), 1205 DIV(CLK_DOUT_CMU_MFC_MFC, "dout_cmu_mfc_mfc", "gout_cmu_mfc_mfc", 1206 CLK_CON_DIV_CLKCMU_MFC_MFC, 0, 4), 1207 DIV(CLK_DOUT_CMU_MIF_BUSP, "dout_cmu_mif_busp", "gout_cmu_mif_busp", 1208 CLK_CON_DIV_CLKCMU_MIF_BUSP, 0, 4), 1209 DIV(CLK_DOUT_CMU_MISC_BUS, "dout_cmu_misc_bus", "gout_cmu_misc_bus", 1210 CLK_CON_DIV_CLKCMU_MISC_BUS, 0, 4), 1211 DIV(CLK_DOUT_CMU_MISC_SSS, "dout_cmu_misc_sss", "gout_cmu_misc_sss", 1212 CLK_CON_DIV_CLKCMU_MISC_SSS, 0, 4), 1213 DIV(CLK_DOUT_CMU_PDP_BUS, "dout_cmu_pdp_bus", "gout_cmu_pdp_bus", 1214 CLK_CON_DIV_CLKCMU_PDP_BUS, 0, 4), 1215 DIV(CLK_DOUT_CMU_PDP_VRA, "dout_cmu_pdp_vra", "gout_cmu_pdp_vra", 1216 CLK_CON_DIV_CLKCMU_PDP_VRA, 0, 4), 1217 DIV(CLK_DOUT_CMU_PERIC0_BUS, "dout_cmu_peric0_bus", 1218 "gout_cmu_peric0_bus", CLK_CON_DIV_CLKCMU_PERIC0_BUS, 0, 4), 1219 DIV(CLK_DOUT_CMU_PERIC0_IP, "dout_cmu_peric0_ip", "gout_cmu_peric0_ip", 1220 CLK_CON_DIV_CLKCMU_PERIC0_IP, 0, 4), 1221 DIV(CLK_DOUT_CMU_PERIC1_BUS, "dout_cmu_peric1_bus", 1222 "gout_cmu_peric1_bus", CLK_CON_DIV_CLKCMU_PERIC1_BUS, 0, 4), 1223 DIV(CLK_DOUT_CMU_PERIC1_IP, "dout_cmu_peric1_ip", "gout_cmu_peric1_ip", 1224 CLK_CON_DIV_CLKCMU_PERIC1_IP, 0, 4), 1225 DIV(CLK_DOUT_CMU_TNR_BUS, "dout_cmu_tnr_bus", "gout_cmu_tnr_bus", 1226 CLK_CON_DIV_CLKCMU_TNR_BUS, 0, 4), 1227 DIV(CLK_DOUT_CMU_TPU_BUS, "dout_cmu_tpu_bus", "gout_cmu_tpu_bus", 1228 CLK_CON_DIV_CLKCMU_TPU_BUS, 0, 4), 1229 DIV(CLK_DOUT_CMU_TPU_TPU, "dout_cmu_tpu_tpu", "gout_cmu_tpu_tpu", 1230 CLK_CON_DIV_CLKCMU_TPU_TPU, 0, 4), 1231 DIV(CLK_DOUT_CMU_TPU_TPUCTL, "dout_cmu_tpu_tpuctl", 1232 "gout_cmu_tpu_tpuctl", CLK_CON_DIV_CLKCMU_TPU_TPUCTL, 0, 4), 1233 DIV(CLK_DOUT_CMU_TPU_UART, "dout_cmu_tpu_uart", "gout_cmu_tpu_uart", 1234 CLK_CON_DIV_CLKCMU_TPU_UART, 0, 4), 1235 DIV(CLK_DOUT_CMU_CMU_BOOST, "dout_cmu_cmu_boost", "gout_cmu_cmu_boost", 1236 CLK_CON_DIV_DIV_CLKCMU_CMU_BOOST, 0, 2), 1237 DIV(CLK_DOUT_CMU_CMU_CMUREF, "dout_cmu_cmuref", "gout_cmu_cmuref", 1238 CLK_CON_DIV_DIV_CLK_CMU_CMUREF, 0, 2), 1239 DIV(CLK_DOUT_CMU_SHARED0_DIV2, "dout_cmu_shared0_div2", 1240 "mout_pll_shared0", CLK_CON_DIV_PLL_SHARED0_DIV2, 0, 1), 1241 DIV(CLK_DOUT_CMU_SHARED0_DIV3, "dout_cmu_shared0_div3", 1242 "mout_pll_shared0", CLK_CON_DIV_PLL_SHARED0_DIV3, 0, 2), 1243 DIV(CLK_DOUT_CMU_SHARED0_DIV4, "dout_cmu_shared0_div4", 1244 "dout_cmu_shared0_div2", CLK_CON_DIV_PLL_SHARED0_DIV4, 0, 1), 1245 DIV(CLK_DOUT_CMU_SHARED0_DIV5, "dout_cmu_shared0_div5", 1246 "mout_pll_shared0", CLK_CON_DIV_PLL_SHARED0_DIV5, 0, 3), 1247 DIV(CLK_DOUT_CMU_SHARED1_DIV2, "dout_cmu_shared1_div2", 1248 "mout_pll_shared1", CLK_CON_DIV_PLL_SHARED1_DIV2, 0, 1), 1249 DIV(CLK_DOUT_CMU_SHARED1_DIV3, "dout_cmu_shared1_div3", 1250 "mout_pll_shared1", CLK_CON_DIV_PLL_SHARED1_DIV3, 0, 2), 1251 DIV(CLK_DOUT_CMU_SHARED1_DIV4, "dout_cmu_shared1_div4", 1252 "mout_pll_shared1", CLK_CON_DIV_PLL_SHARED1_DIV4, 0, 1), 1253 DIV(CLK_DOUT_CMU_SHARED2_DIV2, "dout_cmu_shared2_div2", 1254 "mout_pll_shared2", CLK_CON_DIV_PLL_SHARED2_DIV2, 0, 1), 1255 DIV(CLK_DOUT_CMU_SHARED3_DIV2, "dout_cmu_shared3_div2", 1256 "mout_pll_shared3", CLK_CON_DIV_PLL_SHARED3_DIV2, 0, 1), 1257 }; 1258 1259 static const struct samsung_fixed_factor_clock cmu_top_ffactor[] __initconst = { 1260 FFACTOR(CLK_DOUT_CMU_HSI0_USBDPDBG, "dout_cmu_hsi0_usbdpdbg", 1261 "gout_cmu_hsi0_usbdpdbg", 1, 4, 0), 1262 FFACTOR(CLK_DOUT_CMU_OTP, "dout_cmu_otp", "oscclk", 1, 8, 0), 1263 }; 1264 1265 static const struct samsung_gate_clock cmu_top_gate_clks[] __initconst = { 1266 GATE(CLK_GOUT_CMU_BUS0_BOOST, "gout_cmu_bus0_boost", 1267 "mout_cmu_boost_option1", CLK_CON_GAT_CLKCMU_BUS0_BOOST, 21, 0, 0), 1268 GATE(CLK_GOUT_CMU_BUS1_BOOST, "gout_cmu_bus1_boost", 1269 "mout_cmu_boost_option1", CLK_CON_GAT_CLKCMU_BUS1_BOOST, 21, 0, 0), 1270 GATE(CLK_GOUT_CMU_BUS2_BOOST, "gout_cmu_bus2_boost", 1271 "mout_cmu_boost_option1", CLK_CON_GAT_CLKCMU_BUS2_BOOST, 21, 0, 0), 1272 GATE(CLK_GOUT_CMU_CORE_BOOST, "gout_cmu_core_boost", 1273 "mout_cmu_boost_option1", CLK_CON_GAT_CLKCMU_CORE_BOOST, 21, 0, 0), 1274 GATE(CLK_GOUT_CMU_CPUCL0_BOOST, "gout_cmu_cpucl0_boost", 1275 "mout_cmu_boost_option1", CLK_CON_GAT_CLKCMU_CPUCL0_BOOST, 1276 21, 0, 0), 1277 GATE(CLK_GOUT_CMU_CPUCL1_BOOST, "gout_cmu_cpucl1_boost", 1278 "mout_cmu_boost_option1", CLK_CON_GAT_CLKCMU_CPUCL1_BOOST, 1279 21, 0, 0), 1280 GATE(CLK_GOUT_CMU_CPUCL2_BOOST, "gout_cmu_cpucl2_boost", 1281 "mout_cmu_boost_option1", CLK_CON_GAT_CLKCMU_CPUCL2_BOOST, 1282 21, 0, 0), 1283 GATE(CLK_GOUT_CMU_MIF_BOOST, "gout_cmu_mif_boost", 1284 "mout_cmu_boost_option1", CLK_CON_GAT_CLKCMU_MIF_BOOST, 1285 21, 0, 0), 1286 GATE(CLK_GOUT_CMU_MIF_SWITCH, "gout_cmu_mif_switch", 1287 "mout_cmu_mif_switch", CLK_CON_GAT_CLKCMU_MIF_SWITCH, 21, 0, 0), 1288 GATE(CLK_GOUT_CMU_BO_BUS, "gout_cmu_bo_bus", "mout_cmu_bo_bus", 1289 CLK_CON_GAT_GATE_CLKCMU_BO_BUS, 21, 0, 0), 1290 GATE(CLK_GOUT_CMU_BUS0_BUS, "gout_cmu_bus0_bus", "mout_cmu_bus0_bus", 1291 CLK_CON_GAT_GATE_CLKCMU_BUS0_BUS, 21, 0, 0), 1292 GATE(CLK_GOUT_CMU_BUS1_BUS, "gout_cmu_bus1_bus", "mout_cmu_bus1_bus", 1293 CLK_CON_GAT_GATE_CLKCMU_BUS1_BUS, 21, 0, 0), 1294 GATE(CLK_GOUT_CMU_BUS2_BUS, "gout_cmu_bus2_bus", "mout_cmu_bus2_bus", 1295 CLK_CON_GAT_GATE_CLKCMU_BUS2_BUS, 21, 0, 0), 1296 GATE(CLK_GOUT_CMU_CIS_CLK0, "gout_cmu_cis_clk0", "mout_cmu_cis_clk0", 1297 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK0, 21, 0, 0), 1298 GATE(CLK_GOUT_CMU_CIS_CLK1, "gout_cmu_cis_clk1", "mout_cmu_cis_clk1", 1299 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK1, 21, 0, 0), 1300 GATE(CLK_GOUT_CMU_CIS_CLK2, "gout_cmu_cis_clk2", "mout_cmu_cis_clk2", 1301 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK2, 21, 0, 0), 1302 GATE(CLK_GOUT_CMU_CIS_CLK3, "gout_cmu_cis_clk3", "mout_cmu_cis_clk3", 1303 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK3, 21, 0, 0), 1304 GATE(CLK_GOUT_CMU_CIS_CLK4, "gout_cmu_cis_clk4", "mout_cmu_cis_clk4", 1305 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK4, 21, 0, 0), 1306 GATE(CLK_GOUT_CMU_CIS_CLK5, "gout_cmu_cis_clk5", "mout_cmu_cis_clk5", 1307 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK5, 21, 0, 0), 1308 GATE(CLK_GOUT_CMU_CIS_CLK6, "gout_cmu_cis_clk6", "mout_cmu_cis_clk6", 1309 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK6, 21, 0, 0), 1310 GATE(CLK_GOUT_CMU_CIS_CLK7, "gout_cmu_cis_clk7", "mout_cmu_cis_clk7", 1311 CLK_CON_GAT_GATE_CLKCMU_CIS_CLK7, 21, 0, 0), 1312 GATE(CLK_GOUT_CMU_CMU_BOOST, "gout_cmu_cmu_boost", "mout_cmu_cmu_boost", 1313 CLK_CON_GAT_GATE_CLKCMU_CMU_BOOST, 21, 0, 0), 1314 GATE(CLK_GOUT_CMU_CORE_BUS, "gout_cmu_core_bus", "mout_cmu_core_bus", 1315 CLK_CON_GAT_GATE_CLKCMU_CORE_BUS, 21, 0, 0), 1316 GATE(CLK_GOUT_CMU_CPUCL0_DBG, "gout_cmu_cpucl0_dbg", 1317 "mout_cmu_cpucl0_dbg", CLK_CON_GAT_GATE_CLKCMU_CPUCL0_DBG_BUS, 1318 21, 0, 0), 1319 GATE(CLK_GOUT_CMU_CPUCL0_SWITCH, "gout_cmu_cpucl0_switch", 1320 "mout_cmu_cpucl0_switch", CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH, 1321 21, 0, 0), 1322 GATE(CLK_GOUT_CMU_CPUCL1_SWITCH, "gout_cmu_cpucl1_switch", 1323 "mout_cmu_cpucl1_switch", CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH, 1324 21, 0, 0), 1325 GATE(CLK_GOUT_CMU_CPUCL2_SWITCH, "gout_cmu_cpucl2_switch", 1326 "mout_cmu_cpucl2_switch", CLK_CON_GAT_GATE_CLKCMU_CPUCL2_SWITCH, 1327 21, 0, 0), 1328 GATE(CLK_GOUT_CMU_CSIS_BUS, "gout_cmu_csis_bus", "mout_cmu_csis_bus", 1329 CLK_CON_GAT_GATE_CLKCMU_CSIS_BUS, 21, 0, 0), 1330 GATE(CLK_GOUT_CMU_DISP_BUS, "gout_cmu_disp_bus", "mout_cmu_disp_bus", 1331 CLK_CON_GAT_GATE_CLKCMU_DISP_BUS, 21, 0, 0), 1332 GATE(CLK_GOUT_CMU_DNS_BUS, "gout_cmu_dns_bus", "mout_cmu_dns_bus", 1333 CLK_CON_GAT_GATE_CLKCMU_DNS_BUS, 21, 0, 0), 1334 GATE(CLK_GOUT_CMU_DPU_BUS, "gout_cmu_dpu_bus", "mout_cmu_dpu_bus", 1335 CLK_CON_GAT_GATE_CLKCMU_DPU_BUS, 21, 0, 0), 1336 GATE(CLK_GOUT_CMU_EH_BUS, "gout_cmu_eh_bus", "mout_cmu_eh_bus", 1337 CLK_CON_GAT_GATE_CLKCMU_EH_BUS, 21, 0, 0), 1338 GATE(CLK_GOUT_CMU_G2D_G2D, "gout_cmu_g2d_g2d", "mout_cmu_g2d_g2d", 1339 CLK_CON_GAT_GATE_CLKCMU_G2D_G2D, 21, 0, 0), 1340 GATE(CLK_GOUT_CMU_G2D_MSCL, "gout_cmu_g2d_mscl", "mout_cmu_g2d_mscl", 1341 CLK_CON_GAT_GATE_CLKCMU_G2D_MSCL, 21, 0, 0), 1342 GATE(CLK_GOUT_CMU_G3AA_G3AA, "gout_cmu_g3aa_g3aa", "mout_cmu_g3aa_g3aa", 1343 CLK_CON_MUX_MUX_CLKCMU_G3AA_G3AA, 21, 0, 0), 1344 GATE(CLK_GOUT_CMU_G3D_BUSD, "gout_cmu_g3d_busd", "mout_cmu_g3d_busd", 1345 CLK_CON_GAT_GATE_CLKCMU_G3D_BUSD, 21, 0, 0), 1346 GATE(CLK_GOUT_CMU_G3D_GLB, "gout_cmu_g3d_glb", "mout_cmu_g3d_glb", 1347 CLK_CON_GAT_GATE_CLKCMU_G3D_GLB, 21, 0, 0), 1348 GATE(CLK_GOUT_CMU_G3D_SWITCH, "gout_cmu_g3d_switch", 1349 "mout_cmu_g3d_switch", CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH, 1350 21, 0, 0), 1351 GATE(CLK_GOUT_CMU_GDC_GDC0, "gout_cmu_gdc_gdc0", "mout_cmu_gdc_gdc0", 1352 CLK_CON_GAT_GATE_CLKCMU_GDC_GDC0, 21, 0, 0), 1353 GATE(CLK_GOUT_CMU_GDC_GDC1, "gout_cmu_gdc_gdc1", "mout_cmu_gdc_gdc1", 1354 CLK_CON_GAT_GATE_CLKCMU_GDC_GDC1, 21, 0, 0), 1355 GATE(CLK_GOUT_CMU_GDC_SCSC, "gout_cmu_gdc_scsc", "mout_cmu_gdc_scsc", 1356 CLK_CON_GAT_GATE_CLKCMU_GDC_SCSC, 21, 0, 0), 1357 GATE(CLK_GOUT_CMU_HPM, "gout_cmu_hpm", "mout_cmu_hpm", 1358 CLK_CON_GAT_GATE_CLKCMU_HPM, 21, 0, 0), 1359 GATE(CLK_GOUT_CMU_HSI0_BUS, "gout_cmu_hsi0_bus", "mout_cmu_hsi0_bus", 1360 CLK_CON_GAT_GATE_CLKCMU_HSI0_BUS, 21, 0, 0), 1361 GATE(CLK_GOUT_CMU_HSI0_DPGTC, "gout_cmu_hsi0_dpgtc", 1362 "mout_cmu_hsi0_dpgtc", CLK_CON_GAT_GATE_CLKCMU_HSI0_DPGTC, 1363 21, 0, 0), 1364 GATE(CLK_GOUT_CMU_HSI0_USB31DRD, "gout_cmu_hsi0_usb31drd", 1365 "mout_cmu_hsi0_usb31drd", CLK_CON_GAT_GATE_CLKCMU_HSI0_USB31DRD, 1366 21, 0, 0), 1367 GATE(CLK_GOUT_CMU_HSI0_USBDPDBG, "gout_cmu_hsi0_usbdpdbg", 1368 "mout_cmu_hsi0_usbdpdbg", CLK_CON_GAT_GATE_CLKCMU_HSI0_USBDPDBG, 1369 21, 0, 0), 1370 GATE(CLK_GOUT_CMU_HSI1_BUS, "gout_cmu_hsi1_bus", "mout_cmu_hsi1_bus", 1371 CLK_CON_GAT_GATE_CLKCMU_HSI1_BUS, 21, 0, 0), 1372 GATE(CLK_GOUT_CMU_HSI1_PCIE, "gout_cmu_hsi1_pcie", "mout_cmu_hsi1_pcie", 1373 CLK_CON_GAT_GATE_CLKCMU_HSI1_PCIE, 21, 0, 0), 1374 GATE(CLK_GOUT_CMU_HSI2_BUS, "gout_cmu_hsi2_bus", "mout_cmu_hsi2_bus", 1375 CLK_CON_GAT_GATE_CLKCMU_HSI2_BUS, 21, 0, 0), 1376 GATE(CLK_GOUT_CMU_HSI2_MMC_CARD, "gout_cmu_hsi2_mmc_card", 1377 "mout_cmu_hsi2_mmc_card", CLK_CON_GAT_GATE_CLKCMU_HSI2_MMCCARD, 1378 21, 0, 0), 1379 GATE(CLK_GOUT_CMU_HSI2_PCIE, "gout_cmu_hsi2_pcie", "mout_cmu_hsi2_pcie", 1380 CLK_CON_GAT_GATE_CLKCMU_HSI2_PCIE, 21, 0, 0), 1381 GATE(CLK_GOUT_CMU_HSI2_UFS_EMBD, "gout_cmu_hsi2_ufs_embd", 1382 "mout_cmu_hsi2_ufs_embd", CLK_CON_GAT_GATE_CLKCMU_HSI2_UFS_EMBD, 1383 21, 0, 0), 1384 GATE(CLK_GOUT_CMU_IPP_BUS, "gout_cmu_ipp_bus", "mout_cmu_ipp_bus", 1385 CLK_CON_GAT_GATE_CLKCMU_IPP_BUS, 21, 0, 0), 1386 GATE(CLK_GOUT_CMU_ITP_BUS, "gout_cmu_itp_bus", "mout_cmu_itp_bus", 1387 CLK_CON_GAT_GATE_CLKCMU_ITP_BUS, 21, 0, 0), 1388 GATE(CLK_GOUT_CMU_MCSC_ITSC, "gout_cmu_mcsc_itsc", "mout_cmu_mcsc_itsc", 1389 CLK_CON_GAT_GATE_CLKCMU_MCSC_ITSC, 21, 0, 0), 1390 GATE(CLK_GOUT_CMU_MCSC_MCSC, "gout_cmu_mcsc_mcsc", "mout_cmu_mcsc_mcsc", 1391 CLK_CON_GAT_GATE_CLKCMU_MCSC_MCSC, 21, 0, 0), 1392 GATE(CLK_GOUT_CMU_MFC_MFC, "gout_cmu_mfc_mfc", "mout_cmu_mfc_mfc", 1393 CLK_CON_GAT_GATE_CLKCMU_MFC_MFC, 21, 0, 0), 1394 GATE(CLK_GOUT_CMU_MIF_BUSP, "gout_cmu_mif_busp", "mout_cmu_mif_busp", 1395 CLK_CON_GAT_GATE_CLKCMU_MIF_BUSP, 21, 0, 0), 1396 GATE(CLK_GOUT_CMU_MISC_BUS, "gout_cmu_misc_bus", "mout_cmu_misc_bus", 1397 CLK_CON_GAT_GATE_CLKCMU_MISC_BUS, 21, 0, 0), 1398 GATE(CLK_GOUT_CMU_MISC_SSS, "gout_cmu_misc_sss", "mout_cmu_misc_sss", 1399 CLK_CON_GAT_GATE_CLKCMU_MISC_SSS, 21, 0, 0), 1400 GATE(CLK_GOUT_CMU_PDP_BUS, "gout_cmu_pdp_bus", "mout_cmu_pdp_bus", 1401 CLK_CON_GAT_GATE_CLKCMU_PDP_BUS, 21, 0, 0), 1402 GATE(CLK_GOUT_CMU_PDP_VRA, "gout_cmu_pdp_vra", "mout_cmu_pdp_vra", 1403 CLK_CON_GAT_GATE_CLKCMU_PDP_BUS, 21, 0, 0), 1404 GATE(CLK_GOUT_CMU_PERIC0_BUS, "gout_cmu_peric0_bus", 1405 "mout_cmu_peric0_bus", CLK_CON_GAT_GATE_CLKCMU_PERIC0_BUS, 1406 21, 0, 0), 1407 GATE(CLK_GOUT_CMU_PERIC0_IP, "gout_cmu_peric0_ip", "mout_cmu_peric0_ip", 1408 CLK_CON_GAT_GATE_CLKCMU_PERIC0_IP, 21, 0, 0), 1409 GATE(CLK_GOUT_CMU_PERIC1_BUS, "gout_cmu_peric1_bus", 1410 "mout_cmu_peric1_bus", CLK_CON_GAT_GATE_CLKCMU_PERIC1_BUS, 1411 21, 0, 0), 1412 GATE(CLK_GOUT_CMU_PERIC1_IP, "gout_cmu_peric1_ip", "mout_cmu_peric1_ip", 1413 CLK_CON_GAT_GATE_CLKCMU_PERIC1_IP, 21, 0, 0), 1414 GATE(CLK_GOUT_CMU_TNR_BUS, "gout_cmu_tnr_bus", "mout_cmu_tnr_bus", 1415 CLK_CON_GAT_GATE_CLKCMU_TNR_BUS, 21, 0, 0), 1416 GATE(CLK_GOUT_CMU_TOP_CMUREF, "gout_cmu_top_cmuref", 1417 "mout_cmu_top_cmuref", CLK_CON_GAT_GATE_CLKCMU_TOP_CMUREF, 1418 21, 0, 0), 1419 GATE(CLK_GOUT_CMU_TPU_BUS, "gout_cmu_tpu_bus", "mout_cmu_tpu_bus", 1420 CLK_CON_GAT_GATE_CLKCMU_TPU_BUS, 21, 0, 0), 1421 GATE(CLK_GOUT_CMU_TPU_TPU, "gout_cmu_tpu_tpu", "mout_cmu_tpu_tpu", 1422 CLK_CON_GAT_GATE_CLKCMU_TPU_TPU, 21, 0, 0), 1423 GATE(CLK_GOUT_CMU_TPU_TPUCTL, "gout_cmu_tpu_tpuctl", 1424 "mout_cmu_tpu_tpuctl", CLK_CON_GAT_GATE_CLKCMU_TPU_TPUCTL, 1425 21, 0, 0), 1426 GATE(CLK_GOUT_CMU_TPU_UART, "gout_cmu_tpu_uart", "mout_cmu_tpu_uart", 1427 CLK_CON_GAT_GATE_CLKCMU_TPU_UART, 21, 0, 0), 1428 }; 1429 1430 static const struct samsung_cmu_info top_cmu_info __initconst = { 1431 .pll_clks = cmu_top_pll_clks, 1432 .nr_pll_clks = ARRAY_SIZE(cmu_top_pll_clks), 1433 .mux_clks = cmu_top_mux_clks, 1434 .nr_mux_clks = ARRAY_SIZE(cmu_top_mux_clks), 1435 .div_clks = cmu_top_div_clks, 1436 .nr_div_clks = ARRAY_SIZE(cmu_top_div_clks), 1437 .fixed_factor_clks = cmu_top_ffactor, 1438 .nr_fixed_factor_clks = ARRAY_SIZE(cmu_top_ffactor), 1439 .gate_clks = cmu_top_gate_clks, 1440 .nr_gate_clks = ARRAY_SIZE(cmu_top_gate_clks), 1441 .nr_clk_ids = CLKS_NR_TOP, 1442 .clk_regs = cmu_top_clk_regs, 1443 .nr_clk_regs = ARRAY_SIZE(cmu_top_clk_regs), 1444 }; 1445 1446 static void __init gs101_cmu_top_init(struct device_node *np) 1447 { 1448 exynos_arm64_register_cmu(NULL, np, &top_cmu_info); 1449 } 1450 1451 /* Register CMU_TOP early, as it's a dependency for other early domains */ 1452 CLK_OF_DECLARE(gs101_cmu_top, "google,gs101-cmu-top", 1453 gs101_cmu_top_init); 1454 1455 /* ---- CMU_APM ------------------------------------------------------------- */ 1456 1457 /* Register Offset definitions for CMU_APM (0x17400000) */ 1458 #define APM_CMU_APM_CONTROLLER_OPTION 0x0800 1459 #define CLKOUT_CON_BLK_APM_CMU_APM_CLKOUT0 0x0810 1460 #define CLK_CON_MUX_MUX_CLKCMU_APM_FUNC 0x1000 1461 #define CLK_CON_MUX_MUX_CLKCMU_APM_FUNCSRC 0x1004 1462 #define CLK_CON_DIV_DIV_CLK_APM_BOOST 0x1800 1463 #define CLK_CON_DIV_DIV_CLK_APM_USI0_UART 0x1804 1464 #define CLK_CON_DIV_DIV_CLK_APM_USI0_USI 0x1808 1465 #define CLK_CON_DIV_DIV_CLK_APM_USI1_UART 0x180c 1466 #define CLK_CON_GAT_CLK_BLK_APM_UID_APM_CMU_APM_IPCLKPORT_PCLK 0x2000 1467 #define CLK_CON_GAT_CLK_BUS0_BOOST_OPTION1 0x2004 1468 #define CLK_CON_GAT_CLK_CMU_BOOST_OPTION1 0x2008 1469 #define CLK_CON_GAT_CLK_CORE_BOOST_OPTION1 0x200c 1470 #define CLK_CON_GAT_GATE_CLKCMU_APM_FUNC 0x2010 1471 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_GPIO_ALIVE_IPCLKPORT_PCLK 0x2014 1472 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_GPIO_FAR_ALIVE_IPCLKPORT_PCLK 0x2018 1473 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_PMU_ALIVE_IPCLKPORT_PCLK 0x201c 1474 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_RTC_IPCLKPORT_PCLK 0x2020 1475 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_TRTC_IPCLKPORT_PCLK 0x2024 1476 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_UART_IPCLKPORT_IPCLK 0x2028 1477 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_UART_IPCLKPORT_PCLK 0x202c 1478 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_USI_IPCLKPORT_IPCLK 0x2030 1479 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_USI_IPCLKPORT_PCLK 0x2034 1480 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI1_UART_IPCLKPORT_IPCLK 0x2038 1481 #define CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI1_UART_IPCLKPORT_PCLK 0x203c 1482 #define CLK_CON_GAT_GOUT_BLK_APM_UID_D_TZPC_APM_IPCLKPORT_PCLK 0x2040 1483 #define CLK_CON_GAT_GOUT_BLK_APM_UID_GPC_APM_IPCLKPORT_PCLK 0x2044 1484 #define CLK_CON_GAT_GOUT_BLK_APM_UID_GREBEINTEGRATION_IPCLKPORT_HCLK 0x2048 1485 #define CLK_CON_GAT_GOUT_BLK_APM_UID_INTMEM_IPCLKPORT_ACLK 0x204c 1486 #define CLK_CON_GAT_GOUT_BLK_APM_UID_INTMEM_IPCLKPORT_PCLK 0x2050 1487 #define CLK_CON_GAT_GOUT_BLK_APM_UID_LHM_AXI_G_SWD_IPCLKPORT_I_CLK 0x2054 1488 #define CLK_CON_GAT_GOUT_BLK_APM_UID_LHM_AXI_P_AOCAPM_IPCLKPORT_I_CLK 0x2058 1489 #define CLK_CON_GAT_GOUT_BLK_APM_UID_LHM_AXI_P_APM_IPCLKPORT_I_CLK 0x205c 1490 #define CLK_CON_GAT_GOUT_BLK_APM_UID_LHS_AXI_D_APM_IPCLKPORT_I_CLK 0x2060 1491 #define CLK_CON_GAT_GOUT_BLK_APM_UID_LHS_AXI_G_DBGCORE_IPCLKPORT_I_CLK 0x2064 1492 #define CLK_CON_GAT_GOUT_BLK_APM_UID_LHS_AXI_G_SCAN2DRAM_IPCLKPORT_I_CLK 0x2068 1493 #define CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_AOC_IPCLKPORT_PCLK 0x206c 1494 #define CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_AP_IPCLKPORT_PCLK 0x2070 1495 #define CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_GSA_IPCLKPORT_PCLK 0x2074 1496 #define CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_SWD_IPCLKPORT_PCLK 0x207c 1497 #define CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_TPU_IPCLKPORT_PCLK 0x2080 1498 #define CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_AP_AOC_IPCLKPORT_PCLK 0x2084 1499 #define CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_AP_DBGCORE_IPCLKPORT_PCLK 0x2088 1500 #define CLK_CON_GAT_GOUT_BLK_APM_UID_PMU_INTR_GEN_IPCLKPORT_PCLK 0x208c 1501 #define CLK_CON_GAT_GOUT_BLK_APM_UID_ROM_CRC32_HOST_IPCLKPORT_ACLK 0x2090 1502 #define CLK_CON_GAT_GOUT_BLK_APM_UID_ROM_CRC32_HOST_IPCLKPORT_PCLK 0x2094 1503 #define CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_BUS_IPCLKPORT_CLK 0x2098 1504 #define CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_USI0_UART_IPCLKPORT_CLK 0x209c 1505 #define CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_USI0_USI_IPCLKPORT_CLK 0x20a0 1506 #define CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_USI1_UART_IPCLKPORT_CLK 0x20a4 1507 #define CLK_CON_GAT_GOUT_BLK_APM_UID_SPEEDY_APM_IPCLKPORT_PCLK 0x20a8 1508 #define CLK_CON_GAT_GOUT_BLK_APM_UID_SPEEDY_SUB_APM_IPCLKPORT_PCLK 0x20ac 1509 #define CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_D_APM_IPCLKPORT_ACLK 0x20b0 1510 #define CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_D_APM_IPCLKPORT_PCLK 0x20b4 1511 #define CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_G_DBGCORE_IPCLKPORT_ACLK 0x20b8 1512 #define CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_G_DBGCORE_IPCLKPORT_PCLK 0x20bc 1513 #define CLK_CON_GAT_GOUT_BLK_APM_UID_SS_DBGCORE_IPCLKPORT_SS_DBGCORE_IPCLKPORT_HCLK 0x20c0 1514 #define CLK_CON_GAT_GOUT_BLK_APM_UID_SYSMMU_D_APM_IPCLKPORT_CLK_S2 0x20c4 1515 #define CLK_CON_GAT_GOUT_BLK_APM_UID_SYSREG_APM_IPCLKPORT_PCLK 0x20cc 1516 #define CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_APM_IPCLKPORT_ACLK 0x20d0 1517 #define CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_APM_IPCLKPORT_PCLK 0x20d4 1518 #define CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_DBGCORE_IPCLKPORT_ACLK 0x20d8 1519 #define CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_DBGCORE_IPCLKPORT_PCLK 0x20dc 1520 #define CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_G_SWD_IPCLKPORT_ACLK 0x20e0 1521 #define CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_G_SWD_IPCLKPORT_PCLK 0x20e4 1522 #define CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_AOCAPM_IPCLKPORT_ACLK 0x20e8 1523 #define CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_AOCAPM_IPCLKPORT_PCLK 0x20ec 1524 #define CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_APM_IPCLKPORT_ACLK 0x20f0 1525 #define CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_APM_IPCLKPORT_PCLK 0x20f4 1526 #define CLK_CON_GAT_GOUT_BLK_APM_UID_WDT_APM_IPCLKPORT_PCLK 0x20f8 1527 #define CLK_CON_GAT_GOUT_BLK_APM_UID_XIU_DP_APM_IPCLKPORT_ACLK 0x20fc 1528 #define PCH_CON_LHM_AXI_G_SWD_PCH 0x3000 1529 #define PCH_CON_LHM_AXI_P_AOCAPM_PCH 0x3004 1530 #define PCH_CON_LHM_AXI_P_APM_PCH 0x3008 1531 #define PCH_CON_LHS_AXI_D_APM_PCH 0x300c 1532 #define PCH_CON_LHS_AXI_G_DBGCORE_PCH 0x3010 1533 #define PCH_CON_LHS_AXI_G_SCAN2DRAM_PCH 0x3014 1534 #define QCH_CON_APBIF_GPIO_ALIVE_QCH 0x3018 1535 #define QCH_CON_APBIF_GPIO_FAR_ALIVE_QCH 0x301c 1536 #define QCH_CON_APBIF_PMU_ALIVE_QCH 0x3020 1537 #define QCH_CON_APBIF_RTC_QCH 0x3024 1538 #define QCH_CON_APBIF_TRTC_QCH 0x3028 1539 #define QCH_CON_APM_CMU_APM_QCH 0x302c 1540 #define QCH_CON_APM_USI0_UART_QCH 0x3030 1541 #define QCH_CON_APM_USI0_USI_QCH 0x3034 1542 #define QCH_CON_APM_USI1_UART_QCH 0x3038 1543 #define QCH_CON_D_TZPC_APM_QCH 0x303c 1544 #define QCH_CON_GPC_APM_QCH 0x3040 1545 #define QCH_CON_GREBEINTEGRATION_QCH_DBG 0x3044 1546 #define QCH_CON_GREBEINTEGRATION_QCH_GREBE 0x3048 1547 #define QCH_CON_INTMEM_QCH 0x304c 1548 #define QCH_CON_LHM_AXI_G_SWD_QCH 0x3050 1549 #define QCH_CON_LHM_AXI_P_AOCAPM_QCH 0x3054 1550 #define QCH_CON_LHM_AXI_P_APM_QCH 0x3058 1551 #define QCH_CON_LHS_AXI_D_APM_QCH 0x305c 1552 #define QCH_CON_LHS_AXI_G_DBGCORE_QCH 0x3060 1553 #define QCH_CON_LHS_AXI_G_SCAN2DRAM_QCH 0x3064 1554 #define QCH_CON_MAILBOX_APM_AOC_QCH 0x3068 1555 #define QCH_CON_MAILBOX_APM_AP_QCH 0x306c 1556 #define QCH_CON_MAILBOX_APM_GSA_QCH 0x3070 1557 #define QCH_CON_MAILBOX_APM_SWD_QCH 0x3078 1558 #define QCH_CON_MAILBOX_APM_TPU_QCH 0x307c 1559 #define QCH_CON_MAILBOX_AP_AOC_QCH 0x3080 1560 #define QCH_CON_MAILBOX_AP_DBGCORE_QCH 0x3084 1561 #define QCH_CON_PMU_INTR_GEN_QCH 0x3088 1562 #define QCH_CON_ROM_CRC32_HOST_QCH 0x308c 1563 #define QCH_CON_RSTNSYNC_CLK_APM_BUS_QCH_GREBE 0x3090 1564 #define QCH_CON_RSTNSYNC_CLK_APM_BUS_QCH_GREBE_DBG 0x3094 1565 #define QCH_CON_SPEEDY_APM_QCH 0x3098 1566 #define QCH_CON_SPEEDY_SUB_APM_QCH 0x309c 1567 #define QCH_CON_SSMT_D_APM_QCH 0x30a0 1568 #define QCH_CON_SSMT_G_DBGCORE_QCH 0x30a4 1569 #define QCH_CON_SS_DBGCORE_QCH_DBG 0x30a8 1570 #define QCH_CON_SS_DBGCORE_QCH_GREBE 0x30ac 1571 #define QCH_CON_SYSMMU_D_APM_QCH 0x30b0 1572 #define QCH_CON_SYSREG_APM_QCH 0x30b8 1573 #define QCH_CON_UASC_APM_QCH 0x30bc 1574 #define QCH_CON_UASC_DBGCORE_QCH 0x30c0 1575 #define QCH_CON_UASC_G_SWD_QCH 0x30c4 1576 #define QCH_CON_UASC_P_AOCAPM_QCH 0x30c8 1577 #define QCH_CON_UASC_P_APM_QCH 0x30cc 1578 #define QCH_CON_WDT_APM_QCH 0x30d0 1579 #define QUEUE_CTRL_REG_BLK_APM_CMU_APM 0x3c00 1580 1581 static const unsigned long apm_clk_regs[] __initconst = { 1582 APM_CMU_APM_CONTROLLER_OPTION, 1583 CLKOUT_CON_BLK_APM_CMU_APM_CLKOUT0, 1584 CLK_CON_MUX_MUX_CLKCMU_APM_FUNC, 1585 CLK_CON_MUX_MUX_CLKCMU_APM_FUNCSRC, 1586 CLK_CON_DIV_DIV_CLK_APM_BOOST, 1587 CLK_CON_DIV_DIV_CLK_APM_USI0_UART, 1588 CLK_CON_DIV_DIV_CLK_APM_USI0_USI, 1589 CLK_CON_DIV_DIV_CLK_APM_USI1_UART, 1590 CLK_CON_GAT_CLK_BLK_APM_UID_APM_CMU_APM_IPCLKPORT_PCLK, 1591 CLK_CON_GAT_CLK_BUS0_BOOST_OPTION1, 1592 CLK_CON_GAT_CLK_CMU_BOOST_OPTION1, 1593 CLK_CON_GAT_CLK_CORE_BOOST_OPTION1, 1594 CLK_CON_GAT_GATE_CLKCMU_APM_FUNC, 1595 CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_GPIO_ALIVE_IPCLKPORT_PCLK, 1596 CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_GPIO_FAR_ALIVE_IPCLKPORT_PCLK, 1597 CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_PMU_ALIVE_IPCLKPORT_PCLK, 1598 CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_RTC_IPCLKPORT_PCLK, 1599 CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_TRTC_IPCLKPORT_PCLK, 1600 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_UART_IPCLKPORT_IPCLK, 1601 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_UART_IPCLKPORT_PCLK, 1602 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_USI_IPCLKPORT_IPCLK, 1603 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_USI_IPCLKPORT_PCLK, 1604 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI1_UART_IPCLKPORT_IPCLK, 1605 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI1_UART_IPCLKPORT_PCLK, 1606 CLK_CON_GAT_GOUT_BLK_APM_UID_D_TZPC_APM_IPCLKPORT_PCLK, 1607 CLK_CON_GAT_GOUT_BLK_APM_UID_GPC_APM_IPCLKPORT_PCLK, 1608 CLK_CON_GAT_GOUT_BLK_APM_UID_GREBEINTEGRATION_IPCLKPORT_HCLK, 1609 CLK_CON_GAT_GOUT_BLK_APM_UID_INTMEM_IPCLKPORT_ACLK, 1610 CLK_CON_GAT_GOUT_BLK_APM_UID_INTMEM_IPCLKPORT_PCLK, 1611 CLK_CON_GAT_GOUT_BLK_APM_UID_LHM_AXI_G_SWD_IPCLKPORT_I_CLK, 1612 CLK_CON_GAT_GOUT_BLK_APM_UID_LHM_AXI_P_AOCAPM_IPCLKPORT_I_CLK, 1613 CLK_CON_GAT_GOUT_BLK_APM_UID_LHM_AXI_P_APM_IPCLKPORT_I_CLK, 1614 CLK_CON_GAT_GOUT_BLK_APM_UID_LHS_AXI_D_APM_IPCLKPORT_I_CLK, 1615 CLK_CON_GAT_GOUT_BLK_APM_UID_LHS_AXI_G_DBGCORE_IPCLKPORT_I_CLK, 1616 CLK_CON_GAT_GOUT_BLK_APM_UID_LHS_AXI_G_SCAN2DRAM_IPCLKPORT_I_CLK, 1617 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_AOC_IPCLKPORT_PCLK, 1618 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_AP_IPCLKPORT_PCLK, 1619 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_GSA_IPCLKPORT_PCLK, 1620 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_SWD_IPCLKPORT_PCLK, 1621 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_TPU_IPCLKPORT_PCLK, 1622 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_AP_AOC_IPCLKPORT_PCLK, 1623 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_AP_DBGCORE_IPCLKPORT_PCLK, 1624 CLK_CON_GAT_GOUT_BLK_APM_UID_PMU_INTR_GEN_IPCLKPORT_PCLK, 1625 CLK_CON_GAT_GOUT_BLK_APM_UID_ROM_CRC32_HOST_IPCLKPORT_ACLK, 1626 CLK_CON_GAT_GOUT_BLK_APM_UID_ROM_CRC32_HOST_IPCLKPORT_PCLK, 1627 CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_BUS_IPCLKPORT_CLK, 1628 CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_USI0_UART_IPCLKPORT_CLK, 1629 CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_USI0_USI_IPCLKPORT_CLK, 1630 CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_USI1_UART_IPCLKPORT_CLK, 1631 CLK_CON_GAT_GOUT_BLK_APM_UID_SPEEDY_APM_IPCLKPORT_PCLK, 1632 CLK_CON_GAT_GOUT_BLK_APM_UID_SPEEDY_SUB_APM_IPCLKPORT_PCLK, 1633 CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_D_APM_IPCLKPORT_ACLK, 1634 CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_D_APM_IPCLKPORT_PCLK, 1635 CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_G_DBGCORE_IPCLKPORT_ACLK, 1636 CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_G_DBGCORE_IPCLKPORT_PCLK, 1637 CLK_CON_GAT_GOUT_BLK_APM_UID_SS_DBGCORE_IPCLKPORT_SS_DBGCORE_IPCLKPORT_HCLK, 1638 CLK_CON_GAT_GOUT_BLK_APM_UID_SYSMMU_D_APM_IPCLKPORT_CLK_S2, 1639 CLK_CON_GAT_GOUT_BLK_APM_UID_SYSREG_APM_IPCLKPORT_PCLK, 1640 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_APM_IPCLKPORT_ACLK, 1641 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_APM_IPCLKPORT_PCLK, 1642 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_DBGCORE_IPCLKPORT_ACLK, 1643 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_DBGCORE_IPCLKPORT_PCLK, 1644 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_G_SWD_IPCLKPORT_ACLK, 1645 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_G_SWD_IPCLKPORT_PCLK, 1646 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_AOCAPM_IPCLKPORT_ACLK, 1647 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_AOCAPM_IPCLKPORT_PCLK, 1648 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_APM_IPCLKPORT_ACLK, 1649 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_APM_IPCLKPORT_PCLK, 1650 CLK_CON_GAT_GOUT_BLK_APM_UID_WDT_APM_IPCLKPORT_PCLK, 1651 CLK_CON_GAT_GOUT_BLK_APM_UID_XIU_DP_APM_IPCLKPORT_ACLK, 1652 }; 1653 1654 PNAME(mout_apm_func_p) = { "oscclk", "mout_apm_funcsrc", 1655 "pad_clk_apm", "oscclk" }; 1656 PNAME(mout_apm_funcsrc_p) = { "pll_alv_div2_apm", "pll_alv_div4_apm", 1657 "pll_alv_div16_apm" }; 1658 1659 static const struct samsung_fixed_rate_clock apm_fixed_clks[] __initconst = { 1660 FRATE(CLK_APM_PLL_DIV2_APM, "pll_alv_div2_apm", NULL, 0, 393216000), 1661 FRATE(CLK_APM_PLL_DIV4_APM, "pll_alv_div4_apm", NULL, 0, 196608000), 1662 FRATE(CLK_APM_PLL_DIV16_APM, "pll_alv_div16_apm", NULL, 0, 49152000), 1663 }; 1664 1665 static const struct samsung_mux_clock apm_mux_clks[] __initconst = { 1666 MUX(CLK_MOUT_APM_FUNC, "mout_apm_func", mout_apm_func_p, 1667 CLK_CON_MUX_MUX_CLKCMU_APM_FUNC, 4, 1), 1668 MUX(CLK_MOUT_APM_FUNCSRC, "mout_apm_funcsrc", mout_apm_funcsrc_p, 1669 CLK_CON_MUX_MUX_CLKCMU_APM_FUNCSRC, 3, 1), 1670 }; 1671 1672 static const struct samsung_div_clock apm_div_clks[] __initconst = { 1673 DIV(CLK_DOUT_APM_BOOST, "dout_apm_boost", "gout_apm_func", 1674 CLK_CON_DIV_DIV_CLK_APM_BOOST, 0, 1), 1675 DIV(CLK_DOUT_APM_USI0_UART, "dout_apm_usi0_uart", "gout_apm_func", 1676 CLK_CON_DIV_DIV_CLK_APM_USI0_UART, 0, 7), 1677 DIV(CLK_DOUT_APM_USI0_USI, "dout_apm_usi0_usi", "gout_apm_func", 1678 CLK_CON_DIV_DIV_CLK_APM_USI0_USI, 0, 7), 1679 DIV(CLK_DOUT_APM_USI1_UART, "dout_apm_usi1_uart", "gout_apm_func", 1680 CLK_CON_DIV_DIV_CLK_APM_USI1_UART, 0, 7), 1681 }; 1682 1683 static const struct samsung_gate_clock apm_gate_clks[] __initconst = { 1684 GATE(CLK_GOUT_APM_APM_CMU_APM_PCLK, 1685 "gout_apm_apm_cmu_apm_pclk", "mout_apm_func", 1686 CLK_CON_GAT_CLK_BLK_APM_UID_APM_CMU_APM_IPCLKPORT_PCLK, 21, 0, 0), 1687 GATE(CLK_GOUT_BUS0_BOOST_OPTION1, "gout_bus0_boost_option1", 1688 "dout_apm_boost", CLK_CON_GAT_CLK_BUS0_BOOST_OPTION1, 21, 0, 0), 1689 GATE(CLK_GOUT_CMU_BOOST_OPTION1, "gout_cmu_boost_option1", 1690 "dout_apm_boost", CLK_CON_GAT_CLK_CMU_BOOST_OPTION1, 21, 0, 0), 1691 GATE(CLK_GOUT_CORE_BOOST_OPTION1, "gout_core_boost_option1", 1692 "dout_apm_boost", CLK_CON_GAT_CLK_CORE_BOOST_OPTION1, 21, 0, 0), 1693 GATE(CLK_GOUT_APM_FUNC, "gout_apm_func", "mout_apm_func", 1694 CLK_CON_GAT_GATE_CLKCMU_APM_FUNC, 21, 0, 0), 1695 GATE(CLK_GOUT_APM_APBIF_GPIO_ALIVE_PCLK, 1696 "gout_apm_apbif_gpio_alive_pclk", "gout_apm_func", 1697 CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_GPIO_ALIVE_IPCLKPORT_PCLK, 1698 21, 0, 0), 1699 GATE(CLK_GOUT_APM_APBIF_GPIO_FAR_ALIVE_PCLK, 1700 "gout_apm_apbif_gpio_far_alive_pclk", "gout_apm_func", 1701 CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_GPIO_FAR_ALIVE_IPCLKPORT_PCLK, 1702 21, 0, 0), 1703 GATE(CLK_GOUT_APM_APBIF_PMU_ALIVE_PCLK, 1704 "gout_apm_apbif_pmu_alive_pclk", "gout_apm_func", 1705 CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_PMU_ALIVE_IPCLKPORT_PCLK, 1706 21, 0, 0), 1707 GATE(CLK_GOUT_APM_APBIF_RTC_PCLK, 1708 "gout_apm_apbif_rtc_pclk", "gout_apm_func", 1709 CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_RTC_IPCLKPORT_PCLK, 21, 0, 0), 1710 GATE(CLK_GOUT_APM_APBIF_TRTC_PCLK, 1711 "gout_apm_apbif_trtc_pclk", "gout_apm_func", 1712 CLK_CON_GAT_GOUT_BLK_APM_UID_APBIF_TRTC_IPCLKPORT_PCLK, 21, 0, 0), 1713 GATE(CLK_GOUT_APM_APM_USI0_UART_IPCLK, 1714 "gout_apm_apm_usi0_uart_ipclk", "dout_apm_usi0_uart", 1715 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_UART_IPCLKPORT_IPCLK, 1716 21, 0, 0), 1717 GATE(CLK_GOUT_APM_APM_USI0_UART_PCLK, 1718 "gout_apm_apm_usi0_uart_pclk", "gout_apm_func", 1719 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_UART_IPCLKPORT_PCLK, 1720 21, 0, 0), 1721 GATE(CLK_GOUT_APM_APM_USI0_USI_IPCLK, 1722 "gout_apm_apm_usi0_usi_ipclk", "dout_apm_usi0_usi", 1723 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_USI_IPCLKPORT_IPCLK, 1724 21, 0, 0), 1725 GATE(CLK_GOUT_APM_APM_USI0_USI_PCLK, 1726 "gout_apm_apm_usi0_usi_pclk", "gout_apm_func", 1727 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI0_USI_IPCLKPORT_PCLK, 1728 21, 0, 0), 1729 GATE(CLK_GOUT_APM_APM_USI1_UART_IPCLK, 1730 "gout_apm_apm_usi1_uart_ipclk", "dout_apm_usi1_uart", 1731 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI1_UART_IPCLKPORT_IPCLK, 1732 21, 0, 0), 1733 GATE(CLK_GOUT_APM_APM_USI1_UART_PCLK, 1734 "gout_apm_apm_usi1_uart_pclk", "gout_apm_func", 1735 CLK_CON_GAT_GOUT_BLK_APM_UID_APM_USI1_UART_IPCLKPORT_PCLK, 1736 21, 0, 0), 1737 GATE(CLK_GOUT_APM_D_TZPC_APM_PCLK, 1738 "gout_apm_d_tzpc_apm_pclk", "gout_apm_func", 1739 CLK_CON_GAT_GOUT_BLK_APM_UID_D_TZPC_APM_IPCLKPORT_PCLK, 21, 0, 0), 1740 GATE(CLK_GOUT_APM_GPC_APM_PCLK, 1741 "gout_apm_gpc_apm_pclk", "gout_apm_func", 1742 CLK_CON_GAT_GOUT_BLK_APM_UID_GPC_APM_IPCLKPORT_PCLK, 21, 0, 0), 1743 GATE(CLK_GOUT_APM_GREBEINTEGRATION_HCLK, 1744 "gout_apm_grebeintegration_hclk", "gout_apm_func", 1745 CLK_CON_GAT_GOUT_BLK_APM_UID_GREBEINTEGRATION_IPCLKPORT_HCLK, 1746 21, 0, 0), 1747 GATE(CLK_GOUT_APM_INTMEM_ACLK, 1748 "gout_apm_intmem_aclk", "gout_apm_func", 1749 CLK_CON_GAT_GOUT_BLK_APM_UID_INTMEM_IPCLKPORT_ACLK, 21, 0, 0), 1750 GATE(CLK_GOUT_APM_INTMEM_PCLK, 1751 "gout_apm_intmem_pclk", "gout_apm_func", 1752 CLK_CON_GAT_GOUT_BLK_APM_UID_INTMEM_IPCLKPORT_PCLK, 21, 0, 0), 1753 GATE(CLK_GOUT_APM_LHM_AXI_G_SWD_I_CLK, 1754 "gout_apm_lhm_axi_g_swd_i_clk", "gout_apm_func", 1755 CLK_CON_GAT_GOUT_BLK_APM_UID_LHM_AXI_G_SWD_IPCLKPORT_I_CLK, 1756 21, 0, 0), 1757 GATE(CLK_GOUT_APM_LHM_AXI_P_AOCAPM_I_CLK, 1758 "gout_apm_lhm_axi_p_aocapm_i_clk", "gout_apm_func", 1759 CLK_CON_GAT_GOUT_BLK_APM_UID_LHM_AXI_P_AOCAPM_IPCLKPORT_I_CLK, 1760 21, 0, 0), 1761 GATE(CLK_GOUT_APM_LHM_AXI_P_APM_I_CLK, 1762 "gout_apm_lhm_axi_p_apm_i_clk", "gout_apm_func", 1763 CLK_CON_GAT_GOUT_BLK_APM_UID_LHS_AXI_D_APM_IPCLKPORT_I_CLK, 1764 21, 0, 0), 1765 GATE(CLK_GOUT_APM_LHS_AXI_D_APM_I_CLK, 1766 "gout_apm_lhs_axi_d_apm_i_clk", "gout_apm_func", 1767 CLK_CON_GAT_GOUT_BLK_APM_UID_LHS_AXI_D_APM_IPCLKPORT_I_CLK, 1768 21, 0, 0), 1769 GATE(CLK_GOUT_APM_LHS_AXI_G_DBGCORE_I_CLK, 1770 "gout_apm_lhs_axi_g_dbgcore_i_clk", "gout_apm_func", 1771 CLK_CON_GAT_GOUT_BLK_APM_UID_LHS_AXI_G_DBGCORE_IPCLKPORT_I_CLK, 1772 21, 0, 0), 1773 GATE(CLK_GOUT_APM_LHS_AXI_G_SCAN2DRAM_I_CLK, 1774 "gout_apm_lhs_axi_g_scan2dram_i_clk", 1775 "gout_apm_func", 1776 CLK_CON_GAT_GOUT_BLK_APM_UID_LHS_AXI_G_SCAN2DRAM_IPCLKPORT_I_CLK, 1777 21, 0, 0), 1778 GATE(CLK_GOUT_APM_MAILBOX_APM_AOC_PCLK, 1779 "gout_apm_mailbox_apm_aoc_pclk", "gout_apm_func", 1780 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_AOC_IPCLKPORT_PCLK, 1781 21, 0, 0), 1782 GATE(CLK_GOUT_APM_MAILBOX_APM_AP_PCLK, 1783 "gout_apm_mailbox_apm_ap_pclk", "gout_apm_func", 1784 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_AP_IPCLKPORT_PCLK, 1785 21, 0, 0), 1786 GATE(CLK_GOUT_APM_MAILBOX_APM_GSA_PCLK, 1787 "gout_apm_mailbox_apm_gsa_pclk", "gout_apm_func", 1788 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_GSA_IPCLKPORT_PCLK, 1789 21, 0, 0), 1790 GATE(CLK_GOUT_APM_MAILBOX_APM_SWD_PCLK, 1791 "gout_apm_mailbox_apm_swd_pclk", "gout_apm_func", 1792 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_SWD_IPCLKPORT_PCLK, 1793 21, 0, 0), 1794 GATE(CLK_GOUT_APM_MAILBOX_APM_TPU_PCLK, 1795 "gout_apm_mailbox_apm_tpu_pclk", "gout_apm_func", 1796 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_APM_TPU_IPCLKPORT_PCLK, 1797 21, 0, 0), 1798 GATE(CLK_GOUT_APM_MAILBOX_AP_AOC_PCLK, 1799 "gout_apm_mailbox_ap_aoc_pclk", "gout_apm_func", 1800 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_AP_AOC_IPCLKPORT_PCLK, 1801 21, 0, 0), 1802 GATE(CLK_GOUT_APM_MAILBOX_AP_DBGCORE_PCLK, 1803 "gout_apm_mailbox_ap_dbgcore_pclk", "gout_apm_func", 1804 CLK_CON_GAT_GOUT_BLK_APM_UID_MAILBOX_AP_DBGCORE_IPCLKPORT_PCLK, 1805 21, 0, 0), 1806 GATE(CLK_GOUT_APM_PMU_INTR_GEN_PCLK, 1807 "gout_apm_pmu_intr_gen_pclk", "gout_apm_func", 1808 CLK_CON_GAT_GOUT_BLK_APM_UID_PMU_INTR_GEN_IPCLKPORT_PCLK, 1809 21, 0, 0), 1810 GATE(CLK_GOUT_APM_ROM_CRC32_HOST_ACLK, 1811 "gout_apm_rom_crc32_host_aclk", "gout_apm_func", 1812 CLK_CON_GAT_GOUT_BLK_APM_UID_ROM_CRC32_HOST_IPCLKPORT_ACLK, 1813 21, 0, 0), 1814 GATE(CLK_GOUT_APM_ROM_CRC32_HOST_PCLK, 1815 "gout_apm_rom_crc32_host_pclk", "gout_apm_func", 1816 CLK_CON_GAT_GOUT_BLK_APM_UID_ROM_CRC32_HOST_IPCLKPORT_PCLK, 1817 21, 0, 0), 1818 GATE(CLK_GOUT_APM_CLK_APM_BUS_CLK, 1819 "gout_apm_clk_apm_bus_clk", "gout_apm_func", 1820 CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_BUS_IPCLKPORT_CLK, 1821 21, 0, 0), 1822 GATE(CLK_GOUT_APM_CLK_APM_USI0_UART_CLK, 1823 "gout_apm_clk_apm_usi0_uart_clk", 1824 "dout_apm_usi0_uart", 1825 CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_USI0_UART_IPCLKPORT_CLK, 1826 21, 0, 0), 1827 GATE(CLK_GOUT_APM_CLK_APM_USI0_USI_CLK, 1828 "gout_apm_clk_apm_usi0_usi_clk", 1829 "dout_apm_usi0_usi", 1830 CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_USI0_UART_IPCLKPORT_CLK, 1831 21, 0, 0), 1832 GATE(CLK_GOUT_APM_CLK_APM_USI1_UART_CLK, 1833 "gout_apm_clk_apm_usi1_uart_clk", 1834 "dout_apm_usi1_uart", 1835 CLK_CON_GAT_GOUT_BLK_APM_UID_RSTNSYNC_CLK_APM_USI1_UART_IPCLKPORT_CLK, 1836 21, 0, 0), 1837 GATE(CLK_GOUT_APM_SPEEDY_APM_PCLK, 1838 "gout_apm_speedy_apm_pclk", "gout_apm_func", 1839 CLK_CON_GAT_GOUT_BLK_APM_UID_SPEEDY_APM_IPCLKPORT_PCLK, 21, 0, 0), 1840 GATE(CLK_GOUT_APM_SPEEDY_SUB_APM_PCLK, 1841 "gout_apm_speedy_sub_apm_pclk", "gout_apm_func", 1842 CLK_CON_GAT_GOUT_BLK_APM_UID_SPEEDY_SUB_APM_IPCLKPORT_PCLK, 1843 21, 0, 0), 1844 GATE(CLK_GOUT_APM_SSMT_D_APM_ACLK, 1845 "gout_apm_ssmt_d_apm_aclk", "gout_apm_func", 1846 CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_D_APM_IPCLKPORT_ACLK, 21, 0, 0), 1847 GATE(CLK_GOUT_APM_SSMT_D_APM_PCLK, 1848 "gout_apm_ssmt_d_apm_pclk", "gout_apm_func", 1849 CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_D_APM_IPCLKPORT_PCLK, 21, 0, 0), 1850 GATE(CLK_GOUT_APM_SSMT_G_DBGCORE_ACLK, 1851 "gout_apm_ssmt_g_dbgcore_aclk", "gout_apm_func", 1852 CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_G_DBGCORE_IPCLKPORT_ACLK, 1853 21, 0, 0), 1854 GATE(CLK_GOUT_APM_SSMT_G_DBGCORE_PCLK, 1855 "gout_apm_ssmt_g_dbgcore_pclk", "gout_apm_func", 1856 CLK_CON_GAT_GOUT_BLK_APM_UID_SSMT_G_DBGCORE_IPCLKPORT_PCLK, 1857 21, 0, 0), 1858 GATE(CLK_GOUT_APM_SS_DBGCORE_SS_DBGCORE_HCLK, 1859 "gout_apm_ss_dbgcore_ss_dbgcore_hclk", 1860 "gout_apm_func", 1861 CLK_CON_GAT_GOUT_BLK_APM_UID_SS_DBGCORE_IPCLKPORT_SS_DBGCORE_IPCLKPORT_HCLK, 1862 21, 0, 0), 1863 GATE(CLK_GOUT_APM_SYSMMU_D_APM_CLK_S2, 1864 "gout_apm_sysmmu_d_dpm_clk_s2", "gout_apm_func", 1865 CLK_CON_GAT_GOUT_BLK_APM_UID_SYSMMU_D_APM_IPCLKPORT_CLK_S2, 1866 21, 0, 0), 1867 GATE(CLK_GOUT_APM_SYSREG_APM_PCLK, 1868 "gout_apm_sysreg_apm_pclk", "gout_apm_func", 1869 CLK_CON_GAT_GOUT_BLK_APM_UID_SYSREG_APM_IPCLKPORT_PCLK, 21, 0, 0), 1870 GATE(CLK_GOUT_APM_UASC_APM_ACLK, 1871 "gout_apm_uasc_apm_aclk", "gout_apm_func", 1872 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_APM_IPCLKPORT_ACLK, 21, 0, 0), 1873 GATE(CLK_GOUT_APM_UASC_APM_PCLK, 1874 "gout_apm_uasc_apm_pclk", "gout_apm_func", 1875 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_APM_IPCLKPORT_PCLK, 21, 0, 0), 1876 GATE(CLK_GOUT_APM_UASC_DBGCORE_ACLK, 1877 "gout_apm_uasc_dbgcore_aclk", "gout_apm_func", 1878 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_DBGCORE_IPCLKPORT_ACLK, 1879 21, 0, 0), 1880 GATE(CLK_GOUT_APM_UASC_DBGCORE_PCLK, 1881 "gout_apm_uasc_dbgcore_pclk", "gout_apm_func", 1882 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_DBGCORE_IPCLKPORT_PCLK, 1883 21, 0, 0), 1884 GATE(CLK_GOUT_APM_UASC_G_SWD_ACLK, 1885 "gout_apm_uasc_g_swd_aclk", "gout_apm_func", 1886 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_G_SWD_IPCLKPORT_ACLK, 21, 0, 0), 1887 GATE(CLK_GOUT_APM_UASC_G_SWD_PCLK, 1888 "gout_apm_uasc_g_swd_pclk", "gout_apm_func", 1889 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_G_SWD_IPCLKPORT_PCLK, 21, 0, 0), 1890 GATE(CLK_GOUT_APM_UASC_P_AOCAPM_ACLK, 1891 "gout_apm_uasc_p_aocapm_aclk", "gout_apm_func", 1892 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_AOCAPM_IPCLKPORT_ACLK, 1893 21, 0, 0), 1894 GATE(CLK_GOUT_APM_UASC_P_AOCAPM_PCLK, 1895 "gout_apm_uasc_p_aocapm_pclk", "gout_apm_func", 1896 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_G_SWD_IPCLKPORT_PCLK, 21, 0, 0), 1897 GATE(CLK_GOUT_APM_UASC_P_APM_ACLK, 1898 "gout_apm_uasc_p_apm_aclk", "gout_apm_func", 1899 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_APM_IPCLKPORT_ACLK, 21, CLK_IS_CRITICAL, 0), 1900 GATE(CLK_GOUT_APM_UASC_P_APM_PCLK, 1901 "gout_apm_uasc_p_apm_pclk", "gout_apm_func", 1902 CLK_CON_GAT_GOUT_BLK_APM_UID_UASC_P_APM_IPCLKPORT_PCLK, 21, CLK_IS_CRITICAL, 0), 1903 GATE(CLK_GOUT_APM_WDT_APM_PCLK, 1904 "gout_apm_wdt_apm_pclk", "gout_apm_func", 1905 CLK_CON_GAT_GOUT_BLK_APM_UID_WDT_APM_IPCLKPORT_PCLK, 21, 0, 0), 1906 GATE(CLK_GOUT_APM_XIU_DP_APM_ACLK, 1907 "gout_apm_xiu_dp_apm_aclk", "gout_apm_func", 1908 CLK_CON_GAT_GOUT_BLK_APM_UID_XIU_DP_APM_IPCLKPORT_ACLK, 21, CLK_IS_CRITICAL, 0), 1909 }; 1910 1911 static const struct samsung_cmu_info apm_cmu_info __initconst = { 1912 .mux_clks = apm_mux_clks, 1913 .nr_mux_clks = ARRAY_SIZE(apm_mux_clks), 1914 .div_clks = apm_div_clks, 1915 .nr_div_clks = ARRAY_SIZE(apm_div_clks), 1916 .gate_clks = apm_gate_clks, 1917 .nr_gate_clks = ARRAY_SIZE(apm_gate_clks), 1918 .fixed_clks = apm_fixed_clks, 1919 .nr_fixed_clks = ARRAY_SIZE(apm_fixed_clks), 1920 .nr_clk_ids = CLKS_NR_APM, 1921 .clk_regs = apm_clk_regs, 1922 .nr_clk_regs = ARRAY_SIZE(apm_clk_regs), 1923 }; 1924 1925 /* ---- CMU_HSI0 ------------------------------------------------------------ */ 1926 1927 /* Register Offset definitions for CMU_HSI0 (0x11000000) */ 1928 #define PLL_LOCKTIME_PLL_USB 0x0004 1929 #define PLL_CON0_PLL_USB 0x0140 1930 #define PLL_CON1_PLL_USB 0x0144 1931 #define PLL_CON2_PLL_USB 0x0148 1932 #define PLL_CON3_PLL_USB 0x014c 1933 #define PLL_CON4_PLL_USB 0x0150 1934 #define PLL_CON0_MUX_CLKCMU_HSI0_ALT_USER 0x0600 1935 #define PLL_CON1_MUX_CLKCMU_HSI0_ALT_USER 0x0604 1936 #define PLL_CON0_MUX_CLKCMU_HSI0_BUS_USER 0x0610 1937 #define PLL_CON1_MUX_CLKCMU_HSI0_BUS_USER 0x0614 1938 #define PLL_CON0_MUX_CLKCMU_HSI0_DPGTC_USER 0x0620 1939 #define PLL_CON1_MUX_CLKCMU_HSI0_DPGTC_USER 0x0624 1940 #define PLL_CON0_MUX_CLKCMU_HSI0_TCXO_USER 0x0630 1941 #define PLL_CON1_MUX_CLKCMU_HSI0_TCXO_USER 0x0634 1942 #define PLL_CON0_MUX_CLKCMU_HSI0_USB20_USER 0x0640 1943 #define PLL_CON1_MUX_CLKCMU_HSI0_USB20_USER 0x0644 1944 #define PLL_CON0_MUX_CLKCMU_HSI0_USB31DRD_USER 0x0650 1945 #define PLL_CON1_MUX_CLKCMU_HSI0_USB31DRD_USER 0x0654 1946 #define PLL_CON0_MUX_CLKCMU_HSI0_USPDPDBG_USER 0x0660 1947 #define PLL_CON1_MUX_CLKCMU_HSI0_USPDPDBG_USER 0x0664 1948 #define HSI0_CMU_HSI0_CONTROLLER_OPTION 0x0800 1949 #define CLKOUT_CON_BLK_HSI0_CMU_HSI0_CLKOUT0 0x0810 1950 #define CLK_CON_MUX_MUX_CLK_HSI0_BUS 0x1000 1951 #define CLK_CON_MUX_MUX_CLK_HSI0_USB20_REF 0x1004 1952 #define CLK_CON_MUX_MUX_CLK_HSI0_USB31DRD 0x1008 1953 #define CLK_CON_DIV_DIV_CLK_HSI0_USB31DRD 0x1800 1954 #define CLK_CON_GAT_CLK_BLK_HSI0_UID_HSI0_CMU_HSI0_IPCLKPORT_PCLK 0x2000 1955 #define CLK_CON_GAT_CLK_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USB31DRD_SUSPEND_CLK_26 0x2004 1956 #define CLK_CON_GAT_CLK_HSI0_ALT 0x2008 1957 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_DP_GTC_CLK 0x200c 1958 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_PCLK 0x2010 1959 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_D_TZPC_HSI0_IPCLKPORT_PCLK 0x2014 1960 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_ETR_MIU_IPCLKPORT_I_ACLK 0x2018 1961 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_ETR_MIU_IPCLKPORT_I_PCLK 0x201c 1962 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_GPC_HSI0_IPCLKPORT_PCLK 0x2020 1963 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHM_AXI_G_ETR_HSI0_IPCLKPORT_I_CLK 0x2024 1964 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHM_AXI_P_AOCHSI0_IPCLKPORT_I_CLK 0x2028 1965 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHM_AXI_P_HSI0_IPCLKPORT_I_CLK 0x202c 1966 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHS_ACEL_D_HSI0_IPCLKPORT_I_CLK 0x2030 1967 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHS_AXI_D_HSI0AOC_IPCLKPORT_I_CLK 0x2034 1968 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_AOC_IPCLKPORT_ACLK 0x2038 1969 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_AOC_IPCLKPORT_PCLK 0x203c 1970 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_BUS0_IPCLKPORT_ACLK 0x2040 1971 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_BUS0_IPCLKPORT_PCLK 0x2044 1972 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_RSTNSYNC_CLK_HSI0_BUS_IPCLKPORT_CLK 0x2048 1973 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_SSMT_USB_IPCLKPORT_ACLK 0x204c 1974 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_SSMT_USB_IPCLKPORT_PCLK 0x2050 1975 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_SYSMMU_USB_IPCLKPORT_CLK_S2 0x2054 1976 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_SYSREG_HSI0_IPCLKPORT_PCLK 0x2058 1977 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_CTRL_IPCLKPORT_ACLK 0x205c 1978 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_CTRL_IPCLKPORT_PCLK 0x2060 1979 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_LINK_IPCLKPORT_ACLK 0x2064 1980 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_LINK_IPCLKPORT_PCLK 0x2068 1981 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_ACLK_PHYCTRL 0x206c 1982 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_BUS_CLK_EARLY 0x2070 1983 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USB20_PHY_REFCLK_26 0x2074 1984 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USB31DRD_REF_CLK_40 0x2078 1985 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USBDPPHY_REF_SOC_PLL 0x207c 1986 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USBDPPHY_SCL_APB_PCLK 0x2080 1987 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USBPCS_APB_CLK 0x2084 1988 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_USBDPPHY_I_ACLK 0x2088 1989 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_USBDPPHY_UDBG_I_APB_PCLK 0x208c 1990 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_XIU_D0_HSI0_IPCLKPORT_ACLK 0x2090 1991 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_XIU_D1_HSI0_IPCLKPORT_ACLK 0x2094 1992 #define CLK_CON_GAT_GOUT_BLK_HSI0_UID_XIU_P_HSI0_IPCLKPORT_ACLK 0x2098 1993 #define DMYQCH_CON_USB31DRD_QCH 0x3000 1994 #define DMYQCH_CON_USB31DRD_QCH_REF 0x3004 1995 #define PCH_CON_LHM_AXI_G_ETR_HSI0_PCH 0x3008 1996 #define PCH_CON_LHM_AXI_P_AOCHSI0_PCH 0x300c 1997 #define PCH_CON_LHM_AXI_P_HSI0_PCH 0x3010 1998 #define PCH_CON_LHS_ACEL_D_HSI0_PCH 0x3014 1999 #define PCH_CON_LHS_AXI_D_HSI0AOC_PCH 0x3018 2000 #define QCH_CON_DP_LINK_QCH_GTC_CLK 0x301c 2001 #define QCH_CON_DP_LINK_QCH_PCLK 0x3020 2002 #define QCH_CON_D_TZPC_HSI0_QCH 0x3024 2003 #define QCH_CON_ETR_MIU_QCH_ACLK 0x3028 2004 #define QCH_CON_ETR_MIU_QCH_PCLK 0x302c 2005 #define QCH_CON_GPC_HSI0_QCH 0x3030 2006 #define QCH_CON_HSI0_CMU_HSI0_QCH 0x3034 2007 #define QCH_CON_LHM_AXI_G_ETR_HSI0_QCH 0x3038 2008 #define QCH_CON_LHM_AXI_P_AOCHSI0_QCH 0x303c 2009 #define QCH_CON_LHM_AXI_P_HSI0_QCH 0x3040 2010 #define QCH_CON_LHS_ACEL_D_HSI0_QCH 0x3044 2011 #define QCH_CON_LHS_AXI_D_HSI0AOC_QCH 0x3048 2012 #define QCH_CON_PPMU_HSI0_AOC_QCH 0x304c 2013 #define QCH_CON_PPMU_HSI0_BUS0_QCH 0x3050 2014 #define QCH_CON_SSMT_USB_QCH 0x3054 2015 #define QCH_CON_SYSMMU_USB_QCH 0x3058 2016 #define QCH_CON_SYSREG_HSI0_QCH 0x305c 2017 #define QCH_CON_UASC_HSI0_CTRL_QCH 0x3060 2018 #define QCH_CON_UASC_HSI0_LINK_QCH 0x3064 2019 #define QCH_CON_USB31DRD_QCH_APB 0x3068 2020 #define QCH_CON_USB31DRD_QCH_DBG 0x306c 2021 #define QCH_CON_USB31DRD_QCH_PCS 0x3070 2022 #define QCH_CON_USB31DRD_QCH_SLV_CTRL 0x3074 2023 #define QCH_CON_USB31DRD_QCH_SLV_LINK 0x3078 2024 #define QUEUE_CTRL_REG_BLK_HSI0_CMU_HSI0 0x3c00 2025 2026 static const unsigned long hsi0_clk_regs[] __initconst = { 2027 PLL_LOCKTIME_PLL_USB, 2028 PLL_CON0_PLL_USB, 2029 PLL_CON1_PLL_USB, 2030 PLL_CON2_PLL_USB, 2031 PLL_CON3_PLL_USB, 2032 PLL_CON4_PLL_USB, 2033 PLL_CON0_MUX_CLKCMU_HSI0_ALT_USER, 2034 PLL_CON1_MUX_CLKCMU_HSI0_ALT_USER, 2035 PLL_CON0_MUX_CLKCMU_HSI0_BUS_USER, 2036 PLL_CON1_MUX_CLKCMU_HSI0_BUS_USER, 2037 PLL_CON0_MUX_CLKCMU_HSI0_DPGTC_USER, 2038 PLL_CON1_MUX_CLKCMU_HSI0_DPGTC_USER, 2039 PLL_CON0_MUX_CLKCMU_HSI0_TCXO_USER, 2040 PLL_CON1_MUX_CLKCMU_HSI0_TCXO_USER, 2041 PLL_CON0_MUX_CLKCMU_HSI0_USB20_USER, 2042 PLL_CON1_MUX_CLKCMU_HSI0_USB20_USER, 2043 PLL_CON0_MUX_CLKCMU_HSI0_USB31DRD_USER, 2044 PLL_CON1_MUX_CLKCMU_HSI0_USB31DRD_USER, 2045 PLL_CON0_MUX_CLKCMU_HSI0_USPDPDBG_USER, 2046 PLL_CON1_MUX_CLKCMU_HSI0_USPDPDBG_USER, 2047 HSI0_CMU_HSI0_CONTROLLER_OPTION, 2048 CLKOUT_CON_BLK_HSI0_CMU_HSI0_CLKOUT0, 2049 CLK_CON_MUX_MUX_CLK_HSI0_BUS, 2050 CLK_CON_MUX_MUX_CLK_HSI0_USB20_REF, 2051 CLK_CON_MUX_MUX_CLK_HSI0_USB31DRD, 2052 CLK_CON_DIV_DIV_CLK_HSI0_USB31DRD, 2053 CLK_CON_GAT_CLK_BLK_HSI0_UID_HSI0_CMU_HSI0_IPCLKPORT_PCLK, 2054 CLK_CON_GAT_CLK_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USB31DRD_SUSPEND_CLK_26, 2055 CLK_CON_GAT_CLK_HSI0_ALT, 2056 CLK_CON_GAT_GOUT_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_DP_GTC_CLK, 2057 CLK_CON_GAT_GOUT_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_PCLK, 2058 CLK_CON_GAT_GOUT_BLK_HSI0_UID_D_TZPC_HSI0_IPCLKPORT_PCLK, 2059 CLK_CON_GAT_GOUT_BLK_HSI0_UID_ETR_MIU_IPCLKPORT_I_ACLK, 2060 CLK_CON_GAT_GOUT_BLK_HSI0_UID_ETR_MIU_IPCLKPORT_I_PCLK, 2061 CLK_CON_GAT_GOUT_BLK_HSI0_UID_GPC_HSI0_IPCLKPORT_PCLK, 2062 CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHM_AXI_G_ETR_HSI0_IPCLKPORT_I_CLK, 2063 CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHM_AXI_P_AOCHSI0_IPCLKPORT_I_CLK, 2064 CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHM_AXI_P_HSI0_IPCLKPORT_I_CLK, 2065 CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHS_ACEL_D_HSI0_IPCLKPORT_I_CLK, 2066 CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHS_AXI_D_HSI0AOC_IPCLKPORT_I_CLK, 2067 CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_AOC_IPCLKPORT_ACLK, 2068 CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_AOC_IPCLKPORT_PCLK, 2069 CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_BUS0_IPCLKPORT_ACLK, 2070 CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_BUS0_IPCLKPORT_PCLK, 2071 CLK_CON_GAT_GOUT_BLK_HSI0_UID_RSTNSYNC_CLK_HSI0_BUS_IPCLKPORT_CLK, 2072 CLK_CON_GAT_GOUT_BLK_HSI0_UID_SSMT_USB_IPCLKPORT_ACLK, 2073 CLK_CON_GAT_GOUT_BLK_HSI0_UID_SSMT_USB_IPCLKPORT_PCLK, 2074 CLK_CON_GAT_GOUT_BLK_HSI0_UID_SYSMMU_USB_IPCLKPORT_CLK_S2, 2075 CLK_CON_GAT_GOUT_BLK_HSI0_UID_SYSREG_HSI0_IPCLKPORT_PCLK, 2076 CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_CTRL_IPCLKPORT_ACLK, 2077 CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_CTRL_IPCLKPORT_PCLK, 2078 CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_LINK_IPCLKPORT_ACLK, 2079 CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_LINK_IPCLKPORT_PCLK, 2080 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_ACLK_PHYCTRL, 2081 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_BUS_CLK_EARLY, 2082 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USB20_PHY_REFCLK_26, 2083 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USB31DRD_REF_CLK_40, 2084 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USBDPPHY_REF_SOC_PLL, 2085 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USBDPPHY_SCL_APB_PCLK, 2086 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USBPCS_APB_CLK, 2087 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_USBDPPHY_I_ACLK, 2088 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_USBDPPHY_UDBG_I_APB_PCLK, 2089 CLK_CON_GAT_GOUT_BLK_HSI0_UID_XIU_D0_HSI0_IPCLKPORT_ACLK, 2090 CLK_CON_GAT_GOUT_BLK_HSI0_UID_XIU_D1_HSI0_IPCLKPORT_ACLK, 2091 CLK_CON_GAT_GOUT_BLK_HSI0_UID_XIU_P_HSI0_IPCLKPORT_ACLK, 2092 DMYQCH_CON_USB31DRD_QCH, 2093 DMYQCH_CON_USB31DRD_QCH_REF, 2094 PCH_CON_LHM_AXI_G_ETR_HSI0_PCH, 2095 PCH_CON_LHM_AXI_P_AOCHSI0_PCH, 2096 PCH_CON_LHM_AXI_P_HSI0_PCH, 2097 PCH_CON_LHS_ACEL_D_HSI0_PCH, 2098 PCH_CON_LHS_AXI_D_HSI0AOC_PCH, 2099 QCH_CON_DP_LINK_QCH_GTC_CLK, 2100 QCH_CON_DP_LINK_QCH_PCLK, 2101 QCH_CON_D_TZPC_HSI0_QCH, 2102 QCH_CON_ETR_MIU_QCH_ACLK, 2103 QCH_CON_ETR_MIU_QCH_PCLK, 2104 QCH_CON_GPC_HSI0_QCH, 2105 QCH_CON_HSI0_CMU_HSI0_QCH, 2106 QCH_CON_LHM_AXI_G_ETR_HSI0_QCH, 2107 QCH_CON_LHM_AXI_P_AOCHSI0_QCH, 2108 QCH_CON_LHM_AXI_P_HSI0_QCH, 2109 QCH_CON_LHS_ACEL_D_HSI0_QCH, 2110 QCH_CON_LHS_AXI_D_HSI0AOC_QCH, 2111 QCH_CON_PPMU_HSI0_AOC_QCH, 2112 QCH_CON_PPMU_HSI0_BUS0_QCH, 2113 QCH_CON_SSMT_USB_QCH, 2114 QCH_CON_SYSMMU_USB_QCH, 2115 QCH_CON_SYSREG_HSI0_QCH, 2116 QCH_CON_UASC_HSI0_CTRL_QCH, 2117 QCH_CON_UASC_HSI0_LINK_QCH, 2118 QCH_CON_USB31DRD_QCH_APB, 2119 QCH_CON_USB31DRD_QCH_DBG, 2120 QCH_CON_USB31DRD_QCH_PCS, 2121 QCH_CON_USB31DRD_QCH_SLV_CTRL, 2122 QCH_CON_USB31DRD_QCH_SLV_LINK, 2123 QUEUE_CTRL_REG_BLK_HSI0_CMU_HSI0, 2124 }; 2125 2126 /* List of parent clocks for Muxes in CMU_HSI0 */ 2127 PNAME(mout_pll_usb_p) = { "oscclk", "fout_usb_pll" }; 2128 PNAME(mout_hsi0_alt_user_p) = { "oscclk", 2129 "gout_hsi0_clk_hsi0_alt" }; 2130 PNAME(mout_hsi0_bus_user_p) = { "oscclk", "dout_cmu_hsi0_bus" }; 2131 PNAME(mout_hsi0_dpgtc_user_p) = { "oscclk", "dout_cmu_hsi0_dpgtc" }; 2132 PNAME(mout_hsi0_tcxo_user_p) = { "oscclk", "tcxo_hsi1_hsi0" }; 2133 PNAME(mout_hsi0_usb20_user_p) = { "oscclk", "usb20phy_phy_clock" }; 2134 PNAME(mout_hsi0_usb31drd_user_p) = { "oscclk", 2135 "dout_cmu_hsi0_usb31drd" }; 2136 PNAME(mout_hsi0_usbdpdbg_user_p) = { "oscclk", 2137 "dout_cmu_hsi0_usbdpdbg" }; 2138 PNAME(mout_hsi0_bus_p) = { "mout_hsi0_bus_user", 2139 "mout_hsi0_alt_user" }; 2140 PNAME(mout_hsi0_usb20_ref_p) = { "fout_usb_pll", 2141 "mout_hsi0_tcxo_user" }; 2142 PNAME(mout_hsi0_usb31drd_p) = { "fout_usb_pll", 2143 "mout_hsi0_usb31drd_user", 2144 "dout_hsi0_usb31drd", 2145 "fout_usb_pll" }; 2146 2147 static const struct samsung_pll_rate_table cmu_hsi0_usb_pll_rates[] __initconst = { 2148 PLL_35XX_RATE(24576000, 19200000, 150, 6, 5), 2149 { /* sentinel */ } 2150 }; 2151 2152 static const struct samsung_pll_clock cmu_hsi0_pll_clks[] __initconst = { 2153 PLL(pll_0518x, CLK_FOUT_USB_PLL, "fout_usb_pll", "oscclk", 2154 PLL_LOCKTIME_PLL_USB, PLL_CON3_PLL_USB, 2155 cmu_hsi0_usb_pll_rates), 2156 }; 2157 2158 static const struct samsung_mux_clock hsi0_mux_clks[] __initconst = { 2159 MUX(CLK_MOUT_PLL_USB, 2160 "mout_pll_usb", mout_pll_usb_p, 2161 PLL_CON0_PLL_USB, 4, 1), 2162 MUX(CLK_MOUT_HSI0_ALT_USER, 2163 "mout_hsi0_alt_user", mout_hsi0_alt_user_p, 2164 PLL_CON0_MUX_CLKCMU_HSI0_ALT_USER, 4, 1), 2165 MUX(CLK_MOUT_HSI0_BUS_USER, 2166 "mout_hsi0_bus_user", mout_hsi0_bus_user_p, 2167 PLL_CON0_MUX_CLKCMU_HSI0_BUS_USER, 4, 1), 2168 MUX(CLK_MOUT_HSI0_DPGTC_USER, 2169 "mout_hsi0_dpgtc_user", mout_hsi0_dpgtc_user_p, 2170 PLL_CON0_MUX_CLKCMU_HSI0_DPGTC_USER, 4, 1), 2171 MUX(CLK_MOUT_HSI0_TCXO_USER, 2172 "mout_hsi0_tcxo_user", mout_hsi0_tcxo_user_p, 2173 PLL_CON0_MUX_CLKCMU_HSI0_TCXO_USER, 4, 1), 2174 MUX(CLK_MOUT_HSI0_USB20_USER, 2175 "mout_hsi0_usb20_user", mout_hsi0_usb20_user_p, 2176 PLL_CON0_MUX_CLKCMU_HSI0_USB20_USER, 4, 1), 2177 MUX(CLK_MOUT_HSI0_USB31DRD_USER, 2178 "mout_hsi0_usb31drd_user", mout_hsi0_usb31drd_user_p, 2179 PLL_CON0_MUX_CLKCMU_HSI0_USB31DRD_USER, 4, 1), 2180 MUX(CLK_MOUT_HSI0_USBDPDBG_USER, 2181 "mout_hsi0_usbdpdbg_user", mout_hsi0_usbdpdbg_user_p, 2182 PLL_CON0_MUX_CLKCMU_HSI0_USPDPDBG_USER, 4, 1), 2183 MUX(CLK_MOUT_HSI0_BUS, 2184 "mout_hsi0_bus", mout_hsi0_bus_p, 2185 CLK_CON_MUX_MUX_CLK_HSI0_BUS, 0, 1), 2186 MUX(CLK_MOUT_HSI0_USB20_REF, 2187 "mout_hsi0_usb20_ref", mout_hsi0_usb20_ref_p, 2188 CLK_CON_MUX_MUX_CLK_HSI0_USB20_REF, 0, 1), 2189 MUX(CLK_MOUT_HSI0_USB31DRD, 2190 "mout_hsi0_usb31drd", mout_hsi0_usb31drd_p, 2191 CLK_CON_MUX_MUX_CLK_HSI0_USB31DRD, 0, 2), 2192 }; 2193 2194 static const struct samsung_div_clock hsi0_div_clks[] __initconst = { 2195 DIV(CLK_DOUT_HSI0_USB31DRD, 2196 "dout_hsi0_usb31drd", "mout_hsi0_usb20_user", 2197 CLK_CON_DIV_DIV_CLK_HSI0_USB31DRD, 0, 3), 2198 }; 2199 2200 static const struct samsung_gate_clock hsi0_gate_clks[] __initconst = { 2201 /* TODO: should have a driver for this */ 2202 GATE(CLK_GOUT_HSI0_PCLK, 2203 "gout_hsi0_hsi0_pclk", "mout_hsi0_bus", 2204 CLK_CON_GAT_CLK_BLK_HSI0_UID_HSI0_CMU_HSI0_IPCLKPORT_PCLK, 2205 21, CLK_IGNORE_UNUSED, 0), 2206 GATE(CLK_GOUT_HSI0_USB31DRD_I_USB31DRD_SUSPEND_CLK_26, 2207 "gout_hsi0_usb31drd_i_usb31drd_suspend_clk_26", 2208 "mout_hsi0_usb20_ref", 2209 CLK_CON_GAT_CLK_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USB31DRD_SUSPEND_CLK_26, 2210 21, 0, 0), 2211 GATE(CLK_GOUT_HSI0_CLK_HSI0_ALT, 2212 "gout_hsi0_clk_hsi0_alt", "ioclk_clk_hsi0_alt", 2213 CLK_CON_GAT_CLK_HSI0_ALT, 21, 0, 0), 2214 GATE(CLK_GOUT_HSI0_DP_LINK_I_DP_GTC_CLK, 2215 "gout_hsi0_dp_link_i_dp_gtc_clk", "mout_hsi0_dpgtc_user", 2216 CLK_CON_GAT_GOUT_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_DP_GTC_CLK, 2217 21, 0, 0), 2218 GATE(CLK_GOUT_HSI0_DP_LINK_I_PCLK, 2219 "gout_hsi0_dp_link_i_pclk", "mout_hsi0_bus", 2220 CLK_CON_GAT_GOUT_BLK_HSI0_UID_DP_LINK_IPCLKPORT_I_PCLK, 21, 0, 0), 2221 GATE(CLK_GOUT_HSI0_D_TZPC_HSI0_PCLK, 2222 "gout_hsi0_d_tzpc_hsi0_pclk", "mout_hsi0_bus", 2223 CLK_CON_GAT_GOUT_BLK_HSI0_UID_D_TZPC_HSI0_IPCLKPORT_PCLK, 2224 21, 0, 0), 2225 GATE(CLK_GOUT_HSI0_ETR_MIU_I_ACLK, 2226 "gout_hsi0_etr_miu_i_aclk", "mout_hsi0_bus", 2227 CLK_CON_GAT_GOUT_BLK_HSI0_UID_ETR_MIU_IPCLKPORT_I_ACLK, 21, 0, 0), 2228 GATE(CLK_GOUT_HSI0_ETR_MIU_I_PCLK, 2229 "gout_hsi0_etr_miu_i_pclk", "mout_hsi0_bus", 2230 CLK_CON_GAT_GOUT_BLK_HSI0_UID_ETR_MIU_IPCLKPORT_I_PCLK, 21, 0, 0), 2231 GATE(CLK_GOUT_HSI0_GPC_HSI0_PCLK, 2232 "gout_hsi0_gpc_hsi0_pclk", "mout_hsi0_bus", 2233 CLK_CON_GAT_GOUT_BLK_HSI0_UID_GPC_HSI0_IPCLKPORT_PCLK, 21, 0, 0), 2234 GATE(CLK_GOUT_HSI0_LHM_AXI_G_ETR_HSI0_I_CLK, 2235 "gout_hsi0_lhm_axi_g_etr_hsi0_i_clk", "mout_hsi0_bus", 2236 CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHM_AXI_G_ETR_HSI0_IPCLKPORT_I_CLK, 2237 21, 0, 0), 2238 GATE(CLK_GOUT_HSI0_LHM_AXI_P_AOCHSI0_I_CLK, 2239 "gout_hsi0_lhm_axi_p_aochsi0_i_clk", "mout_hsi0_bus", 2240 CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHM_AXI_P_AOCHSI0_IPCLKPORT_I_CLK, 2241 21, 0, 0), 2242 /* TODO: should have a driver for this */ 2243 GATE(CLK_GOUT_HSI0_LHM_AXI_P_HSI0_I_CLK, 2244 "gout_hsi0_lhm_axi_p_hsi0_i_clk", "mout_hsi0_bus", 2245 CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHM_AXI_P_HSI0_IPCLKPORT_I_CLK, 2246 21, CLK_IGNORE_UNUSED, 0), 2247 /* TODO: should have a driver for this */ 2248 GATE(CLK_GOUT_HSI0_LHS_ACEL_D_HSI0_I_CLK, 2249 "gout_hsi0_lhs_acel_d_hsi0_i_clk", "mout_hsi0_bus", 2250 CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHS_ACEL_D_HSI0_IPCLKPORT_I_CLK, 2251 21, CLK_IGNORE_UNUSED, 0), 2252 GATE(CLK_GOUT_HSI0_LHS_AXI_D_HSI0AOC_I_CLK, 2253 "gout_hsi0_lhs_axi_d_hsi0aoc_i_clk", "mout_hsi0_bus", 2254 CLK_CON_GAT_GOUT_BLK_HSI0_UID_LHS_AXI_D_HSI0AOC_IPCLKPORT_I_CLK, 2255 21, 0, 0), 2256 GATE(CLK_GOUT_HSI0_PPMU_HSI0_AOC_ACLK, 2257 "gout_hsi0_ppmu_hsi0_aoc_aclk", "mout_hsi0_bus", 2258 CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_AOC_IPCLKPORT_ACLK, 2259 21, 0, 0), 2260 GATE(CLK_GOUT_HSI0_PPMU_HSI0_AOC_PCLK, 2261 "gout_hsi0_ppmu_hsi0_aoc_pclk", "mout_hsi0_bus", 2262 CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_AOC_IPCLKPORT_PCLK, 2263 21, 0, 0), 2264 GATE(CLK_GOUT_HSI0_PPMU_HSI0_BUS0_ACLK, 2265 "gout_hsi0_ppmu_hsi0_bus0_aclk", "mout_hsi0_bus", 2266 CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_BUS0_IPCLKPORT_ACLK, 2267 21, 0, 0), 2268 GATE(CLK_GOUT_HSI0_PPMU_HSI0_BUS0_PCLK, 2269 "gout_hsi0_ppmu_hsi0_bus0_pclk", "mout_hsi0_bus", 2270 CLK_CON_GAT_GOUT_BLK_HSI0_UID_PPMU_HSI0_BUS0_IPCLKPORT_PCLK, 2271 21, 0, 0), 2272 GATE(CLK_GOUT_HSI0_CLK_HSI0_BUS_CLK, 2273 "gout_hsi0_clk_hsi0_bus_clk", "mout_hsi0_bus", 2274 CLK_CON_GAT_GOUT_BLK_HSI0_UID_RSTNSYNC_CLK_HSI0_BUS_IPCLKPORT_CLK, 2275 21, 0, 0), 2276 /* TODO: should have a driver for this */ 2277 GATE(CLK_GOUT_HSI0_SSMT_USB_ACLK, 2278 "gout_hsi0_ssmt_usb_aclk", "mout_hsi0_bus", 2279 CLK_CON_GAT_GOUT_BLK_HSI0_UID_SSMT_USB_IPCLKPORT_ACLK, 2280 21, CLK_IGNORE_UNUSED, 0), 2281 /* TODO: should have a driver for this */ 2282 GATE(CLK_GOUT_HSI0_SSMT_USB_PCLK, 2283 "gout_hsi0_ssmt_usb_pclk", "mout_hsi0_bus", 2284 CLK_CON_GAT_GOUT_BLK_HSI0_UID_SSMT_USB_IPCLKPORT_PCLK, 2285 21, CLK_IGNORE_UNUSED, 0), 2286 /* TODO: should have a driver for this */ 2287 GATE(CLK_GOUT_HSI0_SYSMMU_USB_CLK_S2, 2288 "gout_hsi0_sysmmu_usb_clk_s2", "mout_hsi0_bus", 2289 CLK_CON_GAT_GOUT_BLK_HSI0_UID_SYSMMU_USB_IPCLKPORT_CLK_S2, 2290 21, CLK_IGNORE_UNUSED, 0), 2291 GATE(CLK_GOUT_HSI0_SYSREG_HSI0_PCLK, 2292 "gout_hsi0_sysreg_hsi0_pclk", "mout_hsi0_bus", 2293 CLK_CON_GAT_GOUT_BLK_HSI0_UID_SYSREG_HSI0_IPCLKPORT_PCLK, 2294 21, 0, 0), 2295 GATE(CLK_GOUT_HSI0_UASC_HSI0_CTRL_ACLK, 2296 "gout_hsi0_uasc_hsi0_ctrl_aclk", "mout_hsi0_bus", 2297 CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_CTRL_IPCLKPORT_ACLK, 2298 21, 0, 0), 2299 GATE(CLK_GOUT_HSI0_UASC_HSI0_CTRL_PCLK, 2300 "gout_hsi0_uasc_hsi0_ctrl_pclk", "mout_hsi0_bus", 2301 CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_CTRL_IPCLKPORT_PCLK, 2302 21, 0, 0), 2303 GATE(CLK_GOUT_HSI0_UASC_HSI0_LINK_ACLK, 2304 "gout_hsi0_uasc_hsi0_link_aclk", "mout_hsi0_bus", 2305 CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_LINK_IPCLKPORT_ACLK, 2306 21, 0, 0), 2307 GATE(CLK_GOUT_HSI0_UASC_HSI0_LINK_PCLK, 2308 "gout_hsi0_uasc_hsi0_link_pclk", "mout_hsi0_bus", 2309 CLK_CON_GAT_GOUT_BLK_HSI0_UID_UASC_HSI0_LINK_IPCLKPORT_PCLK, 2310 21, 0, 0), 2311 GATE(CLK_GOUT_HSI0_USB31DRD_ACLK_PHYCTRL, 2312 "gout_hsi0_usb31drd_aclk_phyctrl", "mout_hsi0_bus", 2313 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_ACLK_PHYCTRL, 2314 21, 0, 0), 2315 GATE(CLK_GOUT_HSI0_USB31DRD_BUS_CLK_EARLY, 2316 "gout_hsi0_usb31drd_bus_clk_early", "mout_hsi0_bus", 2317 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_BUS_CLK_EARLY, 2318 21, 0, 0), 2319 GATE(CLK_GOUT_HSI0_USB31DRD_I_USB20_PHY_REFCLK_26, 2320 "gout_hsi0_usb31drd_i_usb20_phy_refclk_26", "mout_hsi0_usb20_ref", 2321 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USB20_PHY_REFCLK_26, 2322 21, 0, 0), 2323 GATE(CLK_GOUT_HSI0_USB31DRD_I_USB31DRD_REF_CLK_40, 2324 "gout_hsi0_usb31drd_i_usb31drd_ref_clk_40", "mout_hsi0_usb31drd", 2325 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USB31DRD_REF_CLK_40, 2326 21, 0, 0), 2327 GATE(CLK_GOUT_HSI0_USB31DRD_I_USBDPPHY_REF_SOC_PLL, 2328 "gout_hsi0_usb31drd_i_usbdpphy_ref_soc_pll", 2329 "mout_hsi0_usbdpdbg_user", 2330 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USBDPPHY_REF_SOC_PLL, 2331 21, 0, 0), 2332 GATE(CLK_GOUT_HSI0_USB31DRD_I_USBDPPHY_SCL_APB_PCLK, 2333 "gout_hsi0_usb31drd_i_usbdpphy_scl_apb_pclk", "mout_hsi0_bus", 2334 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USBDPPHY_SCL_APB_PCLK, 2335 21, 0, 0), 2336 GATE(CLK_GOUT_HSI0_USB31DRD_I_USBPCS_APB_CLK, 2337 "gout_hsi0_usb31drd_i_usbpcs_apb_clk", "mout_hsi0_bus", 2338 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_I_USBPCS_APB_CLK, 2339 21, 0, 0), 2340 GATE(CLK_GOUT_HSI0_USB31DRD_USBDPPHY_I_ACLK, 2341 "gout_hsi0_usb31drd_usbdpphy_i_aclk", "mout_hsi0_bus", 2342 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_USBDPPHY_I_ACLK, 2343 21, 0, 0), 2344 GATE(CLK_GOUT_HSI0_USB31DRD_USBDPPHY_UDBG_I_APB_PCLK, 2345 "gout_hsi0_usb31drd_usbdpphy_udbg_i_apb_pclk", "mout_hsi0_bus", 2346 CLK_CON_GAT_GOUT_BLK_HSI0_UID_USB31DRD_IPCLKPORT_USBDPPHY_UDBG_I_APB_PCLK, 2347 21, 0, 0), 2348 /* TODO: should have a driver for this */ 2349 GATE(CLK_GOUT_HSI0_XIU_D0_HSI0_ACLK, 2350 "gout_hsi0_xiu_d0_hsi0_aclk", "mout_hsi0_bus", 2351 CLK_CON_GAT_GOUT_BLK_HSI0_UID_XIU_D0_HSI0_IPCLKPORT_ACLK, 2352 21, CLK_IGNORE_UNUSED, 0), 2353 /* TODO: should have a driver for this */ 2354 GATE(CLK_GOUT_HSI0_XIU_D1_HSI0_ACLK, 2355 "gout_hsi0_xiu_d1_hsi0_aclk", "mout_hsi0_bus", 2356 CLK_CON_GAT_GOUT_BLK_HSI0_UID_XIU_D1_HSI0_IPCLKPORT_ACLK, 2357 21, CLK_IGNORE_UNUSED, 0), 2358 /* TODO: should have a driver for this */ 2359 GATE(CLK_GOUT_HSI0_XIU_P_HSI0_ACLK, 2360 "gout_hsi0_xiu_p_hsi0_aclk", "mout_hsi0_bus", 2361 CLK_CON_GAT_GOUT_BLK_HSI0_UID_XIU_P_HSI0_IPCLKPORT_ACLK, 2362 21, CLK_IGNORE_UNUSED, 0), 2363 }; 2364 2365 static const struct samsung_fixed_rate_clock hsi0_fixed_clks[] __initconst = { 2366 FRATE(0, "tcxo_hsi1_hsi0", NULL, 0, 26000000), 2367 FRATE(0, "usb20phy_phy_clock", NULL, 0, 120000000), 2368 /* until we implement APMGSA */ 2369 FRATE(0, "ioclk_clk_hsi0_alt", NULL, 0, 213000000), 2370 }; 2371 2372 static const struct samsung_cmu_info hsi0_cmu_info __initconst = { 2373 .pll_clks = cmu_hsi0_pll_clks, 2374 .nr_pll_clks = ARRAY_SIZE(cmu_hsi0_pll_clks), 2375 .mux_clks = hsi0_mux_clks, 2376 .nr_mux_clks = ARRAY_SIZE(hsi0_mux_clks), 2377 .div_clks = hsi0_div_clks, 2378 .nr_div_clks = ARRAY_SIZE(hsi0_div_clks), 2379 .gate_clks = hsi0_gate_clks, 2380 .nr_gate_clks = ARRAY_SIZE(hsi0_gate_clks), 2381 .fixed_clks = hsi0_fixed_clks, 2382 .nr_fixed_clks = ARRAY_SIZE(hsi0_fixed_clks), 2383 .nr_clk_ids = CLKS_NR_HSI0, 2384 .clk_regs = hsi0_clk_regs, 2385 .nr_clk_regs = ARRAY_SIZE(hsi0_clk_regs), 2386 .clk_name = "bus", 2387 }; 2388 2389 /* ---- CMU_HSI2 ------------------------------------------------------------ */ 2390 2391 /* Register Offset definitions for CMU_HSI2 (0x14400000) */ 2392 #define PLL_CON0_MUX_CLKCMU_HSI2_BUS_USER 0x0600 2393 #define PLL_CON1_MUX_CLKCMU_HSI2_BUS_USER 0x0604 2394 #define PLL_CON0_MUX_CLKCMU_HSI2_MMC_CARD_USER 0x0610 2395 #define PLL_CON1_MUX_CLKCMU_HSI2_MMC_CARD_USER 0x0614 2396 #define PLL_CON0_MUX_CLKCMU_HSI2_PCIE_USER 0x0620 2397 #define PLL_CON1_MUX_CLKCMU_HSI2_PCIE_USER 0x0624 2398 #define PLL_CON0_MUX_CLKCMU_HSI2_UFS_EMBD_USER 0x0630 2399 #define PLL_CON1_MUX_CLKCMU_HSI2_UFS_EMBD_USER 0x0634 2400 #define HSI2_CMU_HSI2_CONTROLLER_OPTION 0x0800 2401 #define CLKOUT_CON_BLK_HSI2_CMU_HSI2_CLKOUT0 0x0810 2402 #define CLK_CON_GAT_CLK_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_PCIE_SUB_CTRL_INST_0_PHY_REFCLK_IN 0x2000 2403 #define CLK_CON_GAT_CLK_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_PCIE_SUB_CTRL_INST_0_PHY_REFCLK_IN 0x2004 2404 #define CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4A_1_IPCLKPORT_ACLK 0x2008 2405 #define CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4A_1_IPCLKPORT_PCLK 0x200c 2406 #define CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4B_1_IPCLKPORT_ACLK 0x2010 2407 #define CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4B_1_IPCLKPORT_PCLK 0x2014 2408 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_D_TZPC_HSI2_IPCLKPORT_PCLK 0x201c 2409 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_GPC_HSI2_IPCLKPORT_PCLK 0x2020 2410 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_GPIO_HSI2_IPCLKPORT_PCLK 0x2024 2411 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_HSI2_CMU_HSI2_IPCLKPORT_PCLK 0x2028 2412 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_LHM_AXI_P_HSI2_IPCLKPORT_I_CLK 0x202c 2413 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_LHS_ACEL_D_HSI2_IPCLKPORT_I_CLK 0x2030 2414 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_MMC_CARD_IPCLKPORT_I_ACLK 0x2034 2415 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_MMC_CARD_IPCLKPORT_SDCLKIN 0x2038 2416 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_G4X2_DWC_PCIE_CTL_INST_0_DBI_ACLK_UG 0x203c 2417 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_G4X2_DWC_PCIE_CTL_INST_0_MSTR_ACLK_UG 0x2040 2418 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_G4X2_DWC_PCIE_CTL_INST_0_SLV_ACLK_UG 0x2044 2419 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_PCIE_SUB_CTRL_INST_0_I_DRIVER_APB_CLK 0x2048 2420 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_G4X1_DWC_PCIE_CTL_INST_0_DBI_ACLK_UG 0x204c 2421 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_G4X1_DWC_PCIE_CTL_INST_0_MSTR_ACLK_UG 0x2050 2422 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_G4X1_DWC_PCIE_CTL_INST_0_SLV_ACLK_UG 0x2054 2423 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_PCIE_SUB_CTRL_INST_0_I_DRIVER_APB_CLK 0x2058 2424 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCS_PMA_INST_0_PHY_UDBG_I_APB_PCLK 0x205c 2425 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCS_PMA_INST_0_PIPE_PAL_PCIE_INST_0_I_APB_PCLK 0x2060 2426 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCS_PMA_INST_0_SF_PCIEPHY210X2_LN05LPE_QCH_TM_WRAPPER_INST_0_I_APB_PCLK 0x2064 2427 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_IA_GEN4A_1_IPCLKPORT_I_CLK 0x2068 2428 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_IA_GEN4B_1_IPCLKPORT_I_CLK 0x206c 2429 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PPMU_HSI2_IPCLKPORT_ACLK 0x2070 2430 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_PPMU_HSI2_IPCLKPORT_PCLK 0x2074 2431 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_MMC_CARD_HSI2_IPCLKPORT_ACLK 0x2078 2432 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_MMC_CARD_HSI2_IPCLKPORT_PCLK 0x207c 2433 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4A_HSI2_IPCLKPORT_ACLK 0x2080 2434 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4A_HSI2_IPCLKPORT_PCLK 0x2084 2435 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4B_HSI2_IPCLKPORT_ACLK 0x2088 2436 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4B_HSI2_IPCLKPORT_PCLK 0x208c 2437 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_UFS_EMBD_HSI2_IPCLKPORT_ACLK 0x2090 2438 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_UFS_EMBD_HSI2_IPCLKPORT_PCLK 0x2094 2439 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_RSTNSYNC_CLK_HSI2_BUS_IPCLKPORT_CLK 0x2098 2440 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_RSTNSYNC_CLK_HSI2_OSCCLK_IPCLKPORT_CLK 0x209c 2441 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_SSMT_HSI2_IPCLKPORT_ACLK 0x20a0 2442 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_SSMT_HSI2_IPCLKPORT_PCLK 0x20a4 2443 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_SYSMMU_HSI2_IPCLKPORT_CLK_S2 0x20a8 2444 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_SYSREG_HSI2_IPCLKPORT_PCLK 0x20ac 2445 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_DBI_1_IPCLKPORT_ACLK 0x20b0 2446 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_DBI_1_IPCLKPORT_PCLK 0x20b4 2447 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_SLV_1_IPCLKPORT_ACLK 0x20b8 2448 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_SLV_1_IPCLKPORT_PCLK 0x20bc 2449 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_DBI_1_IPCLKPORT_ACLK 0x20c0 2450 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_DBI_1_IPCLKPORT_PCLK 0x20c4 2451 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_SLV_1_IPCLKPORT_ACLK 0x20c8 2452 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_SLV_1_IPCLKPORT_PCLK 0x20cc 2453 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UFS_EMBD_IPCLKPORT_I_ACLK 0x20d0 2454 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UFS_EMBD_IPCLKPORT_I_CLK_UNIPRO 0x20d4 2455 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_UFS_EMBD_IPCLKPORT_I_FMP_CLK 0x20d8 2456 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_XIU_D_HSI2_IPCLKPORT_ACLK 0x20dc 2457 #define CLK_CON_GAT_GOUT_BLK_HSI2_UID_XIU_P_HSI2_IPCLKPORT_ACLK 0x20e0 2458 #define DMYQCH_CON_PCIE_GEN4_1_QCH_SCLK_1 0x3000 2459 #define PCH_CON_LHM_AXI_P_HSI2_PCH 0x3008 2460 #define PCH_CON_LHS_ACEL_D_HSI2_PCH 0x300c 2461 #define QCH_CON_D_TZPC_HSI2_QCH 0x3010 2462 #define QCH_CON_GPC_HSI2_QCH 0x3014 2463 #define QCH_CON_GPIO_HSI2_QCH 0x3018 2464 #define QCH_CON_HSI2_CMU_HSI2_QCH 0x301c 2465 #define QCH_CON_LHM_AXI_P_HSI2_QCH 0x3020 2466 #define QCH_CON_LHS_ACEL_D_HSI2_QCH 0x3024 2467 #define QCH_CON_MMC_CARD_QCH 0x3028 2468 #define QCH_CON_PCIE_GEN4_1_QCH_APB_1 0x302c 2469 #define QCH_CON_PCIE_GEN4_1_QCH_APB_2 0x3030 2470 #define QCH_CON_PCIE_GEN4_1_QCH_AXI_1 0x3034 2471 #define QCH_CON_PCIE_GEN4_1_QCH_AXI_2 0x3038 2472 #define QCH_CON_PCIE_GEN4_1_QCH_DBG_1 0x303c 2473 #define QCH_CON_PCIE_GEN4_1_QCH_DBG_2 0x3040 2474 #define QCH_CON_PCIE_GEN4_1_QCH_PCS_APB 0x3044 2475 #define QCH_CON_PCIE_GEN4_1_QCH_PMA_APB 0x3048 2476 #define QCH_CON_PCIE_GEN4_1_QCH_UDBG 0x304c 2477 #define QCH_CON_PCIE_IA_GEN4A_1_QCH 0x3050 2478 #define QCH_CON_PCIE_IA_GEN4B_1_QCH 0x3054 2479 #define QCH_CON_PPMU_HSI2_QCH 0x3058 2480 #define QCH_CON_QE_MMC_CARD_HSI2_QCH 0x305c 2481 #define QCH_CON_QE_PCIE_GEN4A_HSI2_QCH 0x3060 2482 #define QCH_CON_QE_PCIE_GEN4B_HSI2_QCH 0x3064 2483 #define QCH_CON_QE_UFS_EMBD_HSI2_QCH 0x3068 2484 #define QCH_CON_SSMT_HSI2_QCH 0x306c 2485 #define QCH_CON_SSMT_PCIE_IA_GEN4A_1_QCH 0x3070 2486 #define QCH_CON_SSMT_PCIE_IA_GEN4B_1_QCH 0x3074 2487 #define QCH_CON_SYSMMU_HSI2_QCH 0x3078 2488 #define QCH_CON_SYSREG_HSI2_QCH 0x307c 2489 #define QCH_CON_UASC_PCIE_GEN4A_DBI_1_QCH 0x3080 2490 #define QCH_CON_UASC_PCIE_GEN4A_SLV_1_QCH 0x3084 2491 #define QCH_CON_UASC_PCIE_GEN4B_DBI_1_QCH 0x3088 2492 #define QCH_CON_UASC_PCIE_GEN4B_SLV_1_QCH 0x308c 2493 #define QCH_CON_UFS_EMBD_QCH 0x3090 2494 #define QCH_CON_UFS_EMBD_QCH_FMP 0x3094 2495 #define QUEUE_CTRL_REG_BLK_HSI2_CMU_HSI2 0x3c00 2496 2497 static const unsigned long cmu_hsi2_clk_regs[] __initconst = { 2498 PLL_CON0_MUX_CLKCMU_HSI2_BUS_USER, 2499 PLL_CON1_MUX_CLKCMU_HSI2_BUS_USER, 2500 PLL_CON0_MUX_CLKCMU_HSI2_MMC_CARD_USER, 2501 PLL_CON1_MUX_CLKCMU_HSI2_MMC_CARD_USER, 2502 PLL_CON0_MUX_CLKCMU_HSI2_PCIE_USER, 2503 PLL_CON1_MUX_CLKCMU_HSI2_PCIE_USER, 2504 PLL_CON0_MUX_CLKCMU_HSI2_UFS_EMBD_USER, 2505 PLL_CON1_MUX_CLKCMU_HSI2_UFS_EMBD_USER, 2506 HSI2_CMU_HSI2_CONTROLLER_OPTION, 2507 CLKOUT_CON_BLK_HSI2_CMU_HSI2_CLKOUT0, 2508 CLK_CON_GAT_CLK_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_PCIE_SUB_CTRL_INST_0_PHY_REFCLK_IN, 2509 CLK_CON_GAT_CLK_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_PCIE_SUB_CTRL_INST_0_PHY_REFCLK_IN, 2510 CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4A_1_IPCLKPORT_ACLK, 2511 CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4A_1_IPCLKPORT_PCLK, 2512 CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4B_1_IPCLKPORT_ACLK, 2513 CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4B_1_IPCLKPORT_PCLK, 2514 CLK_CON_GAT_GOUT_BLK_HSI2_UID_D_TZPC_HSI2_IPCLKPORT_PCLK, 2515 CLK_CON_GAT_GOUT_BLK_HSI2_UID_GPC_HSI2_IPCLKPORT_PCLK, 2516 CLK_CON_GAT_GOUT_BLK_HSI2_UID_GPIO_HSI2_IPCLKPORT_PCLK, 2517 CLK_CON_GAT_GOUT_BLK_HSI2_UID_HSI2_CMU_HSI2_IPCLKPORT_PCLK, 2518 CLK_CON_GAT_GOUT_BLK_HSI2_UID_LHM_AXI_P_HSI2_IPCLKPORT_I_CLK, 2519 CLK_CON_GAT_GOUT_BLK_HSI2_UID_LHS_ACEL_D_HSI2_IPCLKPORT_I_CLK, 2520 CLK_CON_GAT_GOUT_BLK_HSI2_UID_MMC_CARD_IPCLKPORT_I_ACLK, 2521 CLK_CON_GAT_GOUT_BLK_HSI2_UID_MMC_CARD_IPCLKPORT_SDCLKIN, 2522 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_G4X2_DWC_PCIE_CTL_INST_0_DBI_ACLK_UG, 2523 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_G4X2_DWC_PCIE_CTL_INST_0_MSTR_ACLK_UG, 2524 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_G4X2_DWC_PCIE_CTL_INST_0_SLV_ACLK_UG, 2525 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_PCIE_SUB_CTRL_INST_0_I_DRIVER_APB_CLK, 2526 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_G4X1_DWC_PCIE_CTL_INST_0_DBI_ACLK_UG, 2527 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_G4X1_DWC_PCIE_CTL_INST_0_MSTR_ACLK_UG, 2528 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_G4X1_DWC_PCIE_CTL_INST_0_SLV_ACLK_UG, 2529 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_PCIE_SUB_CTRL_INST_0_I_DRIVER_APB_CLK, 2530 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCS_PMA_INST_0_PHY_UDBG_I_APB_PCLK, 2531 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCS_PMA_INST_0_PIPE_PAL_PCIE_INST_0_I_APB_PCLK, 2532 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCS_PMA_INST_0_SF_PCIEPHY210X2_LN05LPE_QCH_TM_WRAPPER_INST_0_I_APB_PCLK, 2533 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_IA_GEN4A_1_IPCLKPORT_I_CLK, 2534 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_IA_GEN4B_1_IPCLKPORT_I_CLK, 2535 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PPMU_HSI2_IPCLKPORT_ACLK, 2536 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PPMU_HSI2_IPCLKPORT_PCLK, 2537 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_MMC_CARD_HSI2_IPCLKPORT_ACLK, 2538 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_MMC_CARD_HSI2_IPCLKPORT_PCLK, 2539 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4A_HSI2_IPCLKPORT_ACLK, 2540 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4A_HSI2_IPCLKPORT_PCLK, 2541 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4B_HSI2_IPCLKPORT_ACLK, 2542 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4B_HSI2_IPCLKPORT_PCLK, 2543 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_UFS_EMBD_HSI2_IPCLKPORT_ACLK, 2544 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_UFS_EMBD_HSI2_IPCLKPORT_PCLK, 2545 CLK_CON_GAT_GOUT_BLK_HSI2_UID_RSTNSYNC_CLK_HSI2_BUS_IPCLKPORT_CLK, 2546 CLK_CON_GAT_GOUT_BLK_HSI2_UID_RSTNSYNC_CLK_HSI2_OSCCLK_IPCLKPORT_CLK, 2547 CLK_CON_GAT_GOUT_BLK_HSI2_UID_SSMT_HSI2_IPCLKPORT_ACLK, 2548 CLK_CON_GAT_GOUT_BLK_HSI2_UID_SSMT_HSI2_IPCLKPORT_PCLK, 2549 CLK_CON_GAT_GOUT_BLK_HSI2_UID_SYSMMU_HSI2_IPCLKPORT_CLK_S2, 2550 CLK_CON_GAT_GOUT_BLK_HSI2_UID_SYSREG_HSI2_IPCLKPORT_PCLK, 2551 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_DBI_1_IPCLKPORT_ACLK, 2552 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_DBI_1_IPCLKPORT_PCLK, 2553 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_SLV_1_IPCLKPORT_ACLK, 2554 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_SLV_1_IPCLKPORT_PCLK, 2555 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_DBI_1_IPCLKPORT_ACLK, 2556 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_DBI_1_IPCLKPORT_PCLK, 2557 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_SLV_1_IPCLKPORT_ACLK, 2558 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_SLV_1_IPCLKPORT_PCLK, 2559 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UFS_EMBD_IPCLKPORT_I_ACLK, 2560 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UFS_EMBD_IPCLKPORT_I_CLK_UNIPRO, 2561 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UFS_EMBD_IPCLKPORT_I_FMP_CLK, 2562 CLK_CON_GAT_GOUT_BLK_HSI2_UID_XIU_D_HSI2_IPCLKPORT_ACLK, 2563 CLK_CON_GAT_GOUT_BLK_HSI2_UID_XIU_P_HSI2_IPCLKPORT_ACLK, 2564 DMYQCH_CON_PCIE_GEN4_1_QCH_SCLK_1, 2565 PCH_CON_LHM_AXI_P_HSI2_PCH, 2566 PCH_CON_LHS_ACEL_D_HSI2_PCH, 2567 QCH_CON_D_TZPC_HSI2_QCH, 2568 QCH_CON_GPC_HSI2_QCH, 2569 QCH_CON_GPIO_HSI2_QCH, 2570 QCH_CON_HSI2_CMU_HSI2_QCH, 2571 QCH_CON_LHM_AXI_P_HSI2_QCH, 2572 QCH_CON_LHS_ACEL_D_HSI2_QCH, 2573 QCH_CON_MMC_CARD_QCH, 2574 QCH_CON_PCIE_GEN4_1_QCH_APB_1, 2575 QCH_CON_PCIE_GEN4_1_QCH_APB_2, 2576 QCH_CON_PCIE_GEN4_1_QCH_AXI_1, 2577 QCH_CON_PCIE_GEN4_1_QCH_AXI_2, 2578 QCH_CON_PCIE_GEN4_1_QCH_DBG_1, 2579 QCH_CON_PCIE_GEN4_1_QCH_DBG_2, 2580 QCH_CON_PCIE_GEN4_1_QCH_PCS_APB, 2581 QCH_CON_PCIE_GEN4_1_QCH_PMA_APB, 2582 QCH_CON_PCIE_GEN4_1_QCH_UDBG, 2583 QCH_CON_PCIE_IA_GEN4A_1_QCH, 2584 QCH_CON_PCIE_IA_GEN4B_1_QCH, 2585 QCH_CON_PPMU_HSI2_QCH, 2586 QCH_CON_QE_MMC_CARD_HSI2_QCH, 2587 QCH_CON_QE_PCIE_GEN4A_HSI2_QCH, 2588 QCH_CON_QE_PCIE_GEN4B_HSI2_QCH, 2589 QCH_CON_QE_UFS_EMBD_HSI2_QCH, 2590 QCH_CON_SSMT_HSI2_QCH, 2591 QCH_CON_SSMT_PCIE_IA_GEN4A_1_QCH, 2592 QCH_CON_SSMT_PCIE_IA_GEN4B_1_QCH, 2593 QCH_CON_SYSMMU_HSI2_QCH, 2594 QCH_CON_SYSREG_HSI2_QCH, 2595 QCH_CON_UASC_PCIE_GEN4A_DBI_1_QCH, 2596 QCH_CON_UASC_PCIE_GEN4A_SLV_1_QCH, 2597 QCH_CON_UASC_PCIE_GEN4B_DBI_1_QCH, 2598 QCH_CON_UASC_PCIE_GEN4B_SLV_1_QCH, 2599 QCH_CON_UFS_EMBD_QCH, 2600 QCH_CON_UFS_EMBD_QCH_FMP, 2601 QUEUE_CTRL_REG_BLK_HSI2_CMU_HSI2, 2602 }; 2603 2604 PNAME(mout_hsi2_bus_user_p) = { "oscclk", "dout_cmu_hsi2_bus" }; 2605 PNAME(mout_hsi2_mmc_card_user_p) = { "oscclk", "dout_cmu_hsi2_mmc_card" }; 2606 PNAME(mout_hsi2_pcie_user_p) = { "oscclk", "dout_cmu_hsi2_pcie" }; 2607 PNAME(mout_hsi2_ufs_embd_user_p) = { "oscclk", "dout_cmu_hsi2_ufs_embd" }; 2608 2609 static const struct samsung_mux_clock hsi2_mux_clks[] __initconst = { 2610 MUX(CLK_MOUT_HSI2_BUS_USER, "mout_hsi2_bus_user", mout_hsi2_bus_user_p, 2611 PLL_CON0_MUX_CLKCMU_HSI2_BUS_USER, 4, 1), 2612 MUX(CLK_MOUT_HSI2_MMC_CARD_USER, "mout_hsi2_mmc_card_user", 2613 mout_hsi2_mmc_card_user_p, PLL_CON0_MUX_CLKCMU_HSI2_MMC_CARD_USER, 2614 4, 1), 2615 MUX(CLK_MOUT_HSI2_PCIE_USER, "mout_hsi2_pcie_user", 2616 mout_hsi2_pcie_user_p, PLL_CON0_MUX_CLKCMU_HSI2_PCIE_USER, 2617 4, 1), 2618 MUX(CLK_MOUT_HSI2_UFS_EMBD_USER, "mout_hsi2_ufs_embd_user", 2619 mout_hsi2_ufs_embd_user_p, PLL_CON0_MUX_CLKCMU_HSI2_UFS_EMBD_USER, 2620 4, 1), 2621 }; 2622 2623 static const struct samsung_gate_clock hsi2_gate_clks[] __initconst = { 2624 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCIE_003_PHY_REFCLK_IN, 2625 "gout_hsi2_pcie_gen4_1_pcie_003_phy_refclk_in", 2626 "mout_hsi2_pcie_user", 2627 CLK_CON_GAT_CLK_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_PCIE_SUB_CTRL_INST_0_PHY_REFCLK_IN, 2628 21, 0, 0), 2629 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCIE_004_PHY_REFCLK_IN, 2630 "gout_hsi2_pcie_gen4_1_pcie_004_phy_refclk_in", 2631 "mout_hsi2_pcie_user", 2632 CLK_CON_GAT_CLK_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_PCIE_SUB_CTRL_INST_0_PHY_REFCLK_IN, 2633 21, 0, 0), 2634 GATE(CLK_GOUT_HSI2_SSMT_PCIE_IA_GEN4A_1_ACLK, 2635 "gout_hsi2_ssmt_pcie_ia_gen4a_1_aclk", "mout_hsi2_bus_user", 2636 CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4A_1_IPCLKPORT_ACLK, 2637 21, 0, 0), 2638 GATE(CLK_GOUT_HSI2_SSMT_PCIE_IA_GEN4A_1_PCLK, 2639 "gout_hsi2_ssmt_pcie_ia_gen4a_1_pclk", "mout_hsi2_bus_user", 2640 CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4A_1_IPCLKPORT_PCLK, 2641 21, 0, 0), 2642 GATE(CLK_GOUT_HSI2_SSMT_PCIE_IA_GEN4B_1_ACLK, 2643 "gout_hsi2_ssmt_pcie_ia_gen4b_1_aclk", "mout_hsi2_bus_user", 2644 CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4B_1_IPCLKPORT_ACLK, 2645 21, 0, 0), 2646 GATE(CLK_GOUT_HSI2_SSMT_PCIE_IA_GEN4B_1_PCLK, 2647 "gout_hsi2_ssmt_pcie_ia_gen4b_1_pclk", "mout_hsi2_bus_user", 2648 CLK_CON_GAT_CLK_BLK_HSI2_UID_SSMT_PCIE_IA_GEN4B_1_IPCLKPORT_PCLK, 2649 21, 0, 0), 2650 GATE(CLK_GOUT_HSI2_D_TZPC_HSI2_PCLK, 2651 "gout_hsi2_d_tzpc_hsi2_pclk", "mout_hsi2_bus_user", 2652 CLK_CON_GAT_GOUT_BLK_HSI2_UID_D_TZPC_HSI2_IPCLKPORT_PCLK, 2653 21, 0, 0), 2654 GATE(CLK_GOUT_HSI2_GPC_HSI2_PCLK, 2655 "gout_hsi2_gpc_hsi2_pclk", "mout_hsi2_bus_user", 2656 CLK_CON_GAT_GOUT_BLK_HSI2_UID_GPC_HSI2_IPCLKPORT_PCLK, 21, 0, 0), 2657 GATE(CLK_GOUT_HSI2_GPIO_HSI2_PCLK, 2658 "gout_hsi2_gpio_hsi2_pclk", "mout_hsi2_bus_user", 2659 CLK_CON_GAT_GOUT_BLK_HSI2_UID_GPIO_HSI2_IPCLKPORT_PCLK, 21, 2660 CLK_IGNORE_UNUSED, 0), 2661 /* Disabling this clock makes the system hang. Mark the clock as critical. */ 2662 GATE(CLK_GOUT_HSI2_HSI2_CMU_HSI2_PCLK, 2663 "gout_hsi2_hsi2_cmu_hsi2_pclk", "mout_hsi2_bus_user", 2664 CLK_CON_GAT_GOUT_BLK_HSI2_UID_HSI2_CMU_HSI2_IPCLKPORT_PCLK, 2665 21, CLK_IS_CRITICAL, 0), 2666 /* Disabling this clock makes the system hang. Mark the clock as critical. */ 2667 GATE(CLK_GOUT_HSI2_LHM_AXI_P_HSI2_I_CLK, 2668 "gout_hsi2_lhm_axi_p_hsi2_i_clk", "mout_hsi2_bus_user", 2669 CLK_CON_GAT_GOUT_BLK_HSI2_UID_LHM_AXI_P_HSI2_IPCLKPORT_I_CLK, 2670 21, CLK_IS_CRITICAL, 0), 2671 /* TODO: should have a driver for this */ 2672 GATE(CLK_GOUT_HSI2_LHS_ACEL_D_HSI2_I_CLK, 2673 "gout_hsi2_lhs_acel_d_hsi2_i_clk", "mout_hsi2_bus_user", 2674 CLK_CON_GAT_GOUT_BLK_HSI2_UID_LHS_ACEL_D_HSI2_IPCLKPORT_I_CLK, 2675 21, CLK_IGNORE_UNUSED, 0), 2676 GATE(CLK_GOUT_HSI2_MMC_CARD_I_ACLK, 2677 "gout_hsi2_mmc_card_i_aclk", "mout_hsi2_bus_user", 2678 CLK_CON_GAT_GOUT_BLK_HSI2_UID_MMC_CARD_IPCLKPORT_I_ACLK, 2679 21, 0, 0), 2680 GATE(CLK_GOUT_HSI2_MMC_CARD_SDCLKIN, 2681 "gout_hsi2_mmc_card_sdclkin", "mout_hsi2_mmc_card_user", 2682 CLK_CON_GAT_GOUT_BLK_HSI2_UID_MMC_CARD_IPCLKPORT_SDCLKIN, 2683 21, 0, 0), 2684 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCIE_003_DBI_ACLK_UG, 2685 "gout_hsi2_pcie_gen4_1_pcie_003_dbi_aclk_ug", "mout_hsi2_bus_user", 2686 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_G4X2_DWC_PCIE_CTL_INST_0_DBI_ACLK_UG, 2687 21, 0, 0), 2688 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCIE_003_MSTR_ACLK_UG, 2689 "gout_hsi2_pcie_gen4_1_pcie_003_mstr_aclk_ug", 2690 "mout_hsi2_bus_user", 2691 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_G4X2_DWC_PCIE_CTL_INST_0_MSTR_ACLK_UG, 2692 21, 0, 0), 2693 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCIE_003_SLV_ACLK_UG, 2694 "gout_hsi2_pcie_gen4_1_pcie_003_slv_aclk_ug", "mout_hsi2_bus_user", 2695 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_G4X2_DWC_PCIE_CTL_INST_0_SLV_ACLK_UG, 2696 21, 0, 0), 2697 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCIE_003_I_DRIVER_APB_CLK, 2698 "gout_hsi2_pcie_gen4_1_pcie_003_i_driver_apb_clk", 2699 "mout_hsi2_bus_user", 2700 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_003_PCIE_SUB_CTRL_INST_0_I_DRIVER_APB_CLK, 2701 21, 0, 0), 2702 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCIE_004_DBI_ACLK_UG, 2703 "gout_hsi2_pcie_gen4_1_pcie_004_dbi_aclk_ug", "mout_hsi2_bus_user", 2704 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_G4X1_DWC_PCIE_CTL_INST_0_DBI_ACLK_UG, 2705 21, 0, 0), 2706 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCIE_004_MSTR_ACLK_UG, 2707 "gout_hsi2_pcie_gen4_1_pcie_004_mstr_aclk_ug", 2708 "mout_hsi2_bus_user", 2709 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_G4X1_DWC_PCIE_CTL_INST_0_MSTR_ACLK_UG, 2710 21, 0, 0), 2711 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCIE_004_SLV_ACLK_UG, 2712 "gout_hsi2_pcie_gen4_1_pcie_004_slv_aclk_ug", "mout_hsi2_bus_user", 2713 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_G4X1_DWC_PCIE_CTL_INST_0_SLV_ACLK_UG, 2714 21, 0, 0), 2715 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCIE_004_I_DRIVER_APB_CLK, 2716 "gout_hsi2_pcie_gen4_1_pcie_004_i_driver_apb_clk", 2717 "mout_hsi2_bus_user", 2718 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCIE_004_PCIE_SUB_CTRL_INST_0_I_DRIVER_APB_CLK, 2719 21, 0, 0), 2720 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCS_PMA_PHY_UDBG_I_APB_PCLK, 2721 "gout_hsi2_pcie_gen4_1_pcs_pma_phy_udbg_i_apb_pclk", 2722 "mout_hsi2_bus_user", 2723 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCS_PMA_INST_0_PHY_UDBG_I_APB_PCLK, 2724 21, 0, 0), 2725 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCS_PMA_PIPE_PAL_PCIE_I_APB_PCLK, 2726 "gout_hsi2_pcie_gen4_1_pcs_pma_pipe_pal_pcie_i_apb_pclk", 2727 "mout_hsi2_bus_user", 2728 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCS_PMA_INST_0_PIPE_PAL_PCIE_INST_0_I_APB_PCLK, 2729 21, 0, 0), 2730 GATE(CLK_GOUT_HSI2_PCIE_GEN4_1_PCS_PMA_PCIEPHY210X2_QCH_I_APB_PCLK, 2731 "gout_hsi2_pcie_gen4_1_pcs_pma_pciephy210x2_qch_i_apb_pclk", 2732 "mout_hsi2_bus_user", 2733 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_GEN4_1_IPCLKPORT_PCS_PMA_INST_0_SF_PCIEPHY210X2_LN05LPE_QCH_TM_WRAPPER_INST_0_I_APB_PCLK, 2734 21, 0, 0), 2735 GATE(CLK_GOUT_HSI2_PCIE_IA_GEN4A_1_I_CLK, 2736 "gout_hsi2_pcie_ia_gen4a_1_i_clk", "mout_hsi2_bus_user", 2737 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_IA_GEN4A_1_IPCLKPORT_I_CLK, 2738 21, 0, 0), 2739 GATE(CLK_GOUT_HSI2_PCIE_IA_GEN4B_1_I_CLK, 2740 "gout_hsi2_pcie_ia_gen4b_1_i_clk", "mout_hsi2_bus_user", 2741 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PCIE_IA_GEN4B_1_IPCLKPORT_I_CLK, 2742 21, 0, 0), 2743 GATE(CLK_GOUT_HSI2_PPMU_HSI2_ACLK, 2744 "gout_hsi2_ppmu_hsi2_aclk", "mout_hsi2_bus_user", 2745 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PPMU_HSI2_IPCLKPORT_ACLK, 2746 21, 0, 0), 2747 GATE(CLK_GOUT_HSI2_PPMU_HSI2_PCLK, 2748 "gout_hsi2_ppmu_hsi2_pclk", "mout_hsi2_bus_user", 2749 CLK_CON_GAT_GOUT_BLK_HSI2_UID_PPMU_HSI2_IPCLKPORT_PCLK, 2750 21, 0, 0), 2751 GATE(CLK_GOUT_HSI2_QE_MMC_CARD_HSI2_ACLK, 2752 "gout_hsi2_qe_mmc_card_hsi2_aclk", "mout_hsi2_bus_user", 2753 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_MMC_CARD_HSI2_IPCLKPORT_ACLK, 2754 21, 0, 0), 2755 GATE(CLK_GOUT_HSI2_QE_MMC_CARD_HSI2_PCLK, 2756 "gout_hsi2_qe_mmc_card_hsi2_pclk", "mout_hsi2_bus_user", 2757 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_MMC_CARD_HSI2_IPCLKPORT_PCLK, 2758 21, 0, 0), 2759 GATE(CLK_GOUT_HSI2_QE_PCIE_GEN4A_HSI2_ACLK, 2760 "gout_hsi2_qe_pcie_gen4a_hsi2_aclk", "mout_hsi2_bus_user", 2761 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4A_HSI2_IPCLKPORT_ACLK, 2762 21, 0, 0), 2763 GATE(CLK_GOUT_HSI2_QE_PCIE_GEN4A_HSI2_PCLK, 2764 "gout_hsi2_qe_pcie_gen4a_hsi2_pclk", "mout_hsi2_bus_user", 2765 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4A_HSI2_IPCLKPORT_PCLK, 2766 21, 0, 0), 2767 GATE(CLK_GOUT_HSI2_QE_PCIE_GEN4B_HSI2_ACLK, 2768 "gout_hsi2_qe_pcie_gen4b_hsi2_aclk", "mout_hsi2_bus_user", 2769 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4B_HSI2_IPCLKPORT_ACLK, 2770 21, 0, 0), 2771 GATE(CLK_GOUT_HSI2_QE_PCIE_GEN4B_HSI2_PCLK, 2772 "gout_hsi2_qe_pcie_gen4b_hsi2_pclk", "mout_hsi2_bus_user", 2773 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_PCIE_GEN4B_HSI2_IPCLKPORT_PCLK, 2774 21, 0, 0), 2775 GATE(CLK_GOUT_HSI2_QE_UFS_EMBD_HSI2_ACLK, 2776 "gout_hsi2_qe_ufs_embd_hsi2_aclk", "mout_hsi2_bus_user", 2777 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_UFS_EMBD_HSI2_IPCLKPORT_ACLK, 2778 21, 0, 0), 2779 GATE(CLK_GOUT_HSI2_QE_UFS_EMBD_HSI2_PCLK, 2780 "gout_hsi2_qe_ufs_embd_hsi2_pclk", "mout_hsi2_bus_user", 2781 CLK_CON_GAT_GOUT_BLK_HSI2_UID_QE_UFS_EMBD_HSI2_IPCLKPORT_PCLK, 2782 21, 0, 0), 2783 GATE(CLK_GOUT_HSI2_CLK_HSI2_BUS_CLK, 2784 "gout_hsi2_clk_hsi2_bus_clk", "mout_hsi2_bus_user", 2785 CLK_CON_GAT_GOUT_BLK_HSI2_UID_RSTNSYNC_CLK_HSI2_BUS_IPCLKPORT_CLK, 2786 21, CLK_IS_CRITICAL, 0), 2787 GATE(CLK_GOUT_HSI2_CLK_HSI2_OSCCLK_CLK, 2788 "gout_hsi2_clk_hsi2_oscclk_clk", "oscclk", 2789 CLK_CON_GAT_GOUT_BLK_HSI2_UID_RSTNSYNC_CLK_HSI2_OSCCLK_IPCLKPORT_CLK, 2790 21, 0, 0), 2791 /* TODO: should have a driver for this */ 2792 GATE(CLK_GOUT_HSI2_SSMT_HSI2_ACLK, 2793 "gout_hsi2_ssmt_hsi2_aclk", "mout_hsi2_bus_user", 2794 CLK_CON_GAT_GOUT_BLK_HSI2_UID_SSMT_HSI2_IPCLKPORT_ACLK, 2795 21, CLK_IGNORE_UNUSED, 0), 2796 /* TODO: should have a driver for this */ 2797 GATE(CLK_GOUT_HSI2_SSMT_HSI2_PCLK, 2798 "gout_hsi2_ssmt_hsi2_pclk", "mout_hsi2_bus_user", 2799 CLK_CON_GAT_GOUT_BLK_HSI2_UID_SSMT_HSI2_IPCLKPORT_PCLK, 2800 21, CLK_IGNORE_UNUSED, 0), 2801 /* TODO: should have a driver for this */ 2802 GATE(CLK_GOUT_HSI2_SYSMMU_HSI2_CLK_S2, 2803 "gout_hsi2_sysmmu_hsi2_clk_s2", "mout_hsi2_bus_user", 2804 CLK_CON_GAT_GOUT_BLK_HSI2_UID_SYSMMU_HSI2_IPCLKPORT_CLK_S2, 2805 21, CLK_IGNORE_UNUSED, 0), 2806 GATE(CLK_GOUT_HSI2_SYSREG_HSI2_PCLK, 2807 "gout_hsi2_sysreg_hsi2_pclk", "mout_hsi2_bus_user", 2808 CLK_CON_GAT_GOUT_BLK_HSI2_UID_SYSREG_HSI2_IPCLKPORT_PCLK, 2809 21, 0, 0), 2810 GATE(CLK_GOUT_HSI2_UASC_PCIE_GEN4A_DBI_1_ACLK, 2811 "gout_hsi2_uasc_pcie_gen4a_dbi_1_aclk", "mout_hsi2_bus_user", 2812 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_DBI_1_IPCLKPORT_ACLK, 2813 21, 0, 0), 2814 GATE(CLK_GOUT_HSI2_UASC_PCIE_GEN4A_DBI_1_PCLK, 2815 "gout_hsi2_uasc_pcie_gen4a_dbi_1_pclk", "mout_hsi2_bus_user", 2816 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_DBI_1_IPCLKPORT_PCLK, 2817 21, 0, 0), 2818 GATE(CLK_GOUT_HSI2_UASC_PCIE_GEN4A_SLV_1_ACLK, 2819 "gout_hsi2_uasc_pcie_gen4a_slv_1_aclk", "mout_hsi2_bus_user", 2820 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_SLV_1_IPCLKPORT_ACLK, 2821 21, 0, 0), 2822 GATE(CLK_GOUT_HSI2_UASC_PCIE_GEN4A_SLV_1_PCLK, 2823 "gout_hsi2_uasc_pcie_gen4a_slv_1_pclk", "mout_hsi2_bus_user", 2824 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4A_SLV_1_IPCLKPORT_PCLK, 2825 21, 0, 0), 2826 GATE(CLK_GOUT_HSI2_UASC_PCIE_GEN4B_DBI_1_ACLK, 2827 "gout_hsi2_uasc_pcie_gen4b_dbi_1_aclk", "mout_hsi2_bus_user", 2828 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_DBI_1_IPCLKPORT_ACLK, 2829 21, 0, 0), 2830 GATE(CLK_GOUT_HSI2_UASC_PCIE_GEN4B_DBI_1_PCLK, 2831 "gout_hsi2_uasc_pcie_gen4b_dbi_1_pclk", "mout_hsi2_bus_user", 2832 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_DBI_1_IPCLKPORT_PCLK, 2833 21, 0, 0), 2834 GATE(CLK_GOUT_HSI2_UASC_PCIE_GEN4B_SLV_1_ACLK, 2835 "gout_hsi2_uasc_pcie_gen4b_slv_1_aclk", "mout_hsi2_bus_user", 2836 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_SLV_1_IPCLKPORT_ACLK, 2837 21, 0, 0), 2838 GATE(CLK_GOUT_HSI2_UASC_PCIE_GEN4B_SLV_1_PCLK, 2839 "gout_hsi2_uasc_pcie_gen4b_slv_1_pclk", "mout_hsi2_bus_user", 2840 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UASC_PCIE_GEN4B_SLV_1_IPCLKPORT_PCLK, 2841 21, 0, 0), 2842 GATE(CLK_GOUT_HSI2_UFS_EMBD_I_ACLK, 2843 "gout_hsi2_ufs_embd_i_aclk", "mout_hsi2_bus_user", 2844 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UFS_EMBD_IPCLKPORT_I_ACLK, 2845 21, 0, 0), 2846 GATE(CLK_GOUT_HSI2_UFS_EMBD_I_CLK_UNIPRO, 2847 "gout_hsi2_ufs_embd_i_clk_unipro", "mout_hsi2_ufs_embd_user", 2848 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UFS_EMBD_IPCLKPORT_I_CLK_UNIPRO, 2849 21, 0, 0), 2850 GATE(CLK_GOUT_HSI2_UFS_EMBD_I_FMP_CLK, 2851 "gout_hsi2_ufs_embd_i_fmp_clk", "mout_hsi2_bus_user", 2852 CLK_CON_GAT_GOUT_BLK_HSI2_UID_UFS_EMBD_IPCLKPORT_I_FMP_CLK, 2853 21, 0, 0), 2854 /* TODO: should have a driver for this */ 2855 GATE(CLK_GOUT_HSI2_XIU_D_HSI2_ACLK, 2856 "gout_hsi2_xiu_d_hsi2_aclk", "mout_hsi2_bus_user", 2857 CLK_CON_GAT_GOUT_BLK_HSI2_UID_XIU_D_HSI2_IPCLKPORT_ACLK, 2858 21, CLK_IGNORE_UNUSED, 0), 2859 /* TODO: should have a driver for this */ 2860 GATE(CLK_GOUT_HSI2_XIU_P_HSI2_ACLK, 2861 "gout_hsi2_xiu_p_hsi2_aclk", "mout_hsi2_bus_user", 2862 CLK_CON_GAT_GOUT_BLK_HSI2_UID_XIU_P_HSI2_IPCLKPORT_ACLK, 2863 21, CLK_IGNORE_UNUSED, 0), 2864 }; 2865 2866 static const struct samsung_cmu_info hsi2_cmu_info __initconst = { 2867 .mux_clks = hsi2_mux_clks, 2868 .nr_mux_clks = ARRAY_SIZE(hsi2_mux_clks), 2869 .gate_clks = hsi2_gate_clks, 2870 .nr_gate_clks = ARRAY_SIZE(hsi2_gate_clks), 2871 .nr_clk_ids = CLKS_NR_HSI2, 2872 .clk_regs = cmu_hsi2_clk_regs, 2873 .nr_clk_regs = ARRAY_SIZE(cmu_hsi2_clk_regs), 2874 .clk_name = "bus", 2875 }; 2876 2877 /* ---- CMU_MISC ------------------------------------------------------------ */ 2878 2879 /* Register Offset definitions for CMU_MISC (0x10010000) */ 2880 #define PLL_CON0_MUX_CLKCMU_MISC_BUS_USER 0x0600 2881 #define PLL_CON1_MUX_CLKCMU_MISC_BUS_USER 0x0604 2882 #define PLL_CON0_MUX_CLKCMU_MISC_SSS_USER 0x0610 2883 #define PLL_CON1_MUX_CLKCMU_MISC_SSS_USER 0x0614 2884 #define MISC_CMU_MISC_CONTROLLER_OPTION 0x0800 2885 #define CLKOUT_CON_BLK_MISC_CMU_MISC_CLKOUT0 0x0810 2886 #define CLK_CON_MUX_MUX_CLK_MISC_GIC 0x1000 2887 #define CLK_CON_DIV_DIV_CLK_MISC_BUSP 0x1800 2888 #define CLK_CON_DIV_DIV_CLK_MISC_GIC 0x1804 2889 #define CLK_CON_GAT_CLK_BLK_MISC_UID_MISC_CMU_MISC_IPCLKPORT_PCLK 0x2000 2890 #define CLK_CON_GAT_CLK_BLK_MISC_UID_OTP_CON_BIRA_IPCLKPORT_I_OSCCLK 0x2004 2891 #define CLK_CON_GAT_CLK_BLK_MISC_UID_OTP_CON_BISR_IPCLKPORT_I_OSCCLK 0x2008 2892 #define CLK_CON_GAT_CLK_BLK_MISC_UID_OTP_CON_TOP_IPCLKPORT_I_OSCCLK 0x200c 2893 #define CLK_CON_GAT_CLK_BLK_MISC_UID_RSTNSYNC_CLK_MISC_OSCCLK_IPCLKPORT_CLK 0x2010 2894 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_ADM_AHB_SSS_IPCLKPORT_HCLKM 0x2014 2895 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_AD_APB_DIT_IPCLKPORT_PCLKM 0x2018 2896 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_AD_APB_PUF_IPCLKPORT_PCLKM 0x201c 2897 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_DIT_IPCLKPORT_ICLKL2A 0x2020 2898 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_D_TZPC_MISC_IPCLKPORT_PCLK 0x2024 2899 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_GIC_IPCLKPORT_GICCLK 0x2028 2900 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_GPC_MISC_IPCLKPORT_PCLK 0x202c 2901 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AST_ICC_CPUGIC_IPCLKPORT_I_CLK 0x2030 2902 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AXI_D_SSS_IPCLKPORT_I_CLK 0x2034 2903 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AXI_P_GIC_IPCLKPORT_I_CLK 0x2038 2904 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AXI_P_MISC_IPCLKPORT_I_CLK 0x203c 2905 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_LHS_ACEL_D_MISC_IPCLKPORT_I_CLK 0x2040 2906 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_LHS_AST_IRI_GICCPU_IPCLKPORT_I_CLK 0x2044 2907 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_LHS_AXI_D_SSS_IPCLKPORT_I_CLK 0x2048 2908 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_MCT_IPCLKPORT_PCLK 0x204c 2909 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_OTP_CON_BIRA_IPCLKPORT_PCLK 0x2050 2910 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_OTP_CON_BISR_IPCLKPORT_PCLK 0x2054 2911 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_OTP_CON_TOP_IPCLKPORT_PCLK 0x2058 2912 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_PDMA_IPCLKPORT_ACLK 0x205c 2913 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_PPMU_DMA_IPCLKPORT_ACLK 0x2060 2914 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_PPMU_MISC_IPCLKPORT_ACLK 0x2064 2915 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_PPMU_MISC_IPCLKPORT_PCLK 0x2068 2916 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_PUF_IPCLKPORT_I_CLK 0x206c 2917 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_DIT_IPCLKPORT_ACLK 0x2070 2918 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_DIT_IPCLKPORT_PCLK 0x2074 2919 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PDMA_IPCLKPORT_ACLK 0x2078 2920 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PDMA_IPCLKPORT_PCLK 0x207c 2921 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PPMU_DMA_IPCLKPORT_ACLK 0x2080 2922 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PPMU_DMA_IPCLKPORT_PCLK 0x2084 2923 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_RTIC_IPCLKPORT_ACLK 0x2088 2924 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_RTIC_IPCLKPORT_PCLK 0x208c 2925 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SPDMA_IPCLKPORT_ACLK 0x2090 2926 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SPDMA_IPCLKPORT_PCLK 0x2094 2927 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SSS_IPCLKPORT_ACLK 0x2098 2928 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SSS_IPCLKPORT_PCLK 0x209c 2929 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_BUSD_IPCLKPORT_CLK 0x20a0 2930 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_BUSP_IPCLKPORT_CLK 0x20a4 2931 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_GIC_IPCLKPORT_CLK 0x20a8 2932 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_SSS_IPCLKPORT_CLK 0x20ac 2933 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_RTIC_IPCLKPORT_I_ACLK 0x20b0 2934 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_RTIC_IPCLKPORT_I_PCLK 0x20b4 2935 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SPDMA_IPCLKPORT_ACLK 0x20b8 2936 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_DIT_IPCLKPORT_ACLK 0x20bc 2937 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_DIT_IPCLKPORT_PCLK 0x20c0 2938 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PDMA_IPCLKPORT_ACLK 0x20c4 2939 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PDMA_IPCLKPORT_PCLK 0x20c8 2940 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PPMU_DMA_IPCLKPORT_ACLK 0x20cc 2941 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PPMU_DMA_IPCLKPORT_PCLK 0x20d0 2942 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_RTIC_IPCLKPORT_ACLK 0x20d4 2943 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_RTIC_IPCLKPORT_PCLK 0x20d8 2944 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SPDMA_IPCLKPORT_ACLK 0x20dc 2945 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SPDMA_IPCLKPORT_PCLK 0x20e0 2946 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SSS_IPCLKPORT_ACLK 0x20e4 2947 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SSS_IPCLKPORT_PCLK 0x20e8 2948 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSS_IPCLKPORT_I_ACLK 0x20ec 2949 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SSS_IPCLKPORT_I_PCLK 0x20f0 2950 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SYSMMU_MISC_IPCLKPORT_CLK_S2 0x20f4 2951 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SYSMMU_SSS_IPCLKPORT_CLK_S1 0x20f8 2952 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_SYSREG_MISC_IPCLKPORT_PCLK 0x20fc 2953 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_TMU_SUB_IPCLKPORT_PCLK 0x2100 2954 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_TMU_TOP_IPCLKPORT_PCLK 0x2104 2955 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_WDT_CLUSTER0_IPCLKPORT_PCLK 0x2108 2956 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_WDT_CLUSTER1_IPCLKPORT_PCLK 0x210c 2957 #define CLK_CON_GAT_GOUT_BLK_MISC_UID_XIU_D_MISC_IPCLKPORT_ACLK 0x2110 2958 #define DMYQCH_CON_PPMU_DMA_QCH 0x3000 2959 #define DMYQCH_CON_PUF_QCH 0x3004 2960 #define PCH_CON_LHM_AXI_D_SSS_PCH 0x300c 2961 #define PCH_CON_LHM_AXI_P_GIC_PCH 0x3010 2962 #define PCH_CON_LHM_AXI_P_MISC_PCH 0x3014 2963 #define PCH_CON_LHS_ACEL_D_MISC_PCH 0x3018 2964 #define PCH_CON_LHS_AST_IRI_GICCPU_PCH 0x301c 2965 #define PCH_CON_LHS_AXI_D_SSS_PCH 0x3020 2966 #define QCH_CON_ADM_AHB_SSS_QCH 0x3024 2967 #define QCH_CON_DIT_QCH 0x3028 2968 #define QCH_CON_GIC_QCH 0x3030 2969 #define QCH_CON_LHM_AST_ICC_CPUGIC_QCH 0x3038 2970 #define QCH_CON_LHM_AXI_D_SSS_QCH 0x303c 2971 #define QCH_CON_LHM_AXI_P_GIC_QCH 0x3040 2972 #define QCH_CON_LHM_AXI_P_MISC_QCH 0x3044 2973 #define QCH_CON_LHS_ACEL_D_MISC_QCH 0x3048 2974 #define QCH_CON_LHS_AST_IRI_GICCPU_QCH 0x304c 2975 #define QCH_CON_LHS_AXI_D_SSS_QCH 0x3050 2976 #define QCH_CON_MCT_QCH 0x3054 2977 #define QCH_CON_MISC_CMU_MISC_QCH 0x3058 2978 #define QCH_CON_OTP_CON_BIRA_QCH 0x305c 2979 #define QCH_CON_OTP_CON_BISR_QCH 0x3060 2980 #define QCH_CON_OTP_CON_TOP_QCH 0x3064 2981 #define QCH_CON_PDMA_QCH 0x3068 2982 #define QCH_CON_PPMU_MISC_QCH 0x306c 2983 #define QCH_CON_QE_DIT_QCH 0x3070 2984 #define QCH_CON_QE_PDMA_QCH 0x3074 2985 #define QCH_CON_QE_PPMU_DMA_QCH 0x3078 2986 #define QCH_CON_QE_RTIC_QCH 0x307c 2987 #define QCH_CON_QE_SPDMA_QCH 0x3080 2988 #define QCH_CON_QE_SSS_QCH 0x3084 2989 #define QCH_CON_RTIC_QCH 0x3088 2990 #define QCH_CON_SPDMA_QCH 0x308c 2991 #define QCH_CON_SSMT_DIT_QCH 0x3090 2992 #define QCH_CON_SSMT_PDMA_QCH 0x3094 2993 #define QCH_CON_SSMT_PPMU_DMA_QCH 0x3098 2994 #define QCH_CON_SSMT_RTIC_QCH 0x309c 2995 #define QCH_CON_SSMT_SPDMA_QCH 0x30a0 2996 #define QCH_CON_SSMT_SSS_QCH 0x30a4 2997 #define QCH_CON_SSS_QCH 0x30a8 2998 #define QCH_CON_SYSMMU_MISC_QCH 0x30ac 2999 #define QCH_CON_SYSMMU_SSS_QCH 0x30b0 3000 #define QCH_CON_SYSREG_MISC_QCH 0x30b4 3001 #define QCH_CON_TMU_SUB_QCH 0x30b8 3002 #define QCH_CON_TMU_TOP_QCH 0x30bc 3003 #define QCH_CON_WDT_CLUSTER0_QCH 0x30c0 3004 #define QCH_CON_WDT_CLUSTER1_QCH 0x30c4 3005 #define QUEUE_CTRL_REG_BLK_MISC_CMU_MISC 0x3c00 3006 3007 static const unsigned long misc_clk_regs[] __initconst = { 3008 PLL_CON0_MUX_CLKCMU_MISC_BUS_USER, 3009 PLL_CON1_MUX_CLKCMU_MISC_BUS_USER, 3010 PLL_CON0_MUX_CLKCMU_MISC_SSS_USER, 3011 PLL_CON1_MUX_CLKCMU_MISC_SSS_USER, 3012 MISC_CMU_MISC_CONTROLLER_OPTION, 3013 CLKOUT_CON_BLK_MISC_CMU_MISC_CLKOUT0, 3014 CLK_CON_MUX_MUX_CLK_MISC_GIC, 3015 CLK_CON_DIV_DIV_CLK_MISC_BUSP, 3016 CLK_CON_DIV_DIV_CLK_MISC_GIC, 3017 CLK_CON_GAT_CLK_BLK_MISC_UID_MISC_CMU_MISC_IPCLKPORT_PCLK, 3018 CLK_CON_GAT_CLK_BLK_MISC_UID_OTP_CON_BIRA_IPCLKPORT_I_OSCCLK, 3019 CLK_CON_GAT_CLK_BLK_MISC_UID_OTP_CON_BISR_IPCLKPORT_I_OSCCLK, 3020 CLK_CON_GAT_CLK_BLK_MISC_UID_OTP_CON_TOP_IPCLKPORT_I_OSCCLK, 3021 CLK_CON_GAT_CLK_BLK_MISC_UID_RSTNSYNC_CLK_MISC_OSCCLK_IPCLKPORT_CLK, 3022 CLK_CON_GAT_GOUT_BLK_MISC_UID_ADM_AHB_SSS_IPCLKPORT_HCLKM, 3023 CLK_CON_GAT_GOUT_BLK_MISC_UID_AD_APB_DIT_IPCLKPORT_PCLKM, 3024 CLK_CON_GAT_GOUT_BLK_MISC_UID_AD_APB_PUF_IPCLKPORT_PCLKM, 3025 CLK_CON_GAT_GOUT_BLK_MISC_UID_DIT_IPCLKPORT_ICLKL2A, 3026 CLK_CON_GAT_GOUT_BLK_MISC_UID_D_TZPC_MISC_IPCLKPORT_PCLK, 3027 CLK_CON_GAT_GOUT_BLK_MISC_UID_GIC_IPCLKPORT_GICCLK, 3028 CLK_CON_GAT_GOUT_BLK_MISC_UID_GPC_MISC_IPCLKPORT_PCLK, 3029 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AST_ICC_CPUGIC_IPCLKPORT_I_CLK, 3030 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AXI_D_SSS_IPCLKPORT_I_CLK, 3031 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AXI_P_GIC_IPCLKPORT_I_CLK, 3032 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AXI_P_MISC_IPCLKPORT_I_CLK, 3033 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHS_ACEL_D_MISC_IPCLKPORT_I_CLK, 3034 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHS_AST_IRI_GICCPU_IPCLKPORT_I_CLK, 3035 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHS_AXI_D_SSS_IPCLKPORT_I_CLK, 3036 CLK_CON_GAT_GOUT_BLK_MISC_UID_MCT_IPCLKPORT_PCLK, 3037 CLK_CON_GAT_GOUT_BLK_MISC_UID_OTP_CON_BIRA_IPCLKPORT_PCLK, 3038 CLK_CON_GAT_GOUT_BLK_MISC_UID_OTP_CON_BISR_IPCLKPORT_PCLK, 3039 CLK_CON_GAT_GOUT_BLK_MISC_UID_OTP_CON_TOP_IPCLKPORT_PCLK, 3040 CLK_CON_GAT_GOUT_BLK_MISC_UID_PDMA_IPCLKPORT_ACLK, 3041 CLK_CON_GAT_GOUT_BLK_MISC_UID_PPMU_DMA_IPCLKPORT_ACLK, 3042 CLK_CON_GAT_GOUT_BLK_MISC_UID_PPMU_MISC_IPCLKPORT_ACLK, 3043 CLK_CON_GAT_GOUT_BLK_MISC_UID_PPMU_MISC_IPCLKPORT_PCLK, 3044 CLK_CON_GAT_GOUT_BLK_MISC_UID_PUF_IPCLKPORT_I_CLK, 3045 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_DIT_IPCLKPORT_ACLK, 3046 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_DIT_IPCLKPORT_PCLK, 3047 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PDMA_IPCLKPORT_ACLK, 3048 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PDMA_IPCLKPORT_PCLK, 3049 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PPMU_DMA_IPCLKPORT_ACLK, 3050 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PPMU_DMA_IPCLKPORT_PCLK, 3051 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_RTIC_IPCLKPORT_ACLK, 3052 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_RTIC_IPCLKPORT_PCLK, 3053 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SPDMA_IPCLKPORT_ACLK, 3054 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SPDMA_IPCLKPORT_PCLK, 3055 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SSS_IPCLKPORT_ACLK, 3056 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SSS_IPCLKPORT_PCLK, 3057 CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_BUSD_IPCLKPORT_CLK, 3058 CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_BUSP_IPCLKPORT_CLK, 3059 CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_GIC_IPCLKPORT_CLK, 3060 CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_SSS_IPCLKPORT_CLK, 3061 CLK_CON_GAT_GOUT_BLK_MISC_UID_RTIC_IPCLKPORT_I_ACLK, 3062 CLK_CON_GAT_GOUT_BLK_MISC_UID_RTIC_IPCLKPORT_I_PCLK, 3063 CLK_CON_GAT_GOUT_BLK_MISC_UID_SPDMA_IPCLKPORT_ACLK, 3064 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_DIT_IPCLKPORT_ACLK, 3065 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_DIT_IPCLKPORT_PCLK, 3066 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PDMA_IPCLKPORT_ACLK, 3067 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PDMA_IPCLKPORT_PCLK, 3068 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PPMU_DMA_IPCLKPORT_ACLK, 3069 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PPMU_DMA_IPCLKPORT_PCLK, 3070 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_RTIC_IPCLKPORT_ACLK, 3071 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_RTIC_IPCLKPORT_PCLK, 3072 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SPDMA_IPCLKPORT_ACLK, 3073 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SPDMA_IPCLKPORT_PCLK, 3074 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SSS_IPCLKPORT_ACLK, 3075 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SSS_IPCLKPORT_PCLK, 3076 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSS_IPCLKPORT_I_ACLK, 3077 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSS_IPCLKPORT_I_PCLK, 3078 CLK_CON_GAT_GOUT_BLK_MISC_UID_SYSMMU_MISC_IPCLKPORT_CLK_S2, 3079 CLK_CON_GAT_GOUT_BLK_MISC_UID_SYSMMU_SSS_IPCLKPORT_CLK_S1, 3080 CLK_CON_GAT_GOUT_BLK_MISC_UID_SYSREG_MISC_IPCLKPORT_PCLK, 3081 CLK_CON_GAT_GOUT_BLK_MISC_UID_TMU_SUB_IPCLKPORT_PCLK, 3082 CLK_CON_GAT_GOUT_BLK_MISC_UID_TMU_TOP_IPCLKPORT_PCLK, 3083 CLK_CON_GAT_GOUT_BLK_MISC_UID_WDT_CLUSTER0_IPCLKPORT_PCLK, 3084 CLK_CON_GAT_GOUT_BLK_MISC_UID_WDT_CLUSTER1_IPCLKPORT_PCLK, 3085 CLK_CON_GAT_GOUT_BLK_MISC_UID_XIU_D_MISC_IPCLKPORT_ACLK, 3086 DMYQCH_CON_PPMU_DMA_QCH, 3087 DMYQCH_CON_PUF_QCH, 3088 PCH_CON_LHM_AXI_D_SSS_PCH, 3089 PCH_CON_LHM_AXI_P_GIC_PCH, 3090 PCH_CON_LHM_AXI_P_MISC_PCH, 3091 PCH_CON_LHS_ACEL_D_MISC_PCH, 3092 PCH_CON_LHS_AST_IRI_GICCPU_PCH, 3093 PCH_CON_LHS_AXI_D_SSS_PCH, 3094 QCH_CON_ADM_AHB_SSS_QCH, 3095 QCH_CON_DIT_QCH, 3096 QCH_CON_GIC_QCH, 3097 QCH_CON_LHM_AST_ICC_CPUGIC_QCH, 3098 QCH_CON_LHM_AXI_D_SSS_QCH, 3099 QCH_CON_LHM_AXI_P_GIC_QCH, 3100 QCH_CON_LHM_AXI_P_MISC_QCH, 3101 QCH_CON_LHS_ACEL_D_MISC_QCH, 3102 QCH_CON_LHS_AST_IRI_GICCPU_QCH, 3103 QCH_CON_LHS_AXI_D_SSS_QCH, 3104 QCH_CON_MCT_QCH, 3105 QCH_CON_MISC_CMU_MISC_QCH, 3106 QCH_CON_OTP_CON_BIRA_QCH, 3107 QCH_CON_OTP_CON_BISR_QCH, 3108 QCH_CON_OTP_CON_TOP_QCH, 3109 QCH_CON_PDMA_QCH, 3110 QCH_CON_PPMU_MISC_QCH, 3111 QCH_CON_QE_DIT_QCH, 3112 QCH_CON_QE_PDMA_QCH, 3113 QCH_CON_QE_PPMU_DMA_QCH, 3114 QCH_CON_QE_RTIC_QCH, 3115 QCH_CON_QE_SPDMA_QCH, 3116 QCH_CON_QE_SSS_QCH, 3117 QCH_CON_RTIC_QCH, 3118 QCH_CON_SPDMA_QCH, 3119 QCH_CON_SSMT_DIT_QCH, 3120 QCH_CON_SSMT_PDMA_QCH, 3121 QCH_CON_SSMT_PPMU_DMA_QCH, 3122 QCH_CON_SSMT_RTIC_QCH, 3123 QCH_CON_SSMT_SPDMA_QCH, 3124 QCH_CON_SSMT_SSS_QCH, 3125 QCH_CON_SSS_QCH, 3126 QCH_CON_SYSMMU_MISC_QCH, 3127 QCH_CON_SYSMMU_SSS_QCH, 3128 QCH_CON_SYSREG_MISC_QCH, 3129 QCH_CON_TMU_SUB_QCH, 3130 QCH_CON_TMU_TOP_QCH, 3131 QCH_CON_WDT_CLUSTER0_QCH, 3132 QCH_CON_WDT_CLUSTER1_QCH, 3133 QUEUE_CTRL_REG_BLK_MISC_CMU_MISC, 3134 }; 3135 3136 /* List of parent clocks for Muxes in CMU_MISC */ 3137 PNAME(mout_misc_bus_user_p) = { "oscclk", "dout_cmu_misc_bus" }; 3138 PNAME(mout_misc_sss_user_p) = { "oscclk", "dout_cmu_misc_sss" }; 3139 PNAME(mout_misc_gic_p) = { "dout_misc_gic", "oscclk" }; 3140 3141 static const struct samsung_mux_clock misc_mux_clks[] __initconst = { 3142 MUX(CLK_MOUT_MISC_BUS_USER, "mout_misc_bus_user", mout_misc_bus_user_p, 3143 PLL_CON0_MUX_CLKCMU_MISC_BUS_USER, 4, 1), 3144 MUX(CLK_MOUT_MISC_SSS_USER, "mout_misc_sss_user", mout_misc_sss_user_p, 3145 PLL_CON0_MUX_CLKCMU_MISC_SSS_USER, 4, 1), 3146 MUX(CLK_MOUT_MISC_GIC, "mout_misc_gic", mout_misc_gic_p, 3147 CLK_CON_MUX_MUX_CLK_MISC_GIC, 0, 0), 3148 }; 3149 3150 static const struct samsung_div_clock misc_div_clks[] __initconst = { 3151 DIV(CLK_DOUT_MISC_BUSP, "dout_misc_busp", "mout_misc_bus_user", 3152 CLK_CON_DIV_DIV_CLK_MISC_BUSP, 0, 3), 3153 DIV(CLK_DOUT_MISC_GIC, "dout_misc_gic", "mout_misc_bus_user", 3154 CLK_CON_DIV_DIV_CLK_MISC_GIC, 0, 3), 3155 }; 3156 3157 static const struct samsung_gate_clock misc_gate_clks[] __initconst = { 3158 GATE(CLK_GOUT_MISC_MISC_CMU_MISC_PCLK, 3159 "gout_misc_misc_cmu_misc_pclk", "dout_misc_busp", 3160 CLK_CON_GAT_CLK_BLK_MISC_UID_MISC_CMU_MISC_IPCLKPORT_PCLK, 3161 21, 0, 0), 3162 GATE(CLK_GOUT_MISC_OTP_CON_BIRA_I_OSCCLK, 3163 "gout_misc_otp_con_bira_i_oscclk", "oscclk", 3164 CLK_CON_GAT_CLK_BLK_MISC_UID_OTP_CON_BIRA_IPCLKPORT_I_OSCCLK, 3165 21, 0, 0), 3166 GATE(CLK_GOUT_MISC_OTP_CON_BISR_I_OSCCLK, 3167 "gout_misc_otp_con_bisr_i_oscclk", "oscclk", 3168 CLK_CON_GAT_CLK_BLK_MISC_UID_OTP_CON_BISR_IPCLKPORT_I_OSCCLK, 3169 21, 0, 0), 3170 GATE(CLK_GOUT_MISC_OTP_CON_TOP_I_OSCCLK, 3171 "gout_misc_otp_con_top_i_oscclk", "oscclk", 3172 CLK_CON_GAT_CLK_BLK_MISC_UID_OTP_CON_TOP_IPCLKPORT_I_OSCCLK, 3173 21, 0, 0), 3174 GATE(CLK_GOUT_MISC_CLK_MISC_OSCCLK_CLK, 3175 "gout_misc_clk_misc_oscclk_clk", "oscclk", 3176 CLK_CON_GAT_CLK_BLK_MISC_UID_RSTNSYNC_CLK_MISC_OSCCLK_IPCLKPORT_CLK, 3177 21, 0, 0), 3178 GATE(CLK_GOUT_MISC_ADM_AHB_SSS_HCLKM, 3179 "gout_misc_adm_ahb_sss_hclkm", "mout_misc_sss_user", 3180 CLK_CON_GAT_GOUT_BLK_MISC_UID_ADM_AHB_SSS_IPCLKPORT_HCLKM, 3181 21, 0, 0), 3182 GATE(CLK_GOUT_MISC_AD_APB_DIT_PCLKM, 3183 "gout_misc_ad_apb_dit_pclkm", "mout_misc_bus_user", 3184 CLK_CON_GAT_GOUT_BLK_MISC_UID_AD_APB_DIT_IPCLKPORT_PCLKM, 3185 21, 0, 0), 3186 GATE(CLK_GOUT_MISC_D_TZPC_MISC_PCLK, 3187 "gout_misc_d_tzpc_misc_pclk", "dout_misc_busp", 3188 CLK_CON_GAT_GOUT_BLK_MISC_UID_D_TZPC_MISC_IPCLKPORT_PCLK, 3189 21, 0, 0), 3190 GATE(CLK_GOUT_MISC_GIC_GICCLK, 3191 "gout_misc_gic_gicclk", "mout_misc_gic", 3192 CLK_CON_GAT_GOUT_BLK_MISC_UID_GIC_IPCLKPORT_GICCLK, 3193 21, 0, 0), 3194 GATE(CLK_GOUT_MISC_GPC_MISC_PCLK, 3195 "gout_misc_gpc_misc_pclk", "dout_misc_busp", 3196 CLK_CON_GAT_GOUT_BLK_MISC_UID_GPC_MISC_IPCLKPORT_PCLK, 3197 21, 0, 0), 3198 GATE(CLK_GOUT_MISC_LHM_AST_ICC_CPUGIC_I_CLK, 3199 "gout_misc_lhm_ast_icc_gpugic_i_clk", "mout_misc_gic", 3200 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AST_ICC_CPUGIC_IPCLKPORT_I_CLK, 3201 21, 0, 0), 3202 GATE(CLK_GOUT_MISC_LHM_AXI_D_SSS_I_CLK, 3203 "gout_misc_lhm_axi_d_sss_i_clk", "mout_misc_bus_user", 3204 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AXI_D_SSS_IPCLKPORT_I_CLK, 3205 21, 0, 0), 3206 GATE(CLK_GOUT_MISC_LHM_AXI_P_GIC_I_CLK, 3207 "gout_misc_lhm_axi_p_gic_i_clk", "mout_misc_gic", 3208 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AXI_P_GIC_IPCLKPORT_I_CLK, 3209 21, 0, 0), 3210 GATE(CLK_GOUT_MISC_LHM_AXI_P_MISC_I_CLK, 3211 "gout_misc_lhm_axi_p_misc_i_clk", "dout_misc_busp", 3212 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHM_AXI_P_MISC_IPCLKPORT_I_CLK, 3213 21, 0, 0), 3214 GATE(CLK_GOUT_MISC_LHS_ACEL_D_MISC_I_CLK, 3215 "gout_misc_lhs_acel_d_misc_i_clk", "mout_misc_bus_user", 3216 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHS_ACEL_D_MISC_IPCLKPORT_I_CLK, 3217 21, 0, 0), 3218 GATE(CLK_GOUT_MISC_LHS_AST_IRI_GICCPU_I_CLK, 3219 "gout_misc_lhs_ast_iri_giccpu_i_clk", "mout_misc_gic", 3220 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHS_AST_IRI_GICCPU_IPCLKPORT_I_CLK, 3221 21, 0, 0), 3222 GATE(CLK_GOUT_MISC_LHS_AXI_D_SSS_I_CLK, 3223 "gout_misc_lhs_axi_d_sss_i_clk", "mout_misc_sss_user", 3224 CLK_CON_GAT_GOUT_BLK_MISC_UID_LHS_AXI_D_SSS_IPCLKPORT_I_CLK, 3225 21, 0, 0), 3226 GATE(CLK_GOUT_MISC_MCT_PCLK, "gout_misc_mct_pclk", 3227 "dout_misc_busp", 3228 CLK_CON_GAT_GOUT_BLK_MISC_UID_MCT_IPCLKPORT_PCLK, 3229 21, 0, 0), 3230 GATE(CLK_GOUT_MISC_OTP_CON_BIRA_PCLK, 3231 "gout_misc_otp_con_bira_pclk", "dout_misc_busp", 3232 CLK_CON_GAT_GOUT_BLK_MISC_UID_OTP_CON_BIRA_IPCLKPORT_PCLK, 3233 21, 0, 0), 3234 GATE(CLK_GOUT_MISC_OTP_CON_BISR_PCLK, 3235 "gout_misc_otp_con_bisr_pclk", "dout_misc_busp", 3236 CLK_CON_GAT_GOUT_BLK_MISC_UID_OTP_CON_BISR_IPCLKPORT_PCLK, 3237 21, 0, 0), 3238 GATE(CLK_GOUT_MISC_OTP_CON_TOP_PCLK, 3239 "gout_misc_otp_con_top_pclk", "dout_misc_busp", 3240 CLK_CON_GAT_GOUT_BLK_MISC_UID_OTP_CON_TOP_IPCLKPORT_PCLK, 3241 21, 0, 0), 3242 GATE(CLK_GOUT_MISC_PDMA_ACLK, "gout_misc_pdma_aclk", 3243 "mout_misc_bus_user", 3244 CLK_CON_GAT_GOUT_BLK_MISC_UID_PDMA_IPCLKPORT_ACLK, 3245 21, 0, 0), 3246 GATE(CLK_GOUT_MISC_PPMU_MISC_ACLK, 3247 "gout_misc_ppmu_misc_aclk", "mout_misc_bus_user", 3248 CLK_CON_GAT_GOUT_BLK_MISC_UID_PPMU_MISC_IPCLKPORT_ACLK, 3249 21, 0, 0), 3250 GATE(CLK_GOUT_MISC_PPMU_MISC_PCLK, 3251 "gout_misc_ppmu_misc_pclk", "dout_misc_busp", 3252 CLK_CON_GAT_GOUT_BLK_MISC_UID_PPMU_MISC_IPCLKPORT_PCLK, 3253 21, 0, 0), 3254 GATE(CLK_GOUT_MISC_PUF_I_CLK, 3255 "gout_misc_puf_i_clk", "mout_misc_sss_user", 3256 CLK_CON_GAT_GOUT_BLK_MISC_UID_PUF_IPCLKPORT_I_CLK, 3257 21, 0, 0), 3258 GATE(CLK_GOUT_MISC_QE_DIT_ACLK, 3259 "gout_misc_qe_dit_aclk", "mout_misc_bus_user", 3260 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_DIT_IPCLKPORT_ACLK, 3261 21, 0, 0), 3262 GATE(CLK_GOUT_MISC_QE_DIT_PCLK, 3263 "gout_misc_qe_dit_pclk", "dout_misc_busp", 3264 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_DIT_IPCLKPORT_PCLK, 3265 21, 0, 0), 3266 GATE(CLK_GOUT_MISC_QE_PDMA_ACLK, 3267 "gout_misc_qe_pdma_aclk", "mout_misc_bus_user", 3268 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PDMA_IPCLKPORT_ACLK, 3269 21, 0, 0), 3270 GATE(CLK_GOUT_MISC_QE_PDMA_PCLK, 3271 "gout_misc_qe_pdma_pclk", "dout_misc_busp", 3272 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PDMA_IPCLKPORT_PCLK, 3273 21, 0, 0), 3274 GATE(CLK_GOUT_MISC_QE_PPMU_DMA_ACLK, 3275 "gout_misc_qe_ppmu_dma_aclk", "mout_misc_bus_user", 3276 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PPMU_DMA_IPCLKPORT_ACLK, 3277 21, 0, 0), 3278 GATE(CLK_GOUT_MISC_QE_PPMU_DMA_PCLK, 3279 "gout_misc_qe_ppmu_dma_pclk", "dout_misc_busp", 3280 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_PPMU_DMA_IPCLKPORT_PCLK, 3281 21, 0, 0), 3282 GATE(CLK_GOUT_MISC_QE_RTIC_ACLK, 3283 "gout_misc_qe_rtic_aclk", "mout_misc_bus_user", 3284 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_RTIC_IPCLKPORT_ACLK, 3285 21, 0, 0), 3286 GATE(CLK_GOUT_MISC_QE_RTIC_PCLK, 3287 "gout_misc_qe_rtic_pclk", "dout_misc_busp", 3288 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_RTIC_IPCLKPORT_PCLK, 3289 21, 0, 0), 3290 GATE(CLK_GOUT_MISC_QE_SPDMA_ACLK, 3291 "gout_misc_qe_spdma_aclk", "mout_misc_bus_user", 3292 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SPDMA_IPCLKPORT_ACLK, 3293 21, 0, 0), 3294 GATE(CLK_GOUT_MISC_QE_SPDMA_PCLK, 3295 "gout_misc_qe_spdma_pclk", "dout_misc_busp", 3296 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SPDMA_IPCLKPORT_PCLK, 3297 21, 0, 0), 3298 GATE(CLK_GOUT_MISC_QE_SSS_ACLK, 3299 "gout_misc_qe_sss_aclk", "mout_misc_sss_user", 3300 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SSS_IPCLKPORT_ACLK, 3301 21, 0, 0), 3302 GATE(CLK_GOUT_MISC_QE_SSS_PCLK, 3303 "gout_misc_qe_sss_pclk", "dout_misc_busp", 3304 CLK_CON_GAT_GOUT_BLK_MISC_UID_QE_SSS_IPCLKPORT_PCLK, 3305 21, 0, 0), 3306 GATE(CLK_GOUT_MISC_CLK_MISC_BUSD_CLK, 3307 "gout_misc_clk_misc_busd_clk", "mout_misc_bus_user", 3308 CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_BUSD_IPCLKPORT_CLK, 3309 21, 0, 0), 3310 GATE(CLK_GOUT_MISC_CLK_MISC_BUSP_CLK, 3311 "gout_misc_clk_misc_busp_clk", "dout_misc_busp", 3312 CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_BUSP_IPCLKPORT_CLK, 3313 21, 0, 0), 3314 GATE(CLK_GOUT_MISC_CLK_MISC_GIC_CLK, 3315 "gout_misc_clk_misc_gic_clk", "mout_misc_gic", 3316 CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_GIC_IPCLKPORT_CLK, 3317 21, 0, 0), 3318 GATE(CLK_GOUT_MISC_CLK_MISC_SSS_CLK, 3319 "gout_misc_clk_misc_sss_clk", "mout_misc_sss_user", 3320 CLK_CON_GAT_GOUT_BLK_MISC_UID_RSTNSYNC_CLK_MISC_SSS_IPCLKPORT_CLK, 3321 21, 0, 0), 3322 GATE(CLK_GOUT_MISC_RTIC_I_ACLK, 3323 "gout_misc_rtic_i_aclk", "mout_misc_bus_user", 3324 CLK_CON_GAT_GOUT_BLK_MISC_UID_RTIC_IPCLKPORT_I_ACLK, 3325 21, 0, 0), 3326 GATE(CLK_GOUT_MISC_RTIC_I_PCLK, "gout_misc_rtic_i_pclk", 3327 "dout_misc_busp", 3328 CLK_CON_GAT_GOUT_BLK_MISC_UID_RTIC_IPCLKPORT_I_PCLK, 3329 21, 0, 0), 3330 GATE(CLK_GOUT_MISC_SPDMA_ACLK, 3331 "gout_misc_spdma_ipclockport_aclk", "mout_misc_bus_user", 3332 CLK_CON_GAT_GOUT_BLK_MISC_UID_SPDMA_IPCLKPORT_ACLK, 3333 21, 0, 0), 3334 GATE(CLK_GOUT_MISC_SSMT_DIT_ACLK, 3335 "gout_misc_ssmt_dit_aclk", "mout_misc_bus_user", 3336 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_DIT_IPCLKPORT_ACLK, 3337 21, 0, 0), 3338 GATE(CLK_GOUT_MISC_SSMT_DIT_PCLK, 3339 "gout_misc_ssmt_dit_pclk", "dout_misc_busp", 3340 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_DIT_IPCLKPORT_PCLK, 3341 21, 0, 0), 3342 GATE(CLK_GOUT_MISC_SSMT_PDMA_ACLK, 3343 "gout_misc_ssmt_pdma_aclk", "mout_misc_bus_user", 3344 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PDMA_IPCLKPORT_ACLK, 3345 21, 0, 0), 3346 GATE(CLK_GOUT_MISC_SSMT_PDMA_PCLK, 3347 "gout_misc_ssmt_pdma_pclk", "dout_misc_busp", 3348 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PDMA_IPCLKPORT_PCLK, 3349 21, 0, 0), 3350 GATE(CLK_GOUT_MISC_SSMT_PPMU_DMA_ACLK, 3351 "gout_misc_ssmt_ppmu_dma_aclk", "mout_misc_bus_user", 3352 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PPMU_DMA_IPCLKPORT_ACLK, 3353 21, 0, 0), 3354 GATE(CLK_GOUT_MISC_SSMT_PPMU_DMA_PCLK, 3355 "gout_misc_ssmt_ppmu_dma_pclk", "dout_misc_busp", 3356 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_PPMU_DMA_IPCLKPORT_PCLK, 3357 21, 0, 0), 3358 GATE(CLK_GOUT_MISC_SSMT_RTIC_ACLK, 3359 "gout_misc_ssmt_rtic_aclk", "mout_misc_bus_user", 3360 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_RTIC_IPCLKPORT_ACLK, 3361 21, 0, 0), 3362 GATE(CLK_GOUT_MISC_SSMT_RTIC_PCLK, 3363 "gout_misc_ssmt_rtic_pclk", "dout_misc_busp", 3364 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_RTIC_IPCLKPORT_PCLK, 3365 21, 0, 0), 3366 GATE(CLK_GOUT_MISC_SSMT_SPDMA_ACLK, 3367 "gout_misc_ssmt_spdma_aclk", "mout_misc_bus_user", 3368 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SPDMA_IPCLKPORT_ACLK, 3369 21, 0, 0), 3370 GATE(CLK_GOUT_MISC_SSMT_SPDMA_PCLK, 3371 "gout_misc_ssmt_spdma_pclk", "dout_misc_busp", 3372 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SPDMA_IPCLKPORT_PCLK, 3373 21, 0, 0), 3374 GATE(CLK_GOUT_MISC_SSMT_SSS_ACLK, 3375 "gout_misc_ssmt_sss_aclk", "mout_misc_bus_user", 3376 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SSS_IPCLKPORT_ACLK, 3377 21, 0, 0), 3378 GATE(CLK_GOUT_MISC_SSMT_SSS_PCLK, 3379 "gout_misc_ssmt_sss_pclk", "dout_misc_busp", 3380 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSMT_SSS_IPCLKPORT_PCLK, 3381 21, 0, 0), 3382 GATE(CLK_GOUT_MISC_SSS_I_ACLK, 3383 "gout_misc_sss_i_aclk", "mout_misc_bus_user", 3384 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSS_IPCLKPORT_I_ACLK, 3385 21, 0, 0), 3386 GATE(CLK_GOUT_MISC_SSS_I_PCLK, 3387 "gout_misc_sss_i_pclk", "dout_misc_busp", 3388 CLK_CON_GAT_GOUT_BLK_MISC_UID_SSS_IPCLKPORT_I_PCLK, 3389 21, 0, 0), 3390 GATE(CLK_GOUT_MISC_SYSMMU_MISC_CLK_S2, 3391 "gout_misc_sysmmu_misc_clk_s2", "mout_misc_bus_user", 3392 CLK_CON_GAT_GOUT_BLK_MISC_UID_SYSMMU_MISC_IPCLKPORT_CLK_S2, 3393 21, 0, 0), 3394 GATE(CLK_GOUT_MISC_SYSMMU_SSS_CLK_S1, 3395 "gout_misc_sysmmu_sss_clk_s1", "mout_misc_sss_user", 3396 CLK_CON_GAT_GOUT_BLK_MISC_UID_SYSMMU_SSS_IPCLKPORT_CLK_S1, 3397 21, 0, 0), 3398 GATE(CLK_GOUT_MISC_SYSREG_MISC_PCLK, 3399 "gout_misc_sysreg_misc_pclk", "dout_misc_busp", 3400 CLK_CON_GAT_GOUT_BLK_MISC_UID_SYSREG_MISC_IPCLKPORT_PCLK, 3401 21, 0, 0), 3402 GATE(CLK_GOUT_MISC_TMU_SUB_PCLK, 3403 "gout_misc_tmu_sub_pclk", "dout_misc_busp", 3404 CLK_CON_GAT_GOUT_BLK_MISC_UID_TMU_SUB_IPCLKPORT_PCLK, 3405 21, 0, 0), 3406 GATE(CLK_GOUT_MISC_TMU_TOP_PCLK, 3407 "gout_misc_tmu_top_pclk", "dout_misc_busp", 3408 CLK_CON_GAT_GOUT_BLK_MISC_UID_TMU_TOP_IPCLKPORT_PCLK, 3409 21, 0, 0), 3410 GATE(CLK_GOUT_MISC_WDT_CLUSTER0_PCLK, 3411 "gout_misc_wdt_cluster0_pclk", "dout_misc_busp", 3412 CLK_CON_GAT_GOUT_BLK_MISC_UID_WDT_CLUSTER0_IPCLKPORT_PCLK, 3413 21, 0, 0), 3414 GATE(CLK_GOUT_MISC_WDT_CLUSTER1_PCLK, 3415 "gout_misc_wdt_cluster1_pclk", "dout_misc_busp", 3416 CLK_CON_GAT_GOUT_BLK_MISC_UID_WDT_CLUSTER1_IPCLKPORT_PCLK, 3417 21, 0, 0), 3418 GATE(CLK_GOUT_MISC_XIU_D_MISC_ACLK, 3419 "gout_misc_xiu_d_misc_aclk", "mout_misc_bus_user", 3420 CLK_CON_GAT_GOUT_BLK_MISC_UID_XIU_D_MISC_IPCLKPORT_ACLK, 3421 21, 0, 0), 3422 }; 3423 3424 static const struct samsung_cmu_info misc_cmu_info __initconst = { 3425 .mux_clks = misc_mux_clks, 3426 .nr_mux_clks = ARRAY_SIZE(misc_mux_clks), 3427 .div_clks = misc_div_clks, 3428 .nr_div_clks = ARRAY_SIZE(misc_div_clks), 3429 .gate_clks = misc_gate_clks, 3430 .nr_gate_clks = ARRAY_SIZE(misc_gate_clks), 3431 .nr_clk_ids = CLKS_NR_MISC, 3432 .clk_regs = misc_clk_regs, 3433 .nr_clk_regs = ARRAY_SIZE(misc_clk_regs), 3434 .clk_name = "bus", 3435 }; 3436 3437 static void __init gs101_cmu_misc_init(struct device_node *np) 3438 { 3439 exynos_arm64_register_cmu(NULL, np, &misc_cmu_info); 3440 } 3441 3442 /* Register CMU_MISC early, as it's needed for MCT timer */ 3443 CLK_OF_DECLARE(gs101_cmu_misc, "google,gs101-cmu-misc", 3444 gs101_cmu_misc_init); 3445 3446 /* ---- CMU_PERIC0 ---------------------------------------------------------- */ 3447 3448 /* Register Offset definitions for CMU_PERIC0 (0x10800000) */ 3449 #define PLL_CON0_MUX_CLKCMU_PERIC0_BUS_USER 0x0600 3450 #define PLL_CON1_MUX_CLKCMU_PERIC0_BUS_USER 0x0604 3451 #define PLL_CON0_MUX_CLKCMU_PERIC0_I3C_USER 0x0610 3452 #define PLL_CON1_MUX_CLKCMU_PERIC0_I3C_USER 0x0614 3453 #define PLL_CON0_MUX_CLKCMU_PERIC0_USI0_UART_USER 0x0620 3454 #define PLL_CON1_MUX_CLKCMU_PERIC0_USI0_UART_USER 0x0624 3455 #define PLL_CON0_MUX_CLKCMU_PERIC0_USI14_USI_USER 0x0640 3456 #define PLL_CON1_MUX_CLKCMU_PERIC0_USI14_USI_USER 0x0644 3457 #define PLL_CON0_MUX_CLKCMU_PERIC0_USI1_USI_USER 0x0650 3458 #define PLL_CON1_MUX_CLKCMU_PERIC0_USI1_USI_USER 0x0654 3459 #define PLL_CON0_MUX_CLKCMU_PERIC0_USI2_USI_USER 0x0660 3460 #define PLL_CON1_MUX_CLKCMU_PERIC0_USI2_USI_USER 0x0664 3461 #define PLL_CON0_MUX_CLKCMU_PERIC0_USI3_USI_USER 0x0670 3462 #define PLL_CON1_MUX_CLKCMU_PERIC0_USI3_USI_USER 0x0674 3463 #define PLL_CON0_MUX_CLKCMU_PERIC0_USI4_USI_USER 0x0680 3464 #define PLL_CON1_MUX_CLKCMU_PERIC0_USI4_USI_USER 0x0684 3465 #define PLL_CON0_MUX_CLKCMU_PERIC0_USI5_USI_USER 0x0690 3466 #define PLL_CON1_MUX_CLKCMU_PERIC0_USI5_USI_USER 0x0694 3467 #define PLL_CON0_MUX_CLKCMU_PERIC0_USI6_USI_USER 0x06a0 3468 #define PLL_CON1_MUX_CLKCMU_PERIC0_USI6_USI_USER 0x06a4 3469 #define PLL_CON0_MUX_CLKCMU_PERIC0_USI7_USI_USER 0x06b0 3470 #define PLL_CON1_MUX_CLKCMU_PERIC0_USI7_USI_USER 0x06b4 3471 #define PLL_CON0_MUX_CLKCMU_PERIC0_USI8_USI_USER 0x06c0 3472 #define PLL_CON1_MUX_CLKCMU_PERIC0_USI8_USI_USER 0x06c4 3473 #define PERIC0_CMU_PERIC0_CONTROLLER_OPTION 0x0800 3474 #define CLKOUT_CON_BLK_PERIC0_CMU_PERIC0_CLKOUT0 0x0810 3475 #define CLK_CON_DIV_DIV_CLK_PERIC0_I3C 0x1800 3476 #define CLK_CON_DIV_DIV_CLK_PERIC0_USI0_UART 0x1804 3477 #define CLK_CON_DIV_DIV_CLK_PERIC0_USI14_USI 0x180c 3478 #define CLK_CON_DIV_DIV_CLK_PERIC0_USI1_USI 0x1810 3479 #define CLK_CON_DIV_DIV_CLK_PERIC0_USI2_USI 0x1814 3480 #define CLK_CON_DIV_DIV_CLK_PERIC0_USI3_USI 0x1820 3481 #define CLK_CON_DIV_DIV_CLK_PERIC0_USI4_USI 0x1824 3482 #define CLK_CON_DIV_DIV_CLK_PERIC0_USI5_USI 0x1828 3483 #define CLK_CON_DIV_DIV_CLK_PERIC0_USI6_USI 0x182c 3484 #define CLK_CON_DIV_DIV_CLK_PERIC0_USI7_USI 0x1830 3485 #define CLK_CON_DIV_DIV_CLK_PERIC0_USI8_USI 0x1834 3486 #define CLK_CON_BUF_CLKBUF_PERIC0_IP 0x2000 3487 #define CLK_CON_GAT_CLK_BLK_PERIC0_UID_PERIC0_CMU_PERIC0_IPCLKPORT_PCLK 0x2004 3488 #define CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_OSCCLK_IPCLKPORT_CLK 0x2008 3489 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_D_TZPC_PERIC0_IPCLKPORT_PCLK 0x200c 3490 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_GPC_PERIC0_IPCLKPORT_PCLK 0x2010 3491 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_GPIO_PERIC0_IPCLKPORT_PCLK 0x2014 3492 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_LHM_AXI_P_PERIC0_IPCLKPORT_I_CLK 0x2018 3493 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_0 0x201c 3494 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_1 0x2020 3495 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_10 0x2024 3496 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_11 0x2028 3497 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_12 0x202c 3498 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_13 0x2030 3499 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_14 0x2034 3500 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_15 0x2038 3501 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_2 0x203c 3502 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_3 0x2040 3503 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_4 0x2044 3504 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_5 0x2048 3505 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_6 0x204c 3506 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_7 0x2050 3507 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_8 0x2054 3508 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_9 0x2058 3509 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_0 0x205c 3510 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_1 0x2060 3511 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_10 0x2064 3512 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_11 0x2068 3513 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_12 0x206c 3514 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_13 0x2070 3515 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_14 0x2074 3516 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_15 0x2078 3517 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_2 0x207c 3518 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_3 0x2080 3519 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_4 0x2084 3520 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_5 0x2088 3521 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_6 0x208c 3522 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_7 0x2090 3523 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_8 0x2094 3524 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_9 0x2098 3525 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_IPCLK_0 0x209c 3526 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_IPCLK_2 0x20a4 3527 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_PCLK_0 0x20a8 3528 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_PCLK_2 0x20b0 3529 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_BUSP_IPCLKPORT_CLK 0x20b4 3530 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_I3C_IPCLKPORT_CLK 0x20b8 3531 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI0_UART_IPCLKPORT_CLK 0x20bc 3532 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI14_USI_IPCLKPORT_CLK 0x20c4 3533 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI1_USI_IPCLKPORT_CLK 0x20c8 3534 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI2_USI_IPCLKPORT_CLK 0x20cc 3535 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI3_USI_IPCLKPORT_CLK 0x20d0 3536 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI4_USI_IPCLKPORT_CLK 0x20d4 3537 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI5_USI_IPCLKPORT_CLK 0x20d8 3538 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI6_USI_IPCLKPORT_CLK 0x20dc 3539 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI7_USI_IPCLKPORT_CLK 0x20e0 3540 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI8_USI_IPCLKPORT_CLK 0x20e4 3541 #define CLK_CON_GAT_GOUT_BLK_PERIC0_UID_SYSREG_PERIC0_IPCLKPORT_PCLK 0x20e8 3542 #define DMYQCH_CON_PERIC0_TOP0_QCH_S1 0x3000 3543 #define DMYQCH_CON_PERIC0_TOP0_QCH_S2 0x3004 3544 #define DMYQCH_CON_PERIC0_TOP0_QCH_S3 0x3008 3545 #define DMYQCH_CON_PERIC0_TOP0_QCH_S4 0x300c 3546 #define DMYQCH_CON_PERIC0_TOP0_QCH_S5 0x3010 3547 #define DMYQCH_CON_PERIC0_TOP0_QCH_S6 0x3014 3548 #define DMYQCH_CON_PERIC0_TOP0_QCH_S7 0x3018 3549 #define DMYQCH_CON_PERIC0_TOP0_QCH_S8 0x301c 3550 #define PCH_CON_LHM_AXI_P_PERIC0_PCH 0x3020 3551 #define QCH_CON_D_TZPC_PERIC0_QCH 0x3024 3552 #define QCH_CON_GPC_PERIC0_QCH 0x3028 3553 #define QCH_CON_GPIO_PERIC0_QCH 0x302c 3554 #define QCH_CON_LHM_AXI_P_PERIC0_QCH 0x3030 3555 #define QCH_CON_PERIC0_CMU_PERIC0_QCH 0x3034 3556 #define QCH_CON_PERIC0_TOP0_QCH_I3C1 0x3038 3557 #define QCH_CON_PERIC0_TOP0_QCH_I3C2 0x303c 3558 #define QCH_CON_PERIC0_TOP0_QCH_I3C3 0x3040 3559 #define QCH_CON_PERIC0_TOP0_QCH_I3C4 0x3044 3560 #define QCH_CON_PERIC0_TOP0_QCH_I3C5 0x3048 3561 #define QCH_CON_PERIC0_TOP0_QCH_I3C6 0x304c 3562 #define QCH_CON_PERIC0_TOP0_QCH_I3C7 0x3050 3563 #define QCH_CON_PERIC0_TOP0_QCH_I3C8 0x3054 3564 #define QCH_CON_PERIC0_TOP0_QCH_USI1_USI 0x3058 3565 #define QCH_CON_PERIC0_TOP0_QCH_USI2_USI 0x305c 3566 #define QCH_CON_PERIC0_TOP0_QCH_USI3_USI 0x3060 3567 #define QCH_CON_PERIC0_TOP0_QCH_USI4_USI 0x3064 3568 #define QCH_CON_PERIC0_TOP0_QCH_USI5_USI 0x3068 3569 #define QCH_CON_PERIC0_TOP0_QCH_USI6_USI 0x306c 3570 #define QCH_CON_PERIC0_TOP0_QCH_USI7_USI 0x3070 3571 #define QCH_CON_PERIC0_TOP0_QCH_USI8_USI 0x3074 3572 #define QCH_CON_PERIC0_TOP1_QCH_USI0_UART 0x3078 3573 #define QCH_CON_PERIC0_TOP1_QCH_USI14_UART 0x307c 3574 #define QCH_CON_SYSREG_PERIC0_QCH 0x3080 3575 #define QUEUE_CTRL_REG_BLK_PERIC0_CMU_PERIC0 0x3c00 3576 3577 static const unsigned long peric0_clk_regs[] __initconst = { 3578 PLL_CON0_MUX_CLKCMU_PERIC0_BUS_USER, 3579 PLL_CON1_MUX_CLKCMU_PERIC0_BUS_USER, 3580 PLL_CON0_MUX_CLKCMU_PERIC0_I3C_USER, 3581 PLL_CON1_MUX_CLKCMU_PERIC0_I3C_USER, 3582 PLL_CON0_MUX_CLKCMU_PERIC0_USI0_UART_USER, 3583 PLL_CON1_MUX_CLKCMU_PERIC0_USI0_UART_USER, 3584 PLL_CON0_MUX_CLKCMU_PERIC0_USI14_USI_USER, 3585 PLL_CON1_MUX_CLKCMU_PERIC0_USI14_USI_USER, 3586 PLL_CON0_MUX_CLKCMU_PERIC0_USI1_USI_USER, 3587 PLL_CON1_MUX_CLKCMU_PERIC0_USI1_USI_USER, 3588 PLL_CON0_MUX_CLKCMU_PERIC0_USI2_USI_USER, 3589 PLL_CON1_MUX_CLKCMU_PERIC0_USI2_USI_USER, 3590 PLL_CON0_MUX_CLKCMU_PERIC0_USI3_USI_USER, 3591 PLL_CON1_MUX_CLKCMU_PERIC0_USI3_USI_USER, 3592 PLL_CON0_MUX_CLKCMU_PERIC0_USI4_USI_USER, 3593 PLL_CON1_MUX_CLKCMU_PERIC0_USI4_USI_USER, 3594 PLL_CON0_MUX_CLKCMU_PERIC0_USI5_USI_USER, 3595 PLL_CON1_MUX_CLKCMU_PERIC0_USI5_USI_USER, 3596 PLL_CON0_MUX_CLKCMU_PERIC0_USI6_USI_USER, 3597 PLL_CON1_MUX_CLKCMU_PERIC0_USI6_USI_USER, 3598 PLL_CON0_MUX_CLKCMU_PERIC0_USI7_USI_USER, 3599 PLL_CON1_MUX_CLKCMU_PERIC0_USI7_USI_USER, 3600 PLL_CON0_MUX_CLKCMU_PERIC0_USI8_USI_USER, 3601 PLL_CON1_MUX_CLKCMU_PERIC0_USI8_USI_USER, 3602 PERIC0_CMU_PERIC0_CONTROLLER_OPTION, 3603 CLKOUT_CON_BLK_PERIC0_CMU_PERIC0_CLKOUT0, 3604 CLK_CON_DIV_DIV_CLK_PERIC0_I3C, 3605 CLK_CON_DIV_DIV_CLK_PERIC0_USI0_UART, 3606 CLK_CON_DIV_DIV_CLK_PERIC0_USI14_USI, 3607 CLK_CON_DIV_DIV_CLK_PERIC0_USI1_USI, 3608 CLK_CON_DIV_DIV_CLK_PERIC0_USI2_USI, 3609 CLK_CON_DIV_DIV_CLK_PERIC0_USI3_USI, 3610 CLK_CON_DIV_DIV_CLK_PERIC0_USI4_USI, 3611 CLK_CON_DIV_DIV_CLK_PERIC0_USI5_USI, 3612 CLK_CON_DIV_DIV_CLK_PERIC0_USI6_USI, 3613 CLK_CON_DIV_DIV_CLK_PERIC0_USI6_USI, 3614 CLK_CON_DIV_DIV_CLK_PERIC0_USI8_USI, 3615 CLK_CON_BUF_CLKBUF_PERIC0_IP, 3616 CLK_CON_GAT_CLK_BLK_PERIC0_UID_PERIC0_CMU_PERIC0_IPCLKPORT_PCLK, 3617 CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_OSCCLK_IPCLKPORT_CLK, 3618 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_D_TZPC_PERIC0_IPCLKPORT_PCLK, 3619 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_GPC_PERIC0_IPCLKPORT_PCLK, 3620 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_GPIO_PERIC0_IPCLKPORT_PCLK, 3621 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_LHM_AXI_P_PERIC0_IPCLKPORT_I_CLK, 3622 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_0, 3623 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_1, 3624 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_10, 3625 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_11, 3626 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_12, 3627 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_13, 3628 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_14, 3629 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_15, 3630 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_2, 3631 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_3, 3632 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_4, 3633 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_5, 3634 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_6, 3635 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_7, 3636 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_8, 3637 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_9, 3638 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_0, 3639 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_1, 3640 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_10, 3641 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_11, 3642 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_12, 3643 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_13, 3644 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_14, 3645 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_15, 3646 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_2, 3647 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_3, 3648 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_4, 3649 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_5, 3650 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_6, 3651 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_7, 3652 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_8, 3653 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_9, 3654 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_IPCLK_0, 3655 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_IPCLK_2, 3656 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_PCLK_0, 3657 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_PCLK_2, 3658 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_BUSP_IPCLKPORT_CLK, 3659 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_I3C_IPCLKPORT_CLK, 3660 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI0_UART_IPCLKPORT_CLK, 3661 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI14_USI_IPCLKPORT_CLK, 3662 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI1_USI_IPCLKPORT_CLK, 3663 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI2_USI_IPCLKPORT_CLK, 3664 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI3_USI_IPCLKPORT_CLK, 3665 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI4_USI_IPCLKPORT_CLK, 3666 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI5_USI_IPCLKPORT_CLK, 3667 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI6_USI_IPCLKPORT_CLK, 3668 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI7_USI_IPCLKPORT_CLK, 3669 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI8_USI_IPCLKPORT_CLK, 3670 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_SYSREG_PERIC0_IPCLKPORT_PCLK, 3671 DMYQCH_CON_PERIC0_TOP0_QCH_S1, 3672 DMYQCH_CON_PERIC0_TOP0_QCH_S2, 3673 DMYQCH_CON_PERIC0_TOP0_QCH_S3, 3674 DMYQCH_CON_PERIC0_TOP0_QCH_S4, 3675 DMYQCH_CON_PERIC0_TOP0_QCH_S5, 3676 DMYQCH_CON_PERIC0_TOP0_QCH_S6, 3677 DMYQCH_CON_PERIC0_TOP0_QCH_S7, 3678 DMYQCH_CON_PERIC0_TOP0_QCH_S8, 3679 PCH_CON_LHM_AXI_P_PERIC0_PCH, 3680 QCH_CON_D_TZPC_PERIC0_QCH, 3681 QCH_CON_GPC_PERIC0_QCH, 3682 QCH_CON_GPIO_PERIC0_QCH, 3683 QCH_CON_LHM_AXI_P_PERIC0_QCH, 3684 QCH_CON_PERIC0_CMU_PERIC0_QCH, 3685 QCH_CON_PERIC0_TOP0_QCH_I3C1, 3686 QCH_CON_PERIC0_TOP0_QCH_I3C2, 3687 QCH_CON_PERIC0_TOP0_QCH_I3C3, 3688 QCH_CON_PERIC0_TOP0_QCH_I3C4, 3689 QCH_CON_PERIC0_TOP0_QCH_I3C5, 3690 QCH_CON_PERIC0_TOP0_QCH_I3C6, 3691 QCH_CON_PERIC0_TOP0_QCH_I3C7, 3692 QCH_CON_PERIC0_TOP0_QCH_I3C8, 3693 QCH_CON_PERIC0_TOP0_QCH_USI1_USI, 3694 QCH_CON_PERIC0_TOP0_QCH_USI2_USI, 3695 QCH_CON_PERIC0_TOP0_QCH_USI3_USI, 3696 QCH_CON_PERIC0_TOP0_QCH_USI4_USI, 3697 QCH_CON_PERIC0_TOP0_QCH_USI5_USI, 3698 QCH_CON_PERIC0_TOP0_QCH_USI6_USI, 3699 QCH_CON_PERIC0_TOP0_QCH_USI7_USI, 3700 QCH_CON_PERIC0_TOP0_QCH_USI8_USI, 3701 QCH_CON_PERIC0_TOP1_QCH_USI0_UART, 3702 QCH_CON_PERIC0_TOP1_QCH_USI14_UART, 3703 QCH_CON_SYSREG_PERIC0_QCH, 3704 QUEUE_CTRL_REG_BLK_PERIC0_CMU_PERIC0, 3705 }; 3706 3707 /* List of parent clocks for Muxes in CMU_PERIC0 */ 3708 PNAME(mout_peric0_bus_user_p) = { "oscclk", "dout_cmu_peric0_bus" }; 3709 PNAME(mout_peric0_i3c_user_p) = { "oscclk", "dout_cmu_peric0_ip" }; 3710 PNAME(mout_peric0_usi0_uart_user_p) = { "oscclk", "dout_cmu_peric0_ip" }; 3711 PNAME(mout_peric0_usi_usi_user_p) = { "oscclk", "dout_cmu_peric0_ip" }; 3712 3713 static const struct samsung_mux_clock peric0_mux_clks[] __initconst = { 3714 MUX(CLK_MOUT_PERIC0_BUS_USER, "mout_peric0_bus_user", 3715 mout_peric0_bus_user_p, PLL_CON0_MUX_CLKCMU_PERIC0_BUS_USER, 4, 1), 3716 MUX(CLK_MOUT_PERIC0_I3C_USER, "mout_peric0_i3c_user", 3717 mout_peric0_i3c_user_p, PLL_CON0_MUX_CLKCMU_PERIC0_I3C_USER, 4, 1), 3718 MUX(CLK_MOUT_PERIC0_USI0_UART_USER, 3719 "mout_peric0_usi0_uart_user", mout_peric0_usi0_uart_user_p, 3720 PLL_CON0_MUX_CLKCMU_PERIC0_USI0_UART_USER, 4, 1), 3721 nMUX(CLK_MOUT_PERIC0_USI14_USI_USER, 3722 "mout_peric0_usi14_usi_user", mout_peric0_usi_usi_user_p, 3723 PLL_CON0_MUX_CLKCMU_PERIC0_USI14_USI_USER, 4, 1), 3724 nMUX(CLK_MOUT_PERIC0_USI1_USI_USER, 3725 "mout_peric0_usi1_usi_user", mout_peric0_usi_usi_user_p, 3726 PLL_CON0_MUX_CLKCMU_PERIC0_USI1_USI_USER, 4, 1), 3727 nMUX(CLK_MOUT_PERIC0_USI2_USI_USER, 3728 "mout_peric0_usi2_usi_user", mout_peric0_usi_usi_user_p, 3729 PLL_CON0_MUX_CLKCMU_PERIC0_USI2_USI_USER, 4, 1), 3730 nMUX(CLK_MOUT_PERIC0_USI3_USI_USER, 3731 "mout_peric0_usi3_usi_user", mout_peric0_usi_usi_user_p, 3732 PLL_CON0_MUX_CLKCMU_PERIC0_USI3_USI_USER, 4, 1), 3733 nMUX(CLK_MOUT_PERIC0_USI4_USI_USER, 3734 "mout_peric0_usi4_usi_user", mout_peric0_usi_usi_user_p, 3735 PLL_CON0_MUX_CLKCMU_PERIC0_USI4_USI_USER, 4, 1), 3736 nMUX(CLK_MOUT_PERIC0_USI5_USI_USER, 3737 "mout_peric0_usi5_usi_user", mout_peric0_usi_usi_user_p, 3738 PLL_CON0_MUX_CLKCMU_PERIC0_USI5_USI_USER, 4, 1), 3739 nMUX(CLK_MOUT_PERIC0_USI6_USI_USER, 3740 "mout_peric0_usi6_usi_user", mout_peric0_usi_usi_user_p, 3741 PLL_CON0_MUX_CLKCMU_PERIC0_USI6_USI_USER, 4, 1), 3742 nMUX(CLK_MOUT_PERIC0_USI7_USI_USER, 3743 "mout_peric0_usi7_usi_user", mout_peric0_usi_usi_user_p, 3744 PLL_CON0_MUX_CLKCMU_PERIC0_USI7_USI_USER, 4, 1), 3745 nMUX(CLK_MOUT_PERIC0_USI8_USI_USER, 3746 "mout_peric0_usi8_usi_user", mout_peric0_usi_usi_user_p, 3747 PLL_CON0_MUX_CLKCMU_PERIC0_USI8_USI_USER, 4, 1), 3748 }; 3749 3750 static const struct samsung_div_clock peric0_div_clks[] __initconst = { 3751 DIV(CLK_DOUT_PERIC0_I3C, "dout_peric0_i3c", "mout_peric0_i3c_user", 3752 CLK_CON_DIV_DIV_CLK_PERIC0_I3C, 0, 4), 3753 DIV(CLK_DOUT_PERIC0_USI0_UART, 3754 "dout_peric0_usi0_uart", "mout_peric0_usi0_uart_user", 3755 CLK_CON_DIV_DIV_CLK_PERIC0_USI0_UART, 0, 4), 3756 DIV_F(CLK_DOUT_PERIC0_USI14_USI, 3757 "dout_peric0_usi14_usi", "mout_peric0_usi14_usi_user", 3758 CLK_CON_DIV_DIV_CLK_PERIC0_USI14_USI, 0, 4, 3759 CLK_SET_RATE_PARENT, 0), 3760 DIV_F(CLK_DOUT_PERIC0_USI1_USI, 3761 "dout_peric0_usi1_usi", "mout_peric0_usi1_usi_user", 3762 CLK_CON_DIV_DIV_CLK_PERIC0_USI1_USI, 0, 4, 3763 CLK_SET_RATE_PARENT, 0), 3764 DIV_F(CLK_DOUT_PERIC0_USI2_USI, 3765 "dout_peric0_usi2_usi", "mout_peric0_usi2_usi_user", 3766 CLK_CON_DIV_DIV_CLK_PERIC0_USI2_USI, 0, 4, 3767 CLK_SET_RATE_PARENT, 0), 3768 DIV_F(CLK_DOUT_PERIC0_USI3_USI, 3769 "dout_peric0_usi3_usi", "mout_peric0_usi3_usi_user", 3770 CLK_CON_DIV_DIV_CLK_PERIC0_USI3_USI, 0, 4, 3771 CLK_SET_RATE_PARENT, 0), 3772 DIV_F(CLK_DOUT_PERIC0_USI4_USI, 3773 "dout_peric0_usi4_usi", "mout_peric0_usi4_usi_user", 3774 CLK_CON_DIV_DIV_CLK_PERIC0_USI4_USI, 0, 4, 3775 CLK_SET_RATE_PARENT, 0), 3776 DIV_F(CLK_DOUT_PERIC0_USI5_USI, 3777 "dout_peric0_usi5_usi", "mout_peric0_usi5_usi_user", 3778 CLK_CON_DIV_DIV_CLK_PERIC0_USI5_USI, 0, 4, 3779 CLK_SET_RATE_PARENT, 0), 3780 DIV_F(CLK_DOUT_PERIC0_USI6_USI, 3781 "dout_peric0_usi6_usi", "mout_peric0_usi6_usi_user", 3782 CLK_CON_DIV_DIV_CLK_PERIC0_USI6_USI, 0, 4, 3783 CLK_SET_RATE_PARENT, 0), 3784 DIV_F(CLK_DOUT_PERIC0_USI7_USI, 3785 "dout_peric0_usi7_usi", "mout_peric0_usi7_usi_user", 3786 CLK_CON_DIV_DIV_CLK_PERIC0_USI7_USI, 0, 4, 3787 CLK_SET_RATE_PARENT, 0), 3788 DIV_F(CLK_DOUT_PERIC0_USI8_USI, 3789 "dout_peric0_usi8_usi", "mout_peric0_usi8_usi_user", 3790 CLK_CON_DIV_DIV_CLK_PERIC0_USI8_USI, 0, 4, 3791 CLK_SET_RATE_PARENT, 0), 3792 }; 3793 3794 static const struct samsung_gate_clock peric0_gate_clks[] __initconst = { 3795 /* Disabling this clock makes the system hang. Mark the clock as critical. */ 3796 GATE(CLK_GOUT_PERIC0_PERIC0_CMU_PERIC0_PCLK, 3797 "gout_peric0_peric0_cmu_peric0_pclk", "mout_peric0_bus_user", 3798 CLK_CON_GAT_CLK_BLK_PERIC0_UID_PERIC0_CMU_PERIC0_IPCLKPORT_PCLK, 3799 21, CLK_IS_CRITICAL, 0), 3800 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_OSCCLK_CLK, 3801 "gout_peric0_clk_peric0_oscclk_clk", "oscclk", 3802 CLK_CON_GAT_CLK_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_OSCCLK_IPCLKPORT_CLK, 3803 21, 0, 0), 3804 GATE(CLK_GOUT_PERIC0_D_TZPC_PERIC0_PCLK, 3805 "gout_peric0_d_tzpc_peric0_pclk", "mout_peric0_bus_user", 3806 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_D_TZPC_PERIC0_IPCLKPORT_PCLK, 3807 21, 0, 0), 3808 GATE(CLK_GOUT_PERIC0_GPC_PERIC0_PCLK, 3809 "gout_peric0_gpc_peric0_pclk", "mout_peric0_bus_user", 3810 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_GPC_PERIC0_IPCLKPORT_PCLK, 3811 21, 0, 0), 3812 GATE(CLK_GOUT_PERIC0_GPIO_PERIC0_PCLK, 3813 "gout_peric0_gpio_peric0_pclk", "mout_peric0_bus_user", 3814 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_GPIO_PERIC0_IPCLKPORT_PCLK, 3815 21, CLK_IGNORE_UNUSED, 0), 3816 /* Disabling this clock makes the system hang. Mark the clock as critical. */ 3817 GATE(CLK_GOUT_PERIC0_LHM_AXI_P_PERIC0_I_CLK, 3818 "gout_peric0_lhm_axi_p_peric0_i_clk", "mout_peric0_bus_user", 3819 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_LHM_AXI_P_PERIC0_IPCLKPORT_I_CLK, 3820 21, CLK_IS_CRITICAL, 0), 3821 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_0, 3822 "gout_peric0_peric0_top0_ipclk_0", "dout_peric0_usi1_usi", 3823 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_0, 3824 21, CLK_SET_RATE_PARENT, 0), 3825 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_1, 3826 "gout_peric0_peric0_top0_ipclk_1", "dout_peric0_usi2_usi", 3827 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_1, 3828 21, CLK_SET_RATE_PARENT, 0), 3829 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_10, 3830 "gout_peric0_peric0_top0_ipclk_10", "dout_peric0_i3c", 3831 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_10, 3832 21, 0, 0), 3833 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_11, 3834 "gout_peric0_peric0_top0_ipclk_11", "dout_peric0_i3c", 3835 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_11, 3836 21, 0, 0), 3837 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_12, 3838 "gout_peric0_peric0_top0_ipclk_12", "dout_peric0_i3c", 3839 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_12, 3840 21, 0, 0), 3841 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_13, 3842 "gout_peric0_peric0_top0_ipclk_13", "dout_peric0_i3c", 3843 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_13, 3844 21, 0, 0), 3845 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_14, 3846 "gout_peric0_peric0_top0_ipclk_14", "dout_peric0_i3c", 3847 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_14, 3848 21, 0, 0), 3849 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_15, 3850 "gout_peric0_peric0_top0_ipclk_15", "dout_peric0_i3c", 3851 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_15, 3852 21, 0, 0), 3853 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_2, 3854 "gout_peric0_peric0_top0_ipclk_2", "dout_peric0_usi3_usi", 3855 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_2, 3856 21, CLK_SET_RATE_PARENT, 0), 3857 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_3, 3858 "gout_peric0_peric0_top0_ipclk_3", "dout_peric0_usi4_usi", 3859 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_3, 3860 21, CLK_SET_RATE_PARENT, 0), 3861 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_4, 3862 "gout_peric0_peric0_top0_ipclk_4", "dout_peric0_usi5_usi", 3863 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_4, 3864 21, CLK_SET_RATE_PARENT, 0), 3865 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_5, 3866 "gout_peric0_peric0_top0_ipclk_5", "dout_peric0_usi6_usi", 3867 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_5, 3868 21, CLK_SET_RATE_PARENT, 0), 3869 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_6, 3870 "gout_peric0_peric0_top0_ipclk_6", "dout_peric0_usi7_usi", 3871 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_6, 3872 21, CLK_SET_RATE_PARENT, 0), 3873 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_7, 3874 "gout_peric0_peric0_top0_ipclk_7", "dout_peric0_usi8_usi", 3875 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_7, 3876 21, CLK_SET_RATE_PARENT, 0), 3877 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_8, 3878 "gout_peric0_peric0_top0_ipclk_8", "dout_peric0_i3c", 3879 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_8, 3880 21, 0, 0), 3881 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_IPCLK_9, 3882 "gout_peric0_peric0_top0_ipclk_9", "dout_peric0_i3c", 3883 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_IPCLK_9, 3884 21, 0, 0), 3885 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_0, 3886 "gout_peric0_peric0_top0_pclk_0", "mout_peric0_bus_user", 3887 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_0, 3888 21, 0, 0), 3889 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_1, 3890 "gout_peric0_peric0_top0_pclk_1", "mout_peric0_bus_user", 3891 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_1, 3892 21, 0, 0), 3893 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_10, 3894 "gout_peric0_peric0_top0_pclk_10", "mout_peric0_bus_user", 3895 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_10, 3896 21, 0, 0), 3897 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_11, 3898 "gout_peric0_peric0_top0_pclk_11", "mout_peric0_bus_user", 3899 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_11, 3900 21, 0, 0), 3901 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_12, 3902 "gout_peric0_peric0_top0_pclk_12", "mout_peric0_bus_user", 3903 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_12, 3904 21, 0, 0), 3905 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_13, 3906 "gout_peric0_peric0_top0_pclk_13", "mout_peric0_bus_user", 3907 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_13, 3908 21, 0, 0), 3909 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_14, 3910 "gout_peric0_peric0_top0_pclk_14", "mout_peric0_bus_user", 3911 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_14, 3912 21, 0, 0), 3913 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_15, 3914 "gout_peric0_peric0_top0_pclk_15", "mout_peric0_bus_user", 3915 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_15, 3916 21, 0, 0), 3917 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_2, 3918 "gout_peric0_peric0_top0_pclk_2", "mout_peric0_bus_user", 3919 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_2, 3920 21, 0, 0), 3921 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_3, 3922 "gout_peric0_peric0_top0_pclk_3", "mout_peric0_bus_user", 3923 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_3, 3924 21, 0, 0), 3925 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_4, 3926 "gout_peric0_peric0_top0_pclk_4", "mout_peric0_bus_user", 3927 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_4, 3928 21, 0, 0), 3929 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_5, 3930 "gout_peric0_peric0_top0_pclk_5", "mout_peric0_bus_user", 3931 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_5, 3932 21, 0, 0), 3933 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_6, 3934 "gout_peric0_peric0_top0_pclk_6", "mout_peric0_bus_user", 3935 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_6, 3936 21, 0, 0), 3937 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_7, 3938 "gout_peric0_peric0_top0_pclk_7", "mout_peric0_bus_user", 3939 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_7, 3940 21, 0, 0), 3941 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_8, 3942 "gout_peric0_peric0_top0_pclk_8", "mout_peric0_bus_user", 3943 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_8, 3944 21, 0, 0), 3945 GATE(CLK_GOUT_PERIC0_PERIC0_TOP0_PCLK_9, 3946 "gout_peric0_peric0_top0_pclk_9", "mout_peric0_bus_user", 3947 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP0_IPCLKPORT_PCLK_9, 3948 21, 0, 0), 3949 /* Disabling this clock makes the system hang. Mark the clock as critical. */ 3950 GATE(CLK_GOUT_PERIC0_PERIC0_TOP1_IPCLK_0, 3951 "gout_peric0_peric0_top1_ipclk_0", "dout_peric0_usi0_uart", 3952 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_IPCLK_0, 3953 21, CLK_IS_CRITICAL, 0), 3954 GATE(CLK_GOUT_PERIC0_PERIC0_TOP1_IPCLK_2, 3955 "gout_peric0_peric0_top1_ipclk_2", "dout_peric0_usi14_usi", 3956 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_IPCLK_2, 3957 21, CLK_SET_RATE_PARENT, 0), 3958 /* Disabling this clock makes the system hang. Mark the clock as critical. */ 3959 GATE(CLK_GOUT_PERIC0_PERIC0_TOP1_PCLK_0, 3960 "gout_peric0_peric0_top1_pclk_0", "mout_peric0_bus_user", 3961 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_PCLK_0, 3962 21, CLK_IS_CRITICAL, 0), 3963 GATE(CLK_GOUT_PERIC0_PERIC0_TOP1_PCLK_2, 3964 "gout_peric0_peric0_top1_pclk_2", "mout_peric0_bus_user", 3965 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_PERIC0_TOP1_IPCLKPORT_PCLK_2, 3966 21, 0, 0), 3967 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_BUSP_CLK, 3968 "gout_peric0_clk_peric0_busp_clk", "mout_peric0_bus_user", 3969 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_BUSP_IPCLKPORT_CLK, 3970 21, 0, 0), 3971 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_I3C_CLK, 3972 "gout_peric0_clk_peric0_i3c_clk", "dout_peric0_i3c", 3973 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_I3C_IPCLKPORT_CLK, 3974 21, 0, 0), 3975 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_USI0_UART_CLK, 3976 "gout_peric0_clk_peric0_usi0_uart_clk", "dout_peric0_usi0_uart", 3977 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI0_UART_IPCLKPORT_CLK, 3978 21, 0, 0), 3979 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_USI14_USI_CLK, 3980 "gout_peric0_clk_peric0_usi14_usi_clk", "dout_peric0_usi14_usi", 3981 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI14_USI_IPCLKPORT_CLK, 3982 21, 0, 0), 3983 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_USI1_USI_CLK, 3984 "gout_peric0_clk_peric0_usi1_usi_clk", "dout_peric0_usi1_usi", 3985 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI1_USI_IPCLKPORT_CLK, 3986 21, 0, 0), 3987 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_USI2_USI_CLK, 3988 "gout_peric0_clk_peric0_usi2_usi_clk", "dout_peric0_usi2_usi", 3989 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI2_USI_IPCLKPORT_CLK, 3990 21, 0, 0), 3991 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_USI3_USI_CLK, 3992 "gout_peric0_clk_peric0_usi3_usi_clk", "dout_peric0_usi3_usi", 3993 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI3_USI_IPCLKPORT_CLK, 3994 21, 0, 0), 3995 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_USI4_USI_CLK, 3996 "gout_peric0_clk_peric0_usi4_usi_clk", "dout_peric0_usi4_usi", 3997 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI4_USI_IPCLKPORT_CLK, 3998 21, 0, 0), 3999 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_USI5_USI_CLK, 4000 "gout_peric0_clk_peric0_usi5_usi_clk", "dout_peric0_usi5_usi", 4001 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI5_USI_IPCLKPORT_CLK, 4002 21, 0, 0), 4003 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_USI6_USI_CLK, 4004 "gout_peric0_clk_peric0_usi6_usi_clk", "dout_peric0_usi6_usi", 4005 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI6_USI_IPCLKPORT_CLK, 4006 21, 0, 0), 4007 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_USI7_USI_CLK, 4008 "gout_peric0_clk_peric0_usi7_usi_clk", "dout_peric0_usi7_usi", 4009 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI7_USI_IPCLKPORT_CLK, 4010 21, 0, 0), 4011 GATE(CLK_GOUT_PERIC0_CLK_PERIC0_USI8_USI_CLK, 4012 "gout_peric0_clk_peric0_usi8_usi_clk", "dout_peric0_usi8_usi", 4013 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_RSTNSYNC_CLK_PERIC0_USI8_USI_IPCLKPORT_CLK, 4014 21, 0, 0), 4015 GATE(CLK_GOUT_PERIC0_SYSREG_PERIC0_PCLK, 4016 "gout_peric0_sysreg_peric0_pclk", "mout_peric0_bus_user", 4017 CLK_CON_GAT_GOUT_BLK_PERIC0_UID_SYSREG_PERIC0_IPCLKPORT_PCLK, 4018 21, 0, 0), 4019 }; 4020 4021 static const struct samsung_cmu_info peric0_cmu_info __initconst = { 4022 .mux_clks = peric0_mux_clks, 4023 .nr_mux_clks = ARRAY_SIZE(peric0_mux_clks), 4024 .div_clks = peric0_div_clks, 4025 .nr_div_clks = ARRAY_SIZE(peric0_div_clks), 4026 .gate_clks = peric0_gate_clks, 4027 .nr_gate_clks = ARRAY_SIZE(peric0_gate_clks), 4028 .nr_clk_ids = CLKS_NR_PERIC0, 4029 .clk_regs = peric0_clk_regs, 4030 .nr_clk_regs = ARRAY_SIZE(peric0_clk_regs), 4031 .clk_name = "bus", 4032 }; 4033 4034 /* ---- CMU_PERIC1 ---------------------------------------------------------- */ 4035 4036 /* Register Offset definitions for CMU_PERIC1 (0x10c00000) */ 4037 #define PLL_CON0_MUX_CLKCMU_PERIC1_BUS_USER 0x0600 4038 #define PLL_CON1_MUX_CLKCMU_PERIC1_BUS_USER 0x0604 4039 #define PLL_CON0_MUX_CLKCMU_PERIC1_I3C_USER 0x0610 4040 #define PLL_CON1_MUX_CLKCMU_PERIC1_I3C_USER 0x0614 4041 #define PLL_CON0_MUX_CLKCMU_PERIC1_USI0_USI_USER 0x0620 4042 #define PLL_CON1_MUX_CLKCMU_PERIC1_USI0_USI_USER 0x0624 4043 #define PLL_CON0_MUX_CLKCMU_PERIC1_USI10_USI_USER 0x0630 4044 #define PLL_CON1_MUX_CLKCMU_PERIC1_USI10_USI_USER 0x0634 4045 #define PLL_CON0_MUX_CLKCMU_PERIC1_USI11_USI_USER 0x0640 4046 #define PLL_CON1_MUX_CLKCMU_PERIC1_USI11_USI_USER 0x0644 4047 #define PLL_CON0_MUX_CLKCMU_PERIC1_USI12_USI_USER 0x0650 4048 #define PLL_CON1_MUX_CLKCMU_PERIC1_USI12_USI_USER 0x0654 4049 #define PLL_CON0_MUX_CLKCMU_PERIC1_USI13_USI_USER 0x0660 4050 #define PLL_CON1_MUX_CLKCMU_PERIC1_USI13_USI_USER 0x0664 4051 #define PLL_CON0_MUX_CLKCMU_PERIC1_USI9_USI_USER 0x0670 4052 #define PLL_CON1_MUX_CLKCMU_PERIC1_USI9_USI_USER 0x0674 4053 #define PERIC1_CMU_PERIC1_CONTROLLER_OPTION 0x0800 4054 #define CLKOUT_CON_BLK_PERIC1_CMU_PERIC1_CLKOUT0 0x0810 4055 #define CLK_CON_DIV_DIV_CLK_PERIC1_I3C 0x1800 4056 #define CLK_CON_DIV_DIV_CLK_PERIC1_USI0_USI 0x1804 4057 #define CLK_CON_DIV_DIV_CLK_PERIC1_USI10_USI 0x1808 4058 #define CLK_CON_DIV_DIV_CLK_PERIC1_USI11_USI 0x180c 4059 #define CLK_CON_DIV_DIV_CLK_PERIC1_USI12_USI 0x1810 4060 #define CLK_CON_DIV_DIV_CLK_PERIC1_USI13_USI 0x1814 4061 #define CLK_CON_DIV_DIV_CLK_PERIC1_USI9_USI 0x1818 4062 #define CLK_CON_BUF_CLKBUF_PERIC1_IP 0x2000 4063 #define CLK_CON_GAT_CLK_BLK_PERIC1_UID_PERIC1_CMU_PERIC1_IPCLKPORT_PCLK 0x2004 4064 #define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_I3C_IPCLKPORT_CLK 0x2008 4065 #define CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_OSCCLK_IPCLKPORT_CLK 0x200c 4066 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_D_TZPC_PERIC1_IPCLKPORT_PCLK 0x2010 4067 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_GPC_PERIC1_IPCLKPORT_PCLK 0x2014 4068 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_GPIO_PERIC1_IPCLKPORT_PCLK 0x2018 4069 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_LHM_AXI_P_PERIC1_IPCLKPORT_I_CLK 0x201c 4070 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_1 0x2020 4071 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_2 0x2024 4072 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_3 0x2028 4073 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_4 0x202c 4074 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_5 0x2030 4075 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_6 0x2034 4076 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_8 0x2038 4077 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_1 0x203c 4078 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_15 0x2040 4079 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_2 0x2044 4080 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_3 0x2048 4081 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_4 0x204c 4082 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_5 0x2050 4083 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_6 0x2054 4084 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_8 0x2058 4085 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_BUSP_IPCLKPORT_CLK 0x205c 4086 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI0_USI_IPCLKPORT_CLK 0x2060 4087 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI10_USI_IPCLKPORT_CLK 0x2064 4088 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI11_USI_IPCLKPORT_CLK 0x2068 4089 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI12_USI_IPCLKPORT_CLK 0x206c 4090 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI13_USI_IPCLKPORT_CLK 0x2070 4091 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI9_USI_IPCLKPORT_CLK 0x2074 4092 #define CLK_CON_GAT_GOUT_BLK_PERIC1_UID_SYSREG_PERIC1_IPCLKPORT_PCLK 0x2078 4093 #define DMYQCH_CON_PERIC1_TOP0_QCH_S 0x3000 4094 #define PCH_CON_LHM_AXI_P_PERIC1_PCH 0x3004 4095 #define QCH_CON_D_TZPC_PERIC1_QCH 0x3008 4096 #define QCH_CON_GPC_PERIC1_QCH 0x300c 4097 #define QCH_CON_GPIO_PERIC1_QCH 0x3010 4098 #define QCH_CON_LHM_AXI_P_PERIC1_QCH 0x3014 4099 #define QCH_CON_PERIC1_CMU_PERIC1_QCH 0x3018 4100 #define QCH_CON_PERIC1_TOP0_QCH_I3C0 0x301c 4101 #define QCH_CON_PERIC1_TOP0_QCH_PWM 0x3020 4102 #define QCH_CON_PERIC1_TOP0_QCH_USI0_USI 0x3024 4103 #define QCH_CON_PERIC1_TOP0_QCH_USI10_USI 0x3028 4104 #define QCH_CON_PERIC1_TOP0_QCH_USI11_USI 0x302c 4105 #define QCH_CON_PERIC1_TOP0_QCH_USI12_USI 0x3030 4106 #define QCH_CON_PERIC1_TOP0_QCH_USI13_USI 0x3034 4107 #define QCH_CON_PERIC1_TOP0_QCH_USI9_USI 0x3038 4108 #define QCH_CON_SYSREG_PERIC1_QCH 0x303c 4109 #define QUEUE_CTRL_REG_BLK_PERIC1_CMU_PERIC1 0x3c00 4110 4111 static const unsigned long peric1_clk_regs[] __initconst = { 4112 PLL_CON0_MUX_CLKCMU_PERIC1_BUS_USER, 4113 PLL_CON1_MUX_CLKCMU_PERIC1_BUS_USER, 4114 PLL_CON0_MUX_CLKCMU_PERIC1_I3C_USER, 4115 PLL_CON1_MUX_CLKCMU_PERIC1_I3C_USER, 4116 PLL_CON0_MUX_CLKCMU_PERIC1_USI0_USI_USER, 4117 PLL_CON1_MUX_CLKCMU_PERIC1_USI0_USI_USER, 4118 PLL_CON0_MUX_CLKCMU_PERIC1_USI10_USI_USER, 4119 PLL_CON1_MUX_CLKCMU_PERIC1_USI10_USI_USER, 4120 PLL_CON0_MUX_CLKCMU_PERIC1_USI11_USI_USER, 4121 PLL_CON1_MUX_CLKCMU_PERIC1_USI11_USI_USER, 4122 PLL_CON0_MUX_CLKCMU_PERIC1_USI12_USI_USER, 4123 PLL_CON1_MUX_CLKCMU_PERIC1_USI12_USI_USER, 4124 PLL_CON0_MUX_CLKCMU_PERIC1_USI13_USI_USER, 4125 PLL_CON1_MUX_CLKCMU_PERIC1_USI13_USI_USER, 4126 PLL_CON0_MUX_CLKCMU_PERIC1_USI9_USI_USER, 4127 PLL_CON1_MUX_CLKCMU_PERIC1_USI9_USI_USER, 4128 PERIC1_CMU_PERIC1_CONTROLLER_OPTION, 4129 CLKOUT_CON_BLK_PERIC1_CMU_PERIC1_CLKOUT0, 4130 CLK_CON_DIV_DIV_CLK_PERIC1_I3C, 4131 CLK_CON_DIV_DIV_CLK_PERIC1_USI0_USI, 4132 CLK_CON_DIV_DIV_CLK_PERIC1_USI10_USI, 4133 CLK_CON_DIV_DIV_CLK_PERIC1_USI11_USI, 4134 CLK_CON_DIV_DIV_CLK_PERIC1_USI12_USI, 4135 CLK_CON_DIV_DIV_CLK_PERIC1_USI13_USI, 4136 CLK_CON_DIV_DIV_CLK_PERIC1_USI9_USI, 4137 CLK_CON_BUF_CLKBUF_PERIC1_IP, 4138 CLK_CON_GAT_CLK_BLK_PERIC1_UID_PERIC1_CMU_PERIC1_IPCLKPORT_PCLK, 4139 CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_I3C_IPCLKPORT_CLK, 4140 CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_OSCCLK_IPCLKPORT_CLK, 4141 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_D_TZPC_PERIC1_IPCLKPORT_PCLK, 4142 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_GPC_PERIC1_IPCLKPORT_PCLK, 4143 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_GPIO_PERIC1_IPCLKPORT_PCLK, 4144 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_LHM_AXI_P_PERIC1_IPCLKPORT_I_CLK, 4145 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_1, 4146 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_2, 4147 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_3, 4148 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_4, 4149 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_5, 4150 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_6, 4151 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_8, 4152 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_1, 4153 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_15, 4154 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_2, 4155 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_3, 4156 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_4, 4157 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_5, 4158 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_6, 4159 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_8, 4160 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_BUSP_IPCLKPORT_CLK, 4161 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI0_USI_IPCLKPORT_CLK, 4162 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI10_USI_IPCLKPORT_CLK, 4163 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI11_USI_IPCLKPORT_CLK, 4164 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI12_USI_IPCLKPORT_CLK, 4165 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI13_USI_IPCLKPORT_CLK, 4166 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI9_USI_IPCLKPORT_CLK, 4167 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_SYSREG_PERIC1_IPCLKPORT_PCLK, 4168 DMYQCH_CON_PERIC1_TOP0_QCH_S, 4169 PCH_CON_LHM_AXI_P_PERIC1_PCH, 4170 QCH_CON_D_TZPC_PERIC1_QCH, 4171 QCH_CON_GPC_PERIC1_QCH, 4172 QCH_CON_GPIO_PERIC1_QCH, 4173 QCH_CON_LHM_AXI_P_PERIC1_QCH, 4174 QCH_CON_PERIC1_CMU_PERIC1_QCH, 4175 QCH_CON_PERIC1_TOP0_QCH_I3C0, 4176 QCH_CON_PERIC1_TOP0_QCH_PWM, 4177 QCH_CON_PERIC1_TOP0_QCH_USI0_USI, 4178 QCH_CON_PERIC1_TOP0_QCH_USI10_USI, 4179 QCH_CON_PERIC1_TOP0_QCH_USI11_USI, 4180 QCH_CON_PERIC1_TOP0_QCH_USI12_USI, 4181 QCH_CON_PERIC1_TOP0_QCH_USI13_USI, 4182 QCH_CON_PERIC1_TOP0_QCH_USI9_USI, 4183 QCH_CON_SYSREG_PERIC1_QCH, 4184 QUEUE_CTRL_REG_BLK_PERIC1_CMU_PERIC1, 4185 }; 4186 4187 /* List of parent clocks for Muxes in CMU_PERIC1 */ 4188 PNAME(mout_peric1_bus_user_p) = { "oscclk", "dout_cmu_peric1_bus" }; 4189 PNAME(mout_peric1_nonbususer_p) = { "oscclk", "dout_cmu_peric1_ip" }; 4190 4191 static const struct samsung_mux_clock peric1_mux_clks[] __initconst = { 4192 MUX(CLK_MOUT_PERIC1_BUS_USER, "mout_peric1_bus_user", 4193 mout_peric1_bus_user_p, PLL_CON0_MUX_CLKCMU_PERIC1_BUS_USER, 4, 1), 4194 MUX(CLK_MOUT_PERIC1_I3C_USER, 4195 "mout_peric1_i3c_user", mout_peric1_nonbususer_p, 4196 PLL_CON0_MUX_CLKCMU_PERIC1_I3C_USER, 4, 1), 4197 nMUX(CLK_MOUT_PERIC1_USI0_USI_USER, 4198 "mout_peric1_usi0_usi_user", mout_peric1_nonbususer_p, 4199 PLL_CON0_MUX_CLKCMU_PERIC1_USI0_USI_USER, 4, 1), 4200 nMUX(CLK_MOUT_PERIC1_USI10_USI_USER, 4201 "mout_peric1_usi10_usi_user", mout_peric1_nonbususer_p, 4202 PLL_CON0_MUX_CLKCMU_PERIC1_USI10_USI_USER, 4, 1), 4203 nMUX(CLK_MOUT_PERIC1_USI11_USI_USER, 4204 "mout_peric1_usi11_usi_user", mout_peric1_nonbususer_p, 4205 PLL_CON0_MUX_CLKCMU_PERIC1_USI11_USI_USER, 4, 1), 4206 nMUX(CLK_MOUT_PERIC1_USI12_USI_USER, 4207 "mout_peric1_usi12_usi_user", mout_peric1_nonbususer_p, 4208 PLL_CON0_MUX_CLKCMU_PERIC1_USI12_USI_USER, 4, 1), 4209 nMUX(CLK_MOUT_PERIC1_USI13_USI_USER, 4210 "mout_peric1_usi13_usi_user", mout_peric1_nonbususer_p, 4211 PLL_CON0_MUX_CLKCMU_PERIC1_USI13_USI_USER, 4, 1), 4212 nMUX(CLK_MOUT_PERIC1_USI9_USI_USER, 4213 "mout_peric1_usi9_usi_user", mout_peric1_nonbususer_p, 4214 PLL_CON0_MUX_CLKCMU_PERIC1_USI9_USI_USER, 4, 1), 4215 }; 4216 4217 static const struct samsung_div_clock peric1_div_clks[] __initconst = { 4218 DIV(CLK_DOUT_PERIC1_I3C, "dout_peric1_i3c", "mout_peric1_i3c_user", 4219 CLK_CON_DIV_DIV_CLK_PERIC1_I3C, 0, 4), 4220 DIV_F(CLK_DOUT_PERIC1_USI0_USI, 4221 "dout_peric1_usi0_usi", "mout_peric1_usi0_usi_user", 4222 CLK_CON_DIV_DIV_CLK_PERIC1_USI0_USI, 0, 4, 4223 CLK_SET_RATE_PARENT, 0), 4224 DIV_F(CLK_DOUT_PERIC1_USI10_USI, 4225 "dout_peric1_usi10_usi", "mout_peric1_usi10_usi_user", 4226 CLK_CON_DIV_DIV_CLK_PERIC1_USI10_USI, 0, 4, 4227 CLK_SET_RATE_PARENT, 0), 4228 DIV_F(CLK_DOUT_PERIC1_USI11_USI, 4229 "dout_peric1_usi11_usi", "mout_peric1_usi11_usi_user", 4230 CLK_CON_DIV_DIV_CLK_PERIC1_USI11_USI, 0, 4, 4231 CLK_SET_RATE_PARENT, 0), 4232 DIV_F(CLK_DOUT_PERIC1_USI12_USI, 4233 "dout_peric1_usi12_usi", "mout_peric1_usi12_usi_user", 4234 CLK_CON_DIV_DIV_CLK_PERIC1_USI12_USI, 0, 4, 4235 CLK_SET_RATE_PARENT, 0), 4236 DIV_F(CLK_DOUT_PERIC1_USI13_USI, 4237 "dout_peric1_usi13_usi", "mout_peric1_usi13_usi_user", 4238 CLK_CON_DIV_DIV_CLK_PERIC1_USI13_USI, 0, 4, 4239 CLK_SET_RATE_PARENT, 0), 4240 DIV_F(CLK_DOUT_PERIC1_USI9_USI, 4241 "dout_peric1_usi9_usi", "mout_peric1_usi9_usi_user", 4242 CLK_CON_DIV_DIV_CLK_PERIC1_USI9_USI, 0, 4, 4243 CLK_SET_RATE_PARENT, 0), 4244 }; 4245 4246 static const struct samsung_gate_clock peric1_gate_clks[] __initconst = { 4247 GATE(CLK_GOUT_PERIC1_PCLK, 4248 "gout_peric1_peric1_pclk", "mout_peric1_bus_user", 4249 CLK_CON_GAT_CLK_BLK_PERIC1_UID_PERIC1_CMU_PERIC1_IPCLKPORT_PCLK, 4250 21, CLK_IS_CRITICAL, 0), 4251 GATE(CLK_GOUT_PERIC1_CLK_PERIC1_I3C_CLK, 4252 "gout_peric1_clk_peric1_i3c_clk", "dout_peric1_i3c", 4253 CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_I3C_IPCLKPORT_CLK, 4254 21, 0, 0), 4255 GATE(CLK_GOUT_PERIC1_CLK_PERIC1_OSCCLK_CLK, 4256 "gout_peric1_clk_peric1_oscclk_clk", "oscclk", 4257 CLK_CON_GAT_CLK_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_OSCCLK_IPCLKPORT_CLK, 4258 21, 0, 0), 4259 GATE(CLK_GOUT_PERIC1_D_TZPC_PERIC1_PCLK, 4260 "gout_peric1_d_tzpc_peric1_pclk", "mout_peric1_bus_user", 4261 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_D_TZPC_PERIC1_IPCLKPORT_PCLK, 4262 21, 0, 0), 4263 GATE(CLK_GOUT_PERIC1_GPC_PERIC1_PCLK, 4264 "gout_peric1_gpc_peric1_pclk", "mout_peric1_bus_user", 4265 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_GPC_PERIC1_IPCLKPORT_PCLK, 4266 21, 0, 0), 4267 GATE(CLK_GOUT_PERIC1_GPIO_PERIC1_PCLK, 4268 "gout_peric1_gpio_peric1_pclk", "mout_peric1_bus_user", 4269 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_GPIO_PERIC1_IPCLKPORT_PCLK, 4270 21, CLK_IGNORE_UNUSED, 0), 4271 GATE(CLK_GOUT_PERIC1_LHM_AXI_P_PERIC1_I_CLK, 4272 "gout_peric1_lhm_axi_p_peric1_i_clk", "mout_peric1_bus_user", 4273 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_LHM_AXI_P_PERIC1_IPCLKPORT_I_CLK, 4274 21, CLK_IS_CRITICAL, 0), 4275 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_IPCLK_1, 4276 "gout_peric1_peric1_top0_ipclk_1", "dout_peric1_usi0_usi", 4277 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_1, 4278 21, CLK_SET_RATE_PARENT, 0), 4279 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_IPCLK_2, 4280 "gout_peric1_peric1_top0_ipclk_2", "dout_peric1_usi9_usi", 4281 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_2, 4282 21, CLK_SET_RATE_PARENT, 0), 4283 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_IPCLK_3, 4284 "gout_peric1_peric1_top0_ipclk_3", "dout_peric1_usi10_usi", 4285 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_3, 4286 21, CLK_SET_RATE_PARENT, 0), 4287 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_IPCLK_4, 4288 "gout_peric1_peric1_top0_ipclk_4", "dout_peric1_usi11_usi", 4289 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_4, 4290 21, CLK_SET_RATE_PARENT, 0), 4291 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_IPCLK_5, 4292 "gout_peric1_peric1_top0_ipclk_5", "dout_peric1_usi12_usi", 4293 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_5, 4294 21, CLK_SET_RATE_PARENT, 0), 4295 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_IPCLK_6, 4296 "gout_peric1_peric1_top0_ipclk_6", "dout_peric1_usi13_usi", 4297 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_6, 4298 21, CLK_SET_RATE_PARENT, 0), 4299 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_IPCLK_8, 4300 "gout_peric1_peric1_top0_ipclk_8", "dout_peric1_i3c", 4301 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_IPCLK_8, 4302 21, 0, 0), 4303 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_PCLK_1, 4304 "gout_peric1_peric1_top0_pclk_1", "mout_peric1_bus_user", 4305 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_1, 4306 21, 0, 0), 4307 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_PCLK_15, 4308 "gout_peric1_peric1_top0_pclk_15", "mout_peric1_bus_user", 4309 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_15, 4310 21, 0, 0), 4311 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_PCLK_2, 4312 "gout_peric1_peric1_top0_pclk_2", "mout_peric1_bus_user", 4313 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_2, 4314 21, 0, 0), 4315 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_PCLK_3, 4316 "gout_peric1_peric1_top0_pclk_3", "mout_peric1_bus_user", 4317 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_3, 4318 21, 0, 0), 4319 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_PCLK_4, 4320 "gout_peric1_peric1_top0_pclk_4", "mout_peric1_bus_user", 4321 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_4, 4322 21, 0, 0), 4323 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_PCLK_5, 4324 "gout_peric1_peric1_top0_pclk_5", "mout_peric1_bus_user", 4325 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_5, 4326 21, 0, 0), 4327 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_PCLK_6, 4328 "gout_peric1_peric1_top0_pclk_6", "mout_peric1_bus_user", 4329 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_6, 4330 21, 0, 0), 4331 GATE(CLK_GOUT_PERIC1_PERIC1_TOP0_PCLK_8, 4332 "gout_peric1_peric1_top0_pclk_8", "mout_peric1_bus_user", 4333 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_PERIC1_TOP0_IPCLKPORT_PCLK_8, 4334 21, 0, 0), 4335 GATE(CLK_GOUT_PERIC1_CLK_PERIC1_BUSP_CLK, 4336 "gout_peric1_clk_peric1_busp_clk", "mout_peric1_bus_user", 4337 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_BUSP_IPCLKPORT_CLK, 4338 21, 0, 0), 4339 GATE(CLK_GOUT_PERIC1_CLK_PERIC1_USI0_USI_CLK, 4340 "gout_peric1_clk_peric1_usi0_usi_clk", "dout_peric1_usi0_usi", 4341 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI0_USI_IPCLKPORT_CLK, 4342 21, 0, 0), 4343 GATE(CLK_GOUT_PERIC1_CLK_PERIC1_USI10_USI_CLK, 4344 "gout_peric1_clk_peric1_usi10_usi_clk", "dout_peric1_usi10_usi", 4345 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI10_USI_IPCLKPORT_CLK, 4346 21, 0, 0), 4347 GATE(CLK_GOUT_PERIC1_CLK_PERIC1_USI11_USI_CLK, 4348 "gout_peric1_clk_peric1_usi11_usi_clk", "dout_peric1_usi11_usi", 4349 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI11_USI_IPCLKPORT_CLK, 4350 21, 0, 0), 4351 GATE(CLK_GOUT_PERIC1_CLK_PERIC1_USI12_USI_CLK, 4352 "gout_peric1_clk_peric1_usi12_usi_clk", "dout_peric1_usi12_usi", 4353 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI12_USI_IPCLKPORT_CLK, 4354 21, 0, 0), 4355 GATE(CLK_GOUT_PERIC1_CLK_PERIC1_USI13_USI_CLK, 4356 "gout_peric1_clk_peric1_usi13_usi_clk", "dout_peric1_usi13_usi", 4357 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI13_USI_IPCLKPORT_CLK, 4358 21, 0, 0), 4359 GATE(CLK_GOUT_PERIC1_CLK_PERIC1_USI9_USI_CLK, 4360 "gout_peric1_clk_peric1_usi9_usi_clk", "dout_peric1_usi9_usi", 4361 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_RSTNSYNC_CLK_PERIC1_USI9_USI_IPCLKPORT_CLK, 4362 21, 0, 0), 4363 GATE(CLK_GOUT_PERIC1_SYSREG_PERIC1_PCLK, 4364 "gout_peric1_sysreg_peric1_pclk", "mout_peric1_bus_user", 4365 CLK_CON_GAT_GOUT_BLK_PERIC1_UID_SYSREG_PERIC1_IPCLKPORT_PCLK, 4366 21, 0, 0), 4367 }; 4368 4369 static const struct samsung_cmu_info peric1_cmu_info __initconst = { 4370 .mux_clks = peric1_mux_clks, 4371 .nr_mux_clks = ARRAY_SIZE(peric1_mux_clks), 4372 .div_clks = peric1_div_clks, 4373 .nr_div_clks = ARRAY_SIZE(peric1_div_clks), 4374 .gate_clks = peric1_gate_clks, 4375 .nr_gate_clks = ARRAY_SIZE(peric1_gate_clks), 4376 .nr_clk_ids = CLKS_NR_PERIC1, 4377 .clk_regs = peric1_clk_regs, 4378 .nr_clk_regs = ARRAY_SIZE(peric1_clk_regs), 4379 .clk_name = "bus", 4380 }; 4381 4382 /* ---- platform_driver ----------------------------------------------------- */ 4383 4384 static int __init gs101_cmu_probe(struct platform_device *pdev) 4385 { 4386 const struct samsung_cmu_info *info; 4387 struct device *dev = &pdev->dev; 4388 4389 info = of_device_get_match_data(dev); 4390 exynos_arm64_register_cmu(dev, dev->of_node, info); 4391 4392 return 0; 4393 } 4394 4395 static const struct of_device_id gs101_cmu_of_match[] = { 4396 { 4397 .compatible = "google,gs101-cmu-apm", 4398 .data = &apm_cmu_info, 4399 }, { 4400 .compatible = "google,gs101-cmu-hsi0", 4401 .data = &hsi0_cmu_info, 4402 }, { 4403 .compatible = "google,gs101-cmu-hsi2", 4404 .data = &hsi2_cmu_info, 4405 }, { 4406 .compatible = "google,gs101-cmu-peric0", 4407 .data = &peric0_cmu_info, 4408 }, { 4409 .compatible = "google,gs101-cmu-peric1", 4410 .data = &peric1_cmu_info, 4411 }, { 4412 }, 4413 }; 4414 4415 static struct platform_driver gs101_cmu_driver __refdata = { 4416 .driver = { 4417 .name = "gs101-cmu", 4418 .of_match_table = gs101_cmu_of_match, 4419 .suppress_bind_attrs = true, 4420 }, 4421 .probe = gs101_cmu_probe, 4422 }; 4423 4424 static int __init gs101_cmu_init(void) 4425 { 4426 return platform_driver_register(&gs101_cmu_driver); 4427 } 4428 core_initcall(gs101_cmu_init); 4429