Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux
1
fork

Configure Feed

Select the types of activity you want to include in your feed.

at master 1376 lines 62 kB view raw
1// SPDX-License-Identifier: GPL-2.0 2/* 3 * Copyright 2026, Beijing ESWIN Computing Technology Co., Ltd.. 4 * All rights reserved. 5 * 6 * ESWIN EIC7700 Clk Provider Driver 7 * 8 * Authors: 9 * Yifeng Huang <huangyifeng@eswincomputing.com> 10 * Xuyang Dong <dongxuyang@eswincomputing.com> 11 */ 12 13#include <linux/clk.h> 14#include <linux/clk-provider.h> 15#include <linux/platform_device.h> 16 17#include <dt-bindings/clock/eswin,eic7700-clock.h> 18 19#include "common.h" 20 21/* REG OFFSET OF SYS-CRG */ 22#define EIC7700_REG_OFFSET_SPLL0_CFG_0 0x0 23#define EIC7700_REG_OFFSET_SPLL0_CFG_1 0x4 24#define EIC7700_REG_OFFSET_SPLL0_CFG_2 0x8 25#define EIC7700_REG_OFFSET_SPLL0_DSKEWCAL 0xC 26#define EIC7700_REG_OFFSET_SPLL0_SSC 0x10 27#define EIC7700_REG_OFFSET_SPLL1_CFG_0 0x14 28#define EIC7700_REG_OFFSET_SPLL1_CFG_1 0x18 29#define EIC7700_REG_OFFSET_SPLL1_CFG_2 0x1C 30#define EIC7700_REG_OFFSET_SPLL1_DSKEWCAL 0x20 31#define EIC7700_REG_OFFSET_SPLL1_SSC 0x24 32#define EIC7700_REG_OFFSET_SPLL2_CFG_0 0x28 33#define EIC7700_REG_OFFSET_SPLL2_CFG_1 0x2C 34#define EIC7700_REG_OFFSET_SPLL2_CFG_2 0x30 35#define EIC7700_REG_OFFSET_SPLL2_DSKEWCAL 0x34 36#define EIC7700_REG_OFFSET_SPLL2_SSC 0x38 37#define EIC7700_REG_OFFSET_VPLL_CFG_0 0x3C 38#define EIC7700_REG_OFFSET_VPLL_CFG_1 0x40 39#define EIC7700_REG_OFFSET_VPLL_CFG_2 0x44 40#define EIC7700_REG_OFFSET_VPLL_DSKEWCAL 0x48 41#define EIC7700_REG_OFFSET_VPLL_SSC 0x4C 42#define EIC7700_REG_OFFSET_APLL_CFG_0 0x50 43#define EIC7700_REG_OFFSET_APLL_CFG_1 0x54 44#define EIC7700_REG_OFFSET_APLL_CFG_2 0x58 45#define EIC7700_REG_OFFSET_APLL_DSKEWCAL 0x5C 46#define EIC7700_REG_OFFSET_APLL_SSC 0x60 47#define EIC7700_REG_OFFSET_MCPUT_PLL_CFG_0 0x64 48#define EIC7700_REG_OFFSET_MCPUT_PLL_CFG_1 0x68 49#define EIC7700_REG_OFFSET_MCPUT_PLL_CFG_2 0x6C 50#define EIC7700_REG_OFFSET_MCPUT_PLL_DSKEWCAL 0x70 51#define EIC7700_REG_OFFSET_MCPUT_PLL_SSC 0x74 52#define EIC7700_REG_OFFSET_DDRT_PLL_CFG_0 0x78 53#define EIC7700_REG_OFFSET_DDRT_PLL_CFG_1 0x7C 54#define EIC7700_REG_OFFSET_DDRT_PLL_CFG_2 0x80 55#define EIC7700_REG_OFFSET_DDRT_PLL_DSKEWCAL 0x84 56#define EIC7700_REG_OFFSET_DDRT_PLL_SSC 0x88 57#define EIC7700_REG_OFFSET_PLL_STATUS 0xA4 58#define EIC7700_REG_OFFSET_NOC 0x100 59#define EIC7700_REG_OFFSET_BOOTSPI 0x104 60#define EIC7700_REG_OFFSET_BOOTSPI_CFGCLK 0x108 61#define EIC7700_REG_OFFSET_SCPU_CORE 0x10C 62#define EIC7700_REG_OFFSET_SCPU_BUSCLK 0x110 63#define EIC7700_REG_OFFSET_LPCPU_CORE 0x114 64#define EIC7700_REG_OFFSET_LPCPU_BUSCLK 0x118 65#define EIC7700_REG_OFFSET_TCU_ACLK 0x11C 66#define EIC7700_REG_OFFSET_TCU_CFG 0x120 67#define EIC7700_REG_OFFSET_DDR 0x124 68#define EIC7700_REG_OFFSET_DDR1 0x128 69#define EIC7700_REG_OFFSET_GPU_ACLK 0x12C 70#define EIC7700_REG_OFFSET_GPU_CFG 0x130 71#define EIC7700_REG_OFFSET_GPU_GRAY 0x134 72#define EIC7700_REG_OFFSET_DSP_ACLK 0x138 73#define EIC7700_REG_OFFSET_DSP_CFG 0x13C 74#define EIC7700_REG_OFFSET_D2D_ACLK 0x140 75#define EIC7700_REG_OFFSET_D2D_CFG 0x144 76#define EIC7700_REG_OFFSET_HSP_ACLK 0x148 77#define EIC7700_REG_OFFSET_HSP_CFG 0x14C 78#define EIC7700_REG_OFFSET_SATA_RBC 0x150 79#define EIC7700_REG_OFFSET_SATA_OOB 0x154 80#define EIC7700_REG_OFFSET_ETH0 0x158 81#define EIC7700_REG_OFFSET_ETH1 0x15C 82#define EIC7700_REG_OFFSET_MSHC0_CORE 0x160 83#define EIC7700_REG_OFFSET_MSHC1_CORE 0x164 84#define EIC7700_REG_OFFSET_MSHC2_CORE 0x168 85#define EIC7700_REG_OFFSET_MSHC_USB_SLWCLK 0x16C 86#define EIC7700_REG_OFFSET_PCIE_ACLK 0x170 87#define EIC7700_REG_OFFSET_PCIE_CFG 0x174 88#define EIC7700_REG_OFFSET_NPU_ACLK 0x178 89#define EIC7700_REG_OFFSET_NPU_LLC 0x17C 90#define EIC7700_REG_OFFSET_NPU_CORE 0x180 91#define EIC7700_REG_OFFSET_VI_DWCLK 0x184 92#define EIC7700_REG_OFFSET_VI_ACLK 0x188 93#define EIC7700_REG_OFFSET_VI_DIG_ISP 0x18C 94#define EIC7700_REG_OFFSET_VI_DVP 0x190 95#define EIC7700_REG_OFFSET_VI_SHUTTER0 0x194 96#define EIC7700_REG_OFFSET_VI_SHUTTER1 0x198 97#define EIC7700_REG_OFFSET_VI_SHUTTER2 0x19C 98#define EIC7700_REG_OFFSET_VI_SHUTTER3 0x1A0 99#define EIC7700_REG_OFFSET_VI_SHUTTER4 0x1A4 100#define EIC7700_REG_OFFSET_VI_SHUTTER5 0x1A8 101#define EIC7700_REG_OFFSET_VI_PHY 0x1AC 102#define EIC7700_REG_OFFSET_VO_ACLK 0x1B0 103#define EIC7700_REG_OFFSET_VO_IESMCLK 0x1B4 104#define EIC7700_REG_OFFSET_VO_PIXEL 0x1B8 105#define EIC7700_REG_OFFSET_VO_MCLK 0x1BC 106#define EIC7700_REG_OFFSET_VO_PHY_CLK 0x1C0 107#define EIC7700_REG_OFFSET_VC_ACLK 0x1C4 108#define EIC7700_REG_OFFSET_VCDEC_ROOT 0x1C8 109#define EIC7700_REG_OFFSET_G2D 0x1CC 110#define EIC7700_REG_OFFSET_VC_CLKEN 0x1D0 111#define EIC7700_REG_OFFSET_JE 0x1D4 112#define EIC7700_REG_OFFSET_JD 0x1D8 113#define EIC7700_REG_OFFSET_VD 0x1DC 114#define EIC7700_REG_OFFSET_VE 0x1E0 115#define EIC7700_REG_OFFSET_AON_DMA 0x1E4 116#define EIC7700_REG_OFFSET_TIMER 0x1E8 117#define EIC7700_REG_OFFSET_RTC 0x1EC 118#define EIC7700_REG_OFFSET_PKA 0x1F0 119#define EIC7700_REG_OFFSET_SPACC 0x1F4 120#define EIC7700_REG_OFFSET_TRNG 0x1F8 121#define EIC7700_REG_OFFSET_OTP 0x1FC 122#define EIC7700_REG_OFFSET_LSP_EN0 0x200 123#define EIC7700_REG_OFFSET_LSP_EN1 0x204 124#define EIC7700_REG_OFFSET_U84 0x208 125#define EIC7700_REG_OFFSET_SYSCFG 0x20C 126#define EIC7700_REG_OFFSET_I2C0 0x210 127#define EIC7700_REG_OFFSET_I2C1 0x214 128 129#define EIC7700_NR_CLKS (EIC7700_CLK_GATE_NOC_WDREF + 1) 130 131/* 132 * The 24 MHz oscillator, the root of most of the clock tree. 133 */ 134static const struct clk_parent_data xtal24M[] = { 135 { .index = 0, } 136}; 137 138/* fixed rate clocks */ 139static struct eswin_fixed_rate_clock eic7700_fixed_rate_clks[] = { 140 ESWIN_FIXED(EIC7700_CLK_XTAL_32K, "fixed_rate_clk_xtal_32k", 0, 32768), 141 ESWIN_FIXED(EIC7700_CLK_SPLL0_FOUT1, "fixed_rate_clk_spll0_fout1", 0, 142 1600000000), 143 ESWIN_FIXED(EIC7700_CLK_SPLL0_FOUT2, "fixed_rate_clk_spll0_fout2", 0, 144 800000000), 145 ESWIN_FIXED(EIC7700_CLK_SPLL0_FOUT3, "fixed_rate_clk_spll0_fout3", 0, 146 400000000), 147 ESWIN_FIXED(EIC7700_CLK_SPLL1_FOUT1, "fixed_rate_clk_spll1_fout1", 0, 148 1500000000), 149 ESWIN_FIXED(EIC7700_CLK_SPLL1_FOUT2, "fixed_rate_clk_spll1_fout2", 0, 150 300000000), 151 ESWIN_FIXED(EIC7700_CLK_SPLL1_FOUT3, "fixed_rate_clk_spll1_fout3", 0, 152 250000000), 153 ESWIN_FIXED(EIC7700_CLK_SPLL2_FOUT1, "fixed_rate_clk_spll2_fout1", 0, 154 2080000000), 155 ESWIN_FIXED(EIC7700_CLK_SPLL2_FOUT2, "fixed_rate_clk_spll2_fout2", 0, 156 1040000000), 157 ESWIN_FIXED(EIC7700_CLK_SPLL2_FOUT3, "fixed_rate_clk_spll2_fout3", 0, 158 416000000), 159 ESWIN_FIXED(EIC7700_CLK_VPLL_FOUT1, "fixed_rate_clk_vpll_fout1", 0, 160 1188000000), 161 ESWIN_FIXED(EIC7700_CLK_VPLL_FOUT2, "fixed_rate_clk_vpll_fout2", 0, 162 594000000), 163 ESWIN_FIXED(EIC7700_CLK_VPLL_FOUT3, "fixed_rate_clk_vpll_fout3", 0, 164 49500000), 165 ESWIN_FIXED(EIC7700_CLK_APLL_FOUT2, "fixed_rate_clk_apll_fout2", 0, 0), 166 ESWIN_FIXED(EIC7700_CLK_APLL_FOUT3, "fixed_rate_clk_apll_fout3", 0, 0), 167 ESWIN_FIXED(EIC7700_CLK_EXT_MCLK, "fixed_rate_ext_mclk", 0, 0), 168 ESWIN_FIXED(EIC7700_CLK_LPDDR_REF_BAK, "fixed_rate_lpddr_ref_bak", 0, 169 50000000), 170}; 171 172/* pll clocks */ 173static struct eswin_pll_clock eic7700_pll_clks[] = { 174 ESWIN_PLL(EIC7700_CLK_APLL_FOUT1, "clk_apll_fout1", xtal24M, 175 EIC7700_REG_OFFSET_APLL_CFG_0, 20, 176 EIC7700_REG_OFFSET_APLL_CFG_1, 4, 177 EIC7700_REG_OFFSET_APLL_CFG_2, EIC7700_REG_OFFSET_PLL_STATUS, 178 4, 1, APLL_HIGH_FREQ, APLL_LOW_FREQ), 179 ESWIN_PLL(EIC7700_CLK_PLL_CPU, "clk_pll_cpu", xtal24M, 180 EIC7700_REG_OFFSET_MCPUT_PLL_CFG_0, 20, 181 EIC7700_REG_OFFSET_MCPUT_PLL_CFG_1, 4, 182 EIC7700_REG_OFFSET_MCPUT_PLL_CFG_2, 183 EIC7700_REG_OFFSET_PLL_STATUS, 5, 1, PLL_HIGH_FREQ, 184 PLL_LOW_FREQ), 185}; 186 187/* fixed factor clocks */ 188static struct eswin_fixed_factor_clock eic7700_factor_clks[] = { 189 ESWIN_FACTOR(EIC7700_CLK_FIXED_FACTOR_CLK_1M_DIV24, 190 "fixed_factor_clk_1m_div24", xtal24M, 1, 24, 0), 191 ESWIN_FACTOR(EIC7700_CLK_FIXED_FACTOR_PVT_DIV20, 192 "fixed_factor_pvt_div20", xtal24M, 1, 20, 0), 193}; 194 195/* divider clocks */ 196static struct eswin_divider_clock eic7700_div_clks[] = { 197 ESWIN_DIV(EIC7700_CLK_DIV_U84_RTC_TOGGLE_DYNM, 198 "divider_u84_rtc_toggle_dynm", xtal24M, 0, 199 EIC7700_REG_OFFSET_RTC, 16, 5, 200 CLK_DIVIDER_ONE_BASED | CLK_DIVIDER_ALLOW_ZERO, 0), 201 ESWIN_DIV(EIC7700_CLK_DIV_NOC_WDREF_DYNM, "divider_noc_wdref_dynm", 202 xtal24M, 0, EIC7700_REG_OFFSET_NOC, 4, 16, 203 CLK_DIVIDER_ONE_BASED | CLK_DIVIDER_ALLOW_ZERO, 0), 204}; 205 206/* gate clocks */ 207static struct eswin_gate_clock eic7700_gate_clks[] = { 208 ESWIN_GATE(EIC7700_CLK_GATE_GPU_GRAY_CLK, "gate_gpu_gray_clk", xtal24M, 209 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_GPU_GRAY, 31, 0), 210 ESWIN_GATE(EIC7700_CLK_GATE_VI_PHY_CFG, "gate_vi_phy_cfg", xtal24M, 211 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VI_PHY, 1, 0), 212 ESWIN_GATE(EIC7700_CLK_GATE_TIMER_CLK_0, "gate_time_clk_0", xtal24M, 213 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_TIMER, 0, 0), 214 ESWIN_GATE(EIC7700_CLK_GATE_TIMER_CLK_1, "gate_time_clk_1", xtal24M, 215 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_TIMER, 1, 0), 216 ESWIN_GATE(EIC7700_CLK_GATE_TIMER_CLK_2, "gate_time_clk_2", xtal24M, 217 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_TIMER, 2, 0), 218 ESWIN_GATE(EIC7700_CLK_GATE_TIMER_CLK_3, "gate_time_clk_3", xtal24M, 219 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_TIMER, 3, 0), 220}; 221 222/* Define the early clocks as the parent clocks of the mux clocks. */ 223static struct eswin_clk_info eic7700_early_clks[] = { 224 ESWIN_FACTOR_TYPE(EIC7700_CLK_FIXED_FACTOR_HSP_RMII_REF_DIV6, 225 "fixed_factor_hsp_rmii_ref_div6", 226 EIC7700_CLK_SPLL1_FOUT2, 1, 6, 0), 227 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_NPU_LLC_SRC0_DYNM, 228 "divider_npu_llc_src0_div_dynm", 229 EIC7700_CLK_SPLL0_FOUT1, 0, EIC7700_REG_OFFSET_NPU_LLC, 230 4, 4, 0, ESWIN_PRIV_DIV_MIN_2), 231 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_NPU_LLC_SRC1_DYNM, 232 "divider_npu_llc_src1_div_dynm", 233 EIC7700_CLK_SPLL2_FOUT1, 0, EIC7700_REG_OFFSET_NPU_LLC, 234 8, 4, 0, ESWIN_PRIV_DIV_MIN_2), 235 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_SPLL0_FOUT2, "gate_clk_spll0_fout2", 236 EIC7700_CLK_SPLL0_FOUT2, 237 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 238 EIC7700_REG_OFFSET_SPLL0_CFG_2, 31, 0), 239 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_BOOTSPI_DYNM, "divider_bootspi_div_dynm", 240 EIC7700_CLK_GATE_SPLL0_FOUT2, 0, 241 EIC7700_REG_OFFSET_BOOTSPI, 4, 6, 0, 242 ESWIN_PRIV_DIV_MIN_2), 243 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_SCPU_CORE_DYNM, 244 "divider_scpu_core_div_dynm", EIC7700_CLK_SPLL0_FOUT1, 0, 245 EIC7700_REG_OFFSET_SCPU_CORE, 4, 4, 0, 246 ESWIN_PRIV_DIV_MIN_2), 247 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_LPCPU_CORE_DYNM, 248 "divider_lpcpu_core_div_dynm", EIC7700_CLK_SPLL0_FOUT1, 249 0, EIC7700_REG_OFFSET_LPCPU_CORE, 4, 4, 0, 250 ESWIN_PRIV_DIV_MIN_2), 251 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VO_MCLK_DYNM, "divider_vo_mclk_div_dynm", 252 EIC7700_CLK_APLL_FOUT1, 0, EIC7700_REG_OFFSET_VO_MCLK, 4, 253 8, 0, ESWIN_PRIV_DIV_MIN_2), 254 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_AONDMA_AXI_DYNM, 255 "divider_aondma_axi_div_dynm", EIC7700_CLK_SPLL0_FOUT1, 256 0, EIC7700_REG_OFFSET_AON_DMA, 4, 4, 0, 257 ESWIN_PRIV_DIV_MIN_2), 258 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_SATA_PHY_REF_DYNM, 259 "divider_sata_phy_ref_div_dynm", 260 EIC7700_CLK_SPLL1_FOUT2, 0, EIC7700_REG_OFFSET_SATA_OOB, 261 0, 4, 0, ESWIN_PRIV_DIV_MIN_2), 262 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_SYS_CFG_DYNM, "divider_sys_cfg_div_dynm", 263 EIC7700_CLK_SPLL0_FOUT3, 0, EIC7700_REG_OFFSET_SYSCFG, 4, 264 3, 0, ESWIN_PRIV_DIV_MIN_2), 265 ESWIN_FACTOR_TYPE(EIC7700_CLK_FIXED_FACTOR_U84_CORE_LP_DIV2, 266 "fixed_factor_u84_core_lp_div2", 267 EIC7700_CLK_GATE_SPLL0_FOUT2, 1, 2, 0), 268}; 269 270static const struct clk_parent_data dsp_aclk_root_2mux1_gfree_mux_p[] = { 271 { .hw = &eic7700_fixed_rate_clks[7].hw }, 272 { .hw = &eic7700_fixed_rate_clks[1].hw }, 273}; 274 275static const struct clk_parent_data d2d_aclk_root_2mux1_gfree_mux_p[] = { 276 { .hw = &eic7700_fixed_rate_clks[7].hw }, 277 { .hw = &eic7700_fixed_rate_clks[1].hw }, 278}; 279 280static const struct clk_parent_data ddr_aclk_root_2mux1_gfree_mux_p[] = { 281 { .hw = &eic7700_fixed_rate_clks[7].hw }, 282 { .hw = &eic7700_fixed_rate_clks[1].hw }, 283}; 284 285static const struct clk_parent_data mshcore_root_3mux1_0_mux_p[] = { 286 { .hw = &eic7700_fixed_rate_clks[3].hw }, 287 { .hw = &eic7700_fixed_rate_clks[9].hw }, 288}; 289 290static const struct clk_parent_data mshcore_root_3mux1_1_mux_p[] = { 291 { .hw = &eic7700_fixed_rate_clks[3].hw }, 292 { .hw = &eic7700_fixed_rate_clks[9].hw }, 293}; 294 295static const struct clk_parent_data mshcore_root_3mux1_2_mux_p[] = { 296 { .hw = &eic7700_fixed_rate_clks[3].hw }, 297 { .hw = &eic7700_fixed_rate_clks[9].hw }, 298}; 299 300static const struct clk_parent_data npu_core_3mux1_gfree_mux_p[] = { 301 { .hw = &eic7700_fixed_rate_clks[4].hw }, 302 { .hw = &eic7700_fixed_rate_clks[10].hw }, 303 { .hw = &eic7700_fixed_rate_clks[8].hw }, 304}; 305 306static const struct clk_parent_data npu_e31_3mux1_gfree_mux_p[] = { 307 { .hw = &eic7700_fixed_rate_clks[4].hw }, 308 { .hw = &eic7700_fixed_rate_clks[10].hw }, 309 { .hw = &eic7700_fixed_rate_clks[8].hw }, 310}; 311 312static const struct clk_parent_data vi_aclk_root_2mux1_gfree_mux_p[] = { 313 { .hw = &eic7700_fixed_rate_clks[1].hw }, 314 { .hw = &eic7700_fixed_rate_clks[7].hw }, 315}; 316 317static const struct clk_parent_data mux_vi_dw_root_2mux1_p[] = { 318 { .hw = &eic7700_fixed_rate_clks[10].hw }, 319 { .hw = &eic7700_fixed_rate_clks[1].hw }, 320}; 321 322static const struct clk_parent_data mux_vi_dvp_root_2mux1_gfree_p[] = { 323 { .hw = &eic7700_fixed_rate_clks[10].hw }, 324 { .hw = &eic7700_fixed_rate_clks[1].hw }, 325}; 326 327static const struct clk_parent_data mux_vi_dig_isp_root_2mux1_gfree_p[] = { 328 { .hw = &eic7700_fixed_rate_clks[10].hw }, 329 { .hw = &eic7700_fixed_rate_clks[1].hw }, 330}; 331 332static const struct clk_parent_data mux_vo_aclk_root_2mux1_gfree_p[] = { 333 { .hw = &eic7700_fixed_rate_clks[1].hw }, 334 { .hw = &eic7700_fixed_rate_clks[7].hw }, 335}; 336 337static const struct clk_parent_data mux_vo_pixel_root_2mux1_p[] = { 338 { .hw = &eic7700_fixed_rate_clks[10].hw }, 339 { .hw = &eic7700_fixed_rate_clks[8].hw }, 340}; 341 342static const struct clk_parent_data mux_vcdec_root_2mux1_gfree_p[] = { 343 { .hw = &eic7700_fixed_rate_clks[1].hw }, 344 { .hw = &eic7700_fixed_rate_clks[7].hw }, 345}; 346 347static const struct clk_parent_data mux_vcaclk_root_2mux1_gfree_p[] = { 348 { .hw = &eic7700_fixed_rate_clks[1].hw }, 349 { .hw = &eic7700_fixed_rate_clks[7].hw }, 350}; 351 352static const struct clk_parent_data npu_llclk_3mux1_gfree_mux_p[] = { 353 { .hw = &eic7700_early_clks[1].hw }, 354 { .hw = &eic7700_early_clks[2].hw }, 355 { .hw = &eic7700_fixed_rate_clks[10].hw }, 356}; 357 358static const struct clk_parent_data mux_bootspi_clk_2mux1_gfree_p[] = { 359 { .hw = &eic7700_early_clks[4].hw }, 360 { .index = 0 }, 361}; 362 363static const struct clk_parent_data mux_scpu_core_clk_2mux1_gfree_p[] = { 364 { .hw = &eic7700_early_clks[5].hw }, 365 { .index = 0 }, 366}; 367 368static const struct clk_parent_data mux_lpcpu_core_clk_2mux1_gfree_p[] = { 369 { .hw = &eic7700_early_clks[6].hw }, 370 { .index = 0 }, 371}; 372 373static const struct clk_parent_data mux_vo_mclk_2mux_ext_mclk_p[] = { 374 { .hw = &eic7700_early_clks[7].hw }, 375 { .hw = &eic7700_fixed_rate_clks[15].hw }, 376}; 377 378static const struct clk_parent_data mux_aondma_axi2mux1_gfree_p[] = { 379 { .hw = &eic7700_early_clks[8].hw }, 380 { .index = 0 }, 381}; 382 383static const struct clk_parent_data mux_rmii_ref_2mux1_p[] = { 384 { .hw = &eic7700_early_clks[0].hw }, 385 { .hw = &eic7700_fixed_rate_clks[16].hw }, 386}; 387 388static const struct clk_parent_data mux_eth_core_2mux1_p[] = { 389 { .hw = &eic7700_fixed_rate_clks[6].hw }, 390 { .hw = &eic7700_fixed_rate_clks[16].hw }, 391}; 392 393static const struct clk_parent_data mux_sata_phy_2mux1_p[] = { 394 { .hw = &eic7700_early_clks[9].hw }, 395 { .hw = &eic7700_fixed_rate_clks[16].hw }, 396}; 397 398static const struct clk_parent_data mux_syscfg_clk_root_2mux1_gfree_p[] = { 399 { .hw = &eic7700_early_clks[10].hw }, 400 { .index = 0 }, 401}; 402 403static const struct clk_parent_data mux_cpu_root_3mux1_gfree_p[] = { 404 { .hw = &eic7700_pll_clks[1].hw }, 405 { .hw = &eic7700_early_clks[11].hw }, 406 { .index = 0 }, 407}; 408 409static struct eswin_mux_clock eic7700_mux_clks[] = { 410 ESWIN_MUX(EIC7700_CLK_MUX_CPU_ROOT_3MUX1_GFREE, 411 "mux_cpu_root_3mux1_gfree", mux_cpu_root_3mux1_gfree_p, 412 ARRAY_SIZE(mux_cpu_root_3mux1_gfree_p), 413 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_U84, 0, 2, 414 CLK_MUX_ROUND_CLOSEST), 415 ESWIN_MUX(EIC7700_CLK_MUX_RMII_REF_2MUX, "mux_rmii_ref_2mux1", 416 mux_rmii_ref_2mux1_p, ARRAY_SIZE(mux_rmii_ref_2mux1_p), 417 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_ETH0, 2, 1, 418 CLK_MUX_ROUND_CLOSEST), 419 ESWIN_MUX(EIC7700_CLK_MUX_DSP_ACLK_ROOT_2MUX1_GFREE, 420 "mux_dsp_aclk_root_2mux1_gfree", 421 dsp_aclk_root_2mux1_gfree_mux_p, 422 ARRAY_SIZE(dsp_aclk_root_2mux1_gfree_mux_p), 423 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_DSP_ACLK, 0, 1, 424 CLK_MUX_ROUND_CLOSEST), 425 ESWIN_MUX(EIC7700_CLK_MUX_D2D_ACLK_ROOT_2MUX1_GFREE, 426 "mux_d2d_aclk_root_2mux1_gfree", 427 d2d_aclk_root_2mux1_gfree_mux_p, 428 ARRAY_SIZE(d2d_aclk_root_2mux1_gfree_mux_p), 429 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_D2D_ACLK, 0, 1, 430 CLK_MUX_ROUND_CLOSEST), 431 ESWIN_MUX(EIC7700_CLK_MUX_DDR_ACLK_ROOT_2MUX1_GFREE, 432 "mux_ddr_aclk_root_2mux1_gfree", 433 ddr_aclk_root_2mux1_gfree_mux_p, 434 ARRAY_SIZE(ddr_aclk_root_2mux1_gfree_mux_p), 435 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_DDR, 16, 1, 436 CLK_MUX_ROUND_CLOSEST), 437 ESWIN_MUX(EIC7700_CLK_MUX_MSHCORE_ROOT_3MUX1_0, 438 "mux_mshcore_root_3mux1_0", mshcore_root_3mux1_0_mux_p, 439 ARRAY_SIZE(mshcore_root_3mux1_0_mux_p), CLK_SET_RATE_PARENT, 440 EIC7700_REG_OFFSET_MSHC0_CORE, 0, 1, CLK_MUX_ROUND_CLOSEST), 441 ESWIN_MUX(EIC7700_CLK_MUX_MSHCORE_ROOT_3MUX1_1, 442 "mux_mshcore_root_3mux1_1", mshcore_root_3mux1_1_mux_p, 443 ARRAY_SIZE(mshcore_root_3mux1_1_mux_p), CLK_SET_RATE_PARENT, 444 EIC7700_REG_OFFSET_MSHC1_CORE, 0, 1, CLK_MUX_ROUND_CLOSEST), 445 ESWIN_MUX(EIC7700_CLK_MUX_MSHCORE_ROOT_3MUX1_2, 446 "mux_mshcore_root_3mux1_2", mshcore_root_3mux1_2_mux_p, 447 ARRAY_SIZE(mshcore_root_3mux1_2_mux_p), CLK_SET_RATE_PARENT, 448 EIC7700_REG_OFFSET_MSHC2_CORE, 0, 1, CLK_MUX_ROUND_CLOSEST), 449 ESWIN_MUX(EIC7700_CLK_MUX_NPU_LLCLK_3MUX1_GFREE, 450 "mux_npu_llclk_3mux1_gfree", npu_llclk_3mux1_gfree_mux_p, 451 ARRAY_SIZE(npu_llclk_3mux1_gfree_mux_p), 452 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_NPU_LLC, 0, 2, 453 CLK_MUX_ROUND_CLOSEST), 454 ESWIN_MUX(EIC7700_CLK_MUX_NPU_CORE_3MUX1_GFREE, 455 "mux_npu_core_3mux1_gfree", npu_core_3mux1_gfree_mux_p, 456 ARRAY_SIZE(npu_core_3mux1_gfree_mux_p), CLK_SET_RATE_PARENT, 457 EIC7700_REG_OFFSET_NPU_CORE, 0, 2, CLK_MUX_ROUND_CLOSEST), 458 ESWIN_MUX(EIC7700_CLK_MUX_NPU_E31_3MUX1_GFREE, 459 "mux_npu_e31_3mux1_gfree", npu_e31_3mux1_gfree_mux_p, 460 ARRAY_SIZE(npu_e31_3mux1_gfree_mux_p), CLK_SET_RATE_PARENT, 461 EIC7700_REG_OFFSET_NPU_CORE, 8, 2, CLK_MUX_ROUND_CLOSEST), 462 ESWIN_MUX(EIC7700_CLK_MUX_VI_ACLK_ROOT_2MUX1_GFREE, 463 "mux_vi_aclk_root_2mux1_gfree", 464 vi_aclk_root_2mux1_gfree_mux_p, 465 ARRAY_SIZE(vi_aclk_root_2mux1_gfree_mux_p), 466 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VI_ACLK, 0, 1, 467 CLK_MUX_ROUND_CLOSEST), 468 ESWIN_MUX(EIC7700_CLK_MUX_VI_DW_ROOT_2MUX1, "mux_vi_dw_root_2mux1", 469 mux_vi_dw_root_2mux1_p, ARRAY_SIZE(mux_vi_dw_root_2mux1_p), 470 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VI_DWCLK, 0, 1, 471 CLK_MUX_ROUND_CLOSEST), 472 ESWIN_MUX(EIC7700_CLK_MUX_VI_DVP_ROOT_2MUX1_GFREE, 473 "mux_vi_dvp_root_2mux1_gfree", 474 mux_vi_dvp_root_2mux1_gfree_p, 475 ARRAY_SIZE(mux_vi_dvp_root_2mux1_gfree_p), 476 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VI_DVP, 0, 1, 477 CLK_MUX_ROUND_CLOSEST), 478 ESWIN_MUX(EIC7700_CLK_MUX_VI_DIG_ISP_ROOT_2MUX1_GFREE, 479 "mux_vi_dig_isp_root_2mux1_gfree", 480 mux_vi_dig_isp_root_2mux1_gfree_p, 481 ARRAY_SIZE(mux_vi_dig_isp_root_2mux1_gfree_p), 482 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VI_DIG_ISP, 0, 1, 483 CLK_MUX_ROUND_CLOSEST), 484 ESWIN_MUX(EIC7700_CLK_MUX_VO_ACLK_ROOT_2MUX1_GFREE, 485 "mux_vo_aclk_root_2mux1_gfree", 486 mux_vo_aclk_root_2mux1_gfree_p, 487 ARRAY_SIZE(mux_vo_aclk_root_2mux1_gfree_p), 488 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VO_ACLK, 0, 1, 489 CLK_MUX_ROUND_CLOSEST), 490 ESWIN_MUX(EIC7700_CLK_MUX_VO_PIXEL_ROOT_2MUX1, 491 "mux_vo_pixel_root_2mux1", mux_vo_pixel_root_2mux1_p, 492 ARRAY_SIZE(mux_vo_pixel_root_2mux1_p), CLK_SET_RATE_PARENT, 493 EIC7700_REG_OFFSET_VO_PIXEL, 0, 1, CLK_MUX_ROUND_CLOSEST), 494 ESWIN_MUX(EIC7700_CLK_MUX_VCDEC_ROOT_2MUX1_GFREE, 495 "mux_vcdec_root_2mux1_gfree", mux_vcdec_root_2mux1_gfree_p, 496 ARRAY_SIZE(mux_vcdec_root_2mux1_gfree_p), 497 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VCDEC_ROOT, 0, 1, 498 CLK_MUX_ROUND_CLOSEST), 499 ESWIN_MUX(EIC7700_CLK_MUX_VCACLK_ROOT_2MUX1_GFREE, 500 "mux_vcaclk_root_2mux1_gfree", 501 mux_vcaclk_root_2mux1_gfree_p, 502 ARRAY_SIZE(mux_vcaclk_root_2mux1_gfree_p), 503 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VC_ACLK, 0, 1, 504 CLK_MUX_ROUND_CLOSEST), 505 ESWIN_MUX(EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 506 "mux_syscfg_clk_root_2mux1_gfree", 507 mux_syscfg_clk_root_2mux1_gfree_p, 508 ARRAY_SIZE(mux_syscfg_clk_root_2mux1_gfree_p), 509 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_SYSCFG, 0, 1, 510 CLK_MUX_ROUND_CLOSEST), 511 ESWIN_MUX(EIC7700_CLK_MUX_BOOTSPI_CLK_2MUX1_GFREE, 512 "mux_bootspi_clk_2mux1_gfree", 513 mux_bootspi_clk_2mux1_gfree_p, 514 ARRAY_SIZE(mux_bootspi_clk_2mux1_gfree_p), 515 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_BOOTSPI, 0, 1, 516 CLK_MUX_ROUND_CLOSEST), 517 ESWIN_MUX(EIC7700_CLK_MUX_SCPU_CORE_CLK_2MUX1_GFREE, 518 "mux_scpu_core_clk_2mux1_gfree", 519 mux_scpu_core_clk_2mux1_gfree_p, 520 ARRAY_SIZE(mux_scpu_core_clk_2mux1_gfree_p), 521 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_SCPU_CORE, 0, 1, 522 CLK_MUX_ROUND_CLOSEST), 523 ESWIN_MUX(EIC7700_CLK_MUX_LPCPU_CORE_CLK_2MUX1_GFREE, 524 "mux_lpcpu_core_clk_2mux1_gfree", 525 mux_lpcpu_core_clk_2mux1_gfree_p, 526 ARRAY_SIZE(mux_lpcpu_core_clk_2mux1_gfree_p), 527 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LPCPU_CORE, 0, 1, 528 CLK_MUX_ROUND_CLOSEST), 529 ESWIN_MUX(EIC7700_CLK_MUX_VO_MCLK_2MUX_EXT_MCLK, 530 "mux_vo_mclk_2mux_ext_mclk", mux_vo_mclk_2mux_ext_mclk_p, 531 ARRAY_SIZE(mux_vo_mclk_2mux_ext_mclk_p), 532 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VO_MCLK, 0, 1, 533 CLK_MUX_ROUND_CLOSEST), 534 ESWIN_MUX(EIC7700_CLK_MUX_AONDMA_AXI2MUX1_GFREE, 535 "mux_aondma_axi2mux1_gfree", mux_aondma_axi2mux1_gfree_p, 536 ARRAY_SIZE(mux_aondma_axi2mux1_gfree_p), 537 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_AON_DMA, 0, 1, 538 CLK_MUX_ROUND_CLOSEST), 539 ESWIN_MUX(EIC7700_CLK_MUX_ETH_CORE_2MUX1, "mux_eth_core_2mux1", 540 mux_eth_core_2mux1_p, ARRAY_SIZE(mux_eth_core_2mux1_p), 541 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_ETH0, 1, 1, 542 CLK_MUX_ROUND_CLOSEST), 543 ESWIN_MUX(EIC7700_CLK_MUX_SATA_PHY_2MUX1, "mux_sata_phy_2mux1", 544 mux_sata_phy_2mux1_p, ARRAY_SIZE(mux_sata_phy_2mux1_p), 545 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_SATA_OOB, 9, 1, 546 CLK_MUX_ROUND_CLOSEST), 547}; 548 549static const struct clk_parent_data mux_cpu_aclk_2mux1_gfree_p[] = { 550 { .hw = &eic7700_mux_clks[1].hw }, 551 { .hw = &eic7700_mux_clks[0].hw }, 552}; 553 554static struct eswin_clk_info eic7700_clks[] = { 555 ESWIN_MUX_TYPE(EIC7700_CLK_MUX_CPU_ACLK_2MUX1_GFREE, 556 "mux_cpu_aclk_2mux1_gfree", mux_cpu_aclk_2mux1_gfree_p, 557 ARRAY_SIZE(mux_cpu_aclk_2mux1_gfree_p), 558 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_U84, 20, 1, 559 CLK_MUX_ROUND_CLOSEST, NULL), 560 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_CPU_TRACE_COM_CLK, 561 "gate_clk_cpu_trace_com_clk", 562 EIC7700_CLK_MUX_CPU_ACLK_2MUX1_GFREE, 563 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_U84, 23, 0), 564 ESWIN_FACTOR_TYPE(EIC7700_CLK_FIXED_FACTOR_CPU_DIV2, 565 "fixed_factor_cpu_div2", 566 EIC7700_CLK_MUX_CPU_ROOT_3MUX1_GFREE, 1, 2, 0), 567 ESWIN_FACTOR_TYPE(EIC7700_CLK_FIXED_FACTOR_MIPI_TXESC_DIV10, 568 "fixed_factor_mipi_txesc_div10", 569 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1, 10, 570 0), 571 ESWIN_FACTOR_TYPE(EIC7700_CLK_FIXED_FACTOR_SCPU_BUS_DIV2, 572 "fixed_factor_scpu_bus_div2", 573 EIC7700_CLK_MUX_SCPU_CORE_CLK_2MUX1_GFREE, 1, 2, 0), 574 ESWIN_FACTOR_TYPE(EIC7700_CLK_FIXED_FACTOR_LPCPU_BUS_DIV2, 575 "fixed_factor_lpcpu_bus_div2", 576 EIC7700_CLK_MUX_LPCPU_CORE_CLK_2MUX1_GFREE, 1, 2, 0), 577 ESWIN_FACTOR_TYPE(EIC7700_CLK_FIXED_FACTOR_PCIE_CR_DIV2, 578 "fixed_factor_pcie_cr_div2", 579 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1, 2, 0), 580 ESWIN_FACTOR_TYPE(EIC7700_CLK_FIXED_FACTOR_PCIE_AUX_DIV4, 581 "fixed_factor_pcie_aux_div4", 582 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1, 4, 0), 583 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_D2D_ACLK_DYNM, 584 "divider_d2d_aclk_div_dynm", 585 EIC7700_CLK_MUX_D2D_ACLK_ROOT_2MUX1_GFREE, 0, 586 EIC7700_REG_OFFSET_D2D_ACLK, 4, 4, 0, 587 ESWIN_PRIV_DIV_MIN_2), 588 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_DSP_ACLK_DYNM, 589 "divider_dsp_aclk_div_dynm", 590 EIC7700_CLK_MUX_DSP_ACLK_ROOT_2MUX1_GFREE, 0, 591 EIC7700_REG_OFFSET_DSP_ACLK, 4, 4, 0, 592 ESWIN_PRIV_DIV_MIN_2), 593 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_DDR_ACLK_DYNM, 594 "divider_ddr_aclk_div_dynm", 595 EIC7700_CLK_MUX_DDR_ACLK_ROOT_2MUX1_GFREE, 0, 596 EIC7700_REG_OFFSET_DDR, 20, 4, 0, ESWIN_PRIV_DIV_MIN_2), 597 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_ETH_TXCLK_DYNM_0, 598 "divider_eth_txclk_div_dynm_0", 599 EIC7700_CLK_MUX_ETH_CORE_2MUX1, 0, 600 EIC7700_REG_OFFSET_ETH0, 4, 7, 0, ESWIN_PRIV_DIV_MIN_2), 601 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_ETH_TXCLK_DYNM_1, 602 "divider_eth_txclk_div_dynm_1", 603 EIC7700_CLK_MUX_ETH_CORE_2MUX1, 0, 604 EIC7700_REG_OFFSET_ETH1, 4, 7, 0, ESWIN_PRIV_DIV_MIN_2), 605 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_MSHC_CORE_DYNM_0, 606 "divider_mshc_core_div_dynm_0", 607 EIC7700_CLK_MUX_MSHCORE_ROOT_3MUX1_0, 608 0, EIC7700_REG_OFFSET_MSHC0_CORE, 4, 12, 609 CLK_DIVIDER_ONE_BASED | CLK_DIVIDER_ALLOW_ZERO, 0), 610 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_MSHC_CORE_DYNM_1, 611 "divider_mshc_core_div_dynm_1", 612 EIC7700_CLK_MUX_MSHCORE_ROOT_3MUX1_1, 613 0, EIC7700_REG_OFFSET_MSHC1_CORE, 4, 12, 614 CLK_DIVIDER_ONE_BASED | CLK_DIVIDER_ALLOW_ZERO, 0), 615 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_MSHC_CORE_DYNM_2, 616 "divider_mshc_core_div_dynm_2", 617 EIC7700_CLK_MUX_MSHCORE_ROOT_3MUX1_2, 618 0, EIC7700_REG_OFFSET_MSHC2_CORE, 4, 12, 619 CLK_DIVIDER_ONE_BASED | CLK_DIVIDER_ALLOW_ZERO, 0), 620 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_NPU_CORECLK_DYNM, 621 "divider_npu_coreclk_div_dynm", 622 EIC7700_CLK_MUX_NPU_CORE_3MUX1_GFREE, 623 0, EIC7700_REG_OFFSET_NPU_CORE, 4, 4, 624 CLK_DIVIDER_ONE_BASED | CLK_DIVIDER_ALLOW_ZERO, 0), 625 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_NPU_E31_DYNM, "divider_npu_e31_div_dynm", 626 EIC7700_CLK_MUX_NPU_E31_3MUX1_GFREE, 0, 627 EIC7700_REG_OFFSET_NPU_CORE, 12, 4, 628 CLK_DIVIDER_ONE_BASED | CLK_DIVIDER_ALLOW_ZERO, 0), 629 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VI_ACLK_DYNM, "divider_vi_aclk_div_dynm", 630 EIC7700_CLK_MUX_VI_ACLK_ROOT_2MUX1_GFREE, 0, 631 EIC7700_REG_OFFSET_VI_ACLK, 4, 4, 0, 632 ESWIN_PRIV_DIV_MIN_2), 633 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VI_DW_DYNM, "divider_vi_dw_div_dynm", 634 EIC7700_CLK_MUX_VI_DW_ROOT_2MUX1, 0, 635 EIC7700_REG_OFFSET_VI_DWCLK, 4, 4, 0, 636 ESWIN_PRIV_DIV_MIN_2), 637 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VI_DVP_DYNM, "divider_vi_dvp_div_dynm", 638 EIC7700_CLK_MUX_VI_DVP_ROOT_2MUX1_GFREE, 0, 639 EIC7700_REG_OFFSET_VI_DVP, 4, 4, 0, 640 ESWIN_PRIV_DIV_MIN_2), 641 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VI_DIG_ISP_DYNM, 642 "divider_vi_dig_isp_div_dynm", 643 EIC7700_CLK_MUX_VI_DIG_ISP_ROOT_2MUX1_GFREE, 0, 644 EIC7700_REG_OFFSET_VI_DIG_ISP, 4, 4, 0, 645 ESWIN_PRIV_DIV_MIN_2), 646 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VO_ACLK_DYNM, "divider_vo_aclk_div_dynm", 647 EIC7700_CLK_MUX_VO_ACLK_ROOT_2MUX1_GFREE, 0, 648 EIC7700_REG_OFFSET_VO_ACLK, 4, 4, 0, 649 ESWIN_PRIV_DIV_MIN_2), 650 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VO_PIXEL_DYNM, 651 "divider_vo_pixel_div_dynm", 652 EIC7700_CLK_MUX_VO_PIXEL_ROOT_2MUX1, 0, 653 EIC7700_REG_OFFSET_VO_PIXEL, 4, 6, 0, 654 ESWIN_PRIV_DIV_MIN_2), 655 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VC_ACLK_DYNM, "divider_vc_aclk_div_dynm", 656 EIC7700_CLK_MUX_VCACLK_ROOT_2MUX1_GFREE, 0, 657 EIC7700_REG_OFFSET_VC_ACLK, 4, 4, 0, 658 ESWIN_PRIV_DIV_MIN_2), 659 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_JD_DYNM, "divider_jd_div_dynm", 660 EIC7700_CLK_MUX_VCDEC_ROOT_2MUX1_GFREE, 0, 661 EIC7700_REG_OFFSET_JD, 4, 4, 0, ESWIN_PRIV_DIV_MIN_2), 662 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_JE_DYNM, "divider_je_div_dynm", 663 EIC7700_CLK_MUX_VCDEC_ROOT_2MUX1_GFREE, 0, 664 EIC7700_REG_OFFSET_JE, 4, 4, 0, ESWIN_PRIV_DIV_MIN_2), 665 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VE_DYNM, "divider_ve_div_dynm", 666 EIC7700_CLK_MUX_VCDEC_ROOT_2MUX1_GFREE, 0, 667 EIC7700_REG_OFFSET_VE, 4, 4, 0, ESWIN_PRIV_DIV_MIN_2), 668 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VD_DYNM, "divider_vd_div_dynm", 669 EIC7700_CLK_MUX_VCDEC_ROOT_2MUX1_GFREE, 0, 670 EIC7700_REG_OFFSET_VD, 4, 4, 0, ESWIN_PRIV_DIV_MIN_2), 671 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_G2D_DYNM, "divider_g2d_div_dynm", 672 EIC7700_CLK_MUX_DSP_ACLK_ROOT_2MUX1_GFREE, 0, 673 EIC7700_REG_OFFSET_G2D, 4, 4, 0, ESWIN_PRIV_DIV_MIN_2), 674 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_NOC_NSP_DYNM, "divider_noc_nsp_div_dynm", 675 EIC7700_CLK_SPLL2_FOUT1, 0, EIC7700_REG_OFFSET_NOC, 0, 3, 676 0, ESWIN_PRIV_DIV_MIN_2), 677 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_GPU_ACLK_DYNM, 678 "divider_gpu_aclk_div_dynm", EIC7700_CLK_SPLL0_FOUT1, 0, 679 EIC7700_REG_OFFSET_GPU_ACLK, 4, 4, 0, 680 ESWIN_PRIV_DIV_MIN_2), 681 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_HSP_ACLK_DYNM, 682 "divider_hsp_aclk_div_dynm", EIC7700_CLK_SPLL0_FOUT1, 0, 683 EIC7700_REG_OFFSET_HSP_ACLK, 4, 4, 0, 684 ESWIN_PRIV_DIV_MIN_2), 685 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_PCIE_ACLK_DYNM, 686 "divider_pcie_aclk_div_dynm", EIC7700_CLK_SPLL2_FOUT2, 0, 687 EIC7700_REG_OFFSET_PCIE_ACLK, 4, 4, 0, 688 ESWIN_PRIV_DIV_MIN_2), 689 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_NPU_ACLK_DYNM, 690 "divider_npu_aclk_div_dynm", EIC7700_CLK_SPLL0_FOUT1, 0, 691 EIC7700_REG_OFFSET_NPU_ACLK, 4, 4, 0, 692 ESWIN_PRIV_DIV_MIN_2), 693 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VI_SHUTTER_DYNM_0, 694 "divider_vi_shutter_div_dynm_0", 695 EIC7700_CLK_VPLL_FOUT2, 0, 696 EIC7700_REG_OFFSET_VI_SHUTTER0, 4, 7, 0, 697 ESWIN_PRIV_DIV_MIN_2), 698 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VI_SHUTTER_DYNM_1, 699 "divider_vi_shutter_div_dynm_1", 700 EIC7700_CLK_VPLL_FOUT2, 0, 701 EIC7700_REG_OFFSET_VI_SHUTTER1, 4, 7, 0, 702 ESWIN_PRIV_DIV_MIN_2), 703 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VI_SHUTTER_DYNM_2, 704 "divider_vi_shutter_div_dynm_2", 705 EIC7700_CLK_VPLL_FOUT2, 0, 706 EIC7700_REG_OFFSET_VI_SHUTTER2, 4, 7, 0, 707 ESWIN_PRIV_DIV_MIN_2), 708 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VI_SHUTTER_DYNM_3, 709 "divider_vi_shutter_div_dynm_3", 710 EIC7700_CLK_VPLL_FOUT2, 0, 711 EIC7700_REG_OFFSET_VI_SHUTTER3, 4, 7, 0, 712 ESWIN_PRIV_DIV_MIN_2), 713 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VI_SHUTTER_DYNM_4, 714 "divider_vi_shutter_div_dynm_4", 715 EIC7700_CLK_VPLL_FOUT2, 0, 716 EIC7700_REG_OFFSET_VI_SHUTTER4, 4, 7, 0, 717 ESWIN_PRIV_DIV_MIN_2), 718 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VI_SHUTTER_DYNM_5, 719 "divider_vi_shutter_div_dynm_5", 720 EIC7700_CLK_VPLL_FOUT2, 0, 721 EIC7700_REG_OFFSET_VI_SHUTTER5, 4, 7, 0, 722 ESWIN_PRIV_DIV_MIN_2), 723 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_IESMCLK_DYNM, "divider_iesmclk_div_dynm", 724 EIC7700_CLK_SPLL0_FOUT3, 0, 725 EIC7700_REG_OFFSET_VO_IESMCLK, 4, 4, 0, 726 ESWIN_PRIV_DIV_MIN_2), 727 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_VO_CEC_DYNM, "divider_vo_cec_div_dynm", 728 EIC7700_CLK_VPLL_FOUT2, 0, 729 EIC7700_REG_OFFSET_VO_PHY_CLK, 16, 16, 0, 730 ESWIN_PRIV_DIV_MIN_2), 731 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_CRYPTO_DYNM, "divider_crypto_div_dynm", 732 EIC7700_CLK_SPLL0_FOUT1, 0, 733 EIC7700_REG_OFFSET_SPACC, 4, 4, 0, ESWIN_PRIV_DIV_MIN_2), 734 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_AON_RTC_DYNM, "divider_aon_rtc_div_dynm", 735 EIC7700_CLK_FIXED_FACTOR_CLK_1M_DIV24, 0, 736 EIC7700_REG_OFFSET_RTC, 21, 11, 0, 737 ESWIN_PRIV_DIV_MIN_2), 738 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DSPT_ACLK, "gate_dspt_aclk", 739 EIC7700_CLK_DIV_DSP_ACLK_DYNM, CLK_SET_RATE_PARENT, 740 EIC7700_REG_OFFSET_DSP_ACLK, 31, 0), 741 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_DSP_0_ACLK_DYNM, 742 "divider_dsp_0_aclk_div_dynm", 743 EIC7700_CLK_GATE_DSPT_ACLK, 0, 744 EIC7700_REG_OFFSET_DSP_CFG, 19, 1, 0, 0), 745 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_DSP_1_ACLK_DYNM, 746 "divider_dsp_1_aclk_div_dynm", 747 EIC7700_CLK_GATE_DSPT_ACLK, 0, 748 EIC7700_REG_OFFSET_DSP_CFG, 20, 1, 0, 0), 749 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_DSP_2_ACLK_DYNM, 750 "divider_dsp_2_aclk_div_dynm", 751 EIC7700_CLK_GATE_DSPT_ACLK, 0, 752 EIC7700_REG_OFFSET_DSP_CFG, 21, 1, 0, 0), 753 ESWIN_DIV_TYPE(EIC7700_CLK_DIV_DSP_3_ACLK_DYNM, 754 "divider_dsp_3_aclk_div_dynm", 755 EIC7700_CLK_GATE_DSPT_ACLK, 0, 756 EIC7700_REG_OFFSET_DSP_CFG, 22, 1, 0, 0), 757 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_CPU_EXT_SRC_CORE_CLK_0, 758 "gate_clk_cpu_ext_src_core_clk_0", 759 EIC7700_CLK_MUX_CPU_ROOT_3MUX1_GFREE, 760 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 761 EIC7700_REG_OFFSET_U84, 28, 0), 762 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_CPU_EXT_SRC_CORE_CLK_1, 763 "gate_clk_cpu_ext_src_core_clk_1", 764 EIC7700_CLK_MUX_CPU_ROOT_3MUX1_GFREE, 765 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 766 EIC7700_REG_OFFSET_U84, 29, 0), 767 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_CPU_EXT_SRC_CORE_CLK_2, 768 "gate_clk_cpu_ext_src_core_clk_2", 769 EIC7700_CLK_MUX_CPU_ROOT_3MUX1_GFREE, 770 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 771 EIC7700_REG_OFFSET_U84, 30, 0), 772 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_CPU_EXT_SRC_CORE_CLK_3, 773 "gate_clk_cpu_ext_src_core_clk_3", 774 EIC7700_CLK_MUX_CPU_ROOT_3MUX1_GFREE, 775 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 776 EIC7700_REG_OFFSET_U84, 31, 0), 777 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_CPU_TRACE_CLK_0, 778 "gate_clk_cpu_trace_clk_0", 779 EIC7700_CLK_MUX_CPU_ROOT_3MUX1_GFREE, 780 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_U84, 24, 0), 781 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_CPU_TRACE_CLK_1, 782 "gate_clk_cpu_trace_clk_1", 783 EIC7700_CLK_MUX_CPU_ROOT_3MUX1_GFREE, 784 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_U84, 25, 0), 785 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_CPU_TRACE_CLK_2, 786 "gate_clk_cpu_trace_clk_2", 787 EIC7700_CLK_MUX_CPU_ROOT_3MUX1_GFREE, 788 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_U84, 26, 0), 789 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_CPU_TRACE_CLK_3, 790 "gate_clk_cpu_trace_clk_3", 791 EIC7700_CLK_MUX_CPU_ROOT_3MUX1_GFREE, 792 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_U84, 27, 0), 793 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_NOC_NSP_CLK, "gate_noc_nsp_clk", 794 EIC7700_CLK_DIV_NOC_NSP_DYNM, CLK_SET_RATE_PARENT, 795 EIC7700_REG_OFFSET_NOC, 31, 0), 796 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_BOOTSPI, "gate_clk_bootspi", 797 EIC7700_CLK_MUX_BOOTSPI_CLK_2MUX1_GFREE, 798 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_BOOTSPI, 31, 0), 799 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_BOOTSPI_CFG, "gate_clk_bootspi_cfg", 800 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 801 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_BOOTSPI_CFGCLK, 802 31, 0), 803 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_SCPU_CORE, "gate_clk_scpu_core", 804 EIC7700_CLK_MUX_SCPU_CORE_CLK_2MUX1_GFREE, 805 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_SCPU_CORE, 31, 806 0), 807 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_SCPU_BUS, "gate_clk_scpu_bus", 808 EIC7700_CLK_FIXED_FACTOR_SCPU_BUS_DIV2, 809 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_SCPU_BUSCLK, 31, 810 0), 811 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LPCPU_CORE, "gate_clk_lpcpu_core", 812 EIC7700_CLK_MUX_LPCPU_CORE_CLK_2MUX1_GFREE, 813 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LPCPU_CORE, 31, 814 0), 815 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LPCPU_BUS, "gate_clk_lpcpu_bus", 816 EIC7700_CLK_FIXED_FACTOR_LPCPU_BUS_DIV2, 817 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LPCPU_BUSCLK, 818 31, 0), 819 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_GPU_ACLK, "gate_gpu_aclk", 820 EIC7700_CLK_DIV_GPU_ACLK_DYNM, CLK_SET_RATE_PARENT, 821 EIC7700_REG_OFFSET_GPU_ACLK, 31, 0), 822 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_GPU_CFG_CLK, "gate_gpu_cfg_clk", 823 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 824 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_GPU_CFG, 31, 0), 825 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DSPT_CFG_CLK, "gate_dspt_cfg_clk", 826 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 827 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_DSP_CFG, 31, 0), 828 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_D2D_ACLK, "gate_d2d_aclk", 829 EIC7700_CLK_DIV_D2D_ACLK_DYNM, CLK_SET_RATE_PARENT, 830 EIC7700_REG_OFFSET_D2D_ACLK, 31, 0), 831 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_D2D_CFG_CLK, "gate_d2d_cfg_clk", 832 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 833 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_D2D_CFG, 31, 0), 834 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_TCU_ACLK, "gate_tcu_aclk", 835 EIC7700_CLK_DIV_DDR_ACLK_DYNM, CLK_SET_RATE_PARENT, 836 EIC7700_REG_OFFSET_TCU_ACLK, 31, 0), 837 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_TCU_CFG_CLK, "gate_tcu_cfg_clk", 838 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 839 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_TCU_CFG, 31, 0), 840 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT_CFG_CLK, "gate_ddrt_cfg_clk", 841 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 842 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_DDR, 9, 0), 843 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT0_P0_ACLK, "gate_ddrt0_p0_aclk", 844 EIC7700_CLK_DIV_DDR_ACLK_DYNM, 845 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 846 EIC7700_REG_OFFSET_DDR, 4, 0), 847 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT0_P1_ACLK, "gate_ddrt0_p1_aclk", 848 EIC7700_CLK_DIV_DDR_ACLK_DYNM, 849 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 850 EIC7700_REG_OFFSET_DDR, 5, 0), 851 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT0_P2_ACLK, "gate_ddrt0_p2_aclk", 852 EIC7700_CLK_DIV_DDR_ACLK_DYNM, 853 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 854 EIC7700_REG_OFFSET_DDR, 6, 0), 855 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT0_P3_ACLK, "gate_ddrt0_p3_aclk", 856 EIC7700_CLK_DIV_DDR_ACLK_DYNM, 857 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 858 EIC7700_REG_OFFSET_DDR, 7, 0), 859 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT0_P4_ACLK, "gate_ddrt0_p4_aclk", 860 EIC7700_CLK_DIV_DDR_ACLK_DYNM, 861 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 862 EIC7700_REG_OFFSET_DDR, 8, 0), 863 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT1_P0_ACLK, "gate_ddrt1_p0_aclk", 864 EIC7700_CLK_DIV_DDR_ACLK_DYNM, 865 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 866 EIC7700_REG_OFFSET_DDR1, 4, 0), 867 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT1_P1_ACLK, "gate_ddrt1_p1_aclk", 868 EIC7700_CLK_DIV_DDR_ACLK_DYNM, 869 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 870 EIC7700_REG_OFFSET_DDR1, 5, 0), 871 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT1_P2_ACLK, "gate_ddrt1_p2_aclk", 872 EIC7700_CLK_DIV_DDR_ACLK_DYNM, 873 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 874 EIC7700_REG_OFFSET_DDR1, 6, 0), 875 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT1_P3_ACLK, "gate_ddrt1_p3_aclk", 876 EIC7700_CLK_DIV_DDR_ACLK_DYNM, 877 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 878 EIC7700_REG_OFFSET_DDR1, 7, 0), 879 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDRT1_P4_ACLK, "gate_ddrt1_p4_aclk", 880 EIC7700_CLK_DIV_DDR_ACLK_DYNM, 881 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 882 EIC7700_REG_OFFSET_DDR1, 8, 0), 883 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_ACLK, "gate_clk_hsp_aclk", 884 EIC7700_CLK_DIV_HSP_ACLK_DYNM, CLK_SET_RATE_PARENT, 885 EIC7700_REG_OFFSET_HSP_ACLK, 31, 0), 886 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_CFG_CLK, "gate_clk_hsp_cfg_clk", 887 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 888 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_HSP_CFG, 31, 0), 889 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_PCIET_ACLK, "gate_pciet_aclk", 890 EIC7700_CLK_DIV_PCIE_ACLK_DYNM, CLK_SET_RATE_PARENT, 891 EIC7700_REG_OFFSET_PCIE_ACLK, 31, 0), 892 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_PCIET_CFG_CLK, "gate_pciet_cfg_clk", 893 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 894 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_PCIE_CFG, 31, 895 0), 896 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_PCIET_CR_CLK, "gate_pciet_cr_clk", 897 EIC7700_CLK_FIXED_FACTOR_PCIE_CR_DIV2, 898 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_PCIE_CFG, 0, 0), 899 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_PCIET_AUX_CLK, "gate_pciet_aux_clk", 900 EIC7700_CLK_FIXED_FACTOR_PCIE_AUX_DIV4, 901 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_PCIE_CFG, 1, 0), 902 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_NPU_ACLK, "gate_npu_aclk", 903 EIC7700_CLK_DIV_NPU_ACLK_DYNM, CLK_SET_RATE_PARENT, 904 EIC7700_REG_OFFSET_NPU_ACLK, 31, 0), 905 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_NPU_CFG_CLK, "gate_npu_cfg_clk", 906 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 907 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_NPU_ACLK, 30, 908 0), 909 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_NPU_LLC_ACLK, "gate_npu_llc_aclk", 910 EIC7700_CLK_MUX_NPU_LLCLK_3MUX1_GFREE, 911 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_NPU_LLC, 31, 0), 912 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_NPU_CLK, "gate_npu_clk", 913 EIC7700_CLK_DIV_NPU_CORECLK_DYNM, CLK_SET_RATE_PARENT, 914 EIC7700_REG_OFFSET_NPU_CORE, 31, 0), 915 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_NPU_E31_CLK, "gate_npu_e31_clk", 916 EIC7700_CLK_DIV_NPU_E31_DYNM, CLK_SET_RATE_PARENT, 917 EIC7700_REG_OFFSET_NPU_CORE, 30, 0), 918 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_ACLK, "gate_vi_aclk", 919 EIC7700_CLK_DIV_VI_ACLK_DYNM, CLK_SET_RATE_PARENT, 920 EIC7700_REG_OFFSET_VI_ACLK, 31, 0), 921 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_CFG_CLK, "gate_vi_cfg_clk", 922 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 923 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VI_ACLK, 30, 0), 924 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_DIG_DW_CLK, "gate_vi_dig_dw_clk", 925 EIC7700_CLK_DIV_VI_DW_DYNM, CLK_SET_RATE_PARENT, 926 EIC7700_REG_OFFSET_VI_DWCLK, 31, 0), 927 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_DVP_CLK, "gate_vi_dvp_clk", 928 EIC7700_CLK_DIV_VI_DVP_DYNM, CLK_SET_RATE_PARENT, 929 EIC7700_REG_OFFSET_VI_DVP, 31, 0), 930 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_DIG_ISP_CLK, "gate_vi_dig_isp_clk", 931 EIC7700_CLK_DIV_VI_DIG_ISP_DYNM, CLK_SET_RATE_PARENT, 932 EIC7700_REG_OFFSET_VI_DIG_ISP, 31, 0), 933 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_SHUTTER_0, "gate_vi_shutter_0", 934 EIC7700_CLK_DIV_VI_SHUTTER_DYNM_0, CLK_SET_RATE_PARENT, 935 EIC7700_REG_OFFSET_VI_SHUTTER0, 31, 0), 936 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_SHUTTER_1, "gate_vi_shutter_1", 937 EIC7700_CLK_DIV_VI_SHUTTER_DYNM_1, CLK_SET_RATE_PARENT, 938 EIC7700_REG_OFFSET_VI_SHUTTER1, 31, 0), 939 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_SHUTTER_2, "gate_vi_shutter_2", 940 EIC7700_CLK_DIV_VI_SHUTTER_DYNM_2, CLK_SET_RATE_PARENT, 941 EIC7700_REG_OFFSET_VI_SHUTTER2, 31, 0), 942 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_SHUTTER_3, "gate_vi_shutter_3", 943 EIC7700_CLK_DIV_VI_SHUTTER_DYNM_3, CLK_SET_RATE_PARENT, 944 EIC7700_REG_OFFSET_VI_SHUTTER3, 31, 0), 945 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_SHUTTER_4, "gate_vi_shutter_4", 946 EIC7700_CLK_DIV_VI_SHUTTER_DYNM_4, CLK_SET_RATE_PARENT, 947 EIC7700_REG_OFFSET_VI_SHUTTER4, 31, 0), 948 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_SHUTTER_5, "gate_vi_shutter_5", 949 EIC7700_CLK_DIV_VI_SHUTTER_DYNM_5, CLK_SET_RATE_PARENT, 950 EIC7700_REG_OFFSET_VI_SHUTTER5, 31, 0), 951 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VI_PHY_TXCLKESC, 952 "gate_vi_phy_txclkesc", 953 EIC7700_CLK_FIXED_FACTOR_MIPI_TXESC_DIV10, 954 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VI_PHY, 0, 0), 955 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VO_ACLK, "gate_vo_aclk", 956 EIC7700_CLK_DIV_VO_ACLK_DYNM, CLK_SET_RATE_PARENT, 957 EIC7700_REG_OFFSET_VO_ACLK, 31, 0), 958 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VO_CFG_CLK, "gate_vo_cfg_clk", 959 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 960 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VO_ACLK, 30, 0), 961 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VO_HDMI_IESMCLK, 962 "gate_vo_hdmi_iesmclk", EIC7700_CLK_DIV_IESMCLK_DYNM, 963 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VO_IESMCLK, 31, 964 0), 965 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VO_PIXEL_CLK, "gate_vo_pixel_clk", 966 EIC7700_CLK_DIV_VO_PIXEL_DYNM, CLK_SET_RATE_PARENT, 967 EIC7700_REG_OFFSET_VO_PIXEL, 31, 0), 968 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VO_I2S_MCLK, "gate_vo_i2s_mclk", 969 EIC7700_CLK_MUX_VO_MCLK_2MUX_EXT_MCLK, 970 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VO_MCLK, 31, 0), 971 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VO_CR_CLK, "gate_vo_cr_clk", 972 EIC7700_CLK_FIXED_FACTOR_MIPI_TXESC_DIV10, 973 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VO_PHY_CLK, 1, 974 0), 975 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_ACLK, "gate_vc_aclk", 976 EIC7700_CLK_DIV_VC_ACLK_DYNM, CLK_SET_RATE_PARENT, 977 EIC7700_REG_OFFSET_VC_ACLK, 31, 0), 978 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_CFG_CLK, "gate_vc_cfg_clk", 979 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 980 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VC_CLKEN, 0, 0), 981 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_JE_CLK, "gate_vc_je_clk", 982 EIC7700_CLK_DIV_JE_DYNM, CLK_SET_RATE_PARENT, 983 EIC7700_REG_OFFSET_JE, 31, 0), 984 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_JD_CLK, "gate_vc_jd_clk", 985 EIC7700_CLK_DIV_JD_DYNM, CLK_SET_RATE_PARENT, 986 EIC7700_REG_OFFSET_JD, 31, 0), 987 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_VE_CLK, "gate_vc_ve_clk", 988 EIC7700_CLK_DIV_VE_DYNM, CLK_SET_RATE_PARENT, 989 EIC7700_REG_OFFSET_VE, 31, 0), 990 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_VD_CLK, "gate_vc_vd_clk", 991 EIC7700_CLK_DIV_VD_DYNM, CLK_SET_RATE_PARENT, 992 EIC7700_REG_OFFSET_VD, 31, 0), 993 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_G2D_CFG_CLK, "gate_g2d_cfg_clk", 994 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 995 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_G2D, 28, 0), 996 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_G2D_CLK, "gate_g2d_clk", 997 EIC7700_CLK_DIV_G2D_DYNM, CLK_SET_RATE_PARENT, 998 EIC7700_REG_OFFSET_G2D, 30, 0), 999 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_G2D_ACLK, "gate_g2d_aclk", 1000 EIC7700_CLK_DIV_G2D_DYNM, CLK_SET_RATE_PARENT, 1001 EIC7700_REG_OFFSET_G2D, 31, 0), 1002 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_AONDMA_CFG, "gate_clk_aondma_cfg", 1003 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1004 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_AON_DMA, 30, 0), 1005 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_AONDMA_ACLK, "gate_aondma_aclk", 1006 EIC7700_CLK_MUX_AONDMA_AXI2MUX1_GFREE, 1007 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_AON_DMA, 31, 0), 1008 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_AON_ACLK, "gate_aon_aclk", 1009 EIC7700_CLK_MUX_AONDMA_AXI2MUX1_GFREE, 1010 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_AON_DMA, 29, 0), 1011 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_TIMER_PCLK_0, "gate_timer_pclk_0", 1012 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1013 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_TIMER, 4, 0), 1014 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_TIMER_PCLK_1, "gate_timer_pclk_1", 1015 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1016 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_TIMER, 5, 0), 1017 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_TIMER_PCLK_2, "gate_timer_pclk_2", 1018 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1019 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_TIMER, 6, 0), 1020 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_TIMER_PCLK_3, "gate_timer_pclk_3", 1021 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1022 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_TIMER, 7, 0), 1023 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_TIMER3_CLK8, "gate_timer3_clk8", 1024 EIC7700_CLK_VPLL_FOUT3, CLK_SET_RATE_PARENT, 1025 EIC7700_REG_OFFSET_TIMER, 8, 0), 1026 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_RTC_CFG, "gate_clk_rtc_cfg", 1027 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1028 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_RTC, 2, 0), 1029 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_RTC, "gate_clk_rtc", 1030 EIC7700_CLK_DIV_AON_RTC_DYNM, CLK_SET_RATE_PARENT, 1031 EIC7700_REG_OFFSET_RTC, 1, 0), 1032 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_RMII_REF_0, "gate_hsp_rmii_ref_0", 1033 EIC7700_CLK_MUX_RMII_REF_2MUX, CLK_SET_RATE_PARENT, 1034 EIC7700_REG_OFFSET_ETH0, 31, 0), 1035 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_RMII_REF_1, "gate_hsp_rmii_ref_1", 1036 EIC7700_CLK_MUX_RMII_REF_2MUX, CLK_SET_RATE_PARENT, 1037 EIC7700_REG_OFFSET_ETH1, 31, 0), 1038 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_PKA_CFG, "gate_clk_pka_cfg", 1039 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1040 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_PKA, 31, 0), 1041 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_SPACC_CFG, "gate_clk_spacc_cfg", 1042 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1043 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_SPACC, 31, 0), 1044 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_CRYPTO, "gate_clk_crypto", 1045 EIC7700_CLK_DIV_CRYPTO_DYNM, CLK_SET_RATE_PARENT, 1046 EIC7700_REG_OFFSET_SPACC, 30, 0), 1047 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_TRNG_CFG, "gate_clk_trng_cfg", 1048 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1049 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_TRNG, 31, 0), 1050 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_OTP_CFG, "gate_clk_otp_cfg", 1051 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1052 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_OTP, 31, 0), 1053 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_0, "gate_clk_mailbox_0", 1054 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1055 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 0, 0), 1056 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_1, "gate_clk_mailbox_1", 1057 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1058 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 1, 0), 1059 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_2, "gate_clk_mailbox_2", 1060 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1061 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 2, 0), 1062 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_3, "gate_clk_mailbox_3", 1063 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1064 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 3, 0), 1065 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_4, "gate_clk_mailbox_4", 1066 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1067 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 4, 0), 1068 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_5, "gate_clk_mailbox_5", 1069 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1070 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 5, 0), 1071 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_6, "gate_clk_mailbox_6", 1072 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1073 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 6, 0), 1074 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_7, "gate_clk_mailbox_7", 1075 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1076 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 7, 0), 1077 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_8, "gate_clk_mailbox_8", 1078 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1079 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 8, 0), 1080 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_9, "gate_clk_mailbox_9", 1081 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1082 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 9, 0), 1083 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_10, "gate_clk_mailbox_10", 1084 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1085 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 10, 0), 1086 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_11, "gate_clk_mailbox_11", 1087 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1088 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 11, 0), 1089 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_12, "gate_clk_mailbox_12", 1090 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1091 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 12, 0), 1092 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_13, "gate_clk_mailbox_13", 1093 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1094 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 13, 0), 1095 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_14, "gate_clk_mailbox_14", 1096 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1097 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 14, 0), 1098 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_MAILBOX_15, "gate_clk_mailbox_15", 1099 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1100 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN1, 15, 0), 1101 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_I2C0_PCLK, "gate_i2c0_pclk", 1102 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1103 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 7, 0), 1104 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_I2C1_PCLK, "gate_i2c1_pclk", 1105 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1106 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 8, 0), 1107 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_I2C2_PCLK, "gate_i2c2_pclk", 1108 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1109 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 9, 0), 1110 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_I2C3_PCLK, "gate_i2c3_pclk", 1111 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1112 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 10, 0), 1113 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_I2C4_PCLK, "gate_i2c4_pclk", 1114 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1115 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 11, 0), 1116 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_I2C5_PCLK, "gate_i2c5_pclk", 1117 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1118 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 12, 0), 1119 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_I2C6_PCLK, "gate_i2c6_pclk", 1120 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1121 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 13, 0), 1122 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_I2C7_PCLK, "gate_i2c7_pclk", 1123 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1124 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 14, 0), 1125 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_I2C8_PCLK, "gate_i2c8_pclk", 1126 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1127 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 15, 0), 1128 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_I2C9_PCLK, "gate_i2c9_pclk", 1129 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1130 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 16, 0), 1131 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_WDT0_PCLK, "gate_lsp_wdt0_pclk", 1132 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1133 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 28, 0), 1134 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_WDT1_PCLK, "gate_lsp_wdt1_pclk", 1135 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1136 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 29, 0), 1137 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_WDT2_PCLK, "gate_lsp_wdt2_pclk", 1138 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1139 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 30, 0), 1140 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_WDT3_PCLK, "gate_lsp_wdt3_pclk", 1141 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1142 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 31, 0), 1143 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_SSI0_PCLK, "gate_lsp_ssi0_pclk", 1144 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1145 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 26, 0), 1146 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_SSI1_PCLK, "gate_lsp_ssi1_pclk", 1147 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1148 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 27, 0), 1149 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_UART0_PCLK, "gate_lsp_uart0_pclk", 1150 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1151 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 1152 EIC7700_REG_OFFSET_LSP_EN0, 17, 0), 1153 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_UART1_PCLK, "gate_lsp_uart1_pclk", 1154 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1155 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 18, 0), 1156 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_UART2_PCLK, "gate_lsp_uart2_pclk", 1157 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1158 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 1159 EIC7700_REG_OFFSET_LSP_EN0, 19, 0), 1160 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_UART3_PCLK, "gate_lsp_uart3_pclk", 1161 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1162 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 20, 0), 1163 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_UART4_PCLK, "gate_lsp_uart4_pclk", 1164 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1165 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 21, 0), 1166 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_TIMER_PCLK, "gate_lsp_timer_pclk", 1167 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1168 CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 1169 EIC7700_REG_OFFSET_LSP_EN0, 25, 0), 1170 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_FAN_PCLK, "gate_lsp_fan_pclk", 1171 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1172 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 0, 0), 1173 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_PVT_PCLK, "gate_lsp_pvt_pclk", 1174 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1175 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_LSP_EN0, 1, 0), 1176 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_PVT0_CLK, "gate_pvt0_clk", 1177 EIC7700_CLK_FIXED_FACTOR_PVT_DIV20, CLK_SET_RATE_PARENT, 1178 EIC7700_REG_OFFSET_LSP_EN1, 16, 0), 1179 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_LSP_PVT1_CLK, "gate_pvt1_clk", 1180 EIC7700_CLK_FIXED_FACTOR_PVT_DIV20, CLK_SET_RATE_PARENT, 1181 EIC7700_REG_OFFSET_LSP_EN1, 17, 0), 1182 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_JE_PCLK, "gate_vc_je_pclk", 1183 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1184 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VC_CLKEN, 2, 0), 1185 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_JD_PCLK, "gate_vc_jd_pclk", 1186 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1187 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VC_CLKEN, 1, 0), 1188 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_VE_PCLK, "gate_vc_ve_pclk", 1189 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1190 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VC_CLKEN, 5, 0), 1191 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_VD_PCLK, "gate_vc_vd_pclk", 1192 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1193 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VC_CLKEN, 4, 0), 1194 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_VC_MON_PCLK, "gate_vc_mon_pclk", 1195 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1196 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_VC_CLKEN, 3, 0), 1197 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_MSHC0_CORE_CLK, 1198 "gate_hsp_mshc0_core_clk", 1199 EIC7700_CLK_DIV_MSHC_CORE_DYNM_0, CLK_SET_RATE_PARENT, 1200 EIC7700_REG_OFFSET_MSHC0_CORE, 16, 0), 1201 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_MSHC1_CORE_CLK, 1202 "gate_hsp_mshc1_core_clk", 1203 EIC7700_CLK_DIV_MSHC_CORE_DYNM_1, CLK_SET_RATE_PARENT, 1204 EIC7700_REG_OFFSET_MSHC1_CORE, 16, 0), 1205 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_MSHC2_CORE_CLK, 1206 "gate_hsp_mshc2_core_clk", 1207 EIC7700_CLK_DIV_MSHC_CORE_DYNM_2, CLK_SET_RATE_PARENT, 1208 EIC7700_REG_OFFSET_MSHC2_CORE, 16, 0), 1209 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_SATA_RBC_CLK, 1210 "gate_hsp_sata_rbc_clk", EIC7700_CLK_SPLL1_FOUT2, 1211 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_SATA_RBC, 1212 0, 0), 1213 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_SATA_OOB_CLK, 1214 "gate_hsp_sata_oob_clk", EIC7700_CLK_MUX_SATA_PHY_2MUX1, 1215 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_SATA_OOB, 31, 1216 0), 1217 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_DMA0_CLK_TEST, 1218 "gate_hsp_dma0_clk_test", EIC7700_CLK_GATE_HSP_ACLK, 1219 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_HSP_ACLK, 1, 0), 1220 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_DMA0_CLK, "gate_hsp_dma0_clk", 1221 EIC7700_CLK_GATE_HSP_ACLK, CLK_SET_RATE_PARENT, 1222 EIC7700_REG_OFFSET_HSP_ACLK, 0, 0), 1223 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_ETH0_CORE_CLK, 1224 "gate_hsp_eth0_core_clk", 1225 EIC7700_CLK_DIV_ETH_TXCLK_DYNM_0, CLK_SET_RATE_PARENT, 1226 EIC7700_REG_OFFSET_ETH0, 0, 0), 1227 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_HSP_ETH1_CORE_CLK, 1228 "gate_hsp_eth1_core_clk", 1229 EIC7700_CLK_DIV_ETH_TXCLK_DYNM_1, CLK_SET_RATE_PARENT, 1230 EIC7700_REG_OFFSET_ETH1, 0, 0), 1231 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_AON_I2C0_PCLK, "gate_aon_i2c0_pclk", 1232 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1233 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_I2C0, 31, 0), 1234 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_AON_I2C1_PCLK, "gate_aon_i2c1_pclk", 1235 EIC7700_CLK_MUX_SYSCFG_CLK_ROOT_2MUX1_GFREE, 1236 CLK_SET_RATE_PARENT, EIC7700_REG_OFFSET_I2C1, 31, 0), 1237 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDR0_TRACE, "gate_ddr0_trace", 1238 EIC7700_CLK_DIV_DDR_ACLK_DYNM, CLK_SET_RATE_PARENT, 1239 EIC7700_REG_OFFSET_DDR, 0, 0), 1240 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_DDR1_TRACE, "gate_ddr1_trace", 1241 EIC7700_CLK_DIV_DDR_ACLK_DYNM, CLK_SET_RATE_PARENT, 1242 EIC7700_REG_OFFSET_DDR1, 0, 0), 1243 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_RNOC_NSP, "gate_rnoc_nsp", 1244 EIC7700_CLK_DIV_NOC_NSP_DYNM, CLK_SET_RATE_PARENT, 1245 EIC7700_REG_OFFSET_NOC, 29, 0), 1246 ESWIN_GATE_TYPE(EIC7700_CLK_GATE_NOC_WDREF, "gate_noc_wdref", 1247 EIC7700_CLK_DIV_NOC_WDREF_DYNM, CLK_SET_RATE_PARENT, 1248 EIC7700_REG_OFFSET_NOC, 30, 0), 1249}; 1250 1251/* 1252 * This clock notifier is called when the rate of clk_pll_cpu clock is to be 1253 * changed. The mux_cpu_root_3mux1_gfree clock should save the current parent 1254 * clock and switch its parent clock to fixed_factor_u84_core_lp_div2 before 1255 * clk_pll_cpu rate will be changed. Then switch its parent clock back after 1256 * the clk_pll_cpu rate is completed. 1257 */ 1258static int eic7700_clk_pll_cpu_notifier_cb(struct notifier_block *nb, 1259 unsigned long action, void *data) 1260{ 1261 struct eswin_clock_data *pdata; 1262 struct clk_hw *mux_clk; 1263 struct clk_hw *lp_clk; 1264 int ret = 0; 1265 1266 pdata = container_of(nb, struct eswin_clock_data, pll_nb); 1267 1268 mux_clk = &eic7700_mux_clks[0].hw; 1269 lp_clk = &eic7700_early_clks[11].hw; 1270 1271 if (action == PRE_RATE_CHANGE) { 1272 pdata->original_clk = clk_hw_get_parent(mux_clk); 1273 ret = clk_hw_set_parent(mux_clk, lp_clk); 1274 } else if (action == POST_RATE_CHANGE) { 1275 ret = clk_hw_set_parent(mux_clk, pdata->original_clk); 1276 } 1277 1278 return notifier_from_errno(ret); 1279} 1280 1281static int eic7700_clk_probe(struct platform_device *pdev) 1282{ 1283 struct eswin_clock_data *clk_data; 1284 struct device *dev = &pdev->dev; 1285 struct clk *pll_clk; 1286 int ret; 1287 1288 clk_data = eswin_clk_init(pdev, EIC7700_NR_CLKS); 1289 if (IS_ERR(clk_data)) 1290 return dev_err_probe(dev, PTR_ERR(clk_data), 1291 "failed to get clk data!\n"); 1292 1293 ret = eswin_clk_register_fixed_rate(dev, eic7700_fixed_rate_clks, 1294 ARRAY_SIZE(eic7700_fixed_rate_clks), 1295 clk_data); 1296 if (ret) 1297 return dev_err_probe(dev, ret, 1298 "failed to register fixed rate clock\n"); 1299 1300 ret = eswin_clk_register_pll(dev, eic7700_pll_clks, 1301 ARRAY_SIZE(eic7700_pll_clks), 1302 clk_data); 1303 if (ret) 1304 return dev_err_probe(dev, ret, 1305 "failed to register pll clock\n"); 1306 1307 pll_clk = devm_clk_hw_get_clk(dev, &eic7700_pll_clks[1].hw, 1308 "clk_pll_cpu"); 1309 if (IS_ERR(pll_clk)) 1310 return dev_err_probe(dev, PTR_ERR(pll_clk), 1311 "failed to get clk_pll_cpu\n"); 1312 1313 clk_data->pll_nb.notifier_call = eic7700_clk_pll_cpu_notifier_cb; 1314 ret = devm_clk_notifier_register(dev, pll_clk, &clk_data->pll_nb); 1315 if (ret) 1316 return ret; 1317 1318 ret = eswin_clk_register_fixed_factor(dev, eic7700_factor_clks, 1319 ARRAY_SIZE(eic7700_factor_clks), 1320 clk_data); 1321 if (ret) 1322 return dev_err_probe(dev, ret, 1323 "failed to register fixed factor clock\n"); 1324 1325 ret = eswin_clk_register_divider(dev, eic7700_div_clks, 1326 ARRAY_SIZE(eic7700_div_clks), 1327 clk_data); 1328 if (ret) 1329 return dev_err_probe(dev, ret, 1330 "failed to register divider clock\n"); 1331 1332 ret = eswin_clk_register_gate(dev, eic7700_gate_clks, 1333 ARRAY_SIZE(eic7700_gate_clks), clk_data); 1334 if (ret) 1335 return dev_err_probe(dev, ret, 1336 "failed to register gate clock\n"); 1337 1338 ret = eswin_clk_register_clks(dev, eic7700_early_clks, 1339 ARRAY_SIZE(eic7700_early_clks), clk_data); 1340 if (ret) 1341 return dev_err_probe(dev, ret, "failed to register clock\n"); 1342 1343 ret = eswin_clk_register_mux(dev, eic7700_mux_clks, 1344 ARRAY_SIZE(eic7700_mux_clks), clk_data); 1345 if (ret) 1346 return dev_err_probe(dev, ret, 1347 "failed to register mux clock\n"); 1348 1349 ret = eswin_clk_register_clks(dev, eic7700_clks, 1350 ARRAY_SIZE(eic7700_clks), clk_data); 1351 if (ret) 1352 return dev_err_probe(dev, ret, "failed to register clock\n"); 1353 1354 return devm_of_clk_add_hw_provider(dev, of_clk_hw_onecell_get, 1355 &clk_data->clk_data); 1356} 1357 1358static const struct of_device_id eic7700_clock_dt_ids[] = { 1359 { .compatible = "eswin,eic7700-clock", }, 1360 { /* sentinel */ } 1361}; 1362MODULE_DEVICE_TABLE(of, eic7700_clock_dt_ids); 1363 1364static struct platform_driver eic7700_clock_driver = { 1365 .probe = eic7700_clk_probe, 1366 .driver = { 1367 .name = "eic7700-clock", 1368 .of_match_table = eic7700_clock_dt_ids, 1369 }, 1370}; 1371module_platform_driver(eic7700_clock_driver); 1372 1373MODULE_LICENSE("GPL"); 1374MODULE_AUTHOR("Yifeng Huang <huangyifeng@eswincomputing.com>"); 1375MODULE_AUTHOR("Xuyang Dong <dongxuyang@eswincomputing.com>"); 1376MODULE_DESCRIPTION("ESWIN EIC7700 clock controller driver");