1 // SPDX-License-Identifier: GPL-2.0 2 /* 3 * Qualcomm Global Clock Controller driver for MSM8956/76 4 * 5 * Copyright (c) 2016-2021, AngeloGioacchino Del Regno 6 * <angelogioacchino.delregno@somainline.org> 7 * 8 * Driver cleanup and modernization 9 * Copyright (c) 2021, Konrad Dybcio <konrad.dybcio@somainline.org> 10 * Marijn Suijten <marijn.suijten@somainline.org> 11 * 12 */ 13 14 #include <linux/clk-provider.h> 15 #include <linux/err.h> 16 #include <linux/kernel.h> 17 #include <linux/module.h> 18 #include <linux/of.h> 19 #include <linux/platform_device.h> 20 #include <linux/regmap.h> 21 22 #include <dt-bindings/clock/qcom,gcc-msm8976.h> 23 24 #include "clk-pll.h" 25 #include "clk-branch.h" 26 #include "clk-rcg.h" 27 #include "common.h" 28 #include "gdsc.h" 29 #include "reset.h" 30 31 enum { 32 P_GPLL0_OUT_MAIN, 33 P_GPLL0_AUX, 34 P_GPLL0_OUT, 35 P_GPLL0_OUT_M, 36 P_GPLL0_OUT_MDP, 37 P_GPLL2_AUX, 38 P_GPLL2_OUT, 39 P_GPLL4_OUT_MAIN, 40 P_GPLL4_AUX, 41 P_GPLL4_OUT, 42 P_GPLL4_GFX3D, 43 P_GPLL6_OUT_MAIN, 44 P_GPLL6_AUX, 45 P_GPLL6_OUT, 46 P_GPLL6_GFX3D, 47 P_DSI0PLL, 48 P_DSI1PLL, 49 P_DSI0PLL_BYTE, 50 P_DSI1PLL_BYTE, 51 P_XO_A, 52 P_XO, 53 }; 54 55 static struct clk_pll gpll0 = { 56 .l_reg = 0x21004, 57 .m_reg = 0x21008, 58 .n_reg = 0x2100c, 59 .config_reg = 0x21014, 60 .mode_reg = 0x21000, 61 .status_reg = 0x2101c, 62 .status_bit = 17, 63 .clkr.hw.init = &(struct clk_init_data){ 64 .name = "gpll0", 65 .parent_data = &(const struct clk_parent_data){ 66 .fw_name = "xo", 67 }, 68 .num_parents = 1, 69 .ops = &clk_pll_ops, 70 }, 71 }; 72 73 static struct clk_regmap gpll0_vote = { 74 .enable_reg = 0x45000, 75 .enable_mask = BIT(0), 76 .hw.init = &(struct clk_init_data){ 77 .name = "gpll0_vote", 78 .parent_hws = (const struct clk_hw *[]) { 79 &gpll0.clkr.hw, 80 }, 81 .num_parents = 1, 82 /* This clock is required for other ones to function. */ 83 .flags = CLK_IS_CRITICAL, 84 .ops = &clk_pll_vote_ops, 85 }, 86 }; 87 88 static struct clk_pll gpll2 = { 89 .l_reg = 0x4a004, 90 .m_reg = 0x4a008, 91 .n_reg = 0x4a00c, 92 .config_reg = 0x4a014, 93 .mode_reg = 0x4a000, 94 .status_reg = 0x4a01c, 95 .status_bit = 17, 96 .clkr.hw.init = &(struct clk_init_data){ 97 .name = "gpll2", 98 .parent_data = &(const struct clk_parent_data){ 99 .fw_name = "xo", 100 }, 101 .num_parents = 1, 102 .ops = &clk_pll_ops, 103 }, 104 }; 105 106 static struct clk_regmap gpll2_vote = { 107 .enable_reg = 0x45000, 108 .enable_mask = BIT(2), 109 .hw.init = &(struct clk_init_data){ 110 .name = "gpll2_vote", 111 .parent_hws = (const struct clk_hw *[]) { 112 &gpll2.clkr.hw, 113 }, 114 .num_parents = 1, 115 .ops = &clk_pll_vote_ops, 116 }, 117 }; 118 119 static const struct pll_freq_tbl gpll3_freq_tbl[] = { 120 { 1100000000, 57, 7, 24, 0 }, 121 { } 122 }; 123 124 static struct clk_pll gpll3 = { 125 .l_reg = 0x22004, 126 .m_reg = 0x22008, 127 .n_reg = 0x2200c, 128 .config_reg = 0x22010, 129 .mode_reg = 0x22000, 130 .status_reg = 0x22024, 131 .status_bit = 17, 132 .freq_tbl = gpll3_freq_tbl, 133 .clkr.hw.init = &(struct clk_init_data) { 134 .name = "gpll3", 135 .parent_data = &(const struct clk_parent_data){ 136 .fw_name = "xo", 137 }, 138 .num_parents = 1, 139 .ops = &clk_pll_ops, 140 }, 141 }; 142 143 static struct clk_regmap gpll3_vote = { 144 .enable_reg = 0x45000, 145 .enable_mask = BIT(4), 146 .hw.init = &(struct clk_init_data){ 147 .name = "gpll3_vote", 148 .parent_hws = (const struct clk_hw *[]) { 149 &gpll3.clkr.hw, 150 }, 151 .num_parents = 1, 152 .ops = &clk_pll_vote_ops, 153 }, 154 }; 155 156 /* GPLL3 at 1100MHz, main output enabled. */ 157 static const struct pll_config gpll3_config = { 158 .l = 57, 159 .m = 7, 160 .n = 24, 161 .vco_val = 0x0, 162 .vco_mask = 0x3 << 20, 163 .pre_div_val = 0x0, 164 .pre_div_mask = 0x7 << 12, 165 .post_div_val = 0x0, 166 .post_div_mask = 0x3 << 8, 167 .mn_ena_mask = BIT(24), 168 .main_output_mask = BIT(0), 169 .aux_output_mask = BIT(1), 170 }; 171 172 static struct clk_pll gpll4 = { 173 .l_reg = 0x24004, 174 .m_reg = 0x24008, 175 .n_reg = 0x2400c, 176 .config_reg = 0x24018, 177 .mode_reg = 0x24000, 178 .status_reg = 0x24024, 179 .status_bit = 17, 180 .clkr.hw.init = &(struct clk_init_data){ 181 .name = "gpll4", 182 .parent_data = &(const struct clk_parent_data){ 183 .fw_name = "xo", 184 }, 185 .num_parents = 1, 186 .ops = &clk_pll_ops, 187 }, 188 }; 189 190 static struct clk_regmap gpll4_vote = { 191 .enable_reg = 0x45000, 192 .enable_mask = BIT(5), 193 .hw.init = &(struct clk_init_data){ 194 .name = "gpll4_vote", 195 .parent_hws = (const struct clk_hw *[]) { 196 &gpll4.clkr.hw, 197 }, 198 .num_parents = 1, 199 .ops = &clk_pll_vote_ops, 200 }, 201 }; 202 203 static struct clk_pll gpll6 = { 204 .mode_reg = 0x37000, 205 .l_reg = 0x37004, 206 .m_reg = 0x37008, 207 .n_reg = 0x3700c, 208 .config_reg = 0x37014, 209 .status_reg = 0x3701c, 210 .status_bit = 17, 211 .clkr.hw.init = &(struct clk_init_data){ 212 .name = "gpll6", 213 .parent_data = &(const struct clk_parent_data){ 214 .fw_name = "xo", 215 }, 216 .num_parents = 1, 217 .ops = &clk_pll_ops, 218 }, 219 }; 220 221 static struct clk_regmap gpll6_vote = { 222 .enable_reg = 0x45000, 223 .enable_mask = BIT(7), 224 .hw.init = &(struct clk_init_data){ 225 .name = "gpll6_vote", 226 .parent_hws = (const struct clk_hw *[]) { 227 &gpll6.clkr.hw, 228 }, 229 .num_parents = 1, 230 .ops = &clk_pll_vote_ops, 231 }, 232 }; 233 234 static const struct parent_map gcc_parent_map_1[] = { 235 { P_XO, 0 }, 236 { P_GPLL0_OUT_MAIN, 1 }, 237 { P_GPLL4_OUT, 2 }, 238 }; 239 240 static const struct clk_parent_data gcc_parent_data_1[] = { 241 { .fw_name = "xo" }, 242 { .hw = &gpll0_vote.hw }, 243 { .hw = &gpll4_vote.hw }, 244 }; 245 246 static const struct parent_map gcc_parent_map_v1_1[] = { 247 { P_XO, 0 }, 248 { P_GPLL0_OUT_MAIN, 1 }, 249 { P_GPLL2_OUT, 4 }, 250 }; 251 252 static const struct clk_parent_data gcc_parent_data_v1_1[] = { 253 { .fw_name = "xo" }, 254 { .hw = &gpll0_vote.hw }, 255 { .hw = &gpll2_vote.hw }, 256 }; 257 258 static const struct parent_map gcc_parent_map_2[] = { 259 { P_XO, 0 }, 260 { P_GPLL0_OUT_MAIN, 1 }, 261 { P_GPLL2_AUX, 3 }, 262 { P_GPLL4_OUT, 2 }, 263 }; 264 265 static const struct clk_parent_data gcc_parent_data_2[] = { 266 { .fw_name = "xo" }, 267 { .hw = &gpll0_vote.hw }, 268 { .hw = &gpll2_vote.hw }, 269 { .hw = &gpll4_vote.hw }, 270 }; 271 272 static const struct parent_map gcc_parent_map_3[] = { 273 { P_XO, 0 }, 274 { P_GPLL0_OUT_MAIN, 1 }, 275 { P_GPLL2_AUX, 3 }, 276 { P_GPLL6_AUX, 2 }, 277 }; 278 279 static const struct clk_parent_data gcc_parent_data_3[] = { 280 { .fw_name = "xo" }, 281 { .hw = &gpll0_vote.hw }, 282 { .hw = &gpll2_vote.hw }, 283 { .hw = &gpll6_vote.hw }, 284 }; 285 286 static const struct parent_map gcc_parent_map_4[] = { 287 { P_XO, 0 }, 288 { P_GPLL0_OUT_MAIN, 1 }, 289 }; 290 291 static const struct parent_map gcc_parent_map_4_fs[] = { 292 { P_XO, 0 }, 293 { P_GPLL0_OUT, 2 }, 294 }; 295 296 static const struct parent_map gcc_parent_map_5[] = { 297 { P_XO, 0 }, 298 { P_GPLL4_OUT, 2 }, 299 { P_GPLL6_OUT_MAIN, 1 }, 300 }; 301 302 static const struct clk_parent_data gcc_parent_data_5[] = { 303 { .fw_name = "xo" }, 304 { .hw = &gpll4_vote.hw }, 305 { .hw = &gpll6_vote.hw }, 306 }; 307 308 static const struct parent_map gcc_parent_map_6[] = { 309 { P_XO, 0 }, 310 { P_GPLL0_OUT_MAIN, 1 }, 311 { P_GPLL4_OUT_MAIN, 5 }, 312 }; 313 314 static const struct clk_parent_data gcc_parent_data_6[] = { 315 { .fw_name = "xo" }, 316 { .hw = &gpll0_vote.hw }, 317 { .hw = &gpll4_vote.hw }, 318 }; 319 320 static const struct parent_map gcc_parent_map_7_mdp[] = { 321 { P_XO, 0 }, 322 { P_GPLL6_OUT, 3 }, 323 { P_GPLL0_OUT_MDP, 6 }, 324 }; 325 326 static const struct clk_parent_data gcc_parent_data_7_mdp[] = { 327 { .fw_name = "xo" }, 328 { .hw = &gpll6_vote.hw }, 329 { .hw = &gpll0_vote.hw }, 330 }; 331 332 static const struct parent_map gcc_parent_map_7[] = { 333 { P_GPLL0_OUT_MAIN, 1 }, 334 { P_GPLL6_OUT, 3 }, 335 }; 336 337 static const struct clk_hw * gcc_parent_hws_7[] = { 338 &gpll0_vote.hw, 339 &gpll6_vote.hw, 340 }; 341 342 static const struct parent_map gcc_parent_map_8[] = { 343 { P_XO, 0 }, 344 { P_GPLL0_OUT_MAIN, 1 }, 345 }; 346 347 static const struct clk_parent_data gcc_parent_data_4_8[] = { 348 { .fw_name = "xo" }, 349 { .hw = &gpll0_vote.hw }, 350 }; 351 352 static const struct parent_map gcc_parent_map_8_a[] = { 353 { P_XO_A, 0 }, 354 { P_GPLL0_OUT_MAIN, 1 }, 355 }; 356 357 static const struct clk_parent_data gcc_parent_data_8_a[] = { 358 { .fw_name = "xo_a" }, 359 { .hw = &gpll0_vote.hw }, 360 }; 361 362 static const struct parent_map gcc_parent_map_8_gp[] = { 363 { P_GPLL0_OUT_MAIN, 1 }, 364 }; 365 366 static const struct clk_hw *gcc_parent_hws_8_gp[] = { 367 &gpll0_vote.hw, 368 }; 369 370 static const struct parent_map gcc_parent_map_9[] = { 371 { P_XO, 0 }, 372 { P_GPLL6_OUT_MAIN, 6 }, 373 }; 374 375 static const struct clk_parent_data gcc_parent_data_9[] = { 376 { .fw_name = "xo" }, 377 { .hw = &gpll6_vote.hw }, 378 }; 379 380 static const struct parent_map gcc_parent_map_10[] = { 381 { P_XO, 0 }, 382 }; 383 384 static const struct clk_parent_data gcc_parent_data_10[] = { 385 { .fw_name = "xo" }, 386 }; 387 388 static const struct parent_map gcc_parent_map_sdcc_ice[] = { 389 { P_XO, 0 }, 390 { P_GPLL0_OUT_M, 3 }, 391 }; 392 393 static const struct parent_map gcc_parent_map_cci[] = { 394 { P_XO, 0 }, 395 { P_GPLL0_AUX, 2 }, 396 }; 397 398 static const struct parent_map gcc_parent_map_cpp[] = { 399 { P_XO, 0 }, 400 { P_GPLL0_OUT_MAIN, 1 }, 401 { P_GPLL4_AUX, 3 }, 402 }; 403 404 static const struct parent_map gcc_parent_map_mdss_pix0[] = { 405 { P_XO, 0 }, 406 { P_DSI0PLL, 1 }, 407 }; 408 409 static const struct clk_parent_data gcc_parent_data_mdss_pix0[] = { 410 { .fw_name = "xo" }, 411 { .fw_name = "dsi0pll" }, 412 }; 413 414 static const struct parent_map gcc_parent_map_mdss_pix1[] = { 415 { P_XO, 0 }, 416 { P_DSI0PLL, 3 }, 417 { P_DSI1PLL, 1 }, 418 }; 419 420 static const struct clk_parent_data gcc_parent_data_mdss_pix1[] = { 421 { .fw_name = "xo" }, 422 { .fw_name = "dsi0pll" }, 423 { .fw_name = "dsi1pll" }, 424 }; 425 426 static const struct parent_map gcc_parent_map_mdss_byte0[] = { 427 { P_XO, 0 }, 428 { P_DSI0PLL_BYTE, 1 }, 429 }; 430 431 static const struct clk_parent_data gcc_parent_data_mdss_byte0[] = { 432 { .fw_name = "xo" }, 433 { .fw_name = "dsi0pllbyte" }, 434 }; 435 436 static const struct parent_map gcc_parent_map_mdss_byte1[] = { 437 { P_XO, 0 }, 438 { P_DSI0PLL_BYTE, 3 }, 439 { P_DSI1PLL_BYTE, 1 }, 440 }; 441 442 static const struct clk_parent_data gcc_parent_data_mdss_byte1[] = { 443 { .fw_name = "xo" }, 444 { .fw_name = "dsi0pllbyte" }, 445 { .fw_name = "dsi1pllbyte" }, 446 }; 447 448 static const struct parent_map gcc_parent_map_gfx3d[] = { 449 { P_XO, 0 }, 450 { P_GPLL0_OUT_MAIN, 1 }, 451 { P_GPLL4_GFX3D, 5 }, 452 { P_GPLL6_GFX3D, 3 }, 453 }; 454 455 static const struct clk_parent_data gcc_parent_data_gfx3d[] = { 456 { .fw_name = "xo" }, 457 { .hw = &gpll0_vote.hw }, 458 { .hw = &gpll4_vote.hw }, 459 { .hw = &gpll6_vote.hw }, 460 }; 461 462 static const struct freq_tbl ftbl_aps_0_clk_src[] = { 463 F(19200000, P_XO, 1, 0, 0), 464 F(300000000, P_GPLL4_OUT, 4, 0, 0), 465 F(540000000, P_GPLL6_OUT_MAIN, 2, 0, 0), 466 { } 467 }; 468 469 static struct clk_rcg2 aps_0_clk_src = { 470 .cmd_rcgr = 0x78008, 471 .hid_width = 5, 472 .parent_map = gcc_parent_map_5, 473 .freq_tbl = ftbl_aps_0_clk_src, 474 .clkr.hw.init = &(struct clk_init_data){ 475 .name = "aps_0_clk_src", 476 .parent_data = gcc_parent_data_5, 477 .num_parents = ARRAY_SIZE(gcc_parent_data_5), 478 .ops = &clk_rcg2_ops, 479 }, 480 }; 481 482 static const struct freq_tbl ftbl_aps_1_clk_src[] = { 483 F(19200000, P_XO, 1, 0, 0), 484 F(300000000, P_GPLL4_OUT, 4, 0, 0), 485 F(540000000, P_GPLL6_OUT_MAIN, 2, 0, 0), 486 { } 487 }; 488 489 static struct clk_rcg2 aps_1_clk_src = { 490 .cmd_rcgr = 0x79008, 491 .hid_width = 5, 492 .parent_map = gcc_parent_map_5, 493 .freq_tbl = ftbl_aps_1_clk_src, 494 .clkr.hw.init = &(struct clk_init_data){ 495 .name = "aps_1_clk_src", 496 .parent_data = gcc_parent_data_5, 497 .num_parents = ARRAY_SIZE(gcc_parent_data_5), 498 .ops = &clk_rcg2_ops, 499 }, 500 }; 501 502 static const struct freq_tbl ftbl_apss_ahb_clk_src[] = { 503 F(19200000, P_XO_A, 1, 0, 0), 504 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 505 F(88890000, P_GPLL0_OUT_MAIN, 9, 0, 0), 506 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 507 { } 508 }; 509 510 static struct clk_rcg2 apss_ahb_clk_src = { 511 .cmd_rcgr = 0x46000, 512 .hid_width = 5, 513 .parent_map = gcc_parent_map_8_a, 514 .freq_tbl = ftbl_apss_ahb_clk_src, 515 .clkr.hw.init = &(struct clk_init_data){ 516 .name = "apss_ahb_clk_src", 517 .parent_data = gcc_parent_data_8_a, 518 .num_parents = ARRAY_SIZE(gcc_parent_data_8_a), 519 .ops = &clk_rcg2_ops, 520 /* 521 * This clock allows the CPUs to communicate with 522 * the rest of the SoC. Without it, the brain will 523 * operate without the rest of the body. 524 */ 525 .flags = CLK_IS_CRITICAL, 526 }, 527 }; 528 529 static const struct freq_tbl ftbl_blsp_i2c_apps_clk_src[] = { 530 F(19200000, P_XO, 1, 0, 0), 531 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 532 { } 533 }; 534 535 static struct clk_rcg2 blsp1_qup1_i2c_apps_clk_src = { 536 .cmd_rcgr = 0x200c, 537 .hid_width = 5, 538 .parent_map = gcc_parent_map_8, 539 .freq_tbl = ftbl_blsp_i2c_apps_clk_src, 540 .clkr.hw.init = &(struct clk_init_data){ 541 .name = "blsp1_qup1_i2c_apps_clk_src", 542 .parent_data = gcc_parent_data_4_8, 543 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 544 .ops = &clk_rcg2_ops, 545 }, 546 }; 547 548 static const struct freq_tbl ftbl_blsp_spi_apps_clk_src[] = { 549 F(960000, P_XO, 10, 1, 2), 550 F(4800000, P_XO, 4, 0, 0), 551 F(9600000, P_XO, 2, 0, 0), 552 F(16000000, P_GPLL0_OUT_MAIN, 10, 1, 5), 553 F(19200000, P_XO, 1, 0, 0), 554 F(25000000, P_GPLL0_OUT_MAIN, 16, 1, 2), 555 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 556 { } 557 }; 558 559 static struct clk_rcg2 blsp1_qup1_spi_apps_clk_src = { 560 .cmd_rcgr = 0x2024, 561 .mnd_width = 8, 562 .hid_width = 5, 563 .parent_map = gcc_parent_map_8, 564 .freq_tbl = ftbl_blsp_spi_apps_clk_src, 565 .clkr.hw.init = &(struct clk_init_data){ 566 .name = "blsp1_qup1_spi_apps_clk_src", 567 .parent_data = gcc_parent_data_4_8, 568 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 569 .ops = &clk_rcg2_ops, 570 }, 571 }; 572 573 static struct clk_rcg2 blsp1_qup2_i2c_apps_clk_src = { 574 .cmd_rcgr = 0x3000, 575 .hid_width = 5, 576 .parent_map = gcc_parent_map_8, 577 .freq_tbl = ftbl_blsp_i2c_apps_clk_src, 578 .clkr.hw.init = &(struct clk_init_data){ 579 .name = "blsp1_qup2_i2c_apps_clk_src", 580 .parent_data = gcc_parent_data_4_8, 581 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 582 .ops = &clk_rcg2_ops, 583 }, 584 }; 585 586 static struct clk_rcg2 blsp1_qup2_spi_apps_clk_src = { 587 .cmd_rcgr = 0x3014, 588 .mnd_width = 8, 589 .hid_width = 5, 590 .parent_map = gcc_parent_map_8, 591 .freq_tbl = ftbl_blsp_spi_apps_clk_src, 592 .clkr.hw.init = &(struct clk_init_data){ 593 .name = "blsp1_qup2_spi_apps_clk_src", 594 .parent_data = gcc_parent_data_4_8, 595 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 596 .ops = &clk_rcg2_ops, 597 }, 598 }; 599 600 static struct clk_rcg2 blsp1_qup3_i2c_apps_clk_src = { 601 .cmd_rcgr = 0x4000, 602 .hid_width = 5, 603 .parent_map = gcc_parent_map_8, 604 .freq_tbl = ftbl_blsp_i2c_apps_clk_src, 605 .clkr.hw.init = &(struct clk_init_data){ 606 .name = "blsp1_qup3_i2c_apps_clk_src", 607 .parent_data = gcc_parent_data_4_8, 608 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 609 .ops = &clk_rcg2_ops, 610 }, 611 }; 612 613 static struct clk_rcg2 blsp1_qup3_spi_apps_clk_src = { 614 .cmd_rcgr = 0x4024, 615 .mnd_width = 8, 616 .hid_width = 5, 617 .parent_map = gcc_parent_map_8, 618 .freq_tbl = ftbl_blsp_spi_apps_clk_src, 619 .clkr.hw.init = &(struct clk_init_data){ 620 .name = "blsp1_qup3_spi_apps_clk_src", 621 .parent_data = gcc_parent_data_4_8, 622 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 623 .ops = &clk_rcg2_ops, 624 }, 625 }; 626 627 static struct clk_rcg2 blsp1_qup4_i2c_apps_clk_src = { 628 .cmd_rcgr = 0x5000, 629 .hid_width = 5, 630 .parent_map = gcc_parent_map_8, 631 .freq_tbl = ftbl_blsp_i2c_apps_clk_src, 632 .clkr.hw.init = &(struct clk_init_data){ 633 .name = "blsp1_qup4_i2c_apps_clk_src", 634 .parent_data = gcc_parent_data_4_8, 635 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 636 .ops = &clk_rcg2_ops, 637 }, 638 }; 639 640 static struct clk_rcg2 blsp1_qup4_spi_apps_clk_src = { 641 .cmd_rcgr = 0x5024, 642 .mnd_width = 8, 643 .hid_width = 5, 644 .parent_map = gcc_parent_map_8, 645 .freq_tbl = ftbl_blsp_spi_apps_clk_src, 646 .clkr.hw.init = &(struct clk_init_data){ 647 .name = "blsp1_qup4_spi_apps_clk_src", 648 .parent_data = gcc_parent_data_4_8, 649 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 650 .ops = &clk_rcg2_ops, 651 }, 652 }; 653 654 static const struct freq_tbl ftbl_blsp_uart_apps_clk_src[] = { 655 F(3686400, P_GPLL0_OUT_MAIN, 1, 72, 15625), 656 F(7372800, P_GPLL0_OUT_MAIN, 1, 144, 15625), 657 F(14745600, P_GPLL0_OUT_MAIN, 1, 288, 15625), 658 F(16000000, P_GPLL0_OUT_MAIN, 10, 1, 5), 659 F(19200000, P_XO, 1, 0, 0), 660 F(24000000, P_GPLL0_OUT_MAIN, 1, 3, 100), 661 F(25000000, P_GPLL0_OUT_MAIN, 16, 1, 2), 662 F(32000000, P_GPLL0_OUT_MAIN, 1, 1, 25), 663 F(40000000, P_GPLL0_OUT_MAIN, 1, 1, 20), 664 F(46400000, P_GPLL0_OUT_MAIN, 1, 29, 500), 665 F(48000000, P_GPLL0_OUT_MAIN, 1, 3, 50), 666 F(51200000, P_GPLL0_OUT_MAIN, 1, 8, 125), 667 F(56000000, P_GPLL0_OUT_MAIN, 1, 7, 100), 668 F(58982400, P_GPLL0_OUT_MAIN, 1, 1152, 15625), 669 F(60000000, P_GPLL0_OUT_MAIN, 1, 3, 40), 670 F(64000000, P_GPLL0_OUT_MAIN, 1, 2, 25), 671 { } 672 }; 673 674 static struct clk_rcg2 blsp1_uart1_apps_clk_src = { 675 .cmd_rcgr = 0x2044, 676 .mnd_width = 16, 677 .hid_width = 5, 678 .parent_map = gcc_parent_map_8, 679 .freq_tbl = ftbl_blsp_uart_apps_clk_src, 680 .clkr.hw.init = &(struct clk_init_data){ 681 .name = "blsp1_uart1_apps_clk_src", 682 .parent_data = gcc_parent_data_4_8, 683 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 684 .ops = &clk_rcg2_ops, 685 }, 686 }; 687 688 static struct clk_rcg2 blsp1_uart2_apps_clk_src = { 689 .cmd_rcgr = 0x3034, 690 .mnd_width = 16, 691 .hid_width = 5, 692 .parent_map = gcc_parent_map_8, 693 .freq_tbl = ftbl_blsp_uart_apps_clk_src, 694 .clkr.hw.init = &(struct clk_init_data){ 695 .name = "blsp1_uart2_apps_clk_src", 696 .parent_data = gcc_parent_data_4_8, 697 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 698 .ops = &clk_rcg2_ops, 699 }, 700 }; 701 702 static struct clk_rcg2 blsp2_qup1_i2c_apps_clk_src = { 703 .cmd_rcgr = 0xc00c, 704 .hid_width = 5, 705 .parent_map = gcc_parent_map_8, 706 .freq_tbl = ftbl_blsp_i2c_apps_clk_src, 707 .clkr.hw.init = &(struct clk_init_data){ 708 .name = "blsp2_qup1_i2c_apps_clk_src", 709 .parent_data = gcc_parent_data_4_8, 710 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 711 .ops = &clk_rcg2_ops, 712 }, 713 }; 714 715 static struct clk_rcg2 blsp2_qup1_spi_apps_clk_src = { 716 .cmd_rcgr = 0xc024, 717 .mnd_width = 8, 718 .hid_width = 5, 719 .parent_map = gcc_parent_map_8, 720 .freq_tbl = ftbl_blsp_spi_apps_clk_src, 721 .clkr.hw.init = &(struct clk_init_data){ 722 .name = "blsp2_qup1_spi_apps_clk_src", 723 .parent_data = gcc_parent_data_4_8, 724 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 725 .ops = &clk_rcg2_ops, 726 }, 727 }; 728 729 static struct clk_rcg2 blsp2_qup2_i2c_apps_clk_src = { 730 .cmd_rcgr = 0xd000, 731 .hid_width = 5, 732 .parent_map = gcc_parent_map_8, 733 .freq_tbl = ftbl_blsp_i2c_apps_clk_src, 734 .clkr.hw.init = &(struct clk_init_data){ 735 .name = "blsp2_qup2_i2c_apps_clk_src", 736 .parent_data = gcc_parent_data_4_8, 737 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 738 .ops = &clk_rcg2_ops, 739 }, 740 }; 741 742 static struct clk_rcg2 blsp2_qup2_spi_apps_clk_src = { 743 .cmd_rcgr = 0xd014, 744 .mnd_width = 8, 745 .hid_width = 5, 746 .parent_map = gcc_parent_map_8, 747 .freq_tbl = ftbl_blsp_spi_apps_clk_src, 748 .clkr.hw.init = &(struct clk_init_data){ 749 .name = "blsp2_qup2_spi_apps_clk_src", 750 .parent_data = gcc_parent_data_4_8, 751 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 752 .ops = &clk_rcg2_ops, 753 }, 754 }; 755 756 static struct clk_rcg2 blsp2_qup3_i2c_apps_clk_src = { 757 .cmd_rcgr = 0xf000, 758 .hid_width = 5, 759 .parent_map = gcc_parent_map_8, 760 .freq_tbl = ftbl_blsp_i2c_apps_clk_src, 761 .clkr.hw.init = &(struct clk_init_data){ 762 .name = "blsp2_qup3_i2c_apps_clk_src", 763 .parent_data = gcc_parent_data_4_8, 764 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 765 .ops = &clk_rcg2_ops, 766 }, 767 }; 768 769 static struct clk_rcg2 blsp2_qup3_spi_apps_clk_src = { 770 .cmd_rcgr = 0xf024, 771 .mnd_width = 8, 772 .hid_width = 5, 773 .parent_map = gcc_parent_map_8, 774 .freq_tbl = ftbl_blsp_spi_apps_clk_src, 775 .clkr.hw.init = &(struct clk_init_data){ 776 .name = "blsp2_qup3_spi_apps_clk_src", 777 .parent_data = gcc_parent_data_4_8, 778 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 779 .ops = &clk_rcg2_ops, 780 }, 781 }; 782 783 static struct clk_rcg2 blsp2_qup4_i2c_apps_clk_src = { 784 .cmd_rcgr = 0x18000, 785 .hid_width = 5, 786 .parent_map = gcc_parent_map_8, 787 .freq_tbl = ftbl_blsp_i2c_apps_clk_src, 788 .clkr.hw.init = &(struct clk_init_data){ 789 .name = "blsp2_qup4_i2c_apps_clk_src", 790 .parent_data = gcc_parent_data_4_8, 791 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 792 .ops = &clk_rcg2_ops, 793 }, 794 }; 795 796 static struct clk_rcg2 blsp2_qup4_spi_apps_clk_src = { 797 .cmd_rcgr = 0x18024, 798 .mnd_width = 8, 799 .hid_width = 5, 800 .parent_map = gcc_parent_map_8, 801 .freq_tbl = ftbl_blsp_spi_apps_clk_src, 802 .clkr.hw.init = &(struct clk_init_data){ 803 .name = "blsp2_qup4_spi_apps_clk_src", 804 .parent_data = gcc_parent_data_4_8, 805 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 806 .ops = &clk_rcg2_ops, 807 }, 808 }; 809 810 static struct clk_rcg2 blsp2_uart1_apps_clk_src = { 811 .cmd_rcgr = 0xc044, 812 .mnd_width = 16, 813 .hid_width = 5, 814 .parent_map = gcc_parent_map_8, 815 .freq_tbl = ftbl_blsp_uart_apps_clk_src, 816 .clkr.hw.init = &(struct clk_init_data){ 817 .name = "blsp2_uart1_apps_clk_src", 818 .parent_data = gcc_parent_data_4_8, 819 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 820 .ops = &clk_rcg2_ops, 821 }, 822 }; 823 824 static struct clk_rcg2 blsp2_uart2_apps_clk_src = { 825 .cmd_rcgr = 0xd034, 826 .mnd_width = 16, 827 .hid_width = 5, 828 .parent_map = gcc_parent_map_8, 829 .freq_tbl = ftbl_blsp_uart_apps_clk_src, 830 .clkr.hw.init = &(struct clk_init_data){ 831 .name = "blsp2_uart2_apps_clk_src", 832 .parent_data = gcc_parent_data_4_8, 833 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 834 .ops = &clk_rcg2_ops, 835 }, 836 }; 837 838 static const struct freq_tbl ftbl_cci_clk_src[] = { 839 F(19200000, P_XO, 1, 0, 0), 840 F(37500000, P_GPLL0_AUX, 1, 3, 64), 841 { } 842 }; 843 844 static struct clk_rcg2 cci_clk_src = { 845 .cmd_rcgr = 0x51000, 846 .mnd_width = 8, 847 .hid_width = 5, 848 .parent_map = gcc_parent_map_cci, 849 .freq_tbl = ftbl_cci_clk_src, 850 .clkr.hw.init = &(struct clk_init_data){ 851 .name = "cci_clk_src", 852 .parent_data = gcc_parent_data_4_8, 853 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 854 .ops = &clk_rcg2_ops, 855 }, 856 }; 857 858 static const struct freq_tbl ftbl_cpp_clk_src[] = { 859 F(160000000, P_GPLL0_OUT_MAIN, 5, 0, 0), 860 F(240000000, P_GPLL4_AUX, 5, 0, 0), 861 F(320000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0), 862 F(400000000, P_GPLL0_OUT_MAIN, 2, 0, 0), 863 F(480000000, P_GPLL4_AUX, 2.5, 0, 0), 864 { } 865 }; 866 867 static struct clk_rcg2 cpp_clk_src = { 868 .cmd_rcgr = 0x58018, 869 .hid_width = 5, 870 .parent_map = gcc_parent_map_cpp, 871 .freq_tbl = ftbl_cpp_clk_src, 872 .clkr.hw.init = &(struct clk_init_data){ 873 .name = "cpp_clk_src", 874 .parent_data = gcc_parent_data_6, 875 .num_parents = ARRAY_SIZE(gcc_parent_data_6), 876 .ops = &clk_rcg2_ops, 877 }, 878 }; 879 880 static const struct freq_tbl ftbl_csi0_clk_src[] = { 881 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 882 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 883 F(266670000, P_GPLL0_OUT_MAIN, 3, 0, 0), 884 { } 885 }; 886 887 static struct clk_rcg2 csi0_clk_src = { 888 .cmd_rcgr = 0x4e020, 889 .hid_width = 5, 890 .parent_map = gcc_parent_map_8, 891 .freq_tbl = ftbl_csi0_clk_src, 892 .clkr.hw.init = &(struct clk_init_data){ 893 .name = "csi0_clk_src", 894 .parent_data = gcc_parent_data_4_8, 895 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 896 .ops = &clk_rcg2_ops, 897 }, 898 }; 899 900 static const struct freq_tbl ftbl_csi1_clk_src[] = { 901 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 902 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 903 F(266670000, P_GPLL0_OUT_MAIN, 3, 0, 0), 904 { } 905 }; 906 907 static struct clk_rcg2 csi1_clk_src = { 908 .cmd_rcgr = 0x4f020, 909 .hid_width = 5, 910 .parent_map = gcc_parent_map_8, 911 .freq_tbl = ftbl_csi1_clk_src, 912 .clkr.hw.init = &(struct clk_init_data){ 913 .name = "csi1_clk_src", 914 .parent_data = gcc_parent_data_4_8, 915 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 916 .ops = &clk_rcg2_ops, 917 }, 918 }; 919 920 static const struct freq_tbl ftbl_csi2_clk_src[] = { 921 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 922 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 923 F(266670000, P_GPLL0_OUT_MAIN, 3, 0, 0), 924 { } 925 }; 926 927 static struct clk_rcg2 csi2_clk_src = { 928 .cmd_rcgr = 0x3c020, 929 .hid_width = 5, 930 .parent_map = gcc_parent_map_8, 931 .freq_tbl = ftbl_csi2_clk_src, 932 .clkr.hw.init = &(struct clk_init_data){ 933 .name = "csi2_clk_src", 934 .parent_data = gcc_parent_data_4_8, 935 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 936 .ops = &clk_rcg2_ops, 937 }, 938 }; 939 940 static const struct freq_tbl ftbl_camss_gp0_clk_src[] = { 941 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 942 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 943 F(266670000, P_GPLL0_OUT_MAIN, 3, 0, 0), 944 { } 945 }; 946 947 static struct clk_rcg2 camss_gp0_clk_src = { 948 .cmd_rcgr = 0x54000, 949 .mnd_width = 8, 950 .hid_width = 5, 951 .parent_map = gcc_parent_map_8_gp, 952 .freq_tbl = ftbl_camss_gp0_clk_src, 953 .clkr.hw.init = &(struct clk_init_data){ 954 .name = "camss_gp0_clk_src", 955 .parent_hws = gcc_parent_hws_8_gp, 956 .num_parents = ARRAY_SIZE(gcc_parent_hws_8_gp), 957 .ops = &clk_rcg2_ops, 958 }, 959 }; 960 961 static const struct freq_tbl ftbl_camss_gp1_clk_src[] = { 962 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 963 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 964 F(266670000, P_GPLL0_OUT_MAIN, 3, 0, 0), 965 { } 966 }; 967 968 static struct clk_rcg2 camss_gp1_clk_src = { 969 .cmd_rcgr = 0x55000, 970 .mnd_width = 8, 971 .hid_width = 5, 972 .parent_map = gcc_parent_map_8_gp, 973 .freq_tbl = ftbl_camss_gp1_clk_src, 974 .clkr.hw.init = &(struct clk_init_data){ 975 .name = "camss_gp1_clk_src", 976 .parent_hws = gcc_parent_hws_8_gp, 977 .num_parents = ARRAY_SIZE(gcc_parent_hws_8_gp), 978 .ops = &clk_rcg2_ops, 979 }, 980 }; 981 982 static const struct freq_tbl ftbl_jpeg0_clk_src[] = { 983 F(133330000, P_GPLL0_OUT_MAIN, 6, 0, 0), 984 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 985 F(266666667, P_GPLL0_OUT_MAIN, 3, 0, 0), 986 F(320000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0), 987 { } 988 }; 989 990 static struct clk_rcg2 jpeg0_clk_src = { 991 .cmd_rcgr = 0x57000, 992 .hid_width = 5, 993 .parent_map = gcc_parent_map_6, 994 .freq_tbl = ftbl_jpeg0_clk_src, 995 .clkr.hw.init = &(struct clk_init_data){ 996 .name = "jpeg0_clk_src", 997 .parent_data = gcc_parent_data_6, 998 .num_parents = ARRAY_SIZE(gcc_parent_data_6), 999 .ops = &clk_rcg2_ops, 1000 }, 1001 }; 1002 1003 static const struct freq_tbl ftbl_mclk_clk_src[] = { 1004 F(8000000, P_GPLL0_OUT_MAIN, 1, 1, 100), 1005 F(24000000, P_GPLL6_OUT, 1, 1, 45), 1006 F(66670000, P_GPLL0_OUT_MAIN, 12, 0, 0), 1007 { } 1008 }; 1009 1010 static struct clk_rcg2 mclk0_clk_src = { 1011 .cmd_rcgr = 0x52000, 1012 .mnd_width = 8, 1013 .hid_width = 5, 1014 .parent_map = gcc_parent_map_7, 1015 .freq_tbl = ftbl_mclk_clk_src, 1016 .clkr.hw.init = &(struct clk_init_data){ 1017 .name = "mclk0_clk_src", 1018 .parent_hws = gcc_parent_hws_7, 1019 .num_parents = ARRAY_SIZE(gcc_parent_hws_7), 1020 .ops = &clk_rcg2_ops, 1021 }, 1022 }; 1023 1024 static struct clk_rcg2 mclk1_clk_src = { 1025 .cmd_rcgr = 0x53000, 1026 .mnd_width = 8, 1027 .hid_width = 5, 1028 .parent_map = gcc_parent_map_7, 1029 .freq_tbl = ftbl_mclk_clk_src, 1030 .clkr.hw.init = &(struct clk_init_data){ 1031 .name = "mclk1_clk_src", 1032 .parent_hws = gcc_parent_hws_7, 1033 .num_parents = ARRAY_SIZE(gcc_parent_hws_7), 1034 .ops = &clk_rcg2_ops, 1035 }, 1036 }; 1037 1038 static struct clk_rcg2 mclk2_clk_src = { 1039 .cmd_rcgr = 0x5c000, 1040 .mnd_width = 8, 1041 .hid_width = 5, 1042 .parent_map = gcc_parent_map_7, 1043 .freq_tbl = ftbl_mclk_clk_src, 1044 .clkr.hw.init = &(struct clk_init_data){ 1045 .name = "mclk2_clk_src", 1046 .parent_hws = gcc_parent_hws_7, 1047 .num_parents = ARRAY_SIZE(gcc_parent_hws_7), 1048 .ops = &clk_rcg2_ops, 1049 }, 1050 }; 1051 1052 static const struct freq_tbl ftbl_csi0phytimer_clk_src[] = { 1053 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1054 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1055 F(266670000, P_GPLL0_OUT_MAIN, 3, 0, 0), 1056 { } 1057 }; 1058 1059 static struct clk_rcg2 csi0phytimer_clk_src = { 1060 .cmd_rcgr = 0x4e000, 1061 .hid_width = 5, 1062 .parent_map = gcc_parent_map_8, 1063 .freq_tbl = ftbl_csi0phytimer_clk_src, 1064 .clkr.hw.init = &(struct clk_init_data){ 1065 .name = "csi0phytimer_clk_src", 1066 .parent_data = gcc_parent_data_4_8, 1067 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1068 .ops = &clk_rcg2_ops, 1069 }, 1070 }; 1071 1072 static const struct freq_tbl ftbl_csi1phytimer_clk_src[] = { 1073 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1074 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1075 F(266670000, P_GPLL0_OUT_MAIN, 3, 0, 0), 1076 { } 1077 }; 1078 1079 static struct clk_rcg2 csi1phytimer_clk_src = { 1080 .cmd_rcgr = 0x4f000, 1081 .hid_width = 5, 1082 .parent_map = gcc_parent_map_8, 1083 .freq_tbl = ftbl_csi1phytimer_clk_src, 1084 .clkr.hw.init = &(struct clk_init_data){ 1085 .name = "csi1phytimer_clk_src", 1086 .parent_data = gcc_parent_data_4_8, 1087 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1088 .ops = &clk_rcg2_ops, 1089 }, 1090 }; 1091 1092 static const struct freq_tbl ftbl_camss_top_ahb_clk_src[] = { 1093 F(40000000, P_GPLL0_OUT_MAIN, 10, 1, 2), 1094 F(80000000, P_GPLL0_OUT_MAIN, 10, 0, 0), 1095 { } 1096 }; 1097 1098 static struct clk_rcg2 camss_top_ahb_clk_src = { 1099 .cmd_rcgr = 0x5a000, 1100 .mnd_width = 8, 1101 .hid_width = 5, 1102 .parent_map = gcc_parent_map_8, 1103 .freq_tbl = ftbl_camss_top_ahb_clk_src, 1104 .clkr.hw.init = &(struct clk_init_data){ 1105 .name = "camss_top_ahb_clk_src", 1106 .parent_data = gcc_parent_data_4_8, 1107 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1108 .ops = &clk_rcg2_ops, 1109 }, 1110 }; 1111 1112 static const struct freq_tbl ftbl_vfe0_clk_src[] = { 1113 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 1114 F(80000000, P_GPLL0_OUT_MAIN, 10, 0, 0), 1115 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1116 F(133333333, P_GPLL0_OUT_MAIN, 6, 0, 0), 1117 F(160000000, P_GPLL0_OUT_MAIN, 5, 0, 0), 1118 F(177777778, P_GPLL0_OUT_MAIN, 4.5, 0, 0), 1119 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1120 F(266666667, P_GPLL0_OUT_MAIN, 3, 0, 0), 1121 F(300000000, P_GPLL4_OUT, 4, 0, 0), 1122 F(320000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0), 1123 F(466000000, P_GPLL2_AUX, 2, 0, 0), 1124 { } 1125 }; 1126 1127 static struct clk_rcg2 vfe0_clk_src = { 1128 .cmd_rcgr = 0x58000, 1129 .hid_width = 5, 1130 .parent_map = gcc_parent_map_2, 1131 .freq_tbl = ftbl_vfe0_clk_src, 1132 .clkr.hw.init = &(struct clk_init_data){ 1133 .name = "vfe0_clk_src", 1134 .parent_data = gcc_parent_data_2, 1135 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 1136 .ops = &clk_rcg2_ops, 1137 }, 1138 }; 1139 1140 static const struct freq_tbl ftbl_vfe1_clk_src[] = { 1141 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 1142 F(80000000, P_GPLL0_OUT_MAIN, 10, 0, 0), 1143 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1144 F(133333333, P_GPLL0_OUT_MAIN, 6, 0, 0), 1145 F(160000000, P_GPLL0_OUT_MAIN, 5, 0, 0), 1146 F(177777778, P_GPLL0_OUT_MAIN, 4.5, 0, 0), 1147 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1148 F(266666667, P_GPLL0_OUT_MAIN, 3, 0, 0), 1149 F(300000000, P_GPLL4_OUT, 4, 0, 0), 1150 F(320000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0), 1151 F(466000000, P_GPLL2_AUX, 2, 0, 0), 1152 { } 1153 }; 1154 1155 static struct clk_rcg2 vfe1_clk_src = { 1156 .cmd_rcgr = 0x58054, 1157 .hid_width = 5, 1158 .parent_map = gcc_parent_map_2, 1159 .freq_tbl = ftbl_vfe1_clk_src, 1160 .clkr.hw.init = &(struct clk_init_data){ 1161 .name = "vfe1_clk_src", 1162 .parent_data = gcc_parent_data_2, 1163 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 1164 .ops = &clk_rcg2_ops, 1165 }, 1166 }; 1167 1168 static const struct freq_tbl ftbl_crypto_clk_src[] = { 1169 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 1170 F(80000000, P_GPLL0_OUT_MAIN, 10, 0, 0), 1171 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1172 F(160000000, P_GPLL0_OUT_MAIN, 5, 0, 0), 1173 { } 1174 }; 1175 1176 static struct clk_rcg2 crypto_clk_src = { 1177 .cmd_rcgr = 0x16004, 1178 .hid_width = 5, 1179 .parent_map = gcc_parent_map_8, 1180 .freq_tbl = ftbl_crypto_clk_src, 1181 .clkr.hw.init = &(struct clk_init_data){ 1182 .name = "crypto_clk_src", 1183 .parent_data = gcc_parent_data_4_8, 1184 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1185 .ops = &clk_rcg2_ops, 1186 }, 1187 }; 1188 1189 static const struct freq_tbl ftbl_gp1_clk_src[] = { 1190 F(19200000, P_XO, 1, 0, 0), 1191 { } 1192 }; 1193 1194 static struct clk_rcg2 gp1_clk_src = { 1195 .cmd_rcgr = 0x8004, 1196 .mnd_width = 8, 1197 .hid_width = 5, 1198 .parent_map = gcc_parent_map_8_gp, 1199 .freq_tbl = ftbl_gp1_clk_src, 1200 .clkr.hw.init = &(struct clk_init_data){ 1201 .name = "gp1_clk_src", 1202 .parent_hws = (const struct clk_hw *[]) { 1203 &gpll0_vote.hw, 1204 }, 1205 .num_parents = 1, 1206 .ops = &clk_rcg2_ops, 1207 }, 1208 }; 1209 1210 static const struct freq_tbl ftbl_gp2_clk_src[] = { 1211 F(19200000, P_XO, 1, 0, 0), 1212 { } 1213 }; 1214 1215 static struct clk_rcg2 gp2_clk_src = { 1216 .cmd_rcgr = 0x9004, 1217 .mnd_width = 8, 1218 .hid_width = 5, 1219 .parent_map = gcc_parent_map_8_gp, 1220 .freq_tbl = ftbl_gp2_clk_src, 1221 .clkr.hw.init = &(struct clk_init_data){ 1222 .name = "gp2_clk_src", 1223 .parent_hws = (const struct clk_hw *[]) { 1224 &gpll0_vote.hw, 1225 }, 1226 .num_parents = 1, 1227 .ops = &clk_rcg2_ops, 1228 }, 1229 }; 1230 1231 static const struct freq_tbl ftbl_gp3_clk_src[] = { 1232 F(19200000, P_XO, 1, 0, 0), 1233 { } 1234 }; 1235 1236 static struct clk_rcg2 gp3_clk_src = { 1237 .cmd_rcgr = 0xa004, 1238 .mnd_width = 8, 1239 .hid_width = 5, 1240 .parent_map = gcc_parent_map_8_gp, 1241 .freq_tbl = ftbl_gp3_clk_src, 1242 .clkr.hw.init = &(struct clk_init_data){ 1243 .name = "gp3_clk_src", 1244 .parent_hws = (const struct clk_hw *[]) { 1245 &gpll0_vote.hw, 1246 }, 1247 .num_parents = 1, 1248 .ops = &clk_rcg2_ops, 1249 }, 1250 }; 1251 1252 static struct clk_rcg2 byte0_clk_src = { 1253 .cmd_rcgr = 0x4d044, 1254 .mnd_width = 0, 1255 .hid_width = 5, 1256 .parent_map = gcc_parent_map_mdss_byte0, 1257 .clkr.hw.init = &(struct clk_init_data){ 1258 .name = "byte0_clk_src", 1259 .parent_data = gcc_parent_data_mdss_byte0, 1260 .num_parents = ARRAY_SIZE(gcc_parent_data_mdss_byte0), 1261 .ops = &clk_byte2_ops, 1262 .flags = CLK_SET_RATE_PARENT, 1263 }, 1264 }; 1265 1266 static struct clk_rcg2 byte1_clk_src = { 1267 .cmd_rcgr = 0x4d0b0, 1268 .mnd_width = 0, 1269 .hid_width = 5, 1270 .parent_map = gcc_parent_map_mdss_byte1, 1271 .clkr.hw.init = &(struct clk_init_data){ 1272 .name = "byte1_clk_src", 1273 .parent_data = gcc_parent_data_mdss_byte1, 1274 .num_parents = ARRAY_SIZE(gcc_parent_data_mdss_byte1), 1275 .ops = &clk_byte2_ops, 1276 .flags = CLK_SET_RATE_PARENT, 1277 }, 1278 }; 1279 1280 static const struct freq_tbl ftbl_esc0_1_clk_src[] = { 1281 F(19200000, P_XO, 1, 0, 0), 1282 { } 1283 }; 1284 1285 static struct clk_rcg2 esc0_clk_src = { 1286 .cmd_rcgr = 0x4d05c, 1287 .hid_width = 5, 1288 .freq_tbl = ftbl_esc0_1_clk_src, 1289 .parent_map = gcc_parent_map_mdss_byte0, 1290 .clkr.hw.init = &(struct clk_init_data){ 1291 .name = "esc0_clk_src", 1292 .parent_data = gcc_parent_data_mdss_byte0, 1293 .num_parents = ARRAY_SIZE(gcc_parent_data_mdss_byte0), 1294 .ops = &clk_rcg2_ops, 1295 }, 1296 }; 1297 1298 static struct clk_rcg2 esc1_clk_src = { 1299 .cmd_rcgr = 0x4d0a8, 1300 .hid_width = 5, 1301 .freq_tbl = ftbl_esc0_1_clk_src, 1302 .parent_map = gcc_parent_map_mdss_byte1, 1303 .clkr.hw.init = &(struct clk_init_data){ 1304 .name = "esc1_clk_src", 1305 .parent_data = gcc_parent_data_mdss_byte1, 1306 .num_parents = ARRAY_SIZE(gcc_parent_data_mdss_byte1), 1307 .ops = &clk_rcg2_ops, 1308 }, 1309 }; 1310 1311 static const struct freq_tbl ftbl_mdp_clk_src[] = { 1312 F(50000000, P_GPLL0_OUT_MDP, 16, 0, 0), 1313 F(80000000, P_GPLL0_OUT_MDP, 10, 0, 0), 1314 F(100000000, P_GPLL0_OUT_MDP, 8, 0, 0), 1315 F(145454545, P_GPLL0_OUT_MDP, 5.5, 0, 0), 1316 F(160000000, P_GPLL0_OUT_MDP, 5, 0, 0), 1317 F(177777778, P_GPLL0_OUT_MDP, 4.5, 0, 0), 1318 F(200000000, P_GPLL0_OUT_MDP, 4, 0, 0), 1319 F(270000000, P_GPLL6_OUT, 4, 0, 0), 1320 F(320000000, P_GPLL0_OUT_MDP, 2.5, 0, 0), 1321 F(360000000, P_GPLL6_OUT, 3, 0, 0), 1322 { } 1323 }; 1324 1325 static struct clk_rcg2 mdp_clk_src = { 1326 .cmd_rcgr = 0x4d014, 1327 .hid_width = 5, 1328 .parent_map = gcc_parent_map_7_mdp, 1329 .freq_tbl = ftbl_mdp_clk_src, 1330 .clkr.hw.init = &(struct clk_init_data){ 1331 .name = "mdp_clk_src", 1332 .parent_data = gcc_parent_data_7_mdp, 1333 .num_parents = ARRAY_SIZE(gcc_parent_data_7_mdp), 1334 .ops = &clk_rcg2_ops, 1335 }, 1336 }; 1337 1338 static struct clk_rcg2 pclk0_clk_src = { 1339 .cmd_rcgr = 0x4d000, 1340 .mnd_width = 8, 1341 .hid_width = 5, 1342 .parent_map = gcc_parent_map_mdss_pix0, 1343 .clkr.hw.init = &(struct clk_init_data){ 1344 .name = "pclk0_clk_src", 1345 .parent_data = gcc_parent_data_mdss_pix0, 1346 .num_parents = ARRAY_SIZE(gcc_parent_data_mdss_pix0), 1347 .ops = &clk_pixel_ops, 1348 .flags = CLK_SET_RATE_PARENT, 1349 }, 1350 }; 1351 1352 static struct clk_rcg2 pclk1_clk_src = { 1353 .cmd_rcgr = 0x4d0b8, 1354 .mnd_width = 8, 1355 .hid_width = 5, 1356 .parent_map = gcc_parent_map_mdss_pix1, 1357 .clkr.hw.init = &(struct clk_init_data){ 1358 .name = "pclk1_clk_src", 1359 .parent_data = gcc_parent_data_mdss_pix1, 1360 .num_parents = ARRAY_SIZE(gcc_parent_data_mdss_pix1), 1361 .ops = &clk_pixel_ops, 1362 .flags = CLK_SET_RATE_PARENT, 1363 }, 1364 }; 1365 1366 static const struct freq_tbl ftbl_vsync_clk_src[] = { 1367 F(19200000, P_XO, 1, 0, 0), 1368 { } 1369 }; 1370 1371 static struct clk_rcg2 vsync_clk_src = { 1372 .cmd_rcgr = 0x4d02c, 1373 .hid_width = 5, 1374 .parent_map = gcc_parent_map_10, 1375 .freq_tbl = ftbl_vsync_clk_src, 1376 .clkr.hw.init = &(struct clk_init_data){ 1377 .name = "vsync_clk_src", 1378 .parent_data = gcc_parent_data_10, 1379 .num_parents = ARRAY_SIZE(gcc_parent_data_10), 1380 .ops = &clk_rcg2_ops, 1381 }, 1382 }; 1383 1384 static const struct freq_tbl ftbl_gfx3d_clk_src[] = { 1385 F(19200000, P_XO, 1, 0, 0), 1386 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 1387 F(80000000, P_GPLL0_OUT_MAIN, 10, 0, 0), 1388 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1389 F(133333333, P_GPLL0_OUT_MAIN, 6, 0, 0), 1390 F(160000000, P_GPLL0_OUT_MAIN, 5, 0, 0), 1391 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1392 F(228571429, P_GPLL0_OUT_MAIN, 3.5, 0, 0), 1393 F(240000000, P_GPLL6_GFX3D, 4.5, 0, 0), 1394 F(266666667, P_GPLL0_OUT_MAIN, 3, 0, 0), 1395 F(300000000, P_GPLL4_GFX3D, 4, 0, 0), 1396 F(360000000, P_GPLL6_GFX3D, 3, 0, 0), 1397 F(400000000, P_GPLL0_OUT_MAIN, 2, 0, 0), 1398 F(432000000, P_GPLL6_GFX3D, 2.5, 0, 0), 1399 F(480000000, P_GPLL4_GFX3D, 2.5, 0, 0), 1400 F(540000000, P_GPLL6_GFX3D, 2, 0, 0), 1401 F(600000000, P_GPLL4_GFX3D, 2, 0, 0), 1402 { } 1403 }; 1404 1405 static const struct clk_init_data gfx3d_clk_params = { 1406 .name = "gfx3d_clk_src", 1407 .parent_data = gcc_parent_data_gfx3d, 1408 .num_parents = ARRAY_SIZE(gcc_parent_data_gfx3d), 1409 .ops = &clk_rcg2_ops, 1410 }; 1411 1412 static struct clk_rcg2 gfx3d_clk_src = { 1413 .cmd_rcgr = 0x59000, 1414 .hid_width = 5, 1415 .parent_map = gcc_parent_map_gfx3d, 1416 .freq_tbl = ftbl_gfx3d_clk_src, 1417 .clkr.hw.init = &gfx3d_clk_params, 1418 }; 1419 1420 static const struct freq_tbl ftbl_pdm2_clk_src[] = { 1421 F(64000000, P_GPLL0_OUT_MAIN, 12.5, 0, 0), 1422 { } 1423 }; 1424 1425 static struct clk_rcg2 pdm2_clk_src = { 1426 .cmd_rcgr = 0x44010, 1427 .hid_width = 5, 1428 .parent_map = gcc_parent_map_8, 1429 .freq_tbl = ftbl_pdm2_clk_src, 1430 .clkr.hw.init = &(struct clk_init_data){ 1431 .name = "pdm2_clk_src", 1432 .parent_data = gcc_parent_data_4_8, 1433 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1434 .ops = &clk_rcg2_ops, 1435 }, 1436 }; 1437 1438 static const struct freq_tbl ftbl_rbcpr_gfx_clk_src[] = { 1439 F(19200000, P_XO, 1, 0, 0), 1440 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 1441 { } 1442 }; 1443 1444 static struct clk_rcg2 rbcpr_gfx_clk_src = { 1445 .cmd_rcgr = 0x3a00c, 1446 .hid_width = 5, 1447 .parent_map = gcc_parent_map_8, 1448 .freq_tbl = ftbl_rbcpr_gfx_clk_src, 1449 .clkr.hw.init = &(struct clk_init_data){ 1450 .name = "rbcpr_gfx_clk_src", 1451 .parent_data = gcc_parent_data_4_8, 1452 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1453 .ops = &clk_rcg2_ops, 1454 }, 1455 }; 1456 1457 static const struct freq_tbl ftbl_sdcc1_apps_clk_src[] = { 1458 F(144000, P_XO, 16, 3, 25), 1459 F(400000, P_XO, 12, 1, 4), 1460 F(20000000, P_GPLL0_OUT_MAIN, 10, 1, 4), 1461 F(25000000, P_GPLL0_OUT_MAIN, 16, 1, 2), 1462 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 1463 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1464 F(177777778, P_GPLL0_OUT_MAIN, 4.5, 0, 0), 1465 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1466 F(342850000, P_GPLL4_OUT, 3.5, 0, 0), 1467 F(400000000, P_GPLL4_OUT, 3, 0, 0), 1468 { } 1469 }; 1470 1471 static const struct freq_tbl ftbl_sdcc1_8976_v1_1_apps_clk_src[] = { 1472 F(144000, P_XO, 16, 3, 25), 1473 F(400000, P_XO, 12, 1, 4), 1474 F(20000000, P_GPLL0_OUT_MAIN, 10, 1, 4), 1475 F(25000000, P_GPLL0_OUT_MAIN, 16, 1, 2), 1476 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 1477 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1478 F(177777778, P_GPLL0_OUT_MAIN, 4.5, 0, 0), 1479 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1480 F(186400000, P_GPLL2_OUT, 5, 0, 0), 1481 F(372800000, P_GPLL2_OUT, 2.5, 0, 0), 1482 { } 1483 }; 1484 1485 static const struct clk_init_data sdcc1_apps_clk_src_8976v1_1_init = { 1486 .name = "sdcc1_apps_clk_src", 1487 .parent_data = gcc_parent_data_v1_1, 1488 .num_parents = ARRAY_SIZE(gcc_parent_data_v1_1), 1489 .ops = &clk_rcg2_floor_ops, 1490 }; 1491 1492 static struct clk_rcg2 sdcc1_apps_clk_src = { 1493 .cmd_rcgr = 0x42004, 1494 .mnd_width = 8, 1495 .hid_width = 5, 1496 .parent_map = gcc_parent_map_1, 1497 .freq_tbl = ftbl_sdcc1_apps_clk_src, 1498 .clkr.hw.init = &(struct clk_init_data){ 1499 .name = "sdcc1_apps_clk_src", 1500 .parent_data = gcc_parent_data_1, 1501 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1502 .ops = &clk_rcg2_floor_ops, 1503 }, 1504 }; 1505 1506 static const struct freq_tbl ftbl_sdcc1_ice_core_clk_src[] = { 1507 F(100000000, P_GPLL0_OUT_M, 8, 0, 0), 1508 F(200000000, P_GPLL0_OUT_M, 4, 0, 0), 1509 { } 1510 }; 1511 1512 static struct clk_rcg2 sdcc1_ice_core_clk_src = { 1513 .cmd_rcgr = 0x5d000, 1514 .mnd_width = 8, 1515 .hid_width = 5, 1516 .parent_map = gcc_parent_map_sdcc_ice, 1517 .freq_tbl = ftbl_sdcc1_ice_core_clk_src, 1518 .clkr.hw.init = &(struct clk_init_data){ 1519 .name = "sdcc1_ice_core_clk_src", 1520 .parent_data = gcc_parent_data_4_8, 1521 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1522 .ops = &clk_rcg2_ops, 1523 }, 1524 }; 1525 1526 static const struct freq_tbl ftbl_sdcc2_4_apps_clk_src[] = { 1527 F(144000, P_XO, 16, 3, 25), 1528 F(400000, P_XO, 12, 1, 4), 1529 F(20000000, P_GPLL0_OUT_MAIN, 10, 1, 4), 1530 F(25000000, P_GPLL0_OUT_MAIN, 16, 1, 2), 1531 F(40000000, P_GPLL0_OUT_MAIN, 10, 1, 2), 1532 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 1533 F(80000000, P_GPLL0_OUT_MAIN, 10, 0, 0), 1534 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1535 F(177777778, P_GPLL0_OUT_MAIN, 4.5, 0, 0), 1536 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1537 { } 1538 }; 1539 1540 static struct clk_rcg2 sdcc2_apps_clk_src = { 1541 .cmd_rcgr = 0x43004, 1542 .mnd_width = 8, 1543 .hid_width = 5, 1544 .parent_map = gcc_parent_map_4, 1545 .freq_tbl = ftbl_sdcc2_4_apps_clk_src, 1546 .clkr.hw.init = &(struct clk_init_data){ 1547 .name = "sdcc2_apps_clk_src", 1548 .parent_data = gcc_parent_data_4_8, 1549 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1550 .ops = &clk_rcg2_floor_ops, 1551 }, 1552 }; 1553 1554 static struct clk_rcg2 sdcc3_apps_clk_src = { 1555 .cmd_rcgr = 0x39004, 1556 .mnd_width = 8, 1557 .hid_width = 5, 1558 .parent_map = gcc_parent_map_4, 1559 .freq_tbl = ftbl_sdcc2_4_apps_clk_src, 1560 .clkr.hw.init = &(struct clk_init_data){ 1561 .name = "sdcc3_apps_clk_src", 1562 .parent_data = gcc_parent_data_4_8, 1563 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1564 .ops = &clk_rcg2_ops, 1565 }, 1566 }; 1567 1568 static const struct freq_tbl ftbl_usb_fs_ic_clk_src[] = { 1569 F(60000000, P_GPLL6_OUT_MAIN, 6, 1, 3), 1570 { } 1571 }; 1572 1573 static struct clk_rcg2 usb_fs_ic_clk_src = { 1574 .cmd_rcgr = 0x3f034, 1575 .mnd_width = 8, 1576 .hid_width = 5, 1577 .parent_map = gcc_parent_map_9, 1578 .freq_tbl = ftbl_usb_fs_ic_clk_src, 1579 .clkr.hw.init = &(struct clk_init_data){ 1580 .name = "usb_fs_ic_clk_src", 1581 .parent_data = gcc_parent_data_9, 1582 .num_parents = ARRAY_SIZE(gcc_parent_data_9), 1583 .ops = &clk_rcg2_ops, 1584 }, 1585 }; 1586 1587 static const struct freq_tbl ftbl_usb_fs_system_clk_src[] = { 1588 F(64000000, P_GPLL0_OUT, 12.5, 0, 0), 1589 { } 1590 }; 1591 1592 static struct clk_rcg2 usb_fs_system_clk_src = { 1593 .cmd_rcgr = 0x3f010, 1594 .mnd_width = 8, 1595 .hid_width = 5, 1596 .parent_map = gcc_parent_map_4_fs, 1597 .freq_tbl = ftbl_usb_fs_system_clk_src, 1598 .clkr.hw.init = &(struct clk_init_data){ 1599 .name = "usb_fs_system_clk_src", 1600 .parent_data = gcc_parent_data_4_8, 1601 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1602 .ops = &clk_rcg2_ops, 1603 }, 1604 }; 1605 1606 static const struct freq_tbl ftbl_usb_hs_system_clk_src[] = { 1607 F(57140000, P_GPLL0_OUT_MAIN, 14, 0, 0), 1608 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1609 F(133333333, P_GPLL0_OUT_MAIN, 6, 0, 0), 1610 F(177780000, P_GPLL0_OUT_MAIN, 4.5, 0, 0), 1611 { } 1612 }; 1613 1614 static struct clk_rcg2 usb_hs_system_clk_src = { 1615 .cmd_rcgr = 0x41010, 1616 .hid_width = 5, 1617 .parent_map = gcc_parent_map_4, 1618 .freq_tbl = ftbl_usb_hs_system_clk_src, 1619 .clkr.hw.init = &(struct clk_init_data){ 1620 .name = "usb_hs_system_clk_src", 1621 .parent_data = gcc_parent_data_4_8, 1622 .num_parents = ARRAY_SIZE(gcc_parent_data_4_8), 1623 .ops = &clk_rcg2_ops, 1624 }, 1625 }; 1626 1627 static const struct freq_tbl ftbl_vcodec0_clk_src[] = { 1628 F(72727200, P_GPLL0_OUT_MAIN, 11, 0, 0), 1629 F(80000000, P_GPLL0_OUT_MAIN, 10, 0, 0), 1630 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1631 F(133333333, P_GPLL0_OUT_MAIN, 6, 0, 0), 1632 F(228570000, P_GPLL0_OUT_MAIN, 3.5, 0, 0), 1633 F(310667000, P_GPLL2_AUX, 3, 0, 0), 1634 F(360000000, P_GPLL6_AUX, 3, 0, 0), 1635 F(400000000, P_GPLL0_OUT_MAIN, 2, 0, 0), 1636 F(466000000, P_GPLL2_AUX, 2, 0, 0), 1637 { } 1638 }; 1639 1640 static struct clk_rcg2 vcodec0_clk_src = { 1641 .cmd_rcgr = 0x4c000, 1642 .mnd_width = 8, 1643 .hid_width = 5, 1644 .parent_map = gcc_parent_map_3, 1645 .freq_tbl = ftbl_vcodec0_clk_src, 1646 .clkr.hw.init = &(struct clk_init_data){ 1647 .name = "vcodec0_clk_src", 1648 .parent_data = gcc_parent_data_3, 1649 .num_parents = ARRAY_SIZE(gcc_parent_data_3), 1650 .ops = &clk_rcg2_ops, 1651 }, 1652 }; 1653 1654 static struct clk_branch gcc_aps_0_clk = { 1655 .halt_reg = 0x78004, 1656 .clkr = { 1657 .enable_reg = 0x78004, 1658 .enable_mask = BIT(0), 1659 .hw.init = &(struct clk_init_data) { 1660 .name = "gcc_aps_0_clk", 1661 .parent_hws = (const struct clk_hw *[]) { 1662 &aps_0_clk_src.clkr.hw, 1663 }, 1664 .num_parents = 1, 1665 .flags = CLK_SET_RATE_PARENT, 1666 .ops = &clk_branch2_ops, 1667 }, 1668 }, 1669 }; 1670 1671 static struct clk_branch gcc_aps_1_clk = { 1672 .halt_reg = 0x79004, 1673 .clkr = { 1674 .enable_reg = 0x79004, 1675 .enable_mask = BIT(0), 1676 .hw.init = &(struct clk_init_data) { 1677 .name = "gcc_aps_1_clk", 1678 .parent_hws = (const struct clk_hw *[]) { 1679 &aps_1_clk_src.clkr.hw, 1680 }, 1681 .num_parents = 1, 1682 .flags = CLK_SET_RATE_PARENT, 1683 .ops = &clk_branch2_ops, 1684 }, 1685 }, 1686 }; 1687 1688 static struct clk_branch gcc_blsp1_qup1_i2c_apps_clk = { 1689 .halt_reg = 0x2008, 1690 .halt_check = BRANCH_HALT, 1691 .clkr = { 1692 .enable_reg = 0x2008, 1693 .enable_mask = BIT(0), 1694 .hw.init = &(struct clk_init_data) { 1695 .name = "gcc_blsp1_qup1_i2c_apps_clk", 1696 .parent_hws = (const struct clk_hw *[]) { 1697 &blsp1_qup1_i2c_apps_clk_src.clkr.hw, 1698 }, 1699 .num_parents = 1, 1700 .flags = CLK_SET_RATE_PARENT, 1701 .ops = &clk_branch2_ops, 1702 }, 1703 }, 1704 }; 1705 1706 static struct clk_branch gcc_blsp1_qup1_spi_apps_clk = { 1707 .halt_reg = 0x2004, 1708 .halt_check = BRANCH_HALT, 1709 .clkr = { 1710 .enable_reg = 0x2004, 1711 .enable_mask = BIT(0), 1712 .hw.init = &(struct clk_init_data) { 1713 .name = "gcc_blsp1_qup1_spi_apps_clk", 1714 .parent_hws = (const struct clk_hw *[]) { 1715 &blsp1_qup1_spi_apps_clk_src.clkr.hw, 1716 }, 1717 .num_parents = 1, 1718 .flags = CLK_SET_RATE_PARENT, 1719 .ops = &clk_branch2_ops, 1720 }, 1721 }, 1722 }; 1723 1724 static struct clk_branch gcc_blsp1_qup2_i2c_apps_clk = { 1725 .halt_reg = 0x3010, 1726 .halt_check = BRANCH_HALT, 1727 .clkr = { 1728 .enable_reg = 0x3010, 1729 .enable_mask = BIT(0), 1730 .hw.init = &(struct clk_init_data) { 1731 .name = "gcc_blsp1_qup2_i2c_apps_clk", 1732 .parent_hws = (const struct clk_hw *[]) { 1733 &blsp1_qup2_i2c_apps_clk_src.clkr.hw, 1734 }, 1735 .num_parents = 1, 1736 .flags = CLK_SET_RATE_PARENT, 1737 .ops = &clk_branch2_ops, 1738 }, 1739 }, 1740 }; 1741 1742 static struct clk_branch gcc_blsp1_qup2_spi_apps_clk = { 1743 .halt_reg = 0x300c, 1744 .halt_check = BRANCH_HALT, 1745 .clkr = { 1746 .enable_reg = 0x300c, 1747 .enable_mask = BIT(0), 1748 .hw.init = &(struct clk_init_data) { 1749 .name = "gcc_blsp1_qup2_spi_apps_clk", 1750 .parent_hws = (const struct clk_hw *[]) { 1751 &blsp1_qup2_spi_apps_clk_src.clkr.hw, 1752 }, 1753 .num_parents = 1, 1754 .flags = CLK_SET_RATE_PARENT, 1755 .ops = &clk_branch2_ops, 1756 }, 1757 }, 1758 }; 1759 1760 static struct clk_branch gcc_blsp1_qup3_i2c_apps_clk = { 1761 .halt_reg = 0x4020, 1762 .halt_check = BRANCH_HALT, 1763 .clkr = { 1764 .enable_reg = 0x4020, 1765 .enable_mask = BIT(0), 1766 .hw.init = &(struct clk_init_data) { 1767 .name = "gcc_blsp1_qup3_i2c_apps_clk", 1768 .parent_hws = (const struct clk_hw *[]) { 1769 &blsp1_qup3_i2c_apps_clk_src.clkr.hw, 1770 }, 1771 .num_parents = 1, 1772 .flags = CLK_SET_RATE_PARENT, 1773 .ops = &clk_branch2_ops, 1774 }, 1775 }, 1776 }; 1777 1778 static struct clk_branch gcc_blsp1_qup3_spi_apps_clk = { 1779 .halt_reg = 0x401c, 1780 .halt_check = BRANCH_HALT, 1781 .clkr = { 1782 .enable_reg = 0x401c, 1783 .enable_mask = BIT(0), 1784 .hw.init = &(struct clk_init_data) { 1785 .name = "gcc_blsp1_qup3_spi_apps_clk", 1786 .parent_hws = (const struct clk_hw *[]) { 1787 &blsp1_qup3_spi_apps_clk_src.clkr.hw, 1788 }, 1789 .num_parents = 1, 1790 .flags = CLK_SET_RATE_PARENT, 1791 .ops = &clk_branch2_ops, 1792 }, 1793 }, 1794 }; 1795 1796 static struct clk_branch gcc_blsp1_qup4_i2c_apps_clk = { 1797 .halt_reg = 0x5020, 1798 .halt_check = BRANCH_HALT, 1799 .clkr = { 1800 .enable_reg = 0x5020, 1801 .enable_mask = BIT(0), 1802 .hw.init = &(struct clk_init_data) { 1803 .name = "gcc_blsp1_qup4_i2c_apps_clk", 1804 .parent_hws = (const struct clk_hw *[]) { 1805 &blsp1_qup4_i2c_apps_clk_src.clkr.hw, 1806 }, 1807 .num_parents = 1, 1808 .flags = CLK_SET_RATE_PARENT, 1809 .ops = &clk_branch2_ops, 1810 }, 1811 }, 1812 }; 1813 1814 static struct clk_branch gcc_blsp1_qup4_spi_apps_clk = { 1815 .halt_reg = 0x501c, 1816 .halt_check = BRANCH_HALT, 1817 .clkr = { 1818 .enable_reg = 0x501c, 1819 .enable_mask = BIT(0), 1820 .hw.init = &(struct clk_init_data) { 1821 .name = "gcc_blsp1_qup4_spi_apps_clk", 1822 .parent_hws = (const struct clk_hw *[]) { 1823 &blsp1_qup4_spi_apps_clk_src.clkr.hw, 1824 }, 1825 .num_parents = 1, 1826 .flags = CLK_SET_RATE_PARENT, 1827 .ops = &clk_branch2_ops, 1828 }, 1829 }, 1830 }; 1831 1832 static struct clk_branch gcc_blsp1_uart1_apps_clk = { 1833 .halt_reg = 0x203c, 1834 .halt_check = BRANCH_HALT, 1835 .clkr = { 1836 .enable_reg = 0x203c, 1837 .enable_mask = BIT(0), 1838 .hw.init = &(struct clk_init_data) { 1839 .name = "gcc_blsp1_uart1_apps_clk", 1840 .parent_hws = (const struct clk_hw *[]) { 1841 &blsp1_uart1_apps_clk_src.clkr.hw, 1842 }, 1843 .num_parents = 1, 1844 .flags = CLK_SET_RATE_PARENT, 1845 .ops = &clk_branch2_ops, 1846 }, 1847 }, 1848 }; 1849 1850 static struct clk_branch gcc_blsp1_uart2_apps_clk = { 1851 .halt_reg = 0x302c, 1852 .halt_check = BRANCH_HALT, 1853 .clkr = { 1854 .enable_reg = 0x302c, 1855 .enable_mask = BIT(0), 1856 .hw.init = &(struct clk_init_data) { 1857 .name = "gcc_blsp1_uart2_apps_clk", 1858 .parent_hws = (const struct clk_hw *[]) { 1859 &blsp1_uart2_apps_clk_src.clkr.hw, 1860 }, 1861 .num_parents = 1, 1862 .flags = CLK_SET_RATE_PARENT, 1863 .ops = &clk_branch2_ops, 1864 }, 1865 }, 1866 }; 1867 1868 static struct clk_branch gcc_blsp2_qup1_i2c_apps_clk = { 1869 .halt_reg = 0xc008, 1870 .halt_check = BRANCH_HALT, 1871 .clkr = { 1872 .enable_reg = 0xc008, 1873 .enable_mask = BIT(0), 1874 .hw.init = &(struct clk_init_data) { 1875 .name = "gcc_blsp2_qup1_i2c_apps_clk", 1876 .parent_hws = (const struct clk_hw *[]) { 1877 &blsp2_qup1_i2c_apps_clk_src.clkr.hw, 1878 }, 1879 .num_parents = 1, 1880 .flags = CLK_SET_RATE_PARENT, 1881 .ops = &clk_branch2_ops, 1882 }, 1883 }, 1884 }; 1885 1886 static struct clk_branch gcc_blsp2_qup1_spi_apps_clk = { 1887 .halt_reg = 0xc004, 1888 .halt_check = BRANCH_HALT, 1889 .clkr = { 1890 .enable_reg = 0xc004, 1891 .enable_mask = BIT(0), 1892 .hw.init = &(struct clk_init_data) { 1893 .name = "gcc_blsp2_qup1_spi_apps_clk", 1894 .parent_hws = (const struct clk_hw *[]) { 1895 &blsp2_qup1_spi_apps_clk_src.clkr.hw, 1896 }, 1897 .num_parents = 1, 1898 .flags = CLK_SET_RATE_PARENT, 1899 .ops = &clk_branch2_ops, 1900 }, 1901 }, 1902 }; 1903 1904 static struct clk_branch gcc_blsp2_qup2_i2c_apps_clk = { 1905 .halt_reg = 0xd010, 1906 .halt_check = BRANCH_HALT, 1907 .clkr = { 1908 .enable_reg = 0xd010, 1909 .enable_mask = BIT(0), 1910 .hw.init = &(struct clk_init_data) { 1911 .name = "gcc_blsp2_qup2_i2c_apps_clk", 1912 .parent_hws = (const struct clk_hw *[]) { 1913 &blsp2_qup2_i2c_apps_clk_src.clkr.hw, 1914 }, 1915 .num_parents = 1, 1916 .flags = CLK_SET_RATE_PARENT, 1917 .ops = &clk_branch2_ops, 1918 }, 1919 }, 1920 }; 1921 1922 static struct clk_branch gcc_blsp2_qup2_spi_apps_clk = { 1923 .halt_reg = 0xd00c, 1924 .halt_check = BRANCH_HALT, 1925 .clkr = { 1926 .enable_reg = 0xd00c, 1927 .enable_mask = BIT(0), 1928 .hw.init = &(struct clk_init_data) { 1929 .name = "gcc_blsp2_qup2_spi_apps_clk", 1930 .parent_hws = (const struct clk_hw *[]) { 1931 &blsp2_qup2_spi_apps_clk_src.clkr.hw, 1932 }, 1933 .num_parents = 1, 1934 .flags = CLK_SET_RATE_PARENT, 1935 .ops = &clk_branch2_ops, 1936 }, 1937 }, 1938 }; 1939 1940 static struct clk_branch gcc_blsp2_qup3_i2c_apps_clk = { 1941 .halt_reg = 0xf020, 1942 .halt_check = BRANCH_HALT, 1943 .clkr = { 1944 .enable_reg = 0xf020, 1945 .enable_mask = BIT(0), 1946 .hw.init = &(struct clk_init_data) { 1947 .name = "gcc_blsp2_qup3_i2c_apps_clk", 1948 .parent_hws = (const struct clk_hw *[]) { 1949 &blsp2_qup3_i2c_apps_clk_src.clkr.hw, 1950 }, 1951 .num_parents = 1, 1952 .flags = CLK_SET_RATE_PARENT, 1953 .ops = &clk_branch2_ops, 1954 }, 1955 }, 1956 }; 1957 1958 static struct clk_branch gcc_blsp2_qup3_spi_apps_clk = { 1959 .halt_reg = 0xf01c, 1960 .halt_check = BRANCH_HALT, 1961 .clkr = { 1962 .enable_reg = 0xf01c, 1963 .enable_mask = BIT(0), 1964 .hw.init = &(struct clk_init_data) { 1965 .name = "gcc_blsp2_qup3_spi_apps_clk", 1966 .parent_hws = (const struct clk_hw *[]) { 1967 &blsp2_qup3_spi_apps_clk_src.clkr.hw, 1968 }, 1969 .num_parents = 1, 1970 .flags = CLK_SET_RATE_PARENT, 1971 .ops = &clk_branch2_ops, 1972 }, 1973 }, 1974 }; 1975 1976 static struct clk_branch gcc_blsp2_qup4_i2c_apps_clk = { 1977 .halt_reg = 0x18020, 1978 .halt_check = BRANCH_HALT, 1979 .clkr = { 1980 .enable_reg = 0x18020, 1981 .enable_mask = BIT(0), 1982 .hw.init = &(struct clk_init_data) { 1983 .name = "gcc_blsp2_qup4_i2c_apps_clk", 1984 .parent_hws = (const struct clk_hw *[]) { 1985 &blsp2_qup4_i2c_apps_clk_src.clkr.hw, 1986 }, 1987 .num_parents = 1, 1988 .flags = CLK_SET_RATE_PARENT, 1989 .ops = &clk_branch2_ops, 1990 }, 1991 }, 1992 }; 1993 1994 static struct clk_branch gcc_blsp2_qup4_spi_apps_clk = { 1995 .halt_reg = 0x1801c, 1996 .halt_check = BRANCH_HALT, 1997 .clkr = { 1998 .enable_reg = 0x1801c, 1999 .enable_mask = BIT(0), 2000 .hw.init = &(struct clk_init_data) { 2001 .name = "gcc_blsp2_qup4_spi_apps_clk", 2002 .parent_hws = (const struct clk_hw *[]) { 2003 &blsp2_qup4_spi_apps_clk_src.clkr.hw, 2004 }, 2005 .num_parents = 1, 2006 .flags = CLK_SET_RATE_PARENT, 2007 .ops = &clk_branch2_ops, 2008 }, 2009 }, 2010 }; 2011 2012 static struct clk_branch gcc_blsp2_uart1_apps_clk = { 2013 .halt_reg = 0xc03c, 2014 .halt_check = BRANCH_HALT, 2015 .clkr = { 2016 .enable_reg = 0xc03c, 2017 .enable_mask = BIT(0), 2018 .hw.init = &(struct clk_init_data) { 2019 .name = "gcc_blsp2_uart1_apps_clk", 2020 .parent_hws = (const struct clk_hw *[]) { 2021 &blsp2_uart1_apps_clk_src.clkr.hw, 2022 }, 2023 .num_parents = 1, 2024 .flags = CLK_SET_RATE_PARENT, 2025 .ops = &clk_branch2_ops, 2026 }, 2027 }, 2028 }; 2029 2030 static struct clk_branch gcc_blsp2_uart2_apps_clk = { 2031 .halt_reg = 0xd02c, 2032 .halt_check = BRANCH_HALT, 2033 .clkr = { 2034 .enable_reg = 0xd02c, 2035 .enable_mask = BIT(0), 2036 .hw.init = &(struct clk_init_data) { 2037 .name = "gcc_blsp2_uart2_apps_clk", 2038 .parent_hws = (const struct clk_hw *[]) { 2039 &blsp2_uart2_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_camss_cci_ahb_clk = { 2049 .halt_reg = 0x5101c, 2050 .clkr = { 2051 .enable_reg = 0x5101c, 2052 .enable_mask = BIT(0), 2053 .hw.init = &(struct clk_init_data) { 2054 .name = "gcc_camss_cci_ahb_clk", 2055 .parent_hws = (const struct clk_hw *[]) { 2056 &camss_top_ahb_clk_src.clkr.hw, 2057 }, 2058 .num_parents = 1, 2059 .flags = CLK_SET_RATE_PARENT, 2060 .ops = &clk_branch2_ops, 2061 }, 2062 }, 2063 }; 2064 2065 static struct clk_branch gcc_camss_cci_clk = { 2066 .halt_reg = 0x51018, 2067 .clkr = { 2068 .enable_reg = 0x51018, 2069 .enable_mask = BIT(0), 2070 .hw.init = &(struct clk_init_data) { 2071 .name = "gcc_camss_cci_clk", 2072 .parent_hws = (const struct clk_hw *[]) { 2073 &cci_clk_src.clkr.hw, 2074 }, 2075 .num_parents = 1, 2076 .flags = CLK_SET_RATE_PARENT, 2077 .ops = &clk_branch2_ops, 2078 }, 2079 }, 2080 }; 2081 2082 static struct clk_branch gcc_camss_cpp_ahb_clk = { 2083 .halt_reg = 0x58040, 2084 .clkr = { 2085 .enable_reg = 0x58040, 2086 .enable_mask = BIT(0), 2087 .hw.init = &(struct clk_init_data) { 2088 .name = "gcc_camss_cpp_ahb_clk", 2089 .parent_hws = (const struct clk_hw *[]) { 2090 &camss_top_ahb_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_camss_cpp_axi_clk = { 2100 .halt_reg = 0x58064, 2101 .clkr = { 2102 .enable_reg = 0x58064, 2103 .enable_mask = BIT(0), 2104 .hw.init = &(struct clk_init_data) { 2105 .name = "gcc_camss_cpp_axi_clk", 2106 .ops = &clk_branch2_ops, 2107 }, 2108 }, 2109 }; 2110 2111 static struct clk_branch gcc_camss_cpp_clk = { 2112 .halt_reg = 0x5803c, 2113 .clkr = { 2114 .enable_reg = 0x5803c, 2115 .enable_mask = BIT(0), 2116 .hw.init = &(struct clk_init_data) { 2117 .name = "gcc_camss_cpp_clk", 2118 .parent_hws = (const struct clk_hw *[]) { 2119 &cpp_clk_src.clkr.hw, 2120 }, 2121 .num_parents = 1, 2122 .flags = CLK_SET_RATE_PARENT, 2123 .ops = &clk_branch2_ops, 2124 }, 2125 }, 2126 }; 2127 2128 static struct clk_branch gcc_camss_csi0_ahb_clk = { 2129 .halt_reg = 0x4e040, 2130 .clkr = { 2131 .enable_reg = 0x4e040, 2132 .enable_mask = BIT(0), 2133 .hw.init = &(struct clk_init_data) { 2134 .name = "gcc_camss_csi0_ahb_clk", 2135 .parent_hws = (const struct clk_hw *[]) { 2136 &camss_top_ahb_clk_src.clkr.hw, 2137 }, 2138 .num_parents = 1, 2139 .flags = CLK_SET_RATE_PARENT, 2140 .ops = &clk_branch2_ops, 2141 }, 2142 }, 2143 }; 2144 2145 static struct clk_branch gcc_camss_csi0_clk = { 2146 .halt_reg = 0x4e03c, 2147 .clkr = { 2148 .enable_reg = 0x4e03c, 2149 .enable_mask = BIT(0), 2150 .hw.init = &(struct clk_init_data) { 2151 .name = "gcc_camss_csi0_clk", 2152 .parent_hws = (const struct clk_hw *[]) { 2153 &csi0_clk_src.clkr.hw, 2154 }, 2155 .num_parents = 1, 2156 .flags = CLK_SET_RATE_PARENT, 2157 .ops = &clk_branch2_ops, 2158 }, 2159 }, 2160 }; 2161 2162 static struct clk_branch gcc_camss_csi0phy_clk = { 2163 .halt_reg = 0x4e048, 2164 .clkr = { 2165 .enable_reg = 0x4e048, 2166 .enable_mask = BIT(0), 2167 .hw.init = &(struct clk_init_data) { 2168 .name = "gcc_camss_csi0phy_clk", 2169 .parent_hws = (const struct clk_hw *[]) { 2170 &csi0_clk_src.clkr.hw, 2171 }, 2172 .num_parents = 1, 2173 .flags = CLK_SET_RATE_PARENT, 2174 .ops = &clk_branch2_ops, 2175 }, 2176 }, 2177 }; 2178 2179 static struct clk_branch gcc_camss_csi0pix_clk = { 2180 .halt_reg = 0x4e058, 2181 .clkr = { 2182 .enable_reg = 0x4e058, 2183 .enable_mask = BIT(0), 2184 .hw.init = &(struct clk_init_data) { 2185 .name = "gcc_camss_csi0pix_clk", 2186 .parent_hws = (const struct clk_hw *[]) { 2187 &csi0_clk_src.clkr.hw, 2188 }, 2189 .num_parents = 1, 2190 .flags = CLK_SET_RATE_PARENT, 2191 .ops = &clk_branch2_ops, 2192 }, 2193 }, 2194 }; 2195 2196 static struct clk_branch gcc_camss_csi0rdi_clk = { 2197 .halt_reg = 0x4e050, 2198 .clkr = { 2199 .enable_reg = 0x4e050, 2200 .enable_mask = BIT(0), 2201 .hw.init = &(struct clk_init_data) { 2202 .name = "gcc_camss_csi0rdi_clk", 2203 .parent_hws = (const struct clk_hw *[]) { 2204 &csi0_clk_src.clkr.hw, 2205 }, 2206 .num_parents = 1, 2207 .flags = CLK_SET_RATE_PARENT, 2208 .ops = &clk_branch2_ops, 2209 }, 2210 }, 2211 }; 2212 2213 static struct clk_branch gcc_camss_csi1_ahb_clk = { 2214 .halt_reg = 0x4f040, 2215 .clkr = { 2216 .enable_reg = 0x4f040, 2217 .enable_mask = BIT(0), 2218 .hw.init = &(struct clk_init_data) { 2219 .name = "gcc_camss_csi1_ahb_clk", 2220 .parent_hws = (const struct clk_hw *[]) { 2221 &camss_top_ahb_clk_src.clkr.hw, 2222 }, 2223 .num_parents = 1, 2224 .flags = CLK_SET_RATE_PARENT, 2225 .ops = &clk_branch2_ops, 2226 }, 2227 }, 2228 }; 2229 2230 static struct clk_branch gcc_camss_csi1_clk = { 2231 .halt_reg = 0x4f03c, 2232 .clkr = { 2233 .enable_reg = 0x4f03c, 2234 .enable_mask = BIT(0), 2235 .hw.init = &(struct clk_init_data) { 2236 .name = "gcc_camss_csi1_clk", 2237 .parent_hws = (const struct clk_hw *[]) { 2238 &csi1_clk_src.clkr.hw, 2239 }, 2240 .num_parents = 1, 2241 .flags = CLK_SET_RATE_PARENT, 2242 .ops = &clk_branch2_ops, 2243 }, 2244 }, 2245 }; 2246 2247 static struct clk_branch gcc_camss_csi1phy_clk = { 2248 .halt_reg = 0x4f048, 2249 .clkr = { 2250 .enable_reg = 0x4f048, 2251 .enable_mask = BIT(0), 2252 .hw.init = &(struct clk_init_data) { 2253 .name = "gcc_camss_csi1phy_clk", 2254 .parent_hws = (const struct clk_hw *[]) { 2255 &csi1_clk_src.clkr.hw, 2256 }, 2257 .num_parents = 1, 2258 .flags = CLK_SET_RATE_PARENT, 2259 .ops = &clk_branch2_ops, 2260 }, 2261 }, 2262 }; 2263 2264 static struct clk_branch gcc_camss_csi1pix_clk = { 2265 .halt_reg = 0x4f058, 2266 .clkr = { 2267 .enable_reg = 0x4f058, 2268 .enable_mask = BIT(0), 2269 .hw.init = &(struct clk_init_data) { 2270 .name = "gcc_camss_csi1pix_clk", 2271 .parent_hws = (const struct clk_hw *[]) { 2272 &csi1_clk_src.clkr.hw, 2273 }, 2274 .num_parents = 1, 2275 .flags = CLK_SET_RATE_PARENT, 2276 .ops = &clk_branch2_ops, 2277 }, 2278 }, 2279 }; 2280 2281 static struct clk_branch gcc_camss_csi1rdi_clk = { 2282 .halt_reg = 0x4f050, 2283 .clkr = { 2284 .enable_reg = 0x4f050, 2285 .enable_mask = BIT(0), 2286 .hw.init = &(struct clk_init_data) { 2287 .name = "gcc_camss_csi1rdi_clk", 2288 .parent_hws = (const struct clk_hw *[]) { 2289 &csi1_clk_src.clkr.hw, 2290 }, 2291 .num_parents = 1, 2292 .flags = CLK_SET_RATE_PARENT, 2293 .ops = &clk_branch2_ops, 2294 }, 2295 }, 2296 }; 2297 2298 static struct clk_branch gcc_camss_csi2_ahb_clk = { 2299 .halt_reg = 0x3c040, 2300 .clkr = { 2301 .enable_reg = 0x3c040, 2302 .enable_mask = BIT(0), 2303 .hw.init = &(struct clk_init_data) { 2304 .name = "gcc_camss_csi2_ahb_clk", 2305 .parent_hws = (const struct clk_hw *[]) { 2306 &camss_top_ahb_clk_src.clkr.hw, 2307 }, 2308 .num_parents = 1, 2309 .flags = CLK_SET_RATE_PARENT, 2310 .ops = &clk_branch2_ops, 2311 }, 2312 }, 2313 }; 2314 2315 static struct clk_branch gcc_camss_csi2_clk = { 2316 .halt_reg = 0x3c03c, 2317 .clkr = { 2318 .enable_reg = 0x3c03c, 2319 .enable_mask = BIT(0), 2320 .hw.init = &(struct clk_init_data) { 2321 .name = "gcc_camss_csi2_clk", 2322 .parent_hws = (const struct clk_hw *[]) { 2323 &csi2_clk_src.clkr.hw, 2324 }, 2325 .num_parents = 1, 2326 .flags = CLK_SET_RATE_PARENT, 2327 .ops = &clk_branch2_ops, 2328 }, 2329 }, 2330 }; 2331 2332 static struct clk_branch gcc_camss_csi2phy_clk = { 2333 .halt_reg = 0x3c048, 2334 .clkr = { 2335 .enable_reg = 0x3c048, 2336 .enable_mask = BIT(0), 2337 .hw.init = &(struct clk_init_data) { 2338 .name = "gcc_camss_csi2phy_clk", 2339 .parent_hws = (const struct clk_hw *[]) { 2340 &csi2_clk_src.clkr.hw, 2341 }, 2342 .num_parents = 1, 2343 .flags = CLK_SET_RATE_PARENT, 2344 .ops = &clk_branch2_ops, 2345 }, 2346 }, 2347 }; 2348 2349 static struct clk_branch gcc_camss_csi2pix_clk = { 2350 .halt_reg = 0x3c058, 2351 .clkr = { 2352 .enable_reg = 0x3c058, 2353 .enable_mask = BIT(0), 2354 .hw.init = &(struct clk_init_data) { 2355 .name = "gcc_camss_csi2pix_clk", 2356 .parent_hws = (const struct clk_hw *[]) { 2357 &csi2_clk_src.clkr.hw, 2358 }, 2359 .num_parents = 1, 2360 .flags = CLK_SET_RATE_PARENT, 2361 .ops = &clk_branch2_ops, 2362 }, 2363 }, 2364 }; 2365 2366 static struct clk_branch gcc_camss_csi2rdi_clk = { 2367 .halt_reg = 0x3c050, 2368 .clkr = { 2369 .enable_reg = 0x3c050, 2370 .enable_mask = BIT(0), 2371 .hw.init = &(struct clk_init_data) { 2372 .name = "gcc_camss_csi2rdi_clk", 2373 .parent_hws = (const struct clk_hw *[]) { 2374 &csi2_clk_src.clkr.hw, 2375 }, 2376 .num_parents = 1, 2377 .flags = CLK_SET_RATE_PARENT, 2378 .ops = &clk_branch2_ops, 2379 }, 2380 }, 2381 }; 2382 2383 static struct clk_branch gcc_camss_csi_vfe0_clk = { 2384 .halt_reg = 0x58050, 2385 .clkr = { 2386 .enable_reg = 0x58050, 2387 .enable_mask = BIT(0), 2388 .hw.init = &(struct clk_init_data) { 2389 .name = "gcc_camss_csi_vfe0_clk", 2390 .parent_hws = (const struct clk_hw *[]) { 2391 &vfe0_clk_src.clkr.hw, 2392 }, 2393 .num_parents = 1, 2394 .flags = CLK_SET_RATE_PARENT, 2395 .ops = &clk_branch2_ops, 2396 }, 2397 }, 2398 }; 2399 2400 static struct clk_branch gcc_camss_csi_vfe1_clk = { 2401 .halt_reg = 0x58074, 2402 .clkr = { 2403 .enable_reg = 0x58074, 2404 .enable_mask = BIT(0), 2405 .hw.init = &(struct clk_init_data) { 2406 .name = "gcc_camss_csi_vfe1_clk", 2407 .parent_hws = (const struct clk_hw *[]) { 2408 &vfe1_clk_src.clkr.hw, 2409 }, 2410 .num_parents = 1, 2411 .flags = CLK_SET_RATE_PARENT, 2412 .ops = &clk_branch2_ops, 2413 }, 2414 }, 2415 }; 2416 2417 static struct clk_branch gcc_camss_gp0_clk = { 2418 .halt_reg = 0x54018, 2419 .clkr = { 2420 .enable_reg = 0x54018, 2421 .enable_mask = BIT(0), 2422 .hw.init = &(struct clk_init_data) { 2423 .name = "gcc_camss_gp0_clk", 2424 .parent_hws = (const struct clk_hw *[]) { 2425 &camss_gp0_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_camss_gp1_clk = { 2435 .halt_reg = 0x55018, 2436 .clkr = { 2437 .enable_reg = 0x55018, 2438 .enable_mask = BIT(0), 2439 .hw.init = &(struct clk_init_data) { 2440 .name = "gcc_camss_gp1_clk", 2441 .parent_hws = (const struct clk_hw *[]) { 2442 &camss_gp1_clk_src.clkr.hw, 2443 }, 2444 .num_parents = 1, 2445 .flags = CLK_SET_RATE_PARENT, 2446 .ops = &clk_branch2_ops, 2447 }, 2448 }, 2449 }; 2450 2451 static struct clk_branch gcc_camss_ispif_ahb_clk = { 2452 .halt_reg = 0x50004, 2453 .clkr = { 2454 .enable_reg = 0x50004, 2455 .enable_mask = BIT(0), 2456 .hw.init = &(struct clk_init_data) { 2457 .name = "gcc_camss_ispif_ahb_clk", 2458 .parent_hws = (const struct clk_hw *[]) { 2459 &camss_top_ahb_clk_src.clkr.hw, 2460 }, 2461 .num_parents = 1, 2462 .flags = CLK_SET_RATE_PARENT, 2463 .ops = &clk_branch2_ops, 2464 }, 2465 }, 2466 }; 2467 2468 static struct clk_branch gcc_camss_jpeg0_clk = { 2469 .halt_reg = 0x57020, 2470 .halt_check = BRANCH_HALT, 2471 .clkr = { 2472 .enable_reg = 0x57020, 2473 .enable_mask = BIT(0), 2474 .hw.init = &(struct clk_init_data) { 2475 .name = "gcc_camss_jpeg0_clk", 2476 .parent_hws = (const struct clk_hw *[]) { 2477 &jpeg0_clk_src.clkr.hw, 2478 }, 2479 .num_parents = 1, 2480 .flags = CLK_SET_RATE_PARENT, 2481 .ops = &clk_branch2_ops, 2482 }, 2483 }, 2484 }; 2485 2486 static struct clk_branch gcc_camss_jpeg_ahb_clk = { 2487 .halt_reg = 0x57024, 2488 .clkr = { 2489 .enable_reg = 0x57024, 2490 .enable_mask = BIT(0), 2491 .hw.init = &(struct clk_init_data) { 2492 .name = "gcc_camss_jpeg_ahb_clk", 2493 .parent_hws = (const struct clk_hw *[]) { 2494 &camss_top_ahb_clk_src.clkr.hw, 2495 }, 2496 .num_parents = 1, 2497 .flags = CLK_SET_RATE_PARENT, 2498 .ops = &clk_branch2_ops, 2499 }, 2500 }, 2501 }; 2502 2503 static struct clk_branch gcc_camss_jpeg_axi_clk = { 2504 .halt_reg = 0x57028, 2505 .clkr = { 2506 .enable_reg = 0x57028, 2507 .enable_mask = BIT(0), 2508 .hw.init = &(struct clk_init_data) { 2509 .name = "gcc_camss_jpeg_axi_clk", 2510 .ops = &clk_branch2_ops, 2511 }, 2512 }, 2513 }; 2514 2515 static struct clk_branch gcc_camss_mclk0_clk = { 2516 .halt_reg = 0x52018, 2517 .clkr = { 2518 .enable_reg = 0x52018, 2519 .enable_mask = BIT(0), 2520 .hw.init = &(struct clk_init_data) { 2521 .name = "gcc_camss_mclk0_clk", 2522 .parent_hws = (const struct clk_hw *[]) { 2523 &mclk0_clk_src.clkr.hw, 2524 }, 2525 .num_parents = 1, 2526 .flags = CLK_SET_RATE_PARENT, 2527 .ops = &clk_branch2_ops, 2528 }, 2529 }, 2530 }; 2531 2532 static struct clk_branch gcc_camss_mclk1_clk = { 2533 .halt_reg = 0x53018, 2534 .clkr = { 2535 .enable_reg = 0x53018, 2536 .enable_mask = BIT(0), 2537 .hw.init = &(struct clk_init_data) { 2538 .name = "gcc_camss_mclk1_clk", 2539 .parent_hws = (const struct clk_hw *[]) { 2540 &mclk1_clk_src.clkr.hw, 2541 }, 2542 .num_parents = 1, 2543 .flags = CLK_SET_RATE_PARENT, 2544 .ops = &clk_branch2_ops, 2545 }, 2546 }, 2547 }; 2548 2549 static struct clk_branch gcc_camss_mclk2_clk = { 2550 .halt_reg = 0x5c018, 2551 .clkr = { 2552 .enable_reg = 0x5c018, 2553 .enable_mask = BIT(0), 2554 .hw.init = &(struct clk_init_data) { 2555 .name = "gcc_camss_mclk2_clk", 2556 .parent_hws = (const struct clk_hw *[]) { 2557 &mclk2_clk_src.clkr.hw, 2558 }, 2559 .num_parents = 1, 2560 .ops = &clk_branch2_ops, 2561 }, 2562 }, 2563 }; 2564 2565 static struct clk_branch gcc_camss_micro_ahb_clk = { 2566 .halt_reg = 0x5600c, 2567 .clkr = { 2568 .enable_reg = 0x5600c, 2569 .enable_mask = BIT(0), 2570 .hw.init = &(struct clk_init_data) { 2571 .name = "gcc_camss_micro_ahb_clk", 2572 .parent_hws = (const struct clk_hw *[]) { 2573 &camss_top_ahb_clk_src.clkr.hw, 2574 }, 2575 .num_parents = 1, 2576 .flags = CLK_SET_RATE_PARENT, 2577 .ops = &clk_branch2_ops, 2578 }, 2579 }, 2580 }; 2581 2582 static struct clk_branch gcc_camss_csi0phytimer_clk = { 2583 .halt_reg = 0x4e01c, 2584 .clkr = { 2585 .enable_reg = 0x4e01c, 2586 .enable_mask = BIT(0), 2587 .hw.init = &(struct clk_init_data) { 2588 .name = "gcc_camss_csi0phytimer_clk", 2589 .parent_hws = (const struct clk_hw *[]) { 2590 &csi0phytimer_clk_src.clkr.hw, 2591 }, 2592 .num_parents = 1, 2593 .flags = CLK_SET_RATE_PARENT, 2594 .ops = &clk_branch2_ops, 2595 }, 2596 }, 2597 }; 2598 2599 static struct clk_branch gcc_camss_csi1phytimer_clk = { 2600 .halt_reg = 0x4f01c, 2601 .clkr = { 2602 .enable_reg = 0x4f01c, 2603 .enable_mask = BIT(0), 2604 .hw.init = &(struct clk_init_data) { 2605 .name = "gcc_camss_csi1phytimer_clk", 2606 .parent_hws = (const struct clk_hw *[]) { 2607 &csi1phytimer_clk_src.clkr.hw, 2608 }, 2609 .num_parents = 1, 2610 .flags = CLK_SET_RATE_PARENT, 2611 .ops = &clk_branch2_ops, 2612 }, 2613 }, 2614 }; 2615 2616 static struct clk_branch gcc_camss_ahb_clk = { 2617 .halt_reg = 0x56004, 2618 .clkr = { 2619 .enable_reg = 0x56004, 2620 .enable_mask = BIT(0), 2621 .hw.init = &(struct clk_init_data) { 2622 .name = "gcc_camss_ahb_clk", 2623 .ops = &clk_branch2_ops, 2624 }, 2625 }, 2626 }; 2627 2628 static struct clk_branch gcc_camss_top_ahb_clk = { 2629 .halt_reg = 0x5a014, 2630 .clkr = { 2631 .enable_reg = 0x5a014, 2632 .enable_mask = BIT(0), 2633 .hw.init = &(struct clk_init_data) { 2634 .name = "gcc_camss_top_ahb_clk", 2635 .parent_hws = (const struct clk_hw *[]) { 2636 &camss_top_ahb_clk_src.clkr.hw, 2637 }, 2638 .num_parents = 1, 2639 .flags = CLK_SET_RATE_PARENT, 2640 .ops = &clk_branch2_ops, 2641 }, 2642 }, 2643 }; 2644 2645 static struct clk_branch gcc_camss_vfe0_clk = { 2646 .halt_reg = 0x58038, 2647 .clkr = { 2648 .enable_reg = 0x58038, 2649 .enable_mask = BIT(0), 2650 .hw.init = &(struct clk_init_data) { 2651 .name = "gcc_camss_vfe0_clk", 2652 .parent_hws = (const struct clk_hw *[]) { 2653 &vfe0_clk_src.clkr.hw, 2654 }, 2655 .num_parents = 1, 2656 .flags = CLK_SET_RATE_PARENT, 2657 .ops = &clk_branch2_ops, 2658 }, 2659 }, 2660 }; 2661 2662 static struct clk_branch gcc_camss_vfe_ahb_clk = { 2663 .halt_reg = 0x58044, 2664 .clkr = { 2665 .enable_reg = 0x58044, 2666 .enable_mask = BIT(0), 2667 .hw.init = &(struct clk_init_data) { 2668 .name = "gcc_camss_vfe_ahb_clk", 2669 .parent_hws = (const struct clk_hw *[]) { 2670 &camss_top_ahb_clk_src.clkr.hw, 2671 }, 2672 .num_parents = 1, 2673 .flags = CLK_SET_RATE_PARENT, 2674 .ops = &clk_branch2_ops, 2675 }, 2676 }, 2677 }; 2678 2679 static struct clk_branch gcc_camss_vfe_axi_clk = { 2680 .halt_reg = 0x58048, 2681 .clkr = { 2682 .enable_reg = 0x58048, 2683 .enable_mask = BIT(0), 2684 .hw.init = &(struct clk_init_data) { 2685 .name = "gcc_camss_vfe_axi_clk", 2686 .ops = &clk_branch2_ops, 2687 }, 2688 }, 2689 }; 2690 2691 static struct clk_branch gcc_camss_vfe1_ahb_clk = { 2692 .halt_reg = 0x58060, 2693 .clkr = { 2694 .enable_reg = 0x58060, 2695 .enable_mask = BIT(0), 2696 .hw.init = &(struct clk_init_data) { 2697 .name = "gcc_camss_vfe1_ahb_clk", 2698 .parent_hws = (const struct clk_hw *[]) { 2699 &camss_top_ahb_clk_src.clkr.hw, 2700 }, 2701 .num_parents = 1, 2702 .flags = CLK_SET_RATE_PARENT, 2703 .ops = &clk_branch2_ops, 2704 }, 2705 }, 2706 }; 2707 2708 static struct clk_branch gcc_camss_vfe1_axi_clk = { 2709 .halt_reg = 0x58068, 2710 .clkr = { 2711 .enable_reg = 0x58068, 2712 .enable_mask = BIT(0), 2713 .hw.init = &(struct clk_init_data) { 2714 .name = "gcc_camss_vfe1_axi_clk", 2715 .ops = &clk_branch2_ops, 2716 }, 2717 }, 2718 }; 2719 2720 static struct clk_branch gcc_camss_vfe1_clk = { 2721 .halt_reg = 0x5805c, 2722 .clkr = { 2723 .enable_reg = 0x5805c, 2724 .enable_mask = BIT(0), 2725 .hw.init = &(struct clk_init_data) { 2726 .name = "gcc_camss_vfe1_clk", 2727 .parent_hws = (const struct clk_hw *[]) { 2728 &vfe1_clk_src.clkr.hw, 2729 }, 2730 .num_parents = 1, 2731 .flags = CLK_SET_RATE_PARENT, 2732 .ops = &clk_branch2_ops, 2733 }, 2734 }, 2735 }; 2736 2737 static struct clk_branch gcc_dcc_clk = { 2738 .halt_reg = 0x77004, 2739 .clkr = { 2740 .enable_reg = 0x77004, 2741 .enable_mask = BIT(0), 2742 .hw.init = &(struct clk_init_data) { 2743 .name = "gcc_dcc_clk", 2744 .ops = &clk_branch2_ops, 2745 }, 2746 }, 2747 }; 2748 2749 static struct clk_branch gcc_oxili_gmem_clk = { 2750 .halt_reg = 0x59024, 2751 .clkr = { 2752 .enable_reg = 0x59024, 2753 .enable_mask = BIT(0), 2754 .hw.init = &(struct clk_init_data) { 2755 .name = "gcc_oxili_gmem_clk", 2756 .parent_hws = (const struct clk_hw *[]) { 2757 &gfx3d_clk_src.clkr.hw, 2758 }, 2759 .num_parents = 1, 2760 .flags = CLK_SET_RATE_PARENT, 2761 .ops = &clk_branch2_ops, 2762 }, 2763 }, 2764 }; 2765 2766 static struct clk_branch gcc_gp1_clk = { 2767 .halt_reg = 0x8000, 2768 .halt_check = BRANCH_HALT, 2769 .clkr = { 2770 .enable_reg = 0x8000, 2771 .enable_mask = BIT(0), 2772 .hw.init = &(struct clk_init_data) { 2773 .name = "gcc_gp1_clk", 2774 .parent_hws = (const struct clk_hw *[]) { 2775 &gp1_clk_src.clkr.hw, 2776 }, 2777 .num_parents = 1, 2778 .flags = CLK_SET_RATE_PARENT, 2779 .ops = &clk_branch2_ops, 2780 }, 2781 }, 2782 }; 2783 2784 static struct clk_branch gcc_gp2_clk = { 2785 .halt_reg = 0x9000, 2786 .halt_check = BRANCH_HALT, 2787 .clkr = { 2788 .enable_reg = 0x9000, 2789 .enable_mask = BIT(0), 2790 .hw.init = &(struct clk_init_data) { 2791 .name = "gcc_gp2_clk", 2792 .parent_hws = (const struct clk_hw *[]) { 2793 &gp2_clk_src.clkr.hw, 2794 }, 2795 .num_parents = 1, 2796 .flags = CLK_SET_RATE_PARENT, 2797 .ops = &clk_branch2_ops, 2798 }, 2799 }, 2800 }; 2801 2802 static struct clk_branch gcc_gp3_clk = { 2803 .halt_reg = 0xa000, 2804 .halt_check = BRANCH_HALT, 2805 .clkr = { 2806 .enable_reg = 0xa000, 2807 .enable_mask = BIT(0), 2808 .hw.init = &(struct clk_init_data) { 2809 .name = "gcc_gp3_clk", 2810 .parent_hws = (const struct clk_hw *[]) { 2811 &gp3_clk_src.clkr.hw, 2812 }, 2813 .num_parents = 1, 2814 .flags = CLK_SET_RATE_PARENT, 2815 .ops = &clk_branch2_ops, 2816 }, 2817 }, 2818 }; 2819 2820 static struct clk_branch gcc_mdss_ahb_clk = { 2821 .halt_reg = 0x4d07c, 2822 .halt_check = BRANCH_HALT, 2823 .clkr = { 2824 .enable_reg = 0x4d07c, 2825 .enable_mask = BIT(0), 2826 .hw.init = &(struct clk_init_data) { 2827 .name = "gcc_mdss_ahb_clk", 2828 .ops = &clk_branch2_ops, 2829 }, 2830 }, 2831 }; 2832 2833 static struct clk_branch gcc_mdss_axi_clk = { 2834 .halt_reg = 0x4d080, 2835 .halt_check = BRANCH_HALT, 2836 .clkr = { 2837 .enable_reg = 0x4d080, 2838 .enable_mask = BIT(0), 2839 .hw.init = &(struct clk_init_data) { 2840 .name = "gcc_mdss_axi_clk", 2841 .ops = &clk_branch2_ops, 2842 }, 2843 }, 2844 }; 2845 2846 static struct clk_branch gcc_mdss_byte0_clk = { 2847 .halt_reg = 0x4d094, 2848 .halt_check = BRANCH_HALT, 2849 .clkr = { 2850 .enable_reg = 0x4d094, 2851 .enable_mask = BIT(0), 2852 .hw.init = &(struct clk_init_data) { 2853 .name = "gcc_mdss_byte0_clk", 2854 .parent_hws = (const struct clk_hw *[]) { 2855 &byte0_clk_src.clkr.hw, 2856 }, 2857 .num_parents = 1, 2858 .flags = CLK_SET_RATE_PARENT, 2859 .ops = &clk_branch2_ops, 2860 }, 2861 }, 2862 }; 2863 2864 static struct clk_branch gcc_mdss_byte1_clk = { 2865 .halt_reg = 0x4d0a0, 2866 .halt_check = BRANCH_HALT, 2867 .clkr = { 2868 .enable_reg = 0x4d0a0, 2869 .enable_mask = BIT(0), 2870 .hw.init = &(struct clk_init_data) { 2871 .name = "gcc_mdss_byte1_clk", 2872 .parent_hws = (const struct clk_hw *[]) { 2873 &byte1_clk_src.clkr.hw, 2874 }, 2875 .num_parents = 1, 2876 .flags = CLK_SET_RATE_PARENT, 2877 .ops = &clk_branch2_ops, 2878 }, 2879 }, 2880 }; 2881 2882 static struct clk_branch gcc_mdss_esc0_clk = { 2883 .halt_reg = 0x4d098, 2884 .halt_check = BRANCH_HALT, 2885 .clkr = { 2886 .enable_reg = 0x4d098, 2887 .enable_mask = BIT(0), 2888 .hw.init = &(struct clk_init_data) { 2889 .name = "gcc_mdss_esc0_clk", 2890 .parent_hws = (const struct clk_hw *[]) { 2891 &esc0_clk_src.clkr.hw, 2892 }, 2893 .num_parents = 1, 2894 .flags = CLK_SET_RATE_PARENT, 2895 .ops = &clk_branch2_ops, 2896 }, 2897 }, 2898 }; 2899 2900 static struct clk_branch gcc_mdss_esc1_clk = { 2901 .halt_reg = 0x4d09c, 2902 .halt_check = BRANCH_HALT, 2903 .clkr = { 2904 .enable_reg = 0x4d09c, 2905 .enable_mask = BIT(0), 2906 .hw.init = &(struct clk_init_data) { 2907 .name = "gcc_mdss_esc1_clk", 2908 .parent_hws = (const struct clk_hw *[]) { 2909 &esc1_clk_src.clkr.hw, 2910 }, 2911 .num_parents = 1, 2912 .flags = CLK_SET_RATE_PARENT, 2913 .ops = &clk_branch2_ops, 2914 }, 2915 }, 2916 }; 2917 2918 static struct clk_branch gcc_mdss_mdp_clk = { 2919 .halt_reg = 0x4d088, 2920 .halt_check = BRANCH_HALT, 2921 .clkr = { 2922 .enable_reg = 0x4d088, 2923 .enable_mask = BIT(0), 2924 .hw.init = &(struct clk_init_data) { 2925 .name = "gcc_mdss_mdp_clk", 2926 .parent_hws = (const struct clk_hw *[]) { 2927 &mdp_clk_src.clkr.hw, 2928 }, 2929 .num_parents = 1, 2930 .flags = CLK_SET_RATE_PARENT, 2931 .ops = &clk_branch2_ops, 2932 }, 2933 }, 2934 }; 2935 2936 static struct clk_branch gcc_mdss_pclk0_clk = { 2937 .halt_reg = 0x4d084, 2938 .halt_check = BRANCH_HALT, 2939 .clkr = { 2940 .enable_reg = 0x4d084, 2941 .enable_mask = BIT(0), 2942 .hw.init = &(struct clk_init_data) { 2943 .name = "gcc_mdss_pclk0_clk", 2944 .parent_hws = (const struct clk_hw *[]) { 2945 &pclk0_clk_src.clkr.hw, 2946 }, 2947 .num_parents = 1, 2948 .flags = CLK_SET_RATE_PARENT, 2949 .ops = &clk_branch2_ops, 2950 }, 2951 }, 2952 }; 2953 2954 static struct clk_branch gcc_mdss_pclk1_clk = { 2955 .halt_reg = 0x4d0a4, 2956 .halt_check = BRANCH_HALT, 2957 .clkr = { 2958 .enable_reg = 0x4d0a4, 2959 .enable_mask = BIT(0), 2960 .hw.init = &(struct clk_init_data) { 2961 .name = "gcc_mdss_pclk1_clk", 2962 .parent_hws = (const struct clk_hw *[]) { 2963 &pclk1_clk_src.clkr.hw, 2964 }, 2965 .num_parents = 1, 2966 .flags = CLK_SET_RATE_PARENT, 2967 .ops = &clk_branch2_ops, 2968 }, 2969 }, 2970 }; 2971 2972 static struct clk_branch gcc_mdss_vsync_clk = { 2973 .halt_reg = 0x4d090, 2974 .halt_check = BRANCH_HALT, 2975 .clkr = { 2976 .enable_reg = 0x4d090, 2977 .enable_mask = BIT(0), 2978 .hw.init = &(struct clk_init_data) { 2979 .name = "gcc_mdss_vsync_clk", 2980 .parent_hws = (const struct clk_hw *[]) { 2981 &vsync_clk_src.clkr.hw, 2982 }, 2983 .num_parents = 1, 2984 .flags = CLK_SET_RATE_PARENT, 2985 .ops = &clk_branch2_ops, 2986 }, 2987 }, 2988 }; 2989 2990 static struct clk_branch gcc_mss_cfg_ahb_clk = { 2991 .halt_reg = 0x49000, 2992 .clkr = { 2993 .enable_reg = 0x49000, 2994 .enable_mask = BIT(0), 2995 .hw.init = &(struct clk_init_data) { 2996 .name = "gcc_mss_cfg_ahb_clk", 2997 .ops = &clk_branch2_ops, 2998 }, 2999 }, 3000 }; 3001 3002 static struct clk_branch gcc_mss_q6_bimc_axi_clk = { 3003 .halt_reg = 0x49004, 3004 .halt_check = BRANCH_HALT, 3005 .clkr = { 3006 .enable_reg = 0x49004, 3007 .enable_mask = BIT(0), 3008 .hw.init = &(struct clk_init_data) { 3009 .name = "gcc_mss_q6_bimc_axi_clk", 3010 .ops = &clk_branch2_ops, 3011 }, 3012 }, 3013 }; 3014 3015 static struct clk_branch gcc_bimc_gfx_clk = { 3016 .halt_reg = 0x59048, 3017 .clkr = { 3018 .enable_reg = 0x59048, 3019 .enable_mask = BIT(0), 3020 .hw.init = &(struct clk_init_data) { 3021 .name = "gcc_bimc_gfx_clk", 3022 .ops = &clk_branch2_ops, 3023 }, 3024 }, 3025 }; 3026 3027 static struct clk_branch gcc_oxili_ahb_clk = { 3028 .halt_reg = 0x59028, 3029 .clkr = { 3030 .enable_reg = 0x59028, 3031 .enable_mask = BIT(0), 3032 .hw.init = &(struct clk_init_data) { 3033 .name = "gcc_oxili_ahb_clk", 3034 .ops = &clk_branch2_ops, 3035 }, 3036 }, 3037 }; 3038 3039 static struct clk_branch gcc_oxili_aon_clk = { 3040 .halt_reg = 0x59044, 3041 .clkr = { 3042 .enable_reg = 0x59044, 3043 .enable_mask = BIT(0), 3044 .hw.init = &(struct clk_init_data) { 3045 .name = "gcc_oxili_aon_clk", 3046 .parent_hws = (const struct clk_hw *[]) { 3047 &gfx3d_clk_src.clkr.hw, 3048 }, 3049 .num_parents = 1, 3050 .flags = CLK_SET_RATE_PARENT, 3051 .ops = &clk_branch2_ops, 3052 }, 3053 }, 3054 }; 3055 3056 static struct clk_branch gcc_oxili_gfx3d_clk = { 3057 .halt_reg = 0x59020, 3058 .clkr = { 3059 .enable_reg = 0x59020, 3060 .enable_mask = BIT(0), 3061 .hw.init = &(struct clk_init_data) { 3062 .name = "gcc_oxili_gfx3d_clk", 3063 .parent_hws = (const struct clk_hw *[]) { 3064 &gfx3d_clk_src.clkr.hw, 3065 }, 3066 .num_parents = 1, 3067 .flags = CLK_SET_RATE_PARENT, 3068 .ops = &clk_branch2_ops, 3069 }, 3070 }, 3071 }; 3072 3073 static struct clk_branch gcc_oxili_timer_clk = { 3074 .halt_reg = 0x59040, 3075 .clkr = { 3076 .enable_reg = 0x59040, 3077 .enable_mask = BIT(0), 3078 .hw.init = &(struct clk_init_data) { 3079 .name = "gcc_oxili_timer_clk", 3080 .parent_data = &(const struct clk_parent_data){ 3081 .fw_name = "xo", 3082 }, 3083 .num_parents = 1, 3084 .ops = &clk_branch2_ops, 3085 }, 3086 }, 3087 }; 3088 3089 static struct clk_branch gcc_pdm2_clk = { 3090 .halt_reg = 0x4400c, 3091 .halt_check = BRANCH_HALT, 3092 .clkr = { 3093 .enable_reg = 0x4400c, 3094 .enable_mask = BIT(0), 3095 .hw.init = &(struct clk_init_data) { 3096 .name = "gcc_pdm2_clk", 3097 .parent_hws = (const struct clk_hw *[]) { 3098 &pdm2_clk_src.clkr.hw, 3099 }, 3100 .num_parents = 1, 3101 .flags = CLK_SET_RATE_PARENT, 3102 .ops = &clk_branch2_ops, 3103 }, 3104 }, 3105 }; 3106 3107 static struct clk_branch gcc_pdm_ahb_clk = { 3108 .halt_reg = 0x44004, 3109 .halt_check = BRANCH_HALT, 3110 .clkr = { 3111 .enable_reg = 0x44004, 3112 .enable_mask = BIT(0), 3113 .hw.init = &(struct clk_init_data) { 3114 .name = "gcc_pdm_ahb_clk", 3115 .ops = &clk_branch2_ops, 3116 }, 3117 }, 3118 }; 3119 3120 static struct clk_branch gcc_rbcpr_gfx_ahb_clk = { 3121 .halt_reg = 0x3a008, 3122 .clkr = { 3123 .enable_reg = 0x3a008, 3124 .enable_mask = BIT(0), 3125 .hw.init = &(struct clk_init_data) { 3126 .name = "gcc_rbcpr_gfx_ahb_clk", 3127 .ops = &clk_branch2_ops, 3128 }, 3129 }, 3130 }; 3131 3132 static struct clk_branch gcc_rbcpr_gfx_clk = { 3133 .halt_reg = 0x3a004, 3134 .clkr = { 3135 .enable_reg = 0x3a004, 3136 .enable_mask = BIT(0), 3137 .hw.init = &(struct clk_init_data) { 3138 .name = "gcc_rbcpr_gfx_clk", 3139 .parent_hws = (const struct clk_hw *[]) { 3140 &rbcpr_gfx_clk_src.clkr.hw, 3141 }, 3142 .num_parents = 1, 3143 .flags = CLK_SET_RATE_PARENT, 3144 .ops = &clk_branch2_ops, 3145 }, 3146 }, 3147 }; 3148 3149 static struct clk_branch gcc_sdcc1_ahb_clk = { 3150 .halt_reg = 0x4201c, 3151 .halt_check = BRANCH_HALT, 3152 .clkr = { 3153 .enable_reg = 0x4201c, 3154 .enable_mask = BIT(0), 3155 .hw.init = &(struct clk_init_data) { 3156 .name = "gcc_sdcc1_ahb_clk", 3157 .ops = &clk_branch2_ops, 3158 }, 3159 }, 3160 }; 3161 3162 static struct clk_branch gcc_sdcc1_apps_clk = { 3163 .halt_reg = 0x42018, 3164 .halt_check = BRANCH_HALT, 3165 .clkr = { 3166 .enable_reg = 0x42018, 3167 .enable_mask = BIT(0), 3168 .hw.init = &(struct clk_init_data) { 3169 .name = "gcc_sdcc1_apps_clk", 3170 .parent_hws = (const struct clk_hw *[]) { 3171 &sdcc1_apps_clk_src.clkr.hw, 3172 }, 3173 .num_parents = 1, 3174 .flags = CLK_SET_RATE_PARENT, 3175 .ops = &clk_branch2_ops, 3176 }, 3177 }, 3178 }; 3179 3180 static struct clk_branch gcc_sdcc1_ice_core_clk = { 3181 .halt_reg = 0x5d014, 3182 .halt_check = BRANCH_HALT, 3183 .clkr = { 3184 .enable_reg = 0x5d014, 3185 .enable_mask = BIT(0), 3186 .hw.init = &(struct clk_init_data) { 3187 .name = "gcc_sdcc1_ice_core_clk", 3188 .parent_hws = (const struct clk_hw *[]) { 3189 &sdcc1_ice_core_clk_src.clkr.hw, 3190 }, 3191 .num_parents = 1, 3192 .flags = CLK_SET_RATE_PARENT, 3193 .ops = &clk_branch2_ops, 3194 }, 3195 }, 3196 }; 3197 3198 static struct clk_branch gcc_sdcc2_ahb_clk = { 3199 .halt_reg = 0x4301c, 3200 .halt_check = BRANCH_HALT, 3201 .clkr = { 3202 .enable_reg = 0x4301c, 3203 .enable_mask = BIT(0), 3204 .hw.init = &(struct clk_init_data) { 3205 .name = "gcc_sdcc2_ahb_clk", 3206 .ops = &clk_branch2_ops, 3207 }, 3208 }, 3209 }; 3210 3211 static struct clk_branch gcc_sdcc2_apps_clk = { 3212 .halt_reg = 0x43018, 3213 .halt_check = BRANCH_HALT, 3214 .clkr = { 3215 .enable_reg = 0x43018, 3216 .enable_mask = BIT(0), 3217 .hw.init = &(struct clk_init_data) { 3218 .name = "gcc_sdcc2_apps_clk", 3219 .parent_hws = (const struct clk_hw *[]) { 3220 &sdcc2_apps_clk_src.clkr.hw, 3221 }, 3222 .num_parents = 1, 3223 .flags = CLK_SET_RATE_PARENT, 3224 .ops = &clk_branch2_ops, 3225 }, 3226 }, 3227 }; 3228 3229 static struct clk_branch gcc_sdcc3_ahb_clk = { 3230 .halt_reg = 0x3901c, 3231 .halt_check = BRANCH_HALT, 3232 .clkr = { 3233 .enable_reg = 0x3901c, 3234 .enable_mask = BIT(0), 3235 .hw.init = &(struct clk_init_data) { 3236 .name = "gcc_sdcc3_ahb_clk", 3237 .ops = &clk_branch2_ops, 3238 }, 3239 }, 3240 }; 3241 3242 static struct clk_branch gcc_sdcc3_apps_clk = { 3243 .halt_reg = 0x39018, 3244 .halt_check = BRANCH_HALT, 3245 .clkr = { 3246 .enable_reg = 0x39018, 3247 .enable_mask = BIT(0), 3248 .hw.init = &(struct clk_init_data) { 3249 .name = "gcc_sdcc3_apps_clk", 3250 .parent_hws = (const struct clk_hw *[]) { 3251 &sdcc3_apps_clk_src.clkr.hw, 3252 }, 3253 .num_parents = 1, 3254 .flags = CLK_SET_RATE_PARENT, 3255 .ops = &clk_branch2_ops, 3256 }, 3257 }, 3258 }; 3259 3260 static struct clk_branch gcc_usb2a_phy_sleep_clk = { 3261 .halt_reg = 0x4102c, 3262 .clkr = { 3263 .enable_reg = 0x4102c, 3264 .enable_mask = BIT(0), 3265 .hw.init = &(struct clk_init_data) { 3266 .name = "gcc_usb2a_phy_sleep_clk", 3267 .ops = &clk_branch2_ops, 3268 }, 3269 }, 3270 }; 3271 3272 static struct clk_branch gcc_usb_hs_phy_cfg_ahb_clk = { 3273 .halt_reg = 0x41030, 3274 .clkr = { 3275 .enable_reg = 0x41030, 3276 .enable_mask = BIT(0), 3277 .hw.init = &(struct clk_init_data) { 3278 .name = "gcc_usb_hs_phy_cfg_ahb_clk", 3279 .ops = &clk_branch2_ops, 3280 }, 3281 }, 3282 }; 3283 3284 static struct clk_branch gcc_usb_fs_ahb_clk = { 3285 .halt_reg = 0x3f008, 3286 .clkr = { 3287 .enable_reg = 0x3f008, 3288 .enable_mask = BIT(0), 3289 .hw.init = &(struct clk_init_data) { 3290 .name = "gcc_usb_fs_ahb_clk", 3291 .ops = &clk_branch2_ops, 3292 }, 3293 }, 3294 }; 3295 3296 static struct clk_branch gcc_usb_fs_ic_clk = { 3297 .halt_reg = 0x3f030, 3298 .clkr = { 3299 .enable_reg = 0x3f030, 3300 .enable_mask = BIT(0), 3301 .hw.init = &(struct clk_init_data) { 3302 .name = "gcc_usb_fs_ic_clk", 3303 .parent_hws = (const struct clk_hw *[]) { 3304 &usb_fs_ic_clk_src.clkr.hw, 3305 }, 3306 .num_parents = 1, 3307 .flags = CLK_SET_RATE_PARENT, 3308 .ops = &clk_branch2_ops, 3309 }, 3310 }, 3311 }; 3312 3313 static struct clk_branch gcc_usb_fs_system_clk = { 3314 .halt_reg = 0x3f004, 3315 .clkr = { 3316 .enable_reg = 0x3f004, 3317 .enable_mask = BIT(0), 3318 .hw.init = &(struct clk_init_data) { 3319 .name = "gcc_usb_fs_system_clk", 3320 .parent_hws = (const struct clk_hw *[]) { 3321 &usb_fs_system_clk_src.clkr.hw, 3322 }, 3323 .num_parents = 1, 3324 .flags = CLK_SET_RATE_PARENT, 3325 .ops = &clk_branch2_ops, 3326 }, 3327 }, 3328 }; 3329 3330 static struct clk_branch gcc_usb_hs_ahb_clk = { 3331 .halt_reg = 0x41008, 3332 .clkr = { 3333 .enable_reg = 0x41008, 3334 .enable_mask = BIT(0), 3335 .hw.init = &(struct clk_init_data) { 3336 .name = "gcc_usb_hs_ahb_clk", 3337 .ops = &clk_branch2_ops, 3338 }, 3339 }, 3340 }; 3341 3342 static struct clk_branch gcc_usb_hs_system_clk = { 3343 .halt_reg = 0x41004, 3344 .clkr = { 3345 .enable_reg = 0x41004, 3346 .enable_mask = BIT(0), 3347 .hw.init = &(struct clk_init_data) { 3348 .name = "gcc_usb_hs_system_clk", 3349 .parent_hws = (const struct clk_hw *[]) { 3350 &usb_hs_system_clk_src.clkr.hw, 3351 }, 3352 .num_parents = 1, 3353 .flags = CLK_SET_RATE_PARENT, 3354 .ops = &clk_branch2_ops, 3355 }, 3356 }, 3357 }; 3358 3359 static struct clk_branch gcc_venus0_ahb_clk = { 3360 .halt_reg = 0x4c020, 3361 .clkr = { 3362 .enable_reg = 0x4c020, 3363 .enable_mask = BIT(0), 3364 .hw.init = &(struct clk_init_data) { 3365 .name = "gcc_venus0_ahb_clk", 3366 .ops = &clk_branch2_ops, 3367 }, 3368 }, 3369 }; 3370 3371 static struct clk_branch gcc_venus0_axi_clk = { 3372 .halt_reg = 0x4c024, 3373 .clkr = { 3374 .enable_reg = 0x4c024, 3375 .enable_mask = BIT(0), 3376 .hw.init = &(struct clk_init_data) { 3377 .name = "gcc_venus0_axi_clk", 3378 .ops = &clk_branch2_ops, 3379 }, 3380 }, 3381 }; 3382 3383 static struct clk_branch gcc_venus0_core0_vcodec0_clk = { 3384 .halt_reg = 0x4c02c, 3385 .clkr = { 3386 .enable_reg = 0x4c02c, 3387 .enable_mask = BIT(0), 3388 .hw.init = &(struct clk_init_data) { 3389 .name = "gcc_venus0_core0_vcodec0_clk", 3390 .parent_hws = (const struct clk_hw *[]) { 3391 &vcodec0_clk_src.clkr.hw, 3392 }, 3393 .num_parents = 1, 3394 .flags = CLK_SET_RATE_PARENT, 3395 .ops = &clk_branch2_ops, 3396 }, 3397 }, 3398 }; 3399 3400 static struct clk_branch gcc_venus0_core1_vcodec0_clk = { 3401 .halt_reg = 0x4c034, 3402 .clkr = { 3403 .enable_reg = 0x4c034, 3404 .enable_mask = BIT(0), 3405 .hw.init = &(struct clk_init_data) { 3406 .name = "gcc_venus0_core1_vcodec0_clk", 3407 .parent_hws = (const struct clk_hw *[]) { 3408 &vcodec0_clk_src.clkr.hw, 3409 }, 3410 .num_parents = 1, 3411 .flags = CLK_SET_RATE_PARENT, 3412 .ops = &clk_branch2_ops, 3413 }, 3414 }, 3415 }; 3416 3417 static struct clk_branch gcc_venus0_vcodec0_clk = { 3418 .halt_reg = 0x4c01c, 3419 .clkr = { 3420 .enable_reg = 0x4c01c, 3421 .enable_mask = BIT(0), 3422 .hw.init = &(struct clk_init_data) { 3423 .name = "gcc_venus0_vcodec0_clk", 3424 .parent_hws = (const struct clk_hw *[]) { 3425 &vcodec0_clk_src.clkr.hw, 3426 }, 3427 .num_parents = 1, 3428 .flags = CLK_SET_RATE_PARENT, 3429 .ops = &clk_branch2_ops, 3430 }, 3431 }, 3432 }; 3433 3434 /* Vote clocks */ 3435 static struct clk_branch gcc_apss_ahb_clk = { 3436 .halt_reg = 0x4601c, 3437 .halt_check = BRANCH_HALT_VOTED, 3438 .clkr = { 3439 .enable_reg = 0x45004, 3440 .enable_mask = BIT(14), 3441 .hw.init = &(struct clk_init_data){ 3442 .name = "gcc_apss_ahb_clk", 3443 .ops = &clk_branch2_ops, 3444 }, 3445 }, 3446 }; 3447 3448 static struct clk_branch gcc_apss_axi_clk = { 3449 .halt_reg = 0x46020, 3450 .halt_check = BRANCH_HALT_VOTED, 3451 .clkr = { 3452 .enable_reg = 0x45004, 3453 .enable_mask = BIT(13), 3454 .hw.init = &(struct clk_init_data){ 3455 .name = "gcc_apss_axi_clk", 3456 .ops = &clk_branch2_ops, 3457 }, 3458 }, 3459 }; 3460 3461 static struct clk_branch gcc_blsp1_ahb_clk = { 3462 .halt_reg = 0x1008, 3463 .halt_check = BRANCH_HALT_VOTED, 3464 .clkr = { 3465 .enable_reg = 0x45004, 3466 .enable_mask = BIT(10), 3467 .hw.init = &(struct clk_init_data){ 3468 .name = "gcc_blsp1_ahb_clk", 3469 .ops = &clk_branch2_ops, 3470 }, 3471 }, 3472 }; 3473 3474 static struct clk_branch gcc_blsp2_ahb_clk = { 3475 .halt_reg = 0xb008, 3476 .halt_check = BRANCH_HALT_VOTED, 3477 .clkr = { 3478 .enable_reg = 0x45004, 3479 .enable_mask = BIT(20), 3480 .hw.init = &(struct clk_init_data){ 3481 .name = "gcc_blsp2_ahb_clk", 3482 .ops = &clk_branch2_ops, 3483 }, 3484 }, 3485 }; 3486 3487 static struct clk_branch gcc_prng_ahb_clk = { 3488 .halt_reg = 0x13004, 3489 .halt_check = BRANCH_HALT_VOTED, 3490 .clkr = { 3491 .enable_reg = 0x45004, 3492 .enable_mask = BIT(8), 3493 .hw.init = &(struct clk_init_data){ 3494 .name = "gcc_prng_ahb_clk", 3495 .ops = &clk_branch2_ops, 3496 }, 3497 }, 3498 }; 3499 3500 static struct clk_branch gcc_boot_rom_ahb_clk = { 3501 .halt_reg = 0x1300c, 3502 .halt_check = BRANCH_HALT_VOTED, 3503 .clkr = { 3504 .enable_reg = 0x45004, 3505 .enable_mask = BIT(7), 3506 .hw.init = &(struct clk_init_data){ 3507 .name = "gcc_boot_rom_ahb_clk", 3508 .ops = &clk_branch2_ops, 3509 }, 3510 }, 3511 }; 3512 3513 static struct clk_branch gcc_crypto_ahb_clk = { 3514 .halt_reg = 0x16024, 3515 .halt_check = BRANCH_HALT_VOTED, 3516 .clkr = { 3517 .enable_reg = 0x45004, 3518 .enable_mask = BIT(0), 3519 .hw.init = &(struct clk_init_data){ 3520 .name = "gcc_crypto_ahb_clk", 3521 .ops = &clk_branch2_ops, 3522 }, 3523 }, 3524 }; 3525 3526 static struct clk_branch gcc_crypto_axi_clk = { 3527 .halt_reg = 0x16020, 3528 .halt_check = BRANCH_HALT_VOTED, 3529 .clkr = { 3530 .enable_reg = 0x45004, 3531 .enable_mask = BIT(1), 3532 .hw.init = &(struct clk_init_data){ 3533 .name = "gcc_crypto_axi_clk", 3534 .ops = &clk_branch2_ops, 3535 }, 3536 }, 3537 }; 3538 3539 static struct clk_branch gcc_crypto_clk = { 3540 .halt_reg = 0x1601c, 3541 .halt_check = BRANCH_HALT_VOTED, 3542 .clkr = { 3543 .enable_reg = 0x45004, 3544 .enable_mask = BIT(2), 3545 .hw.init = &(struct clk_init_data){ 3546 .name = "gcc_crypto_clk", 3547 .parent_hws = (const struct clk_hw *[]) { 3548 &crypto_clk_src.clkr.hw, 3549 }, 3550 .num_parents = 1, 3551 .flags = CLK_SET_RATE_PARENT, 3552 .ops = &clk_branch2_ops, 3553 }, 3554 }, 3555 }; 3556 3557 static struct clk_branch gcc_cpp_tbu_clk = { 3558 .halt_reg = 0x12040, 3559 .halt_check = BRANCH_HALT_VOTED, 3560 .clkr = { 3561 .enable_reg = 0x4500c, 3562 .enable_mask = BIT(14), 3563 .hw.init = &(struct clk_init_data){ 3564 .name = "gcc_cpp_tbu_clk", 3565 .ops = &clk_branch2_ops, 3566 }, 3567 }, 3568 }; 3569 3570 static struct clk_branch gcc_gfx_1_tbu_clk = { 3571 .halt_reg = 0x12098, 3572 .halt_check = BRANCH_HALT_VOTED, 3573 .clkr = { 3574 .enable_reg = 0x4500c, 3575 .enable_mask = BIT(19), 3576 .hw.init = &(struct clk_init_data){ 3577 .name = "gcc_gfx_1_tbu_clk", 3578 .ops = &clk_branch2_ops, 3579 }, 3580 }, 3581 }; 3582 3583 static struct clk_branch gcc_gfx_tbu_clk = { 3584 .halt_reg = 0x12010, 3585 .halt_check = BRANCH_HALT_VOTED, 3586 .clkr = { 3587 .enable_reg = 0x4500c, 3588 .enable_mask = BIT(3), 3589 .hw.init = &(struct clk_init_data){ 3590 .name = "gcc_gfx_tbu_clk", 3591 .ops = &clk_branch2_ops, 3592 }, 3593 }, 3594 }; 3595 3596 static struct clk_branch gcc_gfx_tcu_clk = { 3597 .halt_reg = 0x12020, 3598 .halt_check = BRANCH_HALT_VOTED, 3599 .clkr = { 3600 .enable_reg = 0x4500c, 3601 .enable_mask = BIT(2), 3602 .hw.init = &(struct clk_init_data){ 3603 .name = "gcc_gfx_tcu_clk", 3604 .ops = &clk_branch2_ops, 3605 }, 3606 }, 3607 }; 3608 3609 static struct clk_branch gcc_apss_tcu_clk = { 3610 .halt_reg = 0x12018, 3611 .halt_check = BRANCH_HALT_VOTED, 3612 .clkr = { 3613 .enable_reg = 0x4500c, 3614 .enable_mask = BIT(1), 3615 .hw.init = &(struct clk_init_data){ 3616 .name = "gcc_apss_tcu_clk", 3617 .ops = &clk_branch2_ops, 3618 }, 3619 }, 3620 }; 3621 3622 static struct clk_branch gcc_gtcu_ahb_clk = { 3623 .halt_reg = 0x12044, 3624 .halt_check = BRANCH_HALT_VOTED, 3625 .clkr = { 3626 .enable_reg = 0x4500c, 3627 .enable_mask = BIT(13), 3628 .hw.init = &(struct clk_init_data){ 3629 .name = "gcc_gtcu_ahb_clk", 3630 .ops = &clk_branch2_ops, 3631 }, 3632 }, 3633 }; 3634 3635 static struct clk_branch gcc_jpeg_tbu_clk = { 3636 .halt_reg = 0x12034, 3637 .halt_check = BRANCH_HALT_VOTED, 3638 .clkr = { 3639 .enable_reg = 0x4500c, 3640 .enable_mask = BIT(10), 3641 .hw.init = &(struct clk_init_data){ 3642 .name = "gcc_jpeg_tbu_clk", 3643 .ops = &clk_branch2_ops, 3644 }, 3645 }, 3646 }; 3647 3648 static struct clk_branch gcc_mdp_rt_tbu_clk = { 3649 .halt_reg = 0x1204c, 3650 .halt_check = BRANCH_HALT_VOTED, 3651 .clkr = { 3652 .enable_reg = 0x4500c, 3653 .enable_mask = BIT(15), 3654 .hw.init = &(struct clk_init_data){ 3655 .name = "gcc_mdp_rt_tbu_clk", 3656 .ops = &clk_branch2_ops, 3657 }, 3658 }, 3659 }; 3660 3661 static struct clk_branch gcc_mdp_tbu_clk = { 3662 .halt_reg = 0x1201c, 3663 .halt_check = BRANCH_HALT_VOTED, 3664 .clkr = { 3665 .enable_reg = 0x4500c, 3666 .enable_mask = BIT(4), 3667 .hw.init = &(struct clk_init_data){ 3668 .name = "gcc_mdp_tbu_clk", 3669 .ops = &clk_branch2_ops, 3670 }, 3671 }, 3672 }; 3673 3674 static struct clk_branch gcc_smmu_cfg_clk = { 3675 .halt_reg = 0x12038, 3676 .halt_check = BRANCH_HALT_VOTED, 3677 .clkr = { 3678 .enable_reg = 0x4500c, 3679 .enable_mask = BIT(12), 3680 .hw.init = &(struct clk_init_data){ 3681 .name = "gcc_smmu_cfg_clk", 3682 .ops = &clk_branch2_ops, 3683 }, 3684 }, 3685 }; 3686 3687 static struct clk_branch gcc_venus_1_tbu_clk = { 3688 .halt_reg = 0x1209c, 3689 .halt_check = BRANCH_HALT_VOTED, 3690 .clkr = { 3691 .enable_reg = 0x4500c, 3692 .enable_mask = BIT(20), 3693 .hw.init = &(struct clk_init_data){ 3694 .name = "gcc_venus_1_tbu_clk", 3695 .ops = &clk_branch2_ops, 3696 }, 3697 }, 3698 }; 3699 3700 static struct clk_branch gcc_venus_tbu_clk = { 3701 .halt_reg = 0x12014, 3702 .halt_check = BRANCH_HALT_VOTED, 3703 .clkr = { 3704 .enable_reg = 0x4500c, 3705 .enable_mask = BIT(5), 3706 .hw.init = &(struct clk_init_data){ 3707 .name = "gcc_venus_tbu_clk", 3708 .ops = &clk_branch2_ops, 3709 }, 3710 }, 3711 }; 3712 3713 static struct clk_branch gcc_vfe1_tbu_clk = { 3714 .halt_reg = 0x12090, 3715 .halt_check = BRANCH_HALT_VOTED, 3716 .clkr = { 3717 .enable_reg = 0x4500c, 3718 .enable_mask = BIT(17), 3719 .hw.init = &(struct clk_init_data){ 3720 .name = "gcc_vfe1_tbu_clk", 3721 .ops = &clk_branch2_ops, 3722 }, 3723 }, 3724 }; 3725 3726 static struct clk_branch gcc_vfe_tbu_clk = { 3727 .halt_reg = 0x1203c, 3728 .halt_check = BRANCH_HALT_VOTED, 3729 .clkr = { 3730 .enable_reg = 0x4500c, 3731 .enable_mask = BIT(9), 3732 .hw.init = &(struct clk_init_data){ 3733 .name = "gcc_vfe_tbu_clk", 3734 .ops = &clk_branch2_ops, 3735 }, 3736 }, 3737 }; 3738 3739 static struct gdsc venus_gdsc = { 3740 .gdscr = 0x4c018, 3741 .cxcs = (unsigned int []){ 0x4c024, 0x4c01c }, 3742 .cxc_count = 2, 3743 .pd = { 3744 .name = "venus_gdsc", 3745 }, 3746 .pwrsts = PWRSTS_OFF_ON, 3747 }; 3748 3749 static struct gdsc venus_core0_gdsc = { 3750 .gdscr = 0x4c028, 3751 .cxcs = (unsigned int []){ 0x4c02c }, 3752 .cxc_count = 1, 3753 .pd = { 3754 .name = "venus_core0_gdsc", 3755 }, 3756 .pwrsts = PWRSTS_OFF_ON, 3757 }; 3758 3759 static struct gdsc venus_core1_gdsc = { 3760 .gdscr = 0x4c030, 3761 .pd = { 3762 .name = "venus_core1_gdsc", 3763 }, 3764 .pwrsts = PWRSTS_OFF_ON, 3765 }; 3766 3767 static struct gdsc mdss_gdsc = { 3768 .gdscr = 0x4d078, 3769 .cxcs = (unsigned int []){ 0x4d080, 0x4d088 }, 3770 .cxc_count = 2, 3771 .pd = { 3772 .name = "mdss_gdsc", 3773 }, 3774 .pwrsts = PWRSTS_OFF_ON, 3775 }; 3776 3777 static struct gdsc jpeg_gdsc = { 3778 .gdscr = 0x5701c, 3779 .cxcs = (unsigned int []){ 0x57020, 0x57028 }, 3780 .cxc_count = 2, 3781 .pd = { 3782 .name = "jpeg_gdsc", 3783 }, 3784 .pwrsts = PWRSTS_OFF_ON, 3785 }; 3786 3787 static struct gdsc vfe0_gdsc = { 3788 .gdscr = 0x58034, 3789 .cxcs = (unsigned int []){ 0x58038, 0x58048, 0x5600c, 0x58050 }, 3790 .cxc_count = 4, 3791 .pd = { 3792 .name = "vfe0_gdsc", 3793 }, 3794 .pwrsts = PWRSTS_OFF_ON, 3795 }; 3796 3797 static struct gdsc vfe1_gdsc = { 3798 .gdscr = 0x5806c, 3799 .cxcs = (unsigned int []){ 0x5805c, 0x58068, 0x5600c, 0x58074 }, 3800 .cxc_count = 4, 3801 .pd = { 3802 .name = "vfe1_gdsc", 3803 }, 3804 .pwrsts = PWRSTS_OFF_ON, 3805 }; 3806 3807 static struct gdsc cpp_gdsc = { 3808 .gdscr = 0x58078, 3809 .cxcs = (unsigned int []){ 0x5803c, 0x58064 }, 3810 .cxc_count = 2, 3811 .pd = { 3812 .name = "cpp_gdsc", 3813 }, 3814 .pwrsts = PWRSTS_OFF_ON, 3815 }; 3816 3817 static struct gdsc oxili_cx_gdsc = { 3818 .gdscr = 0x5904c, 3819 .cxcs = (unsigned int []){ 0x59020 }, 3820 .cxc_count = 1, 3821 .pd = { 3822 .name = "oxili_cx_gdsc", 3823 }, 3824 .pwrsts = PWRSTS_OFF_ON, 3825 .flags = VOTABLE, 3826 }; 3827 3828 static struct gdsc oxili_gx_gdsc = { 3829 .gdscr = 0x5901c, 3830 .clamp_io_ctrl = 0x5b00c, 3831 .cxcs = (unsigned int []){ 0x59000, 0x59024 }, 3832 .cxc_count = 2, 3833 .pd = { 3834 .name = "oxili_gx_gdsc", 3835 }, 3836 .pwrsts = PWRSTS_OFF_ON, 3837 .supply = "vdd_gfx", 3838 .flags = CLAMP_IO, 3839 }; 3840 3841 static struct clk_regmap *gcc_msm8976_clocks[] = { 3842 [GPLL0] = &gpll0.clkr, 3843 [GPLL2] = &gpll2.clkr, 3844 [GPLL3] = &gpll3.clkr, 3845 [GPLL4] = &gpll4.clkr, 3846 [GPLL6] = &gpll6.clkr, 3847 [GPLL0_CLK_SRC] = &gpll0_vote, 3848 [GPLL2_CLK_SRC] = &gpll2_vote, 3849 [GPLL3_CLK_SRC] = &gpll3_vote, 3850 [GPLL4_CLK_SRC] = &gpll4_vote, 3851 [GPLL6_CLK_SRC] = &gpll6_vote, 3852 [GCC_BLSP1_QUP1_SPI_APPS_CLK] = &gcc_blsp1_qup1_spi_apps_clk.clkr, 3853 [GCC_BLSP1_QUP1_I2C_APPS_CLK] = &gcc_blsp1_qup1_i2c_apps_clk.clkr, 3854 [GCC_BLSP1_QUP2_I2C_APPS_CLK] = &gcc_blsp1_qup2_i2c_apps_clk.clkr, 3855 [GCC_BLSP1_QUP2_SPI_APPS_CLK] = &gcc_blsp1_qup2_spi_apps_clk.clkr, 3856 [GCC_BLSP1_QUP3_I2C_APPS_CLK] = &gcc_blsp1_qup3_i2c_apps_clk.clkr, 3857 [GCC_BLSP1_QUP3_SPI_APPS_CLK] = &gcc_blsp1_qup3_spi_apps_clk.clkr, 3858 [GCC_BLSP1_QUP4_I2C_APPS_CLK] = &gcc_blsp1_qup4_i2c_apps_clk.clkr, 3859 [GCC_BLSP1_QUP4_SPI_APPS_CLK] = &gcc_blsp1_qup4_spi_apps_clk.clkr, 3860 [GCC_BLSP1_UART1_APPS_CLK] = &gcc_blsp1_uart1_apps_clk.clkr, 3861 [GCC_BLSP1_UART2_APPS_CLK] = &gcc_blsp1_uart2_apps_clk.clkr, 3862 [GCC_BLSP2_QUP1_I2C_APPS_CLK] = &gcc_blsp2_qup1_i2c_apps_clk.clkr, 3863 [GCC_BLSP2_QUP1_SPI_APPS_CLK] = &gcc_blsp2_qup1_spi_apps_clk.clkr, 3864 [GCC_BLSP2_QUP2_I2C_APPS_CLK] = &gcc_blsp2_qup2_i2c_apps_clk.clkr, 3865 [GCC_BLSP2_QUP2_SPI_APPS_CLK] = &gcc_blsp2_qup2_spi_apps_clk.clkr, 3866 [GCC_BLSP2_QUP3_I2C_APPS_CLK] = &gcc_blsp2_qup3_i2c_apps_clk.clkr, 3867 [GCC_BLSP2_QUP3_SPI_APPS_CLK] = &gcc_blsp2_qup3_spi_apps_clk.clkr, 3868 [GCC_BLSP2_QUP4_I2C_APPS_CLK] = &gcc_blsp2_qup4_i2c_apps_clk.clkr, 3869 [GCC_BLSP2_QUP4_SPI_APPS_CLK] = &gcc_blsp2_qup4_spi_apps_clk.clkr, 3870 [GCC_BLSP2_UART1_APPS_CLK] = &gcc_blsp2_uart1_apps_clk.clkr, 3871 [GCC_BLSP2_UART2_APPS_CLK] = &gcc_blsp2_uart2_apps_clk.clkr, 3872 [GCC_CAMSS_CCI_AHB_CLK] = &gcc_camss_cci_ahb_clk.clkr, 3873 [GCC_CAMSS_CCI_CLK] = &gcc_camss_cci_clk.clkr, 3874 [GCC_CAMSS_CPP_AHB_CLK] = &gcc_camss_cpp_ahb_clk.clkr, 3875 [GCC_CAMSS_CPP_AXI_CLK] = &gcc_camss_cpp_axi_clk.clkr, 3876 [GCC_CAMSS_CPP_CLK] = &gcc_camss_cpp_clk.clkr, 3877 [GCC_CAMSS_CSI0_AHB_CLK] = &gcc_camss_csi0_ahb_clk.clkr, 3878 [GCC_CAMSS_CSI0_CLK] = &gcc_camss_csi0_clk.clkr, 3879 [GCC_CAMSS_CSI0PHY_CLK] = &gcc_camss_csi0phy_clk.clkr, 3880 [GCC_CAMSS_CSI0PIX_CLK] = &gcc_camss_csi0pix_clk.clkr, 3881 [GCC_CAMSS_CSI0RDI_CLK] = &gcc_camss_csi0rdi_clk.clkr, 3882 [GCC_CAMSS_CSI1_AHB_CLK] = &gcc_camss_csi1_ahb_clk.clkr, 3883 [GCC_CAMSS_CSI1_CLK] = &gcc_camss_csi1_clk.clkr, 3884 [GCC_CAMSS_CSI1PHY_CLK] = &gcc_camss_csi1phy_clk.clkr, 3885 [GCC_CAMSS_CSI1PIX_CLK] = &gcc_camss_csi1pix_clk.clkr, 3886 [GCC_CAMSS_CSI1RDI_CLK] = &gcc_camss_csi1rdi_clk.clkr, 3887 [GCC_CAMSS_CSI2_AHB_CLK] = &gcc_camss_csi2_ahb_clk.clkr, 3888 [GCC_CAMSS_CSI2_CLK] = &gcc_camss_csi2_clk.clkr, 3889 [GCC_CAMSS_CSI2PHY_CLK] = &gcc_camss_csi2phy_clk.clkr, 3890 [GCC_CAMSS_CSI2PIX_CLK] = &gcc_camss_csi2pix_clk.clkr, 3891 [GCC_CAMSS_CSI2RDI_CLK] = &gcc_camss_csi2rdi_clk.clkr, 3892 [GCC_CAMSS_CSI_VFE0_CLK] = &gcc_camss_csi_vfe0_clk.clkr, 3893 [GCC_CAMSS_CSI_VFE1_CLK] = &gcc_camss_csi_vfe1_clk.clkr, 3894 [GCC_CAMSS_GP0_CLK] = &gcc_camss_gp0_clk.clkr, 3895 [GCC_CAMSS_GP1_CLK] = &gcc_camss_gp1_clk.clkr, 3896 [GCC_CAMSS_ISPIF_AHB_CLK] = &gcc_camss_ispif_ahb_clk.clkr, 3897 [GCC_CAMSS_JPEG0_CLK] = &gcc_camss_jpeg0_clk.clkr, 3898 [GCC_CAMSS_JPEG_AHB_CLK] = &gcc_camss_jpeg_ahb_clk.clkr, 3899 [GCC_CAMSS_JPEG_AXI_CLK] = &gcc_camss_jpeg_axi_clk.clkr, 3900 [GCC_CAMSS_MCLK0_CLK] = &gcc_camss_mclk0_clk.clkr, 3901 [GCC_CAMSS_MCLK1_CLK] = &gcc_camss_mclk1_clk.clkr, 3902 [GCC_CAMSS_MCLK2_CLK] = &gcc_camss_mclk2_clk.clkr, 3903 [GCC_CAMSS_MICRO_AHB_CLK] = &gcc_camss_micro_ahb_clk.clkr, 3904 [GCC_CAMSS_CSI0PHYTIMER_CLK] = &gcc_camss_csi0phytimer_clk.clkr, 3905 [GCC_CAMSS_CSI1PHYTIMER_CLK] = &gcc_camss_csi1phytimer_clk.clkr, 3906 [GCC_CAMSS_AHB_CLK] = &gcc_camss_ahb_clk.clkr, 3907 [GCC_CAMSS_TOP_AHB_CLK] = &gcc_camss_top_ahb_clk.clkr, 3908 [GCC_CAMSS_VFE0_CLK] = &gcc_camss_vfe0_clk.clkr, 3909 [GCC_CAMSS_VFE_AHB_CLK] = &gcc_camss_vfe_ahb_clk.clkr, 3910 [GCC_CAMSS_VFE_AXI_CLK] = &gcc_camss_vfe_axi_clk.clkr, 3911 [GCC_CAMSS_VFE1_AHB_CLK] = &gcc_camss_vfe1_ahb_clk.clkr, 3912 [GCC_CAMSS_VFE1_AXI_CLK] = &gcc_camss_vfe1_axi_clk.clkr, 3913 [GCC_CAMSS_VFE1_CLK] = &gcc_camss_vfe1_clk.clkr, 3914 [GCC_DCC_CLK] = &gcc_dcc_clk.clkr, 3915 [GCC_GP1_CLK] = &gcc_gp1_clk.clkr, 3916 [GCC_GP2_CLK] = &gcc_gp2_clk.clkr, 3917 [GCC_GP3_CLK] = &gcc_gp3_clk.clkr, 3918 [GCC_MDSS_AHB_CLK] = &gcc_mdss_ahb_clk.clkr, 3919 [GCC_MDSS_AXI_CLK] = &gcc_mdss_axi_clk.clkr, 3920 [GCC_MDSS_ESC0_CLK] = &gcc_mdss_esc0_clk.clkr, 3921 [GCC_MDSS_ESC1_CLK] = &gcc_mdss_esc1_clk.clkr, 3922 [GCC_MDSS_MDP_CLK] = &gcc_mdss_mdp_clk.clkr, 3923 [GCC_MDSS_VSYNC_CLK] = &gcc_mdss_vsync_clk.clkr, 3924 [GCC_MSS_CFG_AHB_CLK] = &gcc_mss_cfg_ahb_clk.clkr, 3925 [GCC_MSS_Q6_BIMC_AXI_CLK] = &gcc_mss_q6_bimc_axi_clk.clkr, 3926 [GCC_PDM2_CLK] = &gcc_pdm2_clk.clkr, 3927 [GCC_PRNG_AHB_CLK] = &gcc_prng_ahb_clk.clkr, 3928 [GCC_PDM_AHB_CLK] = &gcc_pdm_ahb_clk.clkr, 3929 [GCC_RBCPR_GFX_AHB_CLK] = &gcc_rbcpr_gfx_ahb_clk.clkr, 3930 [GCC_RBCPR_GFX_CLK] = &gcc_rbcpr_gfx_clk.clkr, 3931 [GCC_SDCC1_AHB_CLK] = &gcc_sdcc1_ahb_clk.clkr, 3932 [GCC_SDCC1_APPS_CLK] = &gcc_sdcc1_apps_clk.clkr, 3933 [GCC_SDCC1_ICE_CORE_CLK] = &gcc_sdcc1_ice_core_clk.clkr, 3934 [GCC_SDCC2_AHB_CLK] = &gcc_sdcc2_ahb_clk.clkr, 3935 [GCC_SDCC2_APPS_CLK] = &gcc_sdcc2_apps_clk.clkr, 3936 [GCC_SDCC3_AHB_CLK] = &gcc_sdcc3_ahb_clk.clkr, 3937 [GCC_SDCC3_APPS_CLK] = &gcc_sdcc3_apps_clk.clkr, 3938 [GCC_USB2A_PHY_SLEEP_CLK] = &gcc_usb2a_phy_sleep_clk.clkr, 3939 [GCC_USB_HS_PHY_CFG_AHB_CLK] = &gcc_usb_hs_phy_cfg_ahb_clk.clkr, 3940 [GCC_USB_FS_AHB_CLK] = &gcc_usb_fs_ahb_clk.clkr, 3941 [GCC_USB_FS_IC_CLK] = &gcc_usb_fs_ic_clk.clkr, 3942 [GCC_USB_FS_SYSTEM_CLK] = &gcc_usb_fs_system_clk.clkr, 3943 [GCC_USB_HS_AHB_CLK] = &gcc_usb_hs_ahb_clk.clkr, 3944 [GCC_USB_HS_SYSTEM_CLK] = &gcc_usb_hs_system_clk.clkr, 3945 [GCC_VENUS0_AHB_CLK] = &gcc_venus0_ahb_clk.clkr, 3946 [GCC_VENUS0_AXI_CLK] = &gcc_venus0_axi_clk.clkr, 3947 [GCC_VENUS0_CORE0_VCODEC0_CLK] = &gcc_venus0_core0_vcodec0_clk.clkr, 3948 [GCC_VENUS0_CORE1_VCODEC0_CLK] = &gcc_venus0_core1_vcodec0_clk.clkr, 3949 [GCC_VENUS0_VCODEC0_CLK] = &gcc_venus0_vcodec0_clk.clkr, 3950 [GCC_APSS_AHB_CLK] = &gcc_apss_ahb_clk.clkr, 3951 [GCC_APSS_AXI_CLK] = &gcc_apss_axi_clk.clkr, 3952 [GCC_BLSP1_AHB_CLK] = &gcc_blsp1_ahb_clk.clkr, 3953 [GCC_BLSP2_AHB_CLK] = &gcc_blsp2_ahb_clk.clkr, 3954 [GCC_BOOT_ROM_AHB_CLK] = &gcc_boot_rom_ahb_clk.clkr, 3955 [GCC_CRYPTO_AHB_CLK] = &gcc_crypto_ahb_clk.clkr, 3956 [GCC_CRYPTO_AXI_CLK] = &gcc_crypto_axi_clk.clkr, 3957 [GCC_CRYPTO_CLK] = &gcc_crypto_clk.clkr, 3958 [GCC_CPP_TBU_CLK] = &gcc_cpp_tbu_clk.clkr, 3959 [GCC_APSS_TCU_CLK] = &gcc_apss_tcu_clk.clkr, 3960 [GCC_JPEG_TBU_CLK] = &gcc_jpeg_tbu_clk.clkr, 3961 [GCC_MDP_RT_TBU_CLK] = &gcc_mdp_rt_tbu_clk.clkr, 3962 [GCC_MDP_TBU_CLK] = &gcc_mdp_tbu_clk.clkr, 3963 [GCC_SMMU_CFG_CLK] = &gcc_smmu_cfg_clk.clkr, 3964 [GCC_VENUS_1_TBU_CLK] = &gcc_venus_1_tbu_clk.clkr, 3965 [GCC_VENUS_TBU_CLK] = &gcc_venus_tbu_clk.clkr, 3966 [GCC_VFE1_TBU_CLK] = &gcc_vfe1_tbu_clk.clkr, 3967 [GCC_VFE_TBU_CLK] = &gcc_vfe_tbu_clk.clkr, 3968 [GCC_APS_0_CLK] = &gcc_aps_0_clk.clkr, 3969 [GCC_APS_1_CLK] = &gcc_aps_1_clk.clkr, 3970 [APS_0_CLK_SRC] = &aps_0_clk_src.clkr, 3971 [APS_1_CLK_SRC] = &aps_1_clk_src.clkr, 3972 [APSS_AHB_CLK_SRC] = &apss_ahb_clk_src.clkr, 3973 [BLSP1_QUP1_I2C_APPS_CLK_SRC] = &blsp1_qup1_i2c_apps_clk_src.clkr, 3974 [BLSP1_QUP1_SPI_APPS_CLK_SRC] = &blsp1_qup1_spi_apps_clk_src.clkr, 3975 [BLSP1_QUP2_I2C_APPS_CLK_SRC] = &blsp1_qup2_i2c_apps_clk_src.clkr, 3976 [BLSP1_QUP2_SPI_APPS_CLK_SRC] = &blsp1_qup2_spi_apps_clk_src.clkr, 3977 [BLSP1_QUP3_I2C_APPS_CLK_SRC] = &blsp1_qup3_i2c_apps_clk_src.clkr, 3978 [BLSP1_QUP3_SPI_APPS_CLK_SRC] = &blsp1_qup3_spi_apps_clk_src.clkr, 3979 [BLSP1_QUP4_I2C_APPS_CLK_SRC] = &blsp1_qup4_i2c_apps_clk_src.clkr, 3980 [BLSP1_QUP4_SPI_APPS_CLK_SRC] = &blsp1_qup4_spi_apps_clk_src.clkr, 3981 [BLSP1_UART1_APPS_CLK_SRC] = &blsp1_uart1_apps_clk_src.clkr, 3982 [BLSP1_UART2_APPS_CLK_SRC] = &blsp1_uart2_apps_clk_src.clkr, 3983 [BLSP2_QUP1_I2C_APPS_CLK_SRC] = &blsp2_qup1_i2c_apps_clk_src.clkr, 3984 [BLSP2_QUP1_SPI_APPS_CLK_SRC] = &blsp2_qup1_spi_apps_clk_src.clkr, 3985 [BLSP2_QUP2_I2C_APPS_CLK_SRC] = &blsp2_qup2_i2c_apps_clk_src.clkr, 3986 [BLSP2_QUP2_SPI_APPS_CLK_SRC] = &blsp2_qup2_spi_apps_clk_src.clkr, 3987 [BLSP2_QUP3_I2C_APPS_CLK_SRC] = &blsp2_qup3_i2c_apps_clk_src.clkr, 3988 [BLSP2_QUP3_SPI_APPS_CLK_SRC] = &blsp2_qup3_spi_apps_clk_src.clkr, 3989 [BLSP2_QUP4_I2C_APPS_CLK_SRC] = &blsp2_qup4_i2c_apps_clk_src.clkr, 3990 [BLSP2_QUP4_SPI_APPS_CLK_SRC] = &blsp2_qup4_spi_apps_clk_src.clkr, 3991 [BLSP2_UART1_APPS_CLK_SRC] = &blsp2_uart1_apps_clk_src.clkr, 3992 [BLSP2_UART2_APPS_CLK_SRC] = &blsp2_uart2_apps_clk_src.clkr, 3993 [CCI_CLK_SRC] = &cci_clk_src.clkr, 3994 [CPP_CLK_SRC] = &cpp_clk_src.clkr, 3995 [CSI0_CLK_SRC] = &csi0_clk_src.clkr, 3996 [CSI1_CLK_SRC] = &csi1_clk_src.clkr, 3997 [CSI2_CLK_SRC] = &csi2_clk_src.clkr, 3998 [CAMSS_GP0_CLK_SRC] = &camss_gp0_clk_src.clkr, 3999 [CAMSS_GP1_CLK_SRC] = &camss_gp1_clk_src.clkr, 4000 [JPEG0_CLK_SRC] = &jpeg0_clk_src.clkr, 4001 [MCLK0_CLK_SRC] = &mclk0_clk_src.clkr, 4002 [MCLK1_CLK_SRC] = &mclk1_clk_src.clkr, 4003 [MCLK2_CLK_SRC] = &mclk2_clk_src.clkr, 4004 [CSI0PHYTIMER_CLK_SRC] = &csi0phytimer_clk_src.clkr, 4005 [CSI1PHYTIMER_CLK_SRC] = &csi1phytimer_clk_src.clkr, 4006 [CAMSS_TOP_AHB_CLK_SRC] = &camss_top_ahb_clk_src.clkr, 4007 [VFE0_CLK_SRC] = &vfe0_clk_src.clkr, 4008 [VFE1_CLK_SRC] = &vfe1_clk_src.clkr, 4009 [CRYPTO_CLK_SRC] = &crypto_clk_src.clkr, 4010 [GP1_CLK_SRC] = &gp1_clk_src.clkr, 4011 [GP2_CLK_SRC] = &gp2_clk_src.clkr, 4012 [GP3_CLK_SRC] = &gp3_clk_src.clkr, 4013 [ESC0_CLK_SRC] = &esc0_clk_src.clkr, 4014 [ESC1_CLK_SRC] = &esc1_clk_src.clkr, 4015 [MDP_CLK_SRC] = &mdp_clk_src.clkr, 4016 [VSYNC_CLK_SRC] = &vsync_clk_src.clkr, 4017 [PDM2_CLK_SRC] = &pdm2_clk_src.clkr, 4018 [RBCPR_GFX_CLK_SRC] = &rbcpr_gfx_clk_src.clkr, 4019 [SDCC1_APPS_CLK_SRC] = &sdcc1_apps_clk_src.clkr, 4020 [SDCC1_ICE_CORE_CLK_SRC] = &sdcc1_ice_core_clk_src.clkr, 4021 [SDCC2_APPS_CLK_SRC] = &sdcc2_apps_clk_src.clkr, 4022 [SDCC3_APPS_CLK_SRC] = &sdcc3_apps_clk_src.clkr, 4023 [USB_FS_IC_CLK_SRC] = &usb_fs_ic_clk_src.clkr, 4024 [USB_FS_SYSTEM_CLK_SRC] = &usb_fs_system_clk_src.clkr, 4025 [USB_HS_SYSTEM_CLK_SRC] = &usb_hs_system_clk_src.clkr, 4026 [VCODEC0_CLK_SRC] = &vcodec0_clk_src.clkr, 4027 [GCC_MDSS_BYTE0_CLK_SRC] = &byte0_clk_src.clkr, 4028 [GCC_MDSS_BYTE1_CLK_SRC] = &byte1_clk_src.clkr, 4029 [GCC_MDSS_BYTE0_CLK] = &gcc_mdss_byte0_clk.clkr, 4030 [GCC_MDSS_BYTE1_CLK] = &gcc_mdss_byte1_clk.clkr, 4031 [GCC_MDSS_PCLK0_CLK_SRC] = &pclk0_clk_src.clkr, 4032 [GCC_MDSS_PCLK1_CLK_SRC] = &pclk1_clk_src.clkr, 4033 [GCC_MDSS_PCLK0_CLK] = &gcc_mdss_pclk0_clk.clkr, 4034 [GCC_MDSS_PCLK1_CLK] = &gcc_mdss_pclk1_clk.clkr, 4035 [GCC_GFX3D_CLK_SRC] = &gfx3d_clk_src.clkr, 4036 [GCC_GFX3D_OXILI_CLK] = &gcc_oxili_gfx3d_clk.clkr, 4037 [GCC_GFX3D_BIMC_CLK] = &gcc_bimc_gfx_clk.clkr, 4038 [GCC_GFX3D_OXILI_AHB_CLK] = &gcc_oxili_ahb_clk.clkr, 4039 [GCC_GFX3D_OXILI_AON_CLK] = &gcc_oxili_aon_clk.clkr, 4040 [GCC_GFX3D_OXILI_GMEM_CLK] = &gcc_oxili_gmem_clk.clkr, 4041 [GCC_GFX3D_OXILI_TIMER_CLK] = &gcc_oxili_timer_clk.clkr, 4042 [GCC_GFX3D_TBU0_CLK] = &gcc_gfx_tbu_clk.clkr, 4043 [GCC_GFX3D_TBU1_CLK] = &gcc_gfx_1_tbu_clk.clkr, 4044 [GCC_GFX3D_TCU_CLK] = &gcc_gfx_tcu_clk.clkr, 4045 [GCC_GFX3D_GTCU_AHB_CLK] = &gcc_gtcu_ahb_clk.clkr, 4046 }; 4047 4048 static const struct qcom_reset_map gcc_msm8976_resets[] = { 4049 [RST_CAMSS_MICRO_BCR] = { 0x56008 }, 4050 [RST_USB_HS_BCR] = { 0x41000 }, 4051 [RST_QUSB2_PHY_BCR] = { 0x4103c }, 4052 [RST_USB2_HS_PHY_ONLY_BCR] = { 0x41034 }, 4053 [RST_USB_HS_PHY_CFG_AHB_BCR] = { 0x41038 }, 4054 [RST_USB_FS_BCR] = { 0x3f000 }, 4055 [RST_CAMSS_CSI1PIX_BCR] = { 0x4f054 }, 4056 [RST_CAMSS_CSI_VFE1_BCR] = { 0x58070 }, 4057 [RST_CAMSS_VFE1_BCR] = { 0x5807c }, 4058 [RST_CAMSS_CPP_BCR] = { 0x58080 }, 4059 [RST_MSS_BCR] = { 0x71000 }, 4060 }; 4061 4062 static struct gdsc *gcc_msm8976_gdscs[] = { 4063 [VENUS_GDSC] = &venus_gdsc, 4064 [VENUS_CORE0_GDSC] = &venus_core0_gdsc, 4065 [VENUS_CORE1_GDSC] = &venus_core1_gdsc, 4066 [MDSS_GDSC] = &mdss_gdsc, 4067 [JPEG_GDSC] = &jpeg_gdsc, 4068 [VFE0_GDSC] = &vfe0_gdsc, 4069 [VFE1_GDSC] = &vfe1_gdsc, 4070 [CPP_GDSC] = &cpp_gdsc, 4071 [OXILI_GX_GDSC] = &oxili_gx_gdsc, 4072 [OXILI_CX_GDSC] = &oxili_cx_gdsc, 4073 }; 4074 4075 static const struct regmap_config gcc_msm8976_regmap_config = { 4076 .reg_bits = 32, 4077 .reg_stride = 4, 4078 .val_bits = 32, 4079 .max_register = 0x7fffc, 4080 .fast_io = true, 4081 }; 4082 4083 static const struct qcom_cc_desc gcc_msm8976_desc = { 4084 .config = &gcc_msm8976_regmap_config, 4085 .clks = gcc_msm8976_clocks, 4086 .num_clks = ARRAY_SIZE(gcc_msm8976_clocks), 4087 .resets = gcc_msm8976_resets, 4088 .num_resets = ARRAY_SIZE(gcc_msm8976_resets), 4089 .gdscs = gcc_msm8976_gdscs, 4090 .num_gdscs = ARRAY_SIZE(gcc_msm8976_gdscs), 4091 }; 4092 4093 static const struct of_device_id gcc_msm8976_match_table[] = { 4094 { .compatible = "qcom,gcc-msm8976" }, /* Also valid for 8x56 */ 4095 { .compatible = "qcom,gcc-msm8976-v1.1" }, 4096 { } 4097 }; 4098 MODULE_DEVICE_TABLE(of, gcc_msm8976_match_table); 4099 4100 static int gcc_msm8976_probe(struct platform_device *pdev) 4101 { 4102 struct regmap *regmap; 4103 int ret; 4104 4105 if (of_device_is_compatible(pdev->dev.of_node, "qcom,gcc-msm8976-v1.1")) { 4106 sdcc1_apps_clk_src.parent_map = gcc_parent_map_v1_1; 4107 sdcc1_apps_clk_src.freq_tbl = ftbl_sdcc1_8976_v1_1_apps_clk_src; 4108 sdcc1_apps_clk_src.clkr.hw.init = &sdcc1_apps_clk_src_8976v1_1_init; 4109 } 4110 4111 regmap = qcom_cc_map(pdev, &gcc_msm8976_desc); 4112 if (IS_ERR(regmap)) 4113 return PTR_ERR(regmap); 4114 4115 /* Set Sleep and Wakeup cycles to 0 for GMEM clock */ 4116 ret = regmap_update_bits(regmap, gcc_oxili_gmem_clk.clkr.enable_reg, 0xff0, 0); 4117 if (ret) 4118 return ret; 4119 4120 clk_pll_configure_sr_hpm_lp(&gpll3, regmap, &gpll3_config, true); 4121 4122 /* Enable AUX2 clock for APSS */ 4123 ret = regmap_update_bits(regmap, 0x60000, BIT(2), BIT(2)); 4124 if (ret) 4125 return ret; 4126 4127 /* Set Sleep cycles to 0 for OXILI clock */ 4128 ret = regmap_update_bits(regmap, gcc_oxili_gfx3d_clk.clkr.enable_reg, 0xf0, 0); 4129 if (ret) 4130 return ret; 4131 4132 return qcom_cc_really_probe(&pdev->dev, &gcc_msm8976_desc, regmap); 4133 } 4134 4135 static struct platform_driver gcc_msm8976_driver = { 4136 .probe = gcc_msm8976_probe, 4137 .driver = { 4138 .name = "qcom,gcc-msm8976", 4139 .of_match_table = gcc_msm8976_match_table, 4140 }, 4141 }; 4142 4143 static int __init gcc_msm8976_init(void) 4144 { 4145 return platform_driver_register(&gcc_msm8976_driver); 4146 } 4147 core_initcall(gcc_msm8976_init); 4148 4149 static void __exit gcc_msm8976_exit(void) 4150 { 4151 platform_driver_unregister(&gcc_msm8976_driver); 4152 } 4153 module_exit(gcc_msm8976_exit); 4154 4155 MODULE_AUTHOR("AngeloGioacchino Del Regno <angelogioacchino.delregno@somainline.org>"); 4156 MODULE_LICENSE("GPL v2"); 4157 MODULE_DESCRIPTION("QTI MSM8996 Global Clock Controller"); 4158