xref: /linux/drivers/clk/qcom/dispcc-sm8550.c (revision 566ab427f827b0256d3e8ce0235d088e6a9c28bd)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * Copyright (c) 2021, The Linux Foundation. All rights reserved.
4  * Copyright (c) 2023, Linaro Ltd.
5  */
6 
7 #include <linux/clk.h>
8 #include <linux/clk-provider.h>
9 #include <linux/err.h>
10 #include <linux/kernel.h>
11 #include <linux/module.h>
12 #include <linux/of.h>
13 #include <linux/platform_device.h>
14 #include <linux/regmap.h>
15 #include <linux/pm_runtime.h>
16 
17 #include <dt-bindings/clock/qcom,sm8550-dispcc.h>
18 
19 #include "common.h"
20 #include "clk-alpha-pll.h"
21 #include "clk-branch.h"
22 #include "clk-pll.h"
23 #include "clk-rcg.h"
24 #include "clk-regmap.h"
25 #include "clk-regmap-divider.h"
26 #include "clk-regmap-mux.h"
27 #include "reset.h"
28 #include "gdsc.h"
29 
30 /* Need to match the order of clocks in DT binding */
31 enum {
32 	DT_BI_TCXO,
33 	DT_BI_TCXO_AO,
34 	DT_AHB_CLK,
35 	DT_SLEEP_CLK,
36 
37 	DT_DSI0_PHY_PLL_OUT_BYTECLK,
38 	DT_DSI0_PHY_PLL_OUT_DSICLK,
39 	DT_DSI1_PHY_PLL_OUT_BYTECLK,
40 	DT_DSI1_PHY_PLL_OUT_DSICLK,
41 
42 	DT_DP0_PHY_PLL_LINK_CLK,
43 	DT_DP0_PHY_PLL_VCO_DIV_CLK,
44 	DT_DP1_PHY_PLL_LINK_CLK,
45 	DT_DP1_PHY_PLL_VCO_DIV_CLK,
46 	DT_DP2_PHY_PLL_LINK_CLK,
47 	DT_DP2_PHY_PLL_VCO_DIV_CLK,
48 	DT_DP3_PHY_PLL_LINK_CLK,
49 	DT_DP3_PHY_PLL_VCO_DIV_CLK,
50 };
51 
52 #define DISP_CC_MISC_CMD	0xF000
53 
54 enum {
55 	P_BI_TCXO,
56 	P_DISP_CC_PLL0_OUT_MAIN,
57 	P_DISP_CC_PLL1_OUT_EVEN,
58 	P_DISP_CC_PLL1_OUT_MAIN,
59 	P_DP0_PHY_PLL_LINK_CLK,
60 	P_DP0_PHY_PLL_VCO_DIV_CLK,
61 	P_DP1_PHY_PLL_LINK_CLK,
62 	P_DP1_PHY_PLL_VCO_DIV_CLK,
63 	P_DP2_PHY_PLL_LINK_CLK,
64 	P_DP2_PHY_PLL_VCO_DIV_CLK,
65 	P_DP3_PHY_PLL_LINK_CLK,
66 	P_DP3_PHY_PLL_VCO_DIV_CLK,
67 	P_DSI0_PHY_PLL_OUT_BYTECLK,
68 	P_DSI0_PHY_PLL_OUT_DSICLK,
69 	P_DSI1_PHY_PLL_OUT_BYTECLK,
70 	P_DSI1_PHY_PLL_OUT_DSICLK,
71 	P_SLEEP_CLK,
72 };
73 
74 static struct pll_vco lucid_ole_vco[] = {
75 	{ 249600000, 2000000000, 0 },
76 };
77 
78 static const struct alpha_pll_config disp_cc_pll0_config = {
79 	.l = 0xd,
80 	.alpha = 0x6492,
81 	.config_ctl_val = 0x20485699,
82 	.config_ctl_hi_val = 0x00182261,
83 	.config_ctl_hi1_val = 0x82aa299c,
84 	.test_ctl_val = 0x00000000,
85 	.test_ctl_hi_val = 0x00000003,
86 	.test_ctl_hi1_val = 0x00009000,
87 	.test_ctl_hi2_val = 0x00000034,
88 	.user_ctl_val = 0x00000000,
89 	.user_ctl_hi_val = 0x00000005,
90 };
91 
92 static struct clk_alpha_pll disp_cc_pll0 = {
93 	.offset = 0x0,
94 	.vco_table = lucid_ole_vco,
95 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
96 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
97 	.clkr = {
98 		.hw.init = &(const struct clk_init_data) {
99 			.name = "disp_cc_pll0",
100 			.parent_data = &(const struct clk_parent_data) {
101 				.index = DT_BI_TCXO,
102 			},
103 			.num_parents = 1,
104 			.ops = &clk_alpha_pll_reset_lucid_ole_ops,
105 		},
106 	},
107 };
108 
109 static const struct alpha_pll_config disp_cc_pll1_config = {
110 	.l = 0x1f,
111 	.alpha = 0x4000,
112 	.config_ctl_val = 0x20485699,
113 	.config_ctl_hi_val = 0x00182261,
114 	.config_ctl_hi1_val = 0x82aa299c,
115 	.test_ctl_val = 0x00000000,
116 	.test_ctl_hi_val = 0x00000003,
117 	.test_ctl_hi1_val = 0x00009000,
118 	.test_ctl_hi2_val = 0x00000034,
119 	.user_ctl_val = 0x00000000,
120 	.user_ctl_hi_val = 0x00000005,
121 };
122 
123 static struct clk_alpha_pll disp_cc_pll1 = {
124 	.offset = 0x1000,
125 	.vco_table = lucid_ole_vco,
126 	.num_vco = ARRAY_SIZE(lucid_ole_vco),
127 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE],
128 	.clkr = {
129 		.hw.init = &(const struct clk_init_data) {
130 			.name = "disp_cc_pll1",
131 			.parent_data = &(const struct clk_parent_data) {
132 				.index = DT_BI_TCXO,
133 			},
134 			.num_parents = 1,
135 			.ops = &clk_alpha_pll_reset_lucid_ole_ops,
136 		},
137 	},
138 };
139 
140 static const struct parent_map disp_cc_parent_map_0[] = {
141 	{ P_BI_TCXO, 0 },
142 };
143 
144 static const struct clk_parent_data disp_cc_parent_data_0[] = {
145 	{ .index = DT_BI_TCXO },
146 };
147 
148 static const struct clk_parent_data disp_cc_parent_data_0_ao[] = {
149 	{ .index = DT_BI_TCXO_AO },
150 };
151 
152 static const struct parent_map disp_cc_parent_map_1[] = {
153 	{ P_BI_TCXO, 0 },
154 	{ P_DP3_PHY_PLL_VCO_DIV_CLK, 3 },
155 	{ P_DP1_PHY_PLL_VCO_DIV_CLK, 4 },
156 	{ P_DP2_PHY_PLL_VCO_DIV_CLK, 6 },
157 };
158 
159 static const struct clk_parent_data disp_cc_parent_data_1[] = {
160 	{ .index = DT_BI_TCXO },
161 	{ .index = DT_DP3_PHY_PLL_VCO_DIV_CLK },
162 	{ .index = DT_DP1_PHY_PLL_VCO_DIV_CLK },
163 	{ .index = DT_DP2_PHY_PLL_VCO_DIV_CLK },
164 };
165 
166 static const struct parent_map disp_cc_parent_map_2[] = {
167 	{ P_BI_TCXO, 0 },
168 	{ P_DSI0_PHY_PLL_OUT_DSICLK, 1 },
169 	{ P_DSI0_PHY_PLL_OUT_BYTECLK, 2 },
170 	{ P_DSI1_PHY_PLL_OUT_DSICLK, 3 },
171 	{ P_DSI1_PHY_PLL_OUT_BYTECLK, 4 },
172 };
173 
174 static const struct clk_parent_data disp_cc_parent_data_2[] = {
175 	{ .index = DT_BI_TCXO },
176 	{ .index = DT_DSI0_PHY_PLL_OUT_DSICLK },
177 	{ .index = DT_DSI0_PHY_PLL_OUT_BYTECLK },
178 	{ .index = DT_DSI1_PHY_PLL_OUT_DSICLK },
179 	{ .index = DT_DSI1_PHY_PLL_OUT_BYTECLK },
180 };
181 
182 static const struct parent_map disp_cc_parent_map_3[] = {
183 	{ P_BI_TCXO, 0 },
184 	{ P_DP1_PHY_PLL_LINK_CLK, 2 },
185 	{ P_DP2_PHY_PLL_LINK_CLK, 3 },
186 	{ P_DP3_PHY_PLL_LINK_CLK, 4 },
187 };
188 
189 static const struct clk_parent_data disp_cc_parent_data_3[] = {
190 	{ .index = DT_BI_TCXO },
191 	{ .index = DT_DP1_PHY_PLL_LINK_CLK },
192 	{ .index = DT_DP2_PHY_PLL_LINK_CLK },
193 	{ .index = DT_DP3_PHY_PLL_LINK_CLK },
194 };
195 
196 static const struct parent_map disp_cc_parent_map_4[] = {
197 	{ P_BI_TCXO, 0 },
198 	{ P_DP0_PHY_PLL_LINK_CLK, 1 },
199 	{ P_DP0_PHY_PLL_VCO_DIV_CLK, 2 },
200 	{ P_DP3_PHY_PLL_VCO_DIV_CLK, 3 },
201 	{ P_DP1_PHY_PLL_VCO_DIV_CLK, 4 },
202 	{ P_DP2_PHY_PLL_VCO_DIV_CLK, 6 },
203 };
204 
205 static const struct clk_parent_data disp_cc_parent_data_4[] = {
206 	{ .index = DT_BI_TCXO },
207 	{ .index = DT_DP0_PHY_PLL_LINK_CLK },
208 	{ .index = DT_DP0_PHY_PLL_VCO_DIV_CLK },
209 	{ .index = DT_DP3_PHY_PLL_VCO_DIV_CLK },
210 	{ .index = DT_DP1_PHY_PLL_VCO_DIV_CLK },
211 	{ .index = DT_DP2_PHY_PLL_VCO_DIV_CLK },
212 };
213 
214 static const struct parent_map disp_cc_parent_map_5[] = {
215 	{ P_BI_TCXO, 0 },
216 	{ P_DSI0_PHY_PLL_OUT_BYTECLK, 2 },
217 	{ P_DSI1_PHY_PLL_OUT_BYTECLK, 4 },
218 };
219 
220 static const struct clk_parent_data disp_cc_parent_data_5[] = {
221 	{ .index = DT_BI_TCXO },
222 	{ .index = DT_DSI0_PHY_PLL_OUT_BYTECLK },
223 	{ .index = DT_DSI1_PHY_PLL_OUT_BYTECLK },
224 };
225 
226 static const struct parent_map disp_cc_parent_map_6[] = {
227 	{ P_BI_TCXO, 0 },
228 	{ P_DISP_CC_PLL1_OUT_MAIN, 4 },
229 	{ P_DISP_CC_PLL1_OUT_EVEN, 6 },
230 };
231 
232 static const struct clk_parent_data disp_cc_parent_data_6[] = {
233 	{ .index = DT_BI_TCXO },
234 	{ .hw = &disp_cc_pll1.clkr.hw },
235 	{ .hw = &disp_cc_pll1.clkr.hw },
236 };
237 
238 static const struct parent_map disp_cc_parent_map_7[] = {
239 	{ P_BI_TCXO, 0 },
240 	{ P_DP0_PHY_PLL_LINK_CLK, 1 },
241 	{ P_DP1_PHY_PLL_LINK_CLK, 2 },
242 	{ P_DP2_PHY_PLL_LINK_CLK, 3 },
243 	{ P_DP3_PHY_PLL_LINK_CLK, 4 },
244 };
245 
246 static const struct clk_parent_data disp_cc_parent_data_7[] = {
247 	{ .index = DT_BI_TCXO },
248 	{ .index = DT_DP0_PHY_PLL_LINK_CLK },
249 	{ .index = DT_DP1_PHY_PLL_LINK_CLK },
250 	{ .index = DT_DP2_PHY_PLL_LINK_CLK },
251 	{ .index = DT_DP3_PHY_PLL_LINK_CLK },
252 };
253 
254 static const struct parent_map disp_cc_parent_map_8[] = {
255 	{ P_BI_TCXO, 0 },
256 	{ P_DISP_CC_PLL0_OUT_MAIN, 1 },
257 	{ P_DISP_CC_PLL1_OUT_MAIN, 4 },
258 	{ P_DISP_CC_PLL1_OUT_EVEN, 6 },
259 };
260 
261 static const struct clk_parent_data disp_cc_parent_data_8[] = {
262 	{ .index = DT_BI_TCXO },
263 	{ .hw = &disp_cc_pll0.clkr.hw },
264 	{ .hw = &disp_cc_pll1.clkr.hw },
265 	{ .hw = &disp_cc_pll1.clkr.hw },
266 };
267 
268 static const struct parent_map disp_cc_parent_map_9[] = {
269 	{ P_SLEEP_CLK, 0 },
270 };
271 
272 static const struct clk_parent_data disp_cc_parent_data_9[] = {
273 	{ .index = DT_SLEEP_CLK },
274 };
275 
276 static const struct freq_tbl ftbl_disp_cc_mdss_ahb_clk_src[] = {
277 	F(19200000, P_BI_TCXO, 1, 0, 0),
278 	F(37500000, P_DISP_CC_PLL1_OUT_MAIN, 16, 0, 0),
279 	F(75000000, P_DISP_CC_PLL1_OUT_MAIN, 8, 0, 0),
280 	{ }
281 };
282 
283 static struct clk_rcg2 disp_cc_mdss_ahb_clk_src = {
284 	.cmd_rcgr = 0x82e8,
285 	.mnd_width = 0,
286 	.hid_width = 5,
287 	.parent_map = disp_cc_parent_map_6,
288 	.freq_tbl = ftbl_disp_cc_mdss_ahb_clk_src,
289 	.clkr.hw.init = &(const struct clk_init_data) {
290 		.name = "disp_cc_mdss_ahb_clk_src",
291 		.parent_data = disp_cc_parent_data_6,
292 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_6),
293 		.flags = CLK_SET_RATE_PARENT,
294 		.ops = &clk_rcg2_shared_ops,
295 	},
296 };
297 
298 static const struct freq_tbl ftbl_disp_cc_mdss_byte0_clk_src[] = {
299 	F(19200000, P_BI_TCXO, 1, 0, 0),
300 	{ }
301 };
302 
303 static struct clk_rcg2 disp_cc_mdss_byte0_clk_src = {
304 	.cmd_rcgr = 0x8108,
305 	.mnd_width = 0,
306 	.hid_width = 5,
307 	.parent_map = disp_cc_parent_map_2,
308 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
309 	.clkr.hw.init = &(const struct clk_init_data) {
310 		.name = "disp_cc_mdss_byte0_clk_src",
311 		.parent_data = disp_cc_parent_data_2,
312 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_2),
313 		.flags = CLK_SET_RATE_PARENT,
314 		.ops = &clk_byte2_ops,
315 	},
316 };
317 
318 static struct clk_rcg2 disp_cc_mdss_byte1_clk_src = {
319 	.cmd_rcgr = 0x8124,
320 	.mnd_width = 0,
321 	.hid_width = 5,
322 	.parent_map = disp_cc_parent_map_2,
323 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
324 	.clkr.hw.init = &(const struct clk_init_data) {
325 		.name = "disp_cc_mdss_byte1_clk_src",
326 		.parent_data = disp_cc_parent_data_2,
327 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_2),
328 		.flags = CLK_SET_RATE_PARENT,
329 		.ops = &clk_byte2_ops,
330 	},
331 };
332 
333 static struct clk_rcg2 disp_cc_mdss_dptx0_aux_clk_src = {
334 	.cmd_rcgr = 0x81bc,
335 	.mnd_width = 0,
336 	.hid_width = 5,
337 	.parent_map = disp_cc_parent_map_0,
338 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
339 	.clkr.hw.init = &(const struct clk_init_data) {
340 		.name = "disp_cc_mdss_dptx0_aux_clk_src",
341 		.parent_data = disp_cc_parent_data_0,
342 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_0),
343 		.flags = CLK_SET_RATE_PARENT,
344 		.ops = &clk_rcg2_ops,
345 	},
346 };
347 
348 static struct clk_rcg2 disp_cc_mdss_dptx0_link_clk_src = {
349 	.cmd_rcgr = 0x8170,
350 	.mnd_width = 0,
351 	.hid_width = 5,
352 	.parent_map = disp_cc_parent_map_7,
353 	.clkr.hw.init = &(const struct clk_init_data) {
354 		.name = "disp_cc_mdss_dptx0_link_clk_src",
355 		.parent_data = disp_cc_parent_data_7,
356 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_7),
357 		.flags = CLK_SET_RATE_PARENT,
358 		.ops = &clk_byte2_ops,
359 	},
360 };
361 
362 static struct clk_rcg2 disp_cc_mdss_dptx0_pixel0_clk_src = {
363 	.cmd_rcgr = 0x818c,
364 	.mnd_width = 16,
365 	.hid_width = 5,
366 	.parent_map = disp_cc_parent_map_4,
367 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
368 	.clkr.hw.init = &(const struct clk_init_data) {
369 		.name = "disp_cc_mdss_dptx0_pixel0_clk_src",
370 		.parent_data = disp_cc_parent_data_4,
371 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_4),
372 		.flags = CLK_SET_RATE_PARENT,
373 		.ops = &clk_dp_ops,
374 	},
375 };
376 
377 static struct clk_rcg2 disp_cc_mdss_dptx0_pixel1_clk_src = {
378 	.cmd_rcgr = 0x81a4,
379 	.mnd_width = 16,
380 	.hid_width = 5,
381 	.parent_map = disp_cc_parent_map_4,
382 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
383 	.clkr.hw.init = &(const struct clk_init_data) {
384 		.name = "disp_cc_mdss_dptx0_pixel1_clk_src",
385 		.parent_data = disp_cc_parent_data_4,
386 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_4),
387 		.flags = CLK_SET_RATE_PARENT,
388 		.ops = &clk_dp_ops,
389 	},
390 };
391 
392 static struct clk_rcg2 disp_cc_mdss_dptx1_aux_clk_src = {
393 	.cmd_rcgr = 0x8220,
394 	.mnd_width = 0,
395 	.hid_width = 5,
396 	.parent_map = disp_cc_parent_map_0,
397 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
398 	.clkr.hw.init = &(const struct clk_init_data) {
399 		.name = "disp_cc_mdss_dptx1_aux_clk_src",
400 		.parent_data = disp_cc_parent_data_0,
401 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_0),
402 		.flags = CLK_SET_RATE_PARENT,
403 		.ops = &clk_rcg2_ops,
404 	},
405 };
406 
407 static struct clk_rcg2 disp_cc_mdss_dptx1_link_clk_src = {
408 	.cmd_rcgr = 0x8204,
409 	.mnd_width = 0,
410 	.hid_width = 5,
411 	.parent_map = disp_cc_parent_map_3,
412 	.clkr.hw.init = &(const struct clk_init_data) {
413 		.name = "disp_cc_mdss_dptx1_link_clk_src",
414 		.parent_data = disp_cc_parent_data_3,
415 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_3),
416 		.flags = CLK_SET_RATE_PARENT,
417 		.ops = &clk_byte2_ops,
418 	},
419 };
420 
421 static struct clk_rcg2 disp_cc_mdss_dptx1_pixel0_clk_src = {
422 	.cmd_rcgr = 0x81d4,
423 	.mnd_width = 16,
424 	.hid_width = 5,
425 	.parent_map = disp_cc_parent_map_1,
426 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
427 	.clkr.hw.init = &(const struct clk_init_data) {
428 		.name = "disp_cc_mdss_dptx1_pixel0_clk_src",
429 		.parent_data = disp_cc_parent_data_1,
430 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_1),
431 		.flags = CLK_SET_RATE_PARENT,
432 		.ops = &clk_dp_ops,
433 	},
434 };
435 
436 static struct clk_rcg2 disp_cc_mdss_dptx1_pixel1_clk_src = {
437 	.cmd_rcgr = 0x81ec,
438 	.mnd_width = 16,
439 	.hid_width = 5,
440 	.parent_map = disp_cc_parent_map_1,
441 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
442 	.clkr.hw.init = &(const struct clk_init_data) {
443 		.name = "disp_cc_mdss_dptx1_pixel1_clk_src",
444 		.parent_data = disp_cc_parent_data_1,
445 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_1),
446 		.flags = CLK_SET_RATE_PARENT,
447 		.ops = &clk_dp_ops,
448 	},
449 };
450 
451 static struct clk_rcg2 disp_cc_mdss_dptx2_aux_clk_src = {
452 	.cmd_rcgr = 0x8284,
453 	.mnd_width = 0,
454 	.hid_width = 5,
455 	.parent_map = disp_cc_parent_map_0,
456 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
457 	.clkr.hw.init = &(const struct clk_init_data) {
458 		.name = "disp_cc_mdss_dptx2_aux_clk_src",
459 		.parent_data = disp_cc_parent_data_0,
460 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_0),
461 		.flags = CLK_SET_RATE_PARENT,
462 		.ops = &clk_rcg2_ops,
463 	},
464 };
465 
466 static struct clk_rcg2 disp_cc_mdss_dptx2_link_clk_src = {
467 	.cmd_rcgr = 0x8238,
468 	.mnd_width = 0,
469 	.hid_width = 5,
470 	.parent_map = disp_cc_parent_map_3,
471 	.clkr.hw.init = &(const struct clk_init_data) {
472 		.name = "disp_cc_mdss_dptx2_link_clk_src",
473 		.parent_data = disp_cc_parent_data_3,
474 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_3),
475 		.flags = CLK_SET_RATE_PARENT,
476 		.ops = &clk_byte2_ops,
477 	},
478 };
479 
480 static struct clk_rcg2 disp_cc_mdss_dptx2_pixel0_clk_src = {
481 	.cmd_rcgr = 0x8254,
482 	.mnd_width = 16,
483 	.hid_width = 5,
484 	.parent_map = disp_cc_parent_map_1,
485 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
486 	.clkr.hw.init = &(const struct clk_init_data) {
487 		.name = "disp_cc_mdss_dptx2_pixel0_clk_src",
488 		.parent_data = disp_cc_parent_data_1,
489 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_1),
490 		.flags = CLK_SET_RATE_PARENT,
491 		.ops = &clk_dp_ops,
492 	},
493 };
494 
495 static struct clk_rcg2 disp_cc_mdss_dptx2_pixel1_clk_src = {
496 	.cmd_rcgr = 0x826c,
497 	.mnd_width = 16,
498 	.hid_width = 5,
499 	.parent_map = disp_cc_parent_map_1,
500 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
501 	.clkr.hw.init = &(const struct clk_init_data) {
502 		.name = "disp_cc_mdss_dptx2_pixel1_clk_src",
503 		.parent_data = disp_cc_parent_data_1,
504 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_1),
505 		.flags = CLK_SET_RATE_PARENT,
506 		.ops = &clk_dp_ops,
507 	},
508 };
509 
510 static struct clk_rcg2 disp_cc_mdss_dptx3_aux_clk_src = {
511 	.cmd_rcgr = 0x82d0,
512 	.mnd_width = 0,
513 	.hid_width = 5,
514 	.parent_map = disp_cc_parent_map_0,
515 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
516 	.clkr.hw.init = &(const struct clk_init_data) {
517 		.name = "disp_cc_mdss_dptx3_aux_clk_src",
518 		.parent_data = disp_cc_parent_data_0,
519 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_0),
520 		.flags = CLK_SET_RATE_PARENT,
521 		.ops = &clk_rcg2_ops,
522 	},
523 };
524 
525 static struct clk_rcg2 disp_cc_mdss_dptx3_link_clk_src = {
526 	.cmd_rcgr = 0x82b4,
527 	.mnd_width = 0,
528 	.hid_width = 5,
529 	.parent_map = disp_cc_parent_map_3,
530 	.clkr.hw.init = &(const struct clk_init_data) {
531 		.name = "disp_cc_mdss_dptx3_link_clk_src",
532 		.parent_data = disp_cc_parent_data_3,
533 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_3),
534 		.flags = CLK_SET_RATE_PARENT,
535 		.ops = &clk_byte2_ops,
536 	},
537 };
538 
539 static struct clk_rcg2 disp_cc_mdss_dptx3_pixel0_clk_src = {
540 	.cmd_rcgr = 0x829c,
541 	.mnd_width = 16,
542 	.hid_width = 5,
543 	.parent_map = disp_cc_parent_map_1,
544 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
545 	.clkr.hw.init = &(const struct clk_init_data) {
546 		.name = "disp_cc_mdss_dptx3_pixel0_clk_src",
547 		.parent_data = disp_cc_parent_data_1,
548 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_1),
549 		.flags = CLK_SET_RATE_PARENT,
550 		.ops = &clk_dp_ops,
551 	},
552 };
553 
554 static struct clk_rcg2 disp_cc_mdss_esc0_clk_src = {
555 	.cmd_rcgr = 0x8140,
556 	.mnd_width = 0,
557 	.hid_width = 5,
558 	.parent_map = disp_cc_parent_map_5,
559 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
560 	.clkr.hw.init = &(const struct clk_init_data) {
561 		.name = "disp_cc_mdss_esc0_clk_src",
562 		.parent_data = disp_cc_parent_data_5,
563 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_5),
564 		.flags = CLK_SET_RATE_PARENT,
565 		.ops = &clk_rcg2_shared_ops,
566 	},
567 };
568 
569 static struct clk_rcg2 disp_cc_mdss_esc1_clk_src = {
570 	.cmd_rcgr = 0x8158,
571 	.mnd_width = 0,
572 	.hid_width = 5,
573 	.parent_map = disp_cc_parent_map_5,
574 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
575 	.clkr.hw.init = &(const struct clk_init_data) {
576 		.name = "disp_cc_mdss_esc1_clk_src",
577 		.parent_data = disp_cc_parent_data_5,
578 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_5),
579 		.flags = CLK_SET_RATE_PARENT,
580 		.ops = &clk_rcg2_shared_ops,
581 	},
582 };
583 
584 static const struct freq_tbl ftbl_disp_cc_mdss_mdp_clk_src[] = {
585 	F(19200000, P_BI_TCXO, 1, 0, 0),
586 	F(85714286, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
587 	F(100000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
588 	F(150000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
589 	F(172000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
590 	F(200000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
591 	F(325000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
592 	F(375000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
593 	F(514000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
594 	{ }
595 };
596 
597 static const struct freq_tbl ftbl_disp_cc_mdss_mdp_clk_src_sm8650[] = {
598 	F(19200000, P_BI_TCXO, 1, 0, 0),
599 	F(85714286, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
600 	F(100000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
601 	F(150000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
602 	F(200000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
603 	F(325000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
604 	F(402000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
605 	F(514000000, P_DISP_CC_PLL0_OUT_MAIN, 3, 0, 0),
606 	{ }
607 };
608 
609 static struct clk_rcg2 disp_cc_mdss_mdp_clk_src = {
610 	.cmd_rcgr = 0x80d8,
611 	.mnd_width = 0,
612 	.hid_width = 5,
613 	.parent_map = disp_cc_parent_map_8,
614 	.freq_tbl = ftbl_disp_cc_mdss_mdp_clk_src,
615 	.clkr.hw.init = &(const struct clk_init_data) {
616 		.name = "disp_cc_mdss_mdp_clk_src",
617 		.parent_data = disp_cc_parent_data_8,
618 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_8),
619 		.flags = CLK_SET_RATE_PARENT,
620 		.ops = &clk_rcg2_shared_ops,
621 	},
622 };
623 
624 static struct clk_rcg2 disp_cc_mdss_pclk0_clk_src = {
625 	.cmd_rcgr = 0x80a8,
626 	.mnd_width = 8,
627 	.hid_width = 5,
628 	.parent_map = disp_cc_parent_map_2,
629 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
630 	.clkr.hw.init = &(const struct clk_init_data) {
631 		.name = "disp_cc_mdss_pclk0_clk_src",
632 		.parent_data = disp_cc_parent_data_2,
633 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_2),
634 		.flags = CLK_SET_RATE_PARENT,
635 		.ops = &clk_pixel_ops,
636 	},
637 };
638 
639 static struct clk_rcg2 disp_cc_mdss_pclk1_clk_src = {
640 	.cmd_rcgr = 0x80c0,
641 	.mnd_width = 8,
642 	.hid_width = 5,
643 	.parent_map = disp_cc_parent_map_2,
644 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
645 	.clkr.hw.init = &(const struct clk_init_data) {
646 		.name = "disp_cc_mdss_pclk1_clk_src",
647 		.parent_data = disp_cc_parent_data_2,
648 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_2),
649 		.flags = CLK_SET_RATE_PARENT,
650 		.ops = &clk_pixel_ops,
651 	},
652 };
653 
654 static struct clk_rcg2 disp_cc_mdss_vsync_clk_src = {
655 	.cmd_rcgr = 0x80f0,
656 	.mnd_width = 0,
657 	.hid_width = 5,
658 	.parent_map = disp_cc_parent_map_0,
659 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
660 	.clkr.hw.init = &(const struct clk_init_data) {
661 		.name = "disp_cc_mdss_vsync_clk_src",
662 		.parent_data = disp_cc_parent_data_0,
663 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_0),
664 		.flags = CLK_SET_RATE_PARENT,
665 		.ops = &clk_rcg2_ops,
666 	},
667 };
668 
669 static const struct freq_tbl ftbl_disp_cc_sleep_clk_src[] = {
670 	F(32000, P_SLEEP_CLK, 1, 0, 0),
671 	{ }
672 };
673 
674 static struct clk_rcg2 disp_cc_sleep_clk_src = {
675 	.cmd_rcgr = 0xe05c,
676 	.mnd_width = 0,
677 	.hid_width = 5,
678 	.parent_map = disp_cc_parent_map_9,
679 	.freq_tbl = ftbl_disp_cc_sleep_clk_src,
680 	.clkr.hw.init = &(const struct clk_init_data) {
681 		.name = "disp_cc_sleep_clk_src",
682 		.parent_data = disp_cc_parent_data_9,
683 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_9),
684 		.flags = CLK_SET_RATE_PARENT,
685 		.ops = &clk_rcg2_ops,
686 	},
687 };
688 
689 static struct clk_rcg2 disp_cc_xo_clk_src = {
690 	.cmd_rcgr = 0xe03c,
691 	.mnd_width = 0,
692 	.hid_width = 5,
693 	.parent_map = disp_cc_parent_map_0,
694 	.freq_tbl = ftbl_disp_cc_mdss_byte0_clk_src,
695 	.clkr.hw.init = &(const struct clk_init_data) {
696 		.name = "disp_cc_xo_clk_src",
697 		.parent_data = disp_cc_parent_data_0_ao,
698 		.num_parents = ARRAY_SIZE(disp_cc_parent_data_0_ao),
699 		.flags = CLK_SET_RATE_PARENT,
700 		.ops = &clk_rcg2_ops,
701 	},
702 };
703 
704 static struct clk_regmap_div disp_cc_mdss_byte0_div_clk_src = {
705 	.reg = 0x8120,
706 	.shift = 0,
707 	.width = 4,
708 	.clkr.hw.init = &(const struct clk_init_data) {
709 		.name = "disp_cc_mdss_byte0_div_clk_src",
710 		.parent_hws = (const struct clk_hw*[]) {
711 			&disp_cc_mdss_byte0_clk_src.clkr.hw,
712 		},
713 		.num_parents = 1,
714 		.ops = &clk_regmap_div_ops,
715 	},
716 };
717 
718 static struct clk_regmap_div disp_cc_mdss_byte1_div_clk_src = {
719 	.reg = 0x813c,
720 	.shift = 0,
721 	.width = 4,
722 	.clkr.hw.init = &(const struct clk_init_data) {
723 		.name = "disp_cc_mdss_byte1_div_clk_src",
724 		.parent_hws = (const struct clk_hw*[]) {
725 			&disp_cc_mdss_byte1_clk_src.clkr.hw,
726 		},
727 		.num_parents = 1,
728 		.ops = &clk_regmap_div_ops,
729 	},
730 };
731 
732 static struct clk_regmap_div disp_cc_mdss_dptx0_link_div_clk_src = {
733 	.reg = 0x8188,
734 	.shift = 0,
735 	.width = 4,
736 	.clkr.hw.init = &(const struct clk_init_data) {
737 		.name = "disp_cc_mdss_dptx0_link_div_clk_src",
738 		.parent_hws = (const struct clk_hw*[]) {
739 			&disp_cc_mdss_dptx0_link_clk_src.clkr.hw,
740 		},
741 		.num_parents = 1,
742 		.flags = CLK_SET_RATE_PARENT,
743 		.ops = &clk_regmap_div_ro_ops,
744 	},
745 };
746 
747 static struct clk_regmap_div disp_cc_mdss_dptx1_link_div_clk_src = {
748 	.reg = 0x821c,
749 	.shift = 0,
750 	.width = 4,
751 	.clkr.hw.init = &(const struct clk_init_data) {
752 		.name = "disp_cc_mdss_dptx1_link_div_clk_src",
753 		.parent_hws = (const struct clk_hw*[]) {
754 			&disp_cc_mdss_dptx1_link_clk_src.clkr.hw,
755 		},
756 		.num_parents = 1,
757 		.flags = CLK_SET_RATE_PARENT,
758 		.ops = &clk_regmap_div_ro_ops,
759 	},
760 };
761 
762 static struct clk_regmap_div disp_cc_mdss_dptx2_link_div_clk_src = {
763 	.reg = 0x8250,
764 	.shift = 0,
765 	.width = 4,
766 	.clkr.hw.init = &(const struct clk_init_data) {
767 		.name = "disp_cc_mdss_dptx2_link_div_clk_src",
768 		.parent_hws = (const struct clk_hw*[]) {
769 			&disp_cc_mdss_dptx2_link_clk_src.clkr.hw,
770 		},
771 		.num_parents = 1,
772 		.flags = CLK_SET_RATE_PARENT,
773 		.ops = &clk_regmap_div_ro_ops,
774 	},
775 };
776 
777 static struct clk_regmap_div disp_cc_mdss_dptx3_link_div_clk_src = {
778 	.reg = 0x82cc,
779 	.shift = 0,
780 	.width = 4,
781 	.clkr.hw.init = &(const struct clk_init_data) {
782 		.name = "disp_cc_mdss_dptx3_link_div_clk_src",
783 		.parent_hws = (const struct clk_hw*[]) {
784 			&disp_cc_mdss_dptx3_link_clk_src.clkr.hw,
785 		},
786 		.num_parents = 1,
787 		.flags = CLK_SET_RATE_PARENT,
788 		.ops = &clk_regmap_div_ro_ops,
789 	},
790 };
791 
792 static struct clk_branch disp_cc_mdss_accu_clk = {
793 	.halt_reg = 0xe058,
794 	.halt_check = BRANCH_HALT_VOTED,
795 	.clkr = {
796 		.enable_reg = 0xe058,
797 		.enable_mask = BIT(0),
798 		.hw.init = &(const struct clk_init_data) {
799 			.name = "disp_cc_mdss_accu_clk",
800 			.parent_hws = (const struct clk_hw*[]) {
801 				&disp_cc_xo_clk_src.clkr.hw,
802 			},
803 			.num_parents = 1,
804 			.flags = CLK_SET_RATE_PARENT,
805 			.ops = &clk_branch2_ops,
806 		},
807 	},
808 };
809 
810 static struct clk_branch disp_cc_mdss_ahb1_clk = {
811 	.halt_reg = 0xa020,
812 	.halt_check = BRANCH_HALT,
813 	.clkr = {
814 		.enable_reg = 0xa020,
815 		.enable_mask = BIT(0),
816 		.hw.init = &(const struct clk_init_data) {
817 			.name = "disp_cc_mdss_ahb1_clk",
818 			.parent_hws = (const struct clk_hw*[]) {
819 				&disp_cc_mdss_ahb_clk_src.clkr.hw,
820 			},
821 			.num_parents = 1,
822 			.flags = CLK_SET_RATE_PARENT,
823 			.ops = &clk_branch2_ops,
824 		},
825 	},
826 };
827 
828 static struct clk_branch disp_cc_mdss_ahb_clk = {
829 	.halt_reg = 0x80a4,
830 	.halt_check = BRANCH_HALT,
831 	.clkr = {
832 		.enable_reg = 0x80a4,
833 		.enable_mask = BIT(0),
834 		.hw.init = &(const struct clk_init_data) {
835 			.name = "disp_cc_mdss_ahb_clk",
836 			.parent_hws = (const struct clk_hw*[]) {
837 				&disp_cc_mdss_ahb_clk_src.clkr.hw,
838 			},
839 			.num_parents = 1,
840 			.flags = CLK_SET_RATE_PARENT,
841 			.ops = &clk_branch2_ops,
842 		},
843 	},
844 };
845 
846 static struct clk_branch disp_cc_mdss_byte0_clk = {
847 	.halt_reg = 0x8028,
848 	.halt_check = BRANCH_HALT,
849 	.clkr = {
850 		.enable_reg = 0x8028,
851 		.enable_mask = BIT(0),
852 		.hw.init = &(const struct clk_init_data) {
853 			.name = "disp_cc_mdss_byte0_clk",
854 			.parent_hws = (const struct clk_hw*[]) {
855 				&disp_cc_mdss_byte0_clk_src.clkr.hw,
856 			},
857 			.num_parents = 1,
858 			.flags = CLK_SET_RATE_PARENT,
859 			.ops = &clk_branch2_ops,
860 		},
861 	},
862 };
863 
864 static struct clk_branch disp_cc_mdss_byte0_intf_clk = {
865 	.halt_reg = 0x802c,
866 	.halt_check = BRANCH_HALT,
867 	.clkr = {
868 		.enable_reg = 0x802c,
869 		.enable_mask = BIT(0),
870 		.hw.init = &(const struct clk_init_data) {
871 			.name = "disp_cc_mdss_byte0_intf_clk",
872 			.parent_hws = (const struct clk_hw*[]) {
873 				&disp_cc_mdss_byte0_div_clk_src.clkr.hw,
874 			},
875 			.num_parents = 1,
876 			.flags = CLK_SET_RATE_PARENT,
877 			.ops = &clk_branch2_ops,
878 		},
879 	},
880 };
881 
882 static struct clk_branch disp_cc_mdss_byte1_clk = {
883 	.halt_reg = 0x8030,
884 	.halt_check = BRANCH_HALT,
885 	.clkr = {
886 		.enable_reg = 0x8030,
887 		.enable_mask = BIT(0),
888 		.hw.init = &(const struct clk_init_data) {
889 			.name = "disp_cc_mdss_byte1_clk",
890 			.parent_hws = (const struct clk_hw*[]) {
891 				&disp_cc_mdss_byte1_clk_src.clkr.hw,
892 			},
893 			.num_parents = 1,
894 			.flags = CLK_SET_RATE_PARENT,
895 			.ops = &clk_branch2_ops,
896 		},
897 	},
898 };
899 
900 static struct clk_branch disp_cc_mdss_byte1_intf_clk = {
901 	.halt_reg = 0x8034,
902 	.halt_check = BRANCH_HALT,
903 	.clkr = {
904 		.enable_reg = 0x8034,
905 		.enable_mask = BIT(0),
906 		.hw.init = &(const struct clk_init_data) {
907 			.name = "disp_cc_mdss_byte1_intf_clk",
908 			.parent_hws = (const struct clk_hw*[]) {
909 				&disp_cc_mdss_byte1_div_clk_src.clkr.hw,
910 			},
911 			.num_parents = 1,
912 			.flags = CLK_SET_RATE_PARENT,
913 			.ops = &clk_branch2_ops,
914 		},
915 	},
916 };
917 
918 static struct clk_branch disp_cc_mdss_dptx0_aux_clk = {
919 	.halt_reg = 0x8058,
920 	.halt_check = BRANCH_HALT,
921 	.clkr = {
922 		.enable_reg = 0x8058,
923 		.enable_mask = BIT(0),
924 		.hw.init = &(const struct clk_init_data) {
925 			.name = "disp_cc_mdss_dptx0_aux_clk",
926 			.parent_hws = (const struct clk_hw*[]) {
927 				&disp_cc_mdss_dptx0_aux_clk_src.clkr.hw,
928 			},
929 			.num_parents = 1,
930 			.flags = CLK_SET_RATE_PARENT,
931 			.ops = &clk_branch2_ops,
932 		},
933 	},
934 };
935 
936 static struct clk_branch disp_cc_mdss_dptx0_crypto_clk = {
937 	.halt_reg = 0x804c,
938 	.halt_check = BRANCH_HALT,
939 	.clkr = {
940 		.enable_reg = 0x804c,
941 		.enable_mask = BIT(0),
942 		.hw.init = &(const struct clk_init_data) {
943 			.name = "disp_cc_mdss_dptx0_crypto_clk",
944 			.parent_hws = (const struct clk_hw*[]) {
945 				&disp_cc_mdss_dptx0_link_clk_src.clkr.hw,
946 			},
947 			.num_parents = 1,
948 			.flags = CLK_SET_RATE_PARENT,
949 			.ops = &clk_branch2_ops,
950 		},
951 	},
952 };
953 
954 static struct clk_branch disp_cc_mdss_dptx0_link_clk = {
955 	.halt_reg = 0x8040,
956 	.halt_check = BRANCH_HALT,
957 	.clkr = {
958 		.enable_reg = 0x8040,
959 		.enable_mask = BIT(0),
960 		.hw.init = &(const struct clk_init_data) {
961 			.name = "disp_cc_mdss_dptx0_link_clk",
962 			.parent_hws = (const struct clk_hw*[]) {
963 				&disp_cc_mdss_dptx0_link_clk_src.clkr.hw,
964 			},
965 			.num_parents = 1,
966 			.flags = CLK_SET_RATE_PARENT,
967 			.ops = &clk_branch2_ops,
968 		},
969 	},
970 };
971 
972 static struct clk_branch disp_cc_mdss_dptx0_link_intf_clk = {
973 	.halt_reg = 0x8048,
974 	.halt_check = BRANCH_HALT,
975 	.clkr = {
976 		.enable_reg = 0x8048,
977 		.enable_mask = BIT(0),
978 		.hw.init = &(const struct clk_init_data) {
979 			.name = "disp_cc_mdss_dptx0_link_intf_clk",
980 			.parent_hws = (const struct clk_hw*[]) {
981 				&disp_cc_mdss_dptx0_link_div_clk_src.clkr.hw,
982 			},
983 			.num_parents = 1,
984 			.flags = CLK_SET_RATE_PARENT,
985 			.ops = &clk_branch2_ops,
986 		},
987 	},
988 };
989 
990 static struct clk_branch disp_cc_mdss_dptx0_pixel0_clk = {
991 	.halt_reg = 0x8050,
992 	.halt_check = BRANCH_HALT,
993 	.clkr = {
994 		.enable_reg = 0x8050,
995 		.enable_mask = BIT(0),
996 		.hw.init = &(const struct clk_init_data) {
997 			.name = "disp_cc_mdss_dptx0_pixel0_clk",
998 			.parent_hws = (const struct clk_hw*[]) {
999 				&disp_cc_mdss_dptx0_pixel0_clk_src.clkr.hw,
1000 			},
1001 			.num_parents = 1,
1002 			.flags = CLK_SET_RATE_PARENT,
1003 			.ops = &clk_branch2_ops,
1004 		},
1005 	},
1006 };
1007 
1008 static struct clk_branch disp_cc_mdss_dptx0_pixel1_clk = {
1009 	.halt_reg = 0x8054,
1010 	.halt_check = BRANCH_HALT,
1011 	.clkr = {
1012 		.enable_reg = 0x8054,
1013 		.enable_mask = BIT(0),
1014 		.hw.init = &(const struct clk_init_data) {
1015 			.name = "disp_cc_mdss_dptx0_pixel1_clk",
1016 			.parent_hws = (const struct clk_hw*[]) {
1017 				&disp_cc_mdss_dptx0_pixel1_clk_src.clkr.hw,
1018 			},
1019 			.num_parents = 1,
1020 			.flags = CLK_SET_RATE_PARENT,
1021 			.ops = &clk_branch2_ops,
1022 		},
1023 	},
1024 };
1025 
1026 static struct clk_branch disp_cc_mdss_dptx0_usb_router_link_intf_clk = {
1027 	.halt_reg = 0x8044,
1028 	.halt_check = BRANCH_HALT,
1029 	.clkr = {
1030 		.enable_reg = 0x8044,
1031 		.enable_mask = BIT(0),
1032 		.hw.init = &(const struct clk_init_data) {
1033 			.name = "disp_cc_mdss_dptx0_usb_router_link_intf_clk",
1034 			.parent_hws = (const struct clk_hw*[]) {
1035 				&disp_cc_mdss_dptx0_link_div_clk_src.clkr.hw,
1036 			},
1037 			.num_parents = 1,
1038 			.flags = CLK_SET_RATE_PARENT,
1039 			.ops = &clk_branch2_ops,
1040 		},
1041 	},
1042 };
1043 
1044 static struct clk_branch disp_cc_mdss_dptx1_aux_clk = {
1045 	.halt_reg = 0x8074,
1046 	.halt_check = BRANCH_HALT,
1047 	.clkr = {
1048 		.enable_reg = 0x8074,
1049 		.enable_mask = BIT(0),
1050 		.hw.init = &(const struct clk_init_data) {
1051 			.name = "disp_cc_mdss_dptx1_aux_clk",
1052 			.parent_hws = (const struct clk_hw*[]) {
1053 				&disp_cc_mdss_dptx1_aux_clk_src.clkr.hw,
1054 			},
1055 			.num_parents = 1,
1056 			.flags = CLK_SET_RATE_PARENT,
1057 			.ops = &clk_branch2_ops,
1058 		},
1059 	},
1060 };
1061 
1062 static struct clk_branch disp_cc_mdss_dptx1_crypto_clk = {
1063 	.halt_reg = 0x8070,
1064 	.halt_check = BRANCH_HALT,
1065 	.clkr = {
1066 		.enable_reg = 0x8070,
1067 		.enable_mask = BIT(0),
1068 		.hw.init = &(const struct clk_init_data) {
1069 			.name = "disp_cc_mdss_dptx1_crypto_clk",
1070 			.parent_hws = (const struct clk_hw*[]) {
1071 				&disp_cc_mdss_dptx1_link_clk_src.clkr.hw,
1072 			},
1073 			.num_parents = 1,
1074 			.flags = CLK_SET_RATE_PARENT,
1075 			.ops = &clk_branch2_ops,
1076 		},
1077 	},
1078 };
1079 
1080 static struct clk_branch disp_cc_mdss_dptx1_link_clk = {
1081 	.halt_reg = 0x8064,
1082 	.halt_check = BRANCH_HALT,
1083 	.clkr = {
1084 		.enable_reg = 0x8064,
1085 		.enable_mask = BIT(0),
1086 		.hw.init = &(const struct clk_init_data) {
1087 			.name = "disp_cc_mdss_dptx1_link_clk",
1088 			.parent_hws = (const struct clk_hw*[]) {
1089 				&disp_cc_mdss_dptx1_link_clk_src.clkr.hw,
1090 			},
1091 			.num_parents = 1,
1092 			.flags = CLK_SET_RATE_PARENT,
1093 			.ops = &clk_branch2_ops,
1094 		},
1095 	},
1096 };
1097 
1098 static struct clk_branch disp_cc_mdss_dptx1_link_intf_clk = {
1099 	.halt_reg = 0x806c,
1100 	.halt_check = BRANCH_HALT,
1101 	.clkr = {
1102 		.enable_reg = 0x806c,
1103 		.enable_mask = BIT(0),
1104 		.hw.init = &(const struct clk_init_data) {
1105 			.name = "disp_cc_mdss_dptx1_link_intf_clk",
1106 			.parent_hws = (const struct clk_hw*[]) {
1107 				&disp_cc_mdss_dptx1_link_div_clk_src.clkr.hw,
1108 			},
1109 			.num_parents = 1,
1110 			.flags = CLK_SET_RATE_PARENT,
1111 			.ops = &clk_branch2_ops,
1112 		},
1113 	},
1114 };
1115 
1116 static struct clk_branch disp_cc_mdss_dptx1_pixel0_clk = {
1117 	.halt_reg = 0x805c,
1118 	.halt_check = BRANCH_HALT,
1119 	.clkr = {
1120 		.enable_reg = 0x805c,
1121 		.enable_mask = BIT(0),
1122 		.hw.init = &(const struct clk_init_data) {
1123 			.name = "disp_cc_mdss_dptx1_pixel0_clk",
1124 			.parent_hws = (const struct clk_hw*[]) {
1125 				&disp_cc_mdss_dptx1_pixel0_clk_src.clkr.hw,
1126 			},
1127 			.num_parents = 1,
1128 			.flags = CLK_SET_RATE_PARENT,
1129 			.ops = &clk_branch2_ops,
1130 		},
1131 	},
1132 };
1133 
1134 static struct clk_branch disp_cc_mdss_dptx1_pixel1_clk = {
1135 	.halt_reg = 0x8060,
1136 	.halt_check = BRANCH_HALT,
1137 	.clkr = {
1138 		.enable_reg = 0x8060,
1139 		.enable_mask = BIT(0),
1140 		.hw.init = &(const struct clk_init_data) {
1141 			.name = "disp_cc_mdss_dptx1_pixel1_clk",
1142 			.parent_hws = (const struct clk_hw*[]) {
1143 				&disp_cc_mdss_dptx1_pixel1_clk_src.clkr.hw,
1144 			},
1145 			.num_parents = 1,
1146 			.flags = CLK_SET_RATE_PARENT,
1147 			.ops = &clk_branch2_ops,
1148 		},
1149 	},
1150 };
1151 
1152 static struct clk_branch disp_cc_mdss_dptx1_usb_router_link_intf_clk = {
1153 	.halt_reg = 0x8068,
1154 	.halt_check = BRANCH_HALT,
1155 	.clkr = {
1156 		.enable_reg = 0x8068,
1157 		.enable_mask = BIT(0),
1158 		.hw.init = &(const struct clk_init_data) {
1159 			.name = "disp_cc_mdss_dptx1_usb_router_link_intf_clk",
1160 			.parent_hws = (const struct clk_hw*[]) {
1161 				&disp_cc_mdss_dptx0_link_div_clk_src.clkr.hw,
1162 			},
1163 			.num_parents = 1,
1164 			.flags = CLK_SET_RATE_PARENT,
1165 			.ops = &clk_branch2_ops,
1166 		},
1167 	},
1168 };
1169 
1170 static struct clk_branch disp_cc_mdss_dptx2_aux_clk = {
1171 	.halt_reg = 0x808c,
1172 	.halt_check = BRANCH_HALT,
1173 	.clkr = {
1174 		.enable_reg = 0x808c,
1175 		.enable_mask = BIT(0),
1176 		.hw.init = &(const struct clk_init_data) {
1177 			.name = "disp_cc_mdss_dptx2_aux_clk",
1178 			.parent_hws = (const struct clk_hw*[]) {
1179 				&disp_cc_mdss_dptx2_aux_clk_src.clkr.hw,
1180 			},
1181 			.num_parents = 1,
1182 			.flags = CLK_SET_RATE_PARENT,
1183 			.ops = &clk_branch2_ops,
1184 		},
1185 	},
1186 };
1187 
1188 static struct clk_branch disp_cc_mdss_dptx2_crypto_clk = {
1189 	.halt_reg = 0x8088,
1190 	.halt_check = BRANCH_HALT,
1191 	.clkr = {
1192 		.enable_reg = 0x8088,
1193 		.enable_mask = BIT(0),
1194 		.hw.init = &(const struct clk_init_data) {
1195 			.name = "disp_cc_mdss_dptx2_crypto_clk",
1196 			.parent_hws = (const struct clk_hw*[]) {
1197 				&disp_cc_mdss_dptx2_link_clk_src.clkr.hw,
1198 			},
1199 			.num_parents = 1,
1200 			.flags = CLK_SET_RATE_PARENT,
1201 			.ops = &clk_branch2_ops,
1202 		},
1203 	},
1204 };
1205 
1206 static struct clk_branch disp_cc_mdss_dptx2_link_clk = {
1207 	.halt_reg = 0x8080,
1208 	.halt_check = BRANCH_HALT,
1209 	.clkr = {
1210 		.enable_reg = 0x8080,
1211 		.enable_mask = BIT(0),
1212 		.hw.init = &(const struct clk_init_data) {
1213 			.name = "disp_cc_mdss_dptx2_link_clk",
1214 			.parent_hws = (const struct clk_hw*[]) {
1215 				&disp_cc_mdss_dptx2_link_clk_src.clkr.hw,
1216 			},
1217 			.num_parents = 1,
1218 			.flags = CLK_SET_RATE_PARENT,
1219 			.ops = &clk_branch2_ops,
1220 		},
1221 	},
1222 };
1223 
1224 static struct clk_branch disp_cc_mdss_dptx2_link_intf_clk = {
1225 	.halt_reg = 0x8084,
1226 	.halt_check = BRANCH_HALT,
1227 	.clkr = {
1228 		.enable_reg = 0x8084,
1229 		.enable_mask = BIT(0),
1230 		.hw.init = &(const struct clk_init_data) {
1231 			.name = "disp_cc_mdss_dptx2_link_intf_clk",
1232 			.parent_hws = (const struct clk_hw*[]) {
1233 				&disp_cc_mdss_dptx2_link_div_clk_src.clkr.hw,
1234 			},
1235 			.num_parents = 1,
1236 			.flags = CLK_SET_RATE_PARENT,
1237 			.ops = &clk_branch2_ops,
1238 		},
1239 	},
1240 };
1241 
1242 static struct clk_branch disp_cc_mdss_dptx2_pixel0_clk = {
1243 	.halt_reg = 0x8078,
1244 	.halt_check = BRANCH_HALT,
1245 	.clkr = {
1246 		.enable_reg = 0x8078,
1247 		.enable_mask = BIT(0),
1248 		.hw.init = &(const struct clk_init_data) {
1249 			.name = "disp_cc_mdss_dptx2_pixel0_clk",
1250 			.parent_hws = (const struct clk_hw*[]) {
1251 				&disp_cc_mdss_dptx2_pixel0_clk_src.clkr.hw,
1252 			},
1253 			.num_parents = 1,
1254 			.flags = CLK_SET_RATE_PARENT,
1255 			.ops = &clk_branch2_ops,
1256 		},
1257 	},
1258 };
1259 
1260 static struct clk_branch disp_cc_mdss_dptx2_pixel1_clk = {
1261 	.halt_reg = 0x807c,
1262 	.halt_check = BRANCH_HALT,
1263 	.clkr = {
1264 		.enable_reg = 0x807c,
1265 		.enable_mask = BIT(0),
1266 		.hw.init = &(const struct clk_init_data) {
1267 			.name = "disp_cc_mdss_dptx2_pixel1_clk",
1268 			.parent_hws = (const struct clk_hw*[]) {
1269 				&disp_cc_mdss_dptx2_pixel1_clk_src.clkr.hw,
1270 			},
1271 			.num_parents = 1,
1272 			.flags = CLK_SET_RATE_PARENT,
1273 			.ops = &clk_branch2_ops,
1274 		},
1275 	},
1276 };
1277 
1278 static struct clk_branch disp_cc_mdss_dptx3_aux_clk = {
1279 	.halt_reg = 0x809c,
1280 	.halt_check = BRANCH_HALT,
1281 	.clkr = {
1282 		.enable_reg = 0x809c,
1283 		.enable_mask = BIT(0),
1284 		.hw.init = &(const struct clk_init_data) {
1285 			.name = "disp_cc_mdss_dptx3_aux_clk",
1286 			.parent_hws = (const struct clk_hw*[]) {
1287 				&disp_cc_mdss_dptx3_aux_clk_src.clkr.hw,
1288 			},
1289 			.num_parents = 1,
1290 			.flags = CLK_SET_RATE_PARENT,
1291 			.ops = &clk_branch2_ops,
1292 		},
1293 	},
1294 };
1295 
1296 static struct clk_branch disp_cc_mdss_dptx3_crypto_clk = {
1297 	.halt_reg = 0x80a0,
1298 	.halt_check = BRANCH_HALT,
1299 	.clkr = {
1300 		.enable_reg = 0x80a0,
1301 		.enable_mask = BIT(0),
1302 		.hw.init = &(const struct clk_init_data) {
1303 			.name = "disp_cc_mdss_dptx3_crypto_clk",
1304 			.parent_hws = (const struct clk_hw*[]) {
1305 				&disp_cc_mdss_dptx3_link_clk_src.clkr.hw,
1306 			},
1307 			.num_parents = 1,
1308 			.flags = CLK_SET_RATE_PARENT,
1309 			.ops = &clk_branch2_ops,
1310 		},
1311 	},
1312 };
1313 
1314 static struct clk_branch disp_cc_mdss_dptx3_link_clk = {
1315 	.halt_reg = 0x8094,
1316 	.halt_check = BRANCH_HALT,
1317 	.clkr = {
1318 		.enable_reg = 0x8094,
1319 		.enable_mask = BIT(0),
1320 		.hw.init = &(const struct clk_init_data) {
1321 			.name = "disp_cc_mdss_dptx3_link_clk",
1322 			.parent_hws = (const struct clk_hw*[]) {
1323 				&disp_cc_mdss_dptx3_link_clk_src.clkr.hw,
1324 			},
1325 			.num_parents = 1,
1326 			.flags = CLK_SET_RATE_PARENT,
1327 			.ops = &clk_branch2_ops,
1328 		},
1329 	},
1330 };
1331 
1332 static struct clk_branch disp_cc_mdss_dptx3_link_intf_clk = {
1333 	.halt_reg = 0x8098,
1334 	.halt_check = BRANCH_HALT,
1335 	.clkr = {
1336 		.enable_reg = 0x8098,
1337 		.enable_mask = BIT(0),
1338 		.hw.init = &(const struct clk_init_data) {
1339 			.name = "disp_cc_mdss_dptx3_link_intf_clk",
1340 			.parent_hws = (const struct clk_hw*[]) {
1341 				&disp_cc_mdss_dptx3_link_div_clk_src.clkr.hw,
1342 			},
1343 			.num_parents = 1,
1344 			.flags = CLK_SET_RATE_PARENT,
1345 			.ops = &clk_branch2_ops,
1346 		},
1347 	},
1348 };
1349 
1350 static struct clk_branch disp_cc_mdss_dptx3_pixel0_clk = {
1351 	.halt_reg = 0x8090,
1352 	.halt_check = BRANCH_HALT,
1353 	.clkr = {
1354 		.enable_reg = 0x8090,
1355 		.enable_mask = BIT(0),
1356 		.hw.init = &(const struct clk_init_data) {
1357 			.name = "disp_cc_mdss_dptx3_pixel0_clk",
1358 			.parent_hws = (const struct clk_hw*[]) {
1359 				&disp_cc_mdss_dptx3_pixel0_clk_src.clkr.hw,
1360 			},
1361 			.num_parents = 1,
1362 			.flags = CLK_SET_RATE_PARENT,
1363 			.ops = &clk_branch2_ops,
1364 		},
1365 	},
1366 };
1367 
1368 static struct clk_branch disp_cc_mdss_esc0_clk = {
1369 	.halt_reg = 0x8038,
1370 	.halt_check = BRANCH_HALT,
1371 	.clkr = {
1372 		.enable_reg = 0x8038,
1373 		.enable_mask = BIT(0),
1374 		.hw.init = &(const struct clk_init_data) {
1375 			.name = "disp_cc_mdss_esc0_clk",
1376 			.parent_hws = (const struct clk_hw*[]) {
1377 				&disp_cc_mdss_esc0_clk_src.clkr.hw,
1378 			},
1379 			.num_parents = 1,
1380 			.flags = CLK_SET_RATE_PARENT,
1381 			.ops = &clk_branch2_ops,
1382 		},
1383 	},
1384 };
1385 
1386 static struct clk_branch disp_cc_mdss_esc1_clk = {
1387 	.halt_reg = 0x803c,
1388 	.halt_check = BRANCH_HALT,
1389 	.clkr = {
1390 		.enable_reg = 0x803c,
1391 		.enable_mask = BIT(0),
1392 		.hw.init = &(const struct clk_init_data) {
1393 			.name = "disp_cc_mdss_esc1_clk",
1394 			.parent_hws = (const struct clk_hw*[]) {
1395 				&disp_cc_mdss_esc1_clk_src.clkr.hw,
1396 			},
1397 			.num_parents = 1,
1398 			.flags = CLK_SET_RATE_PARENT,
1399 			.ops = &clk_branch2_ops,
1400 		},
1401 	},
1402 };
1403 
1404 static struct clk_branch disp_cc_mdss_mdp1_clk = {
1405 	.halt_reg = 0xa004,
1406 	.halt_check = BRANCH_HALT,
1407 	.clkr = {
1408 		.enable_reg = 0xa004,
1409 		.enable_mask = BIT(0),
1410 		.hw.init = &(const struct clk_init_data) {
1411 			.name = "disp_cc_mdss_mdp1_clk",
1412 			.parent_hws = (const struct clk_hw*[]) {
1413 				&disp_cc_mdss_mdp_clk_src.clkr.hw,
1414 			},
1415 			.num_parents = 1,
1416 			.flags = CLK_SET_RATE_PARENT,
1417 			.ops = &clk_branch2_ops,
1418 		},
1419 	},
1420 };
1421 
1422 static struct clk_branch disp_cc_mdss_mdp_clk = {
1423 	.halt_reg = 0x800c,
1424 	.halt_check = BRANCH_HALT,
1425 	.clkr = {
1426 		.enable_reg = 0x800c,
1427 		.enable_mask = BIT(0),
1428 		.hw.init = &(const struct clk_init_data) {
1429 			.name = "disp_cc_mdss_mdp_clk",
1430 			.parent_hws = (const struct clk_hw*[]) {
1431 				&disp_cc_mdss_mdp_clk_src.clkr.hw,
1432 			},
1433 			.num_parents = 1,
1434 			.flags = CLK_SET_RATE_PARENT,
1435 			.ops = &clk_branch2_ops,
1436 		},
1437 	},
1438 };
1439 
1440 static struct clk_branch disp_cc_mdss_mdp_lut1_clk = {
1441 	.halt_reg = 0xa010,
1442 	.halt_check = BRANCH_HALT,
1443 	.clkr = {
1444 		.enable_reg = 0xa010,
1445 		.enable_mask = BIT(0),
1446 		.hw.init = &(const struct clk_init_data) {
1447 			.name = "disp_cc_mdss_mdp_lut1_clk",
1448 			.parent_hws = (const struct clk_hw*[]) {
1449 				&disp_cc_mdss_mdp_clk_src.clkr.hw,
1450 			},
1451 			.num_parents = 1,
1452 			.flags = CLK_SET_RATE_PARENT,
1453 			.ops = &clk_branch2_ops,
1454 		},
1455 	},
1456 };
1457 
1458 static struct clk_branch disp_cc_mdss_mdp_lut_clk = {
1459 	.halt_reg = 0x8018,
1460 	.halt_check = BRANCH_HALT_VOTED,
1461 	.clkr = {
1462 		.enable_reg = 0x8018,
1463 		.enable_mask = BIT(0),
1464 		.hw.init = &(const struct clk_init_data) {
1465 			.name = "disp_cc_mdss_mdp_lut_clk",
1466 			.parent_hws = (const struct clk_hw*[]) {
1467 				&disp_cc_mdss_mdp_clk_src.clkr.hw,
1468 			},
1469 			.num_parents = 1,
1470 			.flags = CLK_SET_RATE_PARENT,
1471 			.ops = &clk_branch2_ops,
1472 		},
1473 	},
1474 };
1475 
1476 static struct clk_branch disp_cc_mdss_non_gdsc_ahb_clk = {
1477 	.halt_reg = 0xc004,
1478 	.halt_check = BRANCH_HALT_VOTED,
1479 	.clkr = {
1480 		.enable_reg = 0xc004,
1481 		.enable_mask = BIT(0),
1482 		.hw.init = &(const struct clk_init_data) {
1483 			.name = "disp_cc_mdss_non_gdsc_ahb_clk",
1484 			.parent_hws = (const struct clk_hw*[]) {
1485 				&disp_cc_mdss_ahb_clk_src.clkr.hw,
1486 			},
1487 			.num_parents = 1,
1488 			.flags = CLK_SET_RATE_PARENT,
1489 			.ops = &clk_branch2_ops,
1490 		},
1491 	},
1492 };
1493 
1494 static struct clk_branch disp_cc_mdss_pclk0_clk = {
1495 	.halt_reg = 0x8004,
1496 	.halt_check = BRANCH_HALT,
1497 	.clkr = {
1498 		.enable_reg = 0x8004,
1499 		.enable_mask = BIT(0),
1500 		.hw.init = &(const struct clk_init_data) {
1501 			.name = "disp_cc_mdss_pclk0_clk",
1502 			.parent_hws = (const struct clk_hw*[]) {
1503 				&disp_cc_mdss_pclk0_clk_src.clkr.hw,
1504 			},
1505 			.num_parents = 1,
1506 			.flags = CLK_SET_RATE_PARENT,
1507 			.ops = &clk_branch2_ops,
1508 		},
1509 	},
1510 };
1511 
1512 static struct clk_branch disp_cc_mdss_pclk1_clk = {
1513 	.halt_reg = 0x8008,
1514 	.halt_check = BRANCH_HALT,
1515 	.clkr = {
1516 		.enable_reg = 0x8008,
1517 		.enable_mask = BIT(0),
1518 		.hw.init = &(const struct clk_init_data) {
1519 			.name = "disp_cc_mdss_pclk1_clk",
1520 			.parent_hws = (const struct clk_hw*[]) {
1521 				&disp_cc_mdss_pclk1_clk_src.clkr.hw,
1522 			},
1523 			.num_parents = 1,
1524 			.flags = CLK_SET_RATE_PARENT,
1525 			.ops = &clk_branch2_ops,
1526 		},
1527 	},
1528 };
1529 
1530 static struct clk_branch disp_cc_mdss_rscc_ahb_clk = {
1531 	.halt_reg = 0xc00c,
1532 	.halt_check = BRANCH_HALT,
1533 	.clkr = {
1534 		.enable_reg = 0xc00c,
1535 		.enable_mask = BIT(0),
1536 		.hw.init = &(const struct clk_init_data) {
1537 			.name = "disp_cc_mdss_rscc_ahb_clk",
1538 			.parent_hws = (const struct clk_hw*[]) {
1539 				&disp_cc_mdss_ahb_clk_src.clkr.hw,
1540 			},
1541 			.num_parents = 1,
1542 			.flags = CLK_SET_RATE_PARENT,
1543 			.ops = &clk_branch2_ops,
1544 		},
1545 	},
1546 };
1547 
1548 static struct clk_branch disp_cc_mdss_rscc_vsync_clk = {
1549 	.halt_reg = 0xc008,
1550 	.halt_check = BRANCH_HALT,
1551 	.clkr = {
1552 		.enable_reg = 0xc008,
1553 		.enable_mask = BIT(0),
1554 		.hw.init = &(const struct clk_init_data) {
1555 			.name = "disp_cc_mdss_rscc_vsync_clk",
1556 			.parent_hws = (const struct clk_hw*[]) {
1557 				&disp_cc_mdss_vsync_clk_src.clkr.hw,
1558 			},
1559 			.num_parents = 1,
1560 			.flags = CLK_SET_RATE_PARENT,
1561 			.ops = &clk_branch2_ops,
1562 		},
1563 	},
1564 };
1565 
1566 static struct clk_branch disp_cc_mdss_vsync1_clk = {
1567 	.halt_reg = 0xa01c,
1568 	.halt_check = BRANCH_HALT,
1569 	.clkr = {
1570 		.enable_reg = 0xa01c,
1571 		.enable_mask = BIT(0),
1572 		.hw.init = &(const struct clk_init_data) {
1573 			.name = "disp_cc_mdss_vsync1_clk",
1574 			.parent_hws = (const struct clk_hw*[]) {
1575 				&disp_cc_mdss_vsync_clk_src.clkr.hw,
1576 			},
1577 			.num_parents = 1,
1578 			.flags = CLK_SET_RATE_PARENT,
1579 			.ops = &clk_branch2_ops,
1580 		},
1581 	},
1582 };
1583 
1584 static struct clk_branch disp_cc_mdss_vsync_clk = {
1585 	.halt_reg = 0x8024,
1586 	.halt_check = BRANCH_HALT,
1587 	.clkr = {
1588 		.enable_reg = 0x8024,
1589 		.enable_mask = BIT(0),
1590 		.hw.init = &(const struct clk_init_data) {
1591 			.name = "disp_cc_mdss_vsync_clk",
1592 			.parent_hws = (const struct clk_hw*[]) {
1593 				&disp_cc_mdss_vsync_clk_src.clkr.hw,
1594 			},
1595 			.num_parents = 1,
1596 			.flags = CLK_SET_RATE_PARENT,
1597 			.ops = &clk_branch2_ops,
1598 		},
1599 	},
1600 };
1601 
1602 static struct clk_branch disp_cc_sleep_clk = {
1603 	.halt_reg = 0xe074,
1604 	.halt_check = BRANCH_HALT,
1605 	.clkr = {
1606 		.enable_reg = 0xe074,
1607 		.enable_mask = BIT(0),
1608 		.hw.init = &(const struct clk_init_data) {
1609 			.name = "disp_cc_sleep_clk",
1610 			.parent_hws = (const struct clk_hw*[]) {
1611 				&disp_cc_sleep_clk_src.clkr.hw,
1612 			},
1613 			.num_parents = 1,
1614 			.flags = CLK_SET_RATE_PARENT,
1615 			.ops = &clk_branch2_ops,
1616 		},
1617 	},
1618 };
1619 
1620 static struct gdsc mdss_gdsc = {
1621 	.gdscr = 0x9000,
1622 	.pd = {
1623 		.name = "mdss_gdsc",
1624 	},
1625 	.pwrsts = PWRSTS_OFF_ON,
1626 	.flags = POLL_CFG_GDSCR | HW_CTRL | RETAIN_FF_ENABLE,
1627 };
1628 
1629 static struct gdsc mdss_int2_gdsc = {
1630 	.gdscr = 0xb000,
1631 	.pd = {
1632 		.name = "mdss_int2_gdsc",
1633 	},
1634 	.pwrsts = PWRSTS_OFF_ON,
1635 	.flags = POLL_CFG_GDSCR | HW_CTRL | RETAIN_FF_ENABLE,
1636 };
1637 
1638 static struct clk_regmap *disp_cc_sm8550_clocks[] = {
1639 	[DISP_CC_MDSS_ACCU_CLK] = &disp_cc_mdss_accu_clk.clkr,
1640 	[DISP_CC_MDSS_AHB1_CLK] = &disp_cc_mdss_ahb1_clk.clkr,
1641 	[DISP_CC_MDSS_AHB_CLK] = &disp_cc_mdss_ahb_clk.clkr,
1642 	[DISP_CC_MDSS_AHB_CLK_SRC] = &disp_cc_mdss_ahb_clk_src.clkr,
1643 	[DISP_CC_MDSS_BYTE0_CLK] = &disp_cc_mdss_byte0_clk.clkr,
1644 	[DISP_CC_MDSS_BYTE0_CLK_SRC] = &disp_cc_mdss_byte0_clk_src.clkr,
1645 	[DISP_CC_MDSS_BYTE0_DIV_CLK_SRC] = &disp_cc_mdss_byte0_div_clk_src.clkr,
1646 	[DISP_CC_MDSS_BYTE0_INTF_CLK] = &disp_cc_mdss_byte0_intf_clk.clkr,
1647 	[DISP_CC_MDSS_BYTE1_CLK] = &disp_cc_mdss_byte1_clk.clkr,
1648 	[DISP_CC_MDSS_BYTE1_CLK_SRC] = &disp_cc_mdss_byte1_clk_src.clkr,
1649 	[DISP_CC_MDSS_BYTE1_DIV_CLK_SRC] = &disp_cc_mdss_byte1_div_clk_src.clkr,
1650 	[DISP_CC_MDSS_BYTE1_INTF_CLK] = &disp_cc_mdss_byte1_intf_clk.clkr,
1651 	[DISP_CC_MDSS_DPTX0_AUX_CLK] = &disp_cc_mdss_dptx0_aux_clk.clkr,
1652 	[DISP_CC_MDSS_DPTX0_AUX_CLK_SRC] = &disp_cc_mdss_dptx0_aux_clk_src.clkr,
1653 	[DISP_CC_MDSS_DPTX0_CRYPTO_CLK] = &disp_cc_mdss_dptx0_crypto_clk.clkr,
1654 	[DISP_CC_MDSS_DPTX0_LINK_CLK] = &disp_cc_mdss_dptx0_link_clk.clkr,
1655 	[DISP_CC_MDSS_DPTX0_LINK_CLK_SRC] = &disp_cc_mdss_dptx0_link_clk_src.clkr,
1656 	[DISP_CC_MDSS_DPTX0_LINK_DIV_CLK_SRC] = &disp_cc_mdss_dptx0_link_div_clk_src.clkr,
1657 	[DISP_CC_MDSS_DPTX0_LINK_INTF_CLK] = &disp_cc_mdss_dptx0_link_intf_clk.clkr,
1658 	[DISP_CC_MDSS_DPTX0_PIXEL0_CLK] = &disp_cc_mdss_dptx0_pixel0_clk.clkr,
1659 	[DISP_CC_MDSS_DPTX0_PIXEL0_CLK_SRC] = &disp_cc_mdss_dptx0_pixel0_clk_src.clkr,
1660 	[DISP_CC_MDSS_DPTX0_PIXEL1_CLK] = &disp_cc_mdss_dptx0_pixel1_clk.clkr,
1661 	[DISP_CC_MDSS_DPTX0_PIXEL1_CLK_SRC] = &disp_cc_mdss_dptx0_pixel1_clk_src.clkr,
1662 	[DISP_CC_MDSS_DPTX0_USB_ROUTER_LINK_INTF_CLK] =
1663 		&disp_cc_mdss_dptx0_usb_router_link_intf_clk.clkr,
1664 	[DISP_CC_MDSS_DPTX1_AUX_CLK] = &disp_cc_mdss_dptx1_aux_clk.clkr,
1665 	[DISP_CC_MDSS_DPTX1_AUX_CLK_SRC] = &disp_cc_mdss_dptx1_aux_clk_src.clkr,
1666 	[DISP_CC_MDSS_DPTX1_CRYPTO_CLK] = &disp_cc_mdss_dptx1_crypto_clk.clkr,
1667 	[DISP_CC_MDSS_DPTX1_LINK_CLK] = &disp_cc_mdss_dptx1_link_clk.clkr,
1668 	[DISP_CC_MDSS_DPTX1_LINK_CLK_SRC] = &disp_cc_mdss_dptx1_link_clk_src.clkr,
1669 	[DISP_CC_MDSS_DPTX1_LINK_DIV_CLK_SRC] = &disp_cc_mdss_dptx1_link_div_clk_src.clkr,
1670 	[DISP_CC_MDSS_DPTX1_LINK_INTF_CLK] = &disp_cc_mdss_dptx1_link_intf_clk.clkr,
1671 	[DISP_CC_MDSS_DPTX1_PIXEL0_CLK] = &disp_cc_mdss_dptx1_pixel0_clk.clkr,
1672 	[DISP_CC_MDSS_DPTX1_PIXEL0_CLK_SRC] = &disp_cc_mdss_dptx1_pixel0_clk_src.clkr,
1673 	[DISP_CC_MDSS_DPTX1_PIXEL1_CLK] = &disp_cc_mdss_dptx1_pixel1_clk.clkr,
1674 	[DISP_CC_MDSS_DPTX1_PIXEL1_CLK_SRC] = &disp_cc_mdss_dptx1_pixel1_clk_src.clkr,
1675 	[DISP_CC_MDSS_DPTX1_USB_ROUTER_LINK_INTF_CLK] =
1676 		&disp_cc_mdss_dptx1_usb_router_link_intf_clk.clkr,
1677 	[DISP_CC_MDSS_DPTX2_AUX_CLK] = &disp_cc_mdss_dptx2_aux_clk.clkr,
1678 	[DISP_CC_MDSS_DPTX2_AUX_CLK_SRC] = &disp_cc_mdss_dptx2_aux_clk_src.clkr,
1679 	[DISP_CC_MDSS_DPTX2_CRYPTO_CLK] = &disp_cc_mdss_dptx2_crypto_clk.clkr,
1680 	[DISP_CC_MDSS_DPTX2_LINK_CLK] = &disp_cc_mdss_dptx2_link_clk.clkr,
1681 	[DISP_CC_MDSS_DPTX2_LINK_CLK_SRC] = &disp_cc_mdss_dptx2_link_clk_src.clkr,
1682 	[DISP_CC_MDSS_DPTX2_LINK_DIV_CLK_SRC] = &disp_cc_mdss_dptx2_link_div_clk_src.clkr,
1683 	[DISP_CC_MDSS_DPTX2_LINK_INTF_CLK] = &disp_cc_mdss_dptx2_link_intf_clk.clkr,
1684 	[DISP_CC_MDSS_DPTX2_PIXEL0_CLK] = &disp_cc_mdss_dptx2_pixel0_clk.clkr,
1685 	[DISP_CC_MDSS_DPTX2_PIXEL0_CLK_SRC] = &disp_cc_mdss_dptx2_pixel0_clk_src.clkr,
1686 	[DISP_CC_MDSS_DPTX2_PIXEL1_CLK] = &disp_cc_mdss_dptx2_pixel1_clk.clkr,
1687 	[DISP_CC_MDSS_DPTX2_PIXEL1_CLK_SRC] = &disp_cc_mdss_dptx2_pixel1_clk_src.clkr,
1688 	[DISP_CC_MDSS_DPTX3_AUX_CLK] = &disp_cc_mdss_dptx3_aux_clk.clkr,
1689 	[DISP_CC_MDSS_DPTX3_AUX_CLK_SRC] = &disp_cc_mdss_dptx3_aux_clk_src.clkr,
1690 	[DISP_CC_MDSS_DPTX3_CRYPTO_CLK] = &disp_cc_mdss_dptx3_crypto_clk.clkr,
1691 	[DISP_CC_MDSS_DPTX3_LINK_CLK] = &disp_cc_mdss_dptx3_link_clk.clkr,
1692 	[DISP_CC_MDSS_DPTX3_LINK_CLK_SRC] = &disp_cc_mdss_dptx3_link_clk_src.clkr,
1693 	[DISP_CC_MDSS_DPTX3_LINK_DIV_CLK_SRC] = &disp_cc_mdss_dptx3_link_div_clk_src.clkr,
1694 	[DISP_CC_MDSS_DPTX3_LINK_INTF_CLK] = &disp_cc_mdss_dptx3_link_intf_clk.clkr,
1695 	[DISP_CC_MDSS_DPTX3_PIXEL0_CLK] = &disp_cc_mdss_dptx3_pixel0_clk.clkr,
1696 	[DISP_CC_MDSS_DPTX3_PIXEL0_CLK_SRC] = &disp_cc_mdss_dptx3_pixel0_clk_src.clkr,
1697 	[DISP_CC_MDSS_ESC0_CLK] = &disp_cc_mdss_esc0_clk.clkr,
1698 	[DISP_CC_MDSS_ESC0_CLK_SRC] = &disp_cc_mdss_esc0_clk_src.clkr,
1699 	[DISP_CC_MDSS_ESC1_CLK] = &disp_cc_mdss_esc1_clk.clkr,
1700 	[DISP_CC_MDSS_ESC1_CLK_SRC] = &disp_cc_mdss_esc1_clk_src.clkr,
1701 	[DISP_CC_MDSS_MDP1_CLK] = &disp_cc_mdss_mdp1_clk.clkr,
1702 	[DISP_CC_MDSS_MDP_CLK] = &disp_cc_mdss_mdp_clk.clkr,
1703 	[DISP_CC_MDSS_MDP_CLK_SRC] = &disp_cc_mdss_mdp_clk_src.clkr,
1704 	[DISP_CC_MDSS_MDP_LUT1_CLK] = &disp_cc_mdss_mdp_lut1_clk.clkr,
1705 	[DISP_CC_MDSS_MDP_LUT_CLK] = &disp_cc_mdss_mdp_lut_clk.clkr,
1706 	[DISP_CC_MDSS_NON_GDSC_AHB_CLK] = &disp_cc_mdss_non_gdsc_ahb_clk.clkr,
1707 	[DISP_CC_MDSS_PCLK0_CLK] = &disp_cc_mdss_pclk0_clk.clkr,
1708 	[DISP_CC_MDSS_PCLK0_CLK_SRC] = &disp_cc_mdss_pclk0_clk_src.clkr,
1709 	[DISP_CC_MDSS_PCLK1_CLK] = &disp_cc_mdss_pclk1_clk.clkr,
1710 	[DISP_CC_MDSS_PCLK1_CLK_SRC] = &disp_cc_mdss_pclk1_clk_src.clkr,
1711 	[DISP_CC_MDSS_RSCC_AHB_CLK] = &disp_cc_mdss_rscc_ahb_clk.clkr,
1712 	[DISP_CC_MDSS_RSCC_VSYNC_CLK] = &disp_cc_mdss_rscc_vsync_clk.clkr,
1713 	[DISP_CC_MDSS_VSYNC1_CLK] = &disp_cc_mdss_vsync1_clk.clkr,
1714 	[DISP_CC_MDSS_VSYNC_CLK] = &disp_cc_mdss_vsync_clk.clkr,
1715 	[DISP_CC_MDSS_VSYNC_CLK_SRC] = &disp_cc_mdss_vsync_clk_src.clkr,
1716 	[DISP_CC_PLL0] = &disp_cc_pll0.clkr,
1717 	[DISP_CC_PLL1] = &disp_cc_pll1.clkr,
1718 	[DISP_CC_SLEEP_CLK] = &disp_cc_sleep_clk.clkr,
1719 	[DISP_CC_SLEEP_CLK_SRC] = &disp_cc_sleep_clk_src.clkr,
1720 	[DISP_CC_XO_CLK_SRC] = &disp_cc_xo_clk_src.clkr,
1721 };
1722 
1723 static const struct qcom_reset_map disp_cc_sm8550_resets[] = {
1724 	[DISP_CC_MDSS_CORE_BCR] = { 0x8000 },
1725 	[DISP_CC_MDSS_CORE_INT2_BCR] = { 0xa000 },
1726 	[DISP_CC_MDSS_RSCC_BCR] = { 0xc000 },
1727 };
1728 
1729 static struct gdsc *disp_cc_sm8550_gdscs[] = {
1730 	[MDSS_GDSC] = &mdss_gdsc,
1731 	[MDSS_INT2_GDSC] = &mdss_int2_gdsc,
1732 };
1733 
1734 static const struct regmap_config disp_cc_sm8550_regmap_config = {
1735 	.reg_bits = 32,
1736 	.reg_stride = 4,
1737 	.val_bits = 32,
1738 	.max_register = 0x11008,
1739 	.fast_io = true,
1740 };
1741 
1742 static struct qcom_cc_desc disp_cc_sm8550_desc = {
1743 	.config = &disp_cc_sm8550_regmap_config,
1744 	.clks = disp_cc_sm8550_clocks,
1745 	.num_clks = ARRAY_SIZE(disp_cc_sm8550_clocks),
1746 	.resets = disp_cc_sm8550_resets,
1747 	.num_resets = ARRAY_SIZE(disp_cc_sm8550_resets),
1748 	.gdscs = disp_cc_sm8550_gdscs,
1749 	.num_gdscs = ARRAY_SIZE(disp_cc_sm8550_gdscs),
1750 };
1751 
1752 static const struct of_device_id disp_cc_sm8550_match_table[] = {
1753 	{ .compatible = "qcom,sm8550-dispcc" },
1754 	{ .compatible = "qcom,sm8650-dispcc" },
1755 	{ }
1756 };
1757 MODULE_DEVICE_TABLE(of, disp_cc_sm8550_match_table);
1758 
1759 static int disp_cc_sm8550_probe(struct platform_device *pdev)
1760 {
1761 	struct regmap *regmap;
1762 	int ret;
1763 
1764 	ret = devm_pm_runtime_enable(&pdev->dev);
1765 	if (ret)
1766 		return ret;
1767 
1768 	ret = pm_runtime_resume_and_get(&pdev->dev);
1769 	if (ret)
1770 		return ret;
1771 
1772 	regmap = qcom_cc_map(pdev, &disp_cc_sm8550_desc);
1773 	if (IS_ERR(regmap)) {
1774 		ret = PTR_ERR(regmap);
1775 		goto err_put_rpm;
1776 	}
1777 
1778 	if (of_device_is_compatible(pdev->dev.of_node, "qcom,sm8650-dispcc")) {
1779 		lucid_ole_vco[0].max_freq = 2100000000;
1780 		disp_cc_mdss_mdp_clk_src.freq_tbl = ftbl_disp_cc_mdss_mdp_clk_src_sm8650;
1781 		disp_cc_mdss_dptx1_usb_router_link_intf_clk.clkr.hw.init->parent_hws[0] =
1782 			&disp_cc_mdss_dptx1_link_div_clk_src.clkr.hw;
1783 	}
1784 
1785 	clk_lucid_ole_pll_configure(&disp_cc_pll0, regmap, &disp_cc_pll0_config);
1786 	clk_lucid_ole_pll_configure(&disp_cc_pll1, regmap, &disp_cc_pll1_config);
1787 
1788 	/* Enable clock gating for MDP clocks */
1789 	regmap_update_bits(regmap, DISP_CC_MISC_CMD, 0x10, 0x10);
1790 
1791 	/* Keep some clocks always-on */
1792 	qcom_branch_set_clk_en(regmap, 0xe054); /* DISP_CC_XO_CLK */
1793 
1794 	ret = qcom_cc_really_probe(&pdev->dev, &disp_cc_sm8550_desc, regmap);
1795 	if (ret)
1796 		goto err_put_rpm;
1797 
1798 	pm_runtime_put(&pdev->dev);
1799 
1800 	return 0;
1801 
1802 err_put_rpm:
1803 	pm_runtime_put_sync(&pdev->dev);
1804 
1805 	return ret;
1806 }
1807 
1808 static struct platform_driver disp_cc_sm8550_driver = {
1809 	.probe = disp_cc_sm8550_probe,
1810 	.driver = {
1811 		.name = "disp_cc-sm8550",
1812 		.of_match_table = disp_cc_sm8550_match_table,
1813 	},
1814 };
1815 
1816 module_platform_driver(disp_cc_sm8550_driver);
1817 
1818 MODULE_DESCRIPTION("QTI DISPCC SM8550 / SM8650  Driver");
1819 MODULE_LICENSE("GPL");
1820