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