1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * Copyright (c) 2022, Qualcomm Innovation Center, Inc. All rights reserved 4 * Copyright (c) 2023, Linaro Limited 5 */ 6 7 #include <linux/clk-provider.h> 8 #include <linux/mod_devicetable.h> 9 #include <linux/module.h> 10 #include <linux/platform_device.h> 11 #include <linux/regmap.h> 12 13 #include <dt-bindings/clock/qcom,sm8650-gpucc.h> 14 #include <dt-bindings/reset/qcom,sm8650-gpucc.h> 15 16 #include "clk-alpha-pll.h" 17 #include "clk-branch.h" 18 #include "clk-rcg.h" 19 #include "clk-regmap.h" 20 #include "clk-regmap-divider.h" 21 #include "clk-regmap-mux.h" 22 #include "clk-regmap-phy-mux.h" 23 #include "gdsc.h" 24 #include "reset.h" 25 26 enum { 27 DT_BI_TCXO, 28 DT_GPLL0_OUT_MAIN, 29 DT_GPLL0_OUT_MAIN_DIV, 30 }; 31 32 enum { 33 P_BI_TCXO, 34 P_GPLL0_OUT_MAIN, 35 P_GPLL0_OUT_MAIN_DIV, 36 P_GPU_CC_PLL0_OUT_MAIN, 37 P_GPU_CC_PLL1_OUT_MAIN, 38 }; 39 40 static const struct pll_vco lucid_ole_vco[] = { 41 { 249600000, 2100000000, 0 }, 42 }; 43 44 static const struct alpha_pll_config gpu_cc_pll0_config = { 45 .l = 0x20, 46 .alpha = 0x4aaa, 47 .config_ctl_val = 0x20485699, 48 .config_ctl_hi_val = 0x00182261, 49 .config_ctl_hi1_val = 0x82aa299c, 50 .test_ctl_val = 0x00000000, 51 .test_ctl_hi_val = 0x00000003, 52 .test_ctl_hi1_val = 0x00009000, 53 .test_ctl_hi2_val = 0x00000034, 54 .user_ctl_val = 0x00000000, 55 .user_ctl_hi_val = 0x00000005, 56 }; 57 58 static struct clk_alpha_pll gpu_cc_pll0 = { 59 .offset = 0x0, 60 .vco_table = lucid_ole_vco, 61 .num_vco = ARRAY_SIZE(lucid_ole_vco), 62 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE], 63 .clkr = { 64 .hw.init = &(struct clk_init_data){ 65 .name = "gpu_cc_pll0", 66 .parent_data = &(const struct clk_parent_data){ 67 .index = DT_BI_TCXO, 68 }, 69 .num_parents = 1, 70 .ops = &clk_alpha_pll_lucid_evo_ops, 71 }, 72 }, 73 }; 74 75 static const struct alpha_pll_config gpu_cc_pll1_config = { 76 .l = 0x1b, 77 .alpha = 0x1555, 78 .config_ctl_val = 0x20485699, 79 .config_ctl_hi_val = 0x00182261, 80 .config_ctl_hi1_val = 0x82aa299c, 81 .test_ctl_val = 0x00000000, 82 .test_ctl_hi_val = 0x00000003, 83 .test_ctl_hi1_val = 0x00009000, 84 .test_ctl_hi2_val = 0x00000034, 85 .user_ctl_val = 0x00000000, 86 .user_ctl_hi_val = 0x00000005, 87 }; 88 89 static struct clk_alpha_pll gpu_cc_pll1 = { 90 .offset = 0x1000, 91 .vco_table = lucid_ole_vco, 92 .num_vco = ARRAY_SIZE(lucid_ole_vco), 93 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_LUCID_OLE], 94 .clkr = { 95 .hw.init = &(struct clk_init_data){ 96 .name = "gpu_cc_pll1", 97 .parent_data = &(const struct clk_parent_data){ 98 .index = DT_BI_TCXO, 99 }, 100 .num_parents = 1, 101 .ops = &clk_alpha_pll_lucid_evo_ops, 102 }, 103 }, 104 }; 105 106 static const struct parent_map gpu_cc_parent_map_0[] = { 107 { P_BI_TCXO, 0 }, 108 { P_GPLL0_OUT_MAIN, 5 }, 109 { P_GPLL0_OUT_MAIN_DIV, 6 }, 110 }; 111 112 static const struct clk_parent_data gpu_cc_parent_data_0[] = { 113 { .index = DT_BI_TCXO }, 114 { .index = DT_GPLL0_OUT_MAIN }, 115 { .index = DT_GPLL0_OUT_MAIN_DIV }, 116 }; 117 118 static const struct parent_map gpu_cc_parent_map_1[] = { 119 { P_BI_TCXO, 0 }, 120 { P_GPU_CC_PLL0_OUT_MAIN, 1 }, 121 { P_GPU_CC_PLL1_OUT_MAIN, 3 }, 122 { P_GPLL0_OUT_MAIN, 5 }, 123 { P_GPLL0_OUT_MAIN_DIV, 6 }, 124 }; 125 126 static const struct clk_parent_data gpu_cc_parent_data_1[] = { 127 { .index = DT_BI_TCXO }, 128 { .hw = &gpu_cc_pll0.clkr.hw }, 129 { .hw = &gpu_cc_pll1.clkr.hw }, 130 { .index = DT_GPLL0_OUT_MAIN }, 131 { .index = DT_GPLL0_OUT_MAIN_DIV }, 132 }; 133 134 static const struct parent_map gpu_cc_parent_map_2[] = { 135 { P_BI_TCXO, 0 }, 136 { P_GPU_CC_PLL1_OUT_MAIN, 3 }, 137 { P_GPLL0_OUT_MAIN, 5 }, 138 { P_GPLL0_OUT_MAIN_DIV, 6 }, 139 }; 140 141 static const struct clk_parent_data gpu_cc_parent_data_2[] = { 142 { .index = DT_BI_TCXO }, 143 { .hw = &gpu_cc_pll1.clkr.hw }, 144 { .index = DT_GPLL0_OUT_MAIN }, 145 { .index = DT_GPLL0_OUT_MAIN_DIV }, 146 }; 147 148 static const struct freq_tbl ftbl_gpu_cc_ff_clk_src[] = { 149 F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0), 150 { } 151 }; 152 153 static struct clk_rcg2 gpu_cc_ff_clk_src = { 154 .cmd_rcgr = 0x9474, 155 .mnd_width = 0, 156 .hid_width = 5, 157 .parent_map = gpu_cc_parent_map_0, 158 .freq_tbl = ftbl_gpu_cc_ff_clk_src, 159 .hw_clk_ctrl = true, 160 .clkr.hw.init = &(struct clk_init_data){ 161 .name = "gpu_cc_ff_clk_src", 162 .parent_data = gpu_cc_parent_data_0, 163 .num_parents = ARRAY_SIZE(gpu_cc_parent_data_0), 164 .flags = CLK_SET_RATE_PARENT, 165 .ops = &clk_rcg2_shared_ops, 166 }, 167 }; 168 169 static const struct freq_tbl ftbl_gpu_cc_gmu_clk_src[] = { 170 F(19200000, P_BI_TCXO, 1, 0, 0), 171 F(260000000, P_GPU_CC_PLL1_OUT_MAIN, 2, 0, 0), 172 F(625000000, P_GPU_CC_PLL1_OUT_MAIN, 2, 0, 0), 173 { } 174 }; 175 176 static struct clk_rcg2 gpu_cc_gmu_clk_src = { 177 .cmd_rcgr = 0x9318, 178 .mnd_width = 0, 179 .hid_width = 5, 180 .parent_map = gpu_cc_parent_map_1, 181 .freq_tbl = ftbl_gpu_cc_gmu_clk_src, 182 .hw_clk_ctrl = true, 183 .clkr.hw.init = &(struct clk_init_data){ 184 .name = "gpu_cc_gmu_clk_src", 185 .parent_data = gpu_cc_parent_data_1, 186 .num_parents = ARRAY_SIZE(gpu_cc_parent_data_1), 187 .flags = CLK_SET_RATE_PARENT, 188 .ops = &clk_rcg2_shared_ops, 189 }, 190 }; 191 192 static const struct freq_tbl ftbl_gpu_cc_hub_clk_src[] = { 193 F(200000000, P_GPLL0_OUT_MAIN, 3, 0, 0), 194 F(300000000, P_GPLL0_OUT_MAIN, 2, 0, 0), 195 { } 196 }; 197 198 static struct clk_rcg2 gpu_cc_hub_clk_src = { 199 .cmd_rcgr = 0x93ec, 200 .mnd_width = 0, 201 .hid_width = 5, 202 .parent_map = gpu_cc_parent_map_2, 203 .freq_tbl = ftbl_gpu_cc_hub_clk_src, 204 .hw_clk_ctrl = true, 205 .clkr.hw.init = &(struct clk_init_data){ 206 .name = "gpu_cc_hub_clk_src", 207 .parent_data = gpu_cc_parent_data_2, 208 .num_parents = ARRAY_SIZE(gpu_cc_parent_data_2), 209 .flags = CLK_SET_RATE_PARENT, 210 .ops = &clk_rcg2_shared_ops, 211 }, 212 }; 213 214 static struct clk_regmap_div gpu_cc_hub_div_clk_src = { 215 .reg = 0x942c, 216 .shift = 0, 217 .width = 4, 218 .clkr.hw.init = &(const struct clk_init_data) { 219 .name = "gpu_cc_hub_div_clk_src", 220 .parent_hws = (const struct clk_hw*[]){ 221 &gpu_cc_hub_clk_src.clkr.hw, 222 }, 223 .num_parents = 1, 224 .flags = CLK_SET_RATE_PARENT, 225 .ops = &clk_regmap_div_ro_ops, 226 }, 227 }; 228 229 static struct clk_branch gpu_cc_ahb_clk = { 230 .halt_reg = 0x911c, 231 .halt_check = BRANCH_HALT_DELAY, 232 .clkr = { 233 .enable_reg = 0x911c, 234 .enable_mask = BIT(0), 235 .hw.init = &(struct clk_init_data){ 236 .name = "gpu_cc_ahb_clk", 237 .parent_hws = (const struct clk_hw*[]){ 238 &gpu_cc_hub_div_clk_src.clkr.hw, 239 }, 240 .num_parents = 1, 241 .flags = CLK_SET_RATE_PARENT, 242 .ops = &clk_branch2_ops, 243 }, 244 }, 245 }; 246 247 static struct clk_branch gpu_cc_crc_ahb_clk = { 248 .halt_reg = 0x9120, 249 .halt_check = BRANCH_HALT_VOTED, 250 .clkr = { 251 .enable_reg = 0x9120, 252 .enable_mask = BIT(0), 253 .hw.init = &(struct clk_init_data){ 254 .name = "gpu_cc_crc_ahb_clk", 255 .parent_hws = (const struct clk_hw*[]){ 256 &gpu_cc_hub_clk_src.clkr.hw, 257 }, 258 .num_parents = 1, 259 .flags = CLK_SET_RATE_PARENT, 260 .ops = &clk_branch2_ops, 261 }, 262 }, 263 }; 264 265 static struct clk_branch gpu_cc_cx_accu_shift_clk = { 266 .halt_reg = 0x9160, 267 .halt_check = BRANCH_HALT_VOTED, 268 .clkr = { 269 .enable_reg = 0x9160, 270 .enable_mask = BIT(0), 271 .hw.init = &(const struct clk_init_data){ 272 .name = "gpu_cc_cx_accu_shift_clk", 273 .ops = &clk_branch2_ops, 274 }, 275 }, 276 }; 277 278 static struct clk_branch gpu_cc_cx_ff_clk = { 279 .halt_reg = 0x914c, 280 .halt_check = BRANCH_HALT, 281 .clkr = { 282 .enable_reg = 0x914c, 283 .enable_mask = BIT(0), 284 .hw.init = &(struct clk_init_data){ 285 .name = "gpu_cc_cx_ff_clk", 286 .parent_hws = (const struct clk_hw*[]){ 287 &gpu_cc_ff_clk_src.clkr.hw, 288 }, 289 .num_parents = 1, 290 .flags = CLK_SET_RATE_PARENT, 291 .ops = &clk_branch2_ops, 292 }, 293 }, 294 }; 295 296 static struct clk_branch gpu_cc_cx_gmu_clk = { 297 .halt_reg = 0x913c, 298 .halt_check = BRANCH_HALT_VOTED, 299 .clkr = { 300 .enable_reg = 0x913c, 301 .enable_mask = BIT(0), 302 .hw.init = &(struct clk_init_data){ 303 .name = "gpu_cc_cx_gmu_clk", 304 .parent_hws = (const struct clk_hw*[]){ 305 &gpu_cc_gmu_clk_src.clkr.hw, 306 }, 307 .num_parents = 1, 308 .flags = CLK_SET_RATE_PARENT, 309 .ops = &clk_branch2_aon_ops, 310 }, 311 }, 312 }; 313 314 static struct clk_branch gpu_cc_cxo_aon_clk = { 315 .halt_reg = 0x9004, 316 .halt_check = BRANCH_HALT_VOTED, 317 .clkr = { 318 .enable_reg = 0x9004, 319 .enable_mask = BIT(0), 320 .hw.init = &(struct clk_init_data){ 321 .name = "gpu_cc_cxo_aon_clk", 322 .ops = &clk_branch2_ops, 323 }, 324 }, 325 }; 326 327 static struct clk_branch gpu_cc_cxo_clk = { 328 .halt_reg = 0x9144, 329 .halt_check = BRANCH_HALT, 330 .clkr = { 331 .enable_reg = 0x9144, 332 .enable_mask = BIT(0), 333 .hw.init = &(struct clk_init_data){ 334 .name = "gpu_cc_cxo_clk", 335 .ops = &clk_branch2_ops, 336 }, 337 }, 338 }; 339 340 static struct clk_branch gpu_cc_demet_clk = { 341 .halt_reg = 0x900c, 342 .halt_check = BRANCH_HALT, 343 .clkr = { 344 .enable_reg = 0x900c, 345 .enable_mask = BIT(0), 346 .hw.init = &(struct clk_init_data){ 347 .name = "gpu_cc_demet_clk", 348 .ops = &clk_branch2_aon_ops, 349 }, 350 }, 351 }; 352 353 static struct clk_branch gpu_cc_freq_measure_clk = { 354 .halt_reg = 0x9008, 355 .halt_check = BRANCH_HALT, 356 .clkr = { 357 .enable_reg = 0x9008, 358 .enable_mask = BIT(0), 359 .hw.init = &(struct clk_init_data){ 360 .name = "gpu_cc_freq_measure_clk", 361 .ops = &clk_branch2_ops, 362 }, 363 }, 364 }; 365 366 static struct clk_branch gpu_cc_gx_gfx3d_clk = { 367 .halt_reg = 0x90a8, 368 .halt_check = BRANCH_HALT, 369 .clkr = { 370 .enable_reg = 0x90a8, 371 .enable_mask = BIT(0), 372 .hw.init = &(struct clk_init_data){ 373 .name = "gpu_cc_gx_gfx3d_clk", 374 .ops = &clk_branch2_ops, 375 }, 376 }, 377 }; 378 379 static struct clk_branch gpu_cc_gx_gfx3d_rdvm_clk = { 380 .halt_reg = 0x90c8, 381 .halt_check = BRANCH_HALT, 382 .clkr = { 383 .enable_reg = 0x90c8, 384 .enable_mask = BIT(0), 385 .hw.init = &(struct clk_init_data){ 386 .name = "gpu_cc_gx_gfx3d_rdvm_clk", 387 .ops = &clk_branch2_ops, 388 }, 389 }, 390 }; 391 392 static struct clk_branch gpu_cc_gx_gmu_clk = { 393 .halt_reg = 0x90bc, 394 .halt_check = BRANCH_HALT, 395 .clkr = { 396 .enable_reg = 0x90bc, 397 .enable_mask = BIT(0), 398 .hw.init = &(struct clk_init_data){ 399 .name = "gpu_cc_gx_gmu_clk", 400 .parent_hws = (const struct clk_hw*[]){ 401 &gpu_cc_gmu_clk_src.clkr.hw, 402 }, 403 .num_parents = 1, 404 .flags = CLK_SET_RATE_PARENT, 405 .ops = &clk_branch2_ops, 406 }, 407 }, 408 }; 409 410 static struct clk_branch gpu_cc_gx_vsense_clk = { 411 .halt_reg = 0x90b0, 412 .halt_check = BRANCH_HALT_VOTED, 413 .clkr = { 414 .enable_reg = 0x90b0, 415 .enable_mask = BIT(0), 416 .hw.init = &(struct clk_init_data){ 417 .name = "gpu_cc_gx_vsense_clk", 418 .ops = &clk_branch2_ops, 419 }, 420 }, 421 }; 422 423 static struct clk_branch gpu_cc_gx_accu_shift_clk = { 424 .halt_reg = 0x90d0, 425 .halt_check = BRANCH_HALT_VOTED, 426 .clkr = { 427 .enable_reg = 0x90d0, 428 .enable_mask = BIT(0), 429 .hw.init = &(const struct clk_init_data){ 430 .name = "gpu_cc_gx_accu_shift_clk", 431 .ops = &clk_branch2_ops, 432 }, 433 }, 434 }; 435 436 static struct clk_branch gpu_cc_gx_ff_clk = { 437 .halt_reg = 0x90c0, 438 .halt_check = BRANCH_HALT, 439 .clkr = { 440 .enable_reg = 0x90c0, 441 .enable_mask = BIT(0), 442 .hw.init = &(const struct clk_init_data){ 443 .name = "gpu_cc_gx_ff_clk", 444 .parent_hws = (const struct clk_hw*[]){ 445 &gpu_cc_ff_clk_src.clkr.hw, 446 }, 447 .num_parents = 1, 448 .flags = CLK_SET_RATE_PARENT, 449 .ops = &clk_branch2_ops, 450 }, 451 }, 452 }; 453 454 static struct clk_branch gpu_cc_hlos1_vote_gpu_smmu_clk = { 455 .halt_reg = 0x7000, 456 .halt_check = BRANCH_HALT_VOTED, 457 .clkr = { 458 .enable_reg = 0x7000, 459 .enable_mask = BIT(0), 460 .hw.init = &(struct clk_init_data){ 461 .name = "gpu_cc_hlos1_vote_gpu_smmu_clk", 462 .ops = &clk_branch2_ops, 463 }, 464 }, 465 }; 466 467 static struct clk_branch gpu_cc_hub_aon_clk = { 468 .halt_reg = 0x93e8, 469 .halt_check = BRANCH_HALT_VOTED, 470 .clkr = { 471 .enable_reg = 0x93e8, 472 .enable_mask = BIT(0), 473 .hw.init = &(struct clk_init_data){ 474 .name = "gpu_cc_hub_aon_clk", 475 .parent_hws = (const struct clk_hw*[]){ 476 &gpu_cc_hub_clk_src.clkr.hw, 477 }, 478 .num_parents = 1, 479 .flags = CLK_SET_RATE_PARENT, 480 .ops = &clk_branch2_aon_ops, 481 }, 482 }, 483 }; 484 485 static struct clk_branch gpu_cc_hub_cx_int_clk = { 486 .halt_reg = 0x9148, 487 .halt_check = BRANCH_HALT_VOTED, 488 .clkr = { 489 .enable_reg = 0x9148, 490 .enable_mask = BIT(0), 491 .hw.init = &(struct clk_init_data){ 492 .name = "gpu_cc_hub_cx_int_clk", 493 .parent_hws = (const struct clk_hw*[]){ 494 &gpu_cc_hub_clk_src.clkr.hw, 495 }, 496 .num_parents = 1, 497 .flags = CLK_SET_RATE_PARENT, 498 .ops = &clk_branch2_aon_ops, 499 }, 500 }, 501 }; 502 503 static struct clk_branch gpu_cc_memnoc_gfx_clk = { 504 .halt_reg = 0x9150, 505 .halt_check = BRANCH_HALT_VOTED, 506 .clkr = { 507 .enable_reg = 0x9150, 508 .enable_mask = BIT(0), 509 .hw.init = &(struct clk_init_data){ 510 .name = "gpu_cc_memnoc_gfx_clk", 511 .ops = &clk_branch2_ops, 512 }, 513 }, 514 }; 515 516 static struct clk_branch gpu_cc_sleep_clk = { 517 .halt_reg = 0x9134, 518 .halt_check = BRANCH_HALT_VOTED, 519 .clkr = { 520 .enable_reg = 0x9134, 521 .enable_mask = BIT(0), 522 .hw.init = &(struct clk_init_data){ 523 .name = "gpu_cc_sleep_clk", 524 .ops = &clk_branch2_ops, 525 }, 526 }, 527 }; 528 529 static struct clk_branch gpu_cc_dpm_clk = { 530 .halt_reg = 0x9164, 531 .halt_check = BRANCH_HALT, 532 .clkr = { 533 .enable_reg = 0x9164, 534 .enable_mask = BIT(0), 535 .hw.init = &(const struct clk_init_data){ 536 .name = "gpu_cc_dpm_clk", 537 .ops = &clk_branch2_ops, 538 }, 539 }, 540 }; 541 542 static struct gdsc gpu_cx_gdsc = { 543 .gdscr = 0x9108, 544 .gds_hw_ctrl = 0x9168, 545 .clk_dis_wait_val = 8, 546 .pd = { 547 .name = "gpu_cx_gdsc", 548 }, 549 .pwrsts = PWRSTS_OFF_ON, 550 .flags = VOTABLE | RETAIN_FF_ENABLE, 551 }; 552 553 static struct gdsc gpu_gx_gdsc = { 554 .gdscr = 0x905c, 555 .clamp_io_ctrl = 0x9504, 556 .resets = (unsigned int []){ GPUCC_GPU_CC_GX_BCR, 557 GPUCC_GPU_CC_ACD_BCR, 558 GPUCC_GPU_CC_GX_ACD_IROOT_BCR }, 559 .reset_count = 3, 560 .pd = { 561 .name = "gpu_gx_gdsc", 562 .power_on = gdsc_gx_do_nothing_enable, 563 }, 564 .pwrsts = PWRSTS_OFF_ON, 565 .flags = CLAMP_IO | AON_RESET | SW_RESET | POLL_CFG_GDSCR, 566 }; 567 568 static struct clk_regmap *gpu_cc_sm8650_clocks[] = { 569 [GPU_CC_AHB_CLK] = &gpu_cc_ahb_clk.clkr, 570 [GPU_CC_CRC_AHB_CLK] = &gpu_cc_crc_ahb_clk.clkr, 571 [GPU_CC_CX_ACCU_SHIFT_CLK] = &gpu_cc_cx_accu_shift_clk.clkr, 572 [GPU_CC_CX_FF_CLK] = &gpu_cc_cx_ff_clk.clkr, 573 [GPU_CC_CX_GMU_CLK] = &gpu_cc_cx_gmu_clk.clkr, 574 [GPU_CC_CXO_AON_CLK] = &gpu_cc_cxo_aon_clk.clkr, 575 [GPU_CC_CXO_CLK] = &gpu_cc_cxo_clk.clkr, 576 [GPU_CC_DEMET_CLK] = &gpu_cc_demet_clk.clkr, 577 [GPU_CC_DPM_CLK] = &gpu_cc_dpm_clk.clkr, 578 [GPU_CC_FF_CLK_SRC] = &gpu_cc_ff_clk_src.clkr, 579 [GPU_CC_FREQ_MEASURE_CLK] = &gpu_cc_freq_measure_clk.clkr, 580 [GPU_CC_GMU_CLK_SRC] = &gpu_cc_gmu_clk_src.clkr, 581 [GPU_CC_GX_ACCU_SHIFT_CLK] = &gpu_cc_gx_accu_shift_clk.clkr, 582 [GPU_CC_GX_FF_CLK] = &gpu_cc_gx_ff_clk.clkr, 583 [GPU_CC_GX_GFX3D_CLK] = &gpu_cc_gx_gfx3d_clk.clkr, 584 [GPU_CC_GX_GFX3D_RDVM_CLK] = &gpu_cc_gx_gfx3d_rdvm_clk.clkr, 585 [GPU_CC_GX_GMU_CLK] = &gpu_cc_gx_gmu_clk.clkr, 586 [GPU_CC_GX_VSENSE_CLK] = &gpu_cc_gx_vsense_clk.clkr, 587 [GPU_CC_HLOS1_VOTE_GPU_SMMU_CLK] = &gpu_cc_hlos1_vote_gpu_smmu_clk.clkr, 588 [GPU_CC_HUB_AON_CLK] = &gpu_cc_hub_aon_clk.clkr, 589 [GPU_CC_HUB_CLK_SRC] = &gpu_cc_hub_clk_src.clkr, 590 [GPU_CC_HUB_CX_INT_CLK] = &gpu_cc_hub_cx_int_clk.clkr, 591 [GPU_CC_HUB_DIV_CLK_SRC] = &gpu_cc_hub_div_clk_src.clkr, 592 [GPU_CC_MEMNOC_GFX_CLK] = &gpu_cc_memnoc_gfx_clk.clkr, 593 [GPU_CC_PLL0] = &gpu_cc_pll0.clkr, 594 [GPU_CC_PLL1] = &gpu_cc_pll1.clkr, 595 [GPU_CC_SLEEP_CLK] = &gpu_cc_sleep_clk.clkr, 596 }; 597 598 static const struct qcom_reset_map gpu_cc_sm8650_resets[] = { 599 [GPUCC_GPU_CC_XO_BCR] = { 0x9000 }, 600 [GPUCC_GPU_CC_GX_BCR] = { 0x9058 }, 601 [GPUCC_GPU_CC_CX_BCR] = { 0x9104 }, 602 [GPUCC_GPU_CC_GFX3D_AON_BCR] = { 0x9198 }, 603 [GPUCC_GPU_CC_ACD_BCR] = { 0x9358 }, 604 [GPUCC_GPU_CC_FAST_HUB_BCR] = { 0x93e4 }, 605 [GPUCC_GPU_CC_FF_BCR] = { 0x9470 }, 606 [GPUCC_GPU_CC_GMU_BCR] = { 0x9314 }, 607 [GPUCC_GPU_CC_GX_ACD_IROOT_BCR] = { 0x958c }, 608 }; 609 610 static struct gdsc *gpu_cc_sm8650_gdscs[] = { 611 [GPU_CX_GDSC] = &gpu_cx_gdsc, 612 [GPU_GX_GDSC] = &gpu_gx_gdsc, 613 }; 614 615 static const struct regmap_config gpu_cc_sm8650_regmap_config = { 616 .reg_bits = 32, 617 .reg_stride = 4, 618 .val_bits = 32, 619 .max_register = 0xa000, 620 .fast_io = true, 621 }; 622 623 static const struct qcom_cc_desc gpu_cc_sm8650_desc = { 624 .config = &gpu_cc_sm8650_regmap_config, 625 .clks = gpu_cc_sm8650_clocks, 626 .num_clks = ARRAY_SIZE(gpu_cc_sm8650_clocks), 627 .resets = gpu_cc_sm8650_resets, 628 .num_resets = ARRAY_SIZE(gpu_cc_sm8650_resets), 629 .gdscs = gpu_cc_sm8650_gdscs, 630 .num_gdscs = ARRAY_SIZE(gpu_cc_sm8650_gdscs), 631 }; 632 633 static const struct of_device_id gpu_cc_sm8650_match_table[] = { 634 { .compatible = "qcom,sm8650-gpucc" }, 635 { } 636 }; 637 MODULE_DEVICE_TABLE(of, gpu_cc_sm8650_match_table); 638 639 static int gpu_cc_sm8650_probe(struct platform_device *pdev) 640 { 641 struct regmap *regmap; 642 643 regmap = qcom_cc_map(pdev, &gpu_cc_sm8650_desc); 644 if (IS_ERR(regmap)) 645 return PTR_ERR(regmap); 646 647 clk_lucid_ole_pll_configure(&gpu_cc_pll0, regmap, &gpu_cc_pll0_config); 648 clk_lucid_ole_pll_configure(&gpu_cc_pll1, regmap, &gpu_cc_pll1_config); 649 650 return qcom_cc_really_probe(&pdev->dev, &gpu_cc_sm8650_desc, regmap); 651 } 652 653 static struct platform_driver gpu_cc_sm8650_driver = { 654 .probe = gpu_cc_sm8650_probe, 655 .driver = { 656 .name = "sm8650-gpucc", 657 .of_match_table = gpu_cc_sm8650_match_table, 658 }, 659 }; 660 module_platform_driver(gpu_cc_sm8650_driver); 661 662 MODULE_DESCRIPTION("QTI GPU_CC SM8650 Driver"); 663 MODULE_LICENSE("GPL"); 664