blob: 58aa3ec9a7fc3bb12361b20c375292cca0773835 [file] [log] [blame]
Taniya Das06391ed2018-05-07 16:20:20 +05301// SPDX-License-Identifier: GPL-2.0
2/*
Taniya Das9c3df2b2020-07-15 12:24:10 +05303 * Copyright (c) 2018, 2020, The Linux Foundation. All rights reserved.
Taniya Das06391ed2018-05-07 16:20:20 +05304 */
5
6#include <linux/kernel.h>
7#include <linux/bitops.h>
8#include <linux/err.h>
9#include <linux/platform_device.h>
10#include <linux/module.h>
11#include <linux/of.h>
12#include <linux/of_device.h>
13#include <linux/clk-provider.h>
14#include <linux/regmap.h>
15#include <linux/reset-controller.h>
16
17#include <dt-bindings/clock/qcom,gcc-sdm845.h>
18
19#include "common.h"
20#include "clk-regmap.h"
21#include "clk-pll.h"
22#include "clk-rcg.h"
23#include "clk-branch.h"
24#include "clk-alpha-pll.h"
25#include "gdsc.h"
26#include "reset.h"
27
Taniya Das06391ed2018-05-07 16:20:20 +053028enum {
29 P_BI_TCXO,
30 P_AUD_REF_CLK,
Taniya Das06391ed2018-05-07 16:20:20 +053031 P_GPLL0_OUT_EVEN,
32 P_GPLL0_OUT_MAIN,
33 P_GPLL4_OUT_MAIN,
34 P_SLEEP_CLK,
35};
36
Taniya Das06391ed2018-05-07 16:20:20 +053037static struct clk_alpha_pll gpll0 = {
38 .offset = 0x0,
39 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
40 .clkr = {
41 .enable_reg = 0x52000,
42 .enable_mask = BIT(0),
43 .hw.init = &(struct clk_init_data){
44 .name = "gpll0",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +030045 .parent_data = &(const struct clk_parent_data){
46 .fw_name = "bi_tcxo", .name = "bi_tcxo",
47 },
Taniya Das06391ed2018-05-07 16:20:20 +053048 .num_parents = 1,
49 .ops = &clk_alpha_pll_fixed_fabia_ops,
50 },
51 },
52};
53
54static struct clk_alpha_pll gpll4 = {
55 .offset = 0x76000,
56 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
57 .clkr = {
58 .enable_reg = 0x52000,
59 .enable_mask = BIT(4),
60 .hw.init = &(struct clk_init_data){
61 .name = "gpll4",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +030062 .parent_data = &(const struct clk_parent_data){
63 .fw_name = "bi_tcxo", .name = "bi_tcxo",
64 },
Taniya Das06391ed2018-05-07 16:20:20 +053065 .num_parents = 1,
66 .ops = &clk_alpha_pll_fixed_fabia_ops,
67 },
68 },
69};
70
71static const struct clk_div_table post_div_table_fabia_even[] = {
72 { 0x0, 1 },
73 { 0x1, 2 },
74 { 0x3, 4 },
75 { 0x7, 8 },
76 { }
77};
78
79static struct clk_alpha_pll_postdiv gpll0_out_even = {
80 .offset = 0x0,
81 .post_div_shift = 8,
82 .post_div_table = post_div_table_fabia_even,
83 .num_post_div = ARRAY_SIZE(post_div_table_fabia_even),
84 .width = 4,
85 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
86 .clkr.hw.init = &(struct clk_init_data){
87 .name = "gpll0_out_even",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +030088 .parent_hws = (const struct clk_hw*[]){
89 &gpll0.clkr.hw,
90 },
Taniya Das06391ed2018-05-07 16:20:20 +053091 .num_parents = 1,
92 .ops = &clk_alpha_pll_postdiv_fabia_ops,
93 },
94};
95
Dmitry Baryshkovea434d72021-04-09 21:30:02 +030096static const struct parent_map gcc_parent_map_0[] = {
97 { P_BI_TCXO, 0 },
98 { P_GPLL0_OUT_MAIN, 1 },
99 { P_GPLL0_OUT_EVEN, 6 },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300100};
101
102static const struct clk_parent_data gcc_parent_data_0[] = {
103 { .fw_name = "bi_tcxo", .name = "bi_tcxo" },
104 { .hw = &gpll0.clkr.hw },
105 { .hw = &gpll0_out_even.clkr.hw },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300106};
107
108static const struct parent_map gcc_parent_map_1[] = {
109 { P_BI_TCXO, 0 },
110 { P_GPLL0_OUT_MAIN, 1 },
111 { P_SLEEP_CLK, 5 },
112 { P_GPLL0_OUT_EVEN, 6 },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300113};
114
115static const struct clk_parent_data gcc_parent_data_1[] = {
116 { .fw_name = "bi_tcxo", .name = "bi_tcxo" },
117 { .hw = &gpll0.clkr.hw },
118 { .fw_name = "sleep_clk", .name = "core_pi_sleep_clk" },
119 { .hw = &gpll0_out_even.clkr.hw },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300120};
121
122static const struct parent_map gcc_parent_map_2[] = {
123 { P_BI_TCXO, 0 },
124 { P_SLEEP_CLK, 5 },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300125};
126
127static const struct clk_parent_data gcc_parent_data_2[] = {
128 { .fw_name = "bi_tcxo", .name = "bi_tcxo" },
129 { .fw_name = "sleep_clk", .name = "core_pi_sleep_clk" },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300130};
131
132static const struct parent_map gcc_parent_map_3[] = {
133 { P_BI_TCXO, 0 },
134 { P_GPLL0_OUT_MAIN, 1 },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300135};
136
137static const struct clk_parent_data gcc_parent_data_3[] = {
138 { .fw_name = "bi_tcxo", .name = "bi_tcxo" },
139 { .hw = &gpll0.clkr.hw },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300140};
141
142static const struct parent_map gcc_parent_map_4[] = {
143 { P_BI_TCXO, 0 },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300144};
145
146static const struct clk_parent_data gcc_parent_data_4[] = {
147 { .fw_name = "bi_tcxo", .name = "bi_tcxo" },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300148};
149
150static const struct parent_map gcc_parent_map_6[] = {
151 { P_BI_TCXO, 0 },
152 { P_GPLL0_OUT_MAIN, 1 },
153 { P_AUD_REF_CLK, 2 },
154 { P_GPLL0_OUT_EVEN, 6 },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300155};
156
157static const struct clk_parent_data gcc_parent_data_6[] = {
158 { .fw_name = "bi_tcxo", .name = "bi_tcxo" },
159 { .hw = &gpll0.clkr.hw },
160 { .fw_name = "aud_ref_clk", .name = "aud_ref_clk" },
161 { .hw = &gpll0_out_even.clkr.hw },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300162};
163
164static const struct clk_parent_data gcc_parent_data_7_ao[] = {
165 { .fw_name = "bi_tcxo_ao", .name = "bi_tcxo_ao" },
166 { .hw = &gpll0.clkr.hw },
167 { .hw = &gpll0_out_even.clkr.hw },
168 { .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
169};
170
171static const struct clk_parent_data gcc_parent_data_8[] = {
172 { .fw_name = "bi_tcxo", .name = "bi_tcxo" },
173 { .hw = &gpll0.clkr.hw },
174 { .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
175};
176
177static const struct clk_parent_data gcc_parent_data_8_ao[] = {
178 { .fw_name = "bi_tcxo_ao", .name = "bi_tcxo_ao" },
179 { .hw = &gpll0.clkr.hw },
180 { .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
181};
182
183static const struct parent_map gcc_parent_map_10[] = {
184 { P_BI_TCXO, 0 },
185 { P_GPLL0_OUT_MAIN, 1 },
186 { P_GPLL4_OUT_MAIN, 5 },
187 { P_GPLL0_OUT_EVEN, 6 },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300188};
189
190static const struct clk_parent_data gcc_parent_data_10[] = {
191 { .fw_name = "bi_tcxo", .name = "bi_tcxo" },
192 { .hw = &gpll0.clkr.hw },
193 { .hw = &gpll4.clkr.hw },
194 { .hw = &gpll0_out_even.clkr.hw },
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300195};
196
197
Taniya Das06391ed2018-05-07 16:20:20 +0530198static const struct freq_tbl ftbl_gcc_cpuss_ahb_clk_src[] = {
199 F(19200000, P_BI_TCXO, 1, 0, 0),
200 { }
201};
202
203static struct clk_rcg2 gcc_cpuss_ahb_clk_src = {
204 .cmd_rcgr = 0x48014,
205 .mnd_width = 0,
206 .hid_width = 5,
207 .parent_map = gcc_parent_map_0,
208 .freq_tbl = ftbl_gcc_cpuss_ahb_clk_src,
209 .clkr.hw.init = &(struct clk_init_data){
210 .name = "gcc_cpuss_ahb_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300211 .parent_data = gcc_parent_data_7_ao,
212 .num_parents = ARRAY_SIZE(gcc_parent_data_7_ao),
Taniya Das06391ed2018-05-07 16:20:20 +0530213 .ops = &clk_rcg2_ops,
214 },
215};
216
217static const struct freq_tbl ftbl_gcc_cpuss_rbcpr_clk_src[] = {
218 F(19200000, P_BI_TCXO, 1, 0, 0),
219 { }
220};
221
222static struct clk_rcg2 gcc_cpuss_rbcpr_clk_src = {
223 .cmd_rcgr = 0x4815c,
224 .mnd_width = 0,
225 .hid_width = 5,
226 .parent_map = gcc_parent_map_3,
227 .freq_tbl = ftbl_gcc_cpuss_rbcpr_clk_src,
228 .clkr.hw.init = &(struct clk_init_data){
229 .name = "gcc_cpuss_rbcpr_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300230 .parent_data = gcc_parent_data_8_ao,
231 .num_parents = ARRAY_SIZE(gcc_parent_data_8_ao),
Taniya Das06391ed2018-05-07 16:20:20 +0530232 .ops = &clk_rcg2_ops,
233 },
234};
235
236static const struct freq_tbl ftbl_gcc_gp1_clk_src[] = {
237 F(19200000, P_BI_TCXO, 1, 0, 0),
238 F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
239 F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
240 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
241 F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
242 { }
243};
244
245static struct clk_rcg2 gcc_gp1_clk_src = {
246 .cmd_rcgr = 0x64004,
247 .mnd_width = 8,
248 .hid_width = 5,
249 .parent_map = gcc_parent_map_1,
250 .freq_tbl = ftbl_gcc_gp1_clk_src,
251 .clkr.hw.init = &(struct clk_init_data){
252 .name = "gcc_gp1_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300253 .parent_data = gcc_parent_data_1,
254 .num_parents = ARRAY_SIZE(gcc_parent_data_1),
Taniya Das06391ed2018-05-07 16:20:20 +0530255 .ops = &clk_rcg2_ops,
256 },
257};
258
259static struct clk_rcg2 gcc_gp2_clk_src = {
260 .cmd_rcgr = 0x65004,
261 .mnd_width = 8,
262 .hid_width = 5,
263 .parent_map = gcc_parent_map_1,
264 .freq_tbl = ftbl_gcc_gp1_clk_src,
265 .clkr.hw.init = &(struct clk_init_data){
266 .name = "gcc_gp2_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300267 .parent_data = gcc_parent_data_1,
268 .num_parents = ARRAY_SIZE(gcc_parent_data_1),
Taniya Das06391ed2018-05-07 16:20:20 +0530269 .ops = &clk_rcg2_ops,
270 },
271};
272
273static struct clk_rcg2 gcc_gp3_clk_src = {
274 .cmd_rcgr = 0x66004,
275 .mnd_width = 8,
276 .hid_width = 5,
277 .parent_map = gcc_parent_map_1,
278 .freq_tbl = ftbl_gcc_gp1_clk_src,
279 .clkr.hw.init = &(struct clk_init_data){
280 .name = "gcc_gp3_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300281 .parent_data = gcc_parent_data_1,
282 .num_parents = ARRAY_SIZE(gcc_parent_data_1),
Taniya Das06391ed2018-05-07 16:20:20 +0530283 .ops = &clk_rcg2_ops,
284 },
285};
286
287static const struct freq_tbl ftbl_gcc_pcie_0_aux_clk_src[] = {
288 F(9600000, P_BI_TCXO, 2, 0, 0),
289 F(19200000, P_BI_TCXO, 1, 0, 0),
290 { }
291};
292
293static struct clk_rcg2 gcc_pcie_0_aux_clk_src = {
294 .cmd_rcgr = 0x6b028,
295 .mnd_width = 16,
296 .hid_width = 5,
297 .parent_map = gcc_parent_map_2,
298 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src,
299 .clkr.hw.init = &(struct clk_init_data){
300 .name = "gcc_pcie_0_aux_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300301 .parent_data = gcc_parent_data_2,
302 .num_parents = ARRAY_SIZE(gcc_parent_data_2),
Taniya Das06391ed2018-05-07 16:20:20 +0530303 .ops = &clk_rcg2_ops,
304 },
305};
306
307static struct clk_rcg2 gcc_pcie_1_aux_clk_src = {
308 .cmd_rcgr = 0x8d028,
309 .mnd_width = 16,
310 .hid_width = 5,
311 .parent_map = gcc_parent_map_2,
312 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src,
313 .clkr.hw.init = &(struct clk_init_data){
314 .name = "gcc_pcie_1_aux_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300315 .parent_data = gcc_parent_data_2,
316 .num_parents = ARRAY_SIZE(gcc_parent_data_2),
Taniya Das06391ed2018-05-07 16:20:20 +0530317 .ops = &clk_rcg2_ops,
318 },
319};
320
321static const struct freq_tbl ftbl_gcc_pcie_phy_refgen_clk_src[] = {
322 F(19200000, P_BI_TCXO, 1, 0, 0),
323 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
324 { }
325};
326
327static struct clk_rcg2 gcc_pcie_phy_refgen_clk_src = {
328 .cmd_rcgr = 0x6f014,
329 .mnd_width = 0,
330 .hid_width = 5,
331 .parent_map = gcc_parent_map_0,
332 .freq_tbl = ftbl_gcc_pcie_phy_refgen_clk_src,
333 .clkr.hw.init = &(struct clk_init_data){
334 .name = "gcc_pcie_phy_refgen_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300335 .parent_data = gcc_parent_data_0,
336 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530337 .ops = &clk_rcg2_ops,
338 },
339};
340
Douglas Anderson4f83d9b2018-07-24 10:45:13 -0700341static const struct freq_tbl ftbl_gcc_qspi_core_clk_src[] = {
342 F(19200000, P_BI_TCXO, 1, 0, 0),
343 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
344 F(150000000, P_GPLL0_OUT_MAIN, 4, 0, 0),
345 F(300000000, P_GPLL0_OUT_MAIN, 2, 0, 0),
346 { }
347};
348
349static struct clk_rcg2 gcc_qspi_core_clk_src = {
350 .cmd_rcgr = 0x4b008,
351 .mnd_width = 0,
352 .hid_width = 5,
353 .parent_map = gcc_parent_map_0,
354 .freq_tbl = ftbl_gcc_qspi_core_clk_src,
355 .clkr.hw.init = &(struct clk_init_data){
356 .name = "gcc_qspi_core_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300357 .parent_data = gcc_parent_data_0,
358 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Douglas Anderson4f83d9b2018-07-24 10:45:13 -0700359 .ops = &clk_rcg2_floor_ops,
360 },
361};
362
Taniya Das06391ed2018-05-07 16:20:20 +0530363static const struct freq_tbl ftbl_gcc_pdm2_clk_src[] = {
364 F(9600000, P_BI_TCXO, 2, 0, 0),
365 F(19200000, P_BI_TCXO, 1, 0, 0),
366 F(60000000, P_GPLL0_OUT_MAIN, 10, 0, 0),
367 { }
368};
369
370static struct clk_rcg2 gcc_pdm2_clk_src = {
371 .cmd_rcgr = 0x33010,
372 .mnd_width = 0,
373 .hid_width = 5,
374 .parent_map = gcc_parent_map_0,
375 .freq_tbl = ftbl_gcc_pdm2_clk_src,
376 .clkr.hw.init = &(struct clk_init_data){
377 .name = "gcc_pdm2_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300378 .parent_data = gcc_parent_data_0,
379 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530380 .ops = &clk_rcg2_ops,
381 },
382};
383
384static const struct freq_tbl ftbl_gcc_qupv3_wrap0_s0_clk_src[] = {
385 F(7372800, P_GPLL0_OUT_EVEN, 1, 384, 15625),
386 F(14745600, P_GPLL0_OUT_EVEN, 1, 768, 15625),
387 F(19200000, P_BI_TCXO, 1, 0, 0),
388 F(29491200, P_GPLL0_OUT_EVEN, 1, 1536, 15625),
389 F(32000000, P_GPLL0_OUT_EVEN, 1, 8, 75),
390 F(48000000, P_GPLL0_OUT_EVEN, 1, 4, 25),
391 F(64000000, P_GPLL0_OUT_EVEN, 1, 16, 75),
392 F(80000000, P_GPLL0_OUT_EVEN, 1, 4, 15),
393 F(96000000, P_GPLL0_OUT_EVEN, 1, 8, 25),
394 F(100000000, P_GPLL0_OUT_EVEN, 3, 0, 0),
395 F(102400000, P_GPLL0_OUT_EVEN, 1, 128, 375),
396 F(112000000, P_GPLL0_OUT_EVEN, 1, 28, 75),
397 F(117964800, P_GPLL0_OUT_EVEN, 1, 6144, 15625),
398 F(120000000, P_GPLL0_OUT_EVEN, 2.5, 0, 0),
399 F(128000000, P_GPLL0_OUT_MAIN, 1, 16, 75),
400 { }
401};
402
Taniya Das1a1c7822019-10-14 15:53:04 +0530403static struct clk_init_data gcc_qupv3_wrap0_s0_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530404 .name = "gcc_qupv3_wrap0_s0_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300405 .parent_data = gcc_parent_data_0,
406 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530407 .ops = &clk_rcg2_shared_ops,
408};
409
Taniya Das06391ed2018-05-07 16:20:20 +0530410static struct clk_rcg2 gcc_qupv3_wrap0_s0_clk_src = {
411 .cmd_rcgr = 0x17034,
412 .mnd_width = 16,
413 .hid_width = 5,
414 .parent_map = gcc_parent_map_0,
415 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530416 .clkr.hw.init = &gcc_qupv3_wrap0_s0_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530417};
418
Taniya Das1a1c7822019-10-14 15:53:04 +0530419static struct clk_init_data gcc_qupv3_wrap0_s1_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530420 .name = "gcc_qupv3_wrap0_s1_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300421 .parent_data = gcc_parent_data_0,
422 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530423 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530424};
425
426static struct clk_rcg2 gcc_qupv3_wrap0_s1_clk_src = {
427 .cmd_rcgr = 0x17164,
428 .mnd_width = 16,
429 .hid_width = 5,
430 .parent_map = gcc_parent_map_0,
431 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530432 .clkr.hw.init = &gcc_qupv3_wrap0_s1_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530433};
434
Taniya Das1a1c7822019-10-14 15:53:04 +0530435static struct clk_init_data gcc_qupv3_wrap0_s2_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530436 .name = "gcc_qupv3_wrap0_s2_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300437 .parent_data = gcc_parent_data_0,
438 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530439 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530440};
441
442static struct clk_rcg2 gcc_qupv3_wrap0_s2_clk_src = {
443 .cmd_rcgr = 0x17294,
444 .mnd_width = 16,
445 .hid_width = 5,
446 .parent_map = gcc_parent_map_0,
447 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530448 .clkr.hw.init = &gcc_qupv3_wrap0_s2_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530449};
450
Taniya Das1a1c7822019-10-14 15:53:04 +0530451static struct clk_init_data gcc_qupv3_wrap0_s3_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530452 .name = "gcc_qupv3_wrap0_s3_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300453 .parent_data = gcc_parent_data_0,
454 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530455 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530456};
457
458static struct clk_rcg2 gcc_qupv3_wrap0_s3_clk_src = {
459 .cmd_rcgr = 0x173c4,
460 .mnd_width = 16,
461 .hid_width = 5,
462 .parent_map = gcc_parent_map_0,
463 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530464 .clkr.hw.init = &gcc_qupv3_wrap0_s3_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530465};
466
Taniya Das1a1c7822019-10-14 15:53:04 +0530467static struct clk_init_data gcc_qupv3_wrap0_s4_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530468 .name = "gcc_qupv3_wrap0_s4_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300469 .parent_data = gcc_parent_data_0,
470 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530471 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530472};
473
474static struct clk_rcg2 gcc_qupv3_wrap0_s4_clk_src = {
475 .cmd_rcgr = 0x174f4,
476 .mnd_width = 16,
477 .hid_width = 5,
478 .parent_map = gcc_parent_map_0,
479 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530480 .clkr.hw.init = &gcc_qupv3_wrap0_s4_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530481};
482
Taniya Das1a1c7822019-10-14 15:53:04 +0530483static struct clk_init_data gcc_qupv3_wrap0_s5_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530484 .name = "gcc_qupv3_wrap0_s5_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300485 .parent_data = gcc_parent_data_0,
486 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530487 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530488};
489
490static struct clk_rcg2 gcc_qupv3_wrap0_s5_clk_src = {
491 .cmd_rcgr = 0x17624,
492 .mnd_width = 16,
493 .hid_width = 5,
494 .parent_map = gcc_parent_map_0,
495 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530496 .clkr.hw.init = &gcc_qupv3_wrap0_s5_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530497};
498
Taniya Das1a1c7822019-10-14 15:53:04 +0530499static struct clk_init_data gcc_qupv3_wrap0_s6_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530500 .name = "gcc_qupv3_wrap0_s6_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300501 .parent_data = gcc_parent_data_0,
502 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530503 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530504};
505
506static struct clk_rcg2 gcc_qupv3_wrap0_s6_clk_src = {
507 .cmd_rcgr = 0x17754,
508 .mnd_width = 16,
509 .hid_width = 5,
510 .parent_map = gcc_parent_map_0,
511 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530512 .clkr.hw.init = &gcc_qupv3_wrap0_s6_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530513};
514
Taniya Das1a1c7822019-10-14 15:53:04 +0530515static struct clk_init_data gcc_qupv3_wrap0_s7_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530516 .name = "gcc_qupv3_wrap0_s7_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300517 .parent_data = gcc_parent_data_0,
518 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530519 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530520};
521
522static struct clk_rcg2 gcc_qupv3_wrap0_s7_clk_src = {
523 .cmd_rcgr = 0x17884,
524 .mnd_width = 16,
525 .hid_width = 5,
526 .parent_map = gcc_parent_map_0,
527 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530528 .clkr.hw.init = &gcc_qupv3_wrap0_s7_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530529};
530
Taniya Das1a1c7822019-10-14 15:53:04 +0530531static struct clk_init_data gcc_qupv3_wrap1_s0_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530532 .name = "gcc_qupv3_wrap1_s0_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300533 .parent_data = gcc_parent_data_0,
534 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530535 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530536};
537
538static struct clk_rcg2 gcc_qupv3_wrap1_s0_clk_src = {
539 .cmd_rcgr = 0x18018,
540 .mnd_width = 16,
541 .hid_width = 5,
542 .parent_map = gcc_parent_map_0,
543 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530544 .clkr.hw.init = &gcc_qupv3_wrap1_s0_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530545};
546
Taniya Das1a1c7822019-10-14 15:53:04 +0530547static struct clk_init_data gcc_qupv3_wrap1_s1_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530548 .name = "gcc_qupv3_wrap1_s1_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300549 .parent_data = gcc_parent_data_0,
550 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530551 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530552};
553
554static struct clk_rcg2 gcc_qupv3_wrap1_s1_clk_src = {
555 .cmd_rcgr = 0x18148,
556 .mnd_width = 16,
557 .hid_width = 5,
558 .parent_map = gcc_parent_map_0,
559 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530560 .clkr.hw.init = &gcc_qupv3_wrap1_s1_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530561};
562
Taniya Das1a1c7822019-10-14 15:53:04 +0530563static struct clk_init_data gcc_qupv3_wrap1_s2_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530564 .name = "gcc_qupv3_wrap1_s2_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300565 .parent_data = gcc_parent_data_0,
566 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530567 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530568};
569
570static struct clk_rcg2 gcc_qupv3_wrap1_s2_clk_src = {
571 .cmd_rcgr = 0x18278,
572 .mnd_width = 16,
573 .hid_width = 5,
574 .parent_map = gcc_parent_map_0,
575 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530576 .clkr.hw.init = &gcc_qupv3_wrap1_s2_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530577};
578
Taniya Das1a1c7822019-10-14 15:53:04 +0530579static struct clk_init_data gcc_qupv3_wrap1_s3_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530580 .name = "gcc_qupv3_wrap1_s3_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300581 .parent_data = gcc_parent_data_0,
582 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530583 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530584};
585
586static struct clk_rcg2 gcc_qupv3_wrap1_s3_clk_src = {
587 .cmd_rcgr = 0x183a8,
588 .mnd_width = 16,
589 .hid_width = 5,
590 .parent_map = gcc_parent_map_0,
591 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530592 .clkr.hw.init = &gcc_qupv3_wrap1_s3_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530593};
594
Taniya Das1a1c7822019-10-14 15:53:04 +0530595static struct clk_init_data gcc_qupv3_wrap1_s4_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530596 .name = "gcc_qupv3_wrap1_s4_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300597 .parent_data = gcc_parent_data_0,
598 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530599 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530600};
601
602static struct clk_rcg2 gcc_qupv3_wrap1_s4_clk_src = {
603 .cmd_rcgr = 0x184d8,
604 .mnd_width = 16,
605 .hid_width = 5,
606 .parent_map = gcc_parent_map_0,
607 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530608 .clkr.hw.init = &gcc_qupv3_wrap1_s4_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530609};
610
Taniya Das1a1c7822019-10-14 15:53:04 +0530611static struct clk_init_data gcc_qupv3_wrap1_s5_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530612 .name = "gcc_qupv3_wrap1_s5_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300613 .parent_data = gcc_parent_data_0,
614 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530615 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530616};
617
618static struct clk_rcg2 gcc_qupv3_wrap1_s5_clk_src = {
619 .cmd_rcgr = 0x18608,
620 .mnd_width = 16,
621 .hid_width = 5,
622 .parent_map = gcc_parent_map_0,
623 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530624 .clkr.hw.init = &gcc_qupv3_wrap1_s5_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530625};
626
Taniya Das1a1c7822019-10-14 15:53:04 +0530627static struct clk_init_data gcc_qupv3_wrap1_s6_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530628 .name = "gcc_qupv3_wrap1_s6_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300629 .parent_data = gcc_parent_data_0,
630 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530631 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530632};
633
634static struct clk_rcg2 gcc_qupv3_wrap1_s6_clk_src = {
635 .cmd_rcgr = 0x18738,
636 .mnd_width = 16,
637 .hid_width = 5,
638 .parent_map = gcc_parent_map_0,
639 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530640 .clkr.hw.init = &gcc_qupv3_wrap1_s6_clk_src_init,
Taniya Das8b69c6d2018-08-11 07:23:56 +0530641};
642
Taniya Das1a1c7822019-10-14 15:53:04 +0530643static struct clk_init_data gcc_qupv3_wrap1_s7_clk_src_init = {
Taniya Das8b69c6d2018-08-11 07:23:56 +0530644 .name = "gcc_qupv3_wrap1_s7_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300645 .parent_data = gcc_parent_data_0,
646 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das8b69c6d2018-08-11 07:23:56 +0530647 .ops = &clk_rcg2_shared_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530648};
649
650static struct clk_rcg2 gcc_qupv3_wrap1_s7_clk_src = {
651 .cmd_rcgr = 0x18868,
652 .mnd_width = 16,
653 .hid_width = 5,
654 .parent_map = gcc_parent_map_0,
655 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
Taniya Das1a1c7822019-10-14 15:53:04 +0530656 .clkr.hw.init = &gcc_qupv3_wrap1_s7_clk_src_init,
Taniya Das06391ed2018-05-07 16:20:20 +0530657};
658
659static const struct freq_tbl ftbl_gcc_sdcc2_apps_clk_src[] = {
660 F(400000, P_BI_TCXO, 12, 1, 4),
661 F(9600000, P_BI_TCXO, 2, 0, 0),
662 F(19200000, P_BI_TCXO, 1, 0, 0),
663 F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
664 F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
665 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
666 F(201500000, P_GPLL4_OUT_MAIN, 4, 0, 0),
667 { }
668};
669
670static struct clk_rcg2 gcc_sdcc2_apps_clk_src = {
671 .cmd_rcgr = 0x1400c,
672 .mnd_width = 8,
673 .hid_width = 5,
674 .parent_map = gcc_parent_map_10,
675 .freq_tbl = ftbl_gcc_sdcc2_apps_clk_src,
676 .clkr.hw.init = &(struct clk_init_data){
677 .name = "gcc_sdcc2_apps_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300678 .parent_data = gcc_parent_data_10,
679 .num_parents = ARRAY_SIZE(gcc_parent_data_10),
Stephen Boyd5e4b7e82019-08-30 12:51:42 -0700680 .ops = &clk_rcg2_floor_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530681 },
682};
683
684static const struct freq_tbl ftbl_gcc_sdcc4_apps_clk_src[] = {
685 F(400000, P_BI_TCXO, 12, 1, 4),
686 F(9600000, P_BI_TCXO, 2, 0, 0),
687 F(19200000, P_BI_TCXO, 1, 0, 0),
688 F(25000000, P_GPLL0_OUT_MAIN, 12, 1, 2),
689 F(50000000, P_GPLL0_OUT_MAIN, 12, 0, 0),
690 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
691 { }
692};
693
694static struct clk_rcg2 gcc_sdcc4_apps_clk_src = {
695 .cmd_rcgr = 0x1600c,
696 .mnd_width = 8,
697 .hid_width = 5,
698 .parent_map = gcc_parent_map_0,
699 .freq_tbl = ftbl_gcc_sdcc4_apps_clk_src,
700 .clkr.hw.init = &(struct clk_init_data){
701 .name = "gcc_sdcc4_apps_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300702 .parent_data = gcc_parent_data_0,
703 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Stephen Boyd5e4b7e82019-08-30 12:51:42 -0700704 .ops = &clk_rcg2_floor_ops,
Taniya Das06391ed2018-05-07 16:20:20 +0530705 },
706};
707
708static const struct freq_tbl ftbl_gcc_tsif_ref_clk_src[] = {
709 F(105495, P_BI_TCXO, 2, 1, 91),
710 { }
711};
712
713static struct clk_rcg2 gcc_tsif_ref_clk_src = {
714 .cmd_rcgr = 0x36010,
715 .mnd_width = 8,
716 .hid_width = 5,
717 .parent_map = gcc_parent_map_6,
718 .freq_tbl = ftbl_gcc_tsif_ref_clk_src,
719 .clkr.hw.init = &(struct clk_init_data){
720 .name = "gcc_tsif_ref_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300721 .parent_data = gcc_parent_data_6,
722 .num_parents = ARRAY_SIZE(gcc_parent_data_6),
Taniya Das06391ed2018-05-07 16:20:20 +0530723 .ops = &clk_rcg2_ops,
724 },
725};
726
727static const struct freq_tbl ftbl_gcc_ufs_card_axi_clk_src[] = {
728 F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
729 F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
730 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
731 F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
732 F(240000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0),
733 { }
734};
735
736static struct clk_rcg2 gcc_ufs_card_axi_clk_src = {
737 .cmd_rcgr = 0x7501c,
738 .mnd_width = 8,
739 .hid_width = 5,
740 .parent_map = gcc_parent_map_0,
741 .freq_tbl = ftbl_gcc_ufs_card_axi_clk_src,
742 .clkr.hw.init = &(struct clk_init_data){
743 .name = "gcc_ufs_card_axi_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300744 .parent_data = gcc_parent_data_0,
745 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530746 .ops = &clk_rcg2_shared_ops,
747 },
748};
749
750static const struct freq_tbl ftbl_gcc_ufs_card_ice_core_clk_src[] = {
751 F(37500000, P_GPLL0_OUT_EVEN, 8, 0, 0),
752 F(75000000, P_GPLL0_OUT_EVEN, 4, 0, 0),
753 F(150000000, P_GPLL0_OUT_MAIN, 4, 0, 0),
754 F(300000000, P_GPLL0_OUT_MAIN, 2, 0, 0),
755 { }
756};
757
758static struct clk_rcg2 gcc_ufs_card_ice_core_clk_src = {
759 .cmd_rcgr = 0x7505c,
760 .mnd_width = 0,
761 .hid_width = 5,
762 .parent_map = gcc_parent_map_0,
763 .freq_tbl = ftbl_gcc_ufs_card_ice_core_clk_src,
764 .clkr.hw.init = &(struct clk_init_data){
765 .name = "gcc_ufs_card_ice_core_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300766 .parent_data = gcc_parent_data_0,
767 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530768 .ops = &clk_rcg2_shared_ops,
769 },
770};
771
772static struct clk_rcg2 gcc_ufs_card_phy_aux_clk_src = {
773 .cmd_rcgr = 0x75090,
774 .mnd_width = 0,
775 .hid_width = 5,
776 .parent_map = gcc_parent_map_4,
777 .freq_tbl = ftbl_gcc_cpuss_rbcpr_clk_src,
778 .clkr.hw.init = &(struct clk_init_data){
779 .name = "gcc_ufs_card_phy_aux_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300780 .parent_data = gcc_parent_data_4,
781 .num_parents = ARRAY_SIZE(gcc_parent_data_4),
Taniya Das06391ed2018-05-07 16:20:20 +0530782 .ops = &clk_rcg2_ops,
783 },
784};
785
786static const struct freq_tbl ftbl_gcc_ufs_card_unipro_core_clk_src[] = {
787 F(37500000, P_GPLL0_OUT_EVEN, 8, 0, 0),
788 F(75000000, P_GPLL0_OUT_MAIN, 8, 0, 0),
789 F(150000000, P_GPLL0_OUT_MAIN, 4, 0, 0),
790 { }
791};
792
793static struct clk_rcg2 gcc_ufs_card_unipro_core_clk_src = {
794 .cmd_rcgr = 0x75074,
795 .mnd_width = 0,
796 .hid_width = 5,
797 .parent_map = gcc_parent_map_0,
798 .freq_tbl = ftbl_gcc_ufs_card_unipro_core_clk_src,
799 .clkr.hw.init = &(struct clk_init_data){
800 .name = "gcc_ufs_card_unipro_core_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300801 .parent_data = gcc_parent_data_0,
802 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530803 .ops = &clk_rcg2_shared_ops,
804 },
805};
806
807static const struct freq_tbl ftbl_gcc_ufs_phy_axi_clk_src[] = {
808 F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
809 F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
810 F(100000000, P_GPLL0_OUT_MAIN, 6, 0, 0),
811 F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
812 F(240000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0),
813 { }
814};
815
816static struct clk_rcg2 gcc_ufs_phy_axi_clk_src = {
817 .cmd_rcgr = 0x7701c,
818 .mnd_width = 8,
819 .hid_width = 5,
820 .parent_map = gcc_parent_map_0,
821 .freq_tbl = ftbl_gcc_ufs_phy_axi_clk_src,
822 .clkr.hw.init = &(struct clk_init_data){
823 .name = "gcc_ufs_phy_axi_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300824 .parent_data = gcc_parent_data_0,
825 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530826 .ops = &clk_rcg2_shared_ops,
827 },
828};
829
830static struct clk_rcg2 gcc_ufs_phy_ice_core_clk_src = {
831 .cmd_rcgr = 0x7705c,
832 .mnd_width = 0,
833 .hid_width = 5,
834 .parent_map = gcc_parent_map_0,
835 .freq_tbl = ftbl_gcc_ufs_card_ice_core_clk_src,
836 .clkr.hw.init = &(struct clk_init_data){
837 .name = "gcc_ufs_phy_ice_core_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300838 .parent_data = gcc_parent_data_0,
839 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530840 .ops = &clk_rcg2_shared_ops,
841 },
842};
843
844static struct clk_rcg2 gcc_ufs_phy_phy_aux_clk_src = {
845 .cmd_rcgr = 0x77090,
846 .mnd_width = 0,
847 .hid_width = 5,
848 .parent_map = gcc_parent_map_4,
849 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src,
850 .clkr.hw.init = &(struct clk_init_data){
851 .name = "gcc_ufs_phy_phy_aux_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300852 .parent_data = gcc_parent_data_4,
853 .num_parents = ARRAY_SIZE(gcc_parent_data_4),
Taniya Das06391ed2018-05-07 16:20:20 +0530854 .ops = &clk_rcg2_shared_ops,
855 },
856};
857
858static struct clk_rcg2 gcc_ufs_phy_unipro_core_clk_src = {
859 .cmd_rcgr = 0x77074,
860 .mnd_width = 0,
861 .hid_width = 5,
862 .parent_map = gcc_parent_map_0,
863 .freq_tbl = ftbl_gcc_ufs_card_unipro_core_clk_src,
864 .clkr.hw.init = &(struct clk_init_data){
865 .name = "gcc_ufs_phy_unipro_core_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300866 .parent_data = gcc_parent_data_0,
867 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530868 .ops = &clk_rcg2_shared_ops,
869 },
870};
871
872static const struct freq_tbl ftbl_gcc_usb30_prim_master_clk_src[] = {
873 F(33333333, P_GPLL0_OUT_EVEN, 9, 0, 0),
874 F(66666667, P_GPLL0_OUT_EVEN, 4.5, 0, 0),
875 F(133333333, P_GPLL0_OUT_MAIN, 4.5, 0, 0),
876 F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
877 F(240000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0),
878 { }
879};
880
881static struct clk_rcg2 gcc_usb30_prim_master_clk_src = {
882 .cmd_rcgr = 0xf018,
883 .mnd_width = 8,
884 .hid_width = 5,
885 .parent_map = gcc_parent_map_0,
886 .freq_tbl = ftbl_gcc_usb30_prim_master_clk_src,
887 .clkr.hw.init = &(struct clk_init_data){
888 .name = "gcc_usb30_prim_master_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300889 .parent_data = gcc_parent_data_0,
890 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530891 .ops = &clk_rcg2_shared_ops,
892 },
893};
894
895static const struct freq_tbl ftbl_gcc_usb30_prim_mock_utmi_clk_src[] = {
896 F(19200000, P_BI_TCXO, 1, 0, 0),
897 F(20000000, P_GPLL0_OUT_EVEN, 15, 0, 0),
898 F(40000000, P_GPLL0_OUT_EVEN, 7.5, 0, 0),
899 F(60000000, P_GPLL0_OUT_MAIN, 10, 0, 0),
900 { }
901};
902
903static struct clk_rcg2 gcc_usb30_prim_mock_utmi_clk_src = {
904 .cmd_rcgr = 0xf030,
905 .mnd_width = 0,
906 .hid_width = 5,
907 .parent_map = gcc_parent_map_0,
908 .freq_tbl = ftbl_gcc_usb30_prim_mock_utmi_clk_src,
909 .clkr.hw.init = &(struct clk_init_data){
910 .name = "gcc_usb30_prim_mock_utmi_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300911 .parent_data = gcc_parent_data_0,
912 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530913 .ops = &clk_rcg2_shared_ops,
914 },
915};
916
917static struct clk_rcg2 gcc_usb30_sec_master_clk_src = {
918 .cmd_rcgr = 0x10018,
919 .mnd_width = 8,
920 .hid_width = 5,
921 .parent_map = gcc_parent_map_0,
922 .freq_tbl = ftbl_gcc_usb30_prim_master_clk_src,
923 .clkr.hw.init = &(struct clk_init_data){
924 .name = "gcc_usb30_sec_master_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300925 .parent_data = gcc_parent_data_0,
926 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530927 .ops = &clk_rcg2_ops,
928 },
929};
930
931static struct clk_rcg2 gcc_usb30_sec_mock_utmi_clk_src = {
932 .cmd_rcgr = 0x10030,
933 .mnd_width = 0,
934 .hid_width = 5,
935 .parent_map = gcc_parent_map_0,
936 .freq_tbl = ftbl_gcc_usb30_prim_mock_utmi_clk_src,
937 .clkr.hw.init = &(struct clk_init_data){
938 .name = "gcc_usb30_sec_mock_utmi_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300939 .parent_data = gcc_parent_data_0,
940 .num_parents = ARRAY_SIZE(gcc_parent_data_0),
Taniya Das06391ed2018-05-07 16:20:20 +0530941 .ops = &clk_rcg2_ops,
942 },
943};
944
945static struct clk_rcg2 gcc_usb3_prim_phy_aux_clk_src = {
946 .cmd_rcgr = 0xf05c,
947 .mnd_width = 0,
948 .hid_width = 5,
949 .parent_map = gcc_parent_map_2,
950 .freq_tbl = ftbl_gcc_cpuss_rbcpr_clk_src,
951 .clkr.hw.init = &(struct clk_init_data){
952 .name = "gcc_usb3_prim_phy_aux_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300953 .parent_data = gcc_parent_data_2,
954 .num_parents = ARRAY_SIZE(gcc_parent_data_2),
Taniya Das06391ed2018-05-07 16:20:20 +0530955 .ops = &clk_rcg2_ops,
956 },
957};
958
959static struct clk_rcg2 gcc_usb3_sec_phy_aux_clk_src = {
960 .cmd_rcgr = 0x1005c,
961 .mnd_width = 0,
962 .hid_width = 5,
963 .parent_map = gcc_parent_map_2,
964 .freq_tbl = ftbl_gcc_cpuss_rbcpr_clk_src,
965 .clkr.hw.init = &(struct clk_init_data){
966 .name = "gcc_usb3_sec_phy_aux_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300967 .parent_data = gcc_parent_data_2,
968 .num_parents = ARRAY_SIZE(gcc_parent_data_2),
Taniya Das06391ed2018-05-07 16:20:20 +0530969 .ops = &clk_rcg2_shared_ops,
970 },
971};
972
973static struct clk_rcg2 gcc_vs_ctrl_clk_src = {
974 .cmd_rcgr = 0x7a030,
975 .mnd_width = 0,
976 .hid_width = 5,
977 .parent_map = gcc_parent_map_3,
978 .freq_tbl = ftbl_gcc_cpuss_rbcpr_clk_src,
979 .clkr.hw.init = &(struct clk_init_data){
980 .name = "gcc_vs_ctrl_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +0300981 .parent_data = gcc_parent_data_3,
982 .num_parents = ARRAY_SIZE(gcc_parent_data_3),
Taniya Das06391ed2018-05-07 16:20:20 +0530983 .ops = &clk_rcg2_ops,
984 },
985};
986
987static const struct freq_tbl ftbl_gcc_vsensor_clk_src[] = {
988 F(19200000, P_BI_TCXO, 1, 0, 0),
989 F(300000000, P_GPLL0_OUT_MAIN, 2, 0, 0),
990 F(600000000, P_GPLL0_OUT_MAIN, 1, 0, 0),
991 { }
992};
993
994static struct clk_rcg2 gcc_vsensor_clk_src = {
995 .cmd_rcgr = 0x7a018,
996 .mnd_width = 0,
997 .hid_width = 5,
998 .parent_map = gcc_parent_map_3,
999 .freq_tbl = ftbl_gcc_vsensor_clk_src,
1000 .clkr.hw.init = &(struct clk_init_data){
1001 .name = "gcc_vsensor_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001002 .parent_data = gcc_parent_data_8,
1003 .num_parents = ARRAY_SIZE(gcc_parent_data_8),
Taniya Das06391ed2018-05-07 16:20:20 +05301004 .ops = &clk_rcg2_ops,
1005 },
1006};
1007
1008static struct clk_branch gcc_aggre_noc_pcie_tbu_clk = {
1009 .halt_reg = 0x90014,
1010 .halt_check = BRANCH_HALT,
1011 .clkr = {
1012 .enable_reg = 0x90014,
1013 .enable_mask = BIT(0),
1014 .hw.init = &(struct clk_init_data){
1015 .name = "gcc_aggre_noc_pcie_tbu_clk",
1016 .ops = &clk_branch2_ops,
1017 },
1018 },
1019};
1020
1021static struct clk_branch gcc_aggre_ufs_card_axi_clk = {
1022 .halt_reg = 0x82028,
1023 .halt_check = BRANCH_HALT,
1024 .hwcg_reg = 0x82028,
1025 .hwcg_bit = 1,
1026 .clkr = {
1027 .enable_reg = 0x82028,
1028 .enable_mask = BIT(0),
1029 .hw.init = &(struct clk_init_data){
1030 .name = "gcc_aggre_ufs_card_axi_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001031 .parent_hws = (const struct clk_hw*[]){
1032 &gcc_ufs_card_axi_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301033 },
1034 .num_parents = 1,
1035 .flags = CLK_SET_RATE_PARENT,
1036 .ops = &clk_branch2_ops,
1037 },
1038 },
1039};
1040
1041static struct clk_branch gcc_aggre_ufs_phy_axi_clk = {
1042 .halt_reg = 0x82024,
1043 .halt_check = BRANCH_HALT,
1044 .hwcg_reg = 0x82024,
1045 .hwcg_bit = 1,
1046 .clkr = {
1047 .enable_reg = 0x82024,
1048 .enable_mask = BIT(0),
1049 .hw.init = &(struct clk_init_data){
1050 .name = "gcc_aggre_ufs_phy_axi_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001051 .parent_hws = (const struct clk_hw*[]){
1052 &gcc_ufs_phy_axi_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301053 },
1054 .num_parents = 1,
1055 .flags = CLK_SET_RATE_PARENT,
1056 .ops = &clk_branch2_ops,
1057 },
1058 },
1059};
1060
1061static struct clk_branch gcc_aggre_usb3_prim_axi_clk = {
1062 .halt_reg = 0x8201c,
1063 .halt_check = BRANCH_HALT,
1064 .clkr = {
1065 .enable_reg = 0x8201c,
1066 .enable_mask = BIT(0),
1067 .hw.init = &(struct clk_init_data){
1068 .name = "gcc_aggre_usb3_prim_axi_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001069 .parent_hws = (const struct clk_hw*[]){
1070 &gcc_usb30_prim_master_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301071 },
1072 .num_parents = 1,
1073 .flags = CLK_SET_RATE_PARENT,
1074 .ops = &clk_branch2_ops,
1075 },
1076 },
1077};
1078
1079static struct clk_branch gcc_aggre_usb3_sec_axi_clk = {
1080 .halt_reg = 0x82020,
1081 .halt_check = BRANCH_HALT,
1082 .clkr = {
1083 .enable_reg = 0x82020,
1084 .enable_mask = BIT(0),
1085 .hw.init = &(struct clk_init_data){
1086 .name = "gcc_aggre_usb3_sec_axi_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001087 .parent_hws = (const struct clk_hw*[]){
1088 &gcc_usb30_sec_master_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301089 },
1090 .num_parents = 1,
1091 .flags = CLK_SET_RATE_PARENT,
1092 .ops = &clk_branch2_ops,
1093 },
1094 },
1095};
1096
1097static struct clk_branch gcc_apc_vs_clk = {
1098 .halt_reg = 0x7a050,
1099 .halt_check = BRANCH_HALT,
1100 .clkr = {
1101 .enable_reg = 0x7a050,
1102 .enable_mask = BIT(0),
1103 .hw.init = &(struct clk_init_data){
1104 .name = "gcc_apc_vs_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001105 .parent_hws = (const struct clk_hw*[]){
1106 &gcc_vsensor_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301107 },
1108 .num_parents = 1,
1109 .flags = CLK_SET_RATE_PARENT,
1110 .ops = &clk_branch2_ops,
1111 },
1112 },
1113};
1114
1115static struct clk_branch gcc_boot_rom_ahb_clk = {
1116 .halt_reg = 0x38004,
1117 .halt_check = BRANCH_HALT_VOTED,
1118 .hwcg_reg = 0x38004,
1119 .hwcg_bit = 1,
1120 .clkr = {
1121 .enable_reg = 0x52004,
1122 .enable_mask = BIT(10),
1123 .hw.init = &(struct clk_init_data){
1124 .name = "gcc_boot_rom_ahb_clk",
1125 .ops = &clk_branch2_ops,
1126 },
1127 },
1128};
1129
1130static struct clk_branch gcc_camera_ahb_clk = {
1131 .halt_reg = 0xb008,
1132 .halt_check = BRANCH_HALT,
1133 .hwcg_reg = 0xb008,
1134 .hwcg_bit = 1,
1135 .clkr = {
1136 .enable_reg = 0xb008,
1137 .enable_mask = BIT(0),
1138 .hw.init = &(struct clk_init_data){
1139 .name = "gcc_camera_ahb_clk",
Amit Nischalcfb82822018-06-11 12:08:15 +05301140 .flags = CLK_IS_CRITICAL,
Taniya Das06391ed2018-05-07 16:20:20 +05301141 .ops = &clk_branch2_ops,
1142 },
1143 },
1144};
1145
1146static struct clk_branch gcc_camera_axi_clk = {
1147 .halt_reg = 0xb020,
1148 .halt_check = BRANCH_VOTED,
1149 .clkr = {
1150 .enable_reg = 0xb020,
1151 .enable_mask = BIT(0),
1152 .hw.init = &(struct clk_init_data){
1153 .name = "gcc_camera_axi_clk",
1154 .ops = &clk_branch2_ops,
1155 },
1156 },
1157};
1158
1159static struct clk_branch gcc_camera_xo_clk = {
1160 .halt_reg = 0xb02c,
1161 .halt_check = BRANCH_HALT,
1162 .clkr = {
1163 .enable_reg = 0xb02c,
1164 .enable_mask = BIT(0),
1165 .hw.init = &(struct clk_init_data){
1166 .name = "gcc_camera_xo_clk",
Amit Nischalcfb82822018-06-11 12:08:15 +05301167 .flags = CLK_IS_CRITICAL,
Taniya Das06391ed2018-05-07 16:20:20 +05301168 .ops = &clk_branch2_ops,
1169 },
1170 },
1171};
1172
1173static struct clk_branch gcc_ce1_ahb_clk = {
1174 .halt_reg = 0x4100c,
1175 .halt_check = BRANCH_HALT_VOTED,
1176 .hwcg_reg = 0x4100c,
1177 .hwcg_bit = 1,
1178 .clkr = {
1179 .enable_reg = 0x52004,
1180 .enable_mask = BIT(3),
1181 .hw.init = &(struct clk_init_data){
1182 .name = "gcc_ce1_ahb_clk",
1183 .ops = &clk_branch2_ops,
1184 },
1185 },
1186};
1187
1188static struct clk_branch gcc_ce1_axi_clk = {
1189 .halt_reg = 0x41008,
1190 .halt_check = BRANCH_HALT_VOTED,
1191 .clkr = {
1192 .enable_reg = 0x52004,
1193 .enable_mask = BIT(4),
1194 .hw.init = &(struct clk_init_data){
1195 .name = "gcc_ce1_axi_clk",
1196 .ops = &clk_branch2_ops,
1197 },
1198 },
1199};
1200
1201static struct clk_branch gcc_ce1_clk = {
1202 .halt_reg = 0x41004,
1203 .halt_check = BRANCH_HALT_VOTED,
1204 .clkr = {
1205 .enable_reg = 0x52004,
1206 .enable_mask = BIT(5),
1207 .hw.init = &(struct clk_init_data){
1208 .name = "gcc_ce1_clk",
1209 .ops = &clk_branch2_ops,
1210 },
1211 },
1212};
1213
1214static struct clk_branch gcc_cfg_noc_usb3_prim_axi_clk = {
1215 .halt_reg = 0x502c,
1216 .halt_check = BRANCH_HALT,
1217 .clkr = {
1218 .enable_reg = 0x502c,
1219 .enable_mask = BIT(0),
1220 .hw.init = &(struct clk_init_data){
1221 .name = "gcc_cfg_noc_usb3_prim_axi_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001222 .parent_hws = (const struct clk_hw*[]){
1223 &gcc_usb30_prim_master_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301224 },
1225 .num_parents = 1,
1226 .flags = CLK_SET_RATE_PARENT,
1227 .ops = &clk_branch2_ops,
1228 },
1229 },
1230};
1231
1232static struct clk_branch gcc_cfg_noc_usb3_sec_axi_clk = {
1233 .halt_reg = 0x5030,
1234 .halt_check = BRANCH_HALT,
1235 .clkr = {
1236 .enable_reg = 0x5030,
1237 .enable_mask = BIT(0),
1238 .hw.init = &(struct clk_init_data){
1239 .name = "gcc_cfg_noc_usb3_sec_axi_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001240 .parent_hws = (const struct clk_hw*[]){
1241 &gcc_usb30_sec_master_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301242 },
1243 .num_parents = 1,
1244 .flags = CLK_SET_RATE_PARENT,
1245 .ops = &clk_branch2_ops,
1246 },
1247 },
1248};
1249
1250static struct clk_branch gcc_cpuss_ahb_clk = {
1251 .halt_reg = 0x48000,
1252 .halt_check = BRANCH_HALT_VOTED,
1253 .clkr = {
1254 .enable_reg = 0x52004,
1255 .enable_mask = BIT(21),
1256 .hw.init = &(struct clk_init_data){
1257 .name = "gcc_cpuss_ahb_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001258 .parent_hws = (const struct clk_hw*[]){
1259 &gcc_cpuss_ahb_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301260 },
1261 .num_parents = 1,
1262 .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
1263 .ops = &clk_branch2_ops,
1264 },
1265 },
1266};
1267
1268static struct clk_branch gcc_cpuss_rbcpr_clk = {
1269 .halt_reg = 0x48008,
1270 .halt_check = BRANCH_HALT,
1271 .clkr = {
1272 .enable_reg = 0x48008,
1273 .enable_mask = BIT(0),
1274 .hw.init = &(struct clk_init_data){
1275 .name = "gcc_cpuss_rbcpr_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001276 .parent_hws = (const struct clk_hw*[]){
1277 &gcc_cpuss_rbcpr_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301278 },
1279 .num_parents = 1,
1280 .flags = CLK_SET_RATE_PARENT,
1281 .ops = &clk_branch2_ops,
1282 },
1283 },
1284};
1285
1286static struct clk_branch gcc_ddrss_gpu_axi_clk = {
1287 .halt_reg = 0x44038,
1288 .halt_check = BRANCH_VOTED,
1289 .clkr = {
1290 .enable_reg = 0x44038,
1291 .enable_mask = BIT(0),
1292 .hw.init = &(struct clk_init_data){
1293 .name = "gcc_ddrss_gpu_axi_clk",
1294 .ops = &clk_branch2_ops,
1295 },
1296 },
1297};
1298
1299static struct clk_branch gcc_disp_ahb_clk = {
1300 .halt_reg = 0xb00c,
1301 .halt_check = BRANCH_HALT,
1302 .hwcg_reg = 0xb00c,
1303 .hwcg_bit = 1,
1304 .clkr = {
1305 .enable_reg = 0xb00c,
1306 .enable_mask = BIT(0),
1307 .hw.init = &(struct clk_init_data){
1308 .name = "gcc_disp_ahb_clk",
Amit Nischalcfb82822018-06-11 12:08:15 +05301309 .flags = CLK_IS_CRITICAL,
Taniya Das06391ed2018-05-07 16:20:20 +05301310 .ops = &clk_branch2_ops,
1311 },
1312 },
1313};
1314
1315static struct clk_branch gcc_disp_axi_clk = {
1316 .halt_reg = 0xb024,
1317 .halt_check = BRANCH_VOTED,
1318 .clkr = {
1319 .enable_reg = 0xb024,
1320 .enable_mask = BIT(0),
1321 .hw.init = &(struct clk_init_data){
1322 .name = "gcc_disp_axi_clk",
1323 .ops = &clk_branch2_ops,
1324 },
1325 },
1326};
1327
1328static struct clk_branch gcc_disp_gpll0_clk_src = {
1329 .halt_check = BRANCH_HALT_DELAY,
1330 .clkr = {
1331 .enable_reg = 0x52004,
1332 .enable_mask = BIT(18),
1333 .hw.init = &(struct clk_init_data){
1334 .name = "gcc_disp_gpll0_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001335 .parent_hws = (const struct clk_hw*[]){
1336 &gpll0.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301337 },
1338 .num_parents = 1,
Taniya Das9c3df2b2020-07-15 12:24:10 +05301339 .ops = &clk_branch2_aon_ops,
Taniya Das06391ed2018-05-07 16:20:20 +05301340 },
1341 },
1342};
1343
1344static struct clk_branch gcc_disp_gpll0_div_clk_src = {
1345 .halt_check = BRANCH_HALT_DELAY,
1346 .clkr = {
1347 .enable_reg = 0x52004,
1348 .enable_mask = BIT(19),
1349 .hw.init = &(struct clk_init_data){
1350 .name = "gcc_disp_gpll0_div_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001351 .parent_hws = (const struct clk_hw*[]){
1352 &gpll0_out_even.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301353 },
1354 .num_parents = 1,
1355 .ops = &clk_branch2_ops,
1356 },
1357 },
1358};
1359
1360static struct clk_branch gcc_disp_xo_clk = {
1361 .halt_reg = 0xb030,
1362 .halt_check = BRANCH_HALT,
1363 .clkr = {
1364 .enable_reg = 0xb030,
1365 .enable_mask = BIT(0),
1366 .hw.init = &(struct clk_init_data){
1367 .name = "gcc_disp_xo_clk",
Amit Nischalcfb82822018-06-11 12:08:15 +05301368 .flags = CLK_IS_CRITICAL,
Taniya Das06391ed2018-05-07 16:20:20 +05301369 .ops = &clk_branch2_ops,
1370 },
1371 },
1372};
1373
1374static struct clk_branch gcc_gp1_clk = {
1375 .halt_reg = 0x64000,
1376 .halt_check = BRANCH_HALT,
1377 .clkr = {
1378 .enable_reg = 0x64000,
1379 .enable_mask = BIT(0),
1380 .hw.init = &(struct clk_init_data){
1381 .name = "gcc_gp1_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001382 .parent_hws = (const struct clk_hw*[]){
1383 &gcc_gp1_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301384 },
1385 .num_parents = 1,
1386 .flags = CLK_SET_RATE_PARENT,
1387 .ops = &clk_branch2_ops,
1388 },
1389 },
1390};
1391
1392static struct clk_branch gcc_gp2_clk = {
1393 .halt_reg = 0x65000,
1394 .halt_check = BRANCH_HALT,
1395 .clkr = {
1396 .enable_reg = 0x65000,
1397 .enable_mask = BIT(0),
1398 .hw.init = &(struct clk_init_data){
1399 .name = "gcc_gp2_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001400 .parent_hws = (const struct clk_hw*[]){
1401 &gcc_gp2_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301402 },
1403 .num_parents = 1,
1404 .flags = CLK_SET_RATE_PARENT,
1405 .ops = &clk_branch2_ops,
1406 },
1407 },
1408};
1409
1410static struct clk_branch gcc_gp3_clk = {
1411 .halt_reg = 0x66000,
1412 .halt_check = BRANCH_HALT,
1413 .clkr = {
1414 .enable_reg = 0x66000,
1415 .enable_mask = BIT(0),
1416 .hw.init = &(struct clk_init_data){
1417 .name = "gcc_gp3_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001418 .parent_hws = (const struct clk_hw*[]){
1419 &gcc_gp3_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301420 },
1421 .num_parents = 1,
1422 .flags = CLK_SET_RATE_PARENT,
1423 .ops = &clk_branch2_ops,
1424 },
1425 },
1426};
1427
1428static struct clk_branch gcc_gpu_cfg_ahb_clk = {
1429 .halt_reg = 0x71004,
1430 .halt_check = BRANCH_HALT,
1431 .hwcg_reg = 0x71004,
1432 .hwcg_bit = 1,
1433 .clkr = {
1434 .enable_reg = 0x71004,
1435 .enable_mask = BIT(0),
1436 .hw.init = &(struct clk_init_data){
1437 .name = "gcc_gpu_cfg_ahb_clk",
Amit Nischalcfb82822018-06-11 12:08:15 +05301438 .flags = CLK_IS_CRITICAL,
Taniya Das06391ed2018-05-07 16:20:20 +05301439 .ops = &clk_branch2_ops,
1440 },
1441 },
1442};
1443
1444static struct clk_branch gcc_gpu_gpll0_clk_src = {
1445 .halt_check = BRANCH_HALT_DELAY,
1446 .clkr = {
1447 .enable_reg = 0x52004,
1448 .enable_mask = BIT(15),
1449 .hw.init = &(struct clk_init_data){
1450 .name = "gcc_gpu_gpll0_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001451 .parent_hws = (const struct clk_hw*[]){
1452 &gpll0.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301453 },
1454 .num_parents = 1,
1455 .ops = &clk_branch2_ops,
1456 },
1457 },
1458};
1459
1460static struct clk_branch gcc_gpu_gpll0_div_clk_src = {
1461 .halt_check = BRANCH_HALT_DELAY,
1462 .clkr = {
1463 .enable_reg = 0x52004,
1464 .enable_mask = BIT(16),
1465 .hw.init = &(struct clk_init_data){
1466 .name = "gcc_gpu_gpll0_div_clk_src",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001467 .parent_hws = (const struct clk_hw*[]){
1468 &gpll0_out_even.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301469 },
1470 .num_parents = 1,
1471 .ops = &clk_branch2_ops,
1472 },
1473 },
1474};
1475
1476static struct clk_branch gcc_gpu_iref_clk = {
1477 .halt_reg = 0x8c010,
1478 .halt_check = BRANCH_HALT,
1479 .clkr = {
1480 .enable_reg = 0x8c010,
1481 .enable_mask = BIT(0),
1482 .hw.init = &(struct clk_init_data){
1483 .name = "gcc_gpu_iref_clk",
1484 .ops = &clk_branch2_ops,
1485 },
1486 },
1487};
1488
1489static struct clk_branch gcc_gpu_memnoc_gfx_clk = {
1490 .halt_reg = 0x7100c,
1491 .halt_check = BRANCH_VOTED,
1492 .clkr = {
1493 .enable_reg = 0x7100c,
1494 .enable_mask = BIT(0),
1495 .hw.init = &(struct clk_init_data){
1496 .name = "gcc_gpu_memnoc_gfx_clk",
1497 .ops = &clk_branch2_ops,
1498 },
1499 },
1500};
1501
1502static struct clk_branch gcc_gpu_snoc_dvm_gfx_clk = {
1503 .halt_reg = 0x71018,
1504 .halt_check = BRANCH_HALT,
1505 .clkr = {
1506 .enable_reg = 0x71018,
1507 .enable_mask = BIT(0),
1508 .hw.init = &(struct clk_init_data){
1509 .name = "gcc_gpu_snoc_dvm_gfx_clk",
1510 .ops = &clk_branch2_ops,
1511 },
1512 },
1513};
1514
1515static struct clk_branch gcc_gpu_vs_clk = {
1516 .halt_reg = 0x7a04c,
1517 .halt_check = BRANCH_HALT,
1518 .clkr = {
1519 .enable_reg = 0x7a04c,
1520 .enable_mask = BIT(0),
1521 .hw.init = &(struct clk_init_data){
1522 .name = "gcc_gpu_vs_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001523 .parent_hws = (const struct clk_hw*[]){
1524 &gcc_vsensor_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301525 },
1526 .num_parents = 1,
1527 .flags = CLK_SET_RATE_PARENT,
1528 .ops = &clk_branch2_ops,
1529 },
1530 },
1531};
1532
1533static struct clk_branch gcc_mss_axis2_clk = {
1534 .halt_reg = 0x8a008,
1535 .halt_check = BRANCH_HALT,
1536 .clkr = {
1537 .enable_reg = 0x8a008,
1538 .enable_mask = BIT(0),
1539 .hw.init = &(struct clk_init_data){
1540 .name = "gcc_mss_axis2_clk",
1541 .ops = &clk_branch2_ops,
1542 },
1543 },
1544};
1545
1546static struct clk_branch gcc_mss_cfg_ahb_clk = {
1547 .halt_reg = 0x8a000,
1548 .halt_check = BRANCH_HALT,
1549 .hwcg_reg = 0x8a000,
1550 .hwcg_bit = 1,
1551 .clkr = {
1552 .enable_reg = 0x8a000,
1553 .enable_mask = BIT(0),
1554 .hw.init = &(struct clk_init_data){
1555 .name = "gcc_mss_cfg_ahb_clk",
1556 .ops = &clk_branch2_ops,
1557 },
1558 },
1559};
1560
1561static struct clk_branch gcc_mss_gpll0_div_clk_src = {
1562 .halt_check = BRANCH_HALT_DELAY,
1563 .clkr = {
1564 .enable_reg = 0x52004,
1565 .enable_mask = BIT(17),
1566 .hw.init = &(struct clk_init_data){
1567 .name = "gcc_mss_gpll0_div_clk_src",
1568 .ops = &clk_branch2_ops,
1569 },
1570 },
1571};
1572
1573static struct clk_branch gcc_mss_mfab_axis_clk = {
1574 .halt_reg = 0x8a004,
1575 .halt_check = BRANCH_VOTED,
1576 .hwcg_reg = 0x8a004,
1577 .hwcg_bit = 1,
1578 .clkr = {
1579 .enable_reg = 0x8a004,
1580 .enable_mask = BIT(0),
1581 .hw.init = &(struct clk_init_data){
1582 .name = "gcc_mss_mfab_axis_clk",
1583 .ops = &clk_branch2_ops,
1584 },
1585 },
1586};
1587
1588static struct clk_branch gcc_mss_q6_memnoc_axi_clk = {
1589 .halt_reg = 0x8a154,
1590 .halt_check = BRANCH_VOTED,
1591 .clkr = {
1592 .enable_reg = 0x8a154,
1593 .enable_mask = BIT(0),
1594 .hw.init = &(struct clk_init_data){
1595 .name = "gcc_mss_q6_memnoc_axi_clk",
1596 .ops = &clk_branch2_ops,
1597 },
1598 },
1599};
1600
1601static struct clk_branch gcc_mss_snoc_axi_clk = {
1602 .halt_reg = 0x8a150,
1603 .halt_check = BRANCH_HALT,
1604 .clkr = {
1605 .enable_reg = 0x8a150,
1606 .enable_mask = BIT(0),
1607 .hw.init = &(struct clk_init_data){
1608 .name = "gcc_mss_snoc_axi_clk",
1609 .ops = &clk_branch2_ops,
1610 },
1611 },
1612};
1613
1614static struct clk_branch gcc_mss_vs_clk = {
1615 .halt_reg = 0x7a048,
1616 .halt_check = BRANCH_HALT,
1617 .clkr = {
1618 .enable_reg = 0x7a048,
1619 .enable_mask = BIT(0),
1620 .hw.init = &(struct clk_init_data){
1621 .name = "gcc_mss_vs_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001622 .parent_hws = (const struct clk_hw*[]){
1623 &gcc_vsensor_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301624 },
1625 .num_parents = 1,
1626 .flags = CLK_SET_RATE_PARENT,
1627 .ops = &clk_branch2_ops,
1628 },
1629 },
1630};
1631
1632static struct clk_branch gcc_pcie_0_aux_clk = {
1633 .halt_reg = 0x6b01c,
1634 .halt_check = BRANCH_HALT_VOTED,
1635 .clkr = {
1636 .enable_reg = 0x5200c,
1637 .enable_mask = BIT(3),
1638 .hw.init = &(struct clk_init_data){
1639 .name = "gcc_pcie_0_aux_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001640 .parent_hws = (const struct clk_hw*[]){
1641 &gcc_pcie_0_aux_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301642 },
1643 .num_parents = 1,
1644 .flags = CLK_SET_RATE_PARENT,
1645 .ops = &clk_branch2_ops,
1646 },
1647 },
1648};
1649
1650static struct clk_branch gcc_pcie_0_cfg_ahb_clk = {
1651 .halt_reg = 0x6b018,
1652 .halt_check = BRANCH_HALT_VOTED,
1653 .hwcg_reg = 0x6b018,
1654 .hwcg_bit = 1,
1655 .clkr = {
1656 .enable_reg = 0x5200c,
1657 .enable_mask = BIT(2),
1658 .hw.init = &(struct clk_init_data){
1659 .name = "gcc_pcie_0_cfg_ahb_clk",
1660 .ops = &clk_branch2_ops,
1661 },
1662 },
1663};
1664
1665static struct clk_branch gcc_pcie_0_clkref_clk = {
1666 .halt_reg = 0x8c00c,
1667 .halt_check = BRANCH_HALT,
1668 .clkr = {
1669 .enable_reg = 0x8c00c,
1670 .enable_mask = BIT(0),
1671 .hw.init = &(struct clk_init_data){
1672 .name = "gcc_pcie_0_clkref_clk",
1673 .ops = &clk_branch2_ops,
1674 },
1675 },
1676};
1677
1678static struct clk_branch gcc_pcie_0_mstr_axi_clk = {
1679 .halt_reg = 0x6b014,
1680 .halt_check = BRANCH_HALT_VOTED,
1681 .clkr = {
1682 .enable_reg = 0x5200c,
1683 .enable_mask = BIT(1),
1684 .hw.init = &(struct clk_init_data){
1685 .name = "gcc_pcie_0_mstr_axi_clk",
1686 .ops = &clk_branch2_ops,
1687 },
1688 },
1689};
1690
1691static struct clk_branch gcc_pcie_0_pipe_clk = {
1692 .halt_check = BRANCH_HALT_SKIP,
1693 .clkr = {
1694 .enable_reg = 0x5200c,
1695 .enable_mask = BIT(4),
1696 .hw.init = &(struct clk_init_data){
1697 .name = "gcc_pcie_0_pipe_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001698 .parent_data = &(const struct clk_parent_data){
1699 .fw_name = "pcie_0_pipe_clk", .name = "pcie_0_pipe_clk",
1700 },
Bjorn Andersson4b5a59a2019-02-25 23:02:21 -08001701 .num_parents = 1,
1702 .flags = CLK_SET_RATE_PARENT,
Taniya Das06391ed2018-05-07 16:20:20 +05301703 .ops = &clk_branch2_ops,
1704 },
1705 },
1706};
1707
1708static struct clk_branch gcc_pcie_0_slv_axi_clk = {
1709 .halt_reg = 0x6b010,
1710 .halt_check = BRANCH_HALT_VOTED,
1711 .hwcg_reg = 0x6b010,
1712 .hwcg_bit = 1,
1713 .clkr = {
1714 .enable_reg = 0x5200c,
1715 .enable_mask = BIT(0),
1716 .hw.init = &(struct clk_init_data){
1717 .name = "gcc_pcie_0_slv_axi_clk",
1718 .ops = &clk_branch2_ops,
1719 },
1720 },
1721};
1722
1723static struct clk_branch gcc_pcie_0_slv_q2a_axi_clk = {
1724 .halt_reg = 0x6b00c,
1725 .halt_check = BRANCH_HALT_VOTED,
1726 .clkr = {
1727 .enable_reg = 0x5200c,
1728 .enable_mask = BIT(5),
1729 .hw.init = &(struct clk_init_data){
1730 .name = "gcc_pcie_0_slv_q2a_axi_clk",
1731 .ops = &clk_branch2_ops,
1732 },
1733 },
1734};
1735
1736static struct clk_branch gcc_pcie_1_aux_clk = {
1737 .halt_reg = 0x8d01c,
1738 .halt_check = BRANCH_HALT_VOTED,
1739 .clkr = {
1740 .enable_reg = 0x52004,
1741 .enable_mask = BIT(29),
1742 .hw.init = &(struct clk_init_data){
1743 .name = "gcc_pcie_1_aux_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001744 .parent_hws = (const struct clk_hw*[]){
1745 &gcc_pcie_1_aux_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301746 },
1747 .num_parents = 1,
1748 .flags = CLK_SET_RATE_PARENT,
1749 .ops = &clk_branch2_ops,
1750 },
1751 },
1752};
1753
1754static struct clk_branch gcc_pcie_1_cfg_ahb_clk = {
1755 .halt_reg = 0x8d018,
1756 .halt_check = BRANCH_HALT_VOTED,
1757 .hwcg_reg = 0x8d018,
1758 .hwcg_bit = 1,
1759 .clkr = {
1760 .enable_reg = 0x52004,
1761 .enable_mask = BIT(28),
1762 .hw.init = &(struct clk_init_data){
1763 .name = "gcc_pcie_1_cfg_ahb_clk",
1764 .ops = &clk_branch2_ops,
1765 },
1766 },
1767};
1768
1769static struct clk_branch gcc_pcie_1_clkref_clk = {
1770 .halt_reg = 0x8c02c,
1771 .halt_check = BRANCH_HALT,
1772 .clkr = {
1773 .enable_reg = 0x8c02c,
1774 .enable_mask = BIT(0),
1775 .hw.init = &(struct clk_init_data){
1776 .name = "gcc_pcie_1_clkref_clk",
1777 .ops = &clk_branch2_ops,
1778 },
1779 },
1780};
1781
1782static struct clk_branch gcc_pcie_1_mstr_axi_clk = {
1783 .halt_reg = 0x8d014,
1784 .halt_check = BRANCH_HALT_VOTED,
1785 .clkr = {
1786 .enable_reg = 0x52004,
1787 .enable_mask = BIT(27),
1788 .hw.init = &(struct clk_init_data){
1789 .name = "gcc_pcie_1_mstr_axi_clk",
1790 .ops = &clk_branch2_ops,
1791 },
1792 },
1793};
1794
1795static struct clk_branch gcc_pcie_1_pipe_clk = {
1796 .halt_check = BRANCH_HALT_SKIP,
1797 .clkr = {
1798 .enable_reg = 0x52004,
1799 .enable_mask = BIT(30),
1800 .hw.init = &(struct clk_init_data){
1801 .name = "gcc_pcie_1_pipe_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001802 .parent_data = &(const struct clk_parent_data){
1803 .fw_name = "pcie_1_pipe_clk", .name = "pcie_1_pipe_clk",
1804 },
Bjorn Andersson4b5a59a2019-02-25 23:02:21 -08001805 .num_parents = 1,
Taniya Das06391ed2018-05-07 16:20:20 +05301806 .ops = &clk_branch2_ops,
1807 },
1808 },
1809};
1810
1811static struct clk_branch gcc_pcie_1_slv_axi_clk = {
1812 .halt_reg = 0x8d010,
1813 .halt_check = BRANCH_HALT_VOTED,
1814 .hwcg_reg = 0x8d010,
1815 .hwcg_bit = 1,
1816 .clkr = {
1817 .enable_reg = 0x52004,
1818 .enable_mask = BIT(26),
1819 .hw.init = &(struct clk_init_data){
1820 .name = "gcc_pcie_1_slv_axi_clk",
1821 .ops = &clk_branch2_ops,
1822 },
1823 },
1824};
1825
1826static struct clk_branch gcc_pcie_1_slv_q2a_axi_clk = {
1827 .halt_reg = 0x8d00c,
1828 .halt_check = BRANCH_HALT_VOTED,
1829 .clkr = {
1830 .enable_reg = 0x52004,
1831 .enable_mask = BIT(25),
1832 .hw.init = &(struct clk_init_data){
1833 .name = "gcc_pcie_1_slv_q2a_axi_clk",
1834 .ops = &clk_branch2_ops,
1835 },
1836 },
1837};
1838
1839static struct clk_branch gcc_pcie_phy_aux_clk = {
1840 .halt_reg = 0x6f004,
1841 .halt_check = BRANCH_HALT,
1842 .clkr = {
1843 .enable_reg = 0x6f004,
1844 .enable_mask = BIT(0),
1845 .hw.init = &(struct clk_init_data){
1846 .name = "gcc_pcie_phy_aux_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001847 .parent_hws = (const struct clk_hw*[]){
1848 &gcc_pcie_0_aux_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301849 },
1850 .num_parents = 1,
1851 .flags = CLK_SET_RATE_PARENT,
1852 .ops = &clk_branch2_ops,
1853 },
1854 },
1855};
1856
1857static struct clk_branch gcc_pcie_phy_refgen_clk = {
1858 .halt_reg = 0x6f02c,
1859 .halt_check = BRANCH_HALT,
1860 .clkr = {
1861 .enable_reg = 0x6f02c,
1862 .enable_mask = BIT(0),
1863 .hw.init = &(struct clk_init_data){
1864 .name = "gcc_pcie_phy_refgen_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001865 .parent_hws = (const struct clk_hw*[]){
1866 &gcc_pcie_phy_refgen_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301867 },
1868 .num_parents = 1,
1869 .flags = CLK_SET_RATE_PARENT,
1870 .ops = &clk_branch2_ops,
1871 },
1872 },
1873};
1874
1875static struct clk_branch gcc_pdm2_clk = {
1876 .halt_reg = 0x3300c,
1877 .halt_check = BRANCH_HALT,
1878 .clkr = {
1879 .enable_reg = 0x3300c,
1880 .enable_mask = BIT(0),
1881 .hw.init = &(struct clk_init_data){
1882 .name = "gcc_pdm2_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03001883 .parent_hws = (const struct clk_hw*[]){
1884 &gcc_pdm2_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05301885 },
1886 .num_parents = 1,
1887 .flags = CLK_SET_RATE_PARENT,
1888 .ops = &clk_branch2_ops,
1889 },
1890 },
1891};
1892
1893static struct clk_branch gcc_pdm_ahb_clk = {
1894 .halt_reg = 0x33004,
1895 .halt_check = BRANCH_HALT,
1896 .hwcg_reg = 0x33004,
1897 .hwcg_bit = 1,
1898 .clkr = {
1899 .enable_reg = 0x33004,
1900 .enable_mask = BIT(0),
1901 .hw.init = &(struct clk_init_data){
1902 .name = "gcc_pdm_ahb_clk",
1903 .ops = &clk_branch2_ops,
1904 },
1905 },
1906};
1907
1908static struct clk_branch gcc_pdm_xo4_clk = {
1909 .halt_reg = 0x33008,
1910 .halt_check = BRANCH_HALT,
1911 .clkr = {
1912 .enable_reg = 0x33008,
1913 .enable_mask = BIT(0),
1914 .hw.init = &(struct clk_init_data){
1915 .name = "gcc_pdm_xo4_clk",
1916 .ops = &clk_branch2_ops,
1917 },
1918 },
1919};
1920
1921static struct clk_branch gcc_prng_ahb_clk = {
1922 .halt_reg = 0x34004,
1923 .halt_check = BRANCH_HALT_VOTED,
1924 .hwcg_reg = 0x34004,
1925 .hwcg_bit = 1,
1926 .clkr = {
1927 .enable_reg = 0x52004,
1928 .enable_mask = BIT(13),
1929 .hw.init = &(struct clk_init_data){
1930 .name = "gcc_prng_ahb_clk",
1931 .ops = &clk_branch2_ops,
1932 },
1933 },
1934};
1935
1936static struct clk_branch gcc_qmip_camera_ahb_clk = {
1937 .halt_reg = 0xb014,
1938 .halt_check = BRANCH_HALT,
1939 .hwcg_reg = 0xb014,
1940 .hwcg_bit = 1,
1941 .clkr = {
1942 .enable_reg = 0xb014,
1943 .enable_mask = BIT(0),
1944 .hw.init = &(struct clk_init_data){
1945 .name = "gcc_qmip_camera_ahb_clk",
1946 .ops = &clk_branch2_ops,
1947 },
1948 },
1949};
1950
1951static struct clk_branch gcc_qmip_disp_ahb_clk = {
1952 .halt_reg = 0xb018,
1953 .halt_check = BRANCH_HALT,
1954 .hwcg_reg = 0xb018,
1955 .hwcg_bit = 1,
1956 .clkr = {
1957 .enable_reg = 0xb018,
1958 .enable_mask = BIT(0),
1959 .hw.init = &(struct clk_init_data){
1960 .name = "gcc_qmip_disp_ahb_clk",
1961 .ops = &clk_branch2_ops,
1962 },
1963 },
1964};
1965
1966static struct clk_branch gcc_qmip_video_ahb_clk = {
1967 .halt_reg = 0xb010,
1968 .halt_check = BRANCH_HALT,
1969 .hwcg_reg = 0xb010,
1970 .hwcg_bit = 1,
1971 .clkr = {
1972 .enable_reg = 0xb010,
1973 .enable_mask = BIT(0),
1974 .hw.init = &(struct clk_init_data){
1975 .name = "gcc_qmip_video_ahb_clk",
1976 .ops = &clk_branch2_ops,
1977 },
1978 },
1979};
1980
Douglas Anderson4f83d9b2018-07-24 10:45:13 -07001981static struct clk_branch gcc_qspi_cnoc_periph_ahb_clk = {
1982 .halt_reg = 0x4b000,
1983 .halt_check = BRANCH_HALT,
1984 .clkr = {
1985 .enable_reg = 0x4b000,
1986 .enable_mask = BIT(0),
1987 .hw.init = &(struct clk_init_data){
1988 .name = "gcc_qspi_cnoc_periph_ahb_clk",
1989 .ops = &clk_branch2_ops,
1990 },
1991 },
1992};
1993
1994static struct clk_branch gcc_qspi_core_clk = {
1995 .halt_reg = 0x4b004,
1996 .halt_check = BRANCH_HALT,
1997 .clkr = {
1998 .enable_reg = 0x4b004,
1999 .enable_mask = BIT(0),
2000 .hw.init = &(struct clk_init_data){
2001 .name = "gcc_qspi_core_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002002 .parent_hws = (const struct clk_hw*[]){
2003 &gcc_qspi_core_clk_src.clkr.hw,
Douglas Anderson4f83d9b2018-07-24 10:45:13 -07002004 },
2005 .num_parents = 1,
2006 .flags = CLK_SET_RATE_PARENT,
2007 .ops = &clk_branch2_ops,
2008 },
2009 },
2010};
2011
Taniya Das06391ed2018-05-07 16:20:20 +05302012static struct clk_branch gcc_qupv3_wrap0_s0_clk = {
2013 .halt_reg = 0x17030,
2014 .halt_check = BRANCH_HALT_VOTED,
2015 .clkr = {
2016 .enable_reg = 0x5200c,
2017 .enable_mask = BIT(10),
2018 .hw.init = &(struct clk_init_data){
2019 .name = "gcc_qupv3_wrap0_s0_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002020 .parent_hws = (const struct clk_hw*[]){
2021 &gcc_qupv3_wrap0_s0_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302022 },
2023 .num_parents = 1,
2024 .flags = CLK_SET_RATE_PARENT,
2025 .ops = &clk_branch2_ops,
2026 },
2027 },
2028};
2029
2030static struct clk_branch gcc_qupv3_wrap0_s1_clk = {
2031 .halt_reg = 0x17160,
2032 .halt_check = BRANCH_HALT_VOTED,
2033 .clkr = {
2034 .enable_reg = 0x5200c,
2035 .enable_mask = BIT(11),
2036 .hw.init = &(struct clk_init_data){
2037 .name = "gcc_qupv3_wrap0_s1_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002038 .parent_hws = (const struct clk_hw*[]){
2039 &gcc_qupv3_wrap0_s1_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302040 },
2041 .num_parents = 1,
2042 .flags = CLK_SET_RATE_PARENT,
2043 .ops = &clk_branch2_ops,
2044 },
2045 },
2046};
2047
2048static struct clk_branch gcc_qupv3_wrap0_s2_clk = {
2049 .halt_reg = 0x17290,
2050 .halt_check = BRANCH_HALT_VOTED,
2051 .clkr = {
2052 .enable_reg = 0x5200c,
2053 .enable_mask = BIT(12),
2054 .hw.init = &(struct clk_init_data){
2055 .name = "gcc_qupv3_wrap0_s2_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002056 .parent_hws = (const struct clk_hw*[]){
2057 &gcc_qupv3_wrap0_s2_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302058 },
2059 .num_parents = 1,
2060 .flags = CLK_SET_RATE_PARENT,
2061 .ops = &clk_branch2_ops,
2062 },
2063 },
2064};
2065
2066static struct clk_branch gcc_qupv3_wrap0_s3_clk = {
2067 .halt_reg = 0x173c0,
2068 .halt_check = BRANCH_HALT_VOTED,
2069 .clkr = {
2070 .enable_reg = 0x5200c,
2071 .enable_mask = BIT(13),
2072 .hw.init = &(struct clk_init_data){
2073 .name = "gcc_qupv3_wrap0_s3_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002074 .parent_hws = (const struct clk_hw*[]){
2075 &gcc_qupv3_wrap0_s3_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302076 },
2077 .num_parents = 1,
2078 .flags = CLK_SET_RATE_PARENT,
2079 .ops = &clk_branch2_ops,
2080 },
2081 },
2082};
2083
2084static struct clk_branch gcc_qupv3_wrap0_s4_clk = {
2085 .halt_reg = 0x174f0,
2086 .halt_check = BRANCH_HALT_VOTED,
2087 .clkr = {
2088 .enable_reg = 0x5200c,
2089 .enable_mask = BIT(14),
2090 .hw.init = &(struct clk_init_data){
2091 .name = "gcc_qupv3_wrap0_s4_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002092 .parent_hws = (const struct clk_hw*[]){
2093 &gcc_qupv3_wrap0_s4_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302094 },
2095 .num_parents = 1,
2096 .flags = CLK_SET_RATE_PARENT,
2097 .ops = &clk_branch2_ops,
2098 },
2099 },
2100};
2101
2102static struct clk_branch gcc_qupv3_wrap0_s5_clk = {
2103 .halt_reg = 0x17620,
2104 .halt_check = BRANCH_HALT_VOTED,
2105 .clkr = {
2106 .enable_reg = 0x5200c,
2107 .enable_mask = BIT(15),
2108 .hw.init = &(struct clk_init_data){
2109 .name = "gcc_qupv3_wrap0_s5_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002110 .parent_hws = (const struct clk_hw*[]){
2111 &gcc_qupv3_wrap0_s5_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302112 },
2113 .num_parents = 1,
2114 .flags = CLK_SET_RATE_PARENT,
2115 .ops = &clk_branch2_ops,
2116 },
2117 },
2118};
2119
2120static struct clk_branch gcc_qupv3_wrap0_s6_clk = {
2121 .halt_reg = 0x17750,
2122 .halt_check = BRANCH_HALT_VOTED,
2123 .clkr = {
2124 .enable_reg = 0x5200c,
2125 .enable_mask = BIT(16),
2126 .hw.init = &(struct clk_init_data){
2127 .name = "gcc_qupv3_wrap0_s6_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002128 .parent_hws = (const struct clk_hw*[]){
2129 &gcc_qupv3_wrap0_s6_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302130 },
2131 .num_parents = 1,
2132 .flags = CLK_SET_RATE_PARENT,
2133 .ops = &clk_branch2_ops,
2134 },
2135 },
2136};
2137
2138static struct clk_branch gcc_qupv3_wrap0_s7_clk = {
2139 .halt_reg = 0x17880,
2140 .halt_check = BRANCH_HALT_VOTED,
2141 .clkr = {
2142 .enable_reg = 0x5200c,
2143 .enable_mask = BIT(17),
2144 .hw.init = &(struct clk_init_data){
2145 .name = "gcc_qupv3_wrap0_s7_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002146 .parent_hws = (const struct clk_hw*[]){
2147 &gcc_qupv3_wrap0_s7_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302148 },
2149 .num_parents = 1,
2150 .flags = CLK_SET_RATE_PARENT,
2151 .ops = &clk_branch2_ops,
2152 },
2153 },
2154};
2155
2156static struct clk_branch gcc_qupv3_wrap1_s0_clk = {
2157 .halt_reg = 0x18014,
2158 .halt_check = BRANCH_HALT_VOTED,
2159 .clkr = {
2160 .enable_reg = 0x5200c,
2161 .enable_mask = BIT(22),
2162 .hw.init = &(struct clk_init_data){
2163 .name = "gcc_qupv3_wrap1_s0_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002164 .parent_hws = (const struct clk_hw*[]){
2165 &gcc_qupv3_wrap1_s0_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302166 },
2167 .num_parents = 1,
2168 .flags = CLK_SET_RATE_PARENT,
2169 .ops = &clk_branch2_ops,
2170 },
2171 },
2172};
2173
2174static struct clk_branch gcc_qupv3_wrap1_s1_clk = {
2175 .halt_reg = 0x18144,
2176 .halt_check = BRANCH_HALT_VOTED,
2177 .clkr = {
2178 .enable_reg = 0x5200c,
2179 .enable_mask = BIT(23),
2180 .hw.init = &(struct clk_init_data){
2181 .name = "gcc_qupv3_wrap1_s1_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002182 .parent_hws = (const struct clk_hw*[]){
2183 &gcc_qupv3_wrap1_s1_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302184 },
2185 .num_parents = 1,
2186 .flags = CLK_SET_RATE_PARENT,
2187 .ops = &clk_branch2_ops,
2188 },
2189 },
2190};
2191
2192static struct clk_branch gcc_qupv3_wrap1_s2_clk = {
2193 .halt_reg = 0x18274,
2194 .halt_check = BRANCH_HALT_VOTED,
2195 .clkr = {
2196 .enable_reg = 0x5200c,
2197 .enable_mask = BIT(24),
2198 .hw.init = &(struct clk_init_data){
2199 .name = "gcc_qupv3_wrap1_s2_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002200 .parent_hws = (const struct clk_hw*[]){
2201 &gcc_qupv3_wrap1_s2_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302202 },
2203 .num_parents = 1,
2204 .flags = CLK_SET_RATE_PARENT,
2205 .ops = &clk_branch2_ops,
2206 },
2207 },
2208};
2209
2210static struct clk_branch gcc_qupv3_wrap1_s3_clk = {
2211 .halt_reg = 0x183a4,
2212 .halt_check = BRANCH_HALT_VOTED,
2213 .clkr = {
2214 .enable_reg = 0x5200c,
2215 .enable_mask = BIT(25),
2216 .hw.init = &(struct clk_init_data){
2217 .name = "gcc_qupv3_wrap1_s3_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002218 .parent_hws = (const struct clk_hw*[]){
2219 &gcc_qupv3_wrap1_s3_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302220 },
2221 .num_parents = 1,
2222 .flags = CLK_SET_RATE_PARENT,
2223 .ops = &clk_branch2_ops,
2224 },
2225 },
2226};
2227
2228static struct clk_branch gcc_qupv3_wrap1_s4_clk = {
2229 .halt_reg = 0x184d4,
2230 .halt_check = BRANCH_HALT_VOTED,
2231 .clkr = {
2232 .enable_reg = 0x5200c,
2233 .enable_mask = BIT(26),
2234 .hw.init = &(struct clk_init_data){
2235 .name = "gcc_qupv3_wrap1_s4_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002236 .parent_hws = (const struct clk_hw*[]){
2237 &gcc_qupv3_wrap1_s4_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302238 },
2239 .num_parents = 1,
2240 .flags = CLK_SET_RATE_PARENT,
2241 .ops = &clk_branch2_ops,
2242 },
2243 },
2244};
2245
2246static struct clk_branch gcc_qupv3_wrap1_s5_clk = {
2247 .halt_reg = 0x18604,
2248 .halt_check = BRANCH_HALT_VOTED,
2249 .clkr = {
2250 .enable_reg = 0x5200c,
2251 .enable_mask = BIT(27),
2252 .hw.init = &(struct clk_init_data){
2253 .name = "gcc_qupv3_wrap1_s5_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002254 .parent_hws = (const struct clk_hw*[]){
2255 &gcc_qupv3_wrap1_s5_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302256 },
2257 .num_parents = 1,
2258 .flags = CLK_SET_RATE_PARENT,
2259 .ops = &clk_branch2_ops,
2260 },
2261 },
2262};
2263
2264static struct clk_branch gcc_qupv3_wrap1_s6_clk = {
2265 .halt_reg = 0x18734,
2266 .halt_check = BRANCH_HALT_VOTED,
2267 .clkr = {
2268 .enable_reg = 0x5200c,
2269 .enable_mask = BIT(28),
2270 .hw.init = &(struct clk_init_data){
2271 .name = "gcc_qupv3_wrap1_s6_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002272 .parent_hws = (const struct clk_hw*[]){
2273 &gcc_qupv3_wrap1_s6_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302274 },
2275 .num_parents = 1,
2276 .flags = CLK_SET_RATE_PARENT,
2277 .ops = &clk_branch2_ops,
2278 },
2279 },
2280};
2281
2282static struct clk_branch gcc_qupv3_wrap1_s7_clk = {
2283 .halt_reg = 0x18864,
2284 .halt_check = BRANCH_HALT_VOTED,
2285 .clkr = {
2286 .enable_reg = 0x5200c,
2287 .enable_mask = BIT(29),
2288 .hw.init = &(struct clk_init_data){
2289 .name = "gcc_qupv3_wrap1_s7_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002290 .parent_hws = (const struct clk_hw*[]){
2291 &gcc_qupv3_wrap1_s7_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302292 },
2293 .num_parents = 1,
2294 .flags = CLK_SET_RATE_PARENT,
2295 .ops = &clk_branch2_ops,
2296 },
2297 },
2298};
2299
2300static struct clk_branch gcc_qupv3_wrap_0_m_ahb_clk = {
2301 .halt_reg = 0x17004,
2302 .halt_check = BRANCH_HALT_VOTED,
2303 .clkr = {
2304 .enable_reg = 0x5200c,
2305 .enable_mask = BIT(6),
2306 .hw.init = &(struct clk_init_data){
2307 .name = "gcc_qupv3_wrap_0_m_ahb_clk",
2308 .ops = &clk_branch2_ops,
2309 },
2310 },
2311};
2312
2313static struct clk_branch gcc_qupv3_wrap_0_s_ahb_clk = {
2314 .halt_reg = 0x17008,
2315 .halt_check = BRANCH_HALT_VOTED,
2316 .hwcg_reg = 0x17008,
2317 .hwcg_bit = 1,
2318 .clkr = {
2319 .enable_reg = 0x5200c,
2320 .enable_mask = BIT(7),
2321 .hw.init = &(struct clk_init_data){
2322 .name = "gcc_qupv3_wrap_0_s_ahb_clk",
2323 .ops = &clk_branch2_ops,
2324 },
2325 },
2326};
2327
2328static struct clk_branch gcc_qupv3_wrap_1_m_ahb_clk = {
2329 .halt_reg = 0x1800c,
2330 .halt_check = BRANCH_HALT_VOTED,
2331 .clkr = {
2332 .enable_reg = 0x5200c,
2333 .enable_mask = BIT(20),
2334 .hw.init = &(struct clk_init_data){
2335 .name = "gcc_qupv3_wrap_1_m_ahb_clk",
2336 .ops = &clk_branch2_ops,
2337 },
2338 },
2339};
2340
2341static struct clk_branch gcc_qupv3_wrap_1_s_ahb_clk = {
2342 .halt_reg = 0x18010,
2343 .halt_check = BRANCH_HALT_VOTED,
2344 .hwcg_reg = 0x18010,
2345 .hwcg_bit = 1,
2346 .clkr = {
2347 .enable_reg = 0x5200c,
2348 .enable_mask = BIT(21),
2349 .hw.init = &(struct clk_init_data){
2350 .name = "gcc_qupv3_wrap_1_s_ahb_clk",
2351 .ops = &clk_branch2_ops,
2352 },
2353 },
2354};
2355
2356static struct clk_branch gcc_sdcc2_ahb_clk = {
2357 .halt_reg = 0x14008,
2358 .halt_check = BRANCH_HALT,
2359 .clkr = {
2360 .enable_reg = 0x14008,
2361 .enable_mask = BIT(0),
2362 .hw.init = &(struct clk_init_data){
2363 .name = "gcc_sdcc2_ahb_clk",
2364 .ops = &clk_branch2_ops,
2365 },
2366 },
2367};
2368
2369static struct clk_branch gcc_sdcc2_apps_clk = {
2370 .halt_reg = 0x14004,
2371 .halt_check = BRANCH_HALT,
2372 .clkr = {
2373 .enable_reg = 0x14004,
2374 .enable_mask = BIT(0),
2375 .hw.init = &(struct clk_init_data){
2376 .name = "gcc_sdcc2_apps_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002377 .parent_hws = (const struct clk_hw*[]){
2378 &gcc_sdcc2_apps_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302379 },
2380 .num_parents = 1,
2381 .flags = CLK_SET_RATE_PARENT,
2382 .ops = &clk_branch2_ops,
2383 },
2384 },
2385};
2386
2387static struct clk_branch gcc_sdcc4_ahb_clk = {
2388 .halt_reg = 0x16008,
2389 .halt_check = BRANCH_HALT,
2390 .clkr = {
2391 .enable_reg = 0x16008,
2392 .enable_mask = BIT(0),
2393 .hw.init = &(struct clk_init_data){
2394 .name = "gcc_sdcc4_ahb_clk",
2395 .ops = &clk_branch2_ops,
2396 },
2397 },
2398};
2399
2400static struct clk_branch gcc_sdcc4_apps_clk = {
2401 .halt_reg = 0x16004,
2402 .halt_check = BRANCH_HALT,
2403 .clkr = {
2404 .enable_reg = 0x16004,
2405 .enable_mask = BIT(0),
2406 .hw.init = &(struct clk_init_data){
2407 .name = "gcc_sdcc4_apps_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002408 .parent_hws = (const struct clk_hw*[]){
2409 &gcc_sdcc4_apps_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302410 },
2411 .num_parents = 1,
2412 .flags = CLK_SET_RATE_PARENT,
2413 .ops = &clk_branch2_ops,
2414 },
2415 },
2416};
2417
2418static struct clk_branch gcc_sys_noc_cpuss_ahb_clk = {
2419 .halt_reg = 0x414c,
2420 .halt_check = BRANCH_HALT_VOTED,
2421 .clkr = {
2422 .enable_reg = 0x52004,
2423 .enable_mask = BIT(0),
2424 .hw.init = &(struct clk_init_data){
2425 .name = "gcc_sys_noc_cpuss_ahb_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002426 .parent_hws = (const struct clk_hw*[]){
2427 &gcc_cpuss_ahb_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302428 },
2429 .num_parents = 1,
2430 .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
2431 .ops = &clk_branch2_ops,
2432 },
2433 },
2434};
2435
2436static struct clk_branch gcc_tsif_ahb_clk = {
2437 .halt_reg = 0x36004,
2438 .halt_check = BRANCH_HALT,
2439 .clkr = {
2440 .enable_reg = 0x36004,
2441 .enable_mask = BIT(0),
2442 .hw.init = &(struct clk_init_data){
2443 .name = "gcc_tsif_ahb_clk",
2444 .ops = &clk_branch2_ops,
2445 },
2446 },
2447};
2448
2449static struct clk_branch gcc_tsif_inactivity_timers_clk = {
2450 .halt_reg = 0x3600c,
2451 .halt_check = BRANCH_HALT,
2452 .clkr = {
2453 .enable_reg = 0x3600c,
2454 .enable_mask = BIT(0),
2455 .hw.init = &(struct clk_init_data){
2456 .name = "gcc_tsif_inactivity_timers_clk",
2457 .ops = &clk_branch2_ops,
2458 },
2459 },
2460};
2461
2462static struct clk_branch gcc_tsif_ref_clk = {
2463 .halt_reg = 0x36008,
2464 .halt_check = BRANCH_HALT,
2465 .clkr = {
2466 .enable_reg = 0x36008,
2467 .enable_mask = BIT(0),
2468 .hw.init = &(struct clk_init_data){
2469 .name = "gcc_tsif_ref_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002470 .parent_hws = (const struct clk_hw*[]){
2471 &gcc_tsif_ref_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302472 },
2473 .num_parents = 1,
2474 .flags = CLK_SET_RATE_PARENT,
2475 .ops = &clk_branch2_ops,
2476 },
2477 },
2478};
2479
2480static struct clk_branch gcc_ufs_card_ahb_clk = {
2481 .halt_reg = 0x75010,
2482 .halt_check = BRANCH_HALT,
2483 .hwcg_reg = 0x75010,
2484 .hwcg_bit = 1,
2485 .clkr = {
2486 .enable_reg = 0x75010,
2487 .enable_mask = BIT(0),
2488 .hw.init = &(struct clk_init_data){
2489 .name = "gcc_ufs_card_ahb_clk",
2490 .ops = &clk_branch2_ops,
2491 },
2492 },
2493};
2494
2495static struct clk_branch gcc_ufs_card_axi_clk = {
2496 .halt_reg = 0x7500c,
2497 .halt_check = BRANCH_HALT,
2498 .hwcg_reg = 0x7500c,
2499 .hwcg_bit = 1,
2500 .clkr = {
2501 .enable_reg = 0x7500c,
2502 .enable_mask = BIT(0),
2503 .hw.init = &(struct clk_init_data){
2504 .name = "gcc_ufs_card_axi_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002505 .parent_hws = (const struct clk_hw*[]){
2506 &gcc_ufs_card_axi_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302507 },
2508 .num_parents = 1,
2509 .flags = CLK_SET_RATE_PARENT,
2510 .ops = &clk_branch2_ops,
2511 },
2512 },
2513};
2514
2515static struct clk_branch gcc_ufs_card_clkref_clk = {
2516 .halt_reg = 0x8c004,
2517 .halt_check = BRANCH_HALT,
2518 .clkr = {
2519 .enable_reg = 0x8c004,
2520 .enable_mask = BIT(0),
2521 .hw.init = &(struct clk_init_data){
2522 .name = "gcc_ufs_card_clkref_clk",
2523 .ops = &clk_branch2_ops,
2524 },
2525 },
2526};
2527
2528static struct clk_branch gcc_ufs_card_ice_core_clk = {
2529 .halt_reg = 0x75058,
2530 .halt_check = BRANCH_HALT,
2531 .hwcg_reg = 0x75058,
2532 .hwcg_bit = 1,
2533 .clkr = {
2534 .enable_reg = 0x75058,
2535 .enable_mask = BIT(0),
2536 .hw.init = &(struct clk_init_data){
2537 .name = "gcc_ufs_card_ice_core_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002538 .parent_hws = (const struct clk_hw*[]){
2539 &gcc_ufs_card_ice_core_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302540 },
2541 .num_parents = 1,
2542 .flags = CLK_SET_RATE_PARENT,
2543 .ops = &clk_branch2_ops,
2544 },
2545 },
2546};
2547
2548static struct clk_branch gcc_ufs_card_phy_aux_clk = {
2549 .halt_reg = 0x7508c,
2550 .halt_check = BRANCH_HALT,
2551 .hwcg_reg = 0x7508c,
2552 .hwcg_bit = 1,
2553 .clkr = {
2554 .enable_reg = 0x7508c,
2555 .enable_mask = BIT(0),
2556 .hw.init = &(struct clk_init_data){
2557 .name = "gcc_ufs_card_phy_aux_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002558 .parent_hws = (const struct clk_hw*[]){
2559 &gcc_ufs_card_phy_aux_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302560 },
2561 .num_parents = 1,
2562 .flags = CLK_SET_RATE_PARENT,
2563 .ops = &clk_branch2_ops,
2564 },
2565 },
2566};
2567
2568static struct clk_branch gcc_ufs_card_rx_symbol_0_clk = {
2569 .halt_check = BRANCH_HALT_SKIP,
2570 .clkr = {
2571 .enable_reg = 0x75018,
2572 .enable_mask = BIT(0),
2573 .hw.init = &(struct clk_init_data){
2574 .name = "gcc_ufs_card_rx_symbol_0_clk",
2575 .ops = &clk_branch2_ops,
2576 },
2577 },
2578};
2579
2580static struct clk_branch gcc_ufs_card_rx_symbol_1_clk = {
2581 .halt_check = BRANCH_HALT_SKIP,
2582 .clkr = {
2583 .enable_reg = 0x750a8,
2584 .enable_mask = BIT(0),
2585 .hw.init = &(struct clk_init_data){
2586 .name = "gcc_ufs_card_rx_symbol_1_clk",
2587 .ops = &clk_branch2_ops,
2588 },
2589 },
2590};
2591
2592static struct clk_branch gcc_ufs_card_tx_symbol_0_clk = {
2593 .halt_check = BRANCH_HALT_SKIP,
2594 .clkr = {
2595 .enable_reg = 0x75014,
2596 .enable_mask = BIT(0),
2597 .hw.init = &(struct clk_init_data){
2598 .name = "gcc_ufs_card_tx_symbol_0_clk",
2599 .ops = &clk_branch2_ops,
2600 },
2601 },
2602};
2603
2604static struct clk_branch gcc_ufs_card_unipro_core_clk = {
2605 .halt_reg = 0x75054,
2606 .halt_check = BRANCH_HALT,
2607 .hwcg_reg = 0x75054,
2608 .hwcg_bit = 1,
2609 .clkr = {
2610 .enable_reg = 0x75054,
2611 .enable_mask = BIT(0),
2612 .hw.init = &(struct clk_init_data){
2613 .name = "gcc_ufs_card_unipro_core_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002614 .parent_hws = (const struct clk_hw*[]){
2615 &gcc_ufs_card_unipro_core_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302616 },
2617 .num_parents = 1,
2618 .flags = CLK_SET_RATE_PARENT,
2619 .ops = &clk_branch2_ops,
2620 },
2621 },
2622};
2623
2624static struct clk_branch gcc_ufs_mem_clkref_clk = {
2625 .halt_reg = 0x8c000,
2626 .halt_check = BRANCH_HALT,
2627 .clkr = {
2628 .enable_reg = 0x8c000,
2629 .enable_mask = BIT(0),
2630 .hw.init = &(struct clk_init_data){
2631 .name = "gcc_ufs_mem_clkref_clk",
2632 .ops = &clk_branch2_ops,
2633 },
2634 },
2635};
2636
2637static struct clk_branch gcc_ufs_phy_ahb_clk = {
2638 .halt_reg = 0x77010,
2639 .halt_check = BRANCH_HALT,
2640 .hwcg_reg = 0x77010,
2641 .hwcg_bit = 1,
2642 .clkr = {
2643 .enable_reg = 0x77010,
2644 .enable_mask = BIT(0),
2645 .hw.init = &(struct clk_init_data){
2646 .name = "gcc_ufs_phy_ahb_clk",
2647 .ops = &clk_branch2_ops,
2648 },
2649 },
2650};
2651
2652static struct clk_branch gcc_ufs_phy_axi_clk = {
2653 .halt_reg = 0x7700c,
2654 .halt_check = BRANCH_HALT,
2655 .hwcg_reg = 0x7700c,
2656 .hwcg_bit = 1,
2657 .clkr = {
2658 .enable_reg = 0x7700c,
2659 .enable_mask = BIT(0),
2660 .hw.init = &(struct clk_init_data){
2661 .name = "gcc_ufs_phy_axi_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002662 .parent_hws = (const struct clk_hw*[]){
2663 &gcc_ufs_phy_axi_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302664 },
2665 .num_parents = 1,
2666 .flags = CLK_SET_RATE_PARENT,
2667 .ops = &clk_branch2_ops,
2668 },
2669 },
2670};
2671
2672static struct clk_branch gcc_ufs_phy_ice_core_clk = {
2673 .halt_reg = 0x77058,
2674 .halt_check = BRANCH_HALT,
2675 .hwcg_reg = 0x77058,
2676 .hwcg_bit = 1,
2677 .clkr = {
2678 .enable_reg = 0x77058,
2679 .enable_mask = BIT(0),
2680 .hw.init = &(struct clk_init_data){
2681 .name = "gcc_ufs_phy_ice_core_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002682 .parent_hws = (const struct clk_hw*[]){
2683 &gcc_ufs_phy_ice_core_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302684 },
2685 .num_parents = 1,
2686 .flags = CLK_SET_RATE_PARENT,
2687 .ops = &clk_branch2_ops,
2688 },
2689 },
2690};
2691
2692static struct clk_branch gcc_ufs_phy_phy_aux_clk = {
2693 .halt_reg = 0x7708c,
2694 .halt_check = BRANCH_HALT,
2695 .hwcg_reg = 0x7708c,
2696 .hwcg_bit = 1,
2697 .clkr = {
2698 .enable_reg = 0x7708c,
2699 .enable_mask = BIT(0),
2700 .hw.init = &(struct clk_init_data){
2701 .name = "gcc_ufs_phy_phy_aux_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002702 .parent_hws = (const struct clk_hw*[]){
2703 &gcc_ufs_phy_phy_aux_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302704 },
2705 .num_parents = 1,
2706 .flags = CLK_SET_RATE_PARENT,
2707 .ops = &clk_branch2_ops,
2708 },
2709 },
2710};
2711
2712static struct clk_branch gcc_ufs_phy_rx_symbol_0_clk = {
2713 .halt_check = BRANCH_HALT_SKIP,
2714 .clkr = {
2715 .enable_reg = 0x77018,
2716 .enable_mask = BIT(0),
2717 .hw.init = &(struct clk_init_data){
2718 .name = "gcc_ufs_phy_rx_symbol_0_clk",
2719 .ops = &clk_branch2_ops,
2720 },
2721 },
2722};
2723
2724static struct clk_branch gcc_ufs_phy_rx_symbol_1_clk = {
2725 .halt_check = BRANCH_HALT_SKIP,
2726 .clkr = {
2727 .enable_reg = 0x770a8,
2728 .enable_mask = BIT(0),
2729 .hw.init = &(struct clk_init_data){
2730 .name = "gcc_ufs_phy_rx_symbol_1_clk",
2731 .ops = &clk_branch2_ops,
2732 },
2733 },
2734};
2735
2736static struct clk_branch gcc_ufs_phy_tx_symbol_0_clk = {
2737 .halt_check = BRANCH_HALT_SKIP,
2738 .clkr = {
2739 .enable_reg = 0x77014,
2740 .enable_mask = BIT(0),
2741 .hw.init = &(struct clk_init_data){
2742 .name = "gcc_ufs_phy_tx_symbol_0_clk",
2743 .ops = &clk_branch2_ops,
2744 },
2745 },
2746};
2747
2748static struct clk_branch gcc_ufs_phy_unipro_core_clk = {
2749 .halt_reg = 0x77054,
2750 .halt_check = BRANCH_HALT,
2751 .hwcg_reg = 0x77054,
2752 .hwcg_bit = 1,
2753 .clkr = {
2754 .enable_reg = 0x77054,
2755 .enable_mask = BIT(0),
2756 .hw.init = &(struct clk_init_data){
2757 .name = "gcc_ufs_phy_unipro_core_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002758 .parent_hws = (const struct clk_hw*[]){
2759 &gcc_ufs_phy_unipro_core_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302760 },
2761 .num_parents = 1,
2762 .flags = CLK_SET_RATE_PARENT,
2763 .ops = &clk_branch2_ops,
2764 },
2765 },
2766};
2767
2768static struct clk_branch gcc_usb30_prim_master_clk = {
2769 .halt_reg = 0xf00c,
2770 .halt_check = BRANCH_HALT,
2771 .clkr = {
2772 .enable_reg = 0xf00c,
2773 .enable_mask = BIT(0),
2774 .hw.init = &(struct clk_init_data){
2775 .name = "gcc_usb30_prim_master_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002776 .parent_hws = (const struct clk_hw*[]){
2777 &gcc_usb30_prim_master_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302778 },
2779 .num_parents = 1,
2780 .flags = CLK_SET_RATE_PARENT,
2781 .ops = &clk_branch2_ops,
2782 },
2783 },
2784};
2785
2786static struct clk_branch gcc_usb30_prim_mock_utmi_clk = {
2787 .halt_reg = 0xf014,
2788 .halt_check = BRANCH_HALT,
2789 .clkr = {
2790 .enable_reg = 0xf014,
2791 .enable_mask = BIT(0),
2792 .hw.init = &(struct clk_init_data){
2793 .name = "gcc_usb30_prim_mock_utmi_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002794 .parent_hws = (const struct clk_hw*[]){
2795 &gcc_usb30_prim_mock_utmi_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302796 },
2797 .num_parents = 1,
2798 .flags = CLK_SET_RATE_PARENT,
2799 .ops = &clk_branch2_ops,
2800 },
2801 },
2802};
2803
2804static struct clk_branch gcc_usb30_prim_sleep_clk = {
2805 .halt_reg = 0xf010,
2806 .halt_check = BRANCH_HALT,
2807 .clkr = {
2808 .enable_reg = 0xf010,
2809 .enable_mask = BIT(0),
2810 .hw.init = &(struct clk_init_data){
2811 .name = "gcc_usb30_prim_sleep_clk",
2812 .ops = &clk_branch2_ops,
2813 },
2814 },
2815};
2816
2817static struct clk_branch gcc_usb30_sec_master_clk = {
2818 .halt_reg = 0x1000c,
2819 .halt_check = BRANCH_HALT,
2820 .clkr = {
2821 .enable_reg = 0x1000c,
2822 .enable_mask = BIT(0),
2823 .hw.init = &(struct clk_init_data){
2824 .name = "gcc_usb30_sec_master_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002825 .parent_hws = (const struct clk_hw*[]){
2826 &gcc_usb30_sec_master_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302827 },
2828 .num_parents = 1,
2829 .flags = CLK_SET_RATE_PARENT,
2830 .ops = &clk_branch2_ops,
2831 },
2832 },
2833};
2834
2835static struct clk_branch gcc_usb30_sec_mock_utmi_clk = {
2836 .halt_reg = 0x10014,
2837 .halt_check = BRANCH_HALT,
2838 .clkr = {
2839 .enable_reg = 0x10014,
2840 .enable_mask = BIT(0),
2841 .hw.init = &(struct clk_init_data){
2842 .name = "gcc_usb30_sec_mock_utmi_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002843 .parent_hws = (const struct clk_hw*[]){
2844 &gcc_usb30_sec_mock_utmi_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302845 },
2846 .num_parents = 1,
2847 .flags = CLK_SET_RATE_PARENT,
2848 .ops = &clk_branch2_ops,
2849 },
2850 },
2851};
2852
2853static struct clk_branch gcc_usb30_sec_sleep_clk = {
2854 .halt_reg = 0x10010,
2855 .halt_check = BRANCH_HALT,
2856 .clkr = {
2857 .enable_reg = 0x10010,
2858 .enable_mask = BIT(0),
2859 .hw.init = &(struct clk_init_data){
2860 .name = "gcc_usb30_sec_sleep_clk",
2861 .ops = &clk_branch2_ops,
2862 },
2863 },
2864};
2865
2866static struct clk_branch gcc_usb3_prim_clkref_clk = {
2867 .halt_reg = 0x8c008,
2868 .halt_check = BRANCH_HALT,
2869 .clkr = {
2870 .enable_reg = 0x8c008,
2871 .enable_mask = BIT(0),
2872 .hw.init = &(struct clk_init_data){
2873 .name = "gcc_usb3_prim_clkref_clk",
2874 .ops = &clk_branch2_ops,
2875 },
2876 },
2877};
2878
2879static struct clk_branch gcc_usb3_prim_phy_aux_clk = {
2880 .halt_reg = 0xf04c,
2881 .halt_check = BRANCH_HALT,
2882 .clkr = {
2883 .enable_reg = 0xf04c,
2884 .enable_mask = BIT(0),
2885 .hw.init = &(struct clk_init_data){
2886 .name = "gcc_usb3_prim_phy_aux_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002887 .parent_hws = (const struct clk_hw*[]){
2888 &gcc_usb3_prim_phy_aux_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302889 },
2890 .num_parents = 1,
2891 .flags = CLK_SET_RATE_PARENT,
2892 .ops = &clk_branch2_ops,
2893 },
2894 },
2895};
2896
2897static struct clk_branch gcc_usb3_prim_phy_com_aux_clk = {
2898 .halt_reg = 0xf050,
2899 .halt_check = BRANCH_HALT,
2900 .clkr = {
2901 .enable_reg = 0xf050,
2902 .enable_mask = BIT(0),
2903 .hw.init = &(struct clk_init_data){
2904 .name = "gcc_usb3_prim_phy_com_aux_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002905 .parent_hws = (const struct clk_hw*[]){
2906 &gcc_usb3_prim_phy_aux_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302907 },
2908 .num_parents = 1,
2909 .flags = CLK_SET_RATE_PARENT,
2910 .ops = &clk_branch2_ops,
2911 },
2912 },
2913};
2914
2915static struct clk_branch gcc_usb3_prim_phy_pipe_clk = {
2916 .halt_check = BRANCH_HALT_SKIP,
2917 .clkr = {
2918 .enable_reg = 0xf054,
2919 .enable_mask = BIT(0),
2920 .hw.init = &(struct clk_init_data){
2921 .name = "gcc_usb3_prim_phy_pipe_clk",
2922 .ops = &clk_branch2_ops,
2923 },
2924 },
2925};
2926
2927static struct clk_branch gcc_usb3_sec_clkref_clk = {
2928 .halt_reg = 0x8c028,
2929 .halt_check = BRANCH_HALT,
2930 .clkr = {
2931 .enable_reg = 0x8c028,
2932 .enable_mask = BIT(0),
2933 .hw.init = &(struct clk_init_data){
2934 .name = "gcc_usb3_sec_clkref_clk",
2935 .ops = &clk_branch2_ops,
2936 },
2937 },
2938};
2939
2940static struct clk_branch gcc_usb3_sec_phy_aux_clk = {
2941 .halt_reg = 0x1004c,
2942 .halt_check = BRANCH_HALT,
2943 .clkr = {
2944 .enable_reg = 0x1004c,
2945 .enable_mask = BIT(0),
2946 .hw.init = &(struct clk_init_data){
2947 .name = "gcc_usb3_sec_phy_aux_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002948 .parent_hws = (const struct clk_hw*[]){
2949 &gcc_usb3_sec_phy_aux_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302950 },
2951 .num_parents = 1,
2952 .flags = CLK_SET_RATE_PARENT,
2953 .ops = &clk_branch2_ops,
2954 },
2955 },
2956};
2957
2958static struct clk_branch gcc_usb3_sec_phy_com_aux_clk = {
2959 .halt_reg = 0x10050,
2960 .halt_check = BRANCH_HALT,
2961 .clkr = {
2962 .enable_reg = 0x10050,
2963 .enable_mask = BIT(0),
2964 .hw.init = &(struct clk_init_data){
2965 .name = "gcc_usb3_sec_phy_com_aux_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03002966 .parent_hws = (const struct clk_hw*[]){
2967 &gcc_usb3_sec_phy_aux_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05302968 },
2969 .num_parents = 1,
2970 .flags = CLK_SET_RATE_PARENT,
2971 .ops = &clk_branch2_ops,
2972 },
2973 },
2974};
2975
2976static struct clk_branch gcc_usb3_sec_phy_pipe_clk = {
2977 .halt_check = BRANCH_HALT_SKIP,
2978 .clkr = {
2979 .enable_reg = 0x10054,
2980 .enable_mask = BIT(0),
2981 .hw.init = &(struct clk_init_data){
2982 .name = "gcc_usb3_sec_phy_pipe_clk",
2983 .ops = &clk_branch2_ops,
2984 },
2985 },
2986};
2987
2988static struct clk_branch gcc_usb_phy_cfg_ahb2phy_clk = {
2989 .halt_reg = 0x6a004,
2990 .halt_check = BRANCH_HALT,
2991 .hwcg_reg = 0x6a004,
2992 .hwcg_bit = 1,
2993 .clkr = {
2994 .enable_reg = 0x6a004,
2995 .enable_mask = BIT(0),
2996 .hw.init = &(struct clk_init_data){
2997 .name = "gcc_usb_phy_cfg_ahb2phy_clk",
2998 .ops = &clk_branch2_ops,
2999 },
3000 },
3001};
3002
3003static struct clk_branch gcc_vdda_vs_clk = {
3004 .halt_reg = 0x7a00c,
3005 .halt_check = BRANCH_HALT,
3006 .clkr = {
3007 .enable_reg = 0x7a00c,
3008 .enable_mask = BIT(0),
3009 .hw.init = &(struct clk_init_data){
3010 .name = "gcc_vdda_vs_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03003011 .parent_hws = (const struct clk_hw*[]){
3012 &gcc_vsensor_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05303013 },
3014 .num_parents = 1,
3015 .flags = CLK_SET_RATE_PARENT,
3016 .ops = &clk_branch2_ops,
3017 },
3018 },
3019};
3020
3021static struct clk_branch gcc_vddcx_vs_clk = {
3022 .halt_reg = 0x7a004,
3023 .halt_check = BRANCH_HALT,
3024 .clkr = {
3025 .enable_reg = 0x7a004,
3026 .enable_mask = BIT(0),
3027 .hw.init = &(struct clk_init_data){
3028 .name = "gcc_vddcx_vs_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03003029 .parent_hws = (const struct clk_hw*[]){
3030 &gcc_vsensor_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05303031 },
3032 .num_parents = 1,
3033 .flags = CLK_SET_RATE_PARENT,
3034 .ops = &clk_branch2_ops,
3035 },
3036 },
3037};
3038
3039static struct clk_branch gcc_vddmx_vs_clk = {
3040 .halt_reg = 0x7a008,
3041 .halt_check = BRANCH_HALT,
3042 .clkr = {
3043 .enable_reg = 0x7a008,
3044 .enable_mask = BIT(0),
3045 .hw.init = &(struct clk_init_data){
3046 .name = "gcc_vddmx_vs_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03003047 .parent_hws = (const struct clk_hw*[]){
3048 &gcc_vsensor_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05303049 },
3050 .num_parents = 1,
3051 .flags = CLK_SET_RATE_PARENT,
3052 .ops = &clk_branch2_ops,
3053 },
3054 },
3055};
3056
3057static struct clk_branch gcc_video_ahb_clk = {
3058 .halt_reg = 0xb004,
3059 .halt_check = BRANCH_HALT,
3060 .hwcg_reg = 0xb004,
3061 .hwcg_bit = 1,
3062 .clkr = {
3063 .enable_reg = 0xb004,
3064 .enable_mask = BIT(0),
3065 .hw.init = &(struct clk_init_data){
3066 .name = "gcc_video_ahb_clk",
Amit Nischalcfb82822018-06-11 12:08:15 +05303067 .flags = CLK_IS_CRITICAL,
Taniya Das06391ed2018-05-07 16:20:20 +05303068 .ops = &clk_branch2_ops,
3069 },
3070 },
3071};
3072
3073static struct clk_branch gcc_video_axi_clk = {
3074 .halt_reg = 0xb01c,
3075 .halt_check = BRANCH_VOTED,
3076 .clkr = {
3077 .enable_reg = 0xb01c,
3078 .enable_mask = BIT(0),
3079 .hw.init = &(struct clk_init_data){
3080 .name = "gcc_video_axi_clk",
3081 .ops = &clk_branch2_ops,
3082 },
3083 },
3084};
3085
3086static struct clk_branch gcc_video_xo_clk = {
3087 .halt_reg = 0xb028,
3088 .halt_check = BRANCH_HALT,
3089 .clkr = {
3090 .enable_reg = 0xb028,
3091 .enable_mask = BIT(0),
3092 .hw.init = &(struct clk_init_data){
3093 .name = "gcc_video_xo_clk",
Amit Nischalcfb82822018-06-11 12:08:15 +05303094 .flags = CLK_IS_CRITICAL,
Taniya Das06391ed2018-05-07 16:20:20 +05303095 .ops = &clk_branch2_ops,
3096 },
3097 },
3098};
3099
3100static struct clk_branch gcc_vs_ctrl_ahb_clk = {
3101 .halt_reg = 0x7a014,
3102 .halt_check = BRANCH_HALT,
3103 .hwcg_reg = 0x7a014,
3104 .hwcg_bit = 1,
3105 .clkr = {
3106 .enable_reg = 0x7a014,
3107 .enable_mask = BIT(0),
3108 .hw.init = &(struct clk_init_data){
3109 .name = "gcc_vs_ctrl_ahb_clk",
3110 .ops = &clk_branch2_ops,
3111 },
3112 },
3113};
3114
3115static struct clk_branch gcc_vs_ctrl_clk = {
3116 .halt_reg = 0x7a010,
3117 .halt_check = BRANCH_HALT,
3118 .clkr = {
3119 .enable_reg = 0x7a010,
3120 .enable_mask = BIT(0),
3121 .hw.init = &(struct clk_init_data){
3122 .name = "gcc_vs_ctrl_clk",
Dmitry Baryshkovea434d72021-04-09 21:30:02 +03003123 .parent_hws = (const struct clk_hw*[]){
3124 &gcc_vs_ctrl_clk_src.clkr.hw,
Taniya Das06391ed2018-05-07 16:20:20 +05303125 },
3126 .num_parents = 1,
3127 .flags = CLK_SET_RATE_PARENT,
3128 .ops = &clk_branch2_ops,
3129 },
3130 },
3131};
3132
Amit Nischalcfb82822018-06-11 12:08:15 +05303133static struct clk_branch gcc_cpuss_dvm_bus_clk = {
3134 .halt_reg = 0x48190,
3135 .halt_check = BRANCH_HALT,
3136 .clkr = {
3137 .enable_reg = 0x48190,
3138 .enable_mask = BIT(0),
3139 .hw.init = &(struct clk_init_data){
3140 .name = "gcc_cpuss_dvm_bus_clk",
3141 .flags = CLK_IS_CRITICAL,
3142 .ops = &clk_branch2_ops,
3143 },
3144 },
3145};
3146
3147static struct clk_branch gcc_cpuss_gnoc_clk = {
3148 .halt_reg = 0x48004,
3149 .halt_check = BRANCH_HALT_VOTED,
3150 .hwcg_reg = 0x48004,
3151 .hwcg_bit = 1,
3152 .clkr = {
3153 .enable_reg = 0x52004,
3154 .enable_mask = BIT(22),
3155 .hw.init = &(struct clk_init_data){
3156 .name = "gcc_cpuss_gnoc_clk",
3157 .flags = CLK_IS_CRITICAL,
3158 .ops = &clk_branch2_ops,
3159 },
3160 },
3161};
3162
Taniya Das8d3e5b92018-11-30 23:51:29 +05303163/* TODO: Remove after DTS updated to protect these */
3164#ifdef CONFIG_SDM_LPASSCC_845
3165static struct clk_branch gcc_lpass_q6_axi_clk = {
3166 .halt_reg = 0x47000,
3167 .halt_check = BRANCH_HALT,
3168 .clkr = {
3169 .enable_reg = 0x47000,
3170 .enable_mask = BIT(0),
3171 .hw.init = &(struct clk_init_data){
3172 .name = "gcc_lpass_q6_axi_clk",
3173 .flags = CLK_IS_CRITICAL,
3174 .ops = &clk_branch2_ops,
3175 },
3176 },
3177};
3178
3179static struct clk_branch gcc_lpass_sway_clk = {
3180 .halt_reg = 0x47008,
3181 .halt_check = BRANCH_HALT,
3182 .clkr = {
3183 .enable_reg = 0x47008,
3184 .enable_mask = BIT(0),
3185 .hw.init = &(struct clk_init_data){
3186 .name = "gcc_lpass_sway_clk",
3187 .flags = CLK_IS_CRITICAL,
3188 .ops = &clk_branch2_ops,
3189 },
3190 },
3191};
3192#endif
3193
Taniya Das06391ed2018-05-07 16:20:20 +05303194static struct gdsc pcie_0_gdsc = {
3195 .gdscr = 0x6b004,
3196 .pd = {
3197 .name = "pcie_0_gdsc",
3198 },
3199 .pwrsts = PWRSTS_OFF_ON,
3200 .flags = POLL_CFG_GDSCR,
3201};
3202
3203static struct gdsc pcie_1_gdsc = {
3204 .gdscr = 0x8d004,
3205 .pd = {
3206 .name = "pcie_1_gdsc",
3207 },
3208 .pwrsts = PWRSTS_OFF_ON,
3209 .flags = POLL_CFG_GDSCR,
3210};
3211
3212static struct gdsc ufs_card_gdsc = {
3213 .gdscr = 0x75004,
3214 .pd = {
3215 .name = "ufs_card_gdsc",
3216 },
3217 .pwrsts = PWRSTS_OFF_ON,
3218 .flags = POLL_CFG_GDSCR,
3219};
3220
3221static struct gdsc ufs_phy_gdsc = {
3222 .gdscr = 0x77004,
3223 .pd = {
3224 .name = "ufs_phy_gdsc",
3225 },
3226 .pwrsts = PWRSTS_OFF_ON,
3227 .flags = POLL_CFG_GDSCR,
3228};
3229
3230static struct gdsc usb30_prim_gdsc = {
3231 .gdscr = 0xf004,
3232 .pd = {
3233 .name = "usb30_prim_gdsc",
3234 },
3235 .pwrsts = PWRSTS_OFF_ON,
3236 .flags = POLL_CFG_GDSCR,
3237};
3238
3239static struct gdsc usb30_sec_gdsc = {
3240 .gdscr = 0x10004,
3241 .pd = {
3242 .name = "usb30_sec_gdsc",
3243 },
3244 .pwrsts = PWRSTS_OFF_ON,
3245 .flags = POLL_CFG_GDSCR,
3246};
3247
3248static struct gdsc hlos1_vote_aggre_noc_mmu_audio_tbu_gdsc = {
3249 .gdscr = 0x7d030,
3250 .pd = {
3251 .name = "hlos1_vote_aggre_noc_mmu_audio_tbu_gdsc",
3252 },
3253 .pwrsts = PWRSTS_OFF_ON,
Georgi Djakov5e825482019-11-26 17:34:37 +02003254 .flags = VOTABLE,
Taniya Das06391ed2018-05-07 16:20:20 +05303255};
3256
3257static struct gdsc hlos1_vote_aggre_noc_mmu_pcie_tbu_gdsc = {
3258 .gdscr = 0x7d03c,
3259 .pd = {
3260 .name = "hlos1_vote_aggre_noc_mmu_pcie_tbu_gdsc",
3261 },
3262 .pwrsts = PWRSTS_OFF_ON,
Georgi Djakov5e825482019-11-26 17:34:37 +02003263 .flags = VOTABLE,
Taniya Das06391ed2018-05-07 16:20:20 +05303264};
3265
3266static struct gdsc hlos1_vote_aggre_noc_mmu_tbu1_gdsc = {
3267 .gdscr = 0x7d034,
3268 .pd = {
3269 .name = "hlos1_vote_aggre_noc_mmu_tbu1_gdsc",
3270 },
3271 .pwrsts = PWRSTS_OFF_ON,
Georgi Djakov5e825482019-11-26 17:34:37 +02003272 .flags = VOTABLE,
Taniya Das06391ed2018-05-07 16:20:20 +05303273};
3274
3275static struct gdsc hlos1_vote_aggre_noc_mmu_tbu2_gdsc = {
3276 .gdscr = 0x7d038,
3277 .pd = {
3278 .name = "hlos1_vote_aggre_noc_mmu_tbu2_gdsc",
3279 },
3280 .pwrsts = PWRSTS_OFF_ON,
Georgi Djakov5e825482019-11-26 17:34:37 +02003281 .flags = VOTABLE,
Taniya Das06391ed2018-05-07 16:20:20 +05303282};
3283
3284static struct gdsc hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc = {
3285 .gdscr = 0x7d040,
3286 .pd = {
3287 .name = "hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc",
3288 },
3289 .pwrsts = PWRSTS_OFF_ON,
Georgi Djakov5e825482019-11-26 17:34:37 +02003290 .flags = VOTABLE,
Taniya Das06391ed2018-05-07 16:20:20 +05303291};
3292
3293static struct gdsc hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc = {
3294 .gdscr = 0x7d048,
3295 .pd = {
3296 .name = "hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc",
3297 },
3298 .pwrsts = PWRSTS_OFF_ON,
Georgi Djakov5e825482019-11-26 17:34:37 +02003299 .flags = VOTABLE,
Taniya Das06391ed2018-05-07 16:20:20 +05303300};
3301
3302static struct gdsc hlos1_vote_mmnoc_mmu_tbu_sf_gdsc = {
3303 .gdscr = 0x7d044,
3304 .pd = {
3305 .name = "hlos1_vote_mmnoc_mmu_tbu_sf_gdsc",
3306 },
3307 .pwrsts = PWRSTS_OFF_ON,
Georgi Djakov5e825482019-11-26 17:34:37 +02003308 .flags = VOTABLE,
Taniya Das06391ed2018-05-07 16:20:20 +05303309};
3310
3311static struct clk_regmap *gcc_sdm845_clocks[] = {
3312 [GCC_AGGRE_NOC_PCIE_TBU_CLK] = &gcc_aggre_noc_pcie_tbu_clk.clkr,
3313 [GCC_AGGRE_UFS_CARD_AXI_CLK] = &gcc_aggre_ufs_card_axi_clk.clkr,
3314 [GCC_AGGRE_UFS_PHY_AXI_CLK] = &gcc_aggre_ufs_phy_axi_clk.clkr,
3315 [GCC_AGGRE_USB3_PRIM_AXI_CLK] = &gcc_aggre_usb3_prim_axi_clk.clkr,
3316 [GCC_AGGRE_USB3_SEC_AXI_CLK] = &gcc_aggre_usb3_sec_axi_clk.clkr,
3317 [GCC_APC_VS_CLK] = &gcc_apc_vs_clk.clkr,
3318 [GCC_BOOT_ROM_AHB_CLK] = &gcc_boot_rom_ahb_clk.clkr,
3319 [GCC_CAMERA_AHB_CLK] = &gcc_camera_ahb_clk.clkr,
3320 [GCC_CAMERA_AXI_CLK] = &gcc_camera_axi_clk.clkr,
3321 [GCC_CAMERA_XO_CLK] = &gcc_camera_xo_clk.clkr,
3322 [GCC_CE1_AHB_CLK] = &gcc_ce1_ahb_clk.clkr,
3323 [GCC_CE1_AXI_CLK] = &gcc_ce1_axi_clk.clkr,
3324 [GCC_CE1_CLK] = &gcc_ce1_clk.clkr,
3325 [GCC_CFG_NOC_USB3_PRIM_AXI_CLK] = &gcc_cfg_noc_usb3_prim_axi_clk.clkr,
3326 [GCC_CFG_NOC_USB3_SEC_AXI_CLK] = &gcc_cfg_noc_usb3_sec_axi_clk.clkr,
3327 [GCC_CPUSS_AHB_CLK] = &gcc_cpuss_ahb_clk.clkr,
3328 [GCC_CPUSS_AHB_CLK_SRC] = &gcc_cpuss_ahb_clk_src.clkr,
3329 [GCC_CPUSS_RBCPR_CLK] = &gcc_cpuss_rbcpr_clk.clkr,
3330 [GCC_CPUSS_RBCPR_CLK_SRC] = &gcc_cpuss_rbcpr_clk_src.clkr,
3331 [GCC_DDRSS_GPU_AXI_CLK] = &gcc_ddrss_gpu_axi_clk.clkr,
3332 [GCC_DISP_AHB_CLK] = &gcc_disp_ahb_clk.clkr,
3333 [GCC_DISP_AXI_CLK] = &gcc_disp_axi_clk.clkr,
3334 [GCC_DISP_GPLL0_CLK_SRC] = &gcc_disp_gpll0_clk_src.clkr,
3335 [GCC_DISP_GPLL0_DIV_CLK_SRC] = &gcc_disp_gpll0_div_clk_src.clkr,
3336 [GCC_DISP_XO_CLK] = &gcc_disp_xo_clk.clkr,
3337 [GCC_GP1_CLK] = &gcc_gp1_clk.clkr,
3338 [GCC_GP1_CLK_SRC] = &gcc_gp1_clk_src.clkr,
3339 [GCC_GP2_CLK] = &gcc_gp2_clk.clkr,
3340 [GCC_GP2_CLK_SRC] = &gcc_gp2_clk_src.clkr,
3341 [GCC_GP3_CLK] = &gcc_gp3_clk.clkr,
3342 [GCC_GP3_CLK_SRC] = &gcc_gp3_clk_src.clkr,
3343 [GCC_GPU_CFG_AHB_CLK] = &gcc_gpu_cfg_ahb_clk.clkr,
3344 [GCC_GPU_GPLL0_CLK_SRC] = &gcc_gpu_gpll0_clk_src.clkr,
3345 [GCC_GPU_GPLL0_DIV_CLK_SRC] = &gcc_gpu_gpll0_div_clk_src.clkr,
3346 [GCC_GPU_IREF_CLK] = &gcc_gpu_iref_clk.clkr,
3347 [GCC_GPU_MEMNOC_GFX_CLK] = &gcc_gpu_memnoc_gfx_clk.clkr,
3348 [GCC_GPU_SNOC_DVM_GFX_CLK] = &gcc_gpu_snoc_dvm_gfx_clk.clkr,
3349 [GCC_GPU_VS_CLK] = &gcc_gpu_vs_clk.clkr,
3350 [GCC_MSS_AXIS2_CLK] = &gcc_mss_axis2_clk.clkr,
3351 [GCC_MSS_CFG_AHB_CLK] = &gcc_mss_cfg_ahb_clk.clkr,
3352 [GCC_MSS_GPLL0_DIV_CLK_SRC] = &gcc_mss_gpll0_div_clk_src.clkr,
3353 [GCC_MSS_MFAB_AXIS_CLK] = &gcc_mss_mfab_axis_clk.clkr,
3354 [GCC_MSS_Q6_MEMNOC_AXI_CLK] = &gcc_mss_q6_memnoc_axi_clk.clkr,
3355 [GCC_MSS_SNOC_AXI_CLK] = &gcc_mss_snoc_axi_clk.clkr,
3356 [GCC_MSS_VS_CLK] = &gcc_mss_vs_clk.clkr,
3357 [GCC_PCIE_0_AUX_CLK] = &gcc_pcie_0_aux_clk.clkr,
3358 [GCC_PCIE_0_AUX_CLK_SRC] = &gcc_pcie_0_aux_clk_src.clkr,
3359 [GCC_PCIE_0_CFG_AHB_CLK] = &gcc_pcie_0_cfg_ahb_clk.clkr,
3360 [GCC_PCIE_0_CLKREF_CLK] = &gcc_pcie_0_clkref_clk.clkr,
3361 [GCC_PCIE_0_MSTR_AXI_CLK] = &gcc_pcie_0_mstr_axi_clk.clkr,
3362 [GCC_PCIE_0_PIPE_CLK] = &gcc_pcie_0_pipe_clk.clkr,
3363 [GCC_PCIE_0_SLV_AXI_CLK] = &gcc_pcie_0_slv_axi_clk.clkr,
3364 [GCC_PCIE_0_SLV_Q2A_AXI_CLK] = &gcc_pcie_0_slv_q2a_axi_clk.clkr,
3365 [GCC_PCIE_1_AUX_CLK] = &gcc_pcie_1_aux_clk.clkr,
3366 [GCC_PCIE_1_AUX_CLK_SRC] = &gcc_pcie_1_aux_clk_src.clkr,
3367 [GCC_PCIE_1_CFG_AHB_CLK] = &gcc_pcie_1_cfg_ahb_clk.clkr,
3368 [GCC_PCIE_1_CLKREF_CLK] = &gcc_pcie_1_clkref_clk.clkr,
3369 [GCC_PCIE_1_MSTR_AXI_CLK] = &gcc_pcie_1_mstr_axi_clk.clkr,
3370 [GCC_PCIE_1_PIPE_CLK] = &gcc_pcie_1_pipe_clk.clkr,
3371 [GCC_PCIE_1_SLV_AXI_CLK] = &gcc_pcie_1_slv_axi_clk.clkr,
3372 [GCC_PCIE_1_SLV_Q2A_AXI_CLK] = &gcc_pcie_1_slv_q2a_axi_clk.clkr,
3373 [GCC_PCIE_PHY_AUX_CLK] = &gcc_pcie_phy_aux_clk.clkr,
3374 [GCC_PCIE_PHY_REFGEN_CLK] = &gcc_pcie_phy_refgen_clk.clkr,
3375 [GCC_PCIE_PHY_REFGEN_CLK_SRC] = &gcc_pcie_phy_refgen_clk_src.clkr,
3376 [GCC_PDM2_CLK] = &gcc_pdm2_clk.clkr,
3377 [GCC_PDM2_CLK_SRC] = &gcc_pdm2_clk_src.clkr,
3378 [GCC_PDM_AHB_CLK] = &gcc_pdm_ahb_clk.clkr,
3379 [GCC_PDM_XO4_CLK] = &gcc_pdm_xo4_clk.clkr,
3380 [GCC_PRNG_AHB_CLK] = &gcc_prng_ahb_clk.clkr,
3381 [GCC_QMIP_CAMERA_AHB_CLK] = &gcc_qmip_camera_ahb_clk.clkr,
3382 [GCC_QMIP_DISP_AHB_CLK] = &gcc_qmip_disp_ahb_clk.clkr,
3383 [GCC_QMIP_VIDEO_AHB_CLK] = &gcc_qmip_video_ahb_clk.clkr,
3384 [GCC_QUPV3_WRAP0_S0_CLK] = &gcc_qupv3_wrap0_s0_clk.clkr,
3385 [GCC_QUPV3_WRAP0_S0_CLK_SRC] = &gcc_qupv3_wrap0_s0_clk_src.clkr,
3386 [GCC_QUPV3_WRAP0_S1_CLK] = &gcc_qupv3_wrap0_s1_clk.clkr,
3387 [GCC_QUPV3_WRAP0_S1_CLK_SRC] = &gcc_qupv3_wrap0_s1_clk_src.clkr,
3388 [GCC_QUPV3_WRAP0_S2_CLK] = &gcc_qupv3_wrap0_s2_clk.clkr,
3389 [GCC_QUPV3_WRAP0_S2_CLK_SRC] = &gcc_qupv3_wrap0_s2_clk_src.clkr,
3390 [GCC_QUPV3_WRAP0_S3_CLK] = &gcc_qupv3_wrap0_s3_clk.clkr,
3391 [GCC_QUPV3_WRAP0_S3_CLK_SRC] = &gcc_qupv3_wrap0_s3_clk_src.clkr,
3392 [GCC_QUPV3_WRAP0_S4_CLK] = &gcc_qupv3_wrap0_s4_clk.clkr,
3393 [GCC_QUPV3_WRAP0_S4_CLK_SRC] = &gcc_qupv3_wrap0_s4_clk_src.clkr,
3394 [GCC_QUPV3_WRAP0_S5_CLK] = &gcc_qupv3_wrap0_s5_clk.clkr,
3395 [GCC_QUPV3_WRAP0_S5_CLK_SRC] = &gcc_qupv3_wrap0_s5_clk_src.clkr,
3396 [GCC_QUPV3_WRAP0_S6_CLK] = &gcc_qupv3_wrap0_s6_clk.clkr,
3397 [GCC_QUPV3_WRAP0_S6_CLK_SRC] = &gcc_qupv3_wrap0_s6_clk_src.clkr,
3398 [GCC_QUPV3_WRAP0_S7_CLK] = &gcc_qupv3_wrap0_s7_clk.clkr,
3399 [GCC_QUPV3_WRAP0_S7_CLK_SRC] = &gcc_qupv3_wrap0_s7_clk_src.clkr,
3400 [GCC_QUPV3_WRAP1_S0_CLK] = &gcc_qupv3_wrap1_s0_clk.clkr,
3401 [GCC_QUPV3_WRAP1_S0_CLK_SRC] = &gcc_qupv3_wrap1_s0_clk_src.clkr,
3402 [GCC_QUPV3_WRAP1_S1_CLK] = &gcc_qupv3_wrap1_s1_clk.clkr,
3403 [GCC_QUPV3_WRAP1_S1_CLK_SRC] = &gcc_qupv3_wrap1_s1_clk_src.clkr,
3404 [GCC_QUPV3_WRAP1_S2_CLK] = &gcc_qupv3_wrap1_s2_clk.clkr,
3405 [GCC_QUPV3_WRAP1_S2_CLK_SRC] = &gcc_qupv3_wrap1_s2_clk_src.clkr,
3406 [GCC_QUPV3_WRAP1_S3_CLK] = &gcc_qupv3_wrap1_s3_clk.clkr,
3407 [GCC_QUPV3_WRAP1_S3_CLK_SRC] = &gcc_qupv3_wrap1_s3_clk_src.clkr,
3408 [GCC_QUPV3_WRAP1_S4_CLK] = &gcc_qupv3_wrap1_s4_clk.clkr,
3409 [GCC_QUPV3_WRAP1_S4_CLK_SRC] = &gcc_qupv3_wrap1_s4_clk_src.clkr,
3410 [GCC_QUPV3_WRAP1_S5_CLK] = &gcc_qupv3_wrap1_s5_clk.clkr,
3411 [GCC_QUPV3_WRAP1_S5_CLK_SRC] = &gcc_qupv3_wrap1_s5_clk_src.clkr,
3412 [GCC_QUPV3_WRAP1_S6_CLK] = &gcc_qupv3_wrap1_s6_clk.clkr,
3413 [GCC_QUPV3_WRAP1_S6_CLK_SRC] = &gcc_qupv3_wrap1_s6_clk_src.clkr,
3414 [GCC_QUPV3_WRAP1_S7_CLK] = &gcc_qupv3_wrap1_s7_clk.clkr,
3415 [GCC_QUPV3_WRAP1_S7_CLK_SRC] = &gcc_qupv3_wrap1_s7_clk_src.clkr,
3416 [GCC_QUPV3_WRAP_0_M_AHB_CLK] = &gcc_qupv3_wrap_0_m_ahb_clk.clkr,
3417 [GCC_QUPV3_WRAP_0_S_AHB_CLK] = &gcc_qupv3_wrap_0_s_ahb_clk.clkr,
3418 [GCC_QUPV3_WRAP_1_M_AHB_CLK] = &gcc_qupv3_wrap_1_m_ahb_clk.clkr,
3419 [GCC_QUPV3_WRAP_1_S_AHB_CLK] = &gcc_qupv3_wrap_1_s_ahb_clk.clkr,
3420 [GCC_SDCC2_AHB_CLK] = &gcc_sdcc2_ahb_clk.clkr,
3421 [GCC_SDCC2_APPS_CLK] = &gcc_sdcc2_apps_clk.clkr,
3422 [GCC_SDCC2_APPS_CLK_SRC] = &gcc_sdcc2_apps_clk_src.clkr,
3423 [GCC_SDCC4_AHB_CLK] = &gcc_sdcc4_ahb_clk.clkr,
3424 [GCC_SDCC4_APPS_CLK] = &gcc_sdcc4_apps_clk.clkr,
3425 [GCC_SDCC4_APPS_CLK_SRC] = &gcc_sdcc4_apps_clk_src.clkr,
3426 [GCC_SYS_NOC_CPUSS_AHB_CLK] = &gcc_sys_noc_cpuss_ahb_clk.clkr,
3427 [GCC_TSIF_AHB_CLK] = &gcc_tsif_ahb_clk.clkr,
3428 [GCC_TSIF_INACTIVITY_TIMERS_CLK] =
3429 &gcc_tsif_inactivity_timers_clk.clkr,
3430 [GCC_TSIF_REF_CLK] = &gcc_tsif_ref_clk.clkr,
3431 [GCC_TSIF_REF_CLK_SRC] = &gcc_tsif_ref_clk_src.clkr,
3432 [GCC_UFS_CARD_AHB_CLK] = &gcc_ufs_card_ahb_clk.clkr,
3433 [GCC_UFS_CARD_AXI_CLK] = &gcc_ufs_card_axi_clk.clkr,
3434 [GCC_UFS_CARD_AXI_CLK_SRC] = &gcc_ufs_card_axi_clk_src.clkr,
3435 [GCC_UFS_CARD_CLKREF_CLK] = &gcc_ufs_card_clkref_clk.clkr,
3436 [GCC_UFS_CARD_ICE_CORE_CLK] = &gcc_ufs_card_ice_core_clk.clkr,
3437 [GCC_UFS_CARD_ICE_CORE_CLK_SRC] = &gcc_ufs_card_ice_core_clk_src.clkr,
3438 [GCC_UFS_CARD_PHY_AUX_CLK] = &gcc_ufs_card_phy_aux_clk.clkr,
3439 [GCC_UFS_CARD_PHY_AUX_CLK_SRC] = &gcc_ufs_card_phy_aux_clk_src.clkr,
3440 [GCC_UFS_CARD_RX_SYMBOL_0_CLK] = &gcc_ufs_card_rx_symbol_0_clk.clkr,
3441 [GCC_UFS_CARD_RX_SYMBOL_1_CLK] = &gcc_ufs_card_rx_symbol_1_clk.clkr,
3442 [GCC_UFS_CARD_TX_SYMBOL_0_CLK] = &gcc_ufs_card_tx_symbol_0_clk.clkr,
3443 [GCC_UFS_CARD_UNIPRO_CORE_CLK] = &gcc_ufs_card_unipro_core_clk.clkr,
3444 [GCC_UFS_CARD_UNIPRO_CORE_CLK_SRC] =
3445 &gcc_ufs_card_unipro_core_clk_src.clkr,
3446 [GCC_UFS_MEM_CLKREF_CLK] = &gcc_ufs_mem_clkref_clk.clkr,
3447 [GCC_UFS_PHY_AHB_CLK] = &gcc_ufs_phy_ahb_clk.clkr,
3448 [GCC_UFS_PHY_AXI_CLK] = &gcc_ufs_phy_axi_clk.clkr,
3449 [GCC_UFS_PHY_AXI_CLK_SRC] = &gcc_ufs_phy_axi_clk_src.clkr,
3450 [GCC_UFS_PHY_ICE_CORE_CLK] = &gcc_ufs_phy_ice_core_clk.clkr,
3451 [GCC_UFS_PHY_ICE_CORE_CLK_SRC] = &gcc_ufs_phy_ice_core_clk_src.clkr,
3452 [GCC_UFS_PHY_PHY_AUX_CLK] = &gcc_ufs_phy_phy_aux_clk.clkr,
3453 [GCC_UFS_PHY_PHY_AUX_CLK_SRC] = &gcc_ufs_phy_phy_aux_clk_src.clkr,
3454 [GCC_UFS_PHY_RX_SYMBOL_0_CLK] = &gcc_ufs_phy_rx_symbol_0_clk.clkr,
3455 [GCC_UFS_PHY_RX_SYMBOL_1_CLK] = &gcc_ufs_phy_rx_symbol_1_clk.clkr,
3456 [GCC_UFS_PHY_TX_SYMBOL_0_CLK] = &gcc_ufs_phy_tx_symbol_0_clk.clkr,
3457 [GCC_UFS_PHY_UNIPRO_CORE_CLK] = &gcc_ufs_phy_unipro_core_clk.clkr,
3458 [GCC_UFS_PHY_UNIPRO_CORE_CLK_SRC] =
3459 &gcc_ufs_phy_unipro_core_clk_src.clkr,
3460 [GCC_USB30_PRIM_MASTER_CLK] = &gcc_usb30_prim_master_clk.clkr,
3461 [GCC_USB30_PRIM_MASTER_CLK_SRC] = &gcc_usb30_prim_master_clk_src.clkr,
3462 [GCC_USB30_PRIM_MOCK_UTMI_CLK] = &gcc_usb30_prim_mock_utmi_clk.clkr,
3463 [GCC_USB30_PRIM_MOCK_UTMI_CLK_SRC] =
3464 &gcc_usb30_prim_mock_utmi_clk_src.clkr,
3465 [GCC_USB30_PRIM_SLEEP_CLK] = &gcc_usb30_prim_sleep_clk.clkr,
3466 [GCC_USB30_SEC_MASTER_CLK] = &gcc_usb30_sec_master_clk.clkr,
3467 [GCC_USB30_SEC_MASTER_CLK_SRC] = &gcc_usb30_sec_master_clk_src.clkr,
3468 [GCC_USB30_SEC_MOCK_UTMI_CLK] = &gcc_usb30_sec_mock_utmi_clk.clkr,
3469 [GCC_USB30_SEC_MOCK_UTMI_CLK_SRC] =
3470 &gcc_usb30_sec_mock_utmi_clk_src.clkr,
3471 [GCC_USB30_SEC_SLEEP_CLK] = &gcc_usb30_sec_sleep_clk.clkr,
3472 [GCC_USB3_PRIM_CLKREF_CLK] = &gcc_usb3_prim_clkref_clk.clkr,
3473 [GCC_USB3_PRIM_PHY_AUX_CLK] = &gcc_usb3_prim_phy_aux_clk.clkr,
3474 [GCC_USB3_PRIM_PHY_AUX_CLK_SRC] = &gcc_usb3_prim_phy_aux_clk_src.clkr,
3475 [GCC_USB3_PRIM_PHY_COM_AUX_CLK] = &gcc_usb3_prim_phy_com_aux_clk.clkr,
3476 [GCC_USB3_PRIM_PHY_PIPE_CLK] = &gcc_usb3_prim_phy_pipe_clk.clkr,
3477 [GCC_USB3_SEC_CLKREF_CLK] = &gcc_usb3_sec_clkref_clk.clkr,
3478 [GCC_USB3_SEC_PHY_AUX_CLK] = &gcc_usb3_sec_phy_aux_clk.clkr,
3479 [GCC_USB3_SEC_PHY_AUX_CLK_SRC] = &gcc_usb3_sec_phy_aux_clk_src.clkr,
3480 [GCC_USB3_SEC_PHY_COM_AUX_CLK] = &gcc_usb3_sec_phy_com_aux_clk.clkr,
3481 [GCC_USB3_SEC_PHY_PIPE_CLK] = &gcc_usb3_sec_phy_pipe_clk.clkr,
3482 [GCC_USB_PHY_CFG_AHB2PHY_CLK] = &gcc_usb_phy_cfg_ahb2phy_clk.clkr,
3483 [GCC_VDDA_VS_CLK] = &gcc_vdda_vs_clk.clkr,
3484 [GCC_VDDCX_VS_CLK] = &gcc_vddcx_vs_clk.clkr,
3485 [GCC_VDDMX_VS_CLK] = &gcc_vddmx_vs_clk.clkr,
3486 [GCC_VIDEO_AHB_CLK] = &gcc_video_ahb_clk.clkr,
3487 [GCC_VIDEO_AXI_CLK] = &gcc_video_axi_clk.clkr,
3488 [GCC_VIDEO_XO_CLK] = &gcc_video_xo_clk.clkr,
3489 [GCC_VS_CTRL_AHB_CLK] = &gcc_vs_ctrl_ahb_clk.clkr,
3490 [GCC_VS_CTRL_CLK] = &gcc_vs_ctrl_clk.clkr,
3491 [GCC_VS_CTRL_CLK_SRC] = &gcc_vs_ctrl_clk_src.clkr,
3492 [GCC_VSENSOR_CLK_SRC] = &gcc_vsensor_clk_src.clkr,
3493 [GPLL0] = &gpll0.clkr,
3494 [GPLL0_OUT_EVEN] = &gpll0_out_even.clkr,
3495 [GPLL4] = &gpll4.clkr,
Amit Nischalcfb82822018-06-11 12:08:15 +05303496 [GCC_CPUSS_DVM_BUS_CLK] = &gcc_cpuss_dvm_bus_clk.clkr,
3497 [GCC_CPUSS_GNOC_CLK] = &gcc_cpuss_gnoc_clk.clkr,
Douglas Anderson4f83d9b2018-07-24 10:45:13 -07003498 [GCC_QSPI_CORE_CLK_SRC] = &gcc_qspi_core_clk_src.clkr,
3499 [GCC_QSPI_CORE_CLK] = &gcc_qspi_core_clk.clkr,
3500 [GCC_QSPI_CNOC_PERIPH_AHB_CLK] = &gcc_qspi_cnoc_periph_ahb_clk.clkr,
Taniya Das8d3e5b92018-11-30 23:51:29 +05303501#ifdef CONFIG_SDM_LPASSCC_845
3502 [GCC_LPASS_Q6_AXI_CLK] = &gcc_lpass_q6_axi_clk.clkr,
3503 [GCC_LPASS_SWAY_CLK] = &gcc_lpass_sway_clk.clkr,
3504#endif
Taniya Das06391ed2018-05-07 16:20:20 +05303505};
3506
3507static const struct qcom_reset_map gcc_sdm845_resets[] = {
3508 [GCC_MMSS_BCR] = { 0xb000 },
3509 [GCC_PCIE_0_BCR] = { 0x6b000 },
3510 [GCC_PCIE_1_BCR] = { 0x8d000 },
3511 [GCC_PCIE_PHY_BCR] = { 0x6f000 },
3512 [GCC_PDM_BCR] = { 0x33000 },
3513 [GCC_PRNG_BCR] = { 0x34000 },
3514 [GCC_QUPV3_WRAPPER_0_BCR] = { 0x17000 },
3515 [GCC_QUPV3_WRAPPER_1_BCR] = { 0x18000 },
3516 [GCC_QUSB2PHY_PRIM_BCR] = { 0x12000 },
3517 [GCC_QUSB2PHY_SEC_BCR] = { 0x12004 },
3518 [GCC_SDCC2_BCR] = { 0x14000 },
3519 [GCC_SDCC4_BCR] = { 0x16000 },
3520 [GCC_TSIF_BCR] = { 0x36000 },
3521 [GCC_UFS_CARD_BCR] = { 0x75000 },
3522 [GCC_UFS_PHY_BCR] = { 0x77000 },
3523 [GCC_USB30_PRIM_BCR] = { 0xf000 },
3524 [GCC_USB30_SEC_BCR] = { 0x10000 },
3525 [GCC_USB3_PHY_PRIM_BCR] = { 0x50000 },
3526 [GCC_USB3PHY_PHY_PRIM_BCR] = { 0x50004 },
3527 [GCC_USB3_DP_PHY_PRIM_BCR] = { 0x50008 },
3528 [GCC_USB3_PHY_SEC_BCR] = { 0x5000c },
3529 [GCC_USB3PHY_PHY_SEC_BCR] = { 0x50010 },
3530 [GCC_USB3_DP_PHY_SEC_BCR] = { 0x50014 },
3531 [GCC_USB_PHY_CFG_AHB2PHY_BCR] = { 0x6a000 },
3532 [GCC_PCIE_0_PHY_BCR] = { 0x6c01c },
3533 [GCC_PCIE_1_PHY_BCR] = { 0x8e01c },
3534};
3535
3536static struct gdsc *gcc_sdm845_gdscs[] = {
3537 [PCIE_0_GDSC] = &pcie_0_gdsc,
3538 [PCIE_1_GDSC] = &pcie_1_gdsc,
3539 [UFS_CARD_GDSC] = &ufs_card_gdsc,
3540 [UFS_PHY_GDSC] = &ufs_phy_gdsc,
3541 [USB30_PRIM_GDSC] = &usb30_prim_gdsc,
3542 [USB30_SEC_GDSC] = &usb30_sec_gdsc,
3543 [HLOS1_VOTE_AGGRE_NOC_MMU_AUDIO_TBU_GDSC] =
3544 &hlos1_vote_aggre_noc_mmu_audio_tbu_gdsc,
3545 [HLOS1_VOTE_AGGRE_NOC_MMU_PCIE_TBU_GDSC] =
3546 &hlos1_vote_aggre_noc_mmu_pcie_tbu_gdsc,
3547 [HLOS1_VOTE_AGGRE_NOC_MMU_TBU1_GDSC] =
3548 &hlos1_vote_aggre_noc_mmu_tbu1_gdsc,
3549 [HLOS1_VOTE_AGGRE_NOC_MMU_TBU2_GDSC] =
3550 &hlos1_vote_aggre_noc_mmu_tbu2_gdsc,
3551 [HLOS1_VOTE_MMNOC_MMU_TBU_HF0_GDSC] =
3552 &hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc,
3553 [HLOS1_VOTE_MMNOC_MMU_TBU_HF1_GDSC] =
3554 &hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc,
3555 [HLOS1_VOTE_MMNOC_MMU_TBU_SF_GDSC] = &hlos1_vote_mmnoc_mmu_tbu_sf_gdsc,
3556};
3557
3558static const struct regmap_config gcc_sdm845_regmap_config = {
3559 .reg_bits = 32,
3560 .reg_stride = 4,
3561 .val_bits = 32,
3562 .max_register = 0x182090,
3563 .fast_io = true,
3564};
3565
3566static const struct qcom_cc_desc gcc_sdm845_desc = {
3567 .config = &gcc_sdm845_regmap_config,
3568 .clks = gcc_sdm845_clocks,
3569 .num_clks = ARRAY_SIZE(gcc_sdm845_clocks),
3570 .resets = gcc_sdm845_resets,
3571 .num_resets = ARRAY_SIZE(gcc_sdm845_resets),
3572 .gdscs = gcc_sdm845_gdscs,
3573 .num_gdscs = ARRAY_SIZE(gcc_sdm845_gdscs),
3574};
3575
3576static const struct of_device_id gcc_sdm845_match_table[] = {
3577 { .compatible = "qcom,gcc-sdm845" },
3578 { }
3579};
3580MODULE_DEVICE_TABLE(of, gcc_sdm845_match_table);
3581
Taniya Das8b69c6d2018-08-11 07:23:56 +05303582static const struct clk_rcg_dfs_data gcc_dfs_clocks[] = {
Taniya Das1a1c7822019-10-14 15:53:04 +05303583 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s0_clk_src),
3584 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s1_clk_src),
3585 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s2_clk_src),
3586 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s3_clk_src),
3587 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s4_clk_src),
3588 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s5_clk_src),
3589 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s6_clk_src),
3590 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s7_clk_src),
3591 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s0_clk_src),
3592 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s1_clk_src),
3593 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s2_clk_src),
3594 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s3_clk_src),
3595 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s4_clk_src),
3596 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s5_clk_src),
3597 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s6_clk_src),
3598 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s7_clk_src),
Taniya Das8b69c6d2018-08-11 07:23:56 +05303599};
3600
Taniya Das06391ed2018-05-07 16:20:20 +05303601static int gcc_sdm845_probe(struct platform_device *pdev)
3602{
3603 struct regmap *regmap;
Taniya Das8b69c6d2018-08-11 07:23:56 +05303604 int ret;
Taniya Das06391ed2018-05-07 16:20:20 +05303605
3606 regmap = qcom_cc_map(pdev, &gcc_sdm845_desc);
3607 if (IS_ERR(regmap))
3608 return PTR_ERR(regmap);
3609
3610 /* Disable the GPLL0 active input to MMSS and GPU via MISC registers */
3611 regmap_update_bits(regmap, 0x09ffc, 0x3, 0x3);
3612 regmap_update_bits(regmap, 0x71028, 0x3, 0x3);
3613
Taniya Das8b69c6d2018-08-11 07:23:56 +05303614 ret = qcom_cc_register_rcg_dfs(regmap, gcc_dfs_clocks,
3615 ARRAY_SIZE(gcc_dfs_clocks));
3616 if (ret)
3617 return ret;
3618
Taniya Das06391ed2018-05-07 16:20:20 +05303619 return qcom_cc_really_probe(pdev, &gcc_sdm845_desc, regmap);
3620}
3621
3622static struct platform_driver gcc_sdm845_driver = {
3623 .probe = gcc_sdm845_probe,
3624 .driver = {
3625 .name = "gcc-sdm845",
3626 .of_match_table = gcc_sdm845_match_table,
3627 },
3628};
3629
3630static int __init gcc_sdm845_init(void)
3631{
3632 return platform_driver_register(&gcc_sdm845_driver);
3633}
Amit Kucheriab418bab2019-10-21 17:45:14 +05303634core_initcall(gcc_sdm845_init);
Taniya Das06391ed2018-05-07 16:20:20 +05303635
3636static void __exit gcc_sdm845_exit(void)
3637{
3638 platform_driver_unregister(&gcc_sdm845_driver);
3639}
3640module_exit(gcc_sdm845_exit);
3641
3642MODULE_DESCRIPTION("QTI GCC SDM845 Driver");
3643MODULE_LICENSE("GPL v2");
3644MODULE_ALIAS("platform:gcc-sdm845");