1 // SPDX-License-Identifier: GPL-2.0 2 /* 3 * Copyright (c) 2018, The Linux Foundation. All rights reserved. 4 */ 5 6 #include <linux/kernel.h> 7 #include <linux/platform_device.h> 8 #include <linux/module.h> 9 #include <linux/of.h> 10 #include <linux/clk-provider.h> 11 #include <linux/regmap.h> 12 #include <linux/reset-controller.h> 13 14 #include <dt-bindings/clock/qcom,gcc-qcs404.h> 15 16 #include "clk-alpha-pll.h" 17 #include "clk-branch.h" 18 #include "clk-pll.h" 19 #include "clk-rcg.h" 20 #include "clk-regmap.h" 21 #include "common.h" 22 #include "gdsc.h" 23 #include "reset.h" 24 25 enum { 26 DT_XO, 27 DT_SLEEP_CLK, 28 DT_PCIE_0_PIPE_CLK, 29 DT_DSI0_PHY_PLL_OUT_DSICLK, 30 DT_DSI0_PHY_PLL_OUT_BYTECLK, 31 DT_HDMI_PHY_PLL_CLK, 32 }; 33 34 enum { 35 P_DSI0_PHY_PLL_OUT_BYTECLK, 36 P_DSI0_PHY_PLL_OUT_DSICLK, 37 P_GPLL0_OUT_MAIN, 38 P_GPLL1_OUT_MAIN, 39 P_GPLL3_OUT_MAIN, 40 P_GPLL4_OUT_MAIN, 41 P_GPLL6_OUT_AUX, 42 P_HDMI_PHY_PLL_CLK, 43 P_PCIE_0_PIPE_CLK, 44 P_SLEEP_CLK, 45 P_XO, 46 }; 47 48 static const struct parent_map gcc_parent_map_1[] = { 49 { P_XO, 0 }, 50 }; 51 52 static const struct clk_parent_data gcc_parent_data_1[] = { 53 { .index = DT_XO, .name = "xo-board" }, 54 }; 55 56 static struct clk_fixed_factor cxo = { 57 .mult = 1, 58 .div = 1, 59 .hw.init = &(struct clk_init_data){ 60 .name = "cxo", 61 .parent_data = gcc_parent_data_1, 62 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 63 .ops = &clk_fixed_factor_ops, 64 }, 65 }; 66 67 static struct clk_alpha_pll gpll0_sleep_clk_src = { 68 .offset = 0x21000, 69 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT], 70 .clkr = { 71 .enable_reg = 0x45008, 72 .enable_mask = BIT(23), 73 .enable_is_inverted = true, 74 .hw.init = &(struct clk_init_data){ 75 .name = "gpll0_sleep_clk_src", 76 .parent_data = gcc_parent_data_1, 77 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 78 .ops = &clk_alpha_pll_ops, 79 }, 80 }, 81 }; 82 83 static struct clk_alpha_pll gpll0_out_main = { 84 .offset = 0x21000, 85 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT], 86 .flags = SUPPORTS_FSM_MODE, 87 .clkr = { 88 .enable_reg = 0x45000, 89 .enable_mask = BIT(0), 90 .hw.init = &(struct clk_init_data){ 91 .name = "gpll0_out_main", 92 .parent_data = gcc_parent_data_1, 93 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 94 .ops = &clk_alpha_pll_ops, 95 }, 96 }, 97 }; 98 99 static struct clk_alpha_pll gpll0_ao_out_main = { 100 .offset = 0x21000, 101 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT], 102 .flags = SUPPORTS_FSM_MODE, 103 .clkr = { 104 .enable_reg = 0x45000, 105 .enable_mask = BIT(0), 106 .hw.init = &(struct clk_init_data){ 107 .name = "gpll0_ao_out_main", 108 .parent_data = gcc_parent_data_1, 109 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 110 .flags = CLK_IS_CRITICAL, 111 .ops = &clk_alpha_pll_fixed_ops, 112 }, 113 }, 114 }; 115 116 static struct clk_alpha_pll gpll1_out_main = { 117 .offset = 0x20000, 118 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT], 119 .clkr = { 120 .enable_reg = 0x45000, 121 .enable_mask = BIT(1), 122 .hw.init = &(struct clk_init_data){ 123 .name = "gpll1_out_main", 124 .parent_data = gcc_parent_data_1, 125 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 126 .ops = &clk_alpha_pll_ops, 127 }, 128 }, 129 }; 130 131 /* 930MHz configuration */ 132 static const struct alpha_pll_config gpll3_config = { 133 .l = 48, 134 .alpha_hi = 0x70, 135 .alpha = 0x0, 136 .alpha_en_mask = BIT(24), 137 .post_div_mask = 0xf << 8, 138 .post_div_val = 0x1 << 8, 139 .vco_mask = 0x3 << 20, 140 .main_output_mask = 0x1, 141 .config_ctl_val = 0x4001055b, 142 }; 143 144 static const struct pll_vco gpll3_vco[] = { 145 { 700000000, 1400000000, 0 }, 146 }; 147 148 static struct clk_alpha_pll gpll3_out_main = { 149 .offset = 0x22000, 150 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT], 151 .vco_table = gpll3_vco, 152 .num_vco = ARRAY_SIZE(gpll3_vco), 153 .clkr = { 154 .hw.init = &(struct clk_init_data){ 155 .name = "gpll3_out_main", 156 .parent_data = gcc_parent_data_1, 157 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 158 .ops = &clk_alpha_pll_ops, 159 }, 160 }, 161 }; 162 163 static struct clk_alpha_pll gpll4_out_main = { 164 .offset = 0x24000, 165 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT], 166 .clkr = { 167 .enable_reg = 0x45000, 168 .enable_mask = BIT(5), 169 .hw.init = &(struct clk_init_data){ 170 .name = "gpll4_out_main", 171 .parent_data = gcc_parent_data_1, 172 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 173 .ops = &clk_alpha_pll_ops, 174 }, 175 }, 176 }; 177 178 static struct clk_pll gpll6 = { 179 .l_reg = 0x37004, 180 .m_reg = 0x37008, 181 .n_reg = 0x3700C, 182 .config_reg = 0x37014, 183 .mode_reg = 0x37000, 184 .status_reg = 0x3701C, 185 .status_bit = 17, 186 .clkr.hw.init = &(struct clk_init_data){ 187 .name = "gpll6", 188 .parent_data = gcc_parent_data_1, 189 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 190 .ops = &clk_pll_ops, 191 }, 192 }; 193 194 static struct clk_regmap gpll6_out_aux = { 195 .enable_reg = 0x45000, 196 .enable_mask = BIT(7), 197 .hw.init = &(struct clk_init_data){ 198 .name = "gpll6_out_aux", 199 .parent_hws = (const struct clk_hw*[]) { 200 &gpll6.clkr.hw, 201 }, 202 .num_parents = 1, 203 .ops = &clk_pll_vote_ops, 204 }, 205 }; 206 207 static const struct parent_map gcc_parent_map_0[] = { 208 { P_XO, 0 }, 209 { P_GPLL0_OUT_MAIN, 1 }, 210 }; 211 212 static const struct clk_parent_data gcc_parent_data_0[] = { 213 { .index = DT_XO, .name = "xo-board" }, 214 { .hw = &gpll0_out_main.clkr.hw }, 215 }; 216 217 static const struct clk_parent_data gcc_parent_data_ao_0[] = { 218 { .index = DT_XO, .name = "xo-board" }, 219 { .hw = &gpll0_ao_out_main.clkr.hw }, 220 }; 221 222 static const struct parent_map gcc_parent_map_2[] = { 223 { P_XO, 0 }, 224 { P_GPLL0_OUT_MAIN, 1 }, 225 { P_GPLL6_OUT_AUX, 2 }, 226 { P_SLEEP_CLK, 6 }, 227 }; 228 229 static const struct clk_parent_data gcc_parent_data_2[] = { 230 { .index = DT_XO, .name = "xo-board" }, 231 { .hw = &gpll0_out_main.clkr.hw }, 232 { .hw = &gpll6_out_aux.hw }, 233 { .index = DT_SLEEP_CLK, .name = "sleep_clk" }, 234 }; 235 236 static const struct parent_map gcc_parent_map_3[] = { 237 { P_XO, 0 }, 238 { P_GPLL0_OUT_MAIN, 1 }, 239 { P_GPLL6_OUT_AUX, 2 }, 240 }; 241 242 static const struct clk_parent_data gcc_parent_data_3[] = { 243 { .index = DT_XO, .name = "xo-board" }, 244 { .hw = &gpll0_out_main.clkr.hw }, 245 { .hw = &gpll6_out_aux.hw }, 246 }; 247 248 static const struct parent_map gcc_parent_map_4[] = { 249 { P_XO, 0 }, 250 { P_GPLL1_OUT_MAIN, 1 }, 251 }; 252 253 static const struct clk_parent_data gcc_parent_data_4[] = { 254 { .index = DT_XO, .name = "xo-board" }, 255 { .hw = &gpll1_out_main.clkr.hw }, 256 }; 257 258 static const struct parent_map gcc_parent_map_5[] = { 259 { P_XO, 0 }, 260 { P_DSI0_PHY_PLL_OUT_BYTECLK, 1 }, 261 }; 262 263 static const struct clk_parent_data gcc_parent_data_5[] = { 264 { .index = DT_XO, .name = "xo-board" }, 265 { .index = DT_DSI0_PHY_PLL_OUT_BYTECLK, .name = "dsi0pllbyte" }, 266 }; 267 268 static const struct parent_map gcc_parent_map_6[] = { 269 { P_XO, 0 }, 270 { P_DSI0_PHY_PLL_OUT_BYTECLK, 2 }, 271 }; 272 273 static const struct clk_parent_data gcc_parent_data_6[] = { 274 { .index = DT_XO, .name = "xo-board" }, 275 { .index = DT_DSI0_PHY_PLL_OUT_BYTECLK, .name = "dsi0pllbyte" }, 276 }; 277 278 static const struct parent_map gcc_parent_map_7[] = { 279 { P_XO, 0 }, 280 { P_GPLL0_OUT_MAIN, 1 }, 281 { P_GPLL3_OUT_MAIN, 2 }, 282 { P_GPLL6_OUT_AUX, 3 }, 283 }; 284 285 static const struct clk_parent_data gcc_parent_data_7[] = { 286 { .index = DT_XO, .name = "xo-board" }, 287 { .hw = &gpll0_out_main.clkr.hw }, 288 { .hw = &gpll3_out_main.clkr.hw }, 289 { .hw = &gpll6_out_aux.hw }, 290 }; 291 292 static const struct parent_map gcc_parent_map_8[] = { 293 { P_XO, 0 }, 294 { P_HDMI_PHY_PLL_CLK, 1 }, 295 }; 296 297 static const struct clk_parent_data gcc_parent_data_8[] = { 298 { .index = DT_XO, .name = "xo-board" }, 299 { .index = DT_HDMI_PHY_PLL_CLK, .name = "hdmi_pll" }, 300 }; 301 302 static const struct parent_map gcc_parent_map_9[] = { 303 { P_XO, 0 }, 304 { P_GPLL0_OUT_MAIN, 1 }, 305 { P_DSI0_PHY_PLL_OUT_DSICLK, 2 }, 306 { P_GPLL6_OUT_AUX, 3 }, 307 }; 308 309 static const struct clk_parent_data gcc_parent_data_9[] = { 310 { .index = DT_XO, .name = "xo-board" }, 311 { .hw = &gpll0_out_main.clkr.hw }, 312 { .index = DT_DSI0_PHY_PLL_OUT_DSICLK, .name = "dsi0pll" }, 313 { .hw = &gpll6_out_aux.hw }, 314 }; 315 316 static const struct parent_map gcc_parent_map_10[] = { 317 { P_XO, 0 }, 318 { P_SLEEP_CLK, 1 }, 319 }; 320 321 static const struct clk_parent_data gcc_parent_data_10[] = { 322 { .index = DT_XO, .name = "xo-board" }, 323 { .index = DT_SLEEP_CLK, .name = "sleep_clk" }, 324 }; 325 326 static const struct parent_map gcc_parent_map_11[] = { 327 { P_XO, 0 }, 328 { P_PCIE_0_PIPE_CLK, 1 }, 329 }; 330 331 static const struct clk_parent_data gcc_parent_data_11[] = { 332 { .index = DT_XO, .name = "xo-board" }, 333 { .fw_name = "pcie_0_pipe_clk", .name = "pcie_0_pipe_clk" }, 334 }; 335 336 static const struct parent_map gcc_parent_map_12[] = { 337 { P_XO, 0 }, 338 { P_DSI0_PHY_PLL_OUT_DSICLK, 1 }, 339 }; 340 341 static const struct clk_parent_data gcc_parent_data_12[] = { 342 { .index = DT_XO, .name = "xo-board" }, 343 { .index = DT_DSI0_PHY_PLL_OUT_DSICLK, .name = "dsi0pll" }, 344 }; 345 346 static const struct parent_map gcc_parent_map_13[] = { 347 { P_XO, 0 }, 348 { P_GPLL0_OUT_MAIN, 1 }, 349 { P_GPLL4_OUT_MAIN, 2 }, 350 { P_GPLL6_OUT_AUX, 3 }, 351 }; 352 353 static const struct clk_parent_data gcc_parent_data_13[] = { 354 { .index = DT_XO, .name = "xo-board" }, 355 { .hw = &gpll0_out_main.clkr.hw }, 356 { .hw = &gpll4_out_main.clkr.hw }, 357 { .hw = &gpll6_out_aux.hw }, 358 }; 359 360 static const struct parent_map gcc_parent_map_14[] = { 361 { P_XO, 0 }, 362 { P_GPLL0_OUT_MAIN, 1 }, 363 }; 364 365 static const struct clk_parent_data gcc_parent_data_14[] = { 366 { .index = DT_XO, .name = "xo-board" }, 367 { .hw = &gpll0_out_main.clkr.hw }, 368 }; 369 370 static const struct parent_map gcc_parent_map_15[] = { 371 { P_XO, 0 }, 372 }; 373 374 static const struct clk_parent_data gcc_parent_data_15[] = { 375 { .index = DT_XO, .name = "xo-board" }, 376 }; 377 378 static const struct parent_map gcc_parent_map_16[] = { 379 { P_XO, 0 }, 380 { P_GPLL0_OUT_MAIN, 1 }, 381 }; 382 383 static const struct clk_parent_data gcc_parent_data_16[] = { 384 { .index = DT_XO, .name = "xo-board" }, 385 { .hw = &gpll0_out_main.clkr.hw }, 386 }; 387 388 static const struct freq_tbl ftbl_apss_ahb_clk_src[] = { 389 F(19200000, P_XO, 1, 0, 0), 390 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 391 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 392 F(133333333, P_GPLL0_OUT_MAIN, 6, 0, 0), 393 { } 394 }; 395 396 static struct clk_rcg2 apss_ahb_clk_src = { 397 .cmd_rcgr = 0x46000, 398 .mnd_width = 0, 399 .hid_width = 5, 400 .parent_map = gcc_parent_map_0, 401 .freq_tbl = ftbl_apss_ahb_clk_src, 402 .clkr.hw.init = &(struct clk_init_data){ 403 .name = "apss_ahb_clk_src", 404 .parent_data = gcc_parent_data_ao_0, 405 .num_parents = ARRAY_SIZE(gcc_parent_data_ao_0), 406 .flags = CLK_IS_CRITICAL, 407 .ops = &clk_rcg2_ops, 408 }, 409 }; 410 411 static const struct freq_tbl ftbl_blsp1_qup0_i2c_apps_clk_src[] = { 412 F(19200000, P_XO, 1, 0, 0), 413 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 414 { } 415 }; 416 417 static struct clk_rcg2 blsp1_qup0_i2c_apps_clk_src = { 418 .cmd_rcgr = 0x602c, 419 .mnd_width = 0, 420 .hid_width = 5, 421 .parent_map = gcc_parent_map_0, 422 .freq_tbl = ftbl_blsp1_qup0_i2c_apps_clk_src, 423 .clkr.hw.init = &(struct clk_init_data){ 424 .name = "blsp1_qup0_i2c_apps_clk_src", 425 .parent_data = gcc_parent_data_0, 426 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 427 .ops = &clk_rcg2_ops, 428 }, 429 }; 430 431 static const struct freq_tbl ftbl_blsp1_qup0_spi_apps_clk_src[] = { 432 F(960000, P_XO, 10, 1, 2), 433 F(4800000, P_XO, 4, 0, 0), 434 F(9600000, P_XO, 2, 0, 0), 435 F(16000000, P_GPLL0_OUT_MAIN, 10, 1, 5), 436 F(19200000, P_XO, 1, 0, 0), 437 F(25000000, P_GPLL0_OUT_MAIN, 16, 1, 2), 438 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 439 { } 440 }; 441 442 static struct clk_rcg2 blsp1_qup0_spi_apps_clk_src = { 443 .cmd_rcgr = 0x6034, 444 .mnd_width = 8, 445 .hid_width = 5, 446 .parent_map = gcc_parent_map_0, 447 .freq_tbl = ftbl_blsp1_qup0_spi_apps_clk_src, 448 .clkr.hw.init = &(struct clk_init_data){ 449 .name = "blsp1_qup0_spi_apps_clk_src", 450 .parent_data = gcc_parent_data_0, 451 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 452 .ops = &clk_rcg2_ops, 453 }, 454 }; 455 456 static struct clk_rcg2 blsp1_qup1_i2c_apps_clk_src = { 457 .cmd_rcgr = 0x200c, 458 .mnd_width = 0, 459 .hid_width = 5, 460 .parent_map = gcc_parent_map_0, 461 .freq_tbl = ftbl_blsp1_qup0_i2c_apps_clk_src, 462 .clkr.hw.init = &(struct clk_init_data){ 463 .name = "blsp1_qup1_i2c_apps_clk_src", 464 .parent_data = gcc_parent_data_0, 465 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 466 .ops = &clk_rcg2_ops, 467 }, 468 }; 469 470 static const struct freq_tbl ftbl_blsp1_qup1_spi_apps_clk_src[] = { 471 F(960000, P_XO, 10, 1, 2), 472 F(4800000, P_XO, 4, 0, 0), 473 F(9600000, P_XO, 2, 0, 0), 474 F(10480000, P_GPLL0_OUT_MAIN, 1, 3, 229), 475 F(16000000, P_GPLL0_OUT_MAIN, 10, 1, 5), 476 F(19200000, P_XO, 1, 0, 0), 477 F(20961000, P_GPLL0_OUT_MAIN, 1, 6, 229), 478 { } 479 }; 480 481 static struct clk_rcg2 blsp1_qup1_spi_apps_clk_src = { 482 .cmd_rcgr = 0x2024, 483 .mnd_width = 8, 484 .hid_width = 5, 485 .parent_map = gcc_parent_map_0, 486 .freq_tbl = ftbl_blsp1_qup1_spi_apps_clk_src, 487 .clkr.hw.init = &(struct clk_init_data){ 488 .name = "blsp1_qup1_spi_apps_clk_src", 489 .parent_data = gcc_parent_data_0, 490 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 491 .ops = &clk_rcg2_ops, 492 }, 493 }; 494 495 static struct clk_rcg2 blsp1_qup2_i2c_apps_clk_src = { 496 .cmd_rcgr = 0x3000, 497 .mnd_width = 0, 498 .hid_width = 5, 499 .parent_map = gcc_parent_map_0, 500 .freq_tbl = ftbl_blsp1_qup0_i2c_apps_clk_src, 501 .clkr.hw.init = &(struct clk_init_data){ 502 .name = "blsp1_qup2_i2c_apps_clk_src", 503 .parent_data = gcc_parent_data_0, 504 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 505 .ops = &clk_rcg2_ops, 506 }, 507 }; 508 509 static const struct freq_tbl ftbl_blsp1_qup2_spi_apps_clk_src[] = { 510 F(960000, P_XO, 10, 1, 2), 511 F(4800000, P_XO, 4, 0, 0), 512 F(9600000, P_XO, 2, 0, 0), 513 F(15000000, P_GPLL0_OUT_MAIN, 1, 3, 160), 514 F(16000000, P_GPLL0_OUT_MAIN, 10, 1, 5), 515 F(19200000, P_XO, 1, 0, 0), 516 F(25000000, P_GPLL0_OUT_MAIN, 16, 1, 2), 517 F(30000000, P_GPLL0_OUT_MAIN, 1, 3, 80), 518 { } 519 }; 520 521 static struct clk_rcg2 blsp1_qup2_spi_apps_clk_src = { 522 .cmd_rcgr = 0x3014, 523 .mnd_width = 8, 524 .hid_width = 5, 525 .parent_map = gcc_parent_map_0, 526 .freq_tbl = ftbl_blsp1_qup2_spi_apps_clk_src, 527 .clkr.hw.init = &(struct clk_init_data){ 528 .name = "blsp1_qup2_spi_apps_clk_src", 529 .parent_data = gcc_parent_data_0, 530 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 531 .ops = &clk_rcg2_ops, 532 }, 533 }; 534 535 static struct clk_rcg2 blsp1_qup3_i2c_apps_clk_src = { 536 .cmd_rcgr = 0x4000, 537 .mnd_width = 0, 538 .hid_width = 5, 539 .parent_map = gcc_parent_map_0, 540 .freq_tbl = ftbl_blsp1_qup0_i2c_apps_clk_src, 541 .clkr.hw.init = &(struct clk_init_data){ 542 .name = "blsp1_qup3_i2c_apps_clk_src", 543 .parent_data = gcc_parent_data_0, 544 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 545 .ops = &clk_rcg2_ops, 546 }, 547 }; 548 549 static struct clk_rcg2 blsp1_qup3_spi_apps_clk_src = { 550 .cmd_rcgr = 0x4024, 551 .mnd_width = 8, 552 .hid_width = 5, 553 .parent_map = gcc_parent_map_0, 554 .freq_tbl = ftbl_blsp1_qup0_spi_apps_clk_src, 555 .clkr.hw.init = &(struct clk_init_data){ 556 .name = "blsp1_qup3_spi_apps_clk_src", 557 .parent_data = gcc_parent_data_0, 558 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 559 .ops = &clk_rcg2_ops, 560 }, 561 }; 562 563 static struct clk_rcg2 blsp1_qup4_i2c_apps_clk_src = { 564 .cmd_rcgr = 0x5000, 565 .mnd_width = 0, 566 .hid_width = 5, 567 .parent_map = gcc_parent_map_0, 568 .freq_tbl = ftbl_blsp1_qup0_i2c_apps_clk_src, 569 .clkr.hw.init = &(struct clk_init_data){ 570 .name = "blsp1_qup4_i2c_apps_clk_src", 571 .parent_data = gcc_parent_data_0, 572 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 573 .ops = &clk_rcg2_ops, 574 }, 575 }; 576 577 static struct clk_rcg2 blsp1_qup4_spi_apps_clk_src = { 578 .cmd_rcgr = 0x5024, 579 .mnd_width = 8, 580 .hid_width = 5, 581 .parent_map = gcc_parent_map_0, 582 .freq_tbl = ftbl_blsp1_qup0_spi_apps_clk_src, 583 .clkr.hw.init = &(struct clk_init_data){ 584 .name = "blsp1_qup4_spi_apps_clk_src", 585 .parent_data = gcc_parent_data_0, 586 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 587 .ops = &clk_rcg2_ops, 588 }, 589 }; 590 591 static const struct freq_tbl ftbl_blsp1_uart0_apps_clk_src[] = { 592 F(3686400, P_GPLL0_OUT_MAIN, 1, 72, 15625), 593 F(7372800, P_GPLL0_OUT_MAIN, 1, 144, 15625), 594 F(14745600, P_GPLL0_OUT_MAIN, 1, 288, 15625), 595 F(16000000, P_GPLL0_OUT_MAIN, 10, 1, 5), 596 F(19200000, P_XO, 1, 0, 0), 597 F(24000000, P_GPLL0_OUT_MAIN, 1, 3, 100), 598 F(25000000, P_GPLL0_OUT_MAIN, 16, 1, 2), 599 F(32000000, P_GPLL0_OUT_MAIN, 1, 1, 25), 600 F(40000000, P_GPLL0_OUT_MAIN, 1, 1, 20), 601 F(46400000, P_GPLL0_OUT_MAIN, 1, 29, 500), 602 F(48000000, P_GPLL0_OUT_MAIN, 1, 3, 50), 603 F(51200000, P_GPLL0_OUT_MAIN, 1, 8, 125), 604 F(56000000, P_GPLL0_OUT_MAIN, 1, 7, 100), 605 F(58982400, P_GPLL0_OUT_MAIN, 1, 1152, 15625), 606 F(60000000, P_GPLL0_OUT_MAIN, 1, 3, 40), 607 F(64000000, P_GPLL0_OUT_MAIN, 1, 2, 25), 608 { } 609 }; 610 611 static struct clk_rcg2 blsp1_uart0_apps_clk_src = { 612 .cmd_rcgr = 0x600c, 613 .mnd_width = 16, 614 .hid_width = 5, 615 .parent_map = gcc_parent_map_0, 616 .freq_tbl = ftbl_blsp1_uart0_apps_clk_src, 617 .clkr.hw.init = &(struct clk_init_data){ 618 .name = "blsp1_uart0_apps_clk_src", 619 .parent_data = gcc_parent_data_0, 620 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 621 .ops = &clk_rcg2_ops, 622 }, 623 }; 624 625 static struct clk_rcg2 blsp1_uart1_apps_clk_src = { 626 .cmd_rcgr = 0x2044, 627 .mnd_width = 16, 628 .hid_width = 5, 629 .parent_map = gcc_parent_map_0, 630 .freq_tbl = ftbl_blsp1_uart0_apps_clk_src, 631 .clkr.hw.init = &(struct clk_init_data){ 632 .name = "blsp1_uart1_apps_clk_src", 633 .parent_data = gcc_parent_data_0, 634 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 635 .ops = &clk_rcg2_ops, 636 }, 637 }; 638 639 static struct clk_rcg2 blsp1_uart2_apps_clk_src = { 640 .cmd_rcgr = 0x3034, 641 .mnd_width = 16, 642 .hid_width = 5, 643 .parent_map = gcc_parent_map_0, 644 .freq_tbl = ftbl_blsp1_uart0_apps_clk_src, 645 .clkr.hw.init = &(struct clk_init_data){ 646 .name = "blsp1_uart2_apps_clk_src", 647 .parent_data = gcc_parent_data_0, 648 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 649 .ops = &clk_rcg2_ops, 650 }, 651 }; 652 653 static struct clk_rcg2 blsp1_uart3_apps_clk_src = { 654 .cmd_rcgr = 0x4014, 655 .mnd_width = 16, 656 .hid_width = 5, 657 .cfg_off = 0x20, 658 .parent_map = gcc_parent_map_0, 659 .freq_tbl = ftbl_blsp1_uart0_apps_clk_src, 660 .clkr.hw.init = &(struct clk_init_data){ 661 .name = "blsp1_uart3_apps_clk_src", 662 .parent_data = gcc_parent_data_0, 663 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 664 .ops = &clk_rcg2_ops, 665 }, 666 }; 667 668 static struct clk_rcg2 blsp2_qup0_i2c_apps_clk_src = { 669 .cmd_rcgr = 0xc00c, 670 .mnd_width = 0, 671 .hid_width = 5, 672 .parent_map = gcc_parent_map_0, 673 .freq_tbl = ftbl_blsp1_qup0_i2c_apps_clk_src, 674 .clkr.hw.init = &(struct clk_init_data){ 675 .name = "blsp2_qup0_i2c_apps_clk_src", 676 .parent_data = gcc_parent_data_0, 677 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 678 .ops = &clk_rcg2_ops, 679 }, 680 }; 681 682 static struct clk_rcg2 blsp2_qup0_spi_apps_clk_src = { 683 .cmd_rcgr = 0xc024, 684 .mnd_width = 8, 685 .hid_width = 5, 686 .parent_map = gcc_parent_map_0, 687 .freq_tbl = ftbl_blsp1_qup0_spi_apps_clk_src, 688 .clkr.hw.init = &(struct clk_init_data){ 689 .name = "blsp2_qup0_spi_apps_clk_src", 690 .parent_data = gcc_parent_data_0, 691 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 692 .ops = &clk_rcg2_ops, 693 }, 694 }; 695 696 static struct clk_rcg2 blsp2_uart0_apps_clk_src = { 697 .cmd_rcgr = 0xc044, 698 .mnd_width = 16, 699 .hid_width = 5, 700 .parent_map = gcc_parent_map_0, 701 .freq_tbl = ftbl_blsp1_uart0_apps_clk_src, 702 .clkr.hw.init = &(struct clk_init_data){ 703 .name = "blsp2_uart0_apps_clk_src", 704 .parent_data = gcc_parent_data_0, 705 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 706 .ops = &clk_rcg2_ops, 707 }, 708 }; 709 710 static struct clk_rcg2 byte0_clk_src = { 711 .cmd_rcgr = 0x4d044, 712 .mnd_width = 0, 713 .hid_width = 5, 714 .parent_map = gcc_parent_map_5, 715 .clkr.hw.init = &(struct clk_init_data){ 716 .name = "byte0_clk_src", 717 .parent_data = gcc_parent_data_5, 718 .num_parents = ARRAY_SIZE(gcc_parent_data_5), 719 .flags = CLK_SET_RATE_PARENT, 720 .ops = &clk_byte2_ops, 721 }, 722 }; 723 724 static const struct freq_tbl ftbl_emac_clk_src[] = { 725 F(5000000, P_GPLL1_OUT_MAIN, 2, 1, 50), 726 F(50000000, P_GPLL1_OUT_MAIN, 10, 0, 0), 727 F(125000000, P_GPLL1_OUT_MAIN, 4, 0, 0), 728 F(250000000, P_GPLL1_OUT_MAIN, 2, 0, 0), 729 { } 730 }; 731 732 static struct clk_rcg2 emac_clk_src = { 733 .cmd_rcgr = 0x4e01c, 734 .mnd_width = 8, 735 .hid_width = 5, 736 .parent_map = gcc_parent_map_4, 737 .freq_tbl = ftbl_emac_clk_src, 738 .clkr.hw.init = &(struct clk_init_data){ 739 .name = "emac_clk_src", 740 .parent_data = gcc_parent_data_4, 741 .num_parents = ARRAY_SIZE(gcc_parent_data_4), 742 .ops = &clk_rcg2_ops, 743 }, 744 }; 745 746 static const struct freq_tbl ftbl_emac_ptp_clk_src[] = { 747 F(50000000, P_GPLL1_OUT_MAIN, 10, 0, 0), 748 F(125000000, P_GPLL1_OUT_MAIN, 4, 0, 0), 749 F(250000000, P_GPLL1_OUT_MAIN, 2, 0, 0), 750 { } 751 }; 752 753 static struct clk_rcg2 emac_ptp_clk_src = { 754 .cmd_rcgr = 0x4e014, 755 .mnd_width = 0, 756 .hid_width = 5, 757 .parent_map = gcc_parent_map_4, 758 .freq_tbl = ftbl_emac_ptp_clk_src, 759 .clkr.hw.init = &(struct clk_init_data){ 760 .name = "emac_ptp_clk_src", 761 .parent_data = gcc_parent_data_4, 762 .num_parents = ARRAY_SIZE(gcc_parent_data_4), 763 .ops = &clk_rcg2_ops, 764 }, 765 }; 766 767 static const struct freq_tbl ftbl_esc0_clk_src[] = { 768 F(19200000, P_XO, 1, 0, 0), 769 { } 770 }; 771 772 static struct clk_rcg2 esc0_clk_src = { 773 .cmd_rcgr = 0x4d05c, 774 .mnd_width = 0, 775 .hid_width = 5, 776 .parent_map = gcc_parent_map_6, 777 .freq_tbl = ftbl_esc0_clk_src, 778 .clkr.hw.init = &(struct clk_init_data){ 779 .name = "esc0_clk_src", 780 .parent_data = gcc_parent_data_6, 781 .num_parents = ARRAY_SIZE(gcc_parent_data_6), 782 .ops = &clk_rcg2_ops, 783 }, 784 }; 785 786 static const struct freq_tbl ftbl_gfx3d_clk_src[] = { 787 F(19200000, P_XO, 1, 0, 0), 788 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 789 F(80000000, P_GPLL0_OUT_MAIN, 10, 0, 0), 790 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 791 F(160000000, P_GPLL0_OUT_MAIN, 5, 0, 0), 792 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 793 F(228571429, P_GPLL0_OUT_MAIN, 3.5, 0, 0), 794 F(240000000, P_GPLL6_OUT_AUX, 4.5, 0, 0), 795 F(266666667, P_GPLL0_OUT_MAIN, 3, 0, 0), 796 F(270000000, P_GPLL6_OUT_AUX, 4, 0, 0), 797 F(320000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0), 798 F(400000000, P_GPLL0_OUT_MAIN, 2, 0, 0), 799 F(484800000, P_GPLL3_OUT_MAIN, 1, 0, 0), 800 F(523200000, P_GPLL3_OUT_MAIN, 1, 0, 0), 801 F(550000000, P_GPLL3_OUT_MAIN, 1, 0, 0), 802 F(598000000, P_GPLL3_OUT_MAIN, 1, 0, 0), 803 { } 804 }; 805 806 static struct clk_rcg2 gfx3d_clk_src = { 807 .cmd_rcgr = 0x59000, 808 .mnd_width = 0, 809 .hid_width = 5, 810 .parent_map = gcc_parent_map_7, 811 .freq_tbl = ftbl_gfx3d_clk_src, 812 .clkr.hw.init = &(struct clk_init_data){ 813 .name = "gfx3d_clk_src", 814 .parent_data = gcc_parent_data_7, 815 .num_parents = ARRAY_SIZE(gcc_parent_data_7), 816 .ops = &clk_rcg2_ops, 817 }, 818 }; 819 820 static const struct freq_tbl ftbl_gp1_clk_src[] = { 821 F(19200000, P_XO, 1, 0, 0), 822 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 823 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 824 { } 825 }; 826 827 static struct clk_rcg2 gp1_clk_src = { 828 .cmd_rcgr = 0x8004, 829 .mnd_width = 8, 830 .hid_width = 5, 831 .parent_map = gcc_parent_map_2, 832 .freq_tbl = ftbl_gp1_clk_src, 833 .clkr.hw.init = &(struct clk_init_data){ 834 .name = "gp1_clk_src", 835 .parent_data = gcc_parent_data_2, 836 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 837 .ops = &clk_rcg2_ops, 838 }, 839 }; 840 841 static struct clk_rcg2 gp2_clk_src = { 842 .cmd_rcgr = 0x9004, 843 .mnd_width = 8, 844 .hid_width = 5, 845 .parent_map = gcc_parent_map_2, 846 .freq_tbl = ftbl_gp1_clk_src, 847 .clkr.hw.init = &(struct clk_init_data){ 848 .name = "gp2_clk_src", 849 .parent_data = gcc_parent_data_2, 850 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 851 .ops = &clk_rcg2_ops, 852 }, 853 }; 854 855 static struct clk_rcg2 gp3_clk_src = { 856 .cmd_rcgr = 0xa004, 857 .mnd_width = 8, 858 .hid_width = 5, 859 .parent_map = gcc_parent_map_2, 860 .freq_tbl = ftbl_gp1_clk_src, 861 .clkr.hw.init = &(struct clk_init_data){ 862 .name = "gp3_clk_src", 863 .parent_data = gcc_parent_data_2, 864 .num_parents = ARRAY_SIZE(gcc_parent_data_2), 865 .ops = &clk_rcg2_ops, 866 }, 867 }; 868 869 static struct clk_rcg2 hdmi_app_clk_src = { 870 .cmd_rcgr = 0x4d0e4, 871 .mnd_width = 0, 872 .hid_width = 5, 873 .parent_map = gcc_parent_map_1, 874 .freq_tbl = ftbl_esc0_clk_src, 875 .clkr.hw.init = &(struct clk_init_data){ 876 .name = "hdmi_app_clk_src", 877 .parent_data = gcc_parent_data_1, 878 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 879 .ops = &clk_rcg2_ops, 880 }, 881 }; 882 883 static struct clk_rcg2 hdmi_pclk_clk_src = { 884 .cmd_rcgr = 0x4d0dc, 885 .mnd_width = 0, 886 .hid_width = 5, 887 .parent_map = gcc_parent_map_8, 888 .freq_tbl = ftbl_esc0_clk_src, 889 .clkr.hw.init = &(struct clk_init_data){ 890 .name = "hdmi_pclk_clk_src", 891 .parent_data = gcc_parent_data_8, 892 .num_parents = ARRAY_SIZE(gcc_parent_data_8), 893 .ops = &clk_rcg2_ops, 894 }, 895 }; 896 897 static const struct freq_tbl ftbl_mdp_clk_src[] = { 898 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 899 F(80000000, P_GPLL0_OUT_MAIN, 10, 0, 0), 900 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 901 F(145454545, P_GPLL0_OUT_MAIN, 5.5, 0, 0), 902 F(160000000, P_GPLL0_OUT_MAIN, 5, 0, 0), 903 F(177777778, P_GPLL0_OUT_MAIN, 4.5, 0, 0), 904 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 905 F(266666667, P_GPLL0_OUT_MAIN, 3, 0, 0), 906 F(320000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0), 907 { } 908 }; 909 910 static struct clk_rcg2 mdp_clk_src = { 911 .cmd_rcgr = 0x4d014, 912 .mnd_width = 0, 913 .hid_width = 5, 914 .parent_map = gcc_parent_map_9, 915 .freq_tbl = ftbl_mdp_clk_src, 916 .clkr.hw.init = &(struct clk_init_data){ 917 .name = "mdp_clk_src", 918 .parent_data = gcc_parent_data_9, 919 .num_parents = ARRAY_SIZE(gcc_parent_data_9), 920 .ops = &clk_rcg2_ops, 921 }, 922 }; 923 924 static const struct freq_tbl ftbl_pcie_0_aux_clk_src[] = { 925 F(1200000, P_XO, 16, 0, 0), 926 { } 927 }; 928 929 static struct clk_rcg2 pcie_0_aux_clk_src = { 930 .cmd_rcgr = 0x3e024, 931 .mnd_width = 16, 932 .hid_width = 5, 933 .parent_map = gcc_parent_map_10, 934 .freq_tbl = ftbl_pcie_0_aux_clk_src, 935 .clkr.hw.init = &(struct clk_init_data){ 936 .name = "pcie_0_aux_clk_src", 937 .parent_data = gcc_parent_data_10, 938 .num_parents = ARRAY_SIZE(gcc_parent_data_10), 939 .ops = &clk_rcg2_ops, 940 }, 941 }; 942 943 static const struct freq_tbl ftbl_pcie_0_pipe_clk_src[] = { 944 F(19200000, P_XO, 1, 0, 0), 945 F(125000000, P_PCIE_0_PIPE_CLK, 2, 0, 0), 946 F(250000000, P_PCIE_0_PIPE_CLK, 1, 0, 0), 947 { } 948 }; 949 950 static struct clk_rcg2 pcie_0_pipe_clk_src = { 951 .cmd_rcgr = 0x3e01c, 952 .mnd_width = 0, 953 .hid_width = 5, 954 .parent_map = gcc_parent_map_11, 955 .freq_tbl = ftbl_pcie_0_pipe_clk_src, 956 .clkr.hw.init = &(struct clk_init_data){ 957 .name = "pcie_0_pipe_clk_src", 958 .parent_data = gcc_parent_data_11, 959 .num_parents = ARRAY_SIZE(gcc_parent_data_11), 960 .ops = &clk_rcg2_ops, 961 }, 962 }; 963 964 static struct clk_rcg2 pclk0_clk_src = { 965 .cmd_rcgr = 0x4d000, 966 .mnd_width = 8, 967 .hid_width = 5, 968 .parent_map = gcc_parent_map_12, 969 .clkr.hw.init = &(struct clk_init_data){ 970 .name = "pclk0_clk_src", 971 .parent_data = gcc_parent_data_12, 972 .num_parents = ARRAY_SIZE(gcc_parent_data_12), 973 .flags = CLK_SET_RATE_PARENT, 974 .ops = &clk_pixel_ops, 975 }, 976 }; 977 978 static const struct freq_tbl ftbl_pdm2_clk_src[] = { 979 F(19200000, P_XO, 1, 0, 0), 980 F(64000000, P_GPLL0_OUT_MAIN, 12.5, 0, 0), 981 { } 982 }; 983 984 static struct clk_rcg2 pdm2_clk_src = { 985 .cmd_rcgr = 0x44010, 986 .mnd_width = 0, 987 .hid_width = 5, 988 .parent_map = gcc_parent_map_0, 989 .freq_tbl = ftbl_pdm2_clk_src, 990 .clkr.hw.init = &(struct clk_init_data){ 991 .name = "pdm2_clk_src", 992 .parent_data = gcc_parent_data_0, 993 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 994 .ops = &clk_rcg2_ops, 995 }, 996 }; 997 998 static const struct freq_tbl ftbl_sdcc1_apps_clk_src[] = { 999 F(144000, P_XO, 16, 3, 25), 1000 F(400000, P_XO, 12, 1, 4), 1001 F(20000000, P_GPLL0_OUT_MAIN, 10, 1, 4), 1002 F(25000000, P_GPLL0_OUT_MAIN, 16, 1, 2), 1003 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 1004 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1005 F(177777778, P_GPLL0_OUT_MAIN, 4.5, 0, 0), 1006 F(192000000, P_GPLL4_OUT_MAIN, 6, 0, 0), 1007 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1008 F(384000000, P_GPLL4_OUT_MAIN, 3, 0, 0), 1009 { } 1010 }; 1011 1012 static struct clk_rcg2 sdcc1_apps_clk_src = { 1013 .cmd_rcgr = 0x42004, 1014 .mnd_width = 8, 1015 .hid_width = 5, 1016 .parent_map = gcc_parent_map_13, 1017 .freq_tbl = ftbl_sdcc1_apps_clk_src, 1018 .clkr.hw.init = &(struct clk_init_data){ 1019 .name = "sdcc1_apps_clk_src", 1020 .parent_data = gcc_parent_data_13, 1021 .num_parents = ARRAY_SIZE(gcc_parent_data_13), 1022 .ops = &clk_rcg2_floor_ops, 1023 }, 1024 }; 1025 1026 static const struct freq_tbl ftbl_sdcc1_ice_core_clk_src[] = { 1027 F(160000000, P_GPLL0_OUT_MAIN, 5, 0, 0), 1028 F(266666667, P_GPLL0_OUT_MAIN, 3, 0, 0), 1029 { } 1030 }; 1031 1032 static struct clk_rcg2 sdcc1_ice_core_clk_src = { 1033 .cmd_rcgr = 0x5d000, 1034 .mnd_width = 8, 1035 .hid_width = 5, 1036 .parent_map = gcc_parent_map_3, 1037 .freq_tbl = ftbl_sdcc1_ice_core_clk_src, 1038 .clkr.hw.init = &(struct clk_init_data){ 1039 .name = "sdcc1_ice_core_clk_src", 1040 .parent_data = gcc_parent_data_3, 1041 .num_parents = ARRAY_SIZE(gcc_parent_data_3), 1042 .ops = &clk_rcg2_ops, 1043 }, 1044 }; 1045 1046 static const struct freq_tbl ftbl_sdcc2_apps_clk_src[] = { 1047 F(144000, P_XO, 16, 3, 25), 1048 F(400000, P_XO, 12, 1, 4), 1049 F(20000000, P_GPLL0_OUT_MAIN, 10, 1, 4), 1050 F(25000000, P_GPLL0_OUT_MAIN, 16, 1, 2), 1051 F(50000000, P_GPLL0_OUT_MAIN, 16, 0, 0), 1052 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1053 F(177777778, P_GPLL0_OUT_MAIN, 4.5, 0, 0), 1054 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1055 { } 1056 }; 1057 1058 static struct clk_rcg2 sdcc2_apps_clk_src = { 1059 .cmd_rcgr = 0x43004, 1060 .mnd_width = 8, 1061 .hid_width = 5, 1062 .parent_map = gcc_parent_map_14, 1063 .freq_tbl = ftbl_sdcc2_apps_clk_src, 1064 .clkr.hw.init = &(struct clk_init_data){ 1065 .name = "sdcc2_apps_clk_src", 1066 .parent_data = gcc_parent_data_14, 1067 .num_parents = ARRAY_SIZE(gcc_parent_data_14), 1068 .ops = &clk_rcg2_floor_ops, 1069 }, 1070 }; 1071 1072 static struct clk_rcg2 usb20_mock_utmi_clk_src = { 1073 .cmd_rcgr = 0x41048, 1074 .mnd_width = 0, 1075 .hid_width = 5, 1076 .parent_map = gcc_parent_map_1, 1077 .freq_tbl = ftbl_esc0_clk_src, 1078 .clkr.hw.init = &(struct clk_init_data){ 1079 .name = "usb20_mock_utmi_clk_src", 1080 .parent_data = gcc_parent_data_1, 1081 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1082 .ops = &clk_rcg2_ops, 1083 }, 1084 }; 1085 1086 static const struct freq_tbl ftbl_usb30_master_clk_src[] = { 1087 F(19200000, P_XO, 1, 0, 0), 1088 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1089 F(200000000, P_GPLL0_OUT_MAIN, 4, 0, 0), 1090 F(266666667, P_GPLL0_OUT_MAIN, 3, 0, 0), 1091 { } 1092 }; 1093 1094 static struct clk_rcg2 usb30_master_clk_src = { 1095 .cmd_rcgr = 0x39028, 1096 .mnd_width = 8, 1097 .hid_width = 5, 1098 .parent_map = gcc_parent_map_0, 1099 .freq_tbl = ftbl_usb30_master_clk_src, 1100 .clkr.hw.init = &(struct clk_init_data){ 1101 .name = "usb30_master_clk_src", 1102 .parent_data = gcc_parent_data_0, 1103 .num_parents = ARRAY_SIZE(gcc_parent_data_0), 1104 .ops = &clk_rcg2_ops, 1105 }, 1106 }; 1107 1108 static struct clk_rcg2 usb30_mock_utmi_clk_src = { 1109 .cmd_rcgr = 0x3901c, 1110 .mnd_width = 0, 1111 .hid_width = 5, 1112 .parent_map = gcc_parent_map_1, 1113 .freq_tbl = ftbl_esc0_clk_src, 1114 .clkr.hw.init = &(struct clk_init_data){ 1115 .name = "usb30_mock_utmi_clk_src", 1116 .parent_data = gcc_parent_data_1, 1117 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1118 .ops = &clk_rcg2_ops, 1119 }, 1120 }; 1121 1122 static struct clk_rcg2 usb3_phy_aux_clk_src = { 1123 .cmd_rcgr = 0x3903c, 1124 .mnd_width = 0, 1125 .hid_width = 5, 1126 .parent_map = gcc_parent_map_1, 1127 .freq_tbl = ftbl_pcie_0_aux_clk_src, 1128 .clkr.hw.init = &(struct clk_init_data){ 1129 .name = "usb3_phy_aux_clk_src", 1130 .parent_data = gcc_parent_data_1, 1131 .num_parents = ARRAY_SIZE(gcc_parent_data_1), 1132 .ops = &clk_rcg2_ops, 1133 }, 1134 }; 1135 1136 static const struct freq_tbl ftbl_usb_hs_system_clk_src[] = { 1137 F(19200000, P_XO, 1, 0, 0), 1138 F(80000000, P_GPLL0_OUT_MAIN, 10, 0, 0), 1139 F(100000000, P_GPLL0_OUT_MAIN, 8, 0, 0), 1140 F(133333333, P_GPLL0_OUT_MAIN, 6, 0, 0), 1141 F(177777778, P_GPLL0_OUT_MAIN, 4.5, 0, 0), 1142 { } 1143 }; 1144 1145 static struct clk_rcg2 usb_hs_system_clk_src = { 1146 .cmd_rcgr = 0x41010, 1147 .mnd_width = 0, 1148 .hid_width = 5, 1149 .parent_map = gcc_parent_map_3, 1150 .freq_tbl = ftbl_usb_hs_system_clk_src, 1151 .clkr.hw.init = &(struct clk_init_data){ 1152 .name = "usb_hs_system_clk_src", 1153 .parent_data = gcc_parent_data_3, 1154 .num_parents = ARRAY_SIZE(gcc_parent_data_3), 1155 .ops = &clk_rcg2_ops, 1156 }, 1157 }; 1158 1159 static struct clk_rcg2 vsync_clk_src = { 1160 .cmd_rcgr = 0x4d02c, 1161 .mnd_width = 0, 1162 .hid_width = 5, 1163 .parent_map = gcc_parent_map_15, 1164 .freq_tbl = ftbl_esc0_clk_src, 1165 .clkr.hw.init = &(struct clk_init_data){ 1166 .name = "vsync_clk_src", 1167 .parent_data = gcc_parent_data_15, 1168 .num_parents = ARRAY_SIZE(gcc_parent_data_15), 1169 .ops = &clk_rcg2_ops, 1170 }, 1171 }; 1172 1173 static const struct freq_tbl ftbl_cdsp_bimc_clk_src[] = { 1174 F(19200000, P_XO, 1, 0, 0), 1175 F(133333333, P_GPLL0_OUT_MAIN, 6, 0, 0), 1176 F(266666667, P_GPLL0_OUT_MAIN, 3, 0, 0), 1177 F(320000000, P_GPLL0_OUT_MAIN, 2.5, 0, 0), 1178 { } 1179 }; 1180 1181 static struct clk_rcg2 cdsp_bimc_clk_src = { 1182 .cmd_rcgr = 0x5e010, 1183 .mnd_width = 0, 1184 .hid_width = 5, 1185 .parent_map = gcc_parent_map_16, 1186 .freq_tbl = ftbl_cdsp_bimc_clk_src, 1187 .clkr.hw.init = &(struct clk_init_data) { 1188 .name = "cdsp_bimc_clk_src", 1189 .parent_data = gcc_parent_data_16, 1190 .num_parents = ARRAY_SIZE(gcc_parent_data_16), 1191 .ops = &clk_rcg2_ops, 1192 }, 1193 }; 1194 1195 static struct clk_branch gcc_apss_ahb_clk = { 1196 .halt_reg = 0x4601c, 1197 .halt_check = BRANCH_HALT_VOTED, 1198 .clkr = { 1199 .enable_reg = 0x45004, 1200 .enable_mask = BIT(14), 1201 .hw.init = &(struct clk_init_data){ 1202 .name = "gcc_apss_ahb_clk", 1203 .parent_hws = (const struct clk_hw*[]) { 1204 &apss_ahb_clk_src.clkr.hw, 1205 }, 1206 .num_parents = 1, 1207 .flags = CLK_SET_RATE_PARENT, 1208 .ops = &clk_branch2_ops, 1209 }, 1210 }, 1211 }; 1212 1213 static struct clk_branch gcc_apss_tcu_clk = { 1214 .halt_reg = 0x5b004, 1215 .halt_check = BRANCH_VOTED, 1216 .clkr = { 1217 .enable_reg = 0x4500c, 1218 .enable_mask = BIT(1), 1219 .hw.init = &(struct clk_init_data){ 1220 .name = "gcc_apss_tcu_clk", 1221 .ops = &clk_branch2_ops, 1222 }, 1223 }, 1224 }; 1225 1226 static struct clk_branch gcc_bimc_gfx_clk = { 1227 .halt_reg = 0x59034, 1228 .halt_check = BRANCH_HALT, 1229 .clkr = { 1230 .enable_reg = 0x59034, 1231 .enable_mask = BIT(0), 1232 .hw.init = &(struct clk_init_data){ 1233 .name = "gcc_bimc_gfx_clk", 1234 .ops = &clk_branch2_ops, 1235 .parent_hws = (const struct clk_hw*[]) { 1236 &gcc_apss_tcu_clk.clkr.hw, 1237 }, 1238 1239 }, 1240 }, 1241 }; 1242 1243 static struct clk_branch gcc_bimc_gpu_clk = { 1244 .halt_reg = 0x59030, 1245 .halt_check = BRANCH_HALT, 1246 .clkr = { 1247 .enable_reg = 0x59030, 1248 .enable_mask = BIT(0), 1249 .hw.init = &(struct clk_init_data){ 1250 .name = "gcc_bimc_gpu_clk", 1251 .ops = &clk_branch2_ops, 1252 }, 1253 }, 1254 }; 1255 1256 static struct clk_branch gcc_bimc_cdsp_clk = { 1257 .halt_reg = 0x31030, 1258 .halt_check = BRANCH_HALT, 1259 .clkr = { 1260 .enable_reg = 0x31030, 1261 .enable_mask = BIT(0), 1262 .hw.init = &(struct clk_init_data) { 1263 .name = "gcc_bimc_cdsp_clk", 1264 .parent_hws = (const struct clk_hw*[]) { 1265 &cdsp_bimc_clk_src.clkr.hw 1266 }, 1267 .num_parents = 1, 1268 .flags = CLK_SET_RATE_PARENT, 1269 .ops = &clk_branch2_ops, 1270 }, 1271 }, 1272 }; 1273 1274 static struct clk_branch gcc_bimc_mdss_clk = { 1275 .halt_reg = 0x31038, 1276 .halt_check = BRANCH_HALT, 1277 .clkr = { 1278 .enable_reg = 0x31038, 1279 .enable_mask = BIT(0), 1280 .hw.init = &(struct clk_init_data){ 1281 .name = "gcc_bimc_mdss_clk", 1282 .ops = &clk_branch2_ops, 1283 }, 1284 }, 1285 }; 1286 1287 static struct clk_branch gcc_blsp1_ahb_clk = { 1288 .halt_reg = 0x1008, 1289 .halt_check = BRANCH_HALT_VOTED, 1290 .clkr = { 1291 .enable_reg = 0x45004, 1292 .enable_mask = BIT(10), 1293 .hw.init = &(struct clk_init_data){ 1294 .name = "gcc_blsp1_ahb_clk", 1295 .ops = &clk_branch2_ops, 1296 }, 1297 }, 1298 }; 1299 1300 static struct clk_branch gcc_dcc_clk = { 1301 .halt_reg = 0x77004, 1302 .halt_check = BRANCH_HALT, 1303 .clkr = { 1304 .enable_reg = 0x77004, 1305 .enable_mask = BIT(0), 1306 .hw.init = &(struct clk_init_data){ 1307 .name = "gcc_dcc_clk", 1308 .ops = &clk_branch2_ops, 1309 }, 1310 }, 1311 }; 1312 1313 static struct clk_branch gcc_dcc_xo_clk = { 1314 .halt_reg = 0x77008, 1315 .halt_check = BRANCH_HALT, 1316 .clkr = { 1317 .enable_reg = 0x77008, 1318 .enable_mask = BIT(0), 1319 .hw.init = &(struct clk_init_data){ 1320 .name = "gcc_dcc_xo_clk", 1321 .ops = &clk_branch2_ops, 1322 }, 1323 }, 1324 }; 1325 1326 static struct clk_branch gcc_blsp1_qup0_i2c_apps_clk = { 1327 .halt_reg = 0x6028, 1328 .halt_check = BRANCH_HALT, 1329 .clkr = { 1330 .enable_reg = 0x6028, 1331 .enable_mask = BIT(0), 1332 .hw.init = &(struct clk_init_data){ 1333 .name = "gcc_blsp1_qup0_i2c_apps_clk", 1334 .parent_hws = (const struct clk_hw*[]) { 1335 &blsp1_qup0_i2c_apps_clk_src.clkr.hw, 1336 }, 1337 .num_parents = 1, 1338 .flags = CLK_SET_RATE_PARENT, 1339 .ops = &clk_branch2_ops, 1340 }, 1341 }, 1342 }; 1343 1344 static struct clk_branch gcc_blsp1_qup0_spi_apps_clk = { 1345 .halt_reg = 0x6024, 1346 .halt_check = BRANCH_HALT, 1347 .clkr = { 1348 .enable_reg = 0x6024, 1349 .enable_mask = BIT(0), 1350 .hw.init = &(struct clk_init_data){ 1351 .name = "gcc_blsp1_qup0_spi_apps_clk", 1352 .parent_hws = (const struct clk_hw*[]) { 1353 &blsp1_qup0_spi_apps_clk_src.clkr.hw, 1354 }, 1355 .num_parents = 1, 1356 .flags = CLK_SET_RATE_PARENT, 1357 .ops = &clk_branch2_ops, 1358 }, 1359 }, 1360 }; 1361 1362 static struct clk_branch gcc_blsp1_qup1_i2c_apps_clk = { 1363 .halt_reg = 0x2008, 1364 .halt_check = BRANCH_HALT, 1365 .clkr = { 1366 .enable_reg = 0x2008, 1367 .enable_mask = BIT(0), 1368 .hw.init = &(struct clk_init_data){ 1369 .name = "gcc_blsp1_qup1_i2c_apps_clk", 1370 .parent_hws = (const struct clk_hw*[]) { 1371 &blsp1_qup1_i2c_apps_clk_src.clkr.hw, 1372 }, 1373 .num_parents = 1, 1374 .flags = CLK_SET_RATE_PARENT, 1375 .ops = &clk_branch2_ops, 1376 }, 1377 }, 1378 }; 1379 1380 static struct clk_branch gcc_blsp1_qup1_spi_apps_clk = { 1381 .halt_reg = 0x2004, 1382 .halt_check = BRANCH_HALT, 1383 .clkr = { 1384 .enable_reg = 0x2004, 1385 .enable_mask = BIT(0), 1386 .hw.init = &(struct clk_init_data){ 1387 .name = "gcc_blsp1_qup1_spi_apps_clk", 1388 .parent_hws = (const struct clk_hw*[]) { 1389 &blsp1_qup1_spi_apps_clk_src.clkr.hw, 1390 }, 1391 .num_parents = 1, 1392 .flags = CLK_SET_RATE_PARENT, 1393 .ops = &clk_branch2_ops, 1394 }, 1395 }, 1396 }; 1397 1398 static struct clk_branch gcc_blsp1_qup2_i2c_apps_clk = { 1399 .halt_reg = 0x3010, 1400 .halt_check = BRANCH_HALT, 1401 .clkr = { 1402 .enable_reg = 0x3010, 1403 .enable_mask = BIT(0), 1404 .hw.init = &(struct clk_init_data){ 1405 .name = "gcc_blsp1_qup2_i2c_apps_clk", 1406 .parent_hws = (const struct clk_hw*[]) { 1407 &blsp1_qup2_i2c_apps_clk_src.clkr.hw, 1408 }, 1409 .num_parents = 1, 1410 .flags = CLK_SET_RATE_PARENT, 1411 .ops = &clk_branch2_ops, 1412 }, 1413 }, 1414 }; 1415 1416 static struct clk_branch gcc_blsp1_qup2_spi_apps_clk = { 1417 .halt_reg = 0x300c, 1418 .halt_check = BRANCH_HALT, 1419 .clkr = { 1420 .enable_reg = 0x300c, 1421 .enable_mask = BIT(0), 1422 .hw.init = &(struct clk_init_data){ 1423 .name = "gcc_blsp1_qup2_spi_apps_clk", 1424 .parent_hws = (const struct clk_hw*[]) { 1425 &blsp1_qup2_spi_apps_clk_src.clkr.hw, 1426 }, 1427 .num_parents = 1, 1428 .flags = CLK_SET_RATE_PARENT, 1429 .ops = &clk_branch2_ops, 1430 }, 1431 }, 1432 }; 1433 1434 static struct clk_branch gcc_blsp1_qup3_i2c_apps_clk = { 1435 .halt_reg = 0x4020, 1436 .halt_check = BRANCH_HALT, 1437 .clkr = { 1438 .enable_reg = 0x4020, 1439 .enable_mask = BIT(0), 1440 .hw.init = &(struct clk_init_data){ 1441 .name = "gcc_blsp1_qup3_i2c_apps_clk", 1442 .parent_hws = (const struct clk_hw*[]) { 1443 &blsp1_qup3_i2c_apps_clk_src.clkr.hw, 1444 }, 1445 .num_parents = 1, 1446 .flags = CLK_SET_RATE_PARENT, 1447 .ops = &clk_branch2_ops, 1448 }, 1449 }, 1450 }; 1451 1452 static struct clk_branch gcc_blsp1_qup3_spi_apps_clk = { 1453 .halt_reg = 0x401c, 1454 .halt_check = BRANCH_HALT, 1455 .clkr = { 1456 .enable_reg = 0x401c, 1457 .enable_mask = BIT(0), 1458 .hw.init = &(struct clk_init_data){ 1459 .name = "gcc_blsp1_qup3_spi_apps_clk", 1460 .parent_hws = (const struct clk_hw*[]) { 1461 &blsp1_qup3_spi_apps_clk_src.clkr.hw, 1462 }, 1463 .num_parents = 1, 1464 .flags = CLK_SET_RATE_PARENT, 1465 .ops = &clk_branch2_ops, 1466 }, 1467 }, 1468 }; 1469 1470 static struct clk_branch gcc_blsp1_qup4_i2c_apps_clk = { 1471 .halt_reg = 0x5020, 1472 .halt_check = BRANCH_HALT, 1473 .clkr = { 1474 .enable_reg = 0x5020, 1475 .enable_mask = BIT(0), 1476 .hw.init = &(struct clk_init_data){ 1477 .name = "gcc_blsp1_qup4_i2c_apps_clk", 1478 .parent_hws = (const struct clk_hw*[]) { 1479 &blsp1_qup4_i2c_apps_clk_src.clkr.hw, 1480 }, 1481 .num_parents = 1, 1482 .flags = CLK_SET_RATE_PARENT, 1483 .ops = &clk_branch2_ops, 1484 }, 1485 }, 1486 }; 1487 1488 static struct clk_branch gcc_blsp1_qup4_spi_apps_clk = { 1489 .halt_reg = 0x501c, 1490 .halt_check = BRANCH_HALT, 1491 .clkr = { 1492 .enable_reg = 0x501c, 1493 .enable_mask = BIT(0), 1494 .hw.init = &(struct clk_init_data){ 1495 .name = "gcc_blsp1_qup4_spi_apps_clk", 1496 .parent_hws = (const struct clk_hw*[]) { 1497 &blsp1_qup4_spi_apps_clk_src.clkr.hw, 1498 }, 1499 .num_parents = 1, 1500 .flags = CLK_SET_RATE_PARENT, 1501 .ops = &clk_branch2_ops, 1502 }, 1503 }, 1504 }; 1505 1506 static struct clk_branch gcc_blsp1_uart0_apps_clk = { 1507 .halt_reg = 0x6004, 1508 .halt_check = BRANCH_HALT, 1509 .clkr = { 1510 .enable_reg = 0x6004, 1511 .enable_mask = BIT(0), 1512 .hw.init = &(struct clk_init_data){ 1513 .name = "gcc_blsp1_uart0_apps_clk", 1514 .parent_hws = (const struct clk_hw*[]) { 1515 &blsp1_uart0_apps_clk_src.clkr.hw, 1516 }, 1517 .num_parents = 1, 1518 .flags = CLK_SET_RATE_PARENT, 1519 .ops = &clk_branch2_ops, 1520 }, 1521 }, 1522 }; 1523 1524 static struct clk_branch gcc_blsp1_uart1_apps_clk = { 1525 .halt_reg = 0x203c, 1526 .halt_check = BRANCH_HALT, 1527 .clkr = { 1528 .enable_reg = 0x203c, 1529 .enable_mask = BIT(0), 1530 .hw.init = &(struct clk_init_data){ 1531 .name = "gcc_blsp1_uart1_apps_clk", 1532 .parent_hws = (const struct clk_hw*[]) { 1533 &blsp1_uart1_apps_clk_src.clkr.hw, 1534 }, 1535 .num_parents = 1, 1536 .flags = CLK_SET_RATE_PARENT, 1537 .ops = &clk_branch2_ops, 1538 }, 1539 }, 1540 }; 1541 1542 static struct clk_branch gcc_blsp1_uart2_apps_clk = { 1543 .halt_reg = 0x302c, 1544 .halt_check = BRANCH_HALT, 1545 .clkr = { 1546 .enable_reg = 0x302c, 1547 .enable_mask = BIT(0), 1548 .hw.init = &(struct clk_init_data){ 1549 .name = "gcc_blsp1_uart2_apps_clk", 1550 .parent_hws = (const struct clk_hw*[]) { 1551 &blsp1_uart2_apps_clk_src.clkr.hw, 1552 }, 1553 .num_parents = 1, 1554 .flags = CLK_SET_RATE_PARENT, 1555 .ops = &clk_branch2_ops, 1556 }, 1557 }, 1558 }; 1559 1560 static struct clk_branch gcc_blsp1_uart3_apps_clk = { 1561 .halt_reg = 0x400c, 1562 .halt_check = BRANCH_HALT, 1563 .clkr = { 1564 .enable_reg = 0x400c, 1565 .enable_mask = BIT(0), 1566 .hw.init = &(struct clk_init_data){ 1567 .name = "gcc_blsp1_uart3_apps_clk", 1568 .parent_hws = (const struct clk_hw*[]) { 1569 &blsp1_uart3_apps_clk_src.clkr.hw, 1570 }, 1571 .num_parents = 1, 1572 .flags = CLK_SET_RATE_PARENT, 1573 .ops = &clk_branch2_ops, 1574 }, 1575 }, 1576 }; 1577 1578 static struct clk_branch gcc_blsp2_ahb_clk = { 1579 .halt_reg = 0xb008, 1580 .halt_check = BRANCH_HALT_VOTED, 1581 .clkr = { 1582 .enable_reg = 0x45004, 1583 .enable_mask = BIT(20), 1584 .hw.init = &(struct clk_init_data){ 1585 .name = "gcc_blsp2_ahb_clk", 1586 .ops = &clk_branch2_ops, 1587 }, 1588 }, 1589 }; 1590 1591 static struct clk_branch gcc_blsp2_qup0_i2c_apps_clk = { 1592 .halt_reg = 0xc008, 1593 .halt_check = BRANCH_HALT, 1594 .clkr = { 1595 .enable_reg = 0xc008, 1596 .enable_mask = BIT(0), 1597 .hw.init = &(struct clk_init_data){ 1598 .name = "gcc_blsp2_qup0_i2c_apps_clk", 1599 .parent_hws = (const struct clk_hw*[]) { 1600 &blsp2_qup0_i2c_apps_clk_src.clkr.hw, 1601 }, 1602 .num_parents = 1, 1603 .flags = CLK_SET_RATE_PARENT, 1604 .ops = &clk_branch2_ops, 1605 }, 1606 }, 1607 }; 1608 1609 static struct clk_branch gcc_blsp2_qup0_spi_apps_clk = { 1610 .halt_reg = 0xc004, 1611 .halt_check = BRANCH_HALT, 1612 .clkr = { 1613 .enable_reg = 0xc004, 1614 .enable_mask = BIT(0), 1615 .hw.init = &(struct clk_init_data){ 1616 .name = "gcc_blsp2_qup0_spi_apps_clk", 1617 .parent_hws = (const struct clk_hw*[]) { 1618 &blsp2_qup0_spi_apps_clk_src.clkr.hw, 1619 }, 1620 .num_parents = 1, 1621 .flags = CLK_SET_RATE_PARENT, 1622 .ops = &clk_branch2_ops, 1623 }, 1624 }, 1625 }; 1626 1627 static struct clk_branch gcc_blsp2_uart0_apps_clk = { 1628 .halt_reg = 0xc03c, 1629 .halt_check = BRANCH_HALT, 1630 .clkr = { 1631 .enable_reg = 0xc03c, 1632 .enable_mask = BIT(0), 1633 .hw.init = &(struct clk_init_data){ 1634 .name = "gcc_blsp2_uart0_apps_clk", 1635 .parent_hws = (const struct clk_hw*[]) { 1636 &blsp2_uart0_apps_clk_src.clkr.hw, 1637 }, 1638 .num_parents = 1, 1639 .flags = CLK_SET_RATE_PARENT, 1640 .ops = &clk_branch2_ops, 1641 }, 1642 }, 1643 }; 1644 1645 static struct clk_branch gcc_boot_rom_ahb_clk = { 1646 .halt_reg = 0x1300c, 1647 .halt_check = BRANCH_HALT_VOTED, 1648 .clkr = { 1649 .enable_reg = 0x45004, 1650 .enable_mask = BIT(7), 1651 .hw.init = &(struct clk_init_data){ 1652 .name = "gcc_boot_rom_ahb_clk", 1653 .ops = &clk_branch2_ops, 1654 }, 1655 }, 1656 }; 1657 1658 static struct clk_branch gcc_crypto_ahb_clk = { 1659 .halt_reg = 0x16024, 1660 .halt_check = BRANCH_VOTED, 1661 .clkr = { 1662 .enable_reg = 0x45004, 1663 .enable_mask = BIT(0), 1664 .hw.init = &(struct clk_init_data){ 1665 .name = "gcc_crypto_ahb_clk", 1666 .ops = &clk_branch2_ops, 1667 }, 1668 }, 1669 }; 1670 1671 static struct clk_branch gcc_crypto_axi_clk = { 1672 .halt_reg = 0x16020, 1673 .halt_check = BRANCH_VOTED, 1674 .clkr = { 1675 .enable_reg = 0x45004, 1676 .enable_mask = BIT(1), 1677 .hw.init = &(struct clk_init_data){ 1678 .name = "gcc_crypto_axi_clk", 1679 .ops = &clk_branch2_ops, 1680 }, 1681 }, 1682 }; 1683 1684 static struct clk_branch gcc_crypto_clk = { 1685 .halt_reg = 0x1601c, 1686 .halt_check = BRANCH_VOTED, 1687 .clkr = { 1688 .enable_reg = 0x45004, 1689 .enable_mask = BIT(2), 1690 .hw.init = &(struct clk_init_data){ 1691 .name = "gcc_crypto_clk", 1692 .ops = &clk_branch2_ops, 1693 }, 1694 }, 1695 }; 1696 1697 static struct clk_branch gcc_eth_axi_clk = { 1698 .halt_reg = 0x4e010, 1699 .halt_check = BRANCH_HALT, 1700 .clkr = { 1701 .enable_reg = 0x4e010, 1702 .enable_mask = BIT(0), 1703 .hw.init = &(struct clk_init_data){ 1704 .name = "gcc_eth_axi_clk", 1705 .ops = &clk_branch2_ops, 1706 }, 1707 }, 1708 }; 1709 1710 static struct clk_branch gcc_eth_ptp_clk = { 1711 .halt_reg = 0x4e004, 1712 .halt_check = BRANCH_HALT, 1713 .clkr = { 1714 .enable_reg = 0x4e004, 1715 .enable_mask = BIT(0), 1716 .hw.init = &(struct clk_init_data){ 1717 .name = "gcc_eth_ptp_clk", 1718 .parent_hws = (const struct clk_hw*[]) { 1719 &emac_ptp_clk_src.clkr.hw, 1720 }, 1721 .num_parents = 1, 1722 .flags = CLK_SET_RATE_PARENT, 1723 .ops = &clk_branch2_ops, 1724 }, 1725 }, 1726 }; 1727 1728 static struct clk_branch gcc_eth_rgmii_clk = { 1729 .halt_reg = 0x4e008, 1730 .halt_check = BRANCH_HALT, 1731 .clkr = { 1732 .enable_reg = 0x4e008, 1733 .enable_mask = BIT(0), 1734 .hw.init = &(struct clk_init_data){ 1735 .name = "gcc_eth_rgmii_clk", 1736 .parent_hws = (const struct clk_hw*[]) { 1737 &emac_clk_src.clkr.hw, 1738 }, 1739 .num_parents = 1, 1740 .flags = CLK_SET_RATE_PARENT, 1741 .ops = &clk_branch2_ops, 1742 }, 1743 }, 1744 }; 1745 1746 static struct clk_branch gcc_eth_slave_ahb_clk = { 1747 .halt_reg = 0x4e00c, 1748 .halt_check = BRANCH_HALT, 1749 .clkr = { 1750 .enable_reg = 0x4e00c, 1751 .enable_mask = BIT(0), 1752 .hw.init = &(struct clk_init_data){ 1753 .name = "gcc_eth_slave_ahb_clk", 1754 .ops = &clk_branch2_ops, 1755 }, 1756 }, 1757 }; 1758 1759 static struct clk_branch gcc_geni_ir_s_clk = { 1760 .halt_reg = 0xf008, 1761 .halt_check = BRANCH_HALT, 1762 .clkr = { 1763 .enable_reg = 0xf008, 1764 .enable_mask = BIT(0), 1765 .hw.init = &(struct clk_init_data){ 1766 .name = "gcc_geni_ir_s_clk", 1767 .ops = &clk_branch2_ops, 1768 }, 1769 }, 1770 }; 1771 1772 static struct clk_branch gcc_geni_ir_h_clk = { 1773 .halt_reg = 0xf004, 1774 .halt_check = BRANCH_HALT, 1775 .clkr = { 1776 .enable_reg = 0xf004, 1777 .enable_mask = BIT(0), 1778 .hw.init = &(struct clk_init_data){ 1779 .name = "gcc_geni_ir_h_clk", 1780 .ops = &clk_branch2_ops, 1781 }, 1782 }, 1783 }; 1784 1785 static struct clk_branch gcc_gfx_tcu_clk = { 1786 .halt_reg = 0x12020, 1787 .halt_check = BRANCH_VOTED, 1788 .clkr = { 1789 .enable_reg = 0x4500C, 1790 .enable_mask = BIT(2), 1791 .hw.init = &(struct clk_init_data){ 1792 .name = "gcc_gfx_tcu_clk", 1793 .ops = &clk_branch2_ops, 1794 }, 1795 }, 1796 }; 1797 1798 static struct clk_branch gcc_gfx_tbu_clk = { 1799 .halt_reg = 0x12010, 1800 .halt_check = BRANCH_VOTED, 1801 .clkr = { 1802 .enable_reg = 0x4500C, 1803 .enable_mask = BIT(3), 1804 .hw.init = &(struct clk_init_data){ 1805 .name = "gcc_gfx_tbu_clk", 1806 .ops = &clk_branch2_ops, 1807 }, 1808 }, 1809 }; 1810 1811 static struct clk_branch gcc_cdsp_tbu_clk = { 1812 .halt_reg = 0x1203c, 1813 .halt_check = BRANCH_VOTED, 1814 .clkr = { 1815 .enable_reg = 0x13020, 1816 .enable_mask = BIT(9), 1817 .hw.init = &(struct clk_init_data) { 1818 .name = "gcc_cdsp_tbu_clk", 1819 .parent_hws = (const struct clk_hw*[]) { 1820 &cdsp_bimc_clk_src.clkr.hw 1821 }, 1822 .num_parents = 1, 1823 .flags = CLK_SET_RATE_PARENT, 1824 .ops = &clk_branch2_ops, 1825 }, 1826 }, 1827 }; 1828 1829 static struct clk_branch gcc_gp1_clk = { 1830 .halt_reg = 0x8000, 1831 .halt_check = BRANCH_HALT, 1832 .clkr = { 1833 .enable_reg = 0x8000, 1834 .enable_mask = BIT(0), 1835 .hw.init = &(struct clk_init_data){ 1836 .name = "gcc_gp1_clk", 1837 .parent_hws = (const struct clk_hw*[]) { 1838 &gp1_clk_src.clkr.hw, 1839 }, 1840 .num_parents = 1, 1841 .flags = CLK_SET_RATE_PARENT, 1842 .ops = &clk_branch2_ops, 1843 }, 1844 }, 1845 }; 1846 1847 static struct clk_branch gcc_gp2_clk = { 1848 .halt_reg = 0x9000, 1849 .halt_check = BRANCH_HALT, 1850 .clkr = { 1851 .enable_reg = 0x9000, 1852 .enable_mask = BIT(0), 1853 .hw.init = &(struct clk_init_data){ 1854 .name = "gcc_gp2_clk", 1855 .parent_hws = (const struct clk_hw*[]) { 1856 &gp2_clk_src.clkr.hw, 1857 }, 1858 .num_parents = 1, 1859 .flags = CLK_SET_RATE_PARENT, 1860 .ops = &clk_branch2_ops, 1861 }, 1862 }, 1863 }; 1864 1865 static struct clk_branch gcc_gp3_clk = { 1866 .halt_reg = 0xa000, 1867 .halt_check = BRANCH_HALT, 1868 .clkr = { 1869 .enable_reg = 0xa000, 1870 .enable_mask = BIT(0), 1871 .hw.init = &(struct clk_init_data){ 1872 .name = "gcc_gp3_clk", 1873 .parent_hws = (const struct clk_hw*[]) { 1874 &gp3_clk_src.clkr.hw, 1875 }, 1876 .num_parents = 1, 1877 .flags = CLK_SET_RATE_PARENT, 1878 .ops = &clk_branch2_ops, 1879 }, 1880 }, 1881 }; 1882 1883 static struct clk_branch gcc_gtcu_ahb_clk = { 1884 .halt_reg = 0x12044, 1885 .halt_check = BRANCH_VOTED, 1886 .clkr = { 1887 .enable_reg = 0x4500c, 1888 .enable_mask = BIT(13), 1889 .hw.init = &(struct clk_init_data){ 1890 .name = "gcc_gtcu_ahb_clk", 1891 .ops = &clk_branch2_ops, 1892 }, 1893 }, 1894 }; 1895 1896 static struct clk_branch gcc_mdp_tbu_clk = { 1897 .halt_reg = 0x1201c, 1898 .halt_check = BRANCH_VOTED, 1899 .clkr = { 1900 .enable_reg = 0x4500c, 1901 .enable_mask = BIT(4), 1902 .hw.init = &(struct clk_init_data){ 1903 .name = "gcc_mdp_tbu_clk", 1904 .ops = &clk_branch2_ops, 1905 }, 1906 }, 1907 }; 1908 1909 static struct clk_branch gcc_mdss_ahb_clk = { 1910 .halt_reg = 0x4d07c, 1911 .halt_check = BRANCH_HALT, 1912 .clkr = { 1913 .enable_reg = 0x4d07c, 1914 .enable_mask = BIT(0), 1915 .hw.init = &(struct clk_init_data){ 1916 .name = "gcc_mdss_ahb_clk", 1917 .ops = &clk_branch2_ops, 1918 }, 1919 }, 1920 }; 1921 1922 static struct clk_branch gcc_mdss_axi_clk = { 1923 .halt_reg = 0x4d080, 1924 .halt_check = BRANCH_HALT, 1925 .clkr = { 1926 .enable_reg = 0x4d080, 1927 .enable_mask = BIT(0), 1928 .hw.init = &(struct clk_init_data){ 1929 .name = "gcc_mdss_axi_clk", 1930 .ops = &clk_branch2_ops, 1931 }, 1932 }, 1933 }; 1934 1935 static struct clk_branch gcc_mdss_byte0_clk = { 1936 .halt_reg = 0x4d094, 1937 .halt_check = BRANCH_HALT, 1938 .clkr = { 1939 .enable_reg = 0x4d094, 1940 .enable_mask = BIT(0), 1941 .hw.init = &(struct clk_init_data){ 1942 .name = "gcc_mdss_byte0_clk", 1943 .parent_hws = (const struct clk_hw*[]) { 1944 &byte0_clk_src.clkr.hw, 1945 }, 1946 .num_parents = 1, 1947 .flags = CLK_SET_RATE_PARENT, 1948 .ops = &clk_branch2_ops, 1949 }, 1950 }, 1951 }; 1952 1953 static struct clk_branch gcc_mdss_esc0_clk = { 1954 .halt_reg = 0x4d098, 1955 .halt_check = BRANCH_HALT, 1956 .clkr = { 1957 .enable_reg = 0x4d098, 1958 .enable_mask = BIT(0), 1959 .hw.init = &(struct clk_init_data){ 1960 .name = "gcc_mdss_esc0_clk", 1961 .parent_hws = (const struct clk_hw*[]) { 1962 &esc0_clk_src.clkr.hw, 1963 }, 1964 .num_parents = 1, 1965 .flags = CLK_SET_RATE_PARENT, 1966 .ops = &clk_branch2_ops, 1967 }, 1968 }, 1969 }; 1970 1971 static struct clk_branch gcc_mdss_hdmi_app_clk = { 1972 .halt_reg = 0x4d0d8, 1973 .halt_check = BRANCH_HALT, 1974 .clkr = { 1975 .enable_reg = 0x4d0d8, 1976 .enable_mask = BIT(0), 1977 .hw.init = &(struct clk_init_data){ 1978 .name = "gcc_mdss_hdmi_app_clk", 1979 .parent_hws = (const struct clk_hw*[]) { 1980 &hdmi_app_clk_src.clkr.hw, 1981 }, 1982 .num_parents = 1, 1983 .flags = CLK_SET_RATE_PARENT, 1984 .ops = &clk_branch2_ops, 1985 }, 1986 }, 1987 }; 1988 1989 static struct clk_branch gcc_mdss_hdmi_pclk_clk = { 1990 .halt_reg = 0x4d0d4, 1991 .halt_check = BRANCH_HALT, 1992 .clkr = { 1993 .enable_reg = 0x4d0d4, 1994 .enable_mask = BIT(0), 1995 .hw.init = &(struct clk_init_data){ 1996 .name = "gcc_mdss_hdmi_pclk_clk", 1997 .parent_hws = (const struct clk_hw*[]) { 1998 &hdmi_pclk_clk_src.clkr.hw, 1999 }, 2000 .num_parents = 1, 2001 .flags = CLK_SET_RATE_PARENT, 2002 .ops = &clk_branch2_ops, 2003 }, 2004 }, 2005 }; 2006 2007 static struct clk_branch gcc_mdss_mdp_clk = { 2008 .halt_reg = 0x4d088, 2009 .halt_check = BRANCH_HALT, 2010 .clkr = { 2011 .enable_reg = 0x4d088, 2012 .enable_mask = BIT(0), 2013 .hw.init = &(struct clk_init_data){ 2014 .name = "gcc_mdss_mdp_clk", 2015 .parent_hws = (const struct clk_hw*[]) { 2016 &mdp_clk_src.clkr.hw, 2017 }, 2018 .num_parents = 1, 2019 .flags = CLK_SET_RATE_PARENT, 2020 .ops = &clk_branch2_ops, 2021 }, 2022 }, 2023 }; 2024 2025 static struct clk_branch gcc_mdss_pclk0_clk = { 2026 .halt_reg = 0x4d084, 2027 .halt_check = BRANCH_HALT, 2028 .clkr = { 2029 .enable_reg = 0x4d084, 2030 .enable_mask = BIT(0), 2031 .hw.init = &(struct clk_init_data){ 2032 .name = "gcc_mdss_pclk0_clk", 2033 .parent_hws = (const struct clk_hw*[]) { 2034 &pclk0_clk_src.clkr.hw, 2035 }, 2036 .num_parents = 1, 2037 .flags = CLK_SET_RATE_PARENT, 2038 .ops = &clk_branch2_ops, 2039 }, 2040 }, 2041 }; 2042 2043 static struct clk_branch gcc_mdss_vsync_clk = { 2044 .halt_reg = 0x4d090, 2045 .halt_check = BRANCH_HALT, 2046 .clkr = { 2047 .enable_reg = 0x4d090, 2048 .enable_mask = BIT(0), 2049 .hw.init = &(struct clk_init_data){ 2050 .name = "gcc_mdss_vsync_clk", 2051 .parent_hws = (const struct clk_hw*[]) { 2052 &vsync_clk_src.clkr.hw, 2053 }, 2054 .num_parents = 1, 2055 .flags = CLK_SET_RATE_PARENT, 2056 .ops = &clk_branch2_ops, 2057 }, 2058 }, 2059 }; 2060 2061 static struct clk_branch gcc_oxili_ahb_clk = { 2062 .halt_reg = 0x59028, 2063 .halt_check = BRANCH_HALT, 2064 .clkr = { 2065 .enable_reg = 0x59028, 2066 .enable_mask = BIT(0), 2067 .hw.init = &(struct clk_init_data){ 2068 .name = "gcc_oxili_ahb_clk", 2069 .ops = &clk_branch2_ops, 2070 }, 2071 }, 2072 }; 2073 2074 static struct clk_branch gcc_oxili_gfx3d_clk = { 2075 .halt_reg = 0x59020, 2076 .halt_check = BRANCH_HALT, 2077 .clkr = { 2078 .enable_reg = 0x59020, 2079 .enable_mask = BIT(0), 2080 .hw.init = &(struct clk_init_data){ 2081 .name = "gcc_oxili_gfx3d_clk", 2082 .parent_hws = (const struct clk_hw*[]) { 2083 &gfx3d_clk_src.clkr.hw, 2084 }, 2085 .num_parents = 1, 2086 .flags = CLK_SET_RATE_PARENT, 2087 .ops = &clk_branch2_ops, 2088 }, 2089 }, 2090 }; 2091 2092 static struct clk_branch gcc_pcie_0_aux_clk = { 2093 .halt_reg = 0x3e014, 2094 .halt_check = BRANCH_HALT_VOTED, 2095 .clkr = { 2096 .enable_reg = 0x45004, 2097 .enable_mask = BIT(27), 2098 .hw.init = &(struct clk_init_data){ 2099 .name = "gcc_pcie_0_aux_clk", 2100 .parent_hws = (const struct clk_hw*[]) { 2101 &pcie_0_aux_clk_src.clkr.hw, 2102 }, 2103 .num_parents = 1, 2104 .flags = CLK_SET_RATE_PARENT, 2105 .ops = &clk_branch2_ops, 2106 }, 2107 }, 2108 }; 2109 2110 static struct clk_branch gcc_pcie_0_cfg_ahb_clk = { 2111 .halt_reg = 0x3e008, 2112 .halt_check = BRANCH_HALT_VOTED, 2113 .clkr = { 2114 .enable_reg = 0x45004, 2115 .enable_mask = BIT(11), 2116 .hw.init = &(struct clk_init_data){ 2117 .name = "gcc_pcie_0_cfg_ahb_clk", 2118 .ops = &clk_branch2_ops, 2119 }, 2120 }, 2121 }; 2122 2123 static struct clk_branch gcc_pcie_0_mstr_axi_clk = { 2124 .halt_reg = 0x3e018, 2125 .halt_check = BRANCH_HALT_VOTED, 2126 .clkr = { 2127 .enable_reg = 0x45004, 2128 .enable_mask = BIT(18), 2129 .hw.init = &(struct clk_init_data){ 2130 .name = "gcc_pcie_0_mstr_axi_clk", 2131 .ops = &clk_branch2_ops, 2132 }, 2133 }, 2134 }; 2135 2136 static struct clk_branch gcc_pcie_0_pipe_clk = { 2137 .halt_reg = 0x3e00c, 2138 .halt_check = BRANCH_HALT_VOTED, 2139 .clkr = { 2140 .enable_reg = 0x45004, 2141 .enable_mask = BIT(28), 2142 .hw.init = &(struct clk_init_data){ 2143 .name = "gcc_pcie_0_pipe_clk", 2144 .parent_hws = (const struct clk_hw*[]) { 2145 &pcie_0_pipe_clk_src.clkr.hw, 2146 }, 2147 .num_parents = 1, 2148 .flags = CLK_SET_RATE_PARENT, 2149 .ops = &clk_branch2_ops, 2150 }, 2151 }, 2152 }; 2153 2154 static struct clk_branch gcc_pcie_0_slv_axi_clk = { 2155 .halt_reg = 0x3e010, 2156 .halt_check = BRANCH_HALT_VOTED, 2157 .clkr = { 2158 .enable_reg = 0x45004, 2159 .enable_mask = BIT(22), 2160 .hw.init = &(struct clk_init_data){ 2161 .name = "gcc_pcie_0_slv_axi_clk", 2162 .ops = &clk_branch2_ops, 2163 }, 2164 }, 2165 }; 2166 2167 static struct clk_branch gcc_pcnoc_usb2_clk = { 2168 .halt_reg = 0x27008, 2169 .halt_check = BRANCH_HALT, 2170 .clkr = { 2171 .enable_reg = 0x27008, 2172 .enable_mask = BIT(0), 2173 .hw.init = &(struct clk_init_data){ 2174 .name = "gcc_pcnoc_usb2_clk", 2175 .flags = CLK_IS_CRITICAL, 2176 .ops = &clk_branch2_ops, 2177 }, 2178 }, 2179 }; 2180 2181 static struct clk_branch gcc_pcnoc_usb3_clk = { 2182 .halt_reg = 0x2700c, 2183 .halt_check = BRANCH_HALT, 2184 .clkr = { 2185 .enable_reg = 0x2700c, 2186 .enable_mask = BIT(0), 2187 .hw.init = &(struct clk_init_data){ 2188 .name = "gcc_pcnoc_usb3_clk", 2189 .flags = CLK_IS_CRITICAL, 2190 .ops = &clk_branch2_ops, 2191 }, 2192 }, 2193 }; 2194 2195 static struct clk_branch gcc_pdm2_clk = { 2196 .halt_reg = 0x4400c, 2197 .halt_check = BRANCH_HALT, 2198 .clkr = { 2199 .enable_reg = 0x4400c, 2200 .enable_mask = BIT(0), 2201 .hw.init = &(struct clk_init_data){ 2202 .name = "gcc_pdm2_clk", 2203 .parent_hws = (const struct clk_hw*[]) { 2204 &pdm2_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_pdm_ahb_clk = { 2214 .halt_reg = 0x44004, 2215 .halt_check = BRANCH_HALT, 2216 .clkr = { 2217 .enable_reg = 0x44004, 2218 .enable_mask = BIT(0), 2219 .hw.init = &(struct clk_init_data){ 2220 .name = "gcc_pdm_ahb_clk", 2221 .ops = &clk_branch2_ops, 2222 }, 2223 }, 2224 }; 2225 2226 static struct clk_branch gcc_prng_ahb_clk = { 2227 .halt_reg = 0x13004, 2228 .halt_check = BRANCH_HALT_VOTED, 2229 .clkr = { 2230 .enable_reg = 0x45004, 2231 .enable_mask = BIT(8), 2232 .hw.init = &(struct clk_init_data){ 2233 .name = "gcc_prng_ahb_clk", 2234 .ops = &clk_branch2_ops, 2235 }, 2236 }, 2237 }; 2238 2239 /* PWM clks do not have XO as parent as src clk is a balance root */ 2240 static struct clk_branch gcc_pwm0_xo512_clk = { 2241 .halt_reg = 0x44018, 2242 .halt_check = BRANCH_HALT, 2243 .clkr = { 2244 .enable_reg = 0x44018, 2245 .enable_mask = BIT(0), 2246 .hw.init = &(struct clk_init_data){ 2247 .name = "gcc_pwm0_xo512_clk", 2248 .ops = &clk_branch2_ops, 2249 }, 2250 }, 2251 }; 2252 2253 static struct clk_branch gcc_pwm1_xo512_clk = { 2254 .halt_reg = 0x49004, 2255 .halt_check = BRANCH_HALT, 2256 .clkr = { 2257 .enable_reg = 0x49004, 2258 .enable_mask = BIT(0), 2259 .hw.init = &(struct clk_init_data){ 2260 .name = "gcc_pwm1_xo512_clk", 2261 .ops = &clk_branch2_ops, 2262 }, 2263 }, 2264 }; 2265 2266 static struct clk_branch gcc_pwm2_xo512_clk = { 2267 .halt_reg = 0x4a004, 2268 .halt_check = BRANCH_HALT, 2269 .clkr = { 2270 .enable_reg = 0x4a004, 2271 .enable_mask = BIT(0), 2272 .hw.init = &(struct clk_init_data){ 2273 .name = "gcc_pwm2_xo512_clk", 2274 .ops = &clk_branch2_ops, 2275 }, 2276 }, 2277 }; 2278 2279 static struct clk_branch gcc_qdss_dap_clk = { 2280 .halt_reg = 0x29084, 2281 .halt_check = BRANCH_VOTED, 2282 .clkr = { 2283 .enable_reg = 0x45004, 2284 .enable_mask = BIT(21), 2285 .hw.init = &(struct clk_init_data){ 2286 .name = "gcc_qdss_dap_clk", 2287 .ops = &clk_branch2_ops, 2288 }, 2289 }, 2290 }; 2291 2292 static struct clk_branch gcc_sdcc1_ahb_clk = { 2293 .halt_reg = 0x4201c, 2294 .halt_check = BRANCH_HALT, 2295 .clkr = { 2296 .enable_reg = 0x4201c, 2297 .enable_mask = BIT(0), 2298 .hw.init = &(struct clk_init_data){ 2299 .name = "gcc_sdcc1_ahb_clk", 2300 .ops = &clk_branch2_ops, 2301 }, 2302 }, 2303 }; 2304 2305 static struct clk_branch gcc_sdcc1_apps_clk = { 2306 .halt_reg = 0x42018, 2307 .halt_check = BRANCH_HALT, 2308 .clkr = { 2309 .enable_reg = 0x42018, 2310 .enable_mask = BIT(0), 2311 .hw.init = &(struct clk_init_data){ 2312 .name = "gcc_sdcc1_apps_clk", 2313 .parent_hws = (const struct clk_hw*[]) { 2314 &sdcc1_apps_clk_src.clkr.hw, 2315 }, 2316 .num_parents = 1, 2317 .flags = CLK_SET_RATE_PARENT, 2318 .ops = &clk_branch2_ops, 2319 }, 2320 }, 2321 }; 2322 2323 static struct clk_branch gcc_sdcc1_ice_core_clk = { 2324 .halt_reg = 0x5d014, 2325 .halt_check = BRANCH_HALT, 2326 .clkr = { 2327 .enable_reg = 0x5d014, 2328 .enable_mask = BIT(0), 2329 .hw.init = &(struct clk_init_data){ 2330 .name = "gcc_sdcc1_ice_core_clk", 2331 .parent_hws = (const struct clk_hw*[]) { 2332 &sdcc1_ice_core_clk_src.clkr.hw, 2333 }, 2334 .num_parents = 1, 2335 .flags = CLK_SET_RATE_PARENT, 2336 .ops = &clk_branch2_ops, 2337 }, 2338 }, 2339 }; 2340 2341 static struct clk_branch gcc_cdsp_cfg_ahb_clk = { 2342 .halt_reg = 0x5e004, 2343 .halt_check = BRANCH_HALT, 2344 .clkr = { 2345 .enable_reg = 0x5e004, 2346 .enable_mask = BIT(0), 2347 .hw.init = &(struct clk_init_data) { 2348 .name = "gcc_cdsp_cfg_ahb_cbcr", 2349 .ops = &clk_branch2_ops, 2350 }, 2351 }, 2352 }; 2353 2354 static struct clk_branch gcc_sdcc2_ahb_clk = { 2355 .halt_reg = 0x4301c, 2356 .halt_check = BRANCH_HALT, 2357 .clkr = { 2358 .enable_reg = 0x4301c, 2359 .enable_mask = BIT(0), 2360 .hw.init = &(struct clk_init_data){ 2361 .name = "gcc_sdcc2_ahb_clk", 2362 .ops = &clk_branch2_ops, 2363 }, 2364 }, 2365 }; 2366 2367 static struct clk_branch gcc_sdcc2_apps_clk = { 2368 .halt_reg = 0x43018, 2369 .halt_check = BRANCH_HALT, 2370 .clkr = { 2371 .enable_reg = 0x43018, 2372 .enable_mask = BIT(0), 2373 .hw.init = &(struct clk_init_data){ 2374 .name = "gcc_sdcc2_apps_clk", 2375 .parent_hws = (const struct clk_hw*[]) { 2376 &sdcc2_apps_clk_src.clkr.hw, 2377 }, 2378 .num_parents = 1, 2379 .flags = CLK_SET_RATE_PARENT, 2380 .ops = &clk_branch2_ops, 2381 }, 2382 }, 2383 }; 2384 2385 static struct clk_branch gcc_smmu_cfg_clk = { 2386 .halt_reg = 0x12038, 2387 .halt_check = BRANCH_VOTED, 2388 .clkr = { 2389 .enable_reg = 0x3600C, 2390 .enable_mask = BIT(12), 2391 .hw.init = &(struct clk_init_data){ 2392 .name = "gcc_smmu_cfg_clk", 2393 .ops = &clk_branch2_ops, 2394 }, 2395 }, 2396 }; 2397 2398 static struct clk_branch gcc_sys_noc_usb3_clk = { 2399 .halt_reg = 0x26014, 2400 .halt_check = BRANCH_HALT, 2401 .clkr = { 2402 .enable_reg = 0x26014, 2403 .enable_mask = BIT(0), 2404 .hw.init = &(struct clk_init_data){ 2405 .name = "gcc_sys_noc_usb3_clk", 2406 .parent_hws = (const struct clk_hw*[]) { 2407 &usb30_master_clk_src.clkr.hw, 2408 }, 2409 .num_parents = 1, 2410 .ops = &clk_branch2_ops, 2411 }, 2412 }, 2413 }; 2414 2415 static struct clk_branch gcc_usb_hs_inactivity_timers_clk = { 2416 .halt_reg = 0x4100C, 2417 .halt_check = BRANCH_HALT, 2418 .clkr = { 2419 .enable_reg = 0x4100C, 2420 .enable_mask = BIT(0), 2421 .hw.init = &(struct clk_init_data){ 2422 .name = "gcc_usb_hs_inactivity_timers_clk", 2423 .ops = &clk_branch2_ops, 2424 }, 2425 }, 2426 }; 2427 2428 static struct clk_branch gcc_usb20_mock_utmi_clk = { 2429 .halt_reg = 0x41044, 2430 .halt_check = BRANCH_HALT, 2431 .clkr = { 2432 .enable_reg = 0x41044, 2433 .enable_mask = BIT(0), 2434 .hw.init = &(struct clk_init_data){ 2435 .name = "gcc_usb20_mock_utmi_clk", 2436 .parent_hws = (const struct clk_hw*[]) { 2437 &usb20_mock_utmi_clk_src.clkr.hw, 2438 }, 2439 .num_parents = 1, 2440 .flags = CLK_SET_RATE_PARENT, 2441 .ops = &clk_branch2_ops, 2442 }, 2443 }, 2444 }; 2445 2446 static struct clk_branch gcc_usb2a_phy_sleep_clk = { 2447 .halt_reg = 0x4102c, 2448 .halt_check = BRANCH_HALT, 2449 .clkr = { 2450 .enable_reg = 0x4102c, 2451 .enable_mask = BIT(0), 2452 .hw.init = &(struct clk_init_data){ 2453 .name = "gcc_usb2a_phy_sleep_clk", 2454 .ops = &clk_branch2_ops, 2455 }, 2456 }, 2457 }; 2458 2459 static struct clk_branch gcc_usb30_master_clk = { 2460 .halt_reg = 0x3900c, 2461 .halt_check = BRANCH_HALT, 2462 .clkr = { 2463 .enable_reg = 0x3900c, 2464 .enable_mask = BIT(0), 2465 .hw.init = &(struct clk_init_data){ 2466 .name = "gcc_usb30_master_clk", 2467 .parent_hws = (const struct clk_hw*[]) { 2468 &usb30_master_clk_src.clkr.hw, 2469 }, 2470 .num_parents = 1, 2471 .flags = CLK_SET_RATE_PARENT, 2472 .ops = &clk_branch2_ops, 2473 }, 2474 }, 2475 }; 2476 2477 static struct clk_branch gcc_usb30_mock_utmi_clk = { 2478 .halt_reg = 0x39014, 2479 .halt_check = BRANCH_HALT, 2480 .clkr = { 2481 .enable_reg = 0x39014, 2482 .enable_mask = BIT(0), 2483 .hw.init = &(struct clk_init_data){ 2484 .name = "gcc_usb30_mock_utmi_clk", 2485 .parent_hws = (const struct clk_hw*[]) { 2486 &usb30_mock_utmi_clk_src.clkr.hw, 2487 }, 2488 .num_parents = 1, 2489 .flags = CLK_SET_RATE_PARENT, 2490 .ops = &clk_branch2_ops, 2491 }, 2492 }, 2493 }; 2494 2495 static struct clk_branch gcc_usb30_sleep_clk = { 2496 .halt_reg = 0x39010, 2497 .halt_check = BRANCH_HALT, 2498 .clkr = { 2499 .enable_reg = 0x39010, 2500 .enable_mask = BIT(0), 2501 .hw.init = &(struct clk_init_data){ 2502 .name = "gcc_usb30_sleep_clk", 2503 .ops = &clk_branch2_ops, 2504 }, 2505 }, 2506 }; 2507 2508 static struct clk_branch gcc_usb3_phy_aux_clk = { 2509 .halt_reg = 0x39044, 2510 .halt_check = BRANCH_HALT, 2511 .clkr = { 2512 .enable_reg = 0x39044, 2513 .enable_mask = BIT(0), 2514 .hw.init = &(struct clk_init_data){ 2515 .name = "gcc_usb3_phy_aux_clk", 2516 .parent_hws = (const struct clk_hw*[]) { 2517 &usb3_phy_aux_clk_src.clkr.hw, 2518 }, 2519 .num_parents = 1, 2520 .flags = CLK_SET_RATE_PARENT, 2521 .ops = &clk_branch2_ops, 2522 }, 2523 }, 2524 }; 2525 2526 static struct clk_branch gcc_usb3_phy_pipe_clk = { 2527 .halt_check = BRANCH_HALT_SKIP, 2528 .clkr = { 2529 .enable_reg = 0x39018, 2530 .enable_mask = BIT(0), 2531 .hw.init = &(struct clk_init_data){ 2532 .name = "gcc_usb3_phy_pipe_clk", 2533 .ops = &clk_branch2_ops, 2534 }, 2535 }, 2536 }; 2537 2538 static struct clk_branch gcc_usb_hs_phy_cfg_ahb_clk = { 2539 .halt_reg = 0x41030, 2540 .halt_check = BRANCH_HALT, 2541 .clkr = { 2542 .enable_reg = 0x41030, 2543 .enable_mask = BIT(0), 2544 .hw.init = &(struct clk_init_data){ 2545 .name = "gcc_usb_hs_phy_cfg_ahb_clk", 2546 .ops = &clk_branch2_ops, 2547 }, 2548 }, 2549 }; 2550 2551 static struct clk_branch gcc_usb_hs_system_clk = { 2552 .halt_reg = 0x41004, 2553 .halt_check = BRANCH_HALT, 2554 .clkr = { 2555 .enable_reg = 0x41004, 2556 .enable_mask = BIT(0), 2557 .hw.init = &(struct clk_init_data){ 2558 .name = "gcc_usb_hs_system_clk", 2559 .parent_hws = (const struct clk_hw*[]) { 2560 &usb_hs_system_clk_src.clkr.hw, 2561 }, 2562 .num_parents = 1, 2563 .flags = CLK_SET_RATE_PARENT, 2564 .ops = &clk_branch2_ops, 2565 }, 2566 }, 2567 }; 2568 2569 static struct clk_branch gcc_wdsp_q6ss_ahbs_clk = { 2570 .halt_reg = 0x1e004, 2571 .halt_check = BRANCH_HALT, 2572 .clkr = { 2573 .enable_reg = 0x1e004, 2574 .enable_mask = BIT(0), 2575 .hw.init = &(struct clk_init_data){ 2576 .name = "gcc_wdsp_q6ss_ahbs_clk", 2577 .ops = &clk_branch2_ops, 2578 }, 2579 }, 2580 }; 2581 2582 static struct clk_branch gcc_wdsp_q6ss_axim_clk = { 2583 .halt_reg = 0x1e008, 2584 .halt_check = BRANCH_HALT, 2585 .clkr = { 2586 .enable_reg = 0x1e008, 2587 .enable_mask = BIT(0), 2588 .hw.init = &(struct clk_init_data){ 2589 .name = "gcc_wdsp_q6ss_axim_clk", 2590 .ops = &clk_branch2_ops, 2591 }, 2592 }, 2593 }; 2594 2595 static struct gdsc mdss_gdsc = { 2596 .gdscr = 0x4d078, 2597 .pd = { 2598 .name = "mdss", 2599 }, 2600 .pwrsts = PWRSTS_OFF_ON, 2601 }; 2602 2603 static struct gdsc oxili_gdsc = { 2604 .gdscr = 0x5901c, 2605 .pd = { 2606 .name = "oxili", 2607 }, 2608 .pwrsts = PWRSTS_OFF_ON, 2609 }; 2610 2611 static struct clk_hw *gcc_qcs404_hws[] = { 2612 &cxo.hw, 2613 }; 2614 2615 static struct clk_regmap *gcc_qcs404_clocks[] = { 2616 [GCC_APSS_AHB_CLK_SRC] = &apss_ahb_clk_src.clkr, 2617 [GCC_BLSP1_QUP0_I2C_APPS_CLK_SRC] = &blsp1_qup0_i2c_apps_clk_src.clkr, 2618 [GCC_BLSP1_QUP0_SPI_APPS_CLK_SRC] = &blsp1_qup0_spi_apps_clk_src.clkr, 2619 [GCC_BLSP1_QUP1_I2C_APPS_CLK_SRC] = &blsp1_qup1_i2c_apps_clk_src.clkr, 2620 [GCC_BLSP1_QUP1_SPI_APPS_CLK_SRC] = &blsp1_qup1_spi_apps_clk_src.clkr, 2621 [GCC_BLSP1_QUP2_I2C_APPS_CLK_SRC] = &blsp1_qup2_i2c_apps_clk_src.clkr, 2622 [GCC_BLSP1_QUP2_SPI_APPS_CLK_SRC] = &blsp1_qup2_spi_apps_clk_src.clkr, 2623 [GCC_BLSP1_QUP3_I2C_APPS_CLK_SRC] = &blsp1_qup3_i2c_apps_clk_src.clkr, 2624 [GCC_BLSP1_QUP3_SPI_APPS_CLK_SRC] = &blsp1_qup3_spi_apps_clk_src.clkr, 2625 [GCC_BLSP1_QUP4_I2C_APPS_CLK_SRC] = &blsp1_qup4_i2c_apps_clk_src.clkr, 2626 [GCC_BLSP1_QUP4_SPI_APPS_CLK_SRC] = &blsp1_qup4_spi_apps_clk_src.clkr, 2627 [GCC_BLSP1_UART0_APPS_CLK_SRC] = &blsp1_uart0_apps_clk_src.clkr, 2628 [GCC_BLSP1_UART1_APPS_CLK_SRC] = &blsp1_uart1_apps_clk_src.clkr, 2629 [GCC_BLSP1_UART2_APPS_CLK_SRC] = &blsp1_uart2_apps_clk_src.clkr, 2630 [GCC_BLSP1_UART3_APPS_CLK_SRC] = &blsp1_uart3_apps_clk_src.clkr, 2631 [GCC_BLSP2_QUP0_I2C_APPS_CLK_SRC] = &blsp2_qup0_i2c_apps_clk_src.clkr, 2632 [GCC_BLSP2_QUP0_SPI_APPS_CLK_SRC] = &blsp2_qup0_spi_apps_clk_src.clkr, 2633 [GCC_BLSP2_UART0_APPS_CLK_SRC] = &blsp2_uart0_apps_clk_src.clkr, 2634 [GCC_BYTE0_CLK_SRC] = &byte0_clk_src.clkr, 2635 [GCC_EMAC_CLK_SRC] = &emac_clk_src.clkr, 2636 [GCC_EMAC_PTP_CLK_SRC] = &emac_ptp_clk_src.clkr, 2637 [GCC_ESC0_CLK_SRC] = &esc0_clk_src.clkr, 2638 [GCC_APSS_AHB_CLK] = &gcc_apss_ahb_clk.clkr, 2639 [GCC_BIMC_GFX_CLK] = &gcc_bimc_gfx_clk.clkr, 2640 [GCC_BIMC_CDSP_CLK] = &gcc_bimc_cdsp_clk.clkr, 2641 [GCC_BIMC_MDSS_CLK] = &gcc_bimc_mdss_clk.clkr, 2642 [GCC_BLSP1_AHB_CLK] = &gcc_blsp1_ahb_clk.clkr, 2643 [GCC_BLSP1_QUP0_I2C_APPS_CLK] = &gcc_blsp1_qup0_i2c_apps_clk.clkr, 2644 [GCC_BLSP1_QUP0_SPI_APPS_CLK] = &gcc_blsp1_qup0_spi_apps_clk.clkr, 2645 [GCC_BLSP1_QUP1_I2C_APPS_CLK] = &gcc_blsp1_qup1_i2c_apps_clk.clkr, 2646 [GCC_BLSP1_QUP1_SPI_APPS_CLK] = &gcc_blsp1_qup1_spi_apps_clk.clkr, 2647 [GCC_BLSP1_QUP2_I2C_APPS_CLK] = &gcc_blsp1_qup2_i2c_apps_clk.clkr, 2648 [GCC_BLSP1_QUP2_SPI_APPS_CLK] = &gcc_blsp1_qup2_spi_apps_clk.clkr, 2649 [GCC_BLSP1_QUP3_I2C_APPS_CLK] = &gcc_blsp1_qup3_i2c_apps_clk.clkr, 2650 [GCC_BLSP1_QUP3_SPI_APPS_CLK] = &gcc_blsp1_qup3_spi_apps_clk.clkr, 2651 [GCC_BLSP1_QUP4_I2C_APPS_CLK] = &gcc_blsp1_qup4_i2c_apps_clk.clkr, 2652 [GCC_BLSP1_QUP4_SPI_APPS_CLK] = &gcc_blsp1_qup4_spi_apps_clk.clkr, 2653 [GCC_BLSP1_UART0_APPS_CLK] = &gcc_blsp1_uart0_apps_clk.clkr, 2654 [GCC_BLSP1_UART1_APPS_CLK] = &gcc_blsp1_uart1_apps_clk.clkr, 2655 [GCC_BLSP1_UART2_APPS_CLK] = &gcc_blsp1_uart2_apps_clk.clkr, 2656 [GCC_BLSP1_UART3_APPS_CLK] = &gcc_blsp1_uart3_apps_clk.clkr, 2657 [GCC_BLSP2_AHB_CLK] = &gcc_blsp2_ahb_clk.clkr, 2658 [GCC_BLSP2_QUP0_I2C_APPS_CLK] = &gcc_blsp2_qup0_i2c_apps_clk.clkr, 2659 [GCC_BLSP2_QUP0_SPI_APPS_CLK] = &gcc_blsp2_qup0_spi_apps_clk.clkr, 2660 [GCC_BLSP2_UART0_APPS_CLK] = &gcc_blsp2_uart0_apps_clk.clkr, 2661 [GCC_BOOT_ROM_AHB_CLK] = &gcc_boot_rom_ahb_clk.clkr, 2662 [GCC_ETH_AXI_CLK] = &gcc_eth_axi_clk.clkr, 2663 [GCC_ETH_PTP_CLK] = &gcc_eth_ptp_clk.clkr, 2664 [GCC_ETH_RGMII_CLK] = &gcc_eth_rgmii_clk.clkr, 2665 [GCC_ETH_SLAVE_AHB_CLK] = &gcc_eth_slave_ahb_clk.clkr, 2666 [GCC_GENI_IR_S_CLK] = &gcc_geni_ir_s_clk.clkr, 2667 [GCC_GENI_IR_H_CLK] = &gcc_geni_ir_h_clk.clkr, 2668 [GCC_GP1_CLK] = &gcc_gp1_clk.clkr, 2669 [GCC_GP2_CLK] = &gcc_gp2_clk.clkr, 2670 [GCC_GP3_CLK] = &gcc_gp3_clk.clkr, 2671 [GCC_MDSS_AHB_CLK] = &gcc_mdss_ahb_clk.clkr, 2672 [GCC_MDSS_AXI_CLK] = &gcc_mdss_axi_clk.clkr, 2673 [GCC_MDSS_BYTE0_CLK] = &gcc_mdss_byte0_clk.clkr, 2674 [GCC_MDSS_ESC0_CLK] = &gcc_mdss_esc0_clk.clkr, 2675 [GCC_MDSS_HDMI_APP_CLK] = &gcc_mdss_hdmi_app_clk.clkr, 2676 [GCC_MDSS_HDMI_PCLK_CLK] = &gcc_mdss_hdmi_pclk_clk.clkr, 2677 [GCC_MDSS_MDP_CLK] = &gcc_mdss_mdp_clk.clkr, 2678 [GCC_MDSS_PCLK0_CLK] = &gcc_mdss_pclk0_clk.clkr, 2679 [GCC_MDSS_VSYNC_CLK] = &gcc_mdss_vsync_clk.clkr, 2680 [GCC_OXILI_AHB_CLK] = &gcc_oxili_ahb_clk.clkr, 2681 [GCC_OXILI_GFX3D_CLK] = &gcc_oxili_gfx3d_clk.clkr, 2682 [GCC_PCIE_0_AUX_CLK] = &gcc_pcie_0_aux_clk.clkr, 2683 [GCC_PCIE_0_CFG_AHB_CLK] = &gcc_pcie_0_cfg_ahb_clk.clkr, 2684 [GCC_PCIE_0_MSTR_AXI_CLK] = &gcc_pcie_0_mstr_axi_clk.clkr, 2685 [GCC_PCIE_0_PIPE_CLK] = &gcc_pcie_0_pipe_clk.clkr, 2686 [GCC_PCIE_0_SLV_AXI_CLK] = &gcc_pcie_0_slv_axi_clk.clkr, 2687 [GCC_PCNOC_USB2_CLK] = &gcc_pcnoc_usb2_clk.clkr, 2688 [GCC_PCNOC_USB3_CLK] = &gcc_pcnoc_usb3_clk.clkr, 2689 [GCC_PDM2_CLK] = &gcc_pdm2_clk.clkr, 2690 [GCC_PDM_AHB_CLK] = &gcc_pdm_ahb_clk.clkr, 2691 [GCC_PRNG_AHB_CLK] = &gcc_prng_ahb_clk.clkr, 2692 [GCC_PWM0_XO512_CLK] = &gcc_pwm0_xo512_clk.clkr, 2693 [GCC_PWM1_XO512_CLK] = &gcc_pwm1_xo512_clk.clkr, 2694 [GCC_PWM2_XO512_CLK] = &gcc_pwm2_xo512_clk.clkr, 2695 [GCC_SDCC1_AHB_CLK] = &gcc_sdcc1_ahb_clk.clkr, 2696 [GCC_SDCC1_APPS_CLK] = &gcc_sdcc1_apps_clk.clkr, 2697 [GCC_SDCC1_ICE_CORE_CLK] = &gcc_sdcc1_ice_core_clk.clkr, 2698 [GCC_CDSP_CFG_AHB_CLK] = &gcc_cdsp_cfg_ahb_clk.clkr, 2699 [GCC_SDCC2_AHB_CLK] = &gcc_sdcc2_ahb_clk.clkr, 2700 [GCC_SDCC2_APPS_CLK] = &gcc_sdcc2_apps_clk.clkr, 2701 [GCC_SYS_NOC_USB3_CLK] = &gcc_sys_noc_usb3_clk.clkr, 2702 [GCC_USB20_MOCK_UTMI_CLK] = &gcc_usb20_mock_utmi_clk.clkr, 2703 [GCC_USB2A_PHY_SLEEP_CLK] = &gcc_usb2a_phy_sleep_clk.clkr, 2704 [GCC_USB30_MASTER_CLK] = &gcc_usb30_master_clk.clkr, 2705 [GCC_USB30_MOCK_UTMI_CLK] = &gcc_usb30_mock_utmi_clk.clkr, 2706 [GCC_USB30_SLEEP_CLK] = &gcc_usb30_sleep_clk.clkr, 2707 [GCC_USB3_PHY_AUX_CLK] = &gcc_usb3_phy_aux_clk.clkr, 2708 [GCC_USB3_PHY_PIPE_CLK] = &gcc_usb3_phy_pipe_clk.clkr, 2709 [GCC_USB_HS_PHY_CFG_AHB_CLK] = &gcc_usb_hs_phy_cfg_ahb_clk.clkr, 2710 [GCC_USB_HS_SYSTEM_CLK] = &gcc_usb_hs_system_clk.clkr, 2711 [GCC_GFX3D_CLK_SRC] = &gfx3d_clk_src.clkr, 2712 [GCC_GP1_CLK_SRC] = &gp1_clk_src.clkr, 2713 [GCC_GP2_CLK_SRC] = &gp2_clk_src.clkr, 2714 [GCC_GP3_CLK_SRC] = &gp3_clk_src.clkr, 2715 [GCC_GPLL0_OUT_MAIN] = &gpll0_out_main.clkr, 2716 [GCC_GPLL0_AO_OUT_MAIN] = &gpll0_ao_out_main.clkr, 2717 [GCC_GPLL0_SLEEP_CLK_SRC] = &gpll0_sleep_clk_src.clkr, 2718 [GCC_GPLL1_OUT_MAIN] = &gpll1_out_main.clkr, 2719 [GCC_GPLL3_OUT_MAIN] = &gpll3_out_main.clkr, 2720 [GCC_GPLL4_OUT_MAIN] = &gpll4_out_main.clkr, 2721 [GCC_GPLL6] = &gpll6.clkr, 2722 [GCC_GPLL6_OUT_AUX] = &gpll6_out_aux, 2723 [GCC_HDMI_APP_CLK_SRC] = &hdmi_app_clk_src.clkr, 2724 [GCC_HDMI_PCLK_CLK_SRC] = &hdmi_pclk_clk_src.clkr, 2725 [GCC_MDP_CLK_SRC] = &mdp_clk_src.clkr, 2726 [GCC_PCIE_0_AUX_CLK_SRC] = &pcie_0_aux_clk_src.clkr, 2727 [GCC_PCIE_0_PIPE_CLK_SRC] = &pcie_0_pipe_clk_src.clkr, 2728 [GCC_PCLK0_CLK_SRC] = &pclk0_clk_src.clkr, 2729 [GCC_PDM2_CLK_SRC] = &pdm2_clk_src.clkr, 2730 [GCC_SDCC1_APPS_CLK_SRC] = &sdcc1_apps_clk_src.clkr, 2731 [GCC_SDCC1_ICE_CORE_CLK_SRC] = &sdcc1_ice_core_clk_src.clkr, 2732 [GCC_SDCC2_APPS_CLK_SRC] = &sdcc2_apps_clk_src.clkr, 2733 [GCC_USB20_MOCK_UTMI_CLK_SRC] = &usb20_mock_utmi_clk_src.clkr, 2734 [GCC_USB30_MASTER_CLK_SRC] = &usb30_master_clk_src.clkr, 2735 [GCC_USB30_MOCK_UTMI_CLK_SRC] = &usb30_mock_utmi_clk_src.clkr, 2736 [GCC_USB3_PHY_AUX_CLK_SRC] = &usb3_phy_aux_clk_src.clkr, 2737 [GCC_USB_HS_SYSTEM_CLK_SRC] = &usb_hs_system_clk_src.clkr, 2738 [GCC_VSYNC_CLK_SRC] = &vsync_clk_src.clkr, 2739 [GCC_CDSP_BIMC_CLK_SRC] = &cdsp_bimc_clk_src.clkr, 2740 [GCC_USB_HS_INACTIVITY_TIMERS_CLK] = 2741 &gcc_usb_hs_inactivity_timers_clk.clkr, 2742 [GCC_BIMC_GPU_CLK] = &gcc_bimc_gpu_clk.clkr, 2743 [GCC_GTCU_AHB_CLK] = &gcc_gtcu_ahb_clk.clkr, 2744 [GCC_GFX_TCU_CLK] = &gcc_gfx_tcu_clk.clkr, 2745 [GCC_GFX_TBU_CLK] = &gcc_gfx_tbu_clk.clkr, 2746 [GCC_SMMU_CFG_CLK] = &gcc_smmu_cfg_clk.clkr, 2747 [GCC_APSS_TCU_CLK] = &gcc_apss_tcu_clk.clkr, 2748 [GCC_CDSP_TBU_CLK] = &gcc_cdsp_tbu_clk.clkr, 2749 [GCC_CRYPTO_AHB_CLK] = &gcc_crypto_ahb_clk.clkr, 2750 [GCC_CRYPTO_AXI_CLK] = &gcc_crypto_axi_clk.clkr, 2751 [GCC_CRYPTO_CLK] = &gcc_crypto_clk.clkr, 2752 [GCC_MDP_TBU_CLK] = &gcc_mdp_tbu_clk.clkr, 2753 [GCC_QDSS_DAP_CLK] = &gcc_qdss_dap_clk.clkr, 2754 [GCC_DCC_CLK] = &gcc_dcc_clk.clkr, 2755 [GCC_DCC_XO_CLK] = &gcc_dcc_xo_clk.clkr, 2756 [GCC_WCSS_Q6_AHB_CLK] = &gcc_wdsp_q6ss_ahbs_clk.clkr, 2757 [GCC_WCSS_Q6_AXIM_CLK] = &gcc_wdsp_q6ss_axim_clk.clkr, 2758 2759 }; 2760 2761 static struct gdsc *gcc_qcs404_gdscs[] = { 2762 [MDSS_GDSC] = &mdss_gdsc, 2763 [OXILI_GDSC] = &oxili_gdsc, 2764 }; 2765 2766 static const struct qcom_reset_map gcc_qcs404_resets[] = { 2767 [GCC_GENI_IR_BCR] = { 0x0F000 }, 2768 [GCC_CDSP_RESTART] = { 0x18000 }, 2769 [GCC_USB_HS_BCR] = { 0x41000 }, 2770 [GCC_USB2_HS_PHY_ONLY_BCR] = { 0x41034 }, 2771 [GCC_QUSB2_PHY_BCR] = { 0x4103c }, 2772 [GCC_USB_HS_PHY_CFG_AHB_BCR] = { 0x0000c, 1 }, 2773 [GCC_USB2A_PHY_BCR] = { 0x0000c, 0 }, 2774 [GCC_USB3_PHY_BCR] = { 0x39004 }, 2775 [GCC_USB_30_BCR] = { 0x39000 }, 2776 [GCC_USB3PHY_PHY_BCR] = { 0x39008 }, 2777 [GCC_PCIE_0_BCR] = { 0x3e000 }, 2778 [GCC_PCIE_0_PHY_BCR] = { 0x3e004 }, 2779 [GCC_PCIE_0_LINK_DOWN_BCR] = { 0x3e038 }, 2780 [GCC_PCIEPHY_0_PHY_BCR] = { 0x3e03c }, 2781 [GCC_PCIE_0_AXI_MASTER_STICKY_ARES] = { 0x3e040, 6}, 2782 [GCC_PCIE_0_AHB_ARES] = { 0x3e040, 5 }, 2783 [GCC_PCIE_0_AXI_SLAVE_ARES] = { 0x3e040, 4 }, 2784 [GCC_PCIE_0_AXI_MASTER_ARES] = { 0x3e040, 3 }, 2785 [GCC_PCIE_0_CORE_STICKY_ARES] = { 0x3e040, 2 }, 2786 [GCC_PCIE_0_SLEEP_ARES] = { 0x3e040, 1 }, 2787 [GCC_PCIE_0_PIPE_ARES] = { 0x3e040, 0 }, 2788 [GCC_EMAC_BCR] = { 0x4e000 }, 2789 [GCC_WDSP_RESTART] = {0x19000}, 2790 }; 2791 2792 static const struct regmap_config gcc_qcs404_regmap_config = { 2793 .reg_bits = 32, 2794 .reg_stride = 4, 2795 .val_bits = 32, 2796 .max_register = 0x7f000, 2797 .fast_io = true, 2798 }; 2799 2800 static const struct qcom_cc_desc gcc_qcs404_desc = { 2801 .config = &gcc_qcs404_regmap_config, 2802 .clks = gcc_qcs404_clocks, 2803 .num_clks = ARRAY_SIZE(gcc_qcs404_clocks), 2804 .resets = gcc_qcs404_resets, 2805 .num_resets = ARRAY_SIZE(gcc_qcs404_resets), 2806 .clk_hws = gcc_qcs404_hws, 2807 .num_clk_hws = ARRAY_SIZE(gcc_qcs404_hws), 2808 .gdscs = gcc_qcs404_gdscs, 2809 .num_gdscs = ARRAY_SIZE(gcc_qcs404_gdscs), 2810 }; 2811 2812 static const struct of_device_id gcc_qcs404_match_table[] = { 2813 { .compatible = "qcom,gcc-qcs404" }, 2814 { } 2815 }; 2816 MODULE_DEVICE_TABLE(of, gcc_qcs404_match_table); 2817 2818 static int gcc_qcs404_probe(struct platform_device *pdev) 2819 { 2820 struct regmap *regmap; 2821 2822 regmap = qcom_cc_map(pdev, &gcc_qcs404_desc); 2823 if (IS_ERR(regmap)) 2824 return PTR_ERR(regmap); 2825 2826 clk_alpha_pll_configure(&gpll3_out_main, regmap, &gpll3_config); 2827 2828 return qcom_cc_really_probe(&pdev->dev, &gcc_qcs404_desc, regmap); 2829 } 2830 2831 static struct platform_driver gcc_qcs404_driver = { 2832 .probe = gcc_qcs404_probe, 2833 .driver = { 2834 .name = "gcc-qcs404", 2835 .of_match_table = gcc_qcs404_match_table, 2836 }, 2837 }; 2838 2839 static int __init gcc_qcs404_init(void) 2840 { 2841 return platform_driver_register(&gcc_qcs404_driver); 2842 } 2843 core_initcall(gcc_qcs404_init); 2844 2845 static void __exit gcc_qcs404_exit(void) 2846 { 2847 platform_driver_unregister(&gcc_qcs404_driver); 2848 } 2849 module_exit(gcc_qcs404_exit); 2850 2851 MODULE_DESCRIPTION("Qualcomm GCC QCS404 Driver"); 2852 MODULE_LICENSE("GPL v2"); 2853