1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * Copyright (c) 2023, Qualcomm Innovation Center, Inc. All rights reserved. 4 */ 5 6 #include <linux/clk-provider.h> 7 #include <linux/mod_devicetable.h> 8 #include <linux/module.h> 9 #include <linux/platform_device.h> 10 #include <linux/regmap.h> 11 12 #include <dt-bindings/clock/qcom,sm4450-gcc.h> 13 14 #include "clk-alpha-pll.h" 15 #include "clk-branch.h" 16 #include "clk-rcg.h" 17 #include "clk-regmap.h" 18 #include "clk-regmap-divider.h" 19 #include "clk-regmap-mux.h" 20 #include "clk-regmap-phy-mux.h" 21 #include "gdsc.h" 22 #include "reset.h" 23 24 enum { 25 DT_BI_TCXO, 26 DT_SLEEP_CLK, 27 DT_PCIE_0_PIPE_CLK, 28 DT_UFS_PHY_RX_SYMBOL_0_CLK, 29 DT_UFS_PHY_RX_SYMBOL_1_CLK, 30 DT_UFS_PHY_TX_SYMBOL_0_CLK, 31 DT_USB3_PHY_WRAPPER_GCC_USB30_PIPE_CLK, 32 }; 33 34 enum { 35 P_BI_TCXO, 36 P_GCC_GPLL0_OUT_EVEN, 37 P_GCC_GPLL0_OUT_MAIN, 38 P_GCC_GPLL0_OUT_ODD, 39 P_GCC_GPLL1_OUT_MAIN, 40 P_GCC_GPLL3_OUT_MAIN, 41 P_GCC_GPLL4_OUT_MAIN, 42 P_GCC_GPLL9_OUT_MAIN, 43 P_GCC_GPLL10_OUT_MAIN, 44 P_SLEEP_CLK, 45 P_UFS_PHY_RX_SYMBOL_0_CLK, 46 P_UFS_PHY_RX_SYMBOL_1_CLK, 47 P_UFS_PHY_TX_SYMBOL_0_CLK, 48 P_USB3_PHY_WRAPPER_GCC_USB30_PIPE_CLK, 49 }; 50 51 static const struct pll_vco lucid_evo_vco[] = { 52 { 249600000, 2020000000, 0 }, 53 }; 54 55 static struct clk_alpha_pll gcc_gpll0 = { 56 .offset = 0x0, 57 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_EVO], 58 .clkr = { 59 .enable_reg = 0x62018, 60 .enable_mask = BIT(0), 61 .hw.init = &(const struct clk_init_data) { 62 .name = "gcc_gpll0", 63 .parent_data = &(const struct clk_parent_data) { 64 .index = DT_BI_TCXO, 65 }, 66 .num_parents = 1, 67 .ops = &clk_alpha_pll_fixed_lucid_evo_ops, 68 }, 69 }, 70 }; 71 72 static const struct clk_div_table post_div_table_gcc_gpll0_out_even[] = { 73 { 0x1, 2 }, 74 { } 75 }; 76 77 static struct clk_alpha_pll_postdiv gcc_gpll0_out_even = { 78 .offset = 0x0, 79 .post_div_shift = 10, 80 .post_div_table = post_div_table_gcc_gpll0_out_even, 81 .num_post_div = ARRAY_SIZE(post_div_table_gcc_gpll0_out_even), 82 .width = 4, 83 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_EVO], 84 .clkr.hw.init = &(const struct clk_init_data) { 85 .name = "gcc_gpll0_out_even", 86 .parent_hws = (const struct clk_hw*[]) { 87 &gcc_gpll0.clkr.hw, 88 }, 89 .num_parents = 1, 90 .ops = &clk_alpha_pll_postdiv_lucid_evo_ops, 91 }, 92 }; 93 94 static const struct clk_div_table post_div_table_gcc_gpll0_out_odd[] = { 95 { 0x2, 3 }, 96 { } 97 }; 98 99 static struct clk_alpha_pll_postdiv gcc_gpll0_out_odd = { 100 .offset = 0x0, 101 .post_div_shift = 14, 102 .post_div_table = post_div_table_gcc_gpll0_out_odd, 103 .num_post_div = ARRAY_SIZE(post_div_table_gcc_gpll0_out_odd), 104 .width = 4, 105 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_EVO], 106 .clkr.hw.init = &(const struct clk_init_data) { 107 .name = "gcc_gpll0_out_odd", 108 .parent_hws = (const struct clk_hw*[]) { 109 &gcc_gpll0.clkr.hw, 110 }, 111 .num_parents = 1, 112 .ops = &clk_alpha_pll_postdiv_lucid_evo_ops, 113 }, 114 }; 115 116 static struct clk_alpha_pll gcc_gpll1 = { 117 .offset = 0x1000, 118 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_EVO], 119 .clkr = { 120 .enable_reg = 0x62018, 121 .enable_mask = BIT(1), 122 .hw.init = &(const struct clk_init_data) { 123 .name = "gcc_gpll1", 124 .parent_data = &(const struct clk_parent_data) { 125 .index = DT_BI_TCXO, 126 }, 127 .num_parents = 1, 128 .ops = &clk_alpha_pll_fixed_lucid_evo_ops, 129 }, 130 }, 131 }; 132 133 static const struct alpha_pll_config gcc_gpll3_config = { 134 .l = 0x14, 135 .alpha = 0xd555, 136 .config_ctl_val = 0x20485699, 137 .config_ctl_hi_val = 0x00182261, 138 .config_ctl_hi1_val = 0x32aa299c, 139 .user_ctl_val = 0x00000000, 140 .user_ctl_hi_val = 0x00000805, 141 }; 142 143 static struct clk_alpha_pll gcc_gpll3 = { 144 .offset = 0x3000, 145 .vco_table = lucid_evo_vco, 146 .num_vco = ARRAY_SIZE(lucid_evo_vco), 147 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_EVO], 148 .clkr = { 149 .enable_reg = 0x62018, 150 .enable_mask = BIT(3), 151 .hw.init = &(const struct clk_init_data) { 152 .name = "gcc_gpll3", 153 .parent_data = &(const struct clk_parent_data) { 154 .index = DT_BI_TCXO, 155 }, 156 .num_parents = 1, 157 .ops = &clk_alpha_pll_lucid_evo_ops, 158 }, 159 }, 160 }; 161 162 static struct clk_alpha_pll gcc_gpll4 = { 163 .offset = 0x4000, 164 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_EVO], 165 .clkr = { 166 .enable_reg = 0x62018, 167 .enable_mask = BIT(4), 168 .hw.init = &(const struct clk_init_data) { 169 .name = "gcc_gpll4", 170 .parent_data = &(const struct clk_parent_data) { 171 .index = DT_BI_TCXO, 172 }, 173 .num_parents = 1, 174 .ops = &clk_alpha_pll_fixed_lucid_evo_ops, 175 }, 176 }, 177 }; 178 179 static struct clk_alpha_pll gcc_gpll9 = { 180 .offset = 0x9000, 181 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_EVO], 182 .clkr = { 183 .enable_reg = 0x62018, 184 .enable_mask = BIT(9), 185 .hw.init = &(const struct clk_init_data) { 186 .name = "gcc_gpll9", 187 .parent_data = &(const struct clk_parent_data) { 188 .index = DT_BI_TCXO, 189 }, 190 .num_parents = 1, 191 .ops = &clk_alpha_pll_fixed_lucid_evo_ops, 192 }, 193 }, 194 }; 195 196 static struct clk_alpha_pll gcc_gpll10 = { 197 .offset = 0xa000, 198 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_EVO], 199 .clkr = { 200 .enable_reg = 0x62018, 201 .enable_mask = BIT(10), 202 .hw.init = &(const struct clk_init_data) { 203 .name = "gcc_gpll10", 204 .parent_data = &(const struct clk_parent_data) { 205 .index = DT_BI_TCXO, 206 }, 207 .num_parents = 1, 208 .ops = &clk_alpha_pll_fixed_lucid_evo_ops, 209 }, 210 }, 211 }; 212 213 static const struct parent_map gcc_parent_map_0[] = { 214 { P_BI_TCXO, 0 }, 215 { P_GCC_GPLL0_OUT_MAIN, 1 }, 216 { P_GCC_GPLL0_OUT_EVEN, 6 }, 217 }; 218 219 static const struct clk_parent_data gcc_parent_data_0[] = { 220 { .index = DT_BI_TCXO }, 221 { .hw = &gcc_gpll0.clkr.hw }, 222 { .hw = &gcc_gpll0_out_even.clkr.hw }, 223 }; 224 225 static const struct parent_map gcc_parent_map_1[] = { 226 { P_BI_TCXO, 0 }, 227 { P_GCC_GPLL0_OUT_MAIN, 1 }, 228 { P_SLEEP_CLK, 5 }, 229 { P_GCC_GPLL0_OUT_EVEN, 6 }, 230 }; 231 232 static const struct clk_parent_data gcc_parent_data_1[] = { 233 { .index = DT_BI_TCXO }, 234 { .hw = &gcc_gpll0.clkr.hw }, 235 { .index = DT_SLEEP_CLK }, 236 { .hw = &gcc_gpll0_out_even.clkr.hw }, 237 }; 238 239 static const struct parent_map gcc_parent_map_2[] = { 240 { P_BI_TCXO, 0 }, 241 { P_GCC_GPLL0_OUT_MAIN, 1 }, 242 { P_GCC_GPLL1_OUT_MAIN, 4 }, 243 { P_GCC_GPLL4_OUT_MAIN, 5 }, 244 { P_GCC_GPLL0_OUT_EVEN, 6 }, 245 }; 246 247 static const struct clk_parent_data gcc_parent_data_2[] = { 248 { .index = DT_BI_TCXO }, 249 { .hw = &gcc_gpll0.clkr.hw }, 250 { .hw = &gcc_gpll1.clkr.hw }, 251 { .hw = &gcc_gpll4.clkr.hw }, 252 { .hw = &gcc_gpll0_out_even.clkr.hw }, 253 }; 254 255 static const struct parent_map gcc_parent_map_3[] = { 256 { P_BI_TCXO, 0 }, 257 { P_SLEEP_CLK, 5 }, 258 }; 259 260 static const struct clk_parent_data gcc_parent_data_3[] = { 261 { .index = DT_BI_TCXO }, 262 { .index = DT_SLEEP_CLK }, 263 }; 264 265 static const struct parent_map gcc_parent_map_4[] = { 266 { P_BI_TCXO, 0 }, 267 { P_GCC_GPLL0_OUT_MAIN, 1 }, 268 { P_GCC_GPLL0_OUT_ODD, 2 }, 269 { P_GCC_GPLL10_OUT_MAIN, 3 }, 270 { P_GCC_GPLL0_OUT_EVEN, 6 }, 271 }; 272 273 static const struct clk_parent_data gcc_parent_data_4[] = { 274 { .index = DT_BI_TCXO }, 275 { .hw = &gcc_gpll0.clkr.hw }, 276 { .hw = &gcc_gpll0_out_odd.clkr.hw }, 277 { .hw = &gcc_gpll10.clkr.hw }, 278 { .hw = &gcc_gpll0_out_even.clkr.hw }, 279 }; 280 281 static const struct parent_map gcc_parent_map_5[] = { 282 { P_BI_TCXO, 0 }, 283 }; 284 285 static const struct clk_parent_data gcc_parent_data_5[] = { 286 { .index = DT_BI_TCXO }, 287 }; 288 289 static const struct parent_map gcc_parent_map_6[] = { 290 { P_BI_TCXO, 0 }, 291 { P_GCC_GPLL0_OUT_MAIN, 1 }, 292 { P_GCC_GPLL9_OUT_MAIN, 2 }, 293 { P_GCC_GPLL4_OUT_MAIN, 5 }, 294 { P_GCC_GPLL0_OUT_EVEN, 6 }, 295 }; 296 297 static const struct clk_parent_data gcc_parent_data_6[] = { 298 { .index = DT_BI_TCXO }, 299 { .hw = &gcc_gpll0.clkr.hw }, 300 { .hw = &gcc_gpll9.clkr.hw }, 301 { .hw = &gcc_gpll4.clkr.hw }, 302 { .hw = &gcc_gpll0_out_even.clkr.hw }, 303 }; 304 305 static const struct parent_map gcc_parent_map_7[] = { 306 { P_UFS_PHY_RX_SYMBOL_0_CLK, 0 }, 307 { P_BI_TCXO, 2 }, 308 }; 309 310 static const struct clk_parent_data gcc_parent_data_7[] = { 311 { .index = DT_UFS_PHY_RX_SYMBOL_0_CLK }, 312 { .index = DT_BI_TCXO }, 313 }; 314 315 static const struct parent_map gcc_parent_map_8[] = { 316 { P_UFS_PHY_RX_SYMBOL_1_CLK, 0 }, 317 { P_BI_TCXO, 2 }, 318 }; 319 320 static const struct clk_parent_data gcc_parent_data_8[] = { 321 { .index = DT_UFS_PHY_RX_SYMBOL_1_CLK }, 322 { .index = DT_BI_TCXO }, 323 }; 324 325 static const struct parent_map gcc_parent_map_9[] = { 326 { P_UFS_PHY_TX_SYMBOL_0_CLK, 0 }, 327 { P_BI_TCXO, 2 }, 328 }; 329 330 static const struct clk_parent_data gcc_parent_data_9[] = { 331 { .index = DT_UFS_PHY_TX_SYMBOL_0_CLK }, 332 { .index = DT_BI_TCXO }, 333 }; 334 335 static const struct parent_map gcc_parent_map_10[] = { 336 { P_USB3_PHY_WRAPPER_GCC_USB30_PIPE_CLK, 0 }, 337 { P_BI_TCXO, 2 }, 338 }; 339 340 static const struct clk_parent_data gcc_parent_data_10[] = { 341 { .index = DT_USB3_PHY_WRAPPER_GCC_USB30_PIPE_CLK }, 342 { .index = DT_BI_TCXO }, 343 }; 344 345 static const struct parent_map gcc_parent_map_11[] = { 346 { P_BI_TCXO, 0 }, 347 { P_GCC_GPLL0_OUT_MAIN, 1 }, 348 { P_GCC_GPLL3_OUT_MAIN, 5 }, 349 }; 350 351 static const struct clk_parent_data gcc_parent_data_11[] = { 352 { .index = DT_BI_TCXO }, 353 { .hw = &gcc_gpll0.clkr.hw }, 354 { .hw = &gcc_gpll3.clkr.hw }, 355 }; 356 357 static struct clk_regmap_phy_mux gcc_pcie_0_pipe_clk_src = { 358 .reg = 0x7b060, 359 .clkr = { 360 .hw.init = &(const struct clk_init_data) { 361 .name = "gcc_pcie_0_pipe_clk_src", 362 .parent_data = &(const struct clk_parent_data) { 363 .index = DT_PCIE_0_PIPE_CLK, 364 }, 365 .num_parents = 1, 366 .ops = &clk_regmap_phy_mux_ops, 367 }, 368 }, 369 }; 370 371 static struct clk_regmap_mux gcc_ufs_phy_rx_symbol_0_clk_src = { 372 .reg = 0x87060, 373 .shift = 0, 374 .width = 2, 375 .parent_map = gcc_parent_map_7, 376 .clkr = { 377 .hw.init = &(const struct clk_init_data) { 378 .name = "gcc_ufs_phy_rx_symbol_0_clk_src", 379 .parent_data = gcc_parent_data_7, 380 .num_parents = ARRAY_SIZE(gcc_parent_data_7), 381 .ops = &clk_regmap_mux_closest_ops, 382 }, 383 }, 384 }; 385 386 static struct clk_regmap_mux gcc_ufs_phy_rx_symbol_1_clk_src = { 387 .reg = 0x870d0, 388 .shift = 0, 389 .width = 2, 390 .parent_map = gcc_parent_map_8, 391 .clkr = { 392 .hw.init = &(const struct clk_init_data) { 393 .name = "gcc_ufs_phy_rx_symbol_1_clk_src", 394 .parent_data = gcc_parent_data_8, 395 .num_parents = ARRAY_SIZE(gcc_parent_data_8), 396 .ops = &clk_regmap_mux_closest_ops, 397 }, 398 }, 399 }; 400 401 static struct clk_regmap_mux gcc_ufs_phy_tx_symbol_0_clk_src = { 402 .reg = 0x87050, 403 .shift = 0, 404 .width = 2, 405 .parent_map = gcc_parent_map_9, 406 .clkr = { 407 .hw.init = &(const struct clk_init_data) { 408 .name = "gcc_ufs_phy_tx_symbol_0_clk_src", 409 .parent_data = gcc_parent_data_9, 410 .num_parents = ARRAY_SIZE(gcc_parent_data_9), 411 .ops = &clk_regmap_mux_closest_ops, 412 }, 413 }, 414 }; 415 416 static struct clk_regmap_mux gcc_usb3_prim_phy_pipe_clk_src = { 417 .reg = 0x49068, 418 .shift = 0, 419 .width = 2, 420 .parent_map = gcc_parent_map_10, 421 .clkr = { 422 .hw.init = &(const struct clk_init_data) { 423 .name = "gcc_usb3_prim_phy_pipe_clk_src", 424 .parent_data = gcc_parent_data_10, 425 .num_parents = ARRAY_SIZE(gcc_parent_data_10), 426 .ops = &clk_regmap_mux_closest_ops, 427 }, 428 }, 429 }; 430 431 static const struct freq_tbl ftbl_gcc_gp1_clk_src[] = { 432 F(50000000, P_GCC_GPLL0_OUT_EVEN, 6, 0, 0), 433 F(100000000, P_GCC_GPLL0_OUT_MAIN, 6, 0, 0), 434 F(200000000, P_GCC_GPLL0_OUT_MAIN, 3, 0, 0), 435 { } 436 }; 437 438 static struct clk_rcg2 gcc_gp1_clk_src = { 439 .cmd_rcgr = 0x74004, 440 .mnd_width = 16, 441 .hid_width = 5, 442 .parent_map = gcc_parent_map_1, 443 .freq_tbl = ftbl_gcc_gp1_clk_src, 444 .clkr.hw.init = &(const struct clk_init_data) { 445 .name = "gcc_gp1_clk_src", 446 .parent_data = gcc_parent_data_1, 447 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 448 .flags = CLK_SET_RATE_PARENT, 449 .ops = &clk_rcg2_shared_ops, 450 }, 451 }; 452 453 static struct clk_rcg2 gcc_gp2_clk_src = { 454 .cmd_rcgr = 0x75004, 455 .mnd_width = 16, 456 .hid_width = 5, 457 .parent_map = gcc_parent_map_1, 458 .freq_tbl = ftbl_gcc_gp1_clk_src, 459 .clkr.hw.init = &(const struct clk_init_data) { 460 .name = "gcc_gp2_clk_src", 461 .parent_data = gcc_parent_data_1, 462 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 463 .flags = CLK_SET_RATE_PARENT, 464 .ops = &clk_rcg2_shared_ops, 465 }, 466 }; 467 468 static struct clk_rcg2 gcc_gp3_clk_src = { 469 .cmd_rcgr = 0x76004, 470 .mnd_width = 16, 471 .hid_width = 5, 472 .parent_map = gcc_parent_map_1, 473 .freq_tbl = ftbl_gcc_gp1_clk_src, 474 .clkr.hw.init = &(const struct clk_init_data) { 475 .name = "gcc_gp3_clk_src", 476 .parent_data = gcc_parent_data_1, 477 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 478 .flags = CLK_SET_RATE_PARENT, 479 .ops = &clk_rcg2_shared_ops, 480 }, 481 }; 482 483 static const struct freq_tbl ftbl_gcc_pcie_0_aux_clk_src[] = { 484 F(9600000, P_BI_TCXO, 2, 0, 0), 485 F(19200000, P_BI_TCXO, 1, 0, 0), 486 { } 487 }; 488 489 static struct clk_rcg2 gcc_pcie_0_aux_clk_src = { 490 .cmd_rcgr = 0x7b064, 491 .mnd_width = 16, 492 .hid_width = 5, 493 .parent_map = gcc_parent_map_3, 494 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src, 495 .clkr.hw.init = &(const struct clk_init_data) { 496 .name = "gcc_pcie_0_aux_clk_src", 497 .parent_data = gcc_parent_data_3, 498 .num_parents = ARRAY_SIZE(gcc_parent_data_3), 499 .flags = CLK_SET_RATE_PARENT, 500 .ops = &clk_rcg2_shared_ops, 501 }, 502 }; 503 504 static const struct freq_tbl ftbl_gcc_pcie_0_phy_rchng_clk_src[] = { 505 F(19200000, P_BI_TCXO, 1, 0, 0), 506 F(100000000, P_GCC_GPLL0_OUT_MAIN, 6, 0, 0), 507 { } 508 }; 509 510 static struct clk_rcg2 gcc_pcie_0_phy_rchng_clk_src = { 511 .cmd_rcgr = 0x7b048, 512 .mnd_width = 0, 513 .hid_width = 5, 514 .parent_map = gcc_parent_map_0, 515 .freq_tbl = ftbl_gcc_pcie_0_phy_rchng_clk_src, 516 .clkr.hw.init = &(const struct clk_init_data) { 517 .name = "gcc_pcie_0_phy_rchng_clk_src", 518 .parent_data = gcc_parent_data_0, 519 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 520 .flags = CLK_SET_RATE_PARENT, 521 .ops = &clk_rcg2_shared_ops, 522 }, 523 }; 524 525 static const struct freq_tbl ftbl_gcc_pdm2_clk_src[] = { 526 F(60000000, P_GCC_GPLL0_OUT_MAIN, 10, 0, 0), 527 { } 528 }; 529 530 static struct clk_rcg2 gcc_pdm2_clk_src = { 531 .cmd_rcgr = 0x43010, 532 .mnd_width = 0, 533 .hid_width = 5, 534 .parent_map = gcc_parent_map_0, 535 .freq_tbl = ftbl_gcc_pdm2_clk_src, 536 .clkr.hw.init = &(const struct clk_init_data) { 537 .name = "gcc_pdm2_clk_src", 538 .parent_data = gcc_parent_data_0, 539 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 540 .flags = CLK_SET_RATE_PARENT, 541 .ops = &clk_rcg2_shared_ops, 542 }, 543 }; 544 545 static const struct freq_tbl ftbl_gcc_qupv3_wrap0_s0_clk_src[] = { 546 F(7372800, P_GCC_GPLL0_OUT_EVEN, 1, 384, 15625), 547 F(14745600, P_GCC_GPLL0_OUT_EVEN, 1, 768, 15625), 548 F(19200000, P_BI_TCXO, 1, 0, 0), 549 F(29491200, P_GCC_GPLL0_OUT_EVEN, 1, 1536, 15625), 550 F(32000000, P_GCC_GPLL0_OUT_EVEN, 1, 8, 75), 551 F(48000000, P_GCC_GPLL0_OUT_EVEN, 1, 4, 25), 552 F(64000000, P_GCC_GPLL0_OUT_EVEN, 1, 16, 75), 553 F(75000000, P_GCC_GPLL0_OUT_EVEN, 4, 0, 0), 554 F(80000000, P_GCC_GPLL0_OUT_EVEN, 1, 4, 15), 555 F(96000000, P_GCC_GPLL0_OUT_EVEN, 1, 8, 25), 556 F(100000000, P_GCC_GPLL0_OUT_MAIN, 6, 0, 0), 557 F(102400000, P_GCC_GPLL0_OUT_EVEN, 1, 128, 375), 558 F(112000000, P_GCC_GPLL0_OUT_EVEN, 1, 28, 75), 559 F(117964800, P_GCC_GPLL0_OUT_EVEN, 1, 6144, 15625), 560 F(120000000, P_GCC_GPLL0_OUT_EVEN, 2.5, 0, 0), 561 { } 562 }; 563 564 static struct clk_init_data gcc_qupv3_wrap0_s0_clk_src_init = { 565 .name = "gcc_qupv3_wrap0_s0_clk_src", 566 .parent_data = gcc_parent_data_0, 567 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 568 .flags = CLK_SET_RATE_PARENT, 569 .ops = &clk_rcg2_shared_ops, 570 }; 571 572 static struct clk_rcg2 gcc_qupv3_wrap0_s0_clk_src = { 573 .cmd_rcgr = 0x27014, 574 .mnd_width = 16, 575 .hid_width = 5, 576 .parent_map = gcc_parent_map_0, 577 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 578 .clkr.hw.init = &gcc_qupv3_wrap0_s0_clk_src_init, 579 }; 580 581 static const struct freq_tbl ftbl_gcc_qupv3_wrap0_s1_clk_src[] = { 582 F(7372800, P_GCC_GPLL0_OUT_EVEN, 1, 384, 15625), 583 F(14745600, P_GCC_GPLL0_OUT_EVEN, 1, 768, 15625), 584 F(19200000, P_BI_TCXO, 1, 0, 0), 585 F(29491200, P_GCC_GPLL0_OUT_EVEN, 1, 1536, 15625), 586 F(32000000, P_GCC_GPLL0_OUT_EVEN, 1, 8, 75), 587 F(48000000, P_GCC_GPLL0_OUT_EVEN, 1, 4, 25), 588 F(64000000, P_GCC_GPLL0_OUT_EVEN, 1, 16, 75), 589 F(75000000, P_GCC_GPLL0_OUT_EVEN, 4, 0, 0), 590 F(80000000, P_GCC_GPLL0_OUT_EVEN, 1, 4, 15), 591 F(96000000, P_GCC_GPLL0_OUT_EVEN, 1, 8, 25), 592 F(100000000, P_GCC_GPLL0_OUT_MAIN, 6, 0, 0), 593 { } 594 }; 595 596 static struct clk_init_data gcc_qupv3_wrap0_s1_clk_src_init = { 597 .name = "gcc_qupv3_wrap0_s1_clk_src", 598 .parent_data = gcc_parent_data_0, 599 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 600 .flags = CLK_SET_RATE_PARENT, 601 .ops = &clk_rcg2_shared_ops, 602 }; 603 604 static struct clk_rcg2 gcc_qupv3_wrap0_s1_clk_src = { 605 .cmd_rcgr = 0x27148, 606 .mnd_width = 16, 607 .hid_width = 5, 608 .parent_map = gcc_parent_map_0, 609 .freq_tbl = ftbl_gcc_qupv3_wrap0_s1_clk_src, 610 .clkr.hw.init = &gcc_qupv3_wrap0_s1_clk_src_init, 611 }; 612 613 static struct clk_init_data gcc_qupv3_wrap0_s2_clk_src_init = { 614 .name = "gcc_qupv3_wrap0_s2_clk_src", 615 .parent_data = gcc_parent_data_0, 616 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 617 .flags = CLK_SET_RATE_PARENT, 618 .ops = &clk_rcg2_shared_ops, 619 }; 620 621 static struct clk_rcg2 gcc_qupv3_wrap0_s2_clk_src = { 622 .cmd_rcgr = 0x2727c, 623 .mnd_width = 16, 624 .hid_width = 5, 625 .parent_map = gcc_parent_map_0, 626 .freq_tbl = ftbl_gcc_qupv3_wrap0_s1_clk_src, 627 .clkr.hw.init = &gcc_qupv3_wrap0_s2_clk_src_init, 628 }; 629 630 static struct clk_init_data gcc_qupv3_wrap0_s3_clk_src_init = { 631 .name = "gcc_qupv3_wrap0_s3_clk_src", 632 .parent_data = gcc_parent_data_0, 633 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 634 .flags = CLK_SET_RATE_PARENT, 635 .ops = &clk_rcg2_shared_ops, 636 }; 637 638 static struct clk_rcg2 gcc_qupv3_wrap0_s3_clk_src = { 639 .cmd_rcgr = 0x273b0, 640 .mnd_width = 16, 641 .hid_width = 5, 642 .parent_map = gcc_parent_map_0, 643 .freq_tbl = ftbl_gcc_qupv3_wrap0_s1_clk_src, 644 .clkr.hw.init = &gcc_qupv3_wrap0_s3_clk_src_init, 645 }; 646 647 static struct clk_init_data gcc_qupv3_wrap0_s4_clk_src_init = { 648 .name = "gcc_qupv3_wrap0_s4_clk_src", 649 .parent_data = gcc_parent_data_0, 650 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 651 .flags = CLK_SET_RATE_PARENT, 652 .ops = &clk_rcg2_shared_ops, 653 }; 654 655 static struct clk_rcg2 gcc_qupv3_wrap0_s4_clk_src = { 656 .cmd_rcgr = 0x274e4, 657 .mnd_width = 16, 658 .hid_width = 5, 659 .parent_map = gcc_parent_map_0, 660 .freq_tbl = ftbl_gcc_qupv3_wrap0_s1_clk_src, 661 .clkr.hw.init = &gcc_qupv3_wrap0_s4_clk_src_init, 662 }; 663 664 static struct clk_init_data gcc_qupv3_wrap1_s0_clk_src_init = { 665 .name = "gcc_qupv3_wrap1_s0_clk_src", 666 .parent_data = gcc_parent_data_0, 667 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 668 .flags = CLK_SET_RATE_PARENT, 669 .ops = &clk_rcg2_shared_ops, 670 }; 671 672 static struct clk_rcg2 gcc_qupv3_wrap1_s0_clk_src = { 673 .cmd_rcgr = 0x28014, 674 .mnd_width = 16, 675 .hid_width = 5, 676 .parent_map = gcc_parent_map_0, 677 .freq_tbl = ftbl_gcc_qupv3_wrap0_s0_clk_src, 678 .clkr.hw.init = &gcc_qupv3_wrap1_s0_clk_src_init, 679 }; 680 681 static struct clk_init_data gcc_qupv3_wrap1_s1_clk_src_init = { 682 .name = "gcc_qupv3_wrap1_s1_clk_src", 683 .parent_data = gcc_parent_data_0, 684 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 685 .flags = CLK_SET_RATE_PARENT, 686 .ops = &clk_rcg2_shared_ops, 687 }; 688 689 static struct clk_rcg2 gcc_qupv3_wrap1_s1_clk_src = { 690 .cmd_rcgr = 0x28148, 691 .mnd_width = 16, 692 .hid_width = 5, 693 .parent_map = gcc_parent_map_0, 694 .freq_tbl = ftbl_gcc_qupv3_wrap0_s1_clk_src, 695 .clkr.hw.init = &gcc_qupv3_wrap1_s1_clk_src_init, 696 }; 697 698 static struct clk_init_data gcc_qupv3_wrap1_s2_clk_src_init = { 699 .name = "gcc_qupv3_wrap1_s2_clk_src", 700 .parent_data = gcc_parent_data_0, 701 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 702 .flags = CLK_SET_RATE_PARENT, 703 .ops = &clk_rcg2_shared_ops, 704 }; 705 706 static struct clk_rcg2 gcc_qupv3_wrap1_s2_clk_src = { 707 .cmd_rcgr = 0x2827c, 708 .mnd_width = 16, 709 .hid_width = 5, 710 .parent_map = gcc_parent_map_0, 711 .freq_tbl = ftbl_gcc_qupv3_wrap0_s1_clk_src, 712 .clkr.hw.init = &gcc_qupv3_wrap1_s2_clk_src_init, 713 }; 714 715 static struct clk_init_data gcc_qupv3_wrap1_s3_clk_src_init = { 716 .name = "gcc_qupv3_wrap1_s3_clk_src", 717 .parent_data = gcc_parent_data_0, 718 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 719 .flags = CLK_SET_RATE_PARENT, 720 .ops = &clk_rcg2_shared_ops, 721 }; 722 723 static struct clk_rcg2 gcc_qupv3_wrap1_s3_clk_src = { 724 .cmd_rcgr = 0x283b0, 725 .mnd_width = 16, 726 .hid_width = 5, 727 .parent_map = gcc_parent_map_0, 728 .freq_tbl = ftbl_gcc_qupv3_wrap0_s1_clk_src, 729 .clkr.hw.init = &gcc_qupv3_wrap1_s3_clk_src_init, 730 }; 731 732 static struct clk_init_data gcc_qupv3_wrap1_s4_clk_src_init = { 733 .name = "gcc_qupv3_wrap1_s4_clk_src", 734 .parent_data = gcc_parent_data_0, 735 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 736 .flags = CLK_SET_RATE_PARENT, 737 .ops = &clk_rcg2_shared_ops, 738 }; 739 740 static struct clk_rcg2 gcc_qupv3_wrap1_s4_clk_src = { 741 .cmd_rcgr = 0x284e4, 742 .mnd_width = 16, 743 .hid_width = 5, 744 .parent_map = gcc_parent_map_0, 745 .freq_tbl = ftbl_gcc_qupv3_wrap0_s1_clk_src, 746 .clkr.hw.init = &gcc_qupv3_wrap1_s4_clk_src_init, 747 }; 748 749 static const struct freq_tbl ftbl_gcc_sdcc1_apps_clk_src[] = { 750 F(144000, P_BI_TCXO, 16, 3, 25), 751 F(400000, P_BI_TCXO, 12, 1, 4), 752 F(20000000, P_GCC_GPLL0_OUT_EVEN, 5, 1, 3), 753 F(25000000, P_GCC_GPLL0_OUT_EVEN, 12, 0, 0), 754 F(50000000, P_GCC_GPLL0_OUT_EVEN, 6, 0, 0), 755 F(100000000, P_GCC_GPLL0_OUT_ODD, 2, 0, 0), 756 F(192000000, P_GCC_GPLL10_OUT_MAIN, 2, 0, 0), 757 F(384000000, P_GCC_GPLL10_OUT_MAIN, 1, 0, 0), 758 { } 759 }; 760 761 static struct clk_rcg2 gcc_sdcc1_apps_clk_src = { 762 .cmd_rcgr = 0xb3010, 763 .mnd_width = 8, 764 .hid_width = 5, 765 .parent_map = gcc_parent_map_4, 766 .freq_tbl = ftbl_gcc_sdcc1_apps_clk_src, 767 .clkr.hw.init = &(const struct clk_init_data) { 768 .name = "gcc_sdcc1_apps_clk_src", 769 .parent_data = gcc_parent_data_4, 770 .num_parents = ARRAY_SIZE(gcc_parent_data_4), 771 .flags = CLK_SET_RATE_PARENT, 772 .ops = &clk_rcg2_floor_ops, 773 }, 774 }; 775 776 static const struct freq_tbl ftbl_gcc_sdcc1_ice_core_clk_src[] = { 777 F(100000000, P_GCC_GPLL0_OUT_ODD, 2, 0, 0), 778 F(150000000, P_GCC_GPLL0_OUT_EVEN, 2, 0, 0), 779 F(300000000, P_GCC_GPLL0_OUT_EVEN, 1, 0, 0), 780 { } 781 }; 782 783 static struct clk_rcg2 gcc_sdcc1_ice_core_clk_src = { 784 .cmd_rcgr = 0xb3030, 785 .mnd_width = 0, 786 .hid_width = 5, 787 .parent_map = gcc_parent_map_4, 788 .freq_tbl = ftbl_gcc_sdcc1_ice_core_clk_src, 789 .clkr.hw.init = &(const struct clk_init_data) { 790 .name = "gcc_sdcc1_ice_core_clk_src", 791 .parent_data = gcc_parent_data_4, 792 .num_parents = ARRAY_SIZE(gcc_parent_data_4), 793 .flags = CLK_SET_RATE_PARENT, 794 .ops = &clk_rcg2_floor_ops, 795 }, 796 }; 797 798 static const struct freq_tbl ftbl_gcc_sdcc2_apps_clk_src[] = { 799 F(400000, P_BI_TCXO, 12, 1, 4), 800 F(25000000, P_GCC_GPLL0_OUT_EVEN, 12, 0, 0), 801 F(50000000, P_GCC_GPLL0_OUT_EVEN, 6, 0, 0), 802 F(100000000, P_GCC_GPLL0_OUT_EVEN, 3, 0, 0), 803 F(202000000, P_GCC_GPLL9_OUT_MAIN, 4, 0, 0), 804 { } 805 }; 806 807 static struct clk_rcg2 gcc_sdcc2_apps_clk_src = { 808 .cmd_rcgr = 0x24014, 809 .mnd_width = 8, 810 .hid_width = 5, 811 .parent_map = gcc_parent_map_6, 812 .freq_tbl = ftbl_gcc_sdcc2_apps_clk_src, 813 .clkr.hw.init = &(const struct clk_init_data) { 814 .name = "gcc_sdcc2_apps_clk_src", 815 .parent_data = gcc_parent_data_6, 816 .num_parents = ARRAY_SIZE(gcc_parent_data_6), 817 .flags = CLK_SET_RATE_PARENT, 818 .ops = &clk_rcg2_floor_ops, 819 }, 820 }; 821 822 static const struct freq_tbl ftbl_gcc_ufs_phy_axi_clk_src[] = { 823 F(25000000, P_GCC_GPLL0_OUT_EVEN, 12, 0, 0), 824 F(75000000, P_GCC_GPLL0_OUT_EVEN, 4, 0, 0), 825 F(150000000, P_GCC_GPLL0_OUT_MAIN, 4, 0, 0), 826 F(300000000, P_GCC_GPLL0_OUT_MAIN, 2, 0, 0), 827 { } 828 }; 829 830 static struct clk_rcg2 gcc_ufs_phy_axi_clk_src = { 831 .cmd_rcgr = 0x8702c, 832 .mnd_width = 8, 833 .hid_width = 5, 834 .parent_map = gcc_parent_map_0, 835 .freq_tbl = ftbl_gcc_ufs_phy_axi_clk_src, 836 .clkr.hw.init = &(const struct clk_init_data) { 837 .name = "gcc_ufs_phy_axi_clk_src", 838 .parent_data = gcc_parent_data_0, 839 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 840 .flags = CLK_SET_RATE_PARENT, 841 .ops = &clk_rcg2_shared_ops, 842 }, 843 }; 844 845 static const struct freq_tbl ftbl_gcc_ufs_phy_ice_core_clk_src[] = { 846 F(100000000, P_GCC_GPLL0_OUT_MAIN, 6, 0, 0), 847 F(200000000, P_GCC_GPLL0_OUT_MAIN, 3, 0, 0), 848 F(403000000, P_GCC_GPLL4_OUT_MAIN, 2, 0, 0), 849 { } 850 }; 851 852 static struct clk_rcg2 gcc_ufs_phy_ice_core_clk_src = { 853 .cmd_rcgr = 0x87074, 854 .mnd_width = 0, 855 .hid_width = 5, 856 .parent_map = gcc_parent_map_2, 857 .freq_tbl = ftbl_gcc_ufs_phy_ice_core_clk_src, 858 .clkr.hw.init = &(const struct clk_init_data) { 859 .name = "gcc_ufs_phy_ice_core_clk_src", 860 .parent_data = gcc_parent_data_2, 861 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 862 .flags = CLK_SET_RATE_PARENT, 863 .ops = &clk_rcg2_shared_ops, 864 }, 865 }; 866 867 static struct clk_rcg2 gcc_ufs_phy_phy_aux_clk_src = { 868 .cmd_rcgr = 0x870a8, 869 .mnd_width = 0, 870 .hid_width = 5, 871 .parent_map = gcc_parent_map_5, 872 .freq_tbl = ftbl_gcc_pcie_0_aux_clk_src, 873 .clkr.hw.init = &(const struct clk_init_data) { 874 .name = "gcc_ufs_phy_phy_aux_clk_src", 875 .parent_data = gcc_parent_data_5, 876 .num_parents = ARRAY_SIZE(gcc_parent_data_5), 877 .flags = CLK_SET_RATE_PARENT, 878 .ops = &clk_rcg2_shared_ops, 879 }, 880 }; 881 882 static const struct freq_tbl ftbl_gcc_ufs_phy_unipro_core_clk_src[] = { 883 F(75000000, P_GCC_GPLL0_OUT_EVEN, 4, 0, 0), 884 F(150000000, P_GCC_GPLL0_OUT_MAIN, 4, 0, 0), 885 F(300000000, P_GCC_GPLL0_OUT_MAIN, 2, 0, 0), 886 { } 887 }; 888 889 static struct clk_rcg2 gcc_ufs_phy_unipro_core_clk_src = { 890 .cmd_rcgr = 0x8708c, 891 .mnd_width = 0, 892 .hid_width = 5, 893 .parent_map = gcc_parent_map_0, 894 .freq_tbl = ftbl_gcc_ufs_phy_unipro_core_clk_src, 895 .clkr.hw.init = &(const struct clk_init_data) { 896 .name = "gcc_ufs_phy_unipro_core_clk_src", 897 .parent_data = gcc_parent_data_0, 898 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 899 .flags = CLK_SET_RATE_PARENT, 900 .ops = &clk_rcg2_shared_ops, 901 }, 902 }; 903 904 static const struct freq_tbl ftbl_gcc_usb30_prim_master_clk_src[] = { 905 F(66666667, P_GCC_GPLL0_OUT_EVEN, 4.5, 0, 0), 906 F(133333333, P_GCC_GPLL0_OUT_MAIN, 4.5, 0, 0), 907 F(200000000, P_GCC_GPLL0_OUT_MAIN, 3, 0, 0), 908 F(240000000, P_GCC_GPLL0_OUT_MAIN, 2.5, 0, 0), 909 { } 910 }; 911 912 static struct clk_rcg2 gcc_usb30_prim_master_clk_src = { 913 .cmd_rcgr = 0x49028, 914 .mnd_width = 8, 915 .hid_width = 5, 916 .parent_map = gcc_parent_map_0, 917 .freq_tbl = ftbl_gcc_usb30_prim_master_clk_src, 918 .clkr.hw.init = &(const struct clk_init_data) { 919 .name = "gcc_usb30_prim_master_clk_src", 920 .parent_data = gcc_parent_data_0, 921 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 922 .flags = CLK_SET_RATE_PARENT, 923 .ops = &clk_rcg2_shared_ops, 924 }, 925 }; 926 927 static const struct freq_tbl ftbl_gcc_usb30_prim_mock_utmi_clk_src[] = { 928 F(19200000, P_BI_TCXO, 1, 0, 0), 929 { } 930 }; 931 932 static struct clk_rcg2 gcc_usb30_prim_mock_utmi_clk_src = { 933 .cmd_rcgr = 0x49040, 934 .mnd_width = 0, 935 .hid_width = 5, 936 .parent_map = gcc_parent_map_0, 937 .freq_tbl = ftbl_gcc_usb30_prim_mock_utmi_clk_src, 938 .clkr.hw.init = &(const struct clk_init_data) { 939 .name = "gcc_usb30_prim_mock_utmi_clk_src", 940 .parent_data = gcc_parent_data_0, 941 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 942 .flags = CLK_SET_RATE_PARENT, 943 .ops = &clk_rcg2_shared_ops, 944 }, 945 }; 946 947 static struct clk_rcg2 gcc_usb3_prim_phy_aux_clk_src = { 948 .cmd_rcgr = 0x4906c, 949 .mnd_width = 0, 950 .hid_width = 5, 951 .parent_map = gcc_parent_map_3, 952 .freq_tbl = ftbl_gcc_usb30_prim_mock_utmi_clk_src, 953 .clkr.hw.init = &(const struct clk_init_data) { 954 .name = "gcc_usb3_prim_phy_aux_clk_src", 955 .parent_data = gcc_parent_data_3, 956 .num_parents = ARRAY_SIZE(gcc_parent_data_3), 957 .flags = CLK_SET_RATE_PARENT, 958 .ops = &clk_rcg2_shared_ops, 959 }, 960 }; 961 962 static const struct freq_tbl ftbl_gcc_video_venus_clk_src[] = { 963 F(133333333, P_GCC_GPLL3_OUT_MAIN, 3, 0, 0), 964 F(240000000, P_GCC_GPLL3_OUT_MAIN, 2, 0, 0), 965 F(365000000, P_GCC_GPLL3_OUT_MAIN, 2, 0, 0), 966 F(384000000, P_GCC_GPLL3_OUT_MAIN, 2, 0, 0), 967 { } 968 }; 969 970 static struct clk_rcg2 gcc_video_venus_clk_src = { 971 .cmd_rcgr = 0xb6004, 972 .mnd_width = 0, 973 .hid_width = 5, 974 .parent_map = gcc_parent_map_11, 975 .freq_tbl = ftbl_gcc_video_venus_clk_src, 976 .clkr.hw.init = &(const struct clk_init_data) { 977 .name = "gcc_video_venus_clk_src", 978 .parent_data = gcc_parent_data_11, 979 .num_parents = ARRAY_SIZE(gcc_parent_data_11), 980 .flags = CLK_SET_RATE_PARENT, 981 .ops = &clk_rcg2_shared_ops, 982 }, 983 }; 984 985 static struct clk_regmap_div gcc_pcie_0_pipe_div2_clk_src = { 986 .reg = 0x7b084, 987 .shift = 0, 988 .width = 4, 989 .clkr.hw.init = &(const struct clk_init_data) { 990 .name = "gcc_pcie_0_pipe_div2_clk_src", 991 .parent_hws = (const struct clk_hw*[]) { 992 &gcc_pcie_0_pipe_clk_src.clkr.hw, 993 }, 994 .num_parents = 1, 995 .flags = CLK_SET_RATE_PARENT, 996 .ops = &clk_regmap_div_ro_ops, 997 }, 998 }; 999 1000 static struct clk_regmap_div gcc_usb30_prim_mock_utmi_postdiv_clk_src = { 1001 .reg = 0x49058, 1002 .shift = 0, 1003 .width = 4, 1004 .clkr.hw.init = &(const struct clk_init_data) { 1005 .name = "gcc_usb30_prim_mock_utmi_postdiv_clk_src", 1006 .parent_hws = (const struct clk_hw*[]) { 1007 &gcc_usb30_prim_mock_utmi_clk_src.clkr.hw, 1008 }, 1009 .num_parents = 1, 1010 .flags = CLK_SET_RATE_PARENT, 1011 .ops = &clk_regmap_div_ro_ops, 1012 }, 1013 }; 1014 1015 static struct clk_branch gcc_aggre_noc_pcie_0_axi_clk = { 1016 .halt_reg = 0x7b08c, 1017 .halt_check = BRANCH_HALT_SKIP, 1018 .hwcg_reg = 0x7b08c, 1019 .hwcg_bit = 1, 1020 .clkr = { 1021 .enable_reg = 0x62000, 1022 .enable_mask = BIT(12), 1023 .hw.init = &(const struct clk_init_data) { 1024 .name = "gcc_aggre_noc_pcie_0_axi_clk", 1025 .ops = &clk_branch2_ops, 1026 }, 1027 }, 1028 }; 1029 1030 static struct clk_branch gcc_aggre_ufs_phy_axi_clk = { 1031 .halt_reg = 0x870d4, 1032 .halt_check = BRANCH_HALT_VOTED, 1033 .hwcg_reg = 0x870d4, 1034 .hwcg_bit = 1, 1035 .clkr = { 1036 .enable_reg = 0x870d4, 1037 .enable_mask = BIT(0), 1038 .hw.init = &(const struct clk_init_data) { 1039 .name = "gcc_aggre_ufs_phy_axi_clk", 1040 .parent_hws = (const struct clk_hw*[]) { 1041 &gcc_ufs_phy_axi_clk_src.clkr.hw, 1042 }, 1043 .num_parents = 1, 1044 .flags = CLK_SET_RATE_PARENT, 1045 .ops = &clk_branch2_ops, 1046 }, 1047 }, 1048 }; 1049 1050 static struct clk_branch gcc_aggre_ufs_phy_axi_hw_ctl_clk = { 1051 .halt_reg = 0x870d4, 1052 .halt_check = BRANCH_HALT_VOTED, 1053 .hwcg_reg = 0x870d4, 1054 .hwcg_bit = 1, 1055 .clkr = { 1056 .enable_reg = 0x870d4, 1057 .enable_mask = BIT(1), 1058 .hw.init = &(const struct clk_init_data) { 1059 .name = "gcc_aggre_ufs_phy_axi_hw_ctl_clk", 1060 .parent_hws = (const struct clk_hw*[]) { 1061 &gcc_ufs_phy_axi_clk_src.clkr.hw, 1062 }, 1063 .num_parents = 1, 1064 .flags = CLK_SET_RATE_PARENT, 1065 .ops = &clk_branch2_ops, 1066 }, 1067 }, 1068 }; 1069 1070 static struct clk_branch gcc_aggre_usb3_prim_axi_clk = { 1071 .halt_reg = 0x49088, 1072 .halt_check = BRANCH_HALT_VOTED, 1073 .hwcg_reg = 0x49088, 1074 .hwcg_bit = 1, 1075 .clkr = { 1076 .enable_reg = 0x49088, 1077 .enable_mask = BIT(0), 1078 .hw.init = &(const struct clk_init_data) { 1079 .name = "gcc_aggre_usb3_prim_axi_clk", 1080 .parent_hws = (const struct clk_hw*[]) { 1081 &gcc_usb30_prim_master_clk_src.clkr.hw, 1082 }, 1083 .num_parents = 1, 1084 .flags = CLK_SET_RATE_PARENT, 1085 .ops = &clk_branch2_ops, 1086 }, 1087 }, 1088 }; 1089 1090 static struct clk_branch gcc_boot_rom_ahb_clk = { 1091 .halt_reg = 0x48004, 1092 .halt_check = BRANCH_HALT_VOTED, 1093 .hwcg_reg = 0x48004, 1094 .hwcg_bit = 1, 1095 .clkr = { 1096 .enable_reg = 0x62000, 1097 .enable_mask = BIT(10), 1098 .hw.init = &(const struct clk_init_data) { 1099 .name = "gcc_boot_rom_ahb_clk", 1100 .ops = &clk_branch2_ops, 1101 }, 1102 }, 1103 }; 1104 1105 static struct clk_branch gcc_camera_hf_axi_clk = { 1106 .halt_reg = 0x36010, 1107 .halt_check = BRANCH_HALT_SKIP, 1108 .hwcg_reg = 0x36010, 1109 .hwcg_bit = 1, 1110 .clkr = { 1111 .enable_reg = 0x36010, 1112 .enable_mask = BIT(0), 1113 .hw.init = &(const struct clk_init_data) { 1114 .name = "gcc_camera_hf_axi_clk", 1115 .ops = &clk_branch2_ops, 1116 }, 1117 }, 1118 }; 1119 1120 static struct clk_branch gcc_camera_sf_axi_clk = { 1121 .halt_reg = 0x36014, 1122 .halt_check = BRANCH_HALT_SKIP, 1123 .hwcg_reg = 0x36014, 1124 .hwcg_bit = 1, 1125 .clkr = { 1126 .enable_reg = 0x36014, 1127 .enable_mask = BIT(0), 1128 .hw.init = &(const struct clk_init_data) { 1129 .name = "gcc_camera_sf_axi_clk", 1130 .ops = &clk_branch2_ops, 1131 }, 1132 }, 1133 }; 1134 1135 static struct clk_branch gcc_cfg_noc_pcie_anoc_ahb_clk = { 1136 .halt_reg = 0x20030, 1137 .halt_check = BRANCH_HALT_VOTED, 1138 .hwcg_reg = 0x20030, 1139 .hwcg_bit = 1, 1140 .clkr = { 1141 .enable_reg = 0x62000, 1142 .enable_mask = BIT(20), 1143 .hw.init = &(const struct clk_init_data) { 1144 .name = "gcc_cfg_noc_pcie_anoc_ahb_clk", 1145 .ops = &clk_branch2_ops, 1146 }, 1147 }, 1148 }; 1149 1150 static struct clk_branch gcc_cfg_noc_usb3_prim_axi_clk = { 1151 .halt_reg = 0x49084, 1152 .halt_check = BRANCH_HALT_VOTED, 1153 .hwcg_reg = 0x49084, 1154 .hwcg_bit = 1, 1155 .clkr = { 1156 .enable_reg = 0x49084, 1157 .enable_mask = BIT(0), 1158 .hw.init = &(const struct clk_init_data) { 1159 .name = "gcc_cfg_noc_usb3_prim_axi_clk", 1160 .parent_hws = (const struct clk_hw*[]) { 1161 &gcc_usb30_prim_master_clk_src.clkr.hw, 1162 }, 1163 .num_parents = 1, 1164 .flags = CLK_SET_RATE_PARENT, 1165 .ops = &clk_branch2_ops, 1166 }, 1167 }, 1168 }; 1169 1170 static struct clk_branch gcc_ddrss_gpu_axi_clk = { 1171 .halt_reg = 0x81154, 1172 .halt_check = BRANCH_HALT_SKIP, 1173 .hwcg_reg = 0x81154, 1174 .hwcg_bit = 1, 1175 .clkr = { 1176 .enable_reg = 0x81154, 1177 .enable_mask = BIT(0), 1178 .hw.init = &(const struct clk_init_data) { 1179 .name = "gcc_ddrss_gpu_axi_clk", 1180 .ops = &clk_branch2_aon_ops, 1181 }, 1182 }, 1183 }; 1184 1185 static struct clk_branch gcc_ddrss_pcie_sf_tbu_clk = { 1186 .halt_reg = 0x7b090, 1187 .halt_check = BRANCH_HALT_SKIP, 1188 .hwcg_reg = 0x7b090, 1189 .hwcg_bit = 1, 1190 .clkr = { 1191 .enable_reg = 0x62000, 1192 .enable_mask = BIT(19), 1193 .hw.init = &(const struct clk_init_data) { 1194 .name = "gcc_ddrss_pcie_sf_tbu_clk", 1195 .ops = &clk_branch2_ops, 1196 }, 1197 }, 1198 }; 1199 1200 static struct clk_branch gcc_disp_hf_axi_clk = { 1201 .halt_reg = 0x3700c, 1202 .halt_check = BRANCH_HALT_SKIP, 1203 .hwcg_reg = 0x3700c, 1204 .hwcg_bit = 1, 1205 .clkr = { 1206 .enable_reg = 0x3700c, 1207 .enable_mask = BIT(0), 1208 .hw.init = &(const struct clk_init_data) { 1209 .name = "gcc_disp_hf_axi_clk", 1210 .ops = &clk_branch2_ops, 1211 }, 1212 }, 1213 }; 1214 1215 static struct clk_branch gcc_eusb3_0_clkref_en = { 1216 .halt_reg = 0x9c00c, 1217 .halt_check = BRANCH_HALT_DELAY, 1218 .clkr = { 1219 .enable_reg = 0x9c00c, 1220 .enable_mask = BIT(0), 1221 .hw.init = &(const struct clk_init_data) { 1222 .name = "gcc_eusb3_0_clkref_en", 1223 .ops = &clk_branch2_ops, 1224 }, 1225 }, 1226 }; 1227 1228 static struct clk_branch gcc_gp1_clk = { 1229 .halt_reg = 0x74000, 1230 .halt_check = BRANCH_HALT, 1231 .clkr = { 1232 .enable_reg = 0x74000, 1233 .enable_mask = BIT(0), 1234 .hw.init = &(const struct clk_init_data) { 1235 .name = "gcc_gp1_clk", 1236 .parent_hws = (const struct clk_hw*[]) { 1237 &gcc_gp1_clk_src.clkr.hw, 1238 }, 1239 .num_parents = 1, 1240 .flags = CLK_SET_RATE_PARENT, 1241 .ops = &clk_branch2_ops, 1242 }, 1243 }, 1244 }; 1245 1246 static struct clk_branch gcc_gp2_clk = { 1247 .halt_reg = 0x75000, 1248 .halt_check = BRANCH_HALT, 1249 .clkr = { 1250 .enable_reg = 0x75000, 1251 .enable_mask = BIT(0), 1252 .hw.init = &(const struct clk_init_data) { 1253 .name = "gcc_gp2_clk", 1254 .parent_hws = (const struct clk_hw*[]) { 1255 &gcc_gp2_clk_src.clkr.hw, 1256 }, 1257 .num_parents = 1, 1258 .flags = CLK_SET_RATE_PARENT, 1259 .ops = &clk_branch2_ops, 1260 }, 1261 }, 1262 }; 1263 1264 static struct clk_branch gcc_gp3_clk = { 1265 .halt_reg = 0x76000, 1266 .halt_check = BRANCH_HALT, 1267 .clkr = { 1268 .enable_reg = 0x76000, 1269 .enable_mask = BIT(0), 1270 .hw.init = &(const struct clk_init_data) { 1271 .name = "gcc_gp3_clk", 1272 .parent_hws = (const struct clk_hw*[]) { 1273 &gcc_gp3_clk_src.clkr.hw, 1274 }, 1275 .num_parents = 1, 1276 .flags = CLK_SET_RATE_PARENT, 1277 .ops = &clk_branch2_ops, 1278 }, 1279 }, 1280 }; 1281 1282 static struct clk_branch gcc_gpu_gpll0_clk_src = { 1283 .halt_check = BRANCH_HALT_DELAY, 1284 .clkr = { 1285 .enable_reg = 0x62000, 1286 .enable_mask = BIT(15), 1287 .hw.init = &(const struct clk_init_data) { 1288 .name = "gcc_gpu_gpll0_clk_src", 1289 .parent_hws = (const struct clk_hw*[]) { 1290 &gcc_gpll0.clkr.hw, 1291 }, 1292 .num_parents = 1, 1293 .flags = CLK_SET_RATE_PARENT, 1294 .ops = &clk_branch2_ops, 1295 }, 1296 }, 1297 }; 1298 1299 static struct clk_branch gcc_gpu_gpll0_div_clk_src = { 1300 .halt_check = BRANCH_HALT_DELAY, 1301 .clkr = { 1302 .enable_reg = 0x62000, 1303 .enable_mask = BIT(16), 1304 .hw.init = &(const struct clk_init_data) { 1305 .name = "gcc_gpu_gpll0_div_clk_src", 1306 .parent_hws = (const struct clk_hw*[]) { 1307 &gcc_gpll0_out_even.clkr.hw, 1308 }, 1309 .num_parents = 1, 1310 .flags = CLK_SET_RATE_PARENT, 1311 .ops = &clk_branch2_ops, 1312 }, 1313 }, 1314 }; 1315 1316 static struct clk_branch gcc_gpu_memnoc_gfx_clk = { 1317 .halt_reg = 0x81010, 1318 .halt_check = BRANCH_HALT_VOTED, 1319 .hwcg_reg = 0x81010, 1320 .hwcg_bit = 1, 1321 .clkr = { 1322 .enable_reg = 0x81010, 1323 .enable_mask = BIT(0), 1324 .hw.init = &(const struct clk_init_data) { 1325 .name = "gcc_gpu_memnoc_gfx_clk", 1326 .ops = &clk_branch2_ops, 1327 }, 1328 }, 1329 }; 1330 1331 static struct clk_branch gcc_gpu_snoc_dvm_gfx_clk = { 1332 .halt_reg = 0x81018, 1333 .halt_check = BRANCH_HALT_DELAY, 1334 .clkr = { 1335 .enable_reg = 0x81018, 1336 .enable_mask = BIT(0), 1337 .hw.init = &(const struct clk_init_data) { 1338 .name = "gcc_gpu_snoc_dvm_gfx_clk", 1339 .ops = &clk_branch2_ops, 1340 }, 1341 }, 1342 }; 1343 1344 static struct clk_branch gcc_hlos1_vote_aggre_noc_mmu_audio_tbu_clk = { 1345 .halt_reg = 0x8d004, 1346 .halt_check = BRANCH_HALT_VOTED, 1347 .clkr = { 1348 .enable_reg = 0x8d004, 1349 .enable_mask = BIT(0), 1350 .hw.init = &(const struct clk_init_data){ 1351 .name = "gcc_hlos1_vote_aggre_noc_mmu_audio_tbu_clk", 1352 .ops = &clk_branch2_ops, 1353 }, 1354 }, 1355 }; 1356 1357 static struct clk_branch gcc_hlos1_vote_aggre_noc_mmu_pcie_tbu_clk = { 1358 .halt_reg = 0x8d010, 1359 .halt_check = BRANCH_HALT_VOTED, 1360 .clkr = { 1361 .enable_reg = 0x8d010, 1362 .enable_mask = BIT(0), 1363 .hw.init = &(const struct clk_init_data){ 1364 .name = "gcc_hlos1_vote_aggre_noc_mmu_pcie_tbu_clk", 1365 .ops = &clk_branch2_ops, 1366 }, 1367 }, 1368 }; 1369 1370 static struct clk_branch gcc_hlos1_vote_aggre_noc_mmu_tbu1_clk = { 1371 .halt_reg = 0x8d008, 1372 .halt_check = BRANCH_HALT_VOTED, 1373 .clkr = { 1374 .enable_reg = 0x8d008, 1375 .enable_mask = BIT(0), 1376 .hw.init = &(const struct clk_init_data){ 1377 .name = "gcc_hlos1_vote_aggre_noc_mmu_tbu1_clk", 1378 .ops = &clk_branch2_ops, 1379 }, 1380 }, 1381 }; 1382 1383 static struct clk_branch gcc_hlos1_vote_aggre_noc_mmu_tbu2_clk = { 1384 .halt_reg = 0x8d00c, 1385 .halt_check = BRANCH_HALT_VOTED, 1386 .clkr = { 1387 .enable_reg = 0x8d00c, 1388 .enable_mask = BIT(0), 1389 .hw.init = &(const struct clk_init_data){ 1390 .name = "gcc_hlos1_vote_aggre_noc_mmu_tbu2_clk", 1391 .ops = &clk_branch2_ops, 1392 }, 1393 }, 1394 }; 1395 1396 static struct clk_branch gcc_hlos1_vote_mmnoc_mmu_tbu_hf0_clk = { 1397 .halt_reg = 0x8d018, 1398 .halt_check = BRANCH_HALT_VOTED, 1399 .clkr = { 1400 .enable_reg = 0x8d018, 1401 .enable_mask = BIT(0), 1402 .hw.init = &(const struct clk_init_data){ 1403 .name = "gcc_hlos1_vote_mmnoc_mmu_tbu_hf0_clk", 1404 .ops = &clk_branch2_ops, 1405 }, 1406 }, 1407 }; 1408 1409 static struct clk_branch gcc_hlos1_vote_mmnoc_mmu_tbu_hf1_clk = { 1410 .halt_reg = 0x8d01c, 1411 .halt_check = BRANCH_HALT_VOTED, 1412 .clkr = { 1413 .enable_reg = 0x8d01c, 1414 .enable_mask = BIT(0), 1415 .hw.init = &(const struct clk_init_data){ 1416 .name = "gcc_hlos1_vote_mmnoc_mmu_tbu_hf1_clk", 1417 .ops = &clk_branch2_ops, 1418 }, 1419 }, 1420 }; 1421 1422 static struct clk_branch gcc_hlos1_vote_mmnoc_mmu_tbu_sf0_clk = { 1423 .halt_reg = 0x8d014, 1424 .halt_check = BRANCH_HALT_VOTED, 1425 .clkr = { 1426 .enable_reg = 0x8d014, 1427 .enable_mask = BIT(0), 1428 .hw.init = &(const struct clk_init_data){ 1429 .name = "gcc_hlos1_vote_mmnoc_mmu_tbu_sf0_clk", 1430 .ops = &clk_branch2_ops, 1431 }, 1432 }, 1433 }; 1434 1435 static struct clk_branch gcc_hlos1_vote_mmu_tcu_clk = { 1436 .halt_reg = 0x8d02c, 1437 .halt_check = BRANCH_HALT_VOTED, 1438 .clkr = { 1439 .enable_reg = 0x8d02c, 1440 .enable_mask = BIT(0), 1441 .hw.init = &(const struct clk_init_data){ 1442 .name = "gcc_hlos1_vote_mmu_tcu_clk", 1443 .ops = &clk_branch2_ops, 1444 }, 1445 }, 1446 }; 1447 1448 static struct clk_branch gcc_pcie_0_aux_clk = { 1449 .halt_reg = 0x7b034, 1450 .halt_check = BRANCH_HALT_VOTED, 1451 .clkr = { 1452 .enable_reg = 0x62008, 1453 .enable_mask = BIT(3), 1454 .hw.init = &(const struct clk_init_data) { 1455 .name = "gcc_pcie_0_aux_clk", 1456 .parent_hws = (const struct clk_hw*[]) { 1457 &gcc_pcie_0_aux_clk_src.clkr.hw, 1458 }, 1459 .num_parents = 1, 1460 .flags = CLK_SET_RATE_PARENT, 1461 .ops = &clk_branch2_ops, 1462 }, 1463 }, 1464 }; 1465 1466 static struct clk_branch gcc_pcie_0_cfg_ahb_clk = { 1467 .halt_reg = 0x7b030, 1468 .halt_check = BRANCH_HALT_VOTED, 1469 .hwcg_reg = 0x7b030, 1470 .hwcg_bit = 1, 1471 .clkr = { 1472 .enable_reg = 0x62008, 1473 .enable_mask = BIT(2), 1474 .hw.init = &(const struct clk_init_data) { 1475 .name = "gcc_pcie_0_cfg_ahb_clk", 1476 .ops = &clk_branch2_ops, 1477 }, 1478 }, 1479 }; 1480 1481 static struct clk_branch gcc_pcie_0_clkref_en = { 1482 .halt_reg = 0x9c004, 1483 .halt_check = BRANCH_HALT_DELAY, 1484 .clkr = { 1485 .enable_reg = 0x9c004, 1486 .enable_mask = BIT(0), 1487 .hw.init = &(const struct clk_init_data) { 1488 .name = "gcc_pcie_0_clkref_en", 1489 .ops = &clk_branch2_ops, 1490 }, 1491 }, 1492 }; 1493 1494 static struct clk_branch gcc_pcie_0_mstr_axi_clk = { 1495 .halt_reg = 0x7b028, 1496 .halt_check = BRANCH_HALT_SKIP, 1497 .clkr = { 1498 .enable_reg = 0x62008, 1499 .enable_mask = BIT(1), 1500 .hw.init = &(const struct clk_init_data) { 1501 .name = "gcc_pcie_0_mstr_axi_clk", 1502 .ops = &clk_branch2_ops, 1503 }, 1504 }, 1505 }; 1506 1507 static struct clk_branch gcc_pcie_0_phy_rchng_clk = { 1508 .halt_reg = 0x7b044, 1509 .halt_check = BRANCH_HALT_VOTED, 1510 .clkr = { 1511 .enable_reg = 0x62000, 1512 .enable_mask = BIT(22), 1513 .hw.init = &(const struct clk_init_data) { 1514 .name = "gcc_pcie_0_phy_rchng_clk", 1515 .parent_hws = (const struct clk_hw*[]) { 1516 &gcc_pcie_0_phy_rchng_clk_src.clkr.hw, 1517 }, 1518 .num_parents = 1, 1519 .flags = CLK_SET_RATE_PARENT, 1520 .ops = &clk_branch2_ops, 1521 }, 1522 }, 1523 }; 1524 1525 static struct clk_branch gcc_pcie_0_pipe_clk = { 1526 .halt_reg = 0x7b03c, 1527 .halt_check = BRANCH_HALT_SKIP, 1528 .clkr = { 1529 .enable_reg = 0x62008, 1530 .enable_mask = BIT(4), 1531 .hw.init = &(const struct clk_init_data) { 1532 .name = "gcc_pcie_0_pipe_clk", 1533 .parent_hws = (const struct clk_hw*[]) { 1534 &gcc_pcie_0_pipe_clk_src.clkr.hw, 1535 }, 1536 .num_parents = 1, 1537 .flags = CLK_SET_RATE_PARENT, 1538 .ops = &clk_branch2_ops, 1539 }, 1540 }, 1541 }; 1542 1543 static struct clk_branch gcc_pcie_0_pipe_div2_clk = { 1544 .halt_reg = 0x7b094, 1545 .halt_check = BRANCH_HALT_SKIP, 1546 .clkr = { 1547 .enable_reg = 0x62010, 1548 .enable_mask = BIT(26), 1549 .hw.init = &(const struct clk_init_data) { 1550 .name = "gcc_pcie_0_pipe_div2_clk", 1551 .parent_hws = (const struct clk_hw*[]) { 1552 &gcc_pcie_0_pipe_div2_clk_src.clkr.hw, 1553 }, 1554 .num_parents = 1, 1555 .flags = CLK_SET_RATE_PARENT, 1556 .ops = &clk_branch2_ops, 1557 }, 1558 }, 1559 }; 1560 1561 static struct clk_branch gcc_pcie_0_slv_axi_clk = { 1562 .halt_reg = 0x7b020, 1563 .halt_check = BRANCH_HALT_VOTED, 1564 .hwcg_reg = 0x7b020, 1565 .hwcg_bit = 1, 1566 .clkr = { 1567 .enable_reg = 0x62008, 1568 .enable_mask = BIT(0), 1569 .hw.init = &(const struct clk_init_data) { 1570 .name = "gcc_pcie_0_slv_axi_clk", 1571 .ops = &clk_branch2_ops, 1572 }, 1573 }, 1574 }; 1575 1576 static struct clk_branch gcc_pcie_0_slv_q2a_axi_clk = { 1577 .halt_reg = 0x7b01c, 1578 .halt_check = BRANCH_HALT_VOTED, 1579 .clkr = { 1580 .enable_reg = 0x62008, 1581 .enable_mask = BIT(5), 1582 .hw.init = &(const struct clk_init_data) { 1583 .name = "gcc_pcie_0_slv_q2a_axi_clk", 1584 .ops = &clk_branch2_ops, 1585 }, 1586 }, 1587 }; 1588 1589 static struct clk_branch gcc_pdm2_clk = { 1590 .halt_reg = 0x4300c, 1591 .halt_check = BRANCH_HALT, 1592 .clkr = { 1593 .enable_reg = 0x4300c, 1594 .enable_mask = BIT(0), 1595 .hw.init = &(const struct clk_init_data) { 1596 .name = "gcc_pdm2_clk", 1597 .parent_hws = (const struct clk_hw*[]) { 1598 &gcc_pdm2_clk_src.clkr.hw, 1599 }, 1600 .num_parents = 1, 1601 .flags = CLK_SET_RATE_PARENT, 1602 .ops = &clk_branch2_ops, 1603 }, 1604 }, 1605 }; 1606 1607 static struct clk_branch gcc_pdm_ahb_clk = { 1608 .halt_reg = 0x43004, 1609 .halt_check = BRANCH_HALT_VOTED, 1610 .hwcg_reg = 0x43004, 1611 .hwcg_bit = 1, 1612 .clkr = { 1613 .enable_reg = 0x43004, 1614 .enable_mask = BIT(0), 1615 .hw.init = &(const struct clk_init_data) { 1616 .name = "gcc_pdm_ahb_clk", 1617 .ops = &clk_branch2_ops, 1618 }, 1619 }, 1620 }; 1621 1622 static struct clk_branch gcc_pdm_xo4_clk = { 1623 .halt_reg = 0x43008, 1624 .halt_check = BRANCH_HALT, 1625 .clkr = { 1626 .enable_reg = 0x43008, 1627 .enable_mask = BIT(0), 1628 .hw.init = &(const struct clk_init_data) { 1629 .name = "gcc_pdm_xo4_clk", 1630 .ops = &clk_branch2_ops, 1631 }, 1632 }, 1633 }; 1634 1635 static struct clk_branch gcc_qmip_camera_nrt_ahb_clk = { 1636 .halt_reg = 0x36008, 1637 .halt_check = BRANCH_HALT_VOTED, 1638 .hwcg_reg = 0x36008, 1639 .hwcg_bit = 1, 1640 .clkr = { 1641 .enable_reg = 0x36008, 1642 .enable_mask = BIT(0), 1643 .hw.init = &(const struct clk_init_data) { 1644 .name = "gcc_qmip_camera_nrt_ahb_clk", 1645 .ops = &clk_branch2_ops, 1646 }, 1647 }, 1648 }; 1649 1650 static struct clk_branch gcc_qmip_camera_rt_ahb_clk = { 1651 .halt_reg = 0x3600c, 1652 .halt_check = BRANCH_HALT_VOTED, 1653 .hwcg_reg = 0x3600c, 1654 .hwcg_bit = 1, 1655 .clkr = { 1656 .enable_reg = 0x3600c, 1657 .enable_mask = BIT(0), 1658 .hw.init = &(const struct clk_init_data) { 1659 .name = "gcc_qmip_camera_rt_ahb_clk", 1660 .ops = &clk_branch2_ops, 1661 }, 1662 }, 1663 }; 1664 1665 static struct clk_branch gcc_qmip_disp_ahb_clk = { 1666 .halt_reg = 0x37008, 1667 .halt_check = BRANCH_HALT_VOTED, 1668 .hwcg_reg = 0x37008, 1669 .hwcg_bit = 1, 1670 .clkr = { 1671 .enable_reg = 0x37008, 1672 .enable_mask = BIT(0), 1673 .hw.init = &(const struct clk_init_data) { 1674 .name = "gcc_qmip_disp_ahb_clk", 1675 .ops = &clk_branch2_ops, 1676 }, 1677 }, 1678 }; 1679 1680 static struct clk_branch gcc_qmip_gpu_ahb_clk = { 1681 .halt_reg = 0x81008, 1682 .halt_check = BRANCH_HALT_VOTED, 1683 .hwcg_reg = 0x81008, 1684 .hwcg_bit = 1, 1685 .clkr = { 1686 .enable_reg = 0x81008, 1687 .enable_mask = BIT(0), 1688 .hw.init = &(const struct clk_init_data) { 1689 .name = "gcc_qmip_gpu_ahb_clk", 1690 .ops = &clk_branch2_ops, 1691 }, 1692 }, 1693 }; 1694 1695 static struct clk_branch gcc_qmip_pcie_ahb_clk = { 1696 .halt_reg = 0x7b018, 1697 .halt_check = BRANCH_HALT_VOTED, 1698 .hwcg_reg = 0x7b018, 1699 .hwcg_bit = 1, 1700 .clkr = { 1701 .enable_reg = 0x7b018, 1702 .enable_mask = BIT(0), 1703 .hw.init = &(const struct clk_init_data) { 1704 .name = "gcc_qmip_pcie_ahb_clk", 1705 .ops = &clk_branch2_ops, 1706 }, 1707 }, 1708 }; 1709 1710 static struct clk_branch gcc_qmip_video_vcodec_ahb_clk = { 1711 .halt_reg = 0x42008, 1712 .halt_check = BRANCH_HALT_VOTED, 1713 .hwcg_reg = 0x42008, 1714 .hwcg_bit = 1, 1715 .clkr = { 1716 .enable_reg = 0x42008, 1717 .enable_mask = BIT(0), 1718 .hw.init = &(const struct clk_init_data) { 1719 .name = "gcc_qmip_video_vcodec_ahb_clk", 1720 .ops = &clk_branch2_ops, 1721 }, 1722 }, 1723 }; 1724 1725 static struct clk_branch gcc_qupv3_wrap0_core_2x_clk = { 1726 .halt_reg = 0x3300c, 1727 .halt_check = BRANCH_HALT_VOTED, 1728 .clkr = { 1729 .enable_reg = 0x62008, 1730 .enable_mask = BIT(9), 1731 .hw.init = &(const struct clk_init_data) { 1732 .name = "gcc_qupv3_wrap0_core_2x_clk", 1733 .ops = &clk_branch2_ops, 1734 }, 1735 }, 1736 }; 1737 1738 static struct clk_branch gcc_qupv3_wrap0_core_clk = { 1739 .halt_reg = 0x33000, 1740 .halt_check = BRANCH_HALT_VOTED, 1741 .clkr = { 1742 .enable_reg = 0x62008, 1743 .enable_mask = BIT(8), 1744 .hw.init = &(const struct clk_init_data) { 1745 .name = "gcc_qupv3_wrap0_core_clk", 1746 .ops = &clk_branch2_ops, 1747 }, 1748 }, 1749 }; 1750 1751 static struct clk_branch gcc_qupv3_wrap0_s0_clk = { 1752 .halt_reg = 0x2700c, 1753 .halt_check = BRANCH_HALT_VOTED, 1754 .clkr = { 1755 .enable_reg = 0x62008, 1756 .enable_mask = BIT(10), 1757 .hw.init = &(const struct clk_init_data) { 1758 .name = "gcc_qupv3_wrap0_s0_clk", 1759 .parent_hws = (const struct clk_hw*[]) { 1760 &gcc_qupv3_wrap0_s0_clk_src.clkr.hw, 1761 }, 1762 .num_parents = 1, 1763 .flags = CLK_SET_RATE_PARENT, 1764 .ops = &clk_branch2_ops, 1765 }, 1766 }, 1767 }; 1768 1769 static struct clk_branch gcc_qupv3_wrap0_s1_clk = { 1770 .halt_reg = 0x27140, 1771 .halt_check = BRANCH_HALT_VOTED, 1772 .clkr = { 1773 .enable_reg = 0x62008, 1774 .enable_mask = BIT(11), 1775 .hw.init = &(const struct clk_init_data) { 1776 .name = "gcc_qupv3_wrap0_s1_clk", 1777 .parent_hws = (const struct clk_hw*[]) { 1778 &gcc_qupv3_wrap0_s1_clk_src.clkr.hw, 1779 }, 1780 .num_parents = 1, 1781 .flags = CLK_SET_RATE_PARENT, 1782 .ops = &clk_branch2_ops, 1783 }, 1784 }, 1785 }; 1786 1787 static struct clk_branch gcc_qupv3_wrap0_s2_clk = { 1788 .halt_reg = 0x27274, 1789 .halt_check = BRANCH_HALT_VOTED, 1790 .clkr = { 1791 .enable_reg = 0x62008, 1792 .enable_mask = BIT(12), 1793 .hw.init = &(const struct clk_init_data) { 1794 .name = "gcc_qupv3_wrap0_s2_clk", 1795 .parent_hws = (const struct clk_hw*[]) { 1796 &gcc_qupv3_wrap0_s2_clk_src.clkr.hw, 1797 }, 1798 .num_parents = 1, 1799 .flags = CLK_SET_RATE_PARENT, 1800 .ops = &clk_branch2_ops, 1801 }, 1802 }, 1803 }; 1804 1805 static struct clk_branch gcc_qupv3_wrap0_s3_clk = { 1806 .halt_reg = 0x273a8, 1807 .halt_check = BRANCH_HALT_VOTED, 1808 .clkr = { 1809 .enable_reg = 0x62008, 1810 .enable_mask = BIT(13), 1811 .hw.init = &(const struct clk_init_data) { 1812 .name = "gcc_qupv3_wrap0_s3_clk", 1813 .parent_hws = (const struct clk_hw*[]) { 1814 &gcc_qupv3_wrap0_s3_clk_src.clkr.hw, 1815 }, 1816 .num_parents = 1, 1817 .flags = CLK_SET_RATE_PARENT, 1818 .ops = &clk_branch2_ops, 1819 }, 1820 }, 1821 }; 1822 1823 static struct clk_branch gcc_qupv3_wrap0_s4_clk = { 1824 .halt_reg = 0x274dc, 1825 .halt_check = BRANCH_HALT_VOTED, 1826 .clkr = { 1827 .enable_reg = 0x62008, 1828 .enable_mask = BIT(14), 1829 .hw.init = &(const struct clk_init_data) { 1830 .name = "gcc_qupv3_wrap0_s4_clk", 1831 .parent_hws = (const struct clk_hw*[]) { 1832 &gcc_qupv3_wrap0_s4_clk_src.clkr.hw, 1833 }, 1834 .num_parents = 1, 1835 .flags = CLK_SET_RATE_PARENT, 1836 .ops = &clk_branch2_ops, 1837 }, 1838 }, 1839 }; 1840 1841 static struct clk_branch gcc_qupv3_wrap1_core_2x_clk = { 1842 .halt_reg = 0x3314c, 1843 .halt_check = BRANCH_HALT_VOTED, 1844 .clkr = { 1845 .enable_reg = 0x62008, 1846 .enable_mask = BIT(18), 1847 .hw.init = &(const struct clk_init_data) { 1848 .name = "gcc_qupv3_wrap1_core_2x_clk", 1849 .ops = &clk_branch2_ops, 1850 }, 1851 }, 1852 }; 1853 1854 static struct clk_branch gcc_qupv3_wrap1_core_clk = { 1855 .halt_reg = 0x33140, 1856 .halt_check = BRANCH_HALT_VOTED, 1857 .clkr = { 1858 .enable_reg = 0x62008, 1859 .enable_mask = BIT(19), 1860 .hw.init = &(const struct clk_init_data) { 1861 .name = "gcc_qupv3_wrap1_core_clk", 1862 .ops = &clk_branch2_ops, 1863 }, 1864 }, 1865 }; 1866 1867 static struct clk_branch gcc_qupv3_wrap1_s0_clk = { 1868 .halt_reg = 0x2800c, 1869 .halt_check = BRANCH_HALT_VOTED, 1870 .clkr = { 1871 .enable_reg = 0x62008, 1872 .enable_mask = BIT(22), 1873 .hw.init = &(const struct clk_init_data) { 1874 .name = "gcc_qupv3_wrap1_s0_clk", 1875 .parent_hws = (const struct clk_hw*[]) { 1876 &gcc_qupv3_wrap1_s0_clk_src.clkr.hw, 1877 }, 1878 .num_parents = 1, 1879 .flags = CLK_SET_RATE_PARENT, 1880 .ops = &clk_branch2_ops, 1881 }, 1882 }, 1883 }; 1884 1885 static struct clk_branch gcc_qupv3_wrap1_s1_clk = { 1886 .halt_reg = 0x28140, 1887 .halt_check = BRANCH_HALT_VOTED, 1888 .clkr = { 1889 .enable_reg = 0x62008, 1890 .enable_mask = BIT(23), 1891 .hw.init = &(const struct clk_init_data) { 1892 .name = "gcc_qupv3_wrap1_s1_clk", 1893 .parent_hws = (const struct clk_hw*[]) { 1894 &gcc_qupv3_wrap1_s1_clk_src.clkr.hw, 1895 }, 1896 .num_parents = 1, 1897 .flags = CLK_SET_RATE_PARENT, 1898 .ops = &clk_branch2_ops, 1899 }, 1900 }, 1901 }; 1902 1903 static struct clk_branch gcc_qupv3_wrap1_s2_clk = { 1904 .halt_reg = 0x28274, 1905 .halt_check = BRANCH_HALT_VOTED, 1906 .clkr = { 1907 .enable_reg = 0x62008, 1908 .enable_mask = BIT(24), 1909 .hw.init = &(const struct clk_init_data) { 1910 .name = "gcc_qupv3_wrap1_s2_clk", 1911 .parent_hws = (const struct clk_hw*[]) { 1912 &gcc_qupv3_wrap1_s2_clk_src.clkr.hw, 1913 }, 1914 .num_parents = 1, 1915 .flags = CLK_SET_RATE_PARENT, 1916 .ops = &clk_branch2_ops, 1917 }, 1918 }, 1919 }; 1920 1921 static struct clk_branch gcc_qupv3_wrap1_s3_clk = { 1922 .halt_reg = 0x283a8, 1923 .halt_check = BRANCH_HALT_VOTED, 1924 .clkr = { 1925 .enable_reg = 0x62008, 1926 .enable_mask = BIT(25), 1927 .hw.init = &(const struct clk_init_data) { 1928 .name = "gcc_qupv3_wrap1_s3_clk", 1929 .parent_hws = (const struct clk_hw*[]) { 1930 &gcc_qupv3_wrap1_s3_clk_src.clkr.hw, 1931 }, 1932 .num_parents = 1, 1933 .flags = CLK_SET_RATE_PARENT, 1934 .ops = &clk_branch2_ops, 1935 }, 1936 }, 1937 }; 1938 1939 static struct clk_branch gcc_qupv3_wrap1_s4_clk = { 1940 .halt_reg = 0x284dc, 1941 .halt_check = BRANCH_HALT_VOTED, 1942 .clkr = { 1943 .enable_reg = 0x62008, 1944 .enable_mask = BIT(26), 1945 .hw.init = &(const struct clk_init_data) { 1946 .name = "gcc_qupv3_wrap1_s4_clk", 1947 .parent_hws = (const struct clk_hw*[]) { 1948 &gcc_qupv3_wrap1_s4_clk_src.clkr.hw, 1949 }, 1950 .num_parents = 1, 1951 .flags = CLK_SET_RATE_PARENT, 1952 .ops = &clk_branch2_ops, 1953 }, 1954 }, 1955 }; 1956 1957 static struct clk_branch gcc_qupv3_wrap_0_m_ahb_clk = { 1958 .halt_reg = 0x27004, 1959 .halt_check = BRANCH_HALT_VOTED, 1960 .hwcg_reg = 0x27004, 1961 .hwcg_bit = 1, 1962 .clkr = { 1963 .enable_reg = 0x62008, 1964 .enable_mask = BIT(6), 1965 .hw.init = &(const struct clk_init_data) { 1966 .name = "gcc_qupv3_wrap_0_m_ahb_clk", 1967 .ops = &clk_branch2_ops, 1968 }, 1969 }, 1970 }; 1971 1972 static struct clk_branch gcc_qupv3_wrap_0_s_ahb_clk = { 1973 .halt_reg = 0x27008, 1974 .halt_check = BRANCH_HALT_VOTED, 1975 .hwcg_reg = 0x27008, 1976 .hwcg_bit = 1, 1977 .clkr = { 1978 .enable_reg = 0x62008, 1979 .enable_mask = BIT(7), 1980 .hw.init = &(const struct clk_init_data) { 1981 .name = "gcc_qupv3_wrap_0_s_ahb_clk", 1982 .ops = &clk_branch2_ops, 1983 }, 1984 }, 1985 }; 1986 1987 static struct clk_branch gcc_qupv3_wrap_1_m_ahb_clk = { 1988 .halt_reg = 0x28004, 1989 .halt_check = BRANCH_HALT_VOTED, 1990 .hwcg_reg = 0x28004, 1991 .hwcg_bit = 1, 1992 .clkr = { 1993 .enable_reg = 0x62008, 1994 .enable_mask = BIT(20), 1995 .hw.init = &(const struct clk_init_data) { 1996 .name = "gcc_qupv3_wrap_1_m_ahb_clk", 1997 .ops = &clk_branch2_ops, 1998 }, 1999 }, 2000 }; 2001 2002 static struct clk_branch gcc_qupv3_wrap_1_s_ahb_clk = { 2003 .halt_reg = 0x28008, 2004 .halt_check = BRANCH_HALT_VOTED, 2005 .hwcg_reg = 0x28008, 2006 .hwcg_bit = 1, 2007 .clkr = { 2008 .enable_reg = 0x62008, 2009 .enable_mask = BIT(21), 2010 .hw.init = &(const struct clk_init_data) { 2011 .name = "gcc_qupv3_wrap_1_s_ahb_clk", 2012 .ops = &clk_branch2_ops, 2013 }, 2014 }, 2015 }; 2016 2017 static struct clk_branch gcc_sdcc1_ahb_clk = { 2018 .halt_reg = 0xb3004, 2019 .halt_check = BRANCH_HALT, 2020 .clkr = { 2021 .enable_reg = 0xb3004, 2022 .enable_mask = BIT(0), 2023 .hw.init = &(const struct clk_init_data) { 2024 .name = "gcc_sdcc1_ahb_clk", 2025 .ops = &clk_branch2_ops, 2026 }, 2027 }, 2028 }; 2029 2030 static struct clk_branch gcc_sdcc1_apps_clk = { 2031 .halt_reg = 0xb3008, 2032 .halt_check = BRANCH_HALT, 2033 .clkr = { 2034 .enable_reg = 0xb3008, 2035 .enable_mask = BIT(0), 2036 .hw.init = &(const struct clk_init_data) { 2037 .name = "gcc_sdcc1_apps_clk", 2038 .parent_hws = (const struct clk_hw*[]) { 2039 &gcc_sdcc1_apps_clk_src.clkr.hw, 2040 }, 2041 .num_parents = 1, 2042 .flags = CLK_SET_RATE_PARENT, 2043 .ops = &clk_branch2_ops, 2044 }, 2045 }, 2046 }; 2047 2048 static struct clk_branch gcc_sdcc1_ice_core_clk = { 2049 .halt_reg = 0xb3028, 2050 .halt_check = BRANCH_HALT_VOTED, 2051 .hwcg_reg = 0xb3028, 2052 .hwcg_bit = 1, 2053 .clkr = { 2054 .enable_reg = 0xb3028, 2055 .enable_mask = BIT(0), 2056 .hw.init = &(const struct clk_init_data) { 2057 .name = "gcc_sdcc1_ice_core_clk", 2058 .parent_hws = (const struct clk_hw*[]) { 2059 &gcc_sdcc1_ice_core_clk_src.clkr.hw, 2060 }, 2061 .num_parents = 1, 2062 .flags = CLK_SET_RATE_PARENT, 2063 .ops = &clk_branch2_ops, 2064 }, 2065 }, 2066 }; 2067 2068 static struct clk_branch gcc_sdcc2_ahb_clk = { 2069 .halt_reg = 0x2400c, 2070 .halt_check = BRANCH_HALT, 2071 .clkr = { 2072 .enable_reg = 0x2400c, 2073 .enable_mask = BIT(0), 2074 .hw.init = &(const struct clk_init_data) { 2075 .name = "gcc_sdcc2_ahb_clk", 2076 .ops = &clk_branch2_ops, 2077 }, 2078 }, 2079 }; 2080 2081 static struct clk_branch gcc_sdcc2_apps_clk = { 2082 .halt_reg = 0x24004, 2083 .halt_check = BRANCH_HALT, 2084 .clkr = { 2085 .enable_reg = 0x24004, 2086 .enable_mask = BIT(0), 2087 .hw.init = &(const struct clk_init_data) { 2088 .name = "gcc_sdcc2_apps_clk", 2089 .parent_hws = (const struct clk_hw*[]) { 2090 &gcc_sdcc2_apps_clk_src.clkr.hw, 2091 }, 2092 .num_parents = 1, 2093 .flags = CLK_SET_RATE_PARENT, 2094 .ops = &clk_branch2_ops, 2095 }, 2096 }, 2097 }; 2098 2099 static struct clk_branch gcc_ufs_0_clkref_en = { 2100 .halt_reg = 0x9c000, 2101 .halt_check = BRANCH_HALT_DELAY, 2102 .clkr = { 2103 .enable_reg = 0x9c000, 2104 .enable_mask = BIT(0), 2105 .hw.init = &(const struct clk_init_data) { 2106 .name = "gcc_ufs_0_clkref_en", 2107 .ops = &clk_branch2_ops, 2108 }, 2109 }, 2110 }; 2111 2112 static struct clk_branch gcc_ufs_pad_clkref_en = { 2113 .halt_reg = 0x9c024, 2114 .halt_check = BRANCH_HALT_DELAY, 2115 .clkr = { 2116 .enable_reg = 0x9c024, 2117 .enable_mask = BIT(0), 2118 .hw.init = &(const struct clk_init_data) { 2119 .name = "gcc_ufs_pad_clkref_en", 2120 .ops = &clk_branch2_ops, 2121 }, 2122 }, 2123 }; 2124 2125 static struct clk_branch gcc_ufs_phy_ahb_clk = { 2126 .halt_reg = 0x87020, 2127 .halt_check = BRANCH_HALT_VOTED, 2128 .hwcg_reg = 0x87020, 2129 .hwcg_bit = 1, 2130 .clkr = { 2131 .enable_reg = 0x87020, 2132 .enable_mask = BIT(0), 2133 .hw.init = &(const struct clk_init_data) { 2134 .name = "gcc_ufs_phy_ahb_clk", 2135 .ops = &clk_branch2_ops, 2136 }, 2137 }, 2138 }; 2139 2140 static struct clk_branch gcc_ufs_phy_axi_clk = { 2141 .halt_reg = 0x87018, 2142 .halt_check = BRANCH_HALT_VOTED, 2143 .hwcg_reg = 0x87018, 2144 .hwcg_bit = 1, 2145 .clkr = { 2146 .enable_reg = 0x87018, 2147 .enable_mask = BIT(0), 2148 .hw.init = &(const struct clk_init_data) { 2149 .name = "gcc_ufs_phy_axi_clk", 2150 .parent_hws = (const struct clk_hw*[]) { 2151 &gcc_ufs_phy_axi_clk_src.clkr.hw, 2152 }, 2153 .num_parents = 1, 2154 .flags = CLK_SET_RATE_PARENT, 2155 .ops = &clk_branch2_ops, 2156 }, 2157 }, 2158 }; 2159 2160 static struct clk_branch gcc_ufs_phy_axi_hw_ctl_clk = { 2161 .halt_reg = 0x87018, 2162 .halt_check = BRANCH_HALT_VOTED, 2163 .hwcg_reg = 0x87018, 2164 .hwcg_bit = 1, 2165 .clkr = { 2166 .enable_reg = 0x87018, 2167 .enable_mask = BIT(1), 2168 .hw.init = &(const struct clk_init_data) { 2169 .name = "gcc_ufs_phy_axi_hw_ctl_clk", 2170 .parent_hws = (const struct clk_hw*[]) { 2171 &gcc_ufs_phy_axi_clk_src.clkr.hw, 2172 }, 2173 .num_parents = 1, 2174 .flags = CLK_SET_RATE_PARENT, 2175 .ops = &clk_branch2_ops, 2176 }, 2177 }, 2178 }; 2179 2180 static struct clk_branch gcc_ufs_phy_ice_core_clk = { 2181 .halt_reg = 0x8706c, 2182 .halt_check = BRANCH_HALT_VOTED, 2183 .hwcg_reg = 0x8706c, 2184 .hwcg_bit = 1, 2185 .clkr = { 2186 .enable_reg = 0x8706c, 2187 .enable_mask = BIT(0), 2188 .hw.init = &(const struct clk_init_data) { 2189 .name = "gcc_ufs_phy_ice_core_clk", 2190 .parent_hws = (const struct clk_hw*[]) { 2191 &gcc_ufs_phy_ice_core_clk_src.clkr.hw, 2192 }, 2193 .num_parents = 1, 2194 .flags = CLK_SET_RATE_PARENT, 2195 .ops = &clk_branch2_ops, 2196 }, 2197 }, 2198 }; 2199 2200 static struct clk_branch gcc_ufs_phy_ice_core_hw_ctl_clk = { 2201 .halt_reg = 0x8706c, 2202 .halt_check = BRANCH_HALT_VOTED, 2203 .hwcg_reg = 0x8706c, 2204 .hwcg_bit = 1, 2205 .clkr = { 2206 .enable_reg = 0x8706c, 2207 .enable_mask = BIT(1), 2208 .hw.init = &(const struct clk_init_data) { 2209 .name = "gcc_ufs_phy_ice_core_hw_ctl_clk", 2210 .parent_hws = (const struct clk_hw*[]) { 2211 &gcc_ufs_phy_ice_core_clk_src.clkr.hw, 2212 }, 2213 .num_parents = 1, 2214 .flags = CLK_SET_RATE_PARENT, 2215 .ops = &clk_branch2_ops, 2216 }, 2217 }, 2218 }; 2219 2220 static struct clk_branch gcc_ufs_phy_phy_aux_clk = { 2221 .halt_reg = 0x870a4, 2222 .halt_check = BRANCH_HALT_VOTED, 2223 .hwcg_reg = 0x870a4, 2224 .hwcg_bit = 1, 2225 .clkr = { 2226 .enable_reg = 0x870a4, 2227 .enable_mask = BIT(0), 2228 .hw.init = &(const struct clk_init_data) { 2229 .name = "gcc_ufs_phy_phy_aux_clk", 2230 .parent_hws = (const struct clk_hw*[]) { 2231 &gcc_ufs_phy_phy_aux_clk_src.clkr.hw, 2232 }, 2233 .num_parents = 1, 2234 .flags = CLK_SET_RATE_PARENT, 2235 .ops = &clk_branch2_ops, 2236 }, 2237 }, 2238 }; 2239 2240 static struct clk_branch gcc_ufs_phy_phy_aux_hw_ctl_clk = { 2241 .halt_reg = 0x870a4, 2242 .halt_check = BRANCH_HALT_VOTED, 2243 .hwcg_reg = 0x870a4, 2244 .hwcg_bit = 1, 2245 .clkr = { 2246 .enable_reg = 0x870a4, 2247 .enable_mask = BIT(1), 2248 .hw.init = &(const struct clk_init_data) { 2249 .name = "gcc_ufs_phy_phy_aux_hw_ctl_clk", 2250 .parent_hws = (const struct clk_hw*[]) { 2251 &gcc_ufs_phy_phy_aux_clk_src.clkr.hw, 2252 }, 2253 .num_parents = 1, 2254 .flags = CLK_SET_RATE_PARENT, 2255 .ops = &clk_branch2_ops, 2256 }, 2257 }, 2258 }; 2259 2260 static struct clk_branch gcc_ufs_phy_rx_symbol_0_clk = { 2261 .halt_reg = 0x87028, 2262 .halt_check = BRANCH_HALT_DELAY, 2263 .clkr = { 2264 .enable_reg = 0x87028, 2265 .enable_mask = BIT(0), 2266 .hw.init = &(const struct clk_init_data) { 2267 .name = "gcc_ufs_phy_rx_symbol_0_clk", 2268 .parent_hws = (const struct clk_hw*[]) { 2269 &gcc_ufs_phy_rx_symbol_0_clk_src.clkr.hw, 2270 }, 2271 .num_parents = 1, 2272 .flags = CLK_SET_RATE_PARENT, 2273 .ops = &clk_branch2_ops, 2274 }, 2275 }, 2276 }; 2277 2278 static struct clk_branch gcc_ufs_phy_rx_symbol_1_clk = { 2279 .halt_reg = 0x870c0, 2280 .halt_check = BRANCH_HALT_DELAY, 2281 .clkr = { 2282 .enable_reg = 0x870c0, 2283 .enable_mask = BIT(0), 2284 .hw.init = &(const struct clk_init_data) { 2285 .name = "gcc_ufs_phy_rx_symbol_1_clk", 2286 .parent_hws = (const struct clk_hw*[]) { 2287 &gcc_ufs_phy_rx_symbol_1_clk_src.clkr.hw, 2288 }, 2289 .num_parents = 1, 2290 .flags = CLK_SET_RATE_PARENT, 2291 .ops = &clk_branch2_ops, 2292 }, 2293 }, 2294 }; 2295 2296 static struct clk_branch gcc_ufs_phy_tx_symbol_0_clk = { 2297 .halt_reg = 0x87024, 2298 .halt_check = BRANCH_HALT_DELAY, 2299 .clkr = { 2300 .enable_reg = 0x87024, 2301 .enable_mask = BIT(0), 2302 .hw.init = &(const struct clk_init_data) { 2303 .name = "gcc_ufs_phy_tx_symbol_0_clk", 2304 .parent_hws = (const struct clk_hw*[]) { 2305 &gcc_ufs_phy_tx_symbol_0_clk_src.clkr.hw, 2306 }, 2307 .num_parents = 1, 2308 .flags = CLK_SET_RATE_PARENT, 2309 .ops = &clk_branch2_ops, 2310 }, 2311 }, 2312 }; 2313 2314 static struct clk_branch gcc_ufs_phy_unipro_core_clk = { 2315 .halt_reg = 0x87064, 2316 .halt_check = BRANCH_HALT_VOTED, 2317 .hwcg_reg = 0x87064, 2318 .hwcg_bit = 1, 2319 .clkr = { 2320 .enable_reg = 0x87064, 2321 .enable_mask = BIT(0), 2322 .hw.init = &(const struct clk_init_data) { 2323 .name = "gcc_ufs_phy_unipro_core_clk", 2324 .parent_hws = (const struct clk_hw*[]) { 2325 &gcc_ufs_phy_unipro_core_clk_src.clkr.hw, 2326 }, 2327 .num_parents = 1, 2328 .flags = CLK_SET_RATE_PARENT, 2329 .ops = &clk_branch2_ops, 2330 }, 2331 }, 2332 }; 2333 2334 static struct clk_branch gcc_ufs_phy_unipro_core_hw_ctl_clk = { 2335 .halt_reg = 0x87064, 2336 .halt_check = BRANCH_HALT_VOTED, 2337 .hwcg_reg = 0x87064, 2338 .hwcg_bit = 1, 2339 .clkr = { 2340 .enable_reg = 0x87064, 2341 .enable_mask = BIT(1), 2342 .hw.init = &(const struct clk_init_data) { 2343 .name = "gcc_ufs_phy_unipro_core_hw_ctl_clk", 2344 .parent_hws = (const struct clk_hw*[]) { 2345 &gcc_ufs_phy_unipro_core_clk_src.clkr.hw, 2346 }, 2347 .num_parents = 1, 2348 .flags = CLK_SET_RATE_PARENT, 2349 .ops = &clk_branch2_ops, 2350 }, 2351 }, 2352 }; 2353 2354 static struct clk_branch gcc_usb30_prim_master_clk = { 2355 .halt_reg = 0x49018, 2356 .halt_check = BRANCH_HALT, 2357 .clkr = { 2358 .enable_reg = 0x49018, 2359 .enable_mask = BIT(0), 2360 .hw.init = &(const struct clk_init_data) { 2361 .name = "gcc_usb30_prim_master_clk", 2362 .parent_hws = (const struct clk_hw*[]) { 2363 &gcc_usb30_prim_master_clk_src.clkr.hw, 2364 }, 2365 .num_parents = 1, 2366 .flags = CLK_SET_RATE_PARENT, 2367 .ops = &clk_branch2_ops, 2368 }, 2369 }, 2370 }; 2371 2372 static struct clk_branch gcc_usb30_prim_mock_utmi_clk = { 2373 .halt_reg = 0x49024, 2374 .halt_check = BRANCH_HALT, 2375 .clkr = { 2376 .enable_reg = 0x49024, 2377 .enable_mask = BIT(0), 2378 .hw.init = &(const struct clk_init_data) { 2379 .name = "gcc_usb30_prim_mock_utmi_clk", 2380 .parent_hws = (const struct clk_hw*[]) { 2381 &gcc_usb30_prim_mock_utmi_postdiv_clk_src.clkr.hw, 2382 }, 2383 .num_parents = 1, 2384 .flags = CLK_SET_RATE_PARENT, 2385 .ops = &clk_branch2_ops, 2386 }, 2387 }, 2388 }; 2389 2390 static struct clk_branch gcc_usb30_prim_sleep_clk = { 2391 .halt_reg = 0x49020, 2392 .halt_check = BRANCH_HALT, 2393 .clkr = { 2394 .enable_reg = 0x49020, 2395 .enable_mask = BIT(0), 2396 .hw.init = &(const struct clk_init_data) { 2397 .name = "gcc_usb30_prim_sleep_clk", 2398 .ops = &clk_branch2_ops, 2399 }, 2400 }, 2401 }; 2402 2403 static struct clk_branch gcc_usb3_0_clkref_en = { 2404 .halt_reg = 0x9c010, 2405 .halt_check = BRANCH_HALT_DELAY, 2406 .clkr = { 2407 .enable_reg = 0x9c010, 2408 .enable_mask = BIT(0), 2409 .hw.init = &(const struct clk_init_data) { 2410 .name = "gcc_usb3_0_clkref_en", 2411 .ops = &clk_branch2_ops, 2412 }, 2413 }, 2414 }; 2415 2416 static struct clk_branch gcc_usb3_prim_phy_aux_clk = { 2417 .halt_reg = 0x4905c, 2418 .halt_check = BRANCH_HALT, 2419 .clkr = { 2420 .enable_reg = 0x4905c, 2421 .enable_mask = BIT(0), 2422 .hw.init = &(const struct clk_init_data) { 2423 .name = "gcc_usb3_prim_phy_aux_clk", 2424 .parent_hws = (const struct clk_hw*[]) { 2425 &gcc_usb3_prim_phy_aux_clk_src.clkr.hw, 2426 }, 2427 .num_parents = 1, 2428 .flags = CLK_SET_RATE_PARENT, 2429 .ops = &clk_branch2_ops, 2430 }, 2431 }, 2432 }; 2433 2434 static struct clk_branch gcc_usb3_prim_phy_com_aux_clk = { 2435 .halt_reg = 0x49060, 2436 .halt_check = BRANCH_HALT, 2437 .clkr = { 2438 .enable_reg = 0x49060, 2439 .enable_mask = BIT(0), 2440 .hw.init = &(const struct clk_init_data) { 2441 .name = "gcc_usb3_prim_phy_com_aux_clk", 2442 .parent_hws = (const struct clk_hw*[]) { 2443 &gcc_usb3_prim_phy_aux_clk_src.clkr.hw, 2444 }, 2445 .num_parents = 1, 2446 .flags = CLK_SET_RATE_PARENT, 2447 .ops = &clk_branch2_ops, 2448 }, 2449 }, 2450 }; 2451 2452 static struct clk_branch gcc_usb3_prim_phy_pipe_clk = { 2453 .halt_reg = 0x49064, 2454 .halt_check = BRANCH_HALT_DELAY, 2455 .hwcg_reg = 0x49064, 2456 .hwcg_bit = 1, 2457 .clkr = { 2458 .enable_reg = 0x49064, 2459 .enable_mask = BIT(0), 2460 .hw.init = &(const struct clk_init_data) { 2461 .name = "gcc_usb3_prim_phy_pipe_clk", 2462 .parent_hws = (const struct clk_hw*[]) { 2463 &gcc_usb3_prim_phy_pipe_clk_src.clkr.hw, 2464 }, 2465 .num_parents = 1, 2466 .flags = CLK_SET_RATE_PARENT, 2467 .ops = &clk_branch2_ops, 2468 }, 2469 }, 2470 }; 2471 2472 static struct clk_branch gcc_vcodec0_axi_clk = { 2473 .halt_reg = 0x42020, 2474 .halt_check = BRANCH_HALT_SKIP, 2475 .hwcg_reg = 0x42020, 2476 .hwcg_bit = 1, 2477 .clkr = { 2478 .enable_reg = 0x42020, 2479 .enable_mask = BIT(0), 2480 .hw.init = &(const struct clk_init_data) { 2481 .name = "gcc_vcodec0_axi_clk", 2482 .ops = &clk_branch2_ops, 2483 }, 2484 }, 2485 }; 2486 2487 static struct clk_branch gcc_venus_ctl_axi_clk = { 2488 .halt_reg = 0x4201c, 2489 .halt_check = BRANCH_HALT_SKIP, 2490 .clkr = { 2491 .enable_reg = 0x4201c, 2492 .enable_mask = BIT(0), 2493 .hw.init = &(const struct clk_init_data) { 2494 .name = "gcc_venus_ctl_axi_clk", 2495 .ops = &clk_branch2_ops, 2496 }, 2497 }, 2498 }; 2499 2500 static struct clk_branch gcc_video_throttle_core_clk = { 2501 .halt_reg = 0x42014, 2502 .halt_check = BRANCH_HALT_SKIP, 2503 .hwcg_reg = 0x42014, 2504 .hwcg_bit = 1, 2505 .clkr = { 2506 .enable_reg = 0x42014, 2507 .enable_mask = BIT(0), 2508 .hw.init = &(const struct clk_init_data) { 2509 .name = "gcc_video_throttle_core_clk", 2510 .ops = &clk_branch2_ops, 2511 }, 2512 }, 2513 }; 2514 2515 static struct clk_branch gcc_video_vcodec0_sys_clk = { 2516 .halt_reg = 0xb6058, 2517 .halt_check = BRANCH_HALT_VOTED, 2518 .hwcg_reg = 0xb6058, 2519 .hwcg_bit = 1, 2520 .clkr = { 2521 .enable_reg = 0xb6058, 2522 .enable_mask = BIT(0), 2523 .hw.init = &(const struct clk_init_data) { 2524 .name = "gcc_video_vcodec0_sys_clk", 2525 .parent_hws = (const struct clk_hw*[]) { 2526 &gcc_video_venus_clk_src.clkr.hw, 2527 }, 2528 .num_parents = 1, 2529 .flags = CLK_SET_RATE_PARENT, 2530 .ops = &clk_branch2_ops, 2531 }, 2532 }, 2533 }; 2534 2535 static struct clk_branch gcc_video_venus_ctl_clk = { 2536 .halt_reg = 0xb6038, 2537 .halt_check = BRANCH_HALT, 2538 .clkr = { 2539 .enable_reg = 0xb6038, 2540 .enable_mask = BIT(0), 2541 .hw.init = &(const struct clk_init_data) { 2542 .name = "gcc_video_venus_ctl_clk", 2543 .parent_hws = (const struct clk_hw*[]) { 2544 &gcc_video_venus_clk_src.clkr.hw, 2545 }, 2546 .num_parents = 1, 2547 .flags = CLK_SET_RATE_PARENT, 2548 .ops = &clk_branch2_ops, 2549 }, 2550 }, 2551 }; 2552 2553 static struct gdsc gcc_pcie_0_gdsc = { 2554 .gdscr = 0x7b004, 2555 .en_rest_wait_val = 0x2, 2556 .en_few_wait_val = 0x2, 2557 .clk_dis_wait_val = 0xf, 2558 .pd = { 2559 .name = "gcc_pcie_0_gdsc", 2560 }, 2561 .pwrsts = PWRSTS_OFF_ON, 2562 .flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE | VOTABLE, 2563 }; 2564 2565 static struct gdsc gcc_ufs_phy_gdsc = { 2566 .gdscr = 0x87004, 2567 .en_rest_wait_val = 0x2, 2568 .en_few_wait_val = 0x2, 2569 .clk_dis_wait_val = 0xf, 2570 .pd = { 2571 .name = "gcc_ufs_phy_gdsc", 2572 }, 2573 .pwrsts = PWRSTS_OFF_ON, 2574 .flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE, 2575 }; 2576 2577 static struct gdsc gcc_usb30_prim_gdsc = { 2578 .gdscr = 0x49004, 2579 .en_rest_wait_val = 0x2, 2580 .en_few_wait_val = 0x2, 2581 .clk_dis_wait_val = 0xf, 2582 .pd = { 2583 .name = "gcc_usb30_prim_gdsc", 2584 }, 2585 .pwrsts = PWRSTS_OFF_ON, 2586 .flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE, 2587 }; 2588 2589 static struct gdsc gcc_vcodec0_gdsc = { 2590 .gdscr = 0xb6044, 2591 .en_rest_wait_val = 0x2, 2592 .en_few_wait_val = 0x2, 2593 .clk_dis_wait_val = 0xf, 2594 .pd = { 2595 .name = "gcc_vcodec0_gdsc", 2596 }, 2597 .pwrsts = PWRSTS_OFF_ON, 2598 .flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE | HW_CTRL, 2599 }; 2600 2601 static struct gdsc gcc_venus_gdsc = { 2602 .gdscr = 0xb6020, 2603 .en_rest_wait_val = 0x2, 2604 .en_few_wait_val = 0x2, 2605 .clk_dis_wait_val = 0xf, 2606 .pd = { 2607 .name = "gcc_venus_gdsc", 2608 }, 2609 .pwrsts = PWRSTS_OFF_ON, 2610 .flags = POLL_CFG_GDSCR | RETAIN_FF_ENABLE, 2611 }; 2612 2613 static struct clk_regmap *gcc_sm4450_clocks[] = { 2614 [GCC_AGGRE_NOC_PCIE_0_AXI_CLK] = &gcc_aggre_noc_pcie_0_axi_clk.clkr, 2615 [GCC_AGGRE_UFS_PHY_AXI_CLK] = &gcc_aggre_ufs_phy_axi_clk.clkr, 2616 [GCC_AGGRE_UFS_PHY_AXI_HW_CTL_CLK] = &gcc_aggre_ufs_phy_axi_hw_ctl_clk.clkr, 2617 [GCC_AGGRE_USB3_PRIM_AXI_CLK] = &gcc_aggre_usb3_prim_axi_clk.clkr, 2618 [GCC_BOOT_ROM_AHB_CLK] = &gcc_boot_rom_ahb_clk.clkr, 2619 [GCC_CAMERA_HF_AXI_CLK] = &gcc_camera_hf_axi_clk.clkr, 2620 [GCC_CAMERA_SF_AXI_CLK] = &gcc_camera_sf_axi_clk.clkr, 2621 [GCC_CFG_NOC_PCIE_ANOC_AHB_CLK] = &gcc_cfg_noc_pcie_anoc_ahb_clk.clkr, 2622 [GCC_CFG_NOC_USB3_PRIM_AXI_CLK] = &gcc_cfg_noc_usb3_prim_axi_clk.clkr, 2623 [GCC_DDRSS_GPU_AXI_CLK] = &gcc_ddrss_gpu_axi_clk.clkr, 2624 [GCC_DDRSS_PCIE_SF_TBU_CLK] = &gcc_ddrss_pcie_sf_tbu_clk.clkr, 2625 [GCC_DISP_HF_AXI_CLK] = &gcc_disp_hf_axi_clk.clkr, 2626 [GCC_EUSB3_0_CLKREF_EN] = &gcc_eusb3_0_clkref_en.clkr, 2627 [GCC_GP1_CLK] = &gcc_gp1_clk.clkr, 2628 [GCC_GP1_CLK_SRC] = &gcc_gp1_clk_src.clkr, 2629 [GCC_GP2_CLK] = &gcc_gp2_clk.clkr, 2630 [GCC_GP2_CLK_SRC] = &gcc_gp2_clk_src.clkr, 2631 [GCC_GP3_CLK] = &gcc_gp3_clk.clkr, 2632 [GCC_GP3_CLK_SRC] = &gcc_gp3_clk_src.clkr, 2633 [GCC_GPLL0] = &gcc_gpll0.clkr, 2634 [GCC_GPLL0_OUT_EVEN] = &gcc_gpll0_out_even.clkr, 2635 [GCC_GPLL0_OUT_ODD] = &gcc_gpll0_out_odd.clkr, 2636 [GCC_GPLL1] = &gcc_gpll1.clkr, 2637 [GCC_GPLL3] = &gcc_gpll3.clkr, 2638 [GCC_GPLL4] = &gcc_gpll4.clkr, 2639 [GCC_GPLL9] = &gcc_gpll9.clkr, 2640 [GCC_GPLL10] = &gcc_gpll10.clkr, 2641 [GCC_GPU_GPLL0_CLK_SRC] = &gcc_gpu_gpll0_clk_src.clkr, 2642 [GCC_GPU_GPLL0_DIV_CLK_SRC] = &gcc_gpu_gpll0_div_clk_src.clkr, 2643 [GCC_GPU_MEMNOC_GFX_CLK] = &gcc_gpu_memnoc_gfx_clk.clkr, 2644 [GCC_GPU_SNOC_DVM_GFX_CLK] = &gcc_gpu_snoc_dvm_gfx_clk.clkr, 2645 [GCC_HLOS1_VOTE_AGGRE_NOC_MMU_AUDIO_TBU_CLK] = 2646 &gcc_hlos1_vote_aggre_noc_mmu_audio_tbu_clk.clkr, 2647 [GCC_HLOS1_VOTE_AGGRE_NOC_MMU_PCIE_TBU_CLK] = 2648 &gcc_hlos1_vote_aggre_noc_mmu_pcie_tbu_clk.clkr, 2649 [GCC_HLOS1_VOTE_AGGRE_NOC_MMU_TBU1_CLK] = &gcc_hlos1_vote_aggre_noc_mmu_tbu1_clk.clkr, 2650 [GCC_HLOS1_VOTE_AGGRE_NOC_MMU_TBU2_CLK] = &gcc_hlos1_vote_aggre_noc_mmu_tbu2_clk.clkr, 2651 [GCC_HLOS1_VOTE_MMNOC_MMU_TBU_HF0_CLK] = &gcc_hlos1_vote_mmnoc_mmu_tbu_hf0_clk.clkr, 2652 [GCC_HLOS1_VOTE_MMNOC_MMU_TBU_HF1_CLK] = &gcc_hlos1_vote_mmnoc_mmu_tbu_hf1_clk.clkr, 2653 [GCC_HLOS1_VOTE_MMNOC_MMU_TBU_SF0_CLK] = &gcc_hlos1_vote_mmnoc_mmu_tbu_sf0_clk.clkr, 2654 [GCC_HLOS1_VOTE_MMU_TCU_CLK] = &gcc_hlos1_vote_mmu_tcu_clk.clkr, 2655 [GCC_PCIE_0_AUX_CLK] = &gcc_pcie_0_aux_clk.clkr, 2656 [GCC_PCIE_0_AUX_CLK_SRC] = &gcc_pcie_0_aux_clk_src.clkr, 2657 [GCC_PCIE_0_CFG_AHB_CLK] = &gcc_pcie_0_cfg_ahb_clk.clkr, 2658 [GCC_PCIE_0_CLKREF_EN] = &gcc_pcie_0_clkref_en.clkr, 2659 [GCC_PCIE_0_MSTR_AXI_CLK] = &gcc_pcie_0_mstr_axi_clk.clkr, 2660 [GCC_PCIE_0_PHY_RCHNG_CLK] = &gcc_pcie_0_phy_rchng_clk.clkr, 2661 [GCC_PCIE_0_PHY_RCHNG_CLK_SRC] = &gcc_pcie_0_phy_rchng_clk_src.clkr, 2662 [GCC_PCIE_0_PIPE_CLK] = &gcc_pcie_0_pipe_clk.clkr, 2663 [GCC_PCIE_0_PIPE_CLK_SRC] = &gcc_pcie_0_pipe_clk_src.clkr, 2664 [GCC_PCIE_0_PIPE_DIV2_CLK] = &gcc_pcie_0_pipe_div2_clk.clkr, 2665 [GCC_PCIE_0_PIPE_DIV2_CLK_SRC] = &gcc_pcie_0_pipe_div2_clk_src.clkr, 2666 [GCC_PCIE_0_SLV_AXI_CLK] = &gcc_pcie_0_slv_axi_clk.clkr, 2667 [GCC_PCIE_0_SLV_Q2A_AXI_CLK] = &gcc_pcie_0_slv_q2a_axi_clk.clkr, 2668 [GCC_PDM2_CLK] = &gcc_pdm2_clk.clkr, 2669 [GCC_PDM2_CLK_SRC] = &gcc_pdm2_clk_src.clkr, 2670 [GCC_PDM_AHB_CLK] = &gcc_pdm_ahb_clk.clkr, 2671 [GCC_PDM_XO4_CLK] = &gcc_pdm_xo4_clk.clkr, 2672 [GCC_QMIP_CAMERA_NRT_AHB_CLK] = &gcc_qmip_camera_nrt_ahb_clk.clkr, 2673 [GCC_QMIP_CAMERA_RT_AHB_CLK] = &gcc_qmip_camera_rt_ahb_clk.clkr, 2674 [GCC_QMIP_DISP_AHB_CLK] = &gcc_qmip_disp_ahb_clk.clkr, 2675 [GCC_QMIP_GPU_AHB_CLK] = &gcc_qmip_gpu_ahb_clk.clkr, 2676 [GCC_QMIP_PCIE_AHB_CLK] = &gcc_qmip_pcie_ahb_clk.clkr, 2677 [GCC_QMIP_VIDEO_VCODEC_AHB_CLK] = &gcc_qmip_video_vcodec_ahb_clk.clkr, 2678 [GCC_QUPV3_WRAP0_CORE_2X_CLK] = &gcc_qupv3_wrap0_core_2x_clk.clkr, 2679 [GCC_QUPV3_WRAP0_CORE_CLK] = &gcc_qupv3_wrap0_core_clk.clkr, 2680 [GCC_QUPV3_WRAP0_S0_CLK] = &gcc_qupv3_wrap0_s0_clk.clkr, 2681 [GCC_QUPV3_WRAP0_S0_CLK_SRC] = &gcc_qupv3_wrap0_s0_clk_src.clkr, 2682 [GCC_QUPV3_WRAP0_S1_CLK] = &gcc_qupv3_wrap0_s1_clk.clkr, 2683 [GCC_QUPV3_WRAP0_S1_CLK_SRC] = &gcc_qupv3_wrap0_s1_clk_src.clkr, 2684 [GCC_QUPV3_WRAP0_S2_CLK] = &gcc_qupv3_wrap0_s2_clk.clkr, 2685 [GCC_QUPV3_WRAP0_S2_CLK_SRC] = &gcc_qupv3_wrap0_s2_clk_src.clkr, 2686 [GCC_QUPV3_WRAP0_S3_CLK] = &gcc_qupv3_wrap0_s3_clk.clkr, 2687 [GCC_QUPV3_WRAP0_S3_CLK_SRC] = &gcc_qupv3_wrap0_s3_clk_src.clkr, 2688 [GCC_QUPV3_WRAP0_S4_CLK] = &gcc_qupv3_wrap0_s4_clk.clkr, 2689 [GCC_QUPV3_WRAP0_S4_CLK_SRC] = &gcc_qupv3_wrap0_s4_clk_src.clkr, 2690 [GCC_QUPV3_WRAP1_CORE_2X_CLK] = &gcc_qupv3_wrap1_core_2x_clk.clkr, 2691 [GCC_QUPV3_WRAP1_CORE_CLK] = &gcc_qupv3_wrap1_core_clk.clkr, 2692 [GCC_QUPV3_WRAP1_S0_CLK] = &gcc_qupv3_wrap1_s0_clk.clkr, 2693 [GCC_QUPV3_WRAP1_S0_CLK_SRC] = &gcc_qupv3_wrap1_s0_clk_src.clkr, 2694 [GCC_QUPV3_WRAP1_S1_CLK] = &gcc_qupv3_wrap1_s1_clk.clkr, 2695 [GCC_QUPV3_WRAP1_S1_CLK_SRC] = &gcc_qupv3_wrap1_s1_clk_src.clkr, 2696 [GCC_QUPV3_WRAP1_S2_CLK] = &gcc_qupv3_wrap1_s2_clk.clkr, 2697 [GCC_QUPV3_WRAP1_S2_CLK_SRC] = &gcc_qupv3_wrap1_s2_clk_src.clkr, 2698 [GCC_QUPV3_WRAP1_S3_CLK] = &gcc_qupv3_wrap1_s3_clk.clkr, 2699 [GCC_QUPV3_WRAP1_S3_CLK_SRC] = &gcc_qupv3_wrap1_s3_clk_src.clkr, 2700 [GCC_QUPV3_WRAP1_S4_CLK] = &gcc_qupv3_wrap1_s4_clk.clkr, 2701 [GCC_QUPV3_WRAP1_S4_CLK_SRC] = &gcc_qupv3_wrap1_s4_clk_src.clkr, 2702 [GCC_QUPV3_WRAP_0_M_AHB_CLK] = &gcc_qupv3_wrap_0_m_ahb_clk.clkr, 2703 [GCC_QUPV3_WRAP_0_S_AHB_CLK] = &gcc_qupv3_wrap_0_s_ahb_clk.clkr, 2704 [GCC_QUPV3_WRAP_1_M_AHB_CLK] = &gcc_qupv3_wrap_1_m_ahb_clk.clkr, 2705 [GCC_QUPV3_WRAP_1_S_AHB_CLK] = &gcc_qupv3_wrap_1_s_ahb_clk.clkr, 2706 [GCC_SDCC1_AHB_CLK] = &gcc_sdcc1_ahb_clk.clkr, 2707 [GCC_SDCC1_APPS_CLK] = &gcc_sdcc1_apps_clk.clkr, 2708 [GCC_SDCC1_APPS_CLK_SRC] = &gcc_sdcc1_apps_clk_src.clkr, 2709 [GCC_SDCC1_ICE_CORE_CLK] = &gcc_sdcc1_ice_core_clk.clkr, 2710 [GCC_SDCC1_ICE_CORE_CLK_SRC] = &gcc_sdcc1_ice_core_clk_src.clkr, 2711 [GCC_SDCC2_AHB_CLK] = &gcc_sdcc2_ahb_clk.clkr, 2712 [GCC_SDCC2_APPS_CLK] = &gcc_sdcc2_apps_clk.clkr, 2713 [GCC_SDCC2_APPS_CLK_SRC] = &gcc_sdcc2_apps_clk_src.clkr, 2714 [GCC_UFS_0_CLKREF_EN] = &gcc_ufs_0_clkref_en.clkr, 2715 [GCC_UFS_PAD_CLKREF_EN] = &gcc_ufs_pad_clkref_en.clkr, 2716 [GCC_UFS_PHY_AHB_CLK] = &gcc_ufs_phy_ahb_clk.clkr, 2717 [GCC_UFS_PHY_AXI_CLK] = &gcc_ufs_phy_axi_clk.clkr, 2718 [GCC_UFS_PHY_AXI_CLK_SRC] = &gcc_ufs_phy_axi_clk_src.clkr, 2719 [GCC_UFS_PHY_AXI_HW_CTL_CLK] = &gcc_ufs_phy_axi_hw_ctl_clk.clkr, 2720 [GCC_UFS_PHY_ICE_CORE_CLK] = &gcc_ufs_phy_ice_core_clk.clkr, 2721 [GCC_UFS_PHY_ICE_CORE_CLK_SRC] = &gcc_ufs_phy_ice_core_clk_src.clkr, 2722 [GCC_UFS_PHY_ICE_CORE_HW_CTL_CLK] = &gcc_ufs_phy_ice_core_hw_ctl_clk.clkr, 2723 [GCC_UFS_PHY_PHY_AUX_CLK] = &gcc_ufs_phy_phy_aux_clk.clkr, 2724 [GCC_UFS_PHY_PHY_AUX_CLK_SRC] = &gcc_ufs_phy_phy_aux_clk_src.clkr, 2725 [GCC_UFS_PHY_PHY_AUX_HW_CTL_CLK] = &gcc_ufs_phy_phy_aux_hw_ctl_clk.clkr, 2726 [GCC_UFS_PHY_RX_SYMBOL_0_CLK] = &gcc_ufs_phy_rx_symbol_0_clk.clkr, 2727 [GCC_UFS_PHY_RX_SYMBOL_0_CLK_SRC] = &gcc_ufs_phy_rx_symbol_0_clk_src.clkr, 2728 [GCC_UFS_PHY_RX_SYMBOL_1_CLK] = &gcc_ufs_phy_rx_symbol_1_clk.clkr, 2729 [GCC_UFS_PHY_RX_SYMBOL_1_CLK_SRC] = &gcc_ufs_phy_rx_symbol_1_clk_src.clkr, 2730 [GCC_UFS_PHY_TX_SYMBOL_0_CLK] = &gcc_ufs_phy_tx_symbol_0_clk.clkr, 2731 [GCC_UFS_PHY_TX_SYMBOL_0_CLK_SRC] = &gcc_ufs_phy_tx_symbol_0_clk_src.clkr, 2732 [GCC_UFS_PHY_UNIPRO_CORE_CLK] = &gcc_ufs_phy_unipro_core_clk.clkr, 2733 [GCC_UFS_PHY_UNIPRO_CORE_CLK_SRC] = &gcc_ufs_phy_unipro_core_clk_src.clkr, 2734 [GCC_UFS_PHY_UNIPRO_CORE_HW_CTL_CLK] = &gcc_ufs_phy_unipro_core_hw_ctl_clk.clkr, 2735 [GCC_USB30_PRIM_MASTER_CLK] = &gcc_usb30_prim_master_clk.clkr, 2736 [GCC_USB30_PRIM_MASTER_CLK_SRC] = &gcc_usb30_prim_master_clk_src.clkr, 2737 [GCC_USB30_PRIM_MOCK_UTMI_CLK] = &gcc_usb30_prim_mock_utmi_clk.clkr, 2738 [GCC_USB30_PRIM_MOCK_UTMI_CLK_SRC] = &gcc_usb30_prim_mock_utmi_clk_src.clkr, 2739 [GCC_USB30_PRIM_MOCK_UTMI_POSTDIV_CLK_SRC] = &gcc_usb30_prim_mock_utmi_postdiv_clk_src.clkr, 2740 [GCC_USB30_PRIM_SLEEP_CLK] = &gcc_usb30_prim_sleep_clk.clkr, 2741 [GCC_USB3_0_CLKREF_EN] = &gcc_usb3_0_clkref_en.clkr, 2742 [GCC_USB3_PRIM_PHY_AUX_CLK] = &gcc_usb3_prim_phy_aux_clk.clkr, 2743 [GCC_USB3_PRIM_PHY_AUX_CLK_SRC] = &gcc_usb3_prim_phy_aux_clk_src.clkr, 2744 [GCC_USB3_PRIM_PHY_COM_AUX_CLK] = &gcc_usb3_prim_phy_com_aux_clk.clkr, 2745 [GCC_USB3_PRIM_PHY_PIPE_CLK] = &gcc_usb3_prim_phy_pipe_clk.clkr, 2746 [GCC_USB3_PRIM_PHY_PIPE_CLK_SRC] = &gcc_usb3_prim_phy_pipe_clk_src.clkr, 2747 [GCC_VCODEC0_AXI_CLK] = &gcc_vcodec0_axi_clk.clkr, 2748 [GCC_VENUS_CTL_AXI_CLK] = &gcc_venus_ctl_axi_clk.clkr, 2749 [GCC_VIDEO_THROTTLE_CORE_CLK] = &gcc_video_throttle_core_clk.clkr, 2750 [GCC_VIDEO_VCODEC0_SYS_CLK] = &gcc_video_vcodec0_sys_clk.clkr, 2751 [GCC_VIDEO_VENUS_CLK_SRC] = &gcc_video_venus_clk_src.clkr, 2752 [GCC_VIDEO_VENUS_CTL_CLK] = &gcc_video_venus_ctl_clk.clkr, 2753 }; 2754 2755 static struct gdsc *gcc_sm4450_gdscs[] = { 2756 [GCC_PCIE_0_GDSC] = &gcc_pcie_0_gdsc, 2757 [GCC_UFS_PHY_GDSC] = &gcc_ufs_phy_gdsc, 2758 [GCC_USB30_PRIM_GDSC] = &gcc_usb30_prim_gdsc, 2759 [GCC_VCODEC0_GDSC] = &gcc_vcodec0_gdsc, 2760 [GCC_VENUS_GDSC] = &gcc_venus_gdsc, 2761 }; 2762 2763 static const struct qcom_reset_map gcc_sm4450_resets[] = { 2764 [GCC_CAMERA_BCR] = { 0x36000 }, 2765 [GCC_DISPLAY_BCR] = { 0x37000 }, 2766 [GCC_GPU_BCR] = { 0x81000 }, 2767 [GCC_PCIE_0_BCR] = { 0x7b000 }, 2768 [GCC_PCIE_0_LINK_DOWN_BCR] = { 0x7c014 }, 2769 [GCC_PCIE_0_NOCSR_COM_PHY_BCR] = { 0x7c020 }, 2770 [GCC_PCIE_0_PHY_BCR] = { 0x7c01c }, 2771 [GCC_PCIE_0_PHY_NOCSR_COM_PHY_BCR] = { 0x7c028 }, 2772 [GCC_PCIE_PHY_BCR] = { 0x7f000 }, 2773 [GCC_PCIE_PHY_CFG_AHB_BCR] = { 0x7f00c }, 2774 [GCC_PCIE_PHY_COM_BCR] = { 0x7f010 }, 2775 [GCC_PDM_BCR] = { 0x43000 }, 2776 [GCC_QUPV3_WRAPPER_0_BCR] = { 0x27000 }, 2777 [GCC_QUPV3_WRAPPER_1_BCR] = { 0x28000 }, 2778 [GCC_QUSB2PHY_PRIM_BCR] = { 0x22000 }, 2779 [GCC_QUSB2PHY_SEC_BCR] = { 0x22004 }, 2780 [GCC_SDCC1_BCR] = { 0xb3000 }, 2781 [GCC_SDCC2_BCR] = { 0x24000 }, 2782 [GCC_UFS_PHY_BCR] = { 0x87000 }, 2783 [GCC_USB30_PRIM_BCR] = { 0x49000 }, 2784 [GCC_USB3_DP_PHY_PRIM_BCR] = { 0x60008 }, 2785 [GCC_USB3_DP_PHY_SEC_BCR] = { 0x60014 }, 2786 [GCC_USB3_PHY_PRIM_BCR] = { 0x60000 }, 2787 [GCC_USB3_PHY_SEC_BCR] = { 0x6000c }, 2788 [GCC_USB3PHY_PHY_PRIM_BCR] = { 0x60004 }, 2789 [GCC_USB3PHY_PHY_SEC_BCR] = { 0x60010 }, 2790 [GCC_VCODEC0_BCR] = { 0xb6040 }, 2791 [GCC_VENUS_BCR] = { 0xb601c }, 2792 [GCC_VIDEO_BCR] = { 0x42000 }, 2793 [GCC_VIDEO_VENUS_BCR] = { 0xb6000 }, 2794 [GCC_VENUS_CTL_AXI_CLK_ARES] = { .reg = 0x4201c, .bit = 2, .udelay = 400 }, 2795 [GCC_VIDEO_VENUS_CTL_CLK_ARES] = { .reg = 0xb6038, .bit = 2, .udelay = 400 }, 2796 }; 2797 2798 static const struct clk_rcg_dfs_data gcc_dfs_clocks[] = { 2799 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s0_clk_src), 2800 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s1_clk_src), 2801 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s2_clk_src), 2802 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s3_clk_src), 2803 DEFINE_RCG_DFS(gcc_qupv3_wrap0_s4_clk_src), 2804 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s0_clk_src), 2805 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s1_clk_src), 2806 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s2_clk_src), 2807 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s3_clk_src), 2808 DEFINE_RCG_DFS(gcc_qupv3_wrap1_s4_clk_src), 2809 }; 2810 2811 static const struct regmap_config gcc_sm4450_regmap_config = { 2812 .reg_bits = 32, 2813 .reg_stride = 4, 2814 .val_bits = 32, 2815 .max_register = 0x1f41f0, 2816 .fast_io = true, 2817 }; 2818 2819 static const struct qcom_cc_desc gcc_sm4450_desc = { 2820 .config = &gcc_sm4450_regmap_config, 2821 .clks = gcc_sm4450_clocks, 2822 .num_clks = ARRAY_SIZE(gcc_sm4450_clocks), 2823 .resets = gcc_sm4450_resets, 2824 .num_resets = ARRAY_SIZE(gcc_sm4450_resets), 2825 .gdscs = gcc_sm4450_gdscs, 2826 .num_gdscs = ARRAY_SIZE(gcc_sm4450_gdscs), 2827 }; 2828 2829 static const struct of_device_id gcc_sm4450_match_table[] = { 2830 { .compatible = "qcom,sm4450-gcc" }, 2831 { } 2832 }; 2833 MODULE_DEVICE_TABLE(of, gcc_sm4450_match_table); 2834 2835 static int gcc_sm4450_probe(struct platform_device *pdev) 2836 { 2837 struct regmap *regmap; 2838 int ret; 2839 2840 regmap = qcom_cc_map(pdev, &gcc_sm4450_desc); 2841 if (IS_ERR(regmap)) 2842 return PTR_ERR(regmap); 2843 2844 clk_lucid_evo_pll_configure(&gcc_gpll3, regmap, &gcc_gpll3_config); 2845 ret = qcom_cc_register_rcg_dfs(regmap, gcc_dfs_clocks, 2846 ARRAY_SIZE(gcc_dfs_clocks)); 2847 if (ret) 2848 return ret; 2849 2850 qcom_branch_set_force_mem_core(regmap, gcc_ufs_phy_ice_core_clk, true); 2851 2852 /* Keep some clocks always-on */ 2853 qcom_branch_set_clk_en(regmap, 0x36004); /* GCC_CAMERA_AHB_CLK */ 2854 qcom_branch_set_clk_en(regmap, 0x36018); /* GCC_CAMERA_SLEEP_CLK */ 2855 qcom_branch_set_clk_en(regmap, 0x3601c); /* GCC_CAMERA_XO_CLK */ 2856 qcom_branch_set_clk_en(regmap, 0x37004); /* GCC_DISP_AHB_CLK */ 2857 qcom_branch_set_clk_en(regmap, 0x37014); /* GCC_DISP_XO_CLK */ 2858 qcom_branch_set_clk_en(regmap, 0x81004); /* GCC_GPU_CFG_AHB_CLK */ 2859 qcom_branch_set_clk_en(regmap, 0x42004); /* GCC_VIDEO_AHB_CLK */ 2860 qcom_branch_set_clk_en(regmap, 0x42018); /* GCC_VIDEO_XO_CLK */ 2861 2862 regmap_update_bits(regmap, 0x4201c, BIT(21), BIT(21)); 2863 2864 return qcom_cc_really_probe(&pdev->dev, &gcc_sm4450_desc, regmap); 2865 } 2866 2867 static struct platform_driver gcc_sm4450_driver = { 2868 .probe = gcc_sm4450_probe, 2869 .driver = { 2870 .name = "gcc-sm4450", 2871 .of_match_table = gcc_sm4450_match_table, 2872 }, 2873 }; 2874 2875 static int __init gcc_sm4450_init(void) 2876 { 2877 return platform_driver_register(&gcc_sm4450_driver); 2878 } 2879 subsys_initcall(gcc_sm4450_init); 2880 2881 static void __exit gcc_sm4450_exit(void) 2882 { 2883 platform_driver_unregister(&gcc_sm4450_driver); 2884 } 2885 module_exit(gcc_sm4450_exit); 2886 2887 MODULE_DESCRIPTION("QTI GCC SM4450 Driver"); 2888 MODULE_LICENSE("GPL"); 2889