Linux kernel mirror (for testing)
git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel
os
linux
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");