xref: /openbmc/linux/drivers/clk/qcom/gcc-sc7180.c (revision 8d20c39f063ed33012d7461c77fd5b89665e5163)
117269568STaniya Das // SPDX-License-Identifier: GPL-2.0-only
217269568STaniya Das /*
317269568STaniya Das  * Copyright (c) 2019, The Linux Foundation. All rights reserved.
417269568STaniya Das  */
517269568STaniya Das 
617269568STaniya Das #include <linux/clk-provider.h>
717269568STaniya Das #include <linux/err.h>
817269568STaniya Das #include <linux/kernel.h>
917269568STaniya Das #include <linux/module.h>
1017269568STaniya Das #include <linux/of.h>
1117269568STaniya Das #include <linux/of_device.h>
1217269568STaniya Das #include <linux/regmap.h>
1317269568STaniya Das 
1417269568STaniya Das #include <dt-bindings/clock/qcom,gcc-sc7180.h>
1517269568STaniya Das 
1617269568STaniya Das #include "clk-alpha-pll.h"
1717269568STaniya Das #include "clk-branch.h"
1817269568STaniya Das #include "clk-rcg.h"
1917269568STaniya Das #include "clk-regmap.h"
2017269568STaniya Das #include "common.h"
2117269568STaniya Das #include "gdsc.h"
2217269568STaniya Das #include "reset.h"
2317269568STaniya Das 
2417269568STaniya Das enum {
2517269568STaniya Das 	P_BI_TCXO,
2617269568STaniya Das 	P_CORE_BI_PLL_TEST_SE,
2717269568STaniya Das 	P_GPLL0_OUT_EVEN,
2817269568STaniya Das 	P_GPLL0_OUT_MAIN,
2917269568STaniya Das 	P_GPLL1_OUT_MAIN,
3017269568STaniya Das 	P_GPLL4_OUT_MAIN,
3117269568STaniya Das 	P_GPLL6_OUT_MAIN,
3217269568STaniya Das 	P_GPLL7_OUT_MAIN,
3317269568STaniya Das 	P_SLEEP_CLK,
3417269568STaniya Das };
3517269568STaniya Das 
3617269568STaniya Das static struct clk_alpha_pll gpll0 = {
3717269568STaniya Das 	.offset = 0x0,
3817269568STaniya Das 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
3917269568STaniya Das 	.clkr = {
4017269568STaniya Das 		.enable_reg = 0x52010,
4117269568STaniya Das 		.enable_mask = BIT(0),
4217269568STaniya Das 		.hw.init = &(struct clk_init_data){
4317269568STaniya Das 			.name = "gpll0",
4417269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
4517269568STaniya Das 				.fw_name = "bi_tcxo",
4617269568STaniya Das 				.name = "bi_tcxo",
4717269568STaniya Das 			},
4817269568STaniya Das 			.num_parents = 1,
4917269568STaniya Das 			.ops = &clk_alpha_pll_fixed_fabia_ops,
5017269568STaniya Das 		},
5117269568STaniya Das 	},
5217269568STaniya Das };
5317269568STaniya Das 
5417269568STaniya Das static const struct clk_div_table post_div_table_gpll0_out_even[] = {
5517269568STaniya Das 	{ 0x1, 2 },
5617269568STaniya Das 	{ }
5717269568STaniya Das };
5817269568STaniya Das 
5917269568STaniya Das static struct clk_alpha_pll_postdiv gpll0_out_even = {
6017269568STaniya Das 	.offset = 0x0,
6117269568STaniya Das 	.post_div_shift = 8,
6217269568STaniya Das 	.post_div_table = post_div_table_gpll0_out_even,
6317269568STaniya Das 	.num_post_div = ARRAY_SIZE(post_div_table_gpll0_out_even),
6417269568STaniya Das 	.width = 4,
6517269568STaniya Das 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
6617269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
6717269568STaniya Das 		.name = "gpll0_out_even",
6817269568STaniya Das 		.parent_data = &(const struct clk_parent_data){
6917269568STaniya Das 			.hw = &gpll0.clkr.hw,
7017269568STaniya Das 		},
7117269568STaniya Das 		.num_parents = 1,
7217269568STaniya Das 		.ops = &clk_alpha_pll_postdiv_fabia_ops,
7317269568STaniya Das 	},
7417269568STaniya Das };
7517269568STaniya Das 
7617269568STaniya Das static struct clk_fixed_factor gcc_pll0_main_div_cdiv = {
7717269568STaniya Das 	.mult = 1,
7817269568STaniya Das 	.div = 2,
7917269568STaniya Das 	.hw.init = &(struct clk_init_data){
8017269568STaniya Das 		.name = "gcc_pll0_main_div_cdiv",
8117269568STaniya Das 		.parent_data = &(const struct clk_parent_data){
8217269568STaniya Das 			.hw = &gpll0.clkr.hw,
8317269568STaniya Das 		},
8417269568STaniya Das 		.num_parents = 1,
8517269568STaniya Das 		.ops = &clk_fixed_factor_ops,
8617269568STaniya Das 	},
8717269568STaniya Das };
8817269568STaniya Das 
8917269568STaniya Das static struct clk_alpha_pll gpll1 = {
9017269568STaniya Das 	.offset = 0x01000,
9117269568STaniya Das 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
9217269568STaniya Das 	.clkr = {
9317269568STaniya Das 		.enable_reg = 0x52010,
9417269568STaniya Das 		.enable_mask = BIT(1),
9517269568STaniya Das 		.hw.init = &(struct clk_init_data){
9617269568STaniya Das 			.name = "gpll1",
9717269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
9817269568STaniya Das 				.fw_name = "bi_tcxo",
9917269568STaniya Das 				.name = "bi_tcxo",
10017269568STaniya Das 			},
10117269568STaniya Das 			.num_parents = 1,
10217269568STaniya Das 			.ops = &clk_alpha_pll_fixed_fabia_ops,
10317269568STaniya Das 		},
10417269568STaniya Das 	},
10517269568STaniya Das };
10617269568STaniya Das 
10717269568STaniya Das static struct clk_alpha_pll gpll4 = {
10817269568STaniya Das 	.offset = 0x76000,
10917269568STaniya Das 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
11017269568STaniya Das 	.clkr = {
11117269568STaniya Das 		.enable_reg = 0x52010,
11217269568STaniya Das 		.enable_mask = BIT(4),
11317269568STaniya Das 		.hw.init = &(struct clk_init_data){
11417269568STaniya Das 			.name = "gpll4",
11517269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
11617269568STaniya Das 				.fw_name = "bi_tcxo",
11717269568STaniya Das 				.name = "bi_tcxo",
11817269568STaniya Das 			},
11917269568STaniya Das 			.num_parents = 1,
12017269568STaniya Das 			.ops = &clk_alpha_pll_fixed_fabia_ops,
12117269568STaniya Das 		},
12217269568STaniya Das 	},
12317269568STaniya Das };
12417269568STaniya Das 
12517269568STaniya Das static struct clk_alpha_pll gpll6 = {
12617269568STaniya Das 	.offset = 0x13000,
12717269568STaniya Das 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
12817269568STaniya Das 	.clkr = {
12917269568STaniya Das 		.enable_reg = 0x52010,
13017269568STaniya Das 		.enable_mask = BIT(6),
13117269568STaniya Das 		.hw.init = &(struct clk_init_data){
13217269568STaniya Das 			.name = "gpll6",
13317269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
13417269568STaniya Das 				.fw_name = "bi_tcxo",
13517269568STaniya Das 				.name = "bi_tcxo",
13617269568STaniya Das 			},
13717269568STaniya Das 			.num_parents = 1,
13817269568STaniya Das 			.ops = &clk_alpha_pll_fixed_fabia_ops,
13917269568STaniya Das 		},
14017269568STaniya Das 	},
14117269568STaniya Das };
14217269568STaniya Das 
14317269568STaniya Das static struct clk_alpha_pll gpll7 = {
14417269568STaniya Das 	.offset = 0x27000,
14517269568STaniya Das 	.regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
14617269568STaniya Das 	.clkr = {
14717269568STaniya Das 		.enable_reg = 0x52010,
14817269568STaniya Das 		.enable_mask = BIT(7),
14917269568STaniya Das 		.hw.init = &(struct clk_init_data){
15017269568STaniya Das 			.name = "gpll7",
15117269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
15217269568STaniya Das 				.fw_name = "bi_tcxo",
15317269568STaniya Das 				.name = "bi_tcxo",
15417269568STaniya Das 			},
15517269568STaniya Das 			.num_parents = 1,
15617269568STaniya Das 			.ops = &clk_alpha_pll_fixed_fabia_ops,
15717269568STaniya Das 		},
15817269568STaniya Das 	},
15917269568STaniya Das };
16017269568STaniya Das 
16117269568STaniya Das static const struct parent_map gcc_parent_map_0[] = {
16217269568STaniya Das 	{ P_BI_TCXO, 0 },
16317269568STaniya Das 	{ P_GPLL0_OUT_MAIN, 1 },
16417269568STaniya Das 	{ P_GPLL0_OUT_EVEN, 6 },
16517269568STaniya Das 	{ P_CORE_BI_PLL_TEST_SE, 7 },
16617269568STaniya Das };
16717269568STaniya Das 
16817269568STaniya Das static const struct clk_parent_data gcc_parent_data_0[] = {
16917269568STaniya Das 	{ .fw_name = "bi_tcxo", .name = "bi_tcxo" },
17017269568STaniya Das 	{ .hw = &gpll0.clkr.hw },
17117269568STaniya Das 	{ .hw = &gpll0_out_even.clkr.hw },
17217269568STaniya Das 	{ .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
17317269568STaniya Das };
17417269568STaniya Das 
17517269568STaniya Das static const struct clk_parent_data gcc_parent_data_0_ao[] = {
17617269568STaniya Das 	{ .fw_name = "bi_tcxo_ao", .name = "bi_tcxo_ao" },
17717269568STaniya Das 	{ .hw = &gpll0.clkr.hw },
17817269568STaniya Das 	{ .hw = &gpll0_out_even.clkr.hw },
17917269568STaniya Das 	{ .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
18017269568STaniya Das };
18117269568STaniya Das 
18217269568STaniya Das static const struct parent_map gcc_parent_map_1[] = {
18317269568STaniya Das 	{ P_BI_TCXO, 0 },
18417269568STaniya Das 	{ P_GPLL0_OUT_MAIN, 1 },
18517269568STaniya Das 	{ P_GPLL6_OUT_MAIN, 2 },
18617269568STaniya Das 	{ P_GPLL0_OUT_EVEN, 6 },
18717269568STaniya Das 	{ P_CORE_BI_PLL_TEST_SE, 7 },
18817269568STaniya Das };
18917269568STaniya Das 
19017269568STaniya Das static const struct clk_parent_data gcc_parent_data_1[] = {
19117269568STaniya Das 	{ .fw_name = "bi_tcxo", .name = "bi_tcxo" },
19217269568STaniya Das 	{ .hw = &gpll0.clkr.hw },
19317269568STaniya Das 	{ .hw = &gpll6.clkr.hw },
19417269568STaniya Das 	{ .hw = &gpll0_out_even.clkr.hw },
19517269568STaniya Das 	{ .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
19617269568STaniya Das };
19717269568STaniya Das 
19817269568STaniya Das static const struct parent_map gcc_parent_map_2[] = {
19917269568STaniya Das 	{ P_BI_TCXO, 0 },
20017269568STaniya Das 	{ P_GPLL0_OUT_MAIN, 1 },
20117269568STaniya Das 	{ P_GPLL1_OUT_MAIN, 4 },
20217269568STaniya Das 	{ P_GPLL4_OUT_MAIN, 5 },
20317269568STaniya Das 	{ P_GPLL0_OUT_EVEN, 6 },
20417269568STaniya Das 	{ P_CORE_BI_PLL_TEST_SE, 7 },
20517269568STaniya Das };
20617269568STaniya Das 
20717269568STaniya Das static const struct clk_parent_data gcc_parent_data_2[] = {
20817269568STaniya Das 	{ .fw_name = "bi_tcxo", .name = "bi_tcxo" },
20917269568STaniya Das 	{ .hw = &gpll0.clkr.hw },
21017269568STaniya Das 	{ .hw = &gpll1.clkr.hw },
21117269568STaniya Das 	{ .hw = &gpll4.clkr.hw },
21217269568STaniya Das 	{ .hw = &gpll0_out_even.clkr.hw },
21317269568STaniya Das 	{ .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
21417269568STaniya Das };
21517269568STaniya Das 
21617269568STaniya Das static const struct parent_map gcc_parent_map_3[] = {
21717269568STaniya Das 	{ P_BI_TCXO, 0 },
21817269568STaniya Das 	{ P_GPLL0_OUT_MAIN, 1 },
21917269568STaniya Das 	{ P_CORE_BI_PLL_TEST_SE, 7 },
22017269568STaniya Das };
22117269568STaniya Das 
22217269568STaniya Das static const struct clk_parent_data gcc_parent_data_3[] = {
22317269568STaniya Das 	{ .fw_name = "bi_tcxo", .name = "bi_tcxo" },
22417269568STaniya Das 	{ .hw = &gpll0.clkr.hw },
22517269568STaniya Das 	{ .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
22617269568STaniya Das };
22717269568STaniya Das 
22817269568STaniya Das static const struct parent_map gcc_parent_map_4[] = {
22917269568STaniya Das 	{ P_BI_TCXO, 0 },
23017269568STaniya Das 	{ P_GPLL0_OUT_MAIN, 1 },
23117269568STaniya Das 	{ P_SLEEP_CLK, 5 },
23217269568STaniya Das 	{ P_GPLL0_OUT_EVEN, 6 },
23317269568STaniya Das 	{ P_CORE_BI_PLL_TEST_SE, 7 },
23417269568STaniya Das };
23517269568STaniya Das 
23617269568STaniya Das static const struct clk_parent_data gcc_parent_data_4[] = {
23717269568STaniya Das 	{ .fw_name = "bi_tcxo", .name = "bi_tcxo" },
23817269568STaniya Das 	{ .hw = &gpll0.clkr.hw },
23917269568STaniya Das 	{ .fw_name = "sleep_clk", .name = "sleep_clk" },
24017269568STaniya Das 	{ .hw = &gpll0_out_even.clkr.hw },
24117269568STaniya Das 	{ .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
24217269568STaniya Das };
24317269568STaniya Das 
24417269568STaniya Das static const struct parent_map gcc_parent_map_5[] = {
24517269568STaniya Das 	{ P_BI_TCXO, 0 },
24617269568STaniya Das 	{ P_GPLL0_OUT_MAIN, 1 },
24717269568STaniya Das 	{ P_GPLL7_OUT_MAIN, 3 },
24817269568STaniya Das 	{ P_GPLL0_OUT_EVEN, 6 },
24917269568STaniya Das 	{ P_CORE_BI_PLL_TEST_SE, 7 },
25017269568STaniya Das };
25117269568STaniya Das 
25217269568STaniya Das static const struct clk_parent_data gcc_parent_data_5[] = {
25317269568STaniya Das 	{ .fw_name = "bi_tcxo", .name = "bi_tcxo" },
25417269568STaniya Das 	{ .hw = &gpll0.clkr.hw },
25517269568STaniya Das 	{ .hw = &gpll7.clkr.hw },
25617269568STaniya Das 	{ .hw = &gpll0_out_even.clkr.hw },
25717269568STaniya Das 	{ .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
25817269568STaniya Das };
25917269568STaniya Das 
26017269568STaniya Das static const struct parent_map gcc_parent_map_6[] = {
26117269568STaniya Das 	{ P_BI_TCXO, 0 },
26217269568STaniya Das 	{ P_GPLL0_OUT_MAIN, 1 },
26317269568STaniya Das 	{ P_SLEEP_CLK, 5 },
26417269568STaniya Das 	{ P_CORE_BI_PLL_TEST_SE, 7 },
26517269568STaniya Das };
26617269568STaniya Das 
26717269568STaniya Das static const struct clk_parent_data gcc_parent_data_6[] = {
26817269568STaniya Das 	{ .fw_name = "bi_tcxo", .name = "bi_tcxo" },
26917269568STaniya Das 	{ .hw = &gpll0.clkr.hw },
27017269568STaniya Das 	{ .fw_name = "sleep_clk", .name = "sleep_clk" },
27117269568STaniya Das 	{ .fw_name = "core_bi_pll_test_se", .name = "core_bi_pll_test_se" },
27217269568STaniya Das };
27317269568STaniya Das 
27417269568STaniya Das static const struct freq_tbl ftbl_gcc_cpuss_ahb_clk_src[] = {
27517269568STaniya Das 	F(19200000, P_BI_TCXO, 1, 0, 0),
27617269568STaniya Das 	{ }
27717269568STaniya Das };
27817269568STaniya Das 
27917269568STaniya Das static struct clk_rcg2 gcc_cpuss_ahb_clk_src = {
28017269568STaniya Das 	.cmd_rcgr = 0x48014,
28117269568STaniya Das 	.mnd_width = 0,
28217269568STaniya Das 	.hid_width = 5,
28317269568STaniya Das 	.parent_map = gcc_parent_map_0,
28417269568STaniya Das 	.freq_tbl = ftbl_gcc_cpuss_ahb_clk_src,
28517269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
28617269568STaniya Das 		.name = "gcc_cpuss_ahb_clk_src",
28717269568STaniya Das 		.parent_data = gcc_parent_data_0_ao,
28817269568STaniya Das 		.num_parents = 4,
28917269568STaniya Das 		.flags = CLK_SET_RATE_PARENT,
29017269568STaniya Das 		.ops = &clk_rcg2_ops,
29117269568STaniya Das 		},
29217269568STaniya Das };
29317269568STaniya Das 
29417269568STaniya Das static const struct freq_tbl ftbl_gcc_gp1_clk_src[] = {
29517269568STaniya Das 	F(19200000, P_BI_TCXO, 1, 0, 0),
29617269568STaniya Das 	F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
29717269568STaniya Das 	F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
29817269568STaniya Das 	F(100000000, P_GPLL0_OUT_EVEN, 3, 0, 0),
29917269568STaniya Das 	F(200000000, P_GPLL0_OUT_EVEN, 1.5, 0, 0),
30017269568STaniya Das 	{ }
30117269568STaniya Das };
30217269568STaniya Das 
30317269568STaniya Das static struct clk_rcg2 gcc_gp1_clk_src = {
30417269568STaniya Das 	.cmd_rcgr = 0x64004,
30517269568STaniya Das 	.mnd_width = 8,
30617269568STaniya Das 	.hid_width = 5,
30717269568STaniya Das 	.parent_map = gcc_parent_map_4,
30817269568STaniya Das 	.freq_tbl = ftbl_gcc_gp1_clk_src,
30917269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
31017269568STaniya Das 		.name = "gcc_gp1_clk_src",
31117269568STaniya Das 		.parent_data = gcc_parent_data_4,
31217269568STaniya Das 		.num_parents = 5,
31317269568STaniya Das 		.ops = &clk_rcg2_ops,
31417269568STaniya Das 	},
31517269568STaniya Das };
31617269568STaniya Das 
31717269568STaniya Das static struct clk_rcg2 gcc_gp2_clk_src = {
31817269568STaniya Das 	.cmd_rcgr = 0x65004,
31917269568STaniya Das 	.mnd_width = 8,
32017269568STaniya Das 	.hid_width = 5,
32117269568STaniya Das 	.parent_map = gcc_parent_map_4,
32217269568STaniya Das 	.freq_tbl = ftbl_gcc_gp1_clk_src,
32317269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
32417269568STaniya Das 		.name = "gcc_gp2_clk_src",
32517269568STaniya Das 		.parent_data = gcc_parent_data_4,
32617269568STaniya Das 		.num_parents = 5,
32717269568STaniya Das 		.ops = &clk_rcg2_ops,
32817269568STaniya Das 	},
32917269568STaniya Das };
33017269568STaniya Das 
33117269568STaniya Das static struct clk_rcg2 gcc_gp3_clk_src = {
33217269568STaniya Das 	.cmd_rcgr = 0x66004,
33317269568STaniya Das 	.mnd_width = 8,
33417269568STaniya Das 	.hid_width = 5,
33517269568STaniya Das 	.parent_map = gcc_parent_map_4,
33617269568STaniya Das 	.freq_tbl = ftbl_gcc_gp1_clk_src,
33717269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
33817269568STaniya Das 		.name = "gcc_gp3_clk_src",
33917269568STaniya Das 		.parent_data = gcc_parent_data_4,
34017269568STaniya Das 		.num_parents = 5,
34117269568STaniya Das 		.ops = &clk_rcg2_ops,
34217269568STaniya Das 	},
34317269568STaniya Das };
34417269568STaniya Das 
34517269568STaniya Das static const struct freq_tbl ftbl_gcc_pdm2_clk_src[] = {
34617269568STaniya Das 	F(19200000, P_BI_TCXO, 1, 0, 0),
34717269568STaniya Das 	F(60000000, P_GPLL0_OUT_EVEN, 5, 0, 0),
34817269568STaniya Das 	{ }
34917269568STaniya Das };
35017269568STaniya Das 
35117269568STaniya Das static struct clk_rcg2 gcc_pdm2_clk_src = {
35217269568STaniya Das 	.cmd_rcgr = 0x33010,
35317269568STaniya Das 	.mnd_width = 0,
35417269568STaniya Das 	.hid_width = 5,
35517269568STaniya Das 	.parent_map = gcc_parent_map_0,
35617269568STaniya Das 	.freq_tbl = ftbl_gcc_pdm2_clk_src,
35717269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
35817269568STaniya Das 		.name = "gcc_pdm2_clk_src",
35917269568STaniya Das 		.parent_data = gcc_parent_data_0,
36017269568STaniya Das 		.num_parents = 4,
36117269568STaniya Das 		.ops = &clk_rcg2_ops,
36217269568STaniya Das 	},
36317269568STaniya Das };
36417269568STaniya Das 
36517269568STaniya Das static const struct freq_tbl ftbl_gcc_qspi_core_clk_src[] = {
36617269568STaniya Das 	F(75000000, P_GPLL0_OUT_EVEN, 4, 0, 0),
36717269568STaniya Das 	F(150000000, P_GPLL0_OUT_EVEN, 2, 0, 0),
36817269568STaniya Das 	F(300000000, P_GPLL0_OUT_EVEN, 1, 0, 0),
36917269568STaniya Das 	{ }
37017269568STaniya Das };
37117269568STaniya Das 
37217269568STaniya Das static struct clk_rcg2 gcc_qspi_core_clk_src = {
37317269568STaniya Das 	.cmd_rcgr = 0x4b00c,
37417269568STaniya Das 	.mnd_width = 0,
37517269568STaniya Das 	.hid_width = 5,
37617269568STaniya Das 	.parent_map = gcc_parent_map_2,
37717269568STaniya Das 	.freq_tbl = ftbl_gcc_qspi_core_clk_src,
37817269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
37917269568STaniya Das 		.name = "gcc_qspi_core_clk_src",
38017269568STaniya Das 		.parent_data = gcc_parent_data_2,
38117269568STaniya Das 		.num_parents = 6,
38217269568STaniya Das 		.ops = &clk_rcg2_ops,
38317269568STaniya Das 	},
38417269568STaniya Das };
38517269568STaniya Das 
38617269568STaniya Das static const struct freq_tbl ftbl_gcc_qupv3_wrap0_s0_clk_src[] = {
38717269568STaniya Das 	F(7372800, P_GPLL0_OUT_EVEN, 1, 384, 15625),
38817269568STaniya Das 	F(14745600, P_GPLL0_OUT_EVEN, 1, 768, 15625),
38917269568STaniya Das 	F(19200000, P_BI_TCXO, 1, 0, 0),
39017269568STaniya Das 	F(29491200, P_GPLL0_OUT_EVEN, 1, 1536, 15625),
39117269568STaniya Das 	F(32000000, P_GPLL0_OUT_EVEN, 1, 8, 75),
39217269568STaniya Das 	F(48000000, P_GPLL0_OUT_EVEN, 1, 4, 25),
39317269568STaniya Das 	F(64000000, P_GPLL0_OUT_EVEN, 1, 16, 75),
39417269568STaniya Das 	F(75000000, P_GPLL0_OUT_EVEN, 4, 0, 0),
39517269568STaniya Das 	F(80000000, P_GPLL0_OUT_EVEN, 1, 4, 15),
39617269568STaniya Das 	F(96000000, P_GPLL0_OUT_EVEN, 1, 8, 25),
39717269568STaniya Das 	F(100000000, P_GPLL0_OUT_EVEN, 3, 0, 0),
39817269568STaniya Das 	F(102400000, P_GPLL0_OUT_EVEN, 1, 128, 375),
39917269568STaniya Das 	F(112000000, P_GPLL0_OUT_EVEN, 1, 28, 75),
40017269568STaniya Das 	F(117964800, P_GPLL0_OUT_EVEN, 1, 6144, 15625),
40117269568STaniya Das 	F(120000000, P_GPLL0_OUT_EVEN, 2.5, 0, 0),
40217269568STaniya Das 	F(128000000, P_GPLL6_OUT_MAIN, 3, 0, 0),
40317269568STaniya Das 	{ }
40417269568STaniya Das };
40517269568STaniya Das 
40617269568STaniya Das static struct clk_init_data gcc_qupv3_wrap0_s0_clk_src_init = {
40717269568STaniya Das 	.name = "gcc_qupv3_wrap0_s0_clk_src",
40817269568STaniya Das 	.parent_data = gcc_parent_data_0,
40917269568STaniya Das 	.num_parents = 4,
41017269568STaniya Das 	.ops = &clk_rcg2_ops,
41117269568STaniya Das };
41217269568STaniya Das 
41317269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap0_s0_clk_src = {
41417269568STaniya Das 	.cmd_rcgr = 0x17034,
41517269568STaniya Das 	.mnd_width = 16,
41617269568STaniya Das 	.hid_width = 5,
41717269568STaniya Das 	.parent_map = gcc_parent_map_0,
41817269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
41917269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap0_s0_clk_src_init,
42017269568STaniya Das };
42117269568STaniya Das 
42217269568STaniya Das static struct clk_init_data gcc_qupv3_wrap0_s1_clk_src_init = {
42317269568STaniya Das 	.name = "gcc_qupv3_wrap0_s1_clk_src",
42417269568STaniya Das 	.parent_data = gcc_parent_data_0,
42517269568STaniya Das 	.num_parents = 4,
42617269568STaniya Das 	.ops = &clk_rcg2_ops,
42717269568STaniya Das };
42817269568STaniya Das 
42917269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap0_s1_clk_src = {
43017269568STaniya Das 	.cmd_rcgr = 0x17164,
43117269568STaniya Das 	.mnd_width = 16,
43217269568STaniya Das 	.hid_width = 5,
43317269568STaniya Das 	.parent_map = gcc_parent_map_0,
43417269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
43517269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap0_s1_clk_src_init,
43617269568STaniya Das };
43717269568STaniya Das 
43817269568STaniya Das static struct clk_init_data gcc_qupv3_wrap0_s2_clk_src_init = {
43917269568STaniya Das 	.name = "gcc_qupv3_wrap0_s2_clk_src",
44017269568STaniya Das 	.parent_data = gcc_parent_data_0,
44117269568STaniya Das 	.num_parents = 4,
44217269568STaniya Das 	.ops = &clk_rcg2_ops,
44317269568STaniya Das };
44417269568STaniya Das 
44517269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap0_s2_clk_src = {
44617269568STaniya Das 	.cmd_rcgr = 0x17294,
44717269568STaniya Das 	.mnd_width = 16,
44817269568STaniya Das 	.hid_width = 5,
44917269568STaniya Das 	.parent_map = gcc_parent_map_0,
45017269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
45117269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap0_s2_clk_src_init,
45217269568STaniya Das };
45317269568STaniya Das 
45417269568STaniya Das static struct clk_init_data gcc_qupv3_wrap0_s3_clk_src_init = {
45517269568STaniya Das 	.name = "gcc_qupv3_wrap0_s3_clk_src",
45617269568STaniya Das 	.parent_data = gcc_parent_data_0,
45717269568STaniya Das 	.num_parents = 4,
45817269568STaniya Das 	.ops = &clk_rcg2_ops,
45917269568STaniya Das };
46017269568STaniya Das 
46117269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap0_s3_clk_src = {
46217269568STaniya Das 	.cmd_rcgr = 0x173c4,
46317269568STaniya Das 	.mnd_width = 16,
46417269568STaniya Das 	.hid_width = 5,
46517269568STaniya Das 	.parent_map = gcc_parent_map_0,
46617269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
46717269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap0_s3_clk_src_init,
46817269568STaniya Das };
46917269568STaniya Das 
47017269568STaniya Das static struct clk_init_data gcc_qupv3_wrap0_s4_clk_src_init = {
47117269568STaniya Das 	.name = "gcc_qupv3_wrap0_s4_clk_src",
47217269568STaniya Das 	.parent_data = gcc_parent_data_0,
47317269568STaniya Das 	.num_parents = 4,
47417269568STaniya Das 	.ops = &clk_rcg2_ops,
47517269568STaniya Das };
47617269568STaniya Das 
47717269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap0_s4_clk_src = {
47817269568STaniya Das 	.cmd_rcgr = 0x174f4,
47917269568STaniya Das 	.mnd_width = 16,
48017269568STaniya Das 	.hid_width = 5,
48117269568STaniya Das 	.parent_map = gcc_parent_map_0,
48217269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
48317269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap0_s4_clk_src_init,
48417269568STaniya Das };
48517269568STaniya Das 
48617269568STaniya Das static struct clk_init_data gcc_qupv3_wrap0_s5_clk_src_init = {
48717269568STaniya Das 	.name = "gcc_qupv3_wrap0_s5_clk_src",
48817269568STaniya Das 	.parent_data = gcc_parent_data_0,
48917269568STaniya Das 	.num_parents = 4,
49017269568STaniya Das 	.ops = &clk_rcg2_ops,
49117269568STaniya Das };
49217269568STaniya Das 
49317269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap0_s5_clk_src = {
49417269568STaniya Das 	.cmd_rcgr = 0x17624,
49517269568STaniya Das 	.mnd_width = 16,
49617269568STaniya Das 	.hid_width = 5,
49717269568STaniya Das 	.parent_map = gcc_parent_map_0,
49817269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
49917269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap0_s5_clk_src_init,
50017269568STaniya Das };
50117269568STaniya Das 
50217269568STaniya Das static struct clk_init_data gcc_qupv3_wrap1_s0_clk_src_init = {
50317269568STaniya Das 	.name = "gcc_qupv3_wrap1_s0_clk_src",
50417269568STaniya Das 	.parent_data = gcc_parent_data_0,
50517269568STaniya Das 	.num_parents = 4,
50617269568STaniya Das 	.ops = &clk_rcg2_ops,
50717269568STaniya Das };
50817269568STaniya Das 
50917269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap1_s0_clk_src = {
51017269568STaniya Das 	.cmd_rcgr = 0x18018,
51117269568STaniya Das 	.mnd_width = 16,
51217269568STaniya Das 	.hid_width = 5,
51317269568STaniya Das 	.parent_map = gcc_parent_map_0,
51417269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
51517269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap1_s0_clk_src_init,
51617269568STaniya Das };
51717269568STaniya Das 
51817269568STaniya Das static struct clk_init_data gcc_qupv3_wrap1_s1_clk_src_init = {
51917269568STaniya Das 	.name = "gcc_qupv3_wrap1_s1_clk_src",
52017269568STaniya Das 	.parent_data = gcc_parent_data_0,
52117269568STaniya Das 	.num_parents = 4,
52217269568STaniya Das 	.ops = &clk_rcg2_ops,
52317269568STaniya Das };
52417269568STaniya Das 
52517269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap1_s1_clk_src = {
52617269568STaniya Das 	.cmd_rcgr = 0x18148,
52717269568STaniya Das 	.mnd_width = 16,
52817269568STaniya Das 	.hid_width = 5,
52917269568STaniya Das 	.parent_map = gcc_parent_map_0,
53017269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
53117269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap1_s1_clk_src_init,
53217269568STaniya Das };
53317269568STaniya Das 
53417269568STaniya Das static struct clk_init_data gcc_qupv3_wrap1_s2_clk_src_init = {
53517269568STaniya Das 	.name = "gcc_qupv3_wrap1_s2_clk_src",
53617269568STaniya Das 	.parent_data = gcc_parent_data_0,
53717269568STaniya Das 	.num_parents = 4,
53817269568STaniya Das 	.ops = &clk_rcg2_ops,
53917269568STaniya Das };
54017269568STaniya Das 
54117269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap1_s2_clk_src = {
54217269568STaniya Das 	.cmd_rcgr = 0x18278,
54317269568STaniya Das 	.mnd_width = 16,
54417269568STaniya Das 	.hid_width = 5,
54517269568STaniya Das 	.parent_map = gcc_parent_map_0,
54617269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
54717269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap1_s2_clk_src_init,
54817269568STaniya Das };
54917269568STaniya Das 
55017269568STaniya Das static struct clk_init_data gcc_qupv3_wrap1_s3_clk_src_init = {
55117269568STaniya Das 	.name = "gcc_qupv3_wrap1_s3_clk_src",
55217269568STaniya Das 	.parent_data = gcc_parent_data_0,
55317269568STaniya Das 	.num_parents = 4,
55417269568STaniya Das 	.ops = &clk_rcg2_ops,
55517269568STaniya Das };
55617269568STaniya Das 
55717269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap1_s3_clk_src = {
55817269568STaniya Das 	.cmd_rcgr = 0x183a8,
55917269568STaniya Das 	.mnd_width = 16,
56017269568STaniya Das 	.hid_width = 5,
56117269568STaniya Das 	.parent_map = gcc_parent_map_0,
56217269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
56317269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap1_s3_clk_src_init,
56417269568STaniya Das };
56517269568STaniya Das 
56617269568STaniya Das static struct clk_init_data gcc_qupv3_wrap1_s4_clk_src_init = {
56717269568STaniya Das 	.name = "gcc_qupv3_wrap1_s4_clk_src",
56817269568STaniya Das 	.parent_data = gcc_parent_data_0,
56917269568STaniya Das 	.num_parents = 4,
57017269568STaniya Das 	.ops = &clk_rcg2_ops,
57117269568STaniya Das };
57217269568STaniya Das 
57317269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap1_s4_clk_src = {
57417269568STaniya Das 	.cmd_rcgr = 0x184d8,
57517269568STaniya Das 	.mnd_width = 16,
57617269568STaniya Das 	.hid_width = 5,
57717269568STaniya Das 	.parent_map = gcc_parent_map_0,
57817269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
57917269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap1_s4_clk_src_init,
58017269568STaniya Das };
58117269568STaniya Das 
58217269568STaniya Das static struct clk_init_data gcc_qupv3_wrap1_s5_clk_src_init = {
58317269568STaniya Das 	.name = "gcc_qupv3_wrap1_s5_clk_src",
58417269568STaniya Das 	.parent_data = gcc_parent_data_0,
58517269568STaniya Das 	.num_parents = 4,
58617269568STaniya Das 	.ops = &clk_rcg2_ops,
58717269568STaniya Das };
58817269568STaniya Das 
58917269568STaniya Das static struct clk_rcg2 gcc_qupv3_wrap1_s5_clk_src = {
59017269568STaniya Das 	.cmd_rcgr = 0x18608,
59117269568STaniya Das 	.mnd_width = 16,
59217269568STaniya Das 	.hid_width = 5,
59317269568STaniya Das 	.parent_map = gcc_parent_map_0,
59417269568STaniya Das 	.freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src,
59517269568STaniya Das 	.clkr.hw.init = &gcc_qupv3_wrap1_s5_clk_src_init,
59617269568STaniya Das };
59717269568STaniya Das 
59817269568STaniya Das 
59917269568STaniya Das static const struct freq_tbl ftbl_gcc_sdcc1_apps_clk_src[] = {
60017269568STaniya Das 	F(144000, P_BI_TCXO, 16, 3, 25),
60117269568STaniya Das 	F(400000, P_BI_TCXO, 12, 1, 4),
60217269568STaniya Das 	F(19200000, P_BI_TCXO, 1, 0, 0),
60317269568STaniya Das 	F(20000000, P_GPLL0_OUT_EVEN, 5, 1, 3),
60417269568STaniya Das 	F(25000000, P_GPLL0_OUT_EVEN, 6, 1, 2),
60517269568STaniya Das 	F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
60617269568STaniya Das 	F(100000000, P_GPLL0_OUT_EVEN, 3, 0, 0),
60717269568STaniya Das 	F(192000000, P_GPLL6_OUT_MAIN, 2, 0, 0),
60817269568STaniya Das 	F(384000000, P_GPLL6_OUT_MAIN, 1, 0, 0),
60917269568STaniya Das 	{ }
61017269568STaniya Das };
61117269568STaniya Das 
61217269568STaniya Das static struct clk_rcg2 gcc_sdcc1_apps_clk_src = {
61317269568STaniya Das 	.cmd_rcgr = 0x12028,
61417269568STaniya Das 	.mnd_width = 8,
61517269568STaniya Das 	.hid_width = 5,
61617269568STaniya Das 	.parent_map = gcc_parent_map_1,
61717269568STaniya Das 	.freq_tbl = ftbl_gcc_sdcc1_apps_clk_src,
61817269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
61917269568STaniya Das 		.name = "gcc_sdcc1_apps_clk_src",
62017269568STaniya Das 		.parent_data = gcc_parent_data_1,
62117269568STaniya Das 		.num_parents = 5,
62217269568STaniya Das 		.ops = &clk_rcg2_ops,
62317269568STaniya Das 	},
62417269568STaniya Das };
62517269568STaniya Das 
62617269568STaniya Das static const struct freq_tbl ftbl_gcc_sdcc1_ice_core_clk_src[] = {
62717269568STaniya Das 	F(100000000, P_GPLL0_OUT_EVEN, 3, 0, 0),
62817269568STaniya Das 	F(150000000, P_GPLL0_OUT_EVEN, 2, 0, 0),
62917269568STaniya Das 	F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
63017269568STaniya Das 	F(300000000, P_GPLL0_OUT_EVEN, 1, 0, 0),
63117269568STaniya Das 	{ }
63217269568STaniya Das };
63317269568STaniya Das 
63417269568STaniya Das static struct clk_rcg2 gcc_sdcc1_ice_core_clk_src = {
63517269568STaniya Das 	.cmd_rcgr = 0x12010,
63617269568STaniya Das 	.mnd_width = 0,
63717269568STaniya Das 	.hid_width = 5,
63817269568STaniya Das 	.parent_map = gcc_parent_map_0,
63917269568STaniya Das 	.freq_tbl = ftbl_gcc_sdcc1_ice_core_clk_src,
64017269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
64117269568STaniya Das 		.name = "gcc_sdcc1_ice_core_clk_src",
64217269568STaniya Das 		.parent_data = gcc_parent_data_0,
64317269568STaniya Das 		.num_parents = 4,
64417269568STaniya Das 		.ops = &clk_rcg2_ops,
64517269568STaniya Das 	},
64617269568STaniya Das };
64717269568STaniya Das 
64817269568STaniya Das static const struct freq_tbl ftbl_gcc_sdcc2_apps_clk_src[] = {
64917269568STaniya Das 	F(400000, P_BI_TCXO, 12, 1, 4),
65017269568STaniya Das 	F(9600000, P_BI_TCXO, 2, 0, 0),
65117269568STaniya Das 	F(19200000, P_BI_TCXO, 1, 0, 0),
65217269568STaniya Das 	F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
65317269568STaniya Das 	F(100000000, P_GPLL0_OUT_EVEN, 3, 0, 0),
65417269568STaniya Das 	F(202000000, P_GPLL7_OUT_MAIN, 4, 0, 0),
65517269568STaniya Das 	{ }
65617269568STaniya Das };
65717269568STaniya Das 
65817269568STaniya Das static struct clk_rcg2 gcc_sdcc2_apps_clk_src = {
65917269568STaniya Das 	.cmd_rcgr = 0x1400c,
66017269568STaniya Das 	.mnd_width = 8,
66117269568STaniya Das 	.hid_width = 5,
66217269568STaniya Das 	.parent_map = gcc_parent_map_5,
66317269568STaniya Das 	.freq_tbl = ftbl_gcc_sdcc2_apps_clk_src,
66417269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
66517269568STaniya Das 		.name = "gcc_sdcc2_apps_clk_src",
66617269568STaniya Das 		.parent_data = gcc_parent_data_5,
66717269568STaniya Das 		.num_parents = 5,
66817269568STaniya Das 		.ops = &clk_rcg2_ops,
66917269568STaniya Das 	},
67017269568STaniya Das };
67117269568STaniya Das 
67217269568STaniya Das static const struct freq_tbl ftbl_gcc_ufs_phy_axi_clk_src[] = {
67317269568STaniya Das 	F(25000000, P_GPLL0_OUT_EVEN, 12, 0, 0),
67417269568STaniya Das 	F(50000000, P_GPLL0_OUT_EVEN, 6, 0, 0),
67517269568STaniya Das 	F(100000000, P_GPLL0_OUT_EVEN, 3, 0, 0),
67617269568STaniya Das 	F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
67717269568STaniya Das 	F(240000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0),
67817269568STaniya Das 	{ }
67917269568STaniya Das };
68017269568STaniya Das 
68117269568STaniya Das static struct clk_rcg2 gcc_ufs_phy_axi_clk_src = {
68217269568STaniya Das 	.cmd_rcgr = 0x77020,
68317269568STaniya Das 	.mnd_width = 8,
68417269568STaniya Das 	.hid_width = 5,
68517269568STaniya Das 	.parent_map = gcc_parent_map_0,
68617269568STaniya Das 	.freq_tbl = ftbl_gcc_ufs_phy_axi_clk_src,
68717269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
68817269568STaniya Das 		.name = "gcc_ufs_phy_axi_clk_src",
68917269568STaniya Das 		.parent_data = gcc_parent_data_0,
69017269568STaniya Das 		.num_parents = 4,
69117269568STaniya Das 		.ops = &clk_rcg2_ops,
69217269568STaniya Das 	},
69317269568STaniya Das };
69417269568STaniya Das 
69517269568STaniya Das static const struct freq_tbl ftbl_gcc_ufs_phy_ice_core_clk_src[] = {
69617269568STaniya Das 	F(37500000, P_GPLL0_OUT_EVEN, 8, 0, 0),
69717269568STaniya Das 	F(75000000, P_GPLL0_OUT_EVEN, 4, 0, 0),
69817269568STaniya Das 	F(150000000, P_GPLL0_OUT_EVEN, 2, 0, 0),
69917269568STaniya Das 	F(300000000, P_GPLL0_OUT_EVEN, 1, 0, 0),
70017269568STaniya Das 	{ }
70117269568STaniya Das };
70217269568STaniya Das 
70317269568STaniya Das static struct clk_rcg2 gcc_ufs_phy_ice_core_clk_src = {
70417269568STaniya Das 	.cmd_rcgr = 0x77048,
70517269568STaniya Das 	.mnd_width = 0,
70617269568STaniya Das 	.hid_width = 5,
70717269568STaniya Das 	.parent_map = gcc_parent_map_0,
70817269568STaniya Das 	.freq_tbl = ftbl_gcc_ufs_phy_ice_core_clk_src,
70917269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
71017269568STaniya Das 		.name = "gcc_ufs_phy_ice_core_clk_src",
71117269568STaniya Das 		.parent_data = gcc_parent_data_0,
71217269568STaniya Das 		.num_parents = 4,
71317269568STaniya Das 		.ops = &clk_rcg2_ops,
71417269568STaniya Das 	},
71517269568STaniya Das };
71617269568STaniya Das 
71717269568STaniya Das static const struct freq_tbl ftbl_gcc_ufs_phy_phy_aux_clk_src[] = {
71817269568STaniya Das 	F(9600000, P_BI_TCXO, 2, 0, 0),
71917269568STaniya Das 	F(19200000, P_BI_TCXO, 1, 0, 0),
72017269568STaniya Das 	{ }
72117269568STaniya Das };
72217269568STaniya Das 
72317269568STaniya Das static struct clk_rcg2 gcc_ufs_phy_phy_aux_clk_src = {
72417269568STaniya Das 	.cmd_rcgr = 0x77098,
72517269568STaniya Das 	.mnd_width = 0,
72617269568STaniya Das 	.hid_width = 5,
72717269568STaniya Das 	.parent_map = gcc_parent_map_3,
72817269568STaniya Das 	.freq_tbl = ftbl_gcc_ufs_phy_phy_aux_clk_src,
72917269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
73017269568STaniya Das 		.name = "gcc_ufs_phy_phy_aux_clk_src",
73117269568STaniya Das 		.parent_data = gcc_parent_data_3,
73217269568STaniya Das 		.num_parents = 3,
73317269568STaniya Das 		.ops = &clk_rcg2_ops,
73417269568STaniya Das 	},
73517269568STaniya Das };
73617269568STaniya Das 
73717269568STaniya Das static const struct freq_tbl ftbl_gcc_ufs_phy_unipro_core_clk_src[] = {
73817269568STaniya Das 	F(37500000, P_GPLL0_OUT_EVEN, 8, 0, 0),
73917269568STaniya Das 	F(75000000, P_GPLL0_OUT_EVEN, 4, 0, 0),
74017269568STaniya Das 	F(150000000, P_GPLL0_OUT_EVEN, 2, 0, 0),
74117269568STaniya Das 	{ }
74217269568STaniya Das };
74317269568STaniya Das 
74417269568STaniya Das static struct clk_rcg2 gcc_ufs_phy_unipro_core_clk_src = {
74517269568STaniya Das 	.cmd_rcgr = 0x77060,
74617269568STaniya Das 	.mnd_width = 0,
74717269568STaniya Das 	.hid_width = 5,
74817269568STaniya Das 	.parent_map = gcc_parent_map_0,
74917269568STaniya Das 	.freq_tbl = ftbl_gcc_ufs_phy_unipro_core_clk_src,
75017269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
75117269568STaniya Das 		.name = "gcc_ufs_phy_unipro_core_clk_src",
75217269568STaniya Das 		.parent_data = gcc_parent_data_0,
75317269568STaniya Das 		.num_parents = 4,
75417269568STaniya Das 		.ops = &clk_rcg2_ops,
75517269568STaniya Das 	},
75617269568STaniya Das };
75717269568STaniya Das 
75817269568STaniya Das static const struct freq_tbl ftbl_gcc_usb30_prim_master_clk_src[] = {
75917269568STaniya Das 	F(66666667, P_GPLL0_OUT_EVEN, 4.5, 0, 0),
76017269568STaniya Das 	F(133333333, P_GPLL0_OUT_MAIN, 4.5, 0, 0),
76117269568STaniya Das 	F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0),
76217269568STaniya Das 	F(240000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0),
76317269568STaniya Das 	{ }
76417269568STaniya Das };
76517269568STaniya Das 
76617269568STaniya Das static struct clk_rcg2 gcc_usb30_prim_master_clk_src = {
76717269568STaniya Das 	.cmd_rcgr = 0xf01c,
76817269568STaniya Das 	.mnd_width = 8,
76917269568STaniya Das 	.hid_width = 5,
77017269568STaniya Das 	.parent_map = gcc_parent_map_0,
77117269568STaniya Das 	.freq_tbl = ftbl_gcc_usb30_prim_master_clk_src,
77217269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
77317269568STaniya Das 		.name = "gcc_usb30_prim_master_clk_src",
77417269568STaniya Das 		.parent_data = gcc_parent_data_0,
77517269568STaniya Das 		.num_parents = 4,
77617269568STaniya Das 		.ops = &clk_rcg2_ops,
77717269568STaniya Das 	},
77817269568STaniya Das };
77917269568STaniya Das 
78017269568STaniya Das static const struct freq_tbl ftbl_gcc_usb30_prim_mock_utmi_clk_src[] = {
78117269568STaniya Das 	F(19200000, P_BI_TCXO, 1, 0, 0),
78217269568STaniya Das 	F(20000000, P_GPLL0_OUT_EVEN, 15, 0, 0),
78317269568STaniya Das 	{ }
78417269568STaniya Das };
78517269568STaniya Das 
78617269568STaniya Das static struct clk_rcg2 gcc_usb30_prim_mock_utmi_clk_src = {
78717269568STaniya Das 	.cmd_rcgr = 0xf034,
78817269568STaniya Das 	.mnd_width = 0,
78917269568STaniya Das 	.hid_width = 5,
79017269568STaniya Das 	.parent_map = gcc_parent_map_0,
79117269568STaniya Das 	.freq_tbl = ftbl_gcc_usb30_prim_mock_utmi_clk_src,
79217269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
79317269568STaniya Das 		.name = "gcc_usb30_prim_mock_utmi_clk_src",
79417269568STaniya Das 		.parent_data = gcc_parent_data_0,
79517269568STaniya Das 		.num_parents = 4,
79617269568STaniya Das 		.ops = &clk_rcg2_ops,
79717269568STaniya Das 	},
79817269568STaniya Das };
79917269568STaniya Das 
80017269568STaniya Das static const struct freq_tbl ftbl_gcc_usb3_prim_phy_aux_clk_src[] = {
80117269568STaniya Das 	F(19200000, P_BI_TCXO, 1, 0, 0),
80217269568STaniya Das 	{ }
80317269568STaniya Das };
80417269568STaniya Das 
80517269568STaniya Das static struct clk_rcg2 gcc_usb3_prim_phy_aux_clk_src = {
80617269568STaniya Das 	.cmd_rcgr = 0xf060,
80717269568STaniya Das 	.mnd_width = 0,
80817269568STaniya Das 	.hid_width = 5,
80917269568STaniya Das 	.parent_map = gcc_parent_map_6,
81017269568STaniya Das 	.freq_tbl = ftbl_gcc_usb3_prim_phy_aux_clk_src,
81117269568STaniya Das 	.clkr.hw.init = &(struct clk_init_data){
81217269568STaniya Das 		.name = "gcc_usb3_prim_phy_aux_clk_src",
81317269568STaniya Das 		.parent_data = gcc_parent_data_6,
81417269568STaniya Das 		.num_parents = 4,
81517269568STaniya Das 		.ops = &clk_rcg2_ops,
81617269568STaniya Das 	},
81717269568STaniya Das };
81817269568STaniya Das 
81917269568STaniya Das static struct clk_branch gcc_aggre_ufs_phy_axi_clk = {
82017269568STaniya Das 	.halt_reg = 0x82024,
82117269568STaniya Das 	.halt_check = BRANCH_HALT_DELAY,
82217269568STaniya Das 	.hwcg_reg = 0x82024,
82317269568STaniya Das 	.hwcg_bit = 1,
82417269568STaniya Das 	.clkr = {
82517269568STaniya Das 		.enable_reg = 0x82024,
82617269568STaniya Das 		.enable_mask = BIT(0),
82717269568STaniya Das 		.hw.init = &(struct clk_init_data){
82817269568STaniya Das 			.name = "gcc_aggre_ufs_phy_axi_clk",
82917269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
83017269568STaniya Das 				.hw = &gcc_ufs_phy_axi_clk_src.clkr.hw,
83117269568STaniya Das 			},
83217269568STaniya Das 			.num_parents = 1,
83317269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
83417269568STaniya Das 			.ops = &clk_branch2_ops,
83517269568STaniya Das 		},
83617269568STaniya Das 	},
83717269568STaniya Das };
83817269568STaniya Das 
83917269568STaniya Das static struct clk_branch gcc_aggre_usb3_prim_axi_clk = {
84017269568STaniya Das 	.halt_reg = 0x8201c,
84117269568STaniya Das 	.halt_check = BRANCH_HALT,
84217269568STaniya Das 	.clkr = {
84317269568STaniya Das 		.enable_reg = 0x8201c,
84417269568STaniya Das 		.enable_mask = BIT(0),
84517269568STaniya Das 		.hw.init = &(struct clk_init_data){
84617269568STaniya Das 			.name = "gcc_aggre_usb3_prim_axi_clk",
84717269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
84817269568STaniya Das 				.hw = &gcc_usb30_prim_master_clk_src.clkr.hw,
84917269568STaniya Das 			},
85017269568STaniya Das 			.num_parents = 1,
85117269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
85217269568STaniya Das 			.ops = &clk_branch2_ops,
85317269568STaniya Das 		},
85417269568STaniya Das 	},
85517269568STaniya Das };
85617269568STaniya Das 
85717269568STaniya Das static struct clk_branch gcc_boot_rom_ahb_clk = {
85817269568STaniya Das 	.halt_reg = 0x38004,
85917269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
86017269568STaniya Das 	.hwcg_reg = 0x38004,
86117269568STaniya Das 	.hwcg_bit = 1,
86217269568STaniya Das 	.clkr = {
86317269568STaniya Das 		.enable_reg = 0x52000,
86417269568STaniya Das 		.enable_mask = BIT(10),
86517269568STaniya Das 		.hw.init = &(struct clk_init_data){
86617269568STaniya Das 			.name = "gcc_boot_rom_ahb_clk",
86717269568STaniya Das 			.ops = &clk_branch2_ops,
86817269568STaniya Das 		},
86917269568STaniya Das 	},
87017269568STaniya Das };
87117269568STaniya Das 
87217269568STaniya Das static struct clk_branch gcc_camera_ahb_clk = {
87317269568STaniya Das 	.halt_reg = 0xb008,
87417269568STaniya Das 	.halt_check = BRANCH_HALT,
87517269568STaniya Das 	.hwcg_reg = 0xb008,
87617269568STaniya Das 	.hwcg_bit = 1,
87717269568STaniya Das 	.clkr = {
87817269568STaniya Das 		.enable_reg = 0xb008,
87917269568STaniya Das 		.enable_mask = BIT(0),
88017269568STaniya Das 		.hw.init = &(struct clk_init_data){
88117269568STaniya Das 			.name = "gcc_camera_ahb_clk",
88217269568STaniya Das 			.ops = &clk_branch2_ops,
88317269568STaniya Das 		},
88417269568STaniya Das 	},
88517269568STaniya Das };
88617269568STaniya Das 
88717269568STaniya Das static struct clk_branch gcc_camera_hf_axi_clk = {
88817269568STaniya Das 	.halt_reg = 0xb020,
88917269568STaniya Das 	.halt_check = BRANCH_HALT,
89017269568STaniya Das 	.clkr = {
89117269568STaniya Das 		.enable_reg = 0xb020,
89217269568STaniya Das 		.enable_mask = BIT(0),
89317269568STaniya Das 		.hw.init = &(struct clk_init_data){
89417269568STaniya Das 			.name = "gcc_camera_hf_axi_clk",
89517269568STaniya Das 			.ops = &clk_branch2_ops,
89617269568STaniya Das 		},
89717269568STaniya Das 	},
89817269568STaniya Das };
89917269568STaniya Das 
90017269568STaniya Das static struct clk_branch gcc_camera_throttle_hf_axi_clk = {
90117269568STaniya Das 	.halt_reg = 0xb080,
90217269568STaniya Das 	.halt_check = BRANCH_HALT,
90317269568STaniya Das 	.hwcg_reg = 0xb080,
90417269568STaniya Das 	.hwcg_bit = 1,
90517269568STaniya Das 	.clkr = {
90617269568STaniya Das 		.enable_reg = 0xb080,
90717269568STaniya Das 		.enable_mask = BIT(0),
90817269568STaniya Das 		.hw.init = &(struct clk_init_data){
90917269568STaniya Das 			.name = "gcc_camera_throttle_hf_axi_clk",
91017269568STaniya Das 			.ops = &clk_branch2_ops,
91117269568STaniya Das 		},
91217269568STaniya Das 	},
91317269568STaniya Das };
91417269568STaniya Das 
91517269568STaniya Das static struct clk_branch gcc_camera_xo_clk = {
91617269568STaniya Das 	.halt_reg = 0xb02c,
91717269568STaniya Das 	.halt_check = BRANCH_HALT,
91817269568STaniya Das 	.clkr = {
91917269568STaniya Das 		.enable_reg = 0xb02c,
92017269568STaniya Das 		.enable_mask = BIT(0),
92117269568STaniya Das 		.hw.init = &(struct clk_init_data){
92217269568STaniya Das 			.name = "gcc_camera_xo_clk",
92317269568STaniya Das 			.ops = &clk_branch2_ops,
92417269568STaniya Das 		},
92517269568STaniya Das 	},
92617269568STaniya Das };
92717269568STaniya Das 
92817269568STaniya Das static struct clk_branch gcc_ce1_ahb_clk = {
92917269568STaniya Das 	.halt_reg = 0x4100c,
93017269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
93117269568STaniya Das 	.hwcg_reg = 0x4100c,
93217269568STaniya Das 	.hwcg_bit = 1,
93317269568STaniya Das 	.clkr = {
93417269568STaniya Das 		.enable_reg = 0x52000,
93517269568STaniya Das 		.enable_mask = BIT(3),
93617269568STaniya Das 		.hw.init = &(struct clk_init_data){
93717269568STaniya Das 			.name = "gcc_ce1_ahb_clk",
93817269568STaniya Das 			.ops = &clk_branch2_ops,
93917269568STaniya Das 		},
94017269568STaniya Das 	},
94117269568STaniya Das };
94217269568STaniya Das 
94317269568STaniya Das static struct clk_branch gcc_ce1_axi_clk = {
94417269568STaniya Das 	.halt_reg = 0x41008,
94517269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
94617269568STaniya Das 	.clkr = {
94717269568STaniya Das 		.enable_reg = 0x52000,
94817269568STaniya Das 		.enable_mask = BIT(4),
94917269568STaniya Das 		.hw.init = &(struct clk_init_data){
95017269568STaniya Das 			.name = "gcc_ce1_axi_clk",
95117269568STaniya Das 			.ops = &clk_branch2_ops,
95217269568STaniya Das 		},
95317269568STaniya Das 	},
95417269568STaniya Das };
95517269568STaniya Das 
95617269568STaniya Das static struct clk_branch gcc_ce1_clk = {
95717269568STaniya Das 	.halt_reg = 0x41004,
95817269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
95917269568STaniya Das 	.clkr = {
96017269568STaniya Das 		.enable_reg = 0x52000,
96117269568STaniya Das 		.enable_mask = BIT(5),
96217269568STaniya Das 		.hw.init = &(struct clk_init_data){
96317269568STaniya Das 			.name = "gcc_ce1_clk",
96417269568STaniya Das 			.ops = &clk_branch2_ops,
96517269568STaniya Das 		},
96617269568STaniya Das 	},
96717269568STaniya Das };
96817269568STaniya Das 
96917269568STaniya Das static struct clk_branch gcc_cfg_noc_usb3_prim_axi_clk = {
97017269568STaniya Das 	.halt_reg = 0x502c,
97117269568STaniya Das 	.halt_check = BRANCH_HALT,
97217269568STaniya Das 	.clkr = {
97317269568STaniya Das 		.enable_reg = 0x502c,
97417269568STaniya Das 		.enable_mask = BIT(0),
97517269568STaniya Das 		.hw.init = &(struct clk_init_data){
97617269568STaniya Das 			.name = "gcc_cfg_noc_usb3_prim_axi_clk",
97717269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
97817269568STaniya Das 				.hw = &gcc_usb30_prim_master_clk_src.clkr.hw,
97917269568STaniya Das 			},
98017269568STaniya Das 			.num_parents = 1,
98117269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
98217269568STaniya Das 			.ops = &clk_branch2_ops,
98317269568STaniya Das 		},
98417269568STaniya Das 	},
98517269568STaniya Das };
98617269568STaniya Das 
98717269568STaniya Das /* For CPUSS functionality the AHB clock needs to be left enabled */
98817269568STaniya Das static struct clk_branch gcc_cpuss_ahb_clk = {
98917269568STaniya Das 	.halt_reg = 0x48000,
99017269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
99117269568STaniya Das 	.clkr = {
99217269568STaniya Das 		.enable_reg = 0x52000,
99317269568STaniya Das 		.enable_mask = BIT(21),
99417269568STaniya Das 		.hw.init = &(struct clk_init_data){
99517269568STaniya Das 			.name = "gcc_cpuss_ahb_clk",
99617269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
99717269568STaniya Das 				.hw = &gcc_cpuss_ahb_clk_src.clkr.hw,
99817269568STaniya Das 			},
99917269568STaniya Das 			.num_parents = 1,
100017269568STaniya Das 			.flags = CLK_IS_CRITICAL | CLK_SET_RATE_PARENT,
100117269568STaniya Das 			.ops = &clk_branch2_ops,
100217269568STaniya Das 		},
100317269568STaniya Das 	},
100417269568STaniya Das };
100517269568STaniya Das 
100617269568STaniya Das static struct clk_branch gcc_cpuss_rbcpr_clk = {
100717269568STaniya Das 	.halt_reg = 0x48008,
100817269568STaniya Das 	.halt_check = BRANCH_HALT,
100917269568STaniya Das 	.clkr = {
101017269568STaniya Das 		.enable_reg = 0x48008,
101117269568STaniya Das 		.enable_mask = BIT(0),
101217269568STaniya Das 		.hw.init = &(struct clk_init_data){
101317269568STaniya Das 			.name = "gcc_cpuss_rbcpr_clk",
101417269568STaniya Das 			.ops = &clk_branch2_ops,
101517269568STaniya Das 		},
101617269568STaniya Das 	},
101717269568STaniya Das };
101817269568STaniya Das 
101917269568STaniya Das static struct clk_branch gcc_ddrss_gpu_axi_clk = {
102017269568STaniya Das 	.halt_reg = 0x4452c,
102117269568STaniya Das 	.halt_check = BRANCH_VOTED,
102217269568STaniya Das 	.clkr = {
102317269568STaniya Das 		.enable_reg = 0x4452c,
102417269568STaniya Das 		.enable_mask = BIT(0),
102517269568STaniya Das 		.hw.init = &(struct clk_init_data){
102617269568STaniya Das 			.name = "gcc_ddrss_gpu_axi_clk",
102717269568STaniya Das 			.ops = &clk_branch2_ops,
102817269568STaniya Das 		},
102917269568STaniya Das 	},
103017269568STaniya Das };
103117269568STaniya Das 
103217269568STaniya Das static struct clk_branch gcc_disp_gpll0_clk_src = {
103317269568STaniya Das 	.halt_check = BRANCH_HALT_DELAY,
103417269568STaniya Das 	.clkr = {
103517269568STaniya Das 		.enable_reg = 0x52000,
103617269568STaniya Das 		.enable_mask = BIT(18),
103717269568STaniya Das 		.hw.init = &(struct clk_init_data){
103817269568STaniya Das 			.name = "gcc_disp_gpll0_clk_src",
103917269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
104017269568STaniya Das 				.hw = &gpll0.clkr.hw,
104117269568STaniya Das 			},
104217269568STaniya Das 			.num_parents = 1,
104317269568STaniya Das 			.ops = &clk_branch2_ops,
104417269568STaniya Das 		},
104517269568STaniya Das 	},
104617269568STaniya Das };
104717269568STaniya Das 
104817269568STaniya Das static struct clk_branch gcc_disp_gpll0_div_clk_src = {
104917269568STaniya Das 	.halt_check = BRANCH_HALT_DELAY,
105017269568STaniya Das 	.clkr = {
105117269568STaniya Das 		.enable_reg = 0x52000,
105217269568STaniya Das 		.enable_mask = BIT(19),
105317269568STaniya Das 		.hw.init = &(struct clk_init_data){
105417269568STaniya Das 			.name = "gcc_disp_gpll0_div_clk_src",
105517269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
105617269568STaniya Das 				.hw = &gcc_pll0_main_div_cdiv.hw,
105717269568STaniya Das 			},
105817269568STaniya Das 			.num_parents = 1,
105917269568STaniya Das 			.ops = &clk_branch2_ops,
106017269568STaniya Das 		},
106117269568STaniya Das 	},
106217269568STaniya Das };
106317269568STaniya Das 
106417269568STaniya Das static struct clk_branch gcc_disp_hf_axi_clk = {
106517269568STaniya Das 	.halt_reg = 0xb024,
106617269568STaniya Das 	.halt_check = BRANCH_HALT,
106717269568STaniya Das 	.clkr = {
106817269568STaniya Das 		.enable_reg = 0xb024,
106917269568STaniya Das 		.enable_mask = BIT(0),
107017269568STaniya Das 		.hw.init = &(struct clk_init_data){
107117269568STaniya Das 			.name = "gcc_disp_hf_axi_clk",
107217269568STaniya Das 			.ops = &clk_branch2_ops,
107317269568STaniya Das 		},
107417269568STaniya Das 	},
107517269568STaniya Das };
107617269568STaniya Das 
107717269568STaniya Das static struct clk_branch gcc_disp_throttle_hf_axi_clk = {
107817269568STaniya Das 	.halt_reg = 0xb084,
107917269568STaniya Das 	.halt_check = BRANCH_HALT,
108017269568STaniya Das 	.hwcg_reg = 0xb084,
108117269568STaniya Das 	.hwcg_bit = 1,
108217269568STaniya Das 	.clkr = {
108317269568STaniya Das 		.enable_reg = 0xb084,
108417269568STaniya Das 		.enable_mask = BIT(0),
108517269568STaniya Das 		.hw.init = &(struct clk_init_data){
108617269568STaniya Das 			.name = "gcc_disp_throttle_hf_axi_clk",
108717269568STaniya Das 			.ops = &clk_branch2_ops,
108817269568STaniya Das 		},
108917269568STaniya Das 	},
109017269568STaniya Das };
109117269568STaniya Das 
109217269568STaniya Das static struct clk_branch gcc_disp_xo_clk = {
109317269568STaniya Das 	.halt_reg = 0xb030,
109417269568STaniya Das 	.halt_check = BRANCH_HALT,
109517269568STaniya Das 	.clkr = {
109617269568STaniya Das 		.enable_reg = 0xb030,
109717269568STaniya Das 		.enable_mask = BIT(0),
109817269568STaniya Das 		.hw.init = &(struct clk_init_data){
109917269568STaniya Das 			.name = "gcc_disp_xo_clk",
110017269568STaniya Das 			.ops = &clk_branch2_ops,
110117269568STaniya Das 		},
110217269568STaniya Das 	},
110317269568STaniya Das };
110417269568STaniya Das 
110517269568STaniya Das static struct clk_branch gcc_gp1_clk = {
110617269568STaniya Das 	.halt_reg = 0x64000,
110717269568STaniya Das 	.halt_check = BRANCH_HALT,
110817269568STaniya Das 	.clkr = {
110917269568STaniya Das 		.enable_reg = 0x64000,
111017269568STaniya Das 		.enable_mask = BIT(0),
111117269568STaniya Das 		.hw.init = &(struct clk_init_data){
111217269568STaniya Das 			.name = "gcc_gp1_clk",
111317269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
111417269568STaniya Das 				.hw = &gcc_gp1_clk_src.clkr.hw,
111517269568STaniya Das 			},
111617269568STaniya Das 			.num_parents = 1,
111717269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
111817269568STaniya Das 			.ops = &clk_branch2_ops,
111917269568STaniya Das 		},
112017269568STaniya Das 	},
112117269568STaniya Das };
112217269568STaniya Das 
112317269568STaniya Das static struct clk_branch gcc_gp2_clk = {
112417269568STaniya Das 	.halt_reg = 0x65000,
112517269568STaniya Das 	.halt_check = BRANCH_HALT,
112617269568STaniya Das 	.clkr = {
112717269568STaniya Das 		.enable_reg = 0x65000,
112817269568STaniya Das 		.enable_mask = BIT(0),
112917269568STaniya Das 		.hw.init = &(struct clk_init_data){
113017269568STaniya Das 			.name = "gcc_gp2_clk",
113117269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
113217269568STaniya Das 				.hw = &gcc_gp2_clk_src.clkr.hw,
113317269568STaniya Das 			},
113417269568STaniya Das 			.num_parents = 1,
113517269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
113617269568STaniya Das 			.ops = &clk_branch2_ops,
113717269568STaniya Das 		},
113817269568STaniya Das 	},
113917269568STaniya Das };
114017269568STaniya Das 
114117269568STaniya Das static struct clk_branch gcc_gp3_clk = {
114217269568STaniya Das 	.halt_reg = 0x66000,
114317269568STaniya Das 	.halt_check = BRANCH_HALT,
114417269568STaniya Das 	.clkr = {
114517269568STaniya Das 		.enable_reg = 0x66000,
114617269568STaniya Das 		.enable_mask = BIT(0),
114717269568STaniya Das 		.hw.init = &(struct clk_init_data){
114817269568STaniya Das 			.name = "gcc_gp3_clk",
114917269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
115017269568STaniya Das 				.hw = &gcc_gp3_clk_src.clkr.hw,
115117269568STaniya Das 			},
115217269568STaniya Das 			.num_parents = 1,
115317269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
115417269568STaniya Das 			.ops = &clk_branch2_ops,
115517269568STaniya Das 		},
115617269568STaniya Das 	},
115717269568STaniya Das };
115817269568STaniya Das 
115917269568STaniya Das static struct clk_branch gcc_gpu_gpll0_clk_src = {
116017269568STaniya Das 	.halt_check = BRANCH_HALT_DELAY,
116117269568STaniya Das 	.clkr = {
116217269568STaniya Das 		.enable_reg = 0x52000,
116317269568STaniya Das 		.enable_mask = BIT(15),
116417269568STaniya Das 		.hw.init = &(struct clk_init_data){
116517269568STaniya Das 			.name = "gcc_gpu_gpll0_clk_src",
116617269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
116717269568STaniya Das 				.hw = &gpll0.clkr.hw,
116817269568STaniya Das 			},
116917269568STaniya Das 			.num_parents = 1,
117017269568STaniya Das 			.ops = &clk_branch2_ops,
117117269568STaniya Das 		},
117217269568STaniya Das 	},
117317269568STaniya Das };
117417269568STaniya Das 
117517269568STaniya Das static struct clk_branch gcc_gpu_gpll0_div_clk_src = {
117617269568STaniya Das 	.halt_check = BRANCH_HALT_DELAY,
117717269568STaniya Das 	.clkr = {
117817269568STaniya Das 		.enable_reg = 0x52000,
117917269568STaniya Das 		.enable_mask = BIT(16),
118017269568STaniya Das 		.hw.init = &(struct clk_init_data){
118117269568STaniya Das 			.name = "gcc_gpu_gpll0_div_clk_src",
118217269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
118317269568STaniya Das 				.hw = &gcc_pll0_main_div_cdiv.hw,
118417269568STaniya Das 			},
118517269568STaniya Das 			.num_parents = 1,
118617269568STaniya Das 			.ops = &clk_branch2_ops,
118717269568STaniya Das 		},
118817269568STaniya Das 	},
118917269568STaniya Das };
119017269568STaniya Das 
119117269568STaniya Das static struct clk_branch gcc_gpu_memnoc_gfx_clk = {
119217269568STaniya Das 	.halt_reg = 0x7100c,
119317269568STaniya Das 	.halt_check = BRANCH_VOTED,
119417269568STaniya Das 	.clkr = {
119517269568STaniya Das 		.enable_reg = 0x7100c,
119617269568STaniya Das 		.enable_mask = BIT(0),
119717269568STaniya Das 		.hw.init = &(struct clk_init_data){
119817269568STaniya Das 			.name = "gcc_gpu_memnoc_gfx_clk",
119917269568STaniya Das 			.ops = &clk_branch2_ops,
120017269568STaniya Das 		},
120117269568STaniya Das 	},
120217269568STaniya Das };
120317269568STaniya Das 
120417269568STaniya Das static struct clk_branch gcc_gpu_snoc_dvm_gfx_clk = {
120517269568STaniya Das 	.halt_reg = 0x71018,
120617269568STaniya Das 	.halt_check = BRANCH_HALT,
120717269568STaniya Das 	.clkr = {
120817269568STaniya Das 		.enable_reg = 0x71018,
120917269568STaniya Das 		.enable_mask = BIT(0),
121017269568STaniya Das 		.hw.init = &(struct clk_init_data){
121117269568STaniya Das 			.name = "gcc_gpu_snoc_dvm_gfx_clk",
121217269568STaniya Das 			.ops = &clk_branch2_ops,
121317269568STaniya Das 		},
121417269568STaniya Das 	},
121517269568STaniya Das };
121617269568STaniya Das 
121717269568STaniya Das static struct clk_branch gcc_npu_axi_clk = {
121817269568STaniya Das 	.halt_reg = 0x4d008,
121917269568STaniya Das 	.halt_check = BRANCH_HALT,
122017269568STaniya Das 	.clkr = {
122117269568STaniya Das 		.enable_reg = 0x4d008,
122217269568STaniya Das 		.enable_mask = BIT(0),
122317269568STaniya Das 		.hw.init = &(struct clk_init_data){
122417269568STaniya Das 			.name = "gcc_npu_axi_clk",
122517269568STaniya Das 			.ops = &clk_branch2_ops,
122617269568STaniya Das 		},
122717269568STaniya Das 	},
122817269568STaniya Das };
122917269568STaniya Das 
123017269568STaniya Das static struct clk_branch gcc_npu_bwmon_axi_clk = {
123117269568STaniya Das 	.halt_reg = 0x73008,
123217269568STaniya Das 	.halt_check = BRANCH_HALT,
123317269568STaniya Das 	.clkr = {
123417269568STaniya Das 		.enable_reg = 0x73008,
123517269568STaniya Das 		.enable_mask = BIT(0),
123617269568STaniya Das 		.hw.init = &(struct clk_init_data){
123717269568STaniya Das 			.name = "gcc_npu_bwmon_axi_clk",
123817269568STaniya Das 			.ops = &clk_branch2_ops,
123917269568STaniya Das 		},
124017269568STaniya Das 	},
124117269568STaniya Das };
124217269568STaniya Das 
124317269568STaniya Das static struct clk_branch gcc_npu_bwmon_dma_cfg_ahb_clk = {
124417269568STaniya Das 	.halt_reg = 0x73018,
124517269568STaniya Das 	.halt_check = BRANCH_HALT,
124617269568STaniya Das 	.clkr = {
124717269568STaniya Das 		.enable_reg = 0x73018,
124817269568STaniya Das 		.enable_mask = BIT(0),
124917269568STaniya Das 		.hw.init = &(struct clk_init_data){
125017269568STaniya Das 			.name = "gcc_npu_bwmon_dma_cfg_ahb_clk",
125117269568STaniya Das 			.ops = &clk_branch2_ops,
125217269568STaniya Das 		},
125317269568STaniya Das 	},
125417269568STaniya Das };
125517269568STaniya Das 
125617269568STaniya Das static struct clk_branch gcc_npu_bwmon_dsp_cfg_ahb_clk = {
125717269568STaniya Das 	.halt_reg = 0x7301c,
125817269568STaniya Das 	.halt_check = BRANCH_HALT,
125917269568STaniya Das 	.clkr = {
126017269568STaniya Das 		.enable_reg = 0x7301c,
126117269568STaniya Das 		.enable_mask = BIT(0),
126217269568STaniya Das 		.hw.init = &(struct clk_init_data){
126317269568STaniya Das 			.name = "gcc_npu_bwmon_dsp_cfg_ahb_clk",
126417269568STaniya Das 			.ops = &clk_branch2_ops,
126517269568STaniya Das 		},
126617269568STaniya Das 	},
126717269568STaniya Das };
126817269568STaniya Das 
126917269568STaniya Das static struct clk_branch gcc_npu_cfg_ahb_clk = {
127017269568STaniya Das 	.halt_reg = 0x4d004,
127117269568STaniya Das 	.halt_check = BRANCH_HALT,
127217269568STaniya Das 	.hwcg_reg = 0x4d004,
127317269568STaniya Das 	.hwcg_bit = 1,
127417269568STaniya Das 	.clkr = {
127517269568STaniya Das 		.enable_reg = 0x4d004,
127617269568STaniya Das 		.enable_mask = BIT(0),
127717269568STaniya Das 		.hw.init = &(struct clk_init_data){
127817269568STaniya Das 			.name = "gcc_npu_cfg_ahb_clk",
127917269568STaniya Das 			.ops = &clk_branch2_ops,
128017269568STaniya Das 		},
128117269568STaniya Das 	},
128217269568STaniya Das };
128317269568STaniya Das 
128417269568STaniya Das static struct clk_branch gcc_npu_dma_clk = {
128517269568STaniya Das 	.halt_reg = 0x4d1a0,
128617269568STaniya Das 	.halt_check = BRANCH_HALT,
128717269568STaniya Das 	.hwcg_reg = 0x4d1a0,
128817269568STaniya Das 	.hwcg_bit = 1,
128917269568STaniya Das 	.clkr = {
129017269568STaniya Das 		.enable_reg = 0x4d1a0,
129117269568STaniya Das 		.enable_mask = BIT(0),
129217269568STaniya Das 		.hw.init = &(struct clk_init_data){
129317269568STaniya Das 			.name = "gcc_npu_dma_clk",
129417269568STaniya Das 			.ops = &clk_branch2_ops,
129517269568STaniya Das 		},
129617269568STaniya Das 	},
129717269568STaniya Das };
129817269568STaniya Das 
129917269568STaniya Das static struct clk_branch gcc_npu_gpll0_clk_src = {
130017269568STaniya Das 	.halt_check = BRANCH_HALT_DELAY,
130117269568STaniya Das 	.clkr = {
130217269568STaniya Das 		.enable_reg = 0x52000,
130317269568STaniya Das 		.enable_mask = BIT(25),
130417269568STaniya Das 		.hw.init = &(struct clk_init_data){
130517269568STaniya Das 			.name = "gcc_npu_gpll0_clk_src",
130617269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
130717269568STaniya Das 				.hw = &gpll0.clkr.hw,
130817269568STaniya Das 			},
130917269568STaniya Das 			.num_parents = 1,
131017269568STaniya Das 			.ops = &clk_branch2_ops,
131117269568STaniya Das 		},
131217269568STaniya Das 	},
131317269568STaniya Das };
131417269568STaniya Das 
131517269568STaniya Das static struct clk_branch gcc_npu_gpll0_div_clk_src = {
131617269568STaniya Das 	.halt_check = BRANCH_HALT_DELAY,
131717269568STaniya Das 	.clkr = {
131817269568STaniya Das 		.enable_reg = 0x52000,
131917269568STaniya Das 		.enable_mask = BIT(26),
132017269568STaniya Das 		.hw.init = &(struct clk_init_data){
132117269568STaniya Das 			.name = "gcc_npu_gpll0_div_clk_src",
132217269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
132317269568STaniya Das 				.hw = &gcc_pll0_main_div_cdiv.hw,
132417269568STaniya Das 			},
132517269568STaniya Das 			.num_parents = 1,
132617269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
132717269568STaniya Das 			.ops = &clk_branch2_ops,
132817269568STaniya Das 		},
132917269568STaniya Das 	},
133017269568STaniya Das };
133117269568STaniya Das 
133217269568STaniya Das static struct clk_branch gcc_pdm2_clk = {
133317269568STaniya Das 	.halt_reg = 0x3300c,
133417269568STaniya Das 	.halt_check = BRANCH_HALT,
133517269568STaniya Das 	.clkr = {
133617269568STaniya Das 		.enable_reg = 0x3300c,
133717269568STaniya Das 		.enable_mask = BIT(0),
133817269568STaniya Das 		.hw.init = &(struct clk_init_data){
133917269568STaniya Das 			.name = "gcc_pdm2_clk",
134017269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
134117269568STaniya Das 				.hw = &gcc_pdm2_clk_src.clkr.hw,
134217269568STaniya Das 			},
134317269568STaniya Das 			.num_parents = 1,
134417269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
134517269568STaniya Das 			.ops = &clk_branch2_ops,
134617269568STaniya Das 		},
134717269568STaniya Das 	},
134817269568STaniya Das };
134917269568STaniya Das 
135017269568STaniya Das static struct clk_branch gcc_pdm_ahb_clk = {
135117269568STaniya Das 	.halt_reg = 0x33004,
135217269568STaniya Das 	.halt_check = BRANCH_HALT,
135317269568STaniya Das 	.hwcg_reg = 0x33004,
135417269568STaniya Das 	.hwcg_bit = 1,
135517269568STaniya Das 	.clkr = {
135617269568STaniya Das 		.enable_reg = 0x33004,
135717269568STaniya Das 		.enable_mask = BIT(0),
135817269568STaniya Das 		.hw.init = &(struct clk_init_data){
135917269568STaniya Das 			.name = "gcc_pdm_ahb_clk",
136017269568STaniya Das 			.ops = &clk_branch2_ops,
136117269568STaniya Das 		},
136217269568STaniya Das 	},
136317269568STaniya Das };
136417269568STaniya Das 
136517269568STaniya Das static struct clk_branch gcc_pdm_xo4_clk = {
136617269568STaniya Das 	.halt_reg = 0x33008,
136717269568STaniya Das 	.halt_check = BRANCH_HALT,
136817269568STaniya Das 	.clkr = {
136917269568STaniya Das 		.enable_reg = 0x33008,
137017269568STaniya Das 		.enable_mask = BIT(0),
137117269568STaniya Das 		.hw.init = &(struct clk_init_data){
137217269568STaniya Das 			.name = "gcc_pdm_xo4_clk",
137317269568STaniya Das 			.ops = &clk_branch2_ops,
137417269568STaniya Das 		},
137517269568STaniya Das 	},
137617269568STaniya Das };
137717269568STaniya Das 
137817269568STaniya Das static struct clk_branch gcc_prng_ahb_clk = {
137917269568STaniya Das 	.halt_reg = 0x34004,
138017269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
138117269568STaniya Das 	.hwcg_reg = 0x34004,
138217269568STaniya Das 	.hwcg_bit = 1,
138317269568STaniya Das 	.clkr = {
138417269568STaniya Das 		.enable_reg = 0x52000,
138517269568STaniya Das 		.enable_mask = BIT(13),
138617269568STaniya Das 		.hw.init = &(struct clk_init_data){
138717269568STaniya Das 			.name = "gcc_prng_ahb_clk",
138817269568STaniya Das 			.ops = &clk_branch2_ops,
138917269568STaniya Das 		},
139017269568STaniya Das 	},
139117269568STaniya Das };
139217269568STaniya Das 
139317269568STaniya Das static struct clk_branch gcc_qspi_cnoc_periph_ahb_clk = {
139417269568STaniya Das 	.halt_reg = 0x4b004,
139517269568STaniya Das 	.halt_check = BRANCH_HALT,
139617269568STaniya Das 	.hwcg_reg = 0x4b004,
139717269568STaniya Das 	.hwcg_bit = 1,
139817269568STaniya Das 	.clkr = {
139917269568STaniya Das 		.enable_reg = 0x4b004,
140017269568STaniya Das 		.enable_mask = BIT(0),
140117269568STaniya Das 		.hw.init = &(struct clk_init_data){
140217269568STaniya Das 			.name = "gcc_qspi_cnoc_periph_ahb_clk",
140317269568STaniya Das 			.ops = &clk_branch2_ops,
140417269568STaniya Das 		},
140517269568STaniya Das 	},
140617269568STaniya Das };
140717269568STaniya Das 
140817269568STaniya Das static struct clk_branch gcc_qspi_core_clk = {
140917269568STaniya Das 	.halt_reg = 0x4b008,
141017269568STaniya Das 	.halt_check = BRANCH_HALT,
141117269568STaniya Das 	.clkr = {
141217269568STaniya Das 		.enable_reg = 0x4b008,
141317269568STaniya Das 		.enable_mask = BIT(0),
141417269568STaniya Das 		.hw.init = &(struct clk_init_data){
141517269568STaniya Das 			.name = "gcc_qspi_core_clk",
141617269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
141717269568STaniya Das 				.hw = &gcc_qspi_core_clk_src.clkr.hw,
141817269568STaniya Das 			},
141917269568STaniya Das 			.num_parents = 1,
142017269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
142117269568STaniya Das 			.ops = &clk_branch2_ops,
142217269568STaniya Das 		},
142317269568STaniya Das 	},
142417269568STaniya Das };
142517269568STaniya Das 
142617269568STaniya Das static struct clk_branch gcc_qupv3_wrap0_core_2x_clk = {
142717269568STaniya Das 	.halt_reg = 0x17014,
142817269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
142917269568STaniya Das 	.clkr = {
143017269568STaniya Das 		.enable_reg = 0x52008,
143117269568STaniya Das 		.enable_mask = BIT(9),
143217269568STaniya Das 		.hw.init = &(struct clk_init_data){
143317269568STaniya Das 			.name = "gcc_qupv3_wrap0_core_2x_clk",
143417269568STaniya Das 			.ops = &clk_branch2_ops,
143517269568STaniya Das 		},
143617269568STaniya Das 	},
143717269568STaniya Das };
143817269568STaniya Das 
143917269568STaniya Das static struct clk_branch gcc_qupv3_wrap0_core_clk = {
144017269568STaniya Das 	.halt_reg = 0x1700c,
144117269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
144217269568STaniya Das 	.clkr = {
144317269568STaniya Das 		.enable_reg = 0x52008,
144417269568STaniya Das 		.enable_mask = BIT(8),
144517269568STaniya Das 		.hw.init = &(struct clk_init_data){
144617269568STaniya Das 			.name = "gcc_qupv3_wrap0_core_clk",
144717269568STaniya Das 			.ops = &clk_branch2_ops,
144817269568STaniya Das 		},
144917269568STaniya Das 	},
145017269568STaniya Das };
145117269568STaniya Das 
145217269568STaniya Das static struct clk_branch gcc_qupv3_wrap0_s0_clk = {
145317269568STaniya Das 	.halt_reg = 0x17030,
145417269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
145517269568STaniya Das 	.clkr = {
145617269568STaniya Das 		.enable_reg = 0x52008,
145717269568STaniya Das 		.enable_mask = BIT(10),
145817269568STaniya Das 		.hw.init = &(struct clk_init_data){
145917269568STaniya Das 			.name = "gcc_qupv3_wrap0_s0_clk",
146017269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
146117269568STaniya Das 				.hw = &gcc_qupv3_wrap0_s0_clk_src.clkr.hw,
146217269568STaniya Das 			},
146317269568STaniya Das 			.num_parents = 1,
146417269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
146517269568STaniya Das 			.ops = &clk_branch2_ops,
146617269568STaniya Das 		},
146717269568STaniya Das 	},
146817269568STaniya Das };
146917269568STaniya Das 
147017269568STaniya Das static struct clk_branch gcc_qupv3_wrap0_s1_clk = {
147117269568STaniya Das 	.halt_reg = 0x17160,
147217269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
147317269568STaniya Das 	.clkr = {
147417269568STaniya Das 		.enable_reg = 0x52008,
147517269568STaniya Das 		.enable_mask = BIT(11),
147617269568STaniya Das 		.hw.init = &(struct clk_init_data){
147717269568STaniya Das 			.name = "gcc_qupv3_wrap0_s1_clk",
147817269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
147917269568STaniya Das 				.hw = &gcc_qupv3_wrap0_s1_clk_src.clkr.hw,
148017269568STaniya Das 			},
148117269568STaniya Das 			.num_parents = 1,
148217269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
148317269568STaniya Das 			.ops = &clk_branch2_ops,
148417269568STaniya Das 		},
148517269568STaniya Das 	},
148617269568STaniya Das };
148717269568STaniya Das 
148817269568STaniya Das static struct clk_branch gcc_qupv3_wrap0_s2_clk = {
148917269568STaniya Das 	.halt_reg = 0x17290,
149017269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
149117269568STaniya Das 	.clkr = {
149217269568STaniya Das 		.enable_reg = 0x52008,
149317269568STaniya Das 		.enable_mask = BIT(12),
149417269568STaniya Das 		.hw.init = &(struct clk_init_data){
149517269568STaniya Das 			.name = "gcc_qupv3_wrap0_s2_clk",
149617269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
149717269568STaniya Das 				.hw = &gcc_qupv3_wrap0_s2_clk_src.clkr.hw,
149817269568STaniya Das 			},
149917269568STaniya Das 			.num_parents = 1,
150017269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
150117269568STaniya Das 			.ops = &clk_branch2_ops,
150217269568STaniya Das 		},
150317269568STaniya Das 	},
150417269568STaniya Das };
150517269568STaniya Das 
150617269568STaniya Das static struct clk_branch gcc_qupv3_wrap0_s3_clk = {
150717269568STaniya Das 	.halt_reg = 0x173c0,
150817269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
150917269568STaniya Das 	.clkr = {
151017269568STaniya Das 		.enable_reg = 0x52008,
151117269568STaniya Das 		.enable_mask = BIT(13),
151217269568STaniya Das 		.hw.init = &(struct clk_init_data){
151317269568STaniya Das 			.name = "gcc_qupv3_wrap0_s3_clk",
151417269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
151517269568STaniya Das 				.hw = &gcc_qupv3_wrap0_s3_clk_src.clkr.hw,
151617269568STaniya Das 			},
151717269568STaniya Das 			.num_parents = 1,
151817269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
151917269568STaniya Das 			.ops = &clk_branch2_ops,
152017269568STaniya Das 		},
152117269568STaniya Das 	},
152217269568STaniya Das };
152317269568STaniya Das 
152417269568STaniya Das static struct clk_branch gcc_qupv3_wrap0_s4_clk = {
152517269568STaniya Das 	.halt_reg = 0x174f0,
152617269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
152717269568STaniya Das 	.clkr = {
152817269568STaniya Das 		.enable_reg = 0x52008,
152917269568STaniya Das 		.enable_mask = BIT(14),
153017269568STaniya Das 		.hw.init = &(struct clk_init_data){
153117269568STaniya Das 			.name = "gcc_qupv3_wrap0_s4_clk",
153217269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
153317269568STaniya Das 				.hw = &gcc_qupv3_wrap0_s4_clk_src.clkr.hw,
153417269568STaniya Das 			},
153517269568STaniya Das 			.num_parents = 1,
153617269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
153717269568STaniya Das 			.ops = &clk_branch2_ops,
153817269568STaniya Das 		},
153917269568STaniya Das 	},
154017269568STaniya Das };
154117269568STaniya Das 
154217269568STaniya Das static struct clk_branch gcc_qupv3_wrap0_s5_clk = {
154317269568STaniya Das 	.halt_reg = 0x17620,
154417269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
154517269568STaniya Das 	.clkr = {
154617269568STaniya Das 		.enable_reg = 0x52008,
154717269568STaniya Das 		.enable_mask = BIT(15),
154817269568STaniya Das 		.hw.init = &(struct clk_init_data){
154917269568STaniya Das 			.name = "gcc_qupv3_wrap0_s5_clk",
155017269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
155117269568STaniya Das 				.hw = &gcc_qupv3_wrap0_s5_clk_src.clkr.hw,
155217269568STaniya Das 			},
155317269568STaniya Das 			.num_parents = 1,
155417269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
155517269568STaniya Das 			.ops = &clk_branch2_ops,
155617269568STaniya Das 		},
155717269568STaniya Das 	},
155817269568STaniya Das };
155917269568STaniya Das 
156017269568STaniya Das static struct clk_branch gcc_qupv3_wrap1_core_2x_clk = {
156117269568STaniya Das 	.halt_reg = 0x18004,
156217269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
156317269568STaniya Das 	.clkr = {
156417269568STaniya Das 		.enable_reg = 0x52008,
156517269568STaniya Das 		.enable_mask = BIT(18),
156617269568STaniya Das 		.hw.init = &(struct clk_init_data){
156717269568STaniya Das 			.name = "gcc_qupv3_wrap1_core_2x_clk",
156817269568STaniya Das 			.ops = &clk_branch2_ops,
156917269568STaniya Das 		},
157017269568STaniya Das 	},
157117269568STaniya Das };
157217269568STaniya Das 
157317269568STaniya Das static struct clk_branch gcc_qupv3_wrap1_core_clk = {
157417269568STaniya Das 	.halt_reg = 0x18008,
157517269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
157617269568STaniya Das 	.clkr = {
157717269568STaniya Das 		.enable_reg = 0x52008,
157817269568STaniya Das 		.enable_mask = BIT(19),
157917269568STaniya Das 		.hw.init = &(struct clk_init_data){
158017269568STaniya Das 			.name = "gcc_qupv3_wrap1_core_clk",
158117269568STaniya Das 			.ops = &clk_branch2_ops,
158217269568STaniya Das 		},
158317269568STaniya Das 	},
158417269568STaniya Das };
158517269568STaniya Das 
158617269568STaniya Das static struct clk_branch gcc_qupv3_wrap1_s0_clk = {
158717269568STaniya Das 	.halt_reg = 0x18014,
158817269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
158917269568STaniya Das 	.clkr = {
159017269568STaniya Das 		.enable_reg = 0x52008,
159117269568STaniya Das 		.enable_mask = BIT(22),
159217269568STaniya Das 		.hw.init = &(struct clk_init_data){
159317269568STaniya Das 			.name = "gcc_qupv3_wrap1_s0_clk",
159417269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
159517269568STaniya Das 				.hw = &gcc_qupv3_wrap1_s0_clk_src.clkr.hw,
159617269568STaniya Das 			},
159717269568STaniya Das 			.num_parents = 1,
159817269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
159917269568STaniya Das 			.ops = &clk_branch2_ops,
160017269568STaniya Das 		},
160117269568STaniya Das 	},
160217269568STaniya Das };
160317269568STaniya Das 
160417269568STaniya Das static struct clk_branch gcc_qupv3_wrap1_s1_clk = {
160517269568STaniya Das 	.halt_reg = 0x18144,
160617269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
160717269568STaniya Das 	.clkr = {
160817269568STaniya Das 		.enable_reg = 0x52008,
160917269568STaniya Das 		.enable_mask = BIT(23),
161017269568STaniya Das 		.hw.init = &(struct clk_init_data){
161117269568STaniya Das 			.name = "gcc_qupv3_wrap1_s1_clk",
161217269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
161317269568STaniya Das 				.hw = &gcc_qupv3_wrap1_s1_clk_src.clkr.hw,
161417269568STaniya Das 			},
161517269568STaniya Das 			.num_parents = 1,
161617269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
161717269568STaniya Das 			.ops = &clk_branch2_ops,
161817269568STaniya Das 		},
161917269568STaniya Das 	},
162017269568STaniya Das };
162117269568STaniya Das 
162217269568STaniya Das static struct clk_branch gcc_qupv3_wrap1_s2_clk = {
162317269568STaniya Das 	.halt_reg = 0x18274,
162417269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
162517269568STaniya Das 	.clkr = {
162617269568STaniya Das 		.enable_reg = 0x52008,
162717269568STaniya Das 		.enable_mask = BIT(24),
162817269568STaniya Das 		.hw.init = &(struct clk_init_data){
162917269568STaniya Das 			.name = "gcc_qupv3_wrap1_s2_clk",
163017269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
163117269568STaniya Das 				.hw = &gcc_qupv3_wrap1_s2_clk_src.clkr.hw,
163217269568STaniya Das 			},
163317269568STaniya Das 			.num_parents = 1,
163417269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
163517269568STaniya Das 			.ops = &clk_branch2_ops,
163617269568STaniya Das 		},
163717269568STaniya Das 	},
163817269568STaniya Das };
163917269568STaniya Das 
164017269568STaniya Das static struct clk_branch gcc_qupv3_wrap1_s3_clk = {
164117269568STaniya Das 	.halt_reg = 0x183a4,
164217269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
164317269568STaniya Das 	.clkr = {
164417269568STaniya Das 		.enable_reg = 0x52008,
164517269568STaniya Das 		.enable_mask = BIT(25),
164617269568STaniya Das 		.hw.init = &(struct clk_init_data){
164717269568STaniya Das 			.name = "gcc_qupv3_wrap1_s3_clk",
164817269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
164917269568STaniya Das 				.hw = &gcc_qupv3_wrap1_s3_clk_src.clkr.hw,
165017269568STaniya Das 			},
165117269568STaniya Das 			.num_parents = 1,
165217269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
165317269568STaniya Das 			.ops = &clk_branch2_ops,
165417269568STaniya Das 		},
165517269568STaniya Das 	},
165617269568STaniya Das };
165717269568STaniya Das 
165817269568STaniya Das static struct clk_branch gcc_qupv3_wrap1_s4_clk = {
165917269568STaniya Das 	.halt_reg = 0x184d4,
166017269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
166117269568STaniya Das 	.clkr = {
166217269568STaniya Das 		.enable_reg = 0x52008,
166317269568STaniya Das 		.enable_mask = BIT(26),
166417269568STaniya Das 		.hw.init = &(struct clk_init_data){
166517269568STaniya Das 			.name = "gcc_qupv3_wrap1_s4_clk",
166617269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
166717269568STaniya Das 				.hw = &gcc_qupv3_wrap1_s4_clk_src.clkr.hw,
166817269568STaniya Das 			},
166917269568STaniya Das 			.num_parents = 1,
167017269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
167117269568STaniya Das 			.ops = &clk_branch2_ops,
167217269568STaniya Das 		},
167317269568STaniya Das 	},
167417269568STaniya Das };
167517269568STaniya Das 
167617269568STaniya Das static struct clk_branch gcc_qupv3_wrap1_s5_clk = {
167717269568STaniya Das 	.halt_reg = 0x18604,
167817269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
167917269568STaniya Das 	.clkr = {
168017269568STaniya Das 		.enable_reg = 0x52008,
168117269568STaniya Das 		.enable_mask = BIT(27),
168217269568STaniya Das 		.hw.init = &(struct clk_init_data){
168317269568STaniya Das 			.name = "gcc_qupv3_wrap1_s5_clk",
168417269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
168517269568STaniya Das 				.hw = &gcc_qupv3_wrap1_s5_clk_src.clkr.hw,
168617269568STaniya Das 			},
168717269568STaniya Das 			.num_parents = 1,
168817269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
168917269568STaniya Das 			.ops = &clk_branch2_ops,
169017269568STaniya Das 		},
169117269568STaniya Das 	},
169217269568STaniya Das };
169317269568STaniya Das 
169417269568STaniya Das static struct clk_branch gcc_qupv3_wrap_0_m_ahb_clk = {
169517269568STaniya Das 	.halt_reg = 0x17004,
169617269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
169717269568STaniya Das 	.clkr = {
169817269568STaniya Das 		.enable_reg = 0x52008,
169917269568STaniya Das 		.enable_mask = BIT(6),
170017269568STaniya Das 		.hw.init = &(struct clk_init_data){
170117269568STaniya Das 			.name = "gcc_qupv3_wrap_0_m_ahb_clk",
170217269568STaniya Das 			.ops = &clk_branch2_ops,
170317269568STaniya Das 		},
170417269568STaniya Das 	},
170517269568STaniya Das };
170617269568STaniya Das 
170717269568STaniya Das static struct clk_branch gcc_qupv3_wrap_0_s_ahb_clk = {
170817269568STaniya Das 	.halt_reg = 0x17008,
170917269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
171017269568STaniya Das 	.hwcg_reg = 0x17008,
171117269568STaniya Das 	.hwcg_bit = 1,
171217269568STaniya Das 	.clkr = {
171317269568STaniya Das 		.enable_reg = 0x52008,
171417269568STaniya Das 		.enable_mask = BIT(7),
171517269568STaniya Das 		.hw.init = &(struct clk_init_data){
171617269568STaniya Das 			.name = "gcc_qupv3_wrap_0_s_ahb_clk",
171717269568STaniya Das 			.ops = &clk_branch2_ops,
171817269568STaniya Das 		},
171917269568STaniya Das 	},
172017269568STaniya Das };
172117269568STaniya Das 
172217269568STaniya Das static struct clk_branch gcc_qupv3_wrap_1_m_ahb_clk = {
172317269568STaniya Das 	.halt_reg = 0x1800c,
172417269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
172517269568STaniya Das 	.clkr = {
172617269568STaniya Das 		.enable_reg = 0x52008,
172717269568STaniya Das 		.enable_mask = BIT(20),
172817269568STaniya Das 		.hw.init = &(struct clk_init_data){
172917269568STaniya Das 			.name = "gcc_qupv3_wrap_1_m_ahb_clk",
173017269568STaniya Das 			.ops = &clk_branch2_ops,
173117269568STaniya Das 		},
173217269568STaniya Das 	},
173317269568STaniya Das };
173417269568STaniya Das 
173517269568STaniya Das static struct clk_branch gcc_qupv3_wrap_1_s_ahb_clk = {
173617269568STaniya Das 	.halt_reg = 0x18010,
173717269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
173817269568STaniya Das 	.hwcg_reg = 0x18010,
173917269568STaniya Das 	.hwcg_bit = 1,
174017269568STaniya Das 	.clkr = {
174117269568STaniya Das 		.enable_reg = 0x52008,
174217269568STaniya Das 		.enable_mask = BIT(21),
174317269568STaniya Das 		.hw.init = &(struct clk_init_data){
174417269568STaniya Das 			.name = "gcc_qupv3_wrap_1_s_ahb_clk",
174517269568STaniya Das 			.ops = &clk_branch2_ops,
174617269568STaniya Das 		},
174717269568STaniya Das 	},
174817269568STaniya Das };
174917269568STaniya Das 
175017269568STaniya Das static struct clk_branch gcc_sdcc1_ahb_clk = {
175117269568STaniya Das 	.halt_reg = 0x12008,
175217269568STaniya Das 	.halt_check = BRANCH_HALT,
175317269568STaniya Das 	.clkr = {
175417269568STaniya Das 		.enable_reg = 0x12008,
175517269568STaniya Das 		.enable_mask = BIT(0),
175617269568STaniya Das 		.hw.init = &(struct clk_init_data){
175717269568STaniya Das 			.name = "gcc_sdcc1_ahb_clk",
175817269568STaniya Das 			.ops = &clk_branch2_ops,
175917269568STaniya Das 		},
176017269568STaniya Das 	},
176117269568STaniya Das };
176217269568STaniya Das 
176317269568STaniya Das static struct clk_branch gcc_sdcc1_apps_clk = {
176417269568STaniya Das 	.halt_reg = 0x1200c,
176517269568STaniya Das 	.halt_check = BRANCH_HALT,
176617269568STaniya Das 	.clkr = {
176717269568STaniya Das 		.enable_reg = 0x1200c,
176817269568STaniya Das 		.enable_mask = BIT(0),
176917269568STaniya Das 		.hw.init = &(struct clk_init_data){
177017269568STaniya Das 			.name = "gcc_sdcc1_apps_clk",
177117269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
177217269568STaniya Das 				.hw = &gcc_sdcc1_apps_clk_src.clkr.hw,
177317269568STaniya Das 			},
177417269568STaniya Das 			.num_parents = 1,
177517269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
177617269568STaniya Das 			.ops = &clk_branch2_ops,
177717269568STaniya Das 		},
177817269568STaniya Das 	},
177917269568STaniya Das };
178017269568STaniya Das 
178117269568STaniya Das static struct clk_branch gcc_sdcc1_ice_core_clk = {
178217269568STaniya Das 	.halt_reg = 0x12040,
178317269568STaniya Das 	.halt_check = BRANCH_HALT,
178417269568STaniya Das 	.clkr = {
178517269568STaniya Das 		.enable_reg = 0x12040,
178617269568STaniya Das 		.enable_mask = BIT(0),
178717269568STaniya Das 		.hw.init = &(struct clk_init_data){
178817269568STaniya Das 			.name = "gcc_sdcc1_ice_core_clk",
178917269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
179017269568STaniya Das 				.hw = &gcc_sdcc1_ice_core_clk_src.clkr.hw,
179117269568STaniya Das 			},
179217269568STaniya Das 			.num_parents = 1,
179317269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
179417269568STaniya Das 			.ops = &clk_branch2_ops,
179517269568STaniya Das 		},
179617269568STaniya Das 	},
179717269568STaniya Das };
179817269568STaniya Das 
179917269568STaniya Das static struct clk_branch gcc_sdcc2_ahb_clk = {
180017269568STaniya Das 	.halt_reg = 0x14008,
180117269568STaniya Das 	.halt_check = BRANCH_HALT,
180217269568STaniya Das 	.clkr = {
180317269568STaniya Das 		.enable_reg = 0x14008,
180417269568STaniya Das 		.enable_mask = BIT(0),
180517269568STaniya Das 		.hw.init = &(struct clk_init_data){
180617269568STaniya Das 			.name = "gcc_sdcc2_ahb_clk",
180717269568STaniya Das 			.ops = &clk_branch2_ops,
180817269568STaniya Das 		},
180917269568STaniya Das 	},
181017269568STaniya Das };
181117269568STaniya Das 
181217269568STaniya Das static struct clk_branch gcc_sdcc2_apps_clk = {
181317269568STaniya Das 	.halt_reg = 0x14004,
181417269568STaniya Das 	.halt_check = BRANCH_HALT,
181517269568STaniya Das 	.clkr = {
181617269568STaniya Das 		.enable_reg = 0x14004,
181717269568STaniya Das 		.enable_mask = BIT(0),
181817269568STaniya Das 		.hw.init = &(struct clk_init_data){
181917269568STaniya Das 			.name = "gcc_sdcc2_apps_clk",
182017269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
182117269568STaniya Das 				.hw = &gcc_sdcc2_apps_clk_src.clkr.hw,
182217269568STaniya Das 			},
182317269568STaniya Das 			.num_parents = 1,
182417269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
182517269568STaniya Das 			.ops = &clk_branch2_ops,
182617269568STaniya Das 		},
182717269568STaniya Das 	},
182817269568STaniya Das };
182917269568STaniya Das 
183017269568STaniya Das /* For CPUSS functionality the SYS NOC clock needs to be left enabled */
183117269568STaniya Das static struct clk_branch gcc_sys_noc_cpuss_ahb_clk = {
183217269568STaniya Das 	.halt_reg = 0x4144,
183317269568STaniya Das 	.halt_check = BRANCH_HALT_VOTED,
183417269568STaniya Das 	.clkr = {
183517269568STaniya Das 		.enable_reg = 0x52000,
183617269568STaniya Das 		.enable_mask = BIT(0),
183717269568STaniya Das 		.hw.init = &(struct clk_init_data){
183817269568STaniya Das 			.name = "gcc_sys_noc_cpuss_ahb_clk",
183917269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
184017269568STaniya Das 				.hw = &gcc_cpuss_ahb_clk_src.clkr.hw,
184117269568STaniya Das 			},
184217269568STaniya Das 			.num_parents = 1,
184317269568STaniya Das 			.flags = CLK_IS_CRITICAL | CLK_SET_RATE_PARENT,
184417269568STaniya Das 			.ops = &clk_branch2_ops,
184517269568STaniya Das 		},
184617269568STaniya Das 	},
184717269568STaniya Das };
184817269568STaniya Das 
184917269568STaniya Das static struct clk_branch gcc_ufs_mem_clkref_clk = {
185017269568STaniya Das 	.halt_reg = 0x8c000,
185117269568STaniya Das 	.halt_check = BRANCH_HALT,
185217269568STaniya Das 	.clkr = {
185317269568STaniya Das 		.enable_reg = 0x8c000,
185417269568STaniya Das 		.enable_mask = BIT(0),
185517269568STaniya Das 		.hw.init = &(struct clk_init_data){
185617269568STaniya Das 			.name = "gcc_ufs_mem_clkref_clk",
185717269568STaniya Das 			.ops = &clk_branch2_ops,
185817269568STaniya Das 		},
185917269568STaniya Das 	},
186017269568STaniya Das };
186117269568STaniya Das 
186217269568STaniya Das static struct clk_branch gcc_ufs_phy_ahb_clk = {
186317269568STaniya Das 	.halt_reg = 0x77014,
186417269568STaniya Das 	.halt_check = BRANCH_HALT,
186517269568STaniya Das 	.hwcg_reg = 0x77014,
186617269568STaniya Das 	.hwcg_bit = 1,
186717269568STaniya Das 	.clkr = {
186817269568STaniya Das 		.enable_reg = 0x77014,
186917269568STaniya Das 		.enable_mask = BIT(0),
187017269568STaniya Das 		.hw.init = &(struct clk_init_data){
187117269568STaniya Das 			.name = "gcc_ufs_phy_ahb_clk",
187217269568STaniya Das 			.ops = &clk_branch2_ops,
187317269568STaniya Das 		},
187417269568STaniya Das 	},
187517269568STaniya Das };
187617269568STaniya Das 
187717269568STaniya Das static struct clk_branch gcc_ufs_phy_axi_clk = {
187817269568STaniya Das 	.halt_reg = 0x77038,
187917269568STaniya Das 	.halt_check = BRANCH_HALT,
188017269568STaniya Das 	.hwcg_reg = 0x77038,
188117269568STaniya Das 	.hwcg_bit = 1,
188217269568STaniya Das 	.clkr = {
188317269568STaniya Das 		.enable_reg = 0x77038,
188417269568STaniya Das 		.enable_mask = BIT(0),
188517269568STaniya Das 		.hw.init = &(struct clk_init_data){
188617269568STaniya Das 			.name = "gcc_ufs_phy_axi_clk",
188717269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
188817269568STaniya Das 				.hw = &gcc_ufs_phy_axi_clk_src.clkr.hw,
188917269568STaniya Das 			},
189017269568STaniya Das 			.num_parents = 1,
189117269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
189217269568STaniya Das 			.ops = &clk_branch2_ops,
189317269568STaniya Das 		},
189417269568STaniya Das 	},
189517269568STaniya Das };
189617269568STaniya Das 
189717269568STaniya Das static struct clk_branch gcc_ufs_phy_ice_core_clk = {
189817269568STaniya Das 	.halt_reg = 0x77090,
189917269568STaniya Das 	.halt_check = BRANCH_HALT,
190017269568STaniya Das 	.hwcg_reg = 0x77090,
190117269568STaniya Das 	.hwcg_bit = 1,
190217269568STaniya Das 	.clkr = {
190317269568STaniya Das 		.enable_reg = 0x77090,
190417269568STaniya Das 		.enable_mask = BIT(0),
190517269568STaniya Das 		.hw.init = &(struct clk_init_data){
190617269568STaniya Das 			.name = "gcc_ufs_phy_ice_core_clk",
190717269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
190817269568STaniya Das 				.hw = &gcc_ufs_phy_ice_core_clk_src.clkr.hw,
190917269568STaniya Das 			},
191017269568STaniya Das 			.num_parents = 1,
191117269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
191217269568STaniya Das 			.ops = &clk_branch2_ops,
191317269568STaniya Das 		},
191417269568STaniya Das 	},
191517269568STaniya Das };
191617269568STaniya Das 
191717269568STaniya Das static struct clk_branch gcc_ufs_phy_phy_aux_clk = {
191817269568STaniya Das 	.halt_reg = 0x77094,
191917269568STaniya Das 	.halt_check = BRANCH_HALT,
192017269568STaniya Das 	.hwcg_reg = 0x77094,
192117269568STaniya Das 	.hwcg_bit = 1,
192217269568STaniya Das 	.clkr = {
192317269568STaniya Das 		.enable_reg = 0x77094,
192417269568STaniya Das 		.enable_mask = BIT(0),
192517269568STaniya Das 		.hw.init = &(struct clk_init_data){
192617269568STaniya Das 			.name = "gcc_ufs_phy_phy_aux_clk",
192717269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
192817269568STaniya Das 				.hw = &gcc_ufs_phy_phy_aux_clk_src.clkr.hw,
192917269568STaniya Das 			},
193017269568STaniya Das 			.num_parents = 1,
193117269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
193217269568STaniya Das 			.ops = &clk_branch2_ops,
193317269568STaniya Das 		},
193417269568STaniya Das 	},
193517269568STaniya Das };
193617269568STaniya Das 
193717269568STaniya Das static struct clk_branch gcc_ufs_phy_rx_symbol_0_clk = {
193817269568STaniya Das 	.halt_reg = 0x7701c,
193917269568STaniya Das 	.halt_check = BRANCH_HALT_SKIP,
194017269568STaniya Das 	.clkr = {
194117269568STaniya Das 		.enable_reg = 0x7701c,
194217269568STaniya Das 		.enable_mask = BIT(0),
194317269568STaniya Das 		.hw.init = &(struct clk_init_data){
194417269568STaniya Das 			.name = "gcc_ufs_phy_rx_symbol_0_clk",
194517269568STaniya Das 			.ops = &clk_branch2_ops,
194617269568STaniya Das 		},
194717269568STaniya Das 	},
194817269568STaniya Das };
194917269568STaniya Das 
195017269568STaniya Das static struct clk_branch gcc_ufs_phy_tx_symbol_0_clk = {
195117269568STaniya Das 	.halt_reg = 0x77018,
195217269568STaniya Das 	.halt_check = BRANCH_HALT_SKIP,
195317269568STaniya Das 	.clkr = {
195417269568STaniya Das 		.enable_reg = 0x77018,
195517269568STaniya Das 		.enable_mask = BIT(0),
195617269568STaniya Das 		.hw.init = &(struct clk_init_data){
195717269568STaniya Das 			.name = "gcc_ufs_phy_tx_symbol_0_clk",
195817269568STaniya Das 			.ops = &clk_branch2_ops,
195917269568STaniya Das 		},
196017269568STaniya Das 	},
196117269568STaniya Das };
196217269568STaniya Das 
196317269568STaniya Das static struct clk_branch gcc_ufs_phy_unipro_core_clk = {
196417269568STaniya Das 	.halt_reg = 0x7708c,
196517269568STaniya Das 	.halt_check = BRANCH_HALT,
196617269568STaniya Das 	.hwcg_reg = 0x7708c,
196717269568STaniya Das 	.hwcg_bit = 1,
196817269568STaniya Das 	.clkr = {
196917269568STaniya Das 		.enable_reg = 0x7708c,
197017269568STaniya Das 		.enable_mask = BIT(0),
197117269568STaniya Das 		.hw.init = &(struct clk_init_data){
197217269568STaniya Das 			.name = "gcc_ufs_phy_unipro_core_clk",
197317269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
197417269568STaniya Das 				.hw = &gcc_ufs_phy_unipro_core_clk_src.clkr.hw,
197517269568STaniya Das 			},
197617269568STaniya Das 			.num_parents = 1,
197717269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
197817269568STaniya Das 			.ops = &clk_branch2_ops,
197917269568STaniya Das 		},
198017269568STaniya Das 	},
198117269568STaniya Das };
198217269568STaniya Das 
198317269568STaniya Das static struct clk_branch gcc_usb30_prim_master_clk = {
198417269568STaniya Das 	.halt_reg = 0xf010,
198517269568STaniya Das 	.halt_check = BRANCH_HALT,
198617269568STaniya Das 	.clkr = {
198717269568STaniya Das 		.enable_reg = 0xf010,
198817269568STaniya Das 		.enable_mask = BIT(0),
198917269568STaniya Das 		.hw.init = &(struct clk_init_data){
199017269568STaniya Das 			.name = "gcc_usb30_prim_master_clk",
199117269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
199217269568STaniya Das 				.hw = &gcc_usb30_prim_master_clk_src.clkr.hw,
199317269568STaniya Das 			},
199417269568STaniya Das 			.num_parents = 1,
199517269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
199617269568STaniya Das 			.ops = &clk_branch2_ops,
199717269568STaniya Das 		},
199817269568STaniya Das 	},
199917269568STaniya Das };
200017269568STaniya Das 
200117269568STaniya Das static struct clk_branch gcc_usb30_prim_mock_utmi_clk = {
200217269568STaniya Das 	.halt_reg = 0xf018,
200317269568STaniya Das 	.halt_check = BRANCH_HALT,
200417269568STaniya Das 	.clkr = {
200517269568STaniya Das 		.enable_reg = 0xf018,
200617269568STaniya Das 		.enable_mask = BIT(0),
200717269568STaniya Das 		.hw.init = &(struct clk_init_data){
200817269568STaniya Das 			.name = "gcc_usb30_prim_mock_utmi_clk",
200917269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
201017269568STaniya Das 				.hw =
201117269568STaniya Das 				&gcc_usb30_prim_mock_utmi_clk_src.clkr.hw,
201217269568STaniya Das 			},
201317269568STaniya Das 			.num_parents = 1,
201417269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
201517269568STaniya Das 			.ops = &clk_branch2_ops,
201617269568STaniya Das 		},
201717269568STaniya Das 	},
201817269568STaniya Das };
201917269568STaniya Das 
202017269568STaniya Das static struct clk_branch gcc_usb30_prim_sleep_clk = {
202117269568STaniya Das 	.halt_reg = 0xf014,
202217269568STaniya Das 	.halt_check = BRANCH_HALT,
202317269568STaniya Das 	.clkr = {
202417269568STaniya Das 		.enable_reg = 0xf014,
202517269568STaniya Das 		.enable_mask = BIT(0),
202617269568STaniya Das 		.hw.init = &(struct clk_init_data){
202717269568STaniya Das 			.name = "gcc_usb30_prim_sleep_clk",
202817269568STaniya Das 			.ops = &clk_branch2_ops,
202917269568STaniya Das 		},
203017269568STaniya Das 	},
203117269568STaniya Das };
203217269568STaniya Das 
203317269568STaniya Das static struct clk_branch gcc_usb3_prim_clkref_clk = {
203417269568STaniya Das 	.halt_reg = 0x8c010,
203517269568STaniya Das 	.halt_check = BRANCH_HALT,
203617269568STaniya Das 	.clkr = {
203717269568STaniya Das 		.enable_reg = 0x8c010,
203817269568STaniya Das 		.enable_mask = BIT(0),
203917269568STaniya Das 		.hw.init = &(struct clk_init_data){
204017269568STaniya Das 			.name = "gcc_usb3_prim_clkref_clk",
204117269568STaniya Das 			.ops = &clk_branch2_ops,
204217269568STaniya Das 		},
204317269568STaniya Das 	},
204417269568STaniya Das };
204517269568STaniya Das 
204617269568STaniya Das static struct clk_branch gcc_usb3_prim_phy_aux_clk = {
204717269568STaniya Das 	.halt_reg = 0xf050,
204817269568STaniya Das 	.halt_check = BRANCH_HALT,
204917269568STaniya Das 	.clkr = {
205017269568STaniya Das 		.enable_reg = 0xf050,
205117269568STaniya Das 		.enable_mask = BIT(0),
205217269568STaniya Das 		.hw.init = &(struct clk_init_data){
205317269568STaniya Das 			.name = "gcc_usb3_prim_phy_aux_clk",
205417269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
205517269568STaniya Das 				.hw = &gcc_usb3_prim_phy_aux_clk_src.clkr.hw,
205617269568STaniya Das 			},
205717269568STaniya Das 			.num_parents = 1,
205817269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
205917269568STaniya Das 			.ops = &clk_branch2_ops,
206017269568STaniya Das 		},
206117269568STaniya Das 	},
206217269568STaniya Das };
206317269568STaniya Das 
206417269568STaniya Das static struct clk_branch gcc_usb3_prim_phy_com_aux_clk = {
206517269568STaniya Das 	.halt_reg = 0xf054,
206617269568STaniya Das 	.halt_check = BRANCH_HALT,
206717269568STaniya Das 	.clkr = {
206817269568STaniya Das 		.enable_reg = 0xf054,
206917269568STaniya Das 		.enable_mask = BIT(0),
207017269568STaniya Das 		.hw.init = &(struct clk_init_data){
207117269568STaniya Das 			.name = "gcc_usb3_prim_phy_com_aux_clk",
207217269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
207317269568STaniya Das 				.hw = &gcc_usb3_prim_phy_aux_clk_src.clkr.hw,
207417269568STaniya Das 			},
207517269568STaniya Das 			.num_parents = 1,
207617269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
207717269568STaniya Das 			.ops = &clk_branch2_ops,
207817269568STaniya Das 		},
207917269568STaniya Das 	},
208017269568STaniya Das };
208117269568STaniya Das 
208217269568STaniya Das static struct clk_branch gcc_usb3_prim_phy_pipe_clk = {
208317269568STaniya Das 	.halt_reg = 0xf058,
208417269568STaniya Das 	.halt_check = BRANCH_HALT_SKIP,
208517269568STaniya Das 	.clkr = {
208617269568STaniya Das 		.enable_reg = 0xf058,
208717269568STaniya Das 		.enable_mask = BIT(0),
208817269568STaniya Das 		.hw.init = &(struct clk_init_data){
208917269568STaniya Das 			.name = "gcc_usb3_prim_phy_pipe_clk",
209017269568STaniya Das 			.ops = &clk_branch2_ops,
209117269568STaniya Das 		},
209217269568STaniya Das 	},
209317269568STaniya Das };
209417269568STaniya Das 
209517269568STaniya Das static struct clk_branch gcc_usb_phy_cfg_ahb2phy_clk = {
209617269568STaniya Das 	.halt_reg = 0x6a004,
209717269568STaniya Das 	.halt_check = BRANCH_HALT,
209817269568STaniya Das 	.hwcg_reg = 0x6a004,
209917269568STaniya Das 	.hwcg_bit = 1,
210017269568STaniya Das 	.clkr = {
210117269568STaniya Das 		.enable_reg = 0x6a004,
210217269568STaniya Das 		.enable_mask = BIT(0),
210317269568STaniya Das 		.hw.init = &(struct clk_init_data){
210417269568STaniya Das 			.name = "gcc_usb_phy_cfg_ahb2phy_clk",
210517269568STaniya Das 			.ops = &clk_branch2_ops,
210617269568STaniya Das 		},
210717269568STaniya Das 	},
210817269568STaniya Das };
210917269568STaniya Das 
211017269568STaniya Das static struct clk_branch gcc_video_axi_clk = {
211117269568STaniya Das 	.halt_reg = 0xb01c,
211217269568STaniya Das 	.halt_check = BRANCH_HALT,
211317269568STaniya Das 	.clkr = {
211417269568STaniya Das 		.enable_reg = 0xb01c,
211517269568STaniya Das 		.enable_mask = BIT(0),
211617269568STaniya Das 		.hw.init = &(struct clk_init_data){
211717269568STaniya Das 			.name = "gcc_video_axi_clk",
211817269568STaniya Das 			.ops = &clk_branch2_ops,
211917269568STaniya Das 		},
212017269568STaniya Das 	},
212117269568STaniya Das };
212217269568STaniya Das 
212317269568STaniya Das static struct clk_branch gcc_video_gpll0_div_clk_src = {
212417269568STaniya Das 	.halt_check = BRANCH_HALT_DELAY,
212517269568STaniya Das 	.clkr = {
212617269568STaniya Das 		.enable_reg = 0x52000,
212717269568STaniya Das 		.enable_mask = BIT(20),
212817269568STaniya Das 		.hw.init = &(struct clk_init_data){
212917269568STaniya Das 			.name = "gcc_video_gpll0_div_clk_src",
213017269568STaniya Das 			.parent_data = &(const struct clk_parent_data){
213117269568STaniya Das 				.hw = &gcc_pll0_main_div_cdiv.hw,
213217269568STaniya Das 			},
213317269568STaniya Das 			.num_parents = 1,
213417269568STaniya Das 			.flags = CLK_SET_RATE_PARENT,
213517269568STaniya Das 			.ops = &clk_branch2_ops,
213617269568STaniya Das 		},
213717269568STaniya Das 	},
213817269568STaniya Das };
213917269568STaniya Das 
214017269568STaniya Das static struct clk_branch gcc_video_throttle_axi_clk = {
214117269568STaniya Das 	.halt_reg = 0xb07c,
214217269568STaniya Das 	.halt_check = BRANCH_HALT,
214317269568STaniya Das 	.hwcg_reg = 0xb07c,
214417269568STaniya Das 	.hwcg_bit = 1,
214517269568STaniya Das 	.clkr = {
214617269568STaniya Das 		.enable_reg = 0xb07c,
214717269568STaniya Das 		.enable_mask = BIT(0),
214817269568STaniya Das 		.hw.init = &(struct clk_init_data){
214917269568STaniya Das 			.name = "gcc_video_throttle_axi_clk",
215017269568STaniya Das 			.ops = &clk_branch2_ops,
215117269568STaniya Das 		},
215217269568STaniya Das 	},
215317269568STaniya Das };
215417269568STaniya Das 
215517269568STaniya Das static struct clk_branch gcc_video_xo_clk = {
215617269568STaniya Das 	.halt_reg = 0xb028,
215717269568STaniya Das 	.halt_check = BRANCH_HALT,
215817269568STaniya Das 	.clkr = {
215917269568STaniya Das 		.enable_reg = 0xb028,
216017269568STaniya Das 		.enable_mask = BIT(0),
216117269568STaniya Das 		.hw.init = &(struct clk_init_data){
216217269568STaniya Das 			.name = "gcc_video_xo_clk",
216317269568STaniya Das 			.ops = &clk_branch2_ops,
216417269568STaniya Das 		},
216517269568STaniya Das 	},
216617269568STaniya Das };
216717269568STaniya Das 
216817269568STaniya Das static struct gdsc ufs_phy_gdsc = {
216917269568STaniya Das 	.gdscr = 0x77004,
217017269568STaniya Das 	.pd = {
217117269568STaniya Das 		.name = "ufs_phy_gdsc",
217217269568STaniya Das 	},
217317269568STaniya Das 	.pwrsts = PWRSTS_OFF_ON,
217417269568STaniya Das };
217517269568STaniya Das 
217617269568STaniya Das static struct gdsc usb30_prim_gdsc = {
217717269568STaniya Das 	.gdscr = 0x0f004,
217817269568STaniya Das 	.pd = {
217917269568STaniya Das 		.name = "usb30_prim_gdsc",
218017269568STaniya Das 	},
218117269568STaniya Das 	.pwrsts = PWRSTS_OFF_ON,
218217269568STaniya Das };
218317269568STaniya Das 
218417269568STaniya Das static struct gdsc hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc = {
218517269568STaniya Das 	.gdscr = 0x7d040,
218617269568STaniya Das 	.pd = {
218717269568STaniya Das 		.name = "hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc",
218817269568STaniya Das 	},
2189*8d20c39fSMatthias Kaehlcke 	.pwrsts = PWRSTS_OFF_ON,
2190*8d20c39fSMatthias Kaehlcke 	.flags = VOTABLE,
219117269568STaniya Das };
219217269568STaniya Das 
219317269568STaniya Das static struct gdsc hlos1_vote_mmnoc_mmu_tbu_sf_gdsc = {
219417269568STaniya Das 	.gdscr = 0x7d044,
219517269568STaniya Das 	.pd = {
219617269568STaniya Das 		.name = "hlos1_vote_mmnoc_mmu_tbu_sf_gdsc",
219717269568STaniya Das 	},
2198*8d20c39fSMatthias Kaehlcke 	.pwrsts = PWRSTS_OFF_ON,
2199*8d20c39fSMatthias Kaehlcke 	.flags = VOTABLE,
220017269568STaniya Das };
220117269568STaniya Das 
220217269568STaniya Das static struct gdsc *gcc_sc7180_gdscs[] = {
220317269568STaniya Das 	[UFS_PHY_GDSC] = &ufs_phy_gdsc,
220417269568STaniya Das 	[USB30_PRIM_GDSC] = &usb30_prim_gdsc,
220517269568STaniya Das 	[HLOS1_VOTE_MMNOC_MMU_TBU_HF0_GDSC] =
220617269568STaniya Das 					&hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc,
220717269568STaniya Das 	[HLOS1_VOTE_MMNOC_MMU_TBU_SF_GDSC] =
220817269568STaniya Das 					&hlos1_vote_mmnoc_mmu_tbu_sf_gdsc,
220917269568STaniya Das };
221017269568STaniya Das 
221117269568STaniya Das 
221217269568STaniya Das static struct clk_hw *gcc_sc7180_hws[] = {
221317269568STaniya Das 	[GCC_GPLL0_MAIN_DIV_CDIV] = &gcc_pll0_main_div_cdiv.hw,
221417269568STaniya Das };
221517269568STaniya Das 
221617269568STaniya Das static struct clk_regmap *gcc_sc7180_clocks[] = {
221717269568STaniya Das 	[GCC_AGGRE_UFS_PHY_AXI_CLK] = &gcc_aggre_ufs_phy_axi_clk.clkr,
221817269568STaniya Das 	[GCC_AGGRE_USB3_PRIM_AXI_CLK] = &gcc_aggre_usb3_prim_axi_clk.clkr,
221917269568STaniya Das 	[GCC_BOOT_ROM_AHB_CLK] = &gcc_boot_rom_ahb_clk.clkr,
222017269568STaniya Das 	[GCC_CAMERA_AHB_CLK] = &gcc_camera_ahb_clk.clkr,
222117269568STaniya Das 	[GCC_CAMERA_HF_AXI_CLK] = &gcc_camera_hf_axi_clk.clkr,
222217269568STaniya Das 	[GCC_CAMERA_THROTTLE_HF_AXI_CLK] = &gcc_camera_throttle_hf_axi_clk.clkr,
222317269568STaniya Das 	[GCC_CAMERA_XO_CLK] = &gcc_camera_xo_clk.clkr,
222417269568STaniya Das 	[GCC_CE1_AHB_CLK] = &gcc_ce1_ahb_clk.clkr,
222517269568STaniya Das 	[GCC_CE1_AXI_CLK] = &gcc_ce1_axi_clk.clkr,
222617269568STaniya Das 	[GCC_CE1_CLK] = &gcc_ce1_clk.clkr,
222717269568STaniya Das 	[GCC_CFG_NOC_USB3_PRIM_AXI_CLK] = &gcc_cfg_noc_usb3_prim_axi_clk.clkr,
222817269568STaniya Das 	[GCC_CPUSS_AHB_CLK] = &gcc_cpuss_ahb_clk.clkr,
222917269568STaniya Das 	[GCC_CPUSS_AHB_CLK_SRC] = &gcc_cpuss_ahb_clk_src.clkr,
223017269568STaniya Das 	[GCC_CPUSS_RBCPR_CLK] = &gcc_cpuss_rbcpr_clk.clkr,
223117269568STaniya Das 	[GCC_DDRSS_GPU_AXI_CLK] = &gcc_ddrss_gpu_axi_clk.clkr,
223217269568STaniya Das 	[GCC_DISP_GPLL0_CLK_SRC] = &gcc_disp_gpll0_clk_src.clkr,
223317269568STaniya Das 	[GCC_DISP_GPLL0_DIV_CLK_SRC] = &gcc_disp_gpll0_div_clk_src.clkr,
223417269568STaniya Das 	[GCC_DISP_HF_AXI_CLK] = &gcc_disp_hf_axi_clk.clkr,
223517269568STaniya Das 	[GCC_DISP_THROTTLE_HF_AXI_CLK] = &gcc_disp_throttle_hf_axi_clk.clkr,
223617269568STaniya Das 	[GCC_DISP_XO_CLK] = &gcc_disp_xo_clk.clkr,
223717269568STaniya Das 	[GCC_GP1_CLK] = &gcc_gp1_clk.clkr,
223817269568STaniya Das 	[GCC_GP1_CLK_SRC] = &gcc_gp1_clk_src.clkr,
223917269568STaniya Das 	[GCC_GP2_CLK] = &gcc_gp2_clk.clkr,
224017269568STaniya Das 	[GCC_GP2_CLK_SRC] = &gcc_gp2_clk_src.clkr,
224117269568STaniya Das 	[GCC_GP3_CLK] = &gcc_gp3_clk.clkr,
224217269568STaniya Das 	[GCC_GP3_CLK_SRC] = &gcc_gp3_clk_src.clkr,
224317269568STaniya Das 	[GCC_GPU_GPLL0_CLK_SRC] = &gcc_gpu_gpll0_clk_src.clkr,
224417269568STaniya Das 	[GCC_GPU_GPLL0_DIV_CLK_SRC] = &gcc_gpu_gpll0_div_clk_src.clkr,
224517269568STaniya Das 	[GCC_GPU_MEMNOC_GFX_CLK] = &gcc_gpu_memnoc_gfx_clk.clkr,
224617269568STaniya Das 	[GCC_GPU_SNOC_DVM_GFX_CLK] = &gcc_gpu_snoc_dvm_gfx_clk.clkr,
224717269568STaniya Das 	[GCC_NPU_AXI_CLK] = &gcc_npu_axi_clk.clkr,
224817269568STaniya Das 	[GCC_NPU_BWMON_AXI_CLK] = &gcc_npu_bwmon_axi_clk.clkr,
224917269568STaniya Das 	[GCC_NPU_BWMON_DMA_CFG_AHB_CLK] = &gcc_npu_bwmon_dma_cfg_ahb_clk.clkr,
225017269568STaniya Das 	[GCC_NPU_BWMON_DSP_CFG_AHB_CLK] = &gcc_npu_bwmon_dsp_cfg_ahb_clk.clkr,
225117269568STaniya Das 	[GCC_NPU_CFG_AHB_CLK] = &gcc_npu_cfg_ahb_clk.clkr,
225217269568STaniya Das 	[GCC_NPU_DMA_CLK] = &gcc_npu_dma_clk.clkr,
225317269568STaniya Das 	[GCC_NPU_GPLL0_CLK_SRC] = &gcc_npu_gpll0_clk_src.clkr,
225417269568STaniya Das 	[GCC_NPU_GPLL0_DIV_CLK_SRC] = &gcc_npu_gpll0_div_clk_src.clkr,
225517269568STaniya Das 	[GCC_PDM2_CLK] = &gcc_pdm2_clk.clkr,
225617269568STaniya Das 	[GCC_PDM2_CLK_SRC] = &gcc_pdm2_clk_src.clkr,
225717269568STaniya Das 	[GCC_PDM_AHB_CLK] = &gcc_pdm_ahb_clk.clkr,
225817269568STaniya Das 	[GCC_PDM_XO4_CLK] = &gcc_pdm_xo4_clk.clkr,
225917269568STaniya Das 	[GCC_PRNG_AHB_CLK] = &gcc_prng_ahb_clk.clkr,
226017269568STaniya Das 	[GCC_QSPI_CNOC_PERIPH_AHB_CLK] = &gcc_qspi_cnoc_periph_ahb_clk.clkr,
226117269568STaniya Das 	[GCC_QSPI_CORE_CLK] = &gcc_qspi_core_clk.clkr,
226217269568STaniya Das 	[GCC_QSPI_CORE_CLK_SRC] = &gcc_qspi_core_clk_src.clkr,
226317269568STaniya Das 	[GCC_QUPV3_WRAP0_CORE_2X_CLK] = &gcc_qupv3_wrap0_core_2x_clk.clkr,
226417269568STaniya Das 	[GCC_QUPV3_WRAP0_CORE_CLK] = &gcc_qupv3_wrap0_core_clk.clkr,
226517269568STaniya Das 	[GCC_QUPV3_WRAP0_S0_CLK] = &gcc_qupv3_wrap0_s0_clk.clkr,
226617269568STaniya Das 	[GCC_QUPV3_WRAP0_S0_CLK_SRC] = &gcc_qupv3_wrap0_s0_clk_src.clkr,
226717269568STaniya Das 	[GCC_QUPV3_WRAP0_S1_CLK] = &gcc_qupv3_wrap0_s1_clk.clkr,
226817269568STaniya Das 	[GCC_QUPV3_WRAP0_S1_CLK_SRC] = &gcc_qupv3_wrap0_s1_clk_src.clkr,
226917269568STaniya Das 	[GCC_QUPV3_WRAP0_S2_CLK] = &gcc_qupv3_wrap0_s2_clk.clkr,
227017269568STaniya Das 	[GCC_QUPV3_WRAP0_S2_CLK_SRC] = &gcc_qupv3_wrap0_s2_clk_src.clkr,
227117269568STaniya Das 	[GCC_QUPV3_WRAP0_S3_CLK] = &gcc_qupv3_wrap0_s3_clk.clkr,
227217269568STaniya Das 	[GCC_QUPV3_WRAP0_S3_CLK_SRC] = &gcc_qupv3_wrap0_s3_clk_src.clkr,
227317269568STaniya Das 	[GCC_QUPV3_WRAP0_S4_CLK] = &gcc_qupv3_wrap0_s4_clk.clkr,
227417269568STaniya Das 	[GCC_QUPV3_WRAP0_S4_CLK_SRC] = &gcc_qupv3_wrap0_s4_clk_src.clkr,
227517269568STaniya Das 	[GCC_QUPV3_WRAP0_S5_CLK] = &gcc_qupv3_wrap0_s5_clk.clkr,
227617269568STaniya Das 	[GCC_QUPV3_WRAP0_S5_CLK_SRC] = &gcc_qupv3_wrap0_s5_clk_src.clkr,
227717269568STaniya Das 	[GCC_QUPV3_WRAP1_CORE_2X_CLK] = &gcc_qupv3_wrap1_core_2x_clk.clkr,
227817269568STaniya Das 	[GCC_QUPV3_WRAP1_CORE_CLK] = &gcc_qupv3_wrap1_core_clk.clkr,
227917269568STaniya Das 	[GCC_QUPV3_WRAP1_S0_CLK] = &gcc_qupv3_wrap1_s0_clk.clkr,
228017269568STaniya Das 	[GCC_QUPV3_WRAP1_S0_CLK_SRC] = &gcc_qupv3_wrap1_s0_clk_src.clkr,
228117269568STaniya Das 	[GCC_QUPV3_WRAP1_S1_CLK] = &gcc_qupv3_wrap1_s1_clk.clkr,
228217269568STaniya Das 	[GCC_QUPV3_WRAP1_S1_CLK_SRC] = &gcc_qupv3_wrap1_s1_clk_src.clkr,
228317269568STaniya Das 	[GCC_QUPV3_WRAP1_S2_CLK] = &gcc_qupv3_wrap1_s2_clk.clkr,
228417269568STaniya Das 	[GCC_QUPV3_WRAP1_S2_CLK_SRC] = &gcc_qupv3_wrap1_s2_clk_src.clkr,
228517269568STaniya Das 	[GCC_QUPV3_WRAP1_S3_CLK] = &gcc_qupv3_wrap1_s3_clk.clkr,
228617269568STaniya Das 	[GCC_QUPV3_WRAP1_S3_CLK_SRC] = &gcc_qupv3_wrap1_s3_clk_src.clkr,
228717269568STaniya Das 	[GCC_QUPV3_WRAP1_S4_CLK] = &gcc_qupv3_wrap1_s4_clk.clkr,
228817269568STaniya Das 	[GCC_QUPV3_WRAP1_S4_CLK_SRC] = &gcc_qupv3_wrap1_s4_clk_src.clkr,
228917269568STaniya Das 	[GCC_QUPV3_WRAP1_S5_CLK] = &gcc_qupv3_wrap1_s5_clk.clkr,
229017269568STaniya Das 	[GCC_QUPV3_WRAP1_S5_CLK_SRC] = &gcc_qupv3_wrap1_s5_clk_src.clkr,
229117269568STaniya Das 	[GCC_QUPV3_WRAP_0_M_AHB_CLK] = &gcc_qupv3_wrap_0_m_ahb_clk.clkr,
229217269568STaniya Das 	[GCC_QUPV3_WRAP_0_S_AHB_CLK] = &gcc_qupv3_wrap_0_s_ahb_clk.clkr,
229317269568STaniya Das 	[GCC_QUPV3_WRAP_1_M_AHB_CLK] = &gcc_qupv3_wrap_1_m_ahb_clk.clkr,
229417269568STaniya Das 	[GCC_QUPV3_WRAP_1_S_AHB_CLK] = &gcc_qupv3_wrap_1_s_ahb_clk.clkr,
229517269568STaniya Das 	[GCC_SDCC1_AHB_CLK] = &gcc_sdcc1_ahb_clk.clkr,
229617269568STaniya Das 	[GCC_SDCC1_APPS_CLK] = &gcc_sdcc1_apps_clk.clkr,
229717269568STaniya Das 	[GCC_SDCC1_APPS_CLK_SRC] = &gcc_sdcc1_apps_clk_src.clkr,
229817269568STaniya Das 	[GCC_SDCC1_ICE_CORE_CLK] = &gcc_sdcc1_ice_core_clk.clkr,
229917269568STaniya Das 	[GCC_SDCC1_ICE_CORE_CLK_SRC] = &gcc_sdcc1_ice_core_clk_src.clkr,
230017269568STaniya Das 	[GCC_SDCC2_AHB_CLK] = &gcc_sdcc2_ahb_clk.clkr,
230117269568STaniya Das 	[GCC_SDCC2_APPS_CLK] = &gcc_sdcc2_apps_clk.clkr,
230217269568STaniya Das 	[GCC_SDCC2_APPS_CLK_SRC] = &gcc_sdcc2_apps_clk_src.clkr,
230317269568STaniya Das 	[GCC_SYS_NOC_CPUSS_AHB_CLK] = &gcc_sys_noc_cpuss_ahb_clk.clkr,
230417269568STaniya Das 	[GCC_UFS_MEM_CLKREF_CLK] = &gcc_ufs_mem_clkref_clk.clkr,
230517269568STaniya Das 	[GCC_UFS_PHY_AHB_CLK] = &gcc_ufs_phy_ahb_clk.clkr,
230617269568STaniya Das 	[GCC_UFS_PHY_AXI_CLK] = &gcc_ufs_phy_axi_clk.clkr,
230717269568STaniya Das 	[GCC_UFS_PHY_AXI_CLK_SRC] = &gcc_ufs_phy_axi_clk_src.clkr,
230817269568STaniya Das 	[GCC_UFS_PHY_ICE_CORE_CLK] = &gcc_ufs_phy_ice_core_clk.clkr,
230917269568STaniya Das 	[GCC_UFS_PHY_ICE_CORE_CLK_SRC] = &gcc_ufs_phy_ice_core_clk_src.clkr,
231017269568STaniya Das 	[GCC_UFS_PHY_PHY_AUX_CLK] = &gcc_ufs_phy_phy_aux_clk.clkr,
231117269568STaniya Das 	[GCC_UFS_PHY_PHY_AUX_CLK_SRC] = &gcc_ufs_phy_phy_aux_clk_src.clkr,
231217269568STaniya Das 	[GCC_UFS_PHY_RX_SYMBOL_0_CLK] = &gcc_ufs_phy_rx_symbol_0_clk.clkr,
231317269568STaniya Das 	[GCC_UFS_PHY_TX_SYMBOL_0_CLK] = &gcc_ufs_phy_tx_symbol_0_clk.clkr,
231417269568STaniya Das 	[GCC_UFS_PHY_UNIPRO_CORE_CLK] = &gcc_ufs_phy_unipro_core_clk.clkr,
231517269568STaniya Das 	[GCC_UFS_PHY_UNIPRO_CORE_CLK_SRC] =
231617269568STaniya Das 		&gcc_ufs_phy_unipro_core_clk_src.clkr,
231717269568STaniya Das 	[GCC_USB30_PRIM_MASTER_CLK] = &gcc_usb30_prim_master_clk.clkr,
231817269568STaniya Das 	[GCC_USB30_PRIM_MASTER_CLK_SRC] = &gcc_usb30_prim_master_clk_src.clkr,
231917269568STaniya Das 	[GCC_USB30_PRIM_MOCK_UTMI_CLK] = &gcc_usb30_prim_mock_utmi_clk.clkr,
232017269568STaniya Das 	[GCC_USB30_PRIM_MOCK_UTMI_CLK_SRC] =
232117269568STaniya Das 		&gcc_usb30_prim_mock_utmi_clk_src.clkr,
232217269568STaniya Das 	[GCC_USB30_PRIM_SLEEP_CLK] = &gcc_usb30_prim_sleep_clk.clkr,
232317269568STaniya Das 	[GCC_USB3_PRIM_CLKREF_CLK] = &gcc_usb3_prim_clkref_clk.clkr,
232417269568STaniya Das 	[GCC_USB3_PRIM_PHY_AUX_CLK] = &gcc_usb3_prim_phy_aux_clk.clkr,
232517269568STaniya Das 	[GCC_USB3_PRIM_PHY_AUX_CLK_SRC] = &gcc_usb3_prim_phy_aux_clk_src.clkr,
232617269568STaniya Das 	[GCC_USB3_PRIM_PHY_COM_AUX_CLK] = &gcc_usb3_prim_phy_com_aux_clk.clkr,
232717269568STaniya Das 	[GCC_USB3_PRIM_PHY_PIPE_CLK] = &gcc_usb3_prim_phy_pipe_clk.clkr,
232817269568STaniya Das 	[GCC_USB_PHY_CFG_AHB2PHY_CLK] = &gcc_usb_phy_cfg_ahb2phy_clk.clkr,
232917269568STaniya Das 	[GCC_VIDEO_AXI_CLK] = &gcc_video_axi_clk.clkr,
233017269568STaniya Das 	[GCC_VIDEO_GPLL0_DIV_CLK_SRC] = &gcc_video_gpll0_div_clk_src.clkr,
233117269568STaniya Das 	[GCC_VIDEO_THROTTLE_AXI_CLK] = &gcc_video_throttle_axi_clk.clkr,
233217269568STaniya Das 	[GCC_VIDEO_XO_CLK] = &gcc_video_xo_clk.clkr,
233317269568STaniya Das 	[GPLL0] = &gpll0.clkr,
233417269568STaniya Das 	[GPLL0_OUT_EVEN] = &gpll0_out_even.clkr,
233517269568STaniya Das 	[GPLL6] = &gpll6.clkr,
233617269568STaniya Das 	[GPLL7] = &gpll7.clkr,
233717269568STaniya Das 	[GPLL4] = &gpll4.clkr,
233817269568STaniya Das 	[GPLL1] = &gpll1.clkr,
233917269568STaniya Das };
234017269568STaniya Das 
234117269568STaniya Das static const struct qcom_reset_map gcc_sc7180_resets[] = {
234217269568STaniya Das 	[GCC_QUSB2PHY_PRIM_BCR] = { 0x26000 },
234317269568STaniya Das 	[GCC_QUSB2PHY_SEC_BCR] = { 0x26004 },
234417269568STaniya Das 	[GCC_UFS_PHY_BCR] = { 0x77000 },
234517269568STaniya Das 	[GCC_USB30_PRIM_BCR] = { 0xf000 },
234617269568STaniya Das 	[GCC_USB3_PHY_PRIM_BCR] = { 0x50000 },
234717269568STaniya Das 	[GCC_USB3PHY_PHY_PRIM_BCR] = { 0x50004 },
234817269568STaniya Das 	[GCC_USB3_PHY_SEC_BCR] = { 0x5000c },
234917269568STaniya Das 	[GCC_USB3_DP_PHY_PRIM_BCR] = { 0x50008 },
235017269568STaniya Das 	[GCC_USB3PHY_PHY_SEC_BCR] = { 0x50010 },
235117269568STaniya Das 	[GCC_USB3_DP_PHY_SEC_BCR] = { 0x50014 },
235217269568STaniya Das 	[GCC_USB_PHY_CFG_AHB2PHY_BCR] = { 0x6a000 },
235317269568STaniya Das };
235417269568STaniya Das 
235517269568STaniya Das static struct clk_rcg_dfs_data gcc_dfs_clocks[] = {
235617269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s0_clk_src),
235717269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s1_clk_src),
235817269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s2_clk_src),
235917269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s3_clk_src),
236017269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s4_clk_src),
236117269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap0_s5_clk_src),
236217269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s0_clk_src),
236317269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s1_clk_src),
236417269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s2_clk_src),
236517269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s3_clk_src),
236617269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s4_clk_src),
236717269568STaniya Das 	DEFINE_RCG_DFS(gcc_qupv3_wrap1_s5_clk_src),
236817269568STaniya Das };
236917269568STaniya Das 
237017269568STaniya Das static const struct regmap_config gcc_sc7180_regmap_config = {
237117269568STaniya Das 	.reg_bits = 32,
237217269568STaniya Das 	.reg_stride = 4,
237317269568STaniya Das 	.val_bits = 32,
237417269568STaniya Das 	.max_register = 0x18208c,
237517269568STaniya Das 	.fast_io = true,
237617269568STaniya Das };
237717269568STaniya Das 
237817269568STaniya Das static const struct qcom_cc_desc gcc_sc7180_desc = {
237917269568STaniya Das 	.config = &gcc_sc7180_regmap_config,
238017269568STaniya Das 	.clk_hws = gcc_sc7180_hws,
238117269568STaniya Das 	.num_clk_hws = ARRAY_SIZE(gcc_sc7180_hws),
238217269568STaniya Das 	.clks = gcc_sc7180_clocks,
238317269568STaniya Das 	.num_clks = ARRAY_SIZE(gcc_sc7180_clocks),
238417269568STaniya Das 	.resets = gcc_sc7180_resets,
238517269568STaniya Das 	.num_resets = ARRAY_SIZE(gcc_sc7180_resets),
238617269568STaniya Das 	.gdscs = gcc_sc7180_gdscs,
238717269568STaniya Das 	.num_gdscs = ARRAY_SIZE(gcc_sc7180_gdscs),
238817269568STaniya Das };
238917269568STaniya Das 
239017269568STaniya Das static const struct of_device_id gcc_sc7180_match_table[] = {
239117269568STaniya Das 	{ .compatible = "qcom,gcc-sc7180" },
239217269568STaniya Das 	{ }
239317269568STaniya Das };
239417269568STaniya Das MODULE_DEVICE_TABLE(of, gcc_sc7180_match_table);
239517269568STaniya Das 
239617269568STaniya Das static int gcc_sc7180_probe(struct platform_device *pdev)
239717269568STaniya Das {
239817269568STaniya Das 	struct regmap *regmap;
239917269568STaniya Das 	int ret;
240017269568STaniya Das 
240117269568STaniya Das 	regmap = qcom_cc_map(pdev, &gcc_sc7180_desc);
240217269568STaniya Das 	if (IS_ERR(regmap))
240317269568STaniya Das 		return PTR_ERR(regmap);
240417269568STaniya Das 
240517269568STaniya Das 	/*
240617269568STaniya Das 	 * Disable the GPLL0 active input to MM blocks, NPU
240717269568STaniya Das 	 * and GPU via MISC registers.
240817269568STaniya Das 	 */
240917269568STaniya Das 	regmap_update_bits(regmap, 0x09ffc, 0x3, 0x3);
241017269568STaniya Das 	regmap_update_bits(regmap, 0x4d110, 0x3, 0x3);
241117269568STaniya Das 	regmap_update_bits(regmap, 0x71028, 0x3, 0x3);
241217269568STaniya Das 
241317269568STaniya Das 	/*
241417269568STaniya Das 	 * Keep the clocks always-ON
241517269568STaniya Das 	 * GCC_CPUSS_GNOC_CLK, GCC_VIDEO_AHB_CLK, GCC_DISP_AHB_CLK
241617269568STaniya Das 	 * GCC_GPU_CFG_AHB_CLK
241717269568STaniya Das 	 */
241817269568STaniya Das 	regmap_update_bits(regmap, 0x48004, BIT(0), BIT(0));
241917269568STaniya Das 	regmap_update_bits(regmap, 0x0b004, BIT(0), BIT(0));
242017269568STaniya Das 	regmap_update_bits(regmap, 0x0b00c, BIT(0), BIT(0));
242117269568STaniya Das 	regmap_update_bits(regmap, 0x71004, BIT(0), BIT(0));
242217269568STaniya Das 
242317269568STaniya Das 	ret = qcom_cc_register_rcg_dfs(regmap, gcc_dfs_clocks,
242417269568STaniya Das 					ARRAY_SIZE(gcc_dfs_clocks));
242517269568STaniya Das 	if (ret)
242617269568STaniya Das 		return ret;
242717269568STaniya Das 
242817269568STaniya Das 	return qcom_cc_really_probe(pdev, &gcc_sc7180_desc, regmap);
242917269568STaniya Das }
243017269568STaniya Das 
243117269568STaniya Das static struct platform_driver gcc_sc7180_driver = {
243217269568STaniya Das 	.probe = gcc_sc7180_probe,
243317269568STaniya Das 	.driver = {
243417269568STaniya Das 		.name = "gcc-sc7180",
243517269568STaniya Das 		.of_match_table = gcc_sc7180_match_table,
243617269568STaniya Das 	},
243717269568STaniya Das };
243817269568STaniya Das 
243917269568STaniya Das static int __init gcc_sc7180_init(void)
244017269568STaniya Das {
244117269568STaniya Das 	return platform_driver_register(&gcc_sc7180_driver);
244217269568STaniya Das }
244317269568STaniya Das core_initcall(gcc_sc7180_init);
244417269568STaniya Das 
244517269568STaniya Das static void __exit gcc_sc7180_exit(void)
244617269568STaniya Das {
244717269568STaniya Das 	platform_driver_unregister(&gcc_sc7180_driver);
244817269568STaniya Das }
244917269568STaniya Das module_exit(gcc_sc7180_exit);
245017269568STaniya Das 
245117269568STaniya Das MODULE_DESCRIPTION("QTI GCC SC7180 Driver");
245217269568STaniya Das MODULE_LICENSE("GPL v2");
2453