1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * Copyright (c) 2022, The Linux Foundation. All rights reserved. 4 * Copyright (c) 2022, Linaro Limited 5 */ 6 7 #include <linux/clk-provider.h> 8 #include <linux/module.h> 9 #include <linux/platform_device.h> 10 #include <linux/regmap.h> 11 12 #include <dt-bindings/clock/qcom,sm6350-camcc.h> 13 14 #include "clk-alpha-pll.h" 15 #include "clk-branch.h" 16 #include "clk-rcg.h" 17 #include "common.h" 18 #include "gdsc.h" 19 20 enum { 21 DT_BI_TCXO, 22 }; 23 24 enum { 25 P_BI_TCXO, 26 P_CAMCC_PLL0_OUT_EVEN, 27 P_CAMCC_PLL0_OUT_MAIN, 28 P_CAMCC_PLL1_OUT_EVEN, 29 P_CAMCC_PLL1_OUT_MAIN, 30 P_CAMCC_PLL2_OUT_EARLY, 31 P_CAMCC_PLL2_OUT_MAIN, 32 P_CAMCC_PLL3_OUT_MAIN, 33 }; 34 35 static struct pll_vco fabia_vco[] = { 36 { 249600000, 2000000000, 0 }, 37 }; 38 39 /* 600MHz configuration */ 40 static const struct alpha_pll_config camcc_pll0_config = { 41 .l = 0x1f, 42 .alpha = 0x4000, 43 .config_ctl_val = 0x20485699, 44 .config_ctl_hi_val = 0x00002067, 45 .test_ctl_val = 0x40000000, 46 .test_ctl_hi_val = 0x00000002, 47 .user_ctl_val = 0x00000101, 48 .user_ctl_hi_val = 0x00004805, 49 }; 50 51 static struct clk_alpha_pll camcc_pll0 = { 52 .offset = 0x0, 53 .vco_table = fabia_vco, 54 .num_vco = ARRAY_SIZE(fabia_vco), 55 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], 56 .clkr = { 57 .hw.init = &(struct clk_init_data){ 58 .name = "camcc_pll0", 59 .parent_data = &(const struct clk_parent_data){ 60 .index = DT_BI_TCXO, 61 }, 62 .num_parents = 1, 63 .ops = &clk_alpha_pll_fabia_ops, 64 }, 65 }, 66 }; 67 68 static const struct clk_div_table post_div_table_camcc_pll0_out_even[] = { 69 { 0x1, 2 }, 70 { } 71 }; 72 73 static struct clk_alpha_pll_postdiv camcc_pll0_out_even = { 74 .offset = 0x0, 75 .post_div_shift = 8, 76 .post_div_table = post_div_table_camcc_pll0_out_even, 77 .num_post_div = ARRAY_SIZE(post_div_table_camcc_pll0_out_even), 78 .width = 4, 79 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], 80 .clkr.hw.init = &(struct clk_init_data){ 81 .name = "camcc_pll0_out_even", 82 .parent_hws = (const struct clk_hw*[]){ 83 &camcc_pll0.clkr.hw, 84 }, 85 .num_parents = 1, 86 .flags = CLK_SET_RATE_PARENT, 87 .ops = &clk_alpha_pll_postdiv_fabia_ops, 88 }, 89 }; 90 91 /* 808MHz configuration */ 92 static const struct alpha_pll_config camcc_pll1_config = { 93 .l = 0x2a, 94 .alpha = 0x1555, 95 .config_ctl_val = 0x20485699, 96 .config_ctl_hi_val = 0x00002067, 97 .test_ctl_val = 0x40000000, 98 .test_ctl_hi_val = 0x00000000, 99 .user_ctl_val = 0x00000101, 100 .user_ctl_hi_val = 0x00004805, 101 }; 102 103 static struct clk_alpha_pll camcc_pll1 = { 104 .offset = 0x1000, 105 .vco_table = fabia_vco, 106 .num_vco = ARRAY_SIZE(fabia_vco), 107 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], 108 .clkr = { 109 .hw.init = &(struct clk_init_data){ 110 .name = "camcc_pll1", 111 .parent_data = &(const struct clk_parent_data){ 112 .index = DT_BI_TCXO, 113 }, 114 .num_parents = 1, 115 .ops = &clk_alpha_pll_fabia_ops, 116 }, 117 }, 118 }; 119 120 static const struct clk_div_table post_div_table_camcc_pll1_out_even[] = { 121 { 0x1, 2 }, 122 { } 123 }; 124 125 static struct clk_alpha_pll_postdiv camcc_pll1_out_even = { 126 .offset = 0x1000, 127 .post_div_shift = 8, 128 .post_div_table = post_div_table_camcc_pll1_out_even, 129 .num_post_div = ARRAY_SIZE(post_div_table_camcc_pll1_out_even), 130 .width = 4, 131 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], 132 .clkr.hw.init = &(struct clk_init_data){ 133 .name = "camcc_pll1_out_even", 134 .parent_hws = (const struct clk_hw*[]){ 135 &camcc_pll1.clkr.hw, 136 }, 137 .num_parents = 1, 138 .flags = CLK_SET_RATE_PARENT, 139 .ops = &clk_alpha_pll_postdiv_fabia_ops, 140 }, 141 }; 142 143 /* 1920MHz configuration */ 144 static const struct alpha_pll_config camcc_pll2_config = { 145 .l = 0x64, 146 .alpha = 0x0, 147 .post_div_val = 0x3 << 8, 148 .post_div_mask = 0x3 << 8, 149 .aux_output_mask = BIT(1), 150 .main_output_mask = BIT(0), 151 .early_output_mask = BIT(3), 152 .config_ctl_val = 0x20000800, 153 .config_ctl_hi_val = 0x400003d2, 154 .test_ctl_val = 0x04000400, 155 .test_ctl_hi_val = 0x00004000, 156 }; 157 158 static struct clk_alpha_pll camcc_pll2 = { 159 .offset = 0x2000, 160 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_AGERA], 161 .clkr = { 162 .hw.init = &(struct clk_init_data){ 163 .name = "camcc_pll2", 164 .parent_data = &(const struct clk_parent_data){ 165 .index = DT_BI_TCXO, 166 }, 167 .num_parents = 1, 168 .ops = &clk_alpha_pll_agera_ops, 169 }, 170 }, 171 }; 172 173 static struct clk_fixed_factor camcc_pll2_out_early = { 174 .mult = 1, 175 .div = 2, 176 .hw.init = &(struct clk_init_data){ 177 .name = "camcc_pll2_out_early", 178 .parent_hws = (const struct clk_hw*[]){ 179 &camcc_pll2.clkr.hw, 180 }, 181 .num_parents = 1, 182 .ops = &clk_fixed_factor_ops, 183 }, 184 }; 185 186 static const struct clk_div_table post_div_table_camcc_pll2_out_main[] = { 187 { 0x1, 2 }, 188 { } 189 }; 190 191 static struct clk_alpha_pll_postdiv camcc_pll2_out_main = { 192 .offset = 0x2000, 193 .post_div_shift = 8, 194 .post_div_table = post_div_table_camcc_pll2_out_main, 195 .num_post_div = ARRAY_SIZE(post_div_table_camcc_pll2_out_main), 196 .width = 2, 197 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_AGERA], 198 .clkr.hw.init = &(struct clk_init_data){ 199 .name = "camcc_pll2_out_main", 200 .parent_hws = (const struct clk_hw*[]){ 201 &camcc_pll2.clkr.hw, 202 }, 203 .num_parents = 1, 204 .flags = CLK_SET_RATE_PARENT, 205 .ops = &clk_alpha_pll_postdiv_ops, 206 }, 207 }; 208 209 /* 384MHz configuration */ 210 static const struct alpha_pll_config camcc_pll3_config = { 211 .l = 0x14, 212 .alpha = 0x0, 213 .config_ctl_val = 0x20485699, 214 .config_ctl_hi_val = 0x00002067, 215 .test_ctl_val = 0x40000000, 216 .test_ctl_hi_val = 0x00000002, 217 .user_ctl_val = 0x00000001, 218 .user_ctl_hi_val = 0x00014805, 219 }; 220 221 static struct clk_alpha_pll camcc_pll3 = { 222 .offset = 0x3000, 223 .vco_table = fabia_vco, 224 .num_vco = ARRAY_SIZE(fabia_vco), 225 .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA], 226 .clkr = { 227 .hw.init = &(struct clk_init_data){ 228 .name = "camcc_pll3", 229 .parent_data = &(const struct clk_parent_data){ 230 .index = DT_BI_TCXO, 231 }, 232 .num_parents = 1, 233 .ops = &clk_alpha_pll_fabia_ops, 234 }, 235 }, 236 }; 237 238 static const struct parent_map camcc_parent_map_0[] = { 239 { P_BI_TCXO, 0 }, 240 { P_CAMCC_PLL0_OUT_EVEN, 6 }, 241 }; 242 243 static const struct clk_parent_data camcc_parent_data_0[] = { 244 { .fw_name = "bi_tcxo" }, 245 { .hw = &camcc_pll0_out_even.clkr.hw }, 246 }; 247 248 static const struct parent_map camcc_parent_map_1[] = { 249 { P_BI_TCXO, 0 }, 250 { P_CAMCC_PLL0_OUT_MAIN, 1 }, 251 { P_CAMCC_PLL1_OUT_EVEN, 3 }, 252 { P_CAMCC_PLL2_OUT_MAIN, 4 }, 253 }; 254 255 static const struct clk_parent_data camcc_parent_data_1[] = { 256 { .fw_name = "bi_tcxo" }, 257 { .hw = &camcc_pll0.clkr.hw }, 258 { .hw = &camcc_pll1_out_even.clkr.hw }, 259 { .hw = &camcc_pll2_out_main.clkr.hw }, 260 }; 261 262 static const struct parent_map camcc_parent_map_2[] = { 263 { P_BI_TCXO, 0 }, 264 { P_CAMCC_PLL0_OUT_MAIN, 1 }, 265 { P_CAMCC_PLL3_OUT_MAIN, 5 }, 266 }; 267 268 static const struct clk_parent_data camcc_parent_data_2[] = { 269 { .fw_name = "bi_tcxo" }, 270 { .hw = &camcc_pll0.clkr.hw }, 271 { .hw = &camcc_pll3.clkr.hw }, 272 }; 273 274 static const struct parent_map camcc_parent_map_3[] = { 275 { P_BI_TCXO, 0 }, 276 { P_CAMCC_PLL2_OUT_EARLY, 3 }, 277 }; 278 279 static const struct clk_parent_data camcc_parent_data_3[] = { 280 { .fw_name = "bi_tcxo" }, 281 { .hw = &camcc_pll2_out_early.hw }, 282 }; 283 284 static const struct parent_map camcc_parent_map_4[] = { 285 { P_BI_TCXO, 0 }, 286 { P_CAMCC_PLL0_OUT_MAIN, 1 }, 287 { P_CAMCC_PLL1_OUT_EVEN, 3 }, 288 }; 289 290 static const struct clk_parent_data camcc_parent_data_4[] = { 291 { .fw_name = "bi_tcxo" }, 292 { .hw = &camcc_pll0.clkr.hw }, 293 { .hw = &camcc_pll1_out_even.clkr.hw }, 294 }; 295 296 static const struct parent_map camcc_parent_map_5[] = { 297 { P_BI_TCXO, 0 }, 298 { P_CAMCC_PLL0_OUT_MAIN, 1 }, 299 { P_CAMCC_PLL1_OUT_EVEN, 3 }, 300 { P_CAMCC_PLL3_OUT_MAIN, 5 }, 301 }; 302 303 static const struct clk_parent_data camcc_parent_data_5[] = { 304 { .fw_name = "bi_tcxo" }, 305 { .hw = &camcc_pll0.clkr.hw }, 306 { .hw = &camcc_pll1_out_even.clkr.hw }, 307 { .hw = &camcc_pll3.clkr.hw }, 308 }; 309 310 static const struct parent_map camcc_parent_map_6[] = { 311 { P_BI_TCXO, 0 }, 312 { P_CAMCC_PLL0_OUT_MAIN, 1 }, 313 { P_CAMCC_PLL2_OUT_MAIN, 4 }, 314 }; 315 316 static const struct clk_parent_data camcc_parent_data_6[] = { 317 { .fw_name = "bi_tcxo" }, 318 { .hw = &camcc_pll0.clkr.hw }, 319 { .hw = &camcc_pll2_out_main.clkr.hw }, 320 }; 321 322 static const struct parent_map camcc_parent_map_7[] = { 323 { P_BI_TCXO, 0 }, 324 { P_CAMCC_PLL0_OUT_MAIN, 1 }, 325 { P_CAMCC_PLL1_OUT_MAIN, 2 }, 326 { P_CAMCC_PLL2_OUT_MAIN, 4 }, 327 }; 328 329 static const struct clk_parent_data camcc_parent_data_7[] = { 330 { .fw_name = "bi_tcxo" }, 331 { .hw = &camcc_pll0.clkr.hw }, 332 { .hw = &camcc_pll1.clkr.hw }, 333 { .hw = &camcc_pll2_out_main.clkr.hw }, 334 }; 335 336 static const struct parent_map camcc_parent_map_8[] = { 337 { P_BI_TCXO, 0 }, 338 { P_CAMCC_PLL0_OUT_MAIN, 1 }, 339 { P_CAMCC_PLL1_OUT_MAIN, 2 }, 340 }; 341 342 static const struct clk_parent_data camcc_parent_data_8[] = { 343 { .fw_name = "bi_tcxo" }, 344 { .hw = &camcc_pll0.clkr.hw }, 345 { .hw = &camcc_pll1.clkr.hw }, 346 }; 347 348 static const struct parent_map camcc_parent_map_9[] = { 349 { P_BI_TCXO, 0 }, 350 { P_CAMCC_PLL2_OUT_MAIN, 4 }, 351 }; 352 353 static const struct clk_parent_data camcc_parent_data_9[] = { 354 { .fw_name = "bi_tcxo" }, 355 { .hw = &camcc_pll2_out_main.clkr.hw }, 356 }; 357 358 static const struct freq_tbl ftbl_camcc_bps_clk_src[] = { 359 F(200000000, P_CAMCC_PLL0_OUT_MAIN, 3, 0, 0), 360 F(320000000, P_CAMCC_PLL2_OUT_MAIN, 1.5, 0, 0), 361 F(404000000, P_CAMCC_PLL1_OUT_EVEN, 1, 0, 0), 362 F(480000000, P_CAMCC_PLL2_OUT_MAIN, 1, 0, 0), 363 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0), 364 { } 365 }; 366 367 static struct clk_rcg2 camcc_bps_clk_src = { 368 .cmd_rcgr = 0x6010, 369 .mnd_width = 0, 370 .hid_width = 5, 371 .parent_map = camcc_parent_map_1, 372 .freq_tbl = ftbl_camcc_bps_clk_src, 373 .clkr.hw.init = &(struct clk_init_data){ 374 .name = "camcc_bps_clk_src", 375 .parent_data = camcc_parent_data_1, 376 .num_parents = ARRAY_SIZE(camcc_parent_data_1), 377 .ops = &clk_rcg2_ops, 378 }, 379 }; 380 381 static const struct freq_tbl ftbl_camcc_cci_0_clk_src[] = { 382 F(37500000, P_CAMCC_PLL0_OUT_EVEN, 8, 0, 0), 383 F(50000000, P_CAMCC_PLL0_OUT_EVEN, 6, 0, 0), 384 F(100000000, P_CAMCC_PLL0_OUT_EVEN, 3, 0, 0), 385 { } 386 }; 387 388 static struct clk_rcg2 camcc_cci_0_clk_src = { 389 .cmd_rcgr = 0xf004, 390 .mnd_width = 8, 391 .hid_width = 5, 392 .parent_map = camcc_parent_map_0, 393 .freq_tbl = ftbl_camcc_cci_0_clk_src, 394 .clkr.hw.init = &(struct clk_init_data){ 395 .name = "camcc_cci_0_clk_src", 396 .parent_data = camcc_parent_data_0, 397 .num_parents = ARRAY_SIZE(camcc_parent_data_0), 398 .ops = &clk_rcg2_ops, 399 }, 400 }; 401 402 static struct clk_rcg2 camcc_cci_1_clk_src = { 403 .cmd_rcgr = 0x10004, 404 .mnd_width = 8, 405 .hid_width = 5, 406 .parent_map = camcc_parent_map_0, 407 .freq_tbl = ftbl_camcc_cci_0_clk_src, 408 .clkr.hw.init = &(struct clk_init_data){ 409 .name = "camcc_cci_1_clk_src", 410 .parent_data = camcc_parent_data_0, 411 .num_parents = ARRAY_SIZE(camcc_parent_data_0), 412 .ops = &clk_rcg2_ops, 413 }, 414 }; 415 416 static const struct freq_tbl ftbl_camcc_cphy_rx_clk_src[] = { 417 F(150000000, P_CAMCC_PLL0_OUT_MAIN, 4, 0, 0), 418 F(300000000, P_CAMCC_PLL0_OUT_MAIN, 2, 0, 0), 419 F(384000000, P_CAMCC_PLL3_OUT_MAIN, 1, 0, 0), 420 F(400000000, P_CAMCC_PLL0_OUT_MAIN, 1.5, 0, 0), 421 { } 422 }; 423 424 static struct clk_rcg2 camcc_cphy_rx_clk_src = { 425 .cmd_rcgr = 0x9064, 426 .mnd_width = 0, 427 .hid_width = 5, 428 .parent_map = camcc_parent_map_2, 429 .freq_tbl = ftbl_camcc_cphy_rx_clk_src, 430 .clkr.hw.init = &(struct clk_init_data){ 431 .name = "camcc_cphy_rx_clk_src", 432 .parent_data = camcc_parent_data_2, 433 .num_parents = ARRAY_SIZE(camcc_parent_data_2), 434 .ops = &clk_rcg2_ops, 435 }, 436 }; 437 438 static const struct freq_tbl ftbl_camcc_csi0phytimer_clk_src[] = { 439 F(300000000, P_CAMCC_PLL0_OUT_EVEN, 1, 0, 0), 440 { } 441 }; 442 443 static struct clk_rcg2 camcc_csi0phytimer_clk_src = { 444 .cmd_rcgr = 0x5004, 445 .mnd_width = 0, 446 .hid_width = 5, 447 .parent_map = camcc_parent_map_0, 448 .freq_tbl = ftbl_camcc_csi0phytimer_clk_src, 449 .clkr.hw.init = &(struct clk_init_data){ 450 .name = "camcc_csi0phytimer_clk_src", 451 .parent_data = camcc_parent_data_0, 452 .num_parents = ARRAY_SIZE(camcc_parent_data_0), 453 .ops = &clk_rcg2_ops, 454 }, 455 }; 456 457 static struct clk_rcg2 camcc_csi1phytimer_clk_src = { 458 .cmd_rcgr = 0x5028, 459 .mnd_width = 0, 460 .hid_width = 5, 461 .parent_map = camcc_parent_map_0, 462 .freq_tbl = ftbl_camcc_csi0phytimer_clk_src, 463 .clkr.hw.init = &(struct clk_init_data){ 464 .name = "camcc_csi1phytimer_clk_src", 465 .parent_data = camcc_parent_data_0, 466 .num_parents = ARRAY_SIZE(camcc_parent_data_0), 467 .ops = &clk_rcg2_ops, 468 }, 469 }; 470 471 static struct clk_rcg2 camcc_csi2phytimer_clk_src = { 472 .cmd_rcgr = 0x504c, 473 .mnd_width = 0, 474 .hid_width = 5, 475 .parent_map = camcc_parent_map_0, 476 .freq_tbl = ftbl_camcc_csi0phytimer_clk_src, 477 .clkr.hw.init = &(struct clk_init_data){ 478 .name = "camcc_csi2phytimer_clk_src", 479 .parent_data = camcc_parent_data_0, 480 .num_parents = ARRAY_SIZE(camcc_parent_data_0), 481 .ops = &clk_rcg2_ops, 482 }, 483 }; 484 485 static struct clk_rcg2 camcc_csi3phytimer_clk_src = { 486 .cmd_rcgr = 0x5070, 487 .mnd_width = 0, 488 .hid_width = 5, 489 .parent_map = camcc_parent_map_0, 490 .freq_tbl = ftbl_camcc_csi0phytimer_clk_src, 491 .clkr.hw.init = &(struct clk_init_data){ 492 .name = "camcc_csi3phytimer_clk_src", 493 .parent_data = camcc_parent_data_0, 494 .num_parents = ARRAY_SIZE(camcc_parent_data_0), 495 .ops = &clk_rcg2_ops, 496 }, 497 }; 498 499 static const struct freq_tbl ftbl_camcc_fast_ahb_clk_src[] = { 500 F(100000000, P_CAMCC_PLL0_OUT_MAIN, 6, 0, 0), 501 F(200000000, P_CAMCC_PLL0_OUT_MAIN, 3, 0, 0), 502 F(300000000, P_CAMCC_PLL0_OUT_MAIN, 2, 0, 0), 503 F(404000000, P_CAMCC_PLL1_OUT_EVEN, 1, 0, 0), 504 { } 505 }; 506 507 static struct clk_rcg2 camcc_fast_ahb_clk_src = { 508 .cmd_rcgr = 0x603c, 509 .mnd_width = 0, 510 .hid_width = 5, 511 .parent_map = camcc_parent_map_4, 512 .freq_tbl = ftbl_camcc_fast_ahb_clk_src, 513 .clkr.hw.init = &(struct clk_init_data){ 514 .name = "camcc_fast_ahb_clk_src", 515 .parent_data = camcc_parent_data_4, 516 .num_parents = ARRAY_SIZE(camcc_parent_data_4), 517 .ops = &clk_rcg2_ops, 518 }, 519 }; 520 521 static const struct freq_tbl ftbl_camcc_icp_clk_src[] = { 522 F(240000000, P_CAMCC_PLL0_OUT_MAIN, 2.5, 0, 0), 523 F(384000000, P_CAMCC_PLL3_OUT_MAIN, 1, 0, 0), 524 F(404000000, P_CAMCC_PLL1_OUT_EVEN, 1, 0, 0), 525 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0), 526 { } 527 }; 528 529 static struct clk_rcg2 camcc_icp_clk_src = { 530 .cmd_rcgr = 0xe014, 531 .mnd_width = 0, 532 .hid_width = 5, 533 .parent_map = camcc_parent_map_5, 534 .freq_tbl = ftbl_camcc_icp_clk_src, 535 .clkr.hw.init = &(struct clk_init_data){ 536 .name = "camcc_icp_clk_src", 537 .parent_data = camcc_parent_data_5, 538 .num_parents = ARRAY_SIZE(camcc_parent_data_5), 539 .ops = &clk_rcg2_ops, 540 }, 541 }; 542 543 static const struct freq_tbl ftbl_camcc_ife_0_clk_src[] = { 544 F(240000000, P_CAMCC_PLL0_OUT_MAIN, 2.5, 0, 0), 545 F(320000000, P_CAMCC_PLL2_OUT_MAIN, 1.5, 0, 0), 546 F(404000000, P_CAMCC_PLL1_OUT_EVEN, 1, 0, 0), 547 F(480000000, P_CAMCC_PLL2_OUT_MAIN, 1, 0, 0), 548 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0), 549 { } 550 }; 551 552 static struct clk_rcg2 camcc_ife_0_clk_src = { 553 .cmd_rcgr = 0x9010, 554 .mnd_width = 0, 555 .hid_width = 5, 556 .parent_map = camcc_parent_map_1, 557 .freq_tbl = ftbl_camcc_ife_0_clk_src, 558 .clkr.hw.init = &(struct clk_init_data){ 559 .name = "camcc_ife_0_clk_src", 560 .parent_data = camcc_parent_data_1, 561 .num_parents = ARRAY_SIZE(camcc_parent_data_1), 562 .flags = CLK_SET_RATE_PARENT, 563 .ops = &clk_rcg2_ops, 564 }, 565 }; 566 567 static struct clk_rcg2 camcc_ife_0_csid_clk_src = { 568 .cmd_rcgr = 0x903c, 569 .mnd_width = 0, 570 .hid_width = 5, 571 .parent_map = camcc_parent_map_2, 572 .freq_tbl = ftbl_camcc_cphy_rx_clk_src, 573 .clkr.hw.init = &(struct clk_init_data){ 574 .name = "camcc_ife_0_csid_clk_src", 575 .parent_data = camcc_parent_data_2, 576 .num_parents = ARRAY_SIZE(camcc_parent_data_2), 577 .ops = &clk_rcg2_ops, 578 }, 579 }; 580 581 static struct clk_rcg2 camcc_ife_1_clk_src = { 582 .cmd_rcgr = 0xa010, 583 .mnd_width = 0, 584 .hid_width = 5, 585 .parent_map = camcc_parent_map_1, 586 .freq_tbl = ftbl_camcc_ife_0_clk_src, 587 .clkr.hw.init = &(struct clk_init_data){ 588 .name = "camcc_ife_1_clk_src", 589 .parent_data = camcc_parent_data_1, 590 .num_parents = ARRAY_SIZE(camcc_parent_data_1), 591 .flags = CLK_SET_RATE_PARENT, 592 .ops = &clk_rcg2_ops, 593 }, 594 }; 595 596 static struct clk_rcg2 camcc_ife_1_csid_clk_src = { 597 .cmd_rcgr = 0xa034, 598 .mnd_width = 0, 599 .hid_width = 5, 600 .parent_map = camcc_parent_map_2, 601 .freq_tbl = ftbl_camcc_cphy_rx_clk_src, 602 .clkr.hw.init = &(struct clk_init_data){ 603 .name = "camcc_ife_1_csid_clk_src", 604 .parent_data = camcc_parent_data_2, 605 .num_parents = ARRAY_SIZE(camcc_parent_data_2), 606 .ops = &clk_rcg2_ops, 607 }, 608 }; 609 610 static struct clk_rcg2 camcc_ife_2_clk_src = { 611 .cmd_rcgr = 0xb00c, 612 .mnd_width = 0, 613 .hid_width = 5, 614 .parent_map = camcc_parent_map_1, 615 .freq_tbl = ftbl_camcc_ife_0_clk_src, 616 .clkr.hw.init = &(struct clk_init_data){ 617 .name = "camcc_ife_2_clk_src", 618 .parent_data = camcc_parent_data_1, 619 .num_parents = ARRAY_SIZE(camcc_parent_data_1), 620 .ops = &clk_rcg2_ops, 621 }, 622 }; 623 624 static struct clk_rcg2 camcc_ife_2_csid_clk_src = { 625 .cmd_rcgr = 0xb030, 626 .mnd_width = 0, 627 .hid_width = 5, 628 .parent_map = camcc_parent_map_2, 629 .freq_tbl = ftbl_camcc_cphy_rx_clk_src, 630 .clkr.hw.init = &(struct clk_init_data){ 631 .name = "camcc_ife_2_csid_clk_src", 632 .parent_data = camcc_parent_data_2, 633 .num_parents = ARRAY_SIZE(camcc_parent_data_2), 634 .ops = &clk_rcg2_ops, 635 }, 636 }; 637 638 static const struct freq_tbl ftbl_camcc_ife_lite_clk_src[] = { 639 F(320000000, P_CAMCC_PLL2_OUT_MAIN, 1.5, 0, 0), 640 F(400000000, P_CAMCC_PLL0_OUT_MAIN, 1.5, 0, 0), 641 F(480000000, P_CAMCC_PLL2_OUT_MAIN, 1, 0, 0), 642 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0), 643 { } 644 }; 645 646 static struct clk_rcg2 camcc_ife_lite_clk_src = { 647 .cmd_rcgr = 0xc004, 648 .mnd_width = 0, 649 .hid_width = 5, 650 .parent_map = camcc_parent_map_6, 651 .freq_tbl = ftbl_camcc_ife_lite_clk_src, 652 .clkr.hw.init = &(struct clk_init_data){ 653 .name = "camcc_ife_lite_clk_src", 654 .parent_data = camcc_parent_data_6, 655 .num_parents = ARRAY_SIZE(camcc_parent_data_6), 656 .ops = &clk_rcg2_ops, 657 }, 658 }; 659 660 static struct clk_rcg2 camcc_ife_lite_csid_clk_src = { 661 .cmd_rcgr = 0xc024, 662 .mnd_width = 0, 663 .hid_width = 5, 664 .parent_map = camcc_parent_map_2, 665 .freq_tbl = ftbl_camcc_cphy_rx_clk_src, 666 .clkr.hw.init = &(struct clk_init_data){ 667 .name = "camcc_ife_lite_csid_clk_src", 668 .parent_data = camcc_parent_data_2, 669 .num_parents = ARRAY_SIZE(camcc_parent_data_2), 670 .ops = &clk_rcg2_ops, 671 }, 672 }; 673 674 static const struct freq_tbl ftbl_camcc_ipe_0_clk_src[] = { 675 F(240000000, P_CAMCC_PLL2_OUT_MAIN, 2, 0, 0), 676 F(320000000, P_CAMCC_PLL2_OUT_MAIN, 1.5, 0, 0), 677 F(404000000, P_CAMCC_PLL1_OUT_MAIN, 2, 0, 0), 678 F(538666667, P_CAMCC_PLL1_OUT_MAIN, 1.5, 0, 0), 679 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0), 680 { } 681 }; 682 683 static struct clk_rcg2 camcc_ipe_0_clk_src = { 684 .cmd_rcgr = 0x7010, 685 .mnd_width = 0, 686 .hid_width = 5, 687 .parent_map = camcc_parent_map_7, 688 .freq_tbl = ftbl_camcc_ipe_0_clk_src, 689 .clkr.hw.init = &(struct clk_init_data){ 690 .name = "camcc_ipe_0_clk_src", 691 .parent_data = camcc_parent_data_7, 692 .num_parents = ARRAY_SIZE(camcc_parent_data_7), 693 .flags = CLK_SET_RATE_PARENT, 694 .ops = &clk_rcg2_ops, 695 }, 696 }; 697 698 static const struct freq_tbl ftbl_camcc_jpeg_clk_src[] = { 699 F(66666667, P_CAMCC_PLL0_OUT_MAIN, 9, 0, 0), 700 F(133333333, P_CAMCC_PLL0_OUT_MAIN, 4.5, 0, 0), 701 F(200000000, P_CAMCC_PLL0_OUT_MAIN, 3, 0, 0), 702 F(404000000, P_CAMCC_PLL1_OUT_EVEN, 1, 0, 0), 703 F(480000000, P_CAMCC_PLL2_OUT_MAIN, 1, 0, 0), 704 F(600000000, P_CAMCC_PLL0_OUT_MAIN, 1, 0, 0), 705 { } 706 }; 707 708 static struct clk_rcg2 camcc_jpeg_clk_src = { 709 .cmd_rcgr = 0xd004, 710 .mnd_width = 0, 711 .hid_width = 5, 712 .parent_map = camcc_parent_map_1, 713 .freq_tbl = ftbl_camcc_jpeg_clk_src, 714 .clkr.hw.init = &(struct clk_init_data){ 715 .name = "camcc_jpeg_clk_src", 716 .parent_data = camcc_parent_data_1, 717 .num_parents = ARRAY_SIZE(camcc_parent_data_1), 718 .ops = &clk_rcg2_ops, 719 }, 720 }; 721 722 static const struct freq_tbl ftbl_camcc_lrme_clk_src[] = { 723 F(200000000, P_CAMCC_PLL0_OUT_MAIN, 3, 0, 0), 724 F(269333333, P_CAMCC_PLL1_OUT_MAIN, 3, 0, 0), 725 F(323200000, P_CAMCC_PLL1_OUT_MAIN, 2.5, 0, 0), 726 F(404000000, P_CAMCC_PLL1_OUT_MAIN, 2, 0, 0), 727 { } 728 }; 729 730 static struct clk_rcg2 camcc_lrme_clk_src = { 731 .cmd_rcgr = 0x11004, 732 .mnd_width = 0, 733 .hid_width = 5, 734 .parent_map = camcc_parent_map_8, 735 .freq_tbl = ftbl_camcc_lrme_clk_src, 736 .clkr.hw.init = &(struct clk_init_data){ 737 .name = "camcc_lrme_clk_src", 738 .parent_data = camcc_parent_data_8, 739 .num_parents = ARRAY_SIZE(camcc_parent_data_8), 740 .ops = &clk_rcg2_ops, 741 }, 742 }; 743 744 static const struct freq_tbl ftbl_camcc_mclk0_clk_src[] = { 745 F(19200000, P_CAMCC_PLL2_OUT_EARLY, 1, 1, 50), 746 F(24000000, P_CAMCC_PLL2_OUT_EARLY, 10, 1, 4), 747 F(64000000, P_CAMCC_PLL2_OUT_EARLY, 15, 0, 0), 748 { } 749 }; 750 751 static struct clk_rcg2 camcc_mclk0_clk_src = { 752 .cmd_rcgr = 0x4004, 753 .mnd_width = 8, 754 .hid_width = 5, 755 .parent_map = camcc_parent_map_3, 756 .freq_tbl = ftbl_camcc_mclk0_clk_src, 757 .clkr.hw.init = &(struct clk_init_data){ 758 .name = "camcc_mclk0_clk_src", 759 .parent_data = camcc_parent_data_3, 760 .num_parents = ARRAY_SIZE(camcc_parent_data_3), 761 .ops = &clk_rcg2_ops, 762 }, 763 }; 764 765 static struct clk_rcg2 camcc_mclk1_clk_src = { 766 .cmd_rcgr = 0x4024, 767 .mnd_width = 8, 768 .hid_width = 5, 769 .parent_map = camcc_parent_map_3, 770 .freq_tbl = ftbl_camcc_mclk0_clk_src, 771 .clkr.hw.init = &(struct clk_init_data){ 772 .name = "camcc_mclk1_clk_src", 773 .parent_data = camcc_parent_data_3, 774 .num_parents = ARRAY_SIZE(camcc_parent_data_3), 775 .ops = &clk_rcg2_ops, 776 }, 777 }; 778 779 static struct clk_rcg2 camcc_mclk2_clk_src = { 780 .cmd_rcgr = 0x4044, 781 .mnd_width = 8, 782 .hid_width = 5, 783 .parent_map = camcc_parent_map_3, 784 .freq_tbl = ftbl_camcc_mclk0_clk_src, 785 .clkr.hw.init = &(struct clk_init_data){ 786 .name = "camcc_mclk2_clk_src", 787 .parent_data = camcc_parent_data_3, 788 .num_parents = ARRAY_SIZE(camcc_parent_data_3), 789 .ops = &clk_rcg2_ops, 790 }, 791 }; 792 793 static struct clk_rcg2 camcc_mclk3_clk_src = { 794 .cmd_rcgr = 0x4064, 795 .mnd_width = 8, 796 .hid_width = 5, 797 .parent_map = camcc_parent_map_3, 798 .freq_tbl = ftbl_camcc_mclk0_clk_src, 799 .clkr.hw.init = &(struct clk_init_data){ 800 .name = "camcc_mclk3_clk_src", 801 .parent_data = camcc_parent_data_3, 802 .num_parents = ARRAY_SIZE(camcc_parent_data_3), 803 .ops = &clk_rcg2_ops, 804 }, 805 }; 806 807 static struct clk_rcg2 camcc_mclk4_clk_src = { 808 .cmd_rcgr = 0x4084, 809 .mnd_width = 8, 810 .hid_width = 5, 811 .parent_map = camcc_parent_map_3, 812 .freq_tbl = ftbl_camcc_mclk0_clk_src, 813 .clkr.hw.init = &(struct clk_init_data){ 814 .name = "camcc_mclk4_clk_src", 815 .parent_data = camcc_parent_data_3, 816 .num_parents = ARRAY_SIZE(camcc_parent_data_3), 817 .ops = &clk_rcg2_ops, 818 }, 819 }; 820 821 static const struct freq_tbl ftbl_camcc_slow_ahb_clk_src[] = { 822 F(80000000, P_CAMCC_PLL2_OUT_MAIN, 6, 0, 0), 823 { } 824 }; 825 826 static struct clk_rcg2 camcc_slow_ahb_clk_src = { 827 .cmd_rcgr = 0x6058, 828 .mnd_width = 0, 829 .hid_width = 5, 830 .parent_map = camcc_parent_map_9, 831 .freq_tbl = ftbl_camcc_slow_ahb_clk_src, 832 .clkr.hw.init = &(struct clk_init_data){ 833 .name = "camcc_slow_ahb_clk_src", 834 .parent_data = camcc_parent_data_9, 835 .num_parents = ARRAY_SIZE(camcc_parent_data_9), 836 .ops = &clk_rcg2_ops, 837 }, 838 }; 839 840 static struct clk_branch camcc_bps_ahb_clk = { 841 .halt_reg = 0x6070, 842 .halt_check = BRANCH_HALT, 843 .clkr = { 844 .enable_reg = 0x6070, 845 .enable_mask = BIT(0), 846 .hw.init = &(struct clk_init_data){ 847 .name = "camcc_bps_ahb_clk", 848 .parent_hws = (const struct clk_hw*[]){ 849 &camcc_slow_ahb_clk_src.clkr.hw 850 }, 851 .num_parents = 1, 852 .flags = CLK_SET_RATE_PARENT, 853 .ops = &clk_branch2_ops, 854 }, 855 }, 856 }; 857 858 static struct clk_branch camcc_bps_areg_clk = { 859 .halt_reg = 0x6054, 860 .halt_check = BRANCH_HALT, 861 .clkr = { 862 .enable_reg = 0x6054, 863 .enable_mask = BIT(0), 864 .hw.init = &(struct clk_init_data){ 865 .name = "camcc_bps_areg_clk", 866 .parent_hws = (const struct clk_hw*[]){ 867 &camcc_fast_ahb_clk_src.clkr.hw 868 }, 869 .num_parents = 1, 870 .flags = CLK_SET_RATE_PARENT, 871 .ops = &clk_branch2_ops, 872 }, 873 }, 874 }; 875 876 static struct clk_branch camcc_bps_axi_clk = { 877 .halt_reg = 0x6038, 878 .halt_check = BRANCH_HALT, 879 .clkr = { 880 .enable_reg = 0x6038, 881 .enable_mask = BIT(0), 882 .hw.init = &(struct clk_init_data){ 883 .name = "camcc_bps_axi_clk", 884 .ops = &clk_branch2_ops, 885 }, 886 }, 887 }; 888 889 static struct clk_branch camcc_bps_clk = { 890 .halt_reg = 0x6028, 891 .halt_check = BRANCH_HALT, 892 .clkr = { 893 .enable_reg = 0x6028, 894 .enable_mask = BIT(0), 895 .hw.init = &(struct clk_init_data){ 896 .name = "camcc_bps_clk", 897 .parent_hws = (const struct clk_hw*[]){ 898 &camcc_bps_clk_src.clkr.hw 899 }, 900 .num_parents = 1, 901 .flags = CLK_SET_RATE_PARENT, 902 .ops = &clk_branch2_ops, 903 }, 904 }, 905 }; 906 907 static struct clk_branch camcc_camnoc_axi_clk = { 908 .halt_reg = 0x13004, 909 .halt_check = BRANCH_HALT, 910 .clkr = { 911 .enable_reg = 0x13004, 912 .enable_mask = BIT(0), 913 .hw.init = &(struct clk_init_data){ 914 .name = "camcc_camnoc_axi_clk", 915 .ops = &clk_branch2_ops, 916 }, 917 }, 918 }; 919 920 static struct clk_branch camcc_cci_0_clk = { 921 .halt_reg = 0xf01c, 922 .halt_check = BRANCH_HALT, 923 .clkr = { 924 .enable_reg = 0xf01c, 925 .enable_mask = BIT(0), 926 .hw.init = &(struct clk_init_data){ 927 .name = "camcc_cci_0_clk", 928 .parent_hws = (const struct clk_hw*[]){ 929 &camcc_cci_0_clk_src.clkr.hw 930 }, 931 .num_parents = 1, 932 .flags = CLK_SET_RATE_PARENT, 933 .ops = &clk_branch2_ops, 934 }, 935 }, 936 }; 937 938 static struct clk_branch camcc_cci_1_clk = { 939 .halt_reg = 0x1001c, 940 .halt_check = BRANCH_HALT, 941 .clkr = { 942 .enable_reg = 0x1001c, 943 .enable_mask = BIT(0), 944 .hw.init = &(struct clk_init_data){ 945 .name = "camcc_cci_1_clk", 946 .parent_hws = (const struct clk_hw*[]){ 947 &camcc_cci_1_clk_src.clkr.hw 948 }, 949 .num_parents = 1, 950 .flags = CLK_SET_RATE_PARENT, 951 .ops = &clk_branch2_ops, 952 }, 953 }, 954 }; 955 956 static struct clk_branch camcc_core_ahb_clk = { 957 .halt_reg = 0x14010, 958 .halt_check = BRANCH_HALT_VOTED, 959 .clkr = { 960 .enable_reg = 0x14010, 961 .enable_mask = BIT(0), 962 .hw.init = &(struct clk_init_data){ 963 .name = "camcc_core_ahb_clk", 964 .parent_hws = (const struct clk_hw*[]){ 965 &camcc_slow_ahb_clk_src.clkr.hw 966 }, 967 .num_parents = 1, 968 .flags = CLK_SET_RATE_PARENT, 969 .ops = &clk_branch2_ops, 970 }, 971 }, 972 }; 973 974 static struct clk_branch camcc_cpas_ahb_clk = { 975 .halt_reg = 0x12004, 976 .halt_check = BRANCH_HALT, 977 .clkr = { 978 .enable_reg = 0x12004, 979 .enable_mask = BIT(0), 980 .hw.init = &(struct clk_init_data){ 981 .name = "camcc_cpas_ahb_clk", 982 .parent_hws = (const struct clk_hw*[]){ 983 &camcc_slow_ahb_clk_src.clkr.hw 984 }, 985 .num_parents = 1, 986 .flags = CLK_SET_RATE_PARENT, 987 .ops = &clk_branch2_ops, 988 }, 989 }, 990 }; 991 992 static struct clk_branch camcc_csi0phytimer_clk = { 993 .halt_reg = 0x501c, 994 .halt_check = BRANCH_HALT, 995 .clkr = { 996 .enable_reg = 0x501c, 997 .enable_mask = BIT(0), 998 .hw.init = &(struct clk_init_data){ 999 .name = "camcc_csi0phytimer_clk", 1000 .parent_hws = (const struct clk_hw*[]){ 1001 &camcc_csi0phytimer_clk_src.clkr.hw 1002 }, 1003 .num_parents = 1, 1004 .flags = CLK_SET_RATE_PARENT, 1005 .ops = &clk_branch2_ops, 1006 }, 1007 }, 1008 }; 1009 1010 static struct clk_branch camcc_csi1phytimer_clk = { 1011 .halt_reg = 0x5040, 1012 .halt_check = BRANCH_HALT, 1013 .clkr = { 1014 .enable_reg = 0x5040, 1015 .enable_mask = BIT(0), 1016 .hw.init = &(struct clk_init_data){ 1017 .name = "camcc_csi1phytimer_clk", 1018 .parent_hws = (const struct clk_hw*[]){ 1019 &camcc_csi1phytimer_clk_src.clkr.hw 1020 }, 1021 .num_parents = 1, 1022 .flags = CLK_SET_RATE_PARENT, 1023 .ops = &clk_branch2_ops, 1024 }, 1025 }, 1026 }; 1027 1028 static struct clk_branch camcc_csi2phytimer_clk = { 1029 .halt_reg = 0x5064, 1030 .halt_check = BRANCH_HALT, 1031 .clkr = { 1032 .enable_reg = 0x5064, 1033 .enable_mask = BIT(0), 1034 .hw.init = &(struct clk_init_data){ 1035 .name = "camcc_csi2phytimer_clk", 1036 .parent_hws = (const struct clk_hw*[]){ 1037 &camcc_csi2phytimer_clk_src.clkr.hw 1038 }, 1039 .num_parents = 1, 1040 .flags = CLK_SET_RATE_PARENT, 1041 .ops = &clk_branch2_ops, 1042 }, 1043 }, 1044 }; 1045 1046 static struct clk_branch camcc_csi3phytimer_clk = { 1047 .halt_reg = 0x5088, 1048 .halt_check = BRANCH_HALT, 1049 .clkr = { 1050 .enable_reg = 0x5088, 1051 .enable_mask = BIT(0), 1052 .hw.init = &(struct clk_init_data){ 1053 .name = "camcc_csi3phytimer_clk", 1054 .parent_hws = (const struct clk_hw*[]){ 1055 &camcc_csi3phytimer_clk_src.clkr.hw 1056 }, 1057 .num_parents = 1, 1058 .flags = CLK_SET_RATE_PARENT, 1059 .ops = &clk_branch2_ops, 1060 }, 1061 }, 1062 }; 1063 1064 static struct clk_branch camcc_csiphy0_clk = { 1065 .halt_reg = 0x5020, 1066 .halt_check = BRANCH_HALT, 1067 .clkr = { 1068 .enable_reg = 0x5020, 1069 .enable_mask = BIT(0), 1070 .hw.init = &(struct clk_init_data){ 1071 .name = "camcc_csiphy0_clk", 1072 .parent_hws = (const struct clk_hw*[]){ 1073 &camcc_cphy_rx_clk_src.clkr.hw 1074 }, 1075 .num_parents = 1, 1076 .flags = CLK_SET_RATE_PARENT, 1077 .ops = &clk_branch2_ops, 1078 }, 1079 }, 1080 }; 1081 1082 static struct clk_branch camcc_csiphy1_clk = { 1083 .halt_reg = 0x5044, 1084 .halt_check = BRANCH_HALT, 1085 .clkr = { 1086 .enable_reg = 0x5044, 1087 .enable_mask = BIT(0), 1088 .hw.init = &(struct clk_init_data){ 1089 .name = "camcc_csiphy1_clk", 1090 .parent_hws = (const struct clk_hw*[]){ 1091 &camcc_cphy_rx_clk_src.clkr.hw 1092 }, 1093 .num_parents = 1, 1094 .flags = CLK_SET_RATE_PARENT, 1095 .ops = &clk_branch2_ops, 1096 }, 1097 }, 1098 }; 1099 1100 static struct clk_branch camcc_csiphy2_clk = { 1101 .halt_reg = 0x5068, 1102 .halt_check = BRANCH_HALT, 1103 .clkr = { 1104 .enable_reg = 0x5068, 1105 .enable_mask = BIT(0), 1106 .hw.init = &(struct clk_init_data){ 1107 .name = "camcc_csiphy2_clk", 1108 .parent_hws = (const struct clk_hw*[]){ 1109 &camcc_cphy_rx_clk_src.clkr.hw 1110 }, 1111 .num_parents = 1, 1112 .flags = CLK_SET_RATE_PARENT, 1113 .ops = &clk_branch2_ops, 1114 }, 1115 }, 1116 }; 1117 1118 static struct clk_branch camcc_csiphy3_clk = { 1119 .halt_reg = 0x508c, 1120 .halt_check = BRANCH_HALT, 1121 .clkr = { 1122 .enable_reg = 0x508c, 1123 .enable_mask = BIT(0), 1124 .hw.init = &(struct clk_init_data){ 1125 .name = "camcc_csiphy3_clk", 1126 .parent_hws = (const struct clk_hw*[]){ 1127 &camcc_cphy_rx_clk_src.clkr.hw 1128 }, 1129 .num_parents = 1, 1130 .flags = CLK_SET_RATE_PARENT, 1131 .ops = &clk_branch2_ops, 1132 }, 1133 }, 1134 }; 1135 1136 static struct clk_branch camcc_icp_clk = { 1137 .halt_reg = 0xe02c, 1138 .halt_check = BRANCH_HALT, 1139 .clkr = { 1140 .enable_reg = 0xe02c, 1141 .enable_mask = BIT(0), 1142 .hw.init = &(struct clk_init_data){ 1143 .name = "camcc_icp_clk", 1144 .parent_hws = (const struct clk_hw*[]){ 1145 &camcc_icp_clk_src.clkr.hw 1146 }, 1147 .num_parents = 1, 1148 .flags = CLK_SET_RATE_PARENT, 1149 .ops = &clk_branch2_ops, 1150 }, 1151 }, 1152 }; 1153 1154 static struct clk_branch camcc_icp_ts_clk = { 1155 .halt_reg = 0xe00c, 1156 .halt_check = BRANCH_HALT, 1157 .clkr = { 1158 .enable_reg = 0xe00c, 1159 .enable_mask = BIT(0), 1160 .hw.init = &(struct clk_init_data){ 1161 .name = "camcc_icp_ts_clk", 1162 .ops = &clk_branch2_ops, 1163 }, 1164 }, 1165 }; 1166 1167 static struct clk_branch camcc_ife_0_axi_clk = { 1168 .halt_reg = 0x9080, 1169 .halt_check = BRANCH_HALT, 1170 .clkr = { 1171 .enable_reg = 0x9080, 1172 .enable_mask = BIT(0), 1173 .hw.init = &(struct clk_init_data){ 1174 .name = "camcc_ife_0_axi_clk", 1175 .ops = &clk_branch2_ops, 1176 }, 1177 }, 1178 }; 1179 1180 static struct clk_branch camcc_ife_0_clk = { 1181 .halt_reg = 0x9028, 1182 .halt_check = BRANCH_HALT, 1183 .clkr = { 1184 .enable_reg = 0x9028, 1185 .enable_mask = BIT(0), 1186 .hw.init = &(struct clk_init_data){ 1187 .name = "camcc_ife_0_clk", 1188 .parent_hws = (const struct clk_hw*[]){ 1189 &camcc_ife_0_clk_src.clkr.hw 1190 }, 1191 .num_parents = 1, 1192 .flags = CLK_SET_RATE_PARENT, 1193 .ops = &clk_branch2_ops, 1194 }, 1195 }, 1196 }; 1197 1198 static struct clk_branch camcc_ife_0_cphy_rx_clk = { 1199 .halt_reg = 0x907c, 1200 .halt_check = BRANCH_HALT, 1201 .clkr = { 1202 .enable_reg = 0x907c, 1203 .enable_mask = BIT(0), 1204 .hw.init = &(struct clk_init_data){ 1205 .name = "camcc_ife_0_cphy_rx_clk", 1206 .parent_hws = (const struct clk_hw*[]){ 1207 &camcc_cphy_rx_clk_src.clkr.hw 1208 }, 1209 .num_parents = 1, 1210 .flags = CLK_SET_RATE_PARENT, 1211 .ops = &clk_branch2_ops, 1212 }, 1213 }, 1214 }; 1215 1216 static struct clk_branch camcc_ife_0_csid_clk = { 1217 .halt_reg = 0x9054, 1218 .halt_check = BRANCH_HALT, 1219 .clkr = { 1220 .enable_reg = 0x9054, 1221 .enable_mask = BIT(0), 1222 .hw.init = &(struct clk_init_data){ 1223 .name = "camcc_ife_0_csid_clk", 1224 .parent_hws = (const struct clk_hw*[]){ 1225 &camcc_ife_0_csid_clk_src.clkr.hw 1226 }, 1227 .num_parents = 1, 1228 .flags = CLK_SET_RATE_PARENT, 1229 .ops = &clk_branch2_ops, 1230 }, 1231 }, 1232 }; 1233 1234 static struct clk_branch camcc_ife_0_dsp_clk = { 1235 .halt_reg = 0x9038, 1236 .halt_check = BRANCH_HALT, 1237 .clkr = { 1238 .enable_reg = 0x9038, 1239 .enable_mask = BIT(0), 1240 .hw.init = &(struct clk_init_data){ 1241 .name = "camcc_ife_0_dsp_clk", 1242 .parent_hws = (const struct clk_hw*[]){ 1243 &camcc_ife_0_clk_src.clkr.hw 1244 }, 1245 .num_parents = 1, 1246 .flags = CLK_SET_RATE_PARENT, 1247 .ops = &clk_branch2_ops, 1248 }, 1249 }, 1250 }; 1251 1252 static struct clk_branch camcc_ife_1_axi_clk = { 1253 .halt_reg = 0xa058, 1254 .halt_check = BRANCH_HALT, 1255 .clkr = { 1256 .enable_reg = 0xa058, 1257 .enable_mask = BIT(0), 1258 .hw.init = &(struct clk_init_data){ 1259 .name = "camcc_ife_1_axi_clk", 1260 .ops = &clk_branch2_ops, 1261 }, 1262 }, 1263 }; 1264 1265 static struct clk_branch camcc_ife_1_clk = { 1266 .halt_reg = 0xa028, 1267 .halt_check = BRANCH_HALT, 1268 .clkr = { 1269 .enable_reg = 0xa028, 1270 .enable_mask = BIT(0), 1271 .hw.init = &(struct clk_init_data){ 1272 .name = "camcc_ife_1_clk", 1273 .parent_hws = (const struct clk_hw*[]){ 1274 &camcc_ife_1_clk_src.clkr.hw 1275 }, 1276 .num_parents = 1, 1277 .flags = CLK_SET_RATE_PARENT, 1278 .ops = &clk_branch2_ops, 1279 }, 1280 }, 1281 }; 1282 1283 static struct clk_branch camcc_ife_1_cphy_rx_clk = { 1284 .halt_reg = 0xa054, 1285 .halt_check = BRANCH_HALT, 1286 .clkr = { 1287 .enable_reg = 0xa054, 1288 .enable_mask = BIT(0), 1289 .hw.init = &(struct clk_init_data){ 1290 .name = "camcc_ife_1_cphy_rx_clk", 1291 .parent_hws = (const struct clk_hw*[]){ 1292 &camcc_cphy_rx_clk_src.clkr.hw 1293 }, 1294 .num_parents = 1, 1295 .flags = CLK_SET_RATE_PARENT, 1296 .ops = &clk_branch2_ops, 1297 }, 1298 }, 1299 }; 1300 1301 static struct clk_branch camcc_ife_1_csid_clk = { 1302 .halt_reg = 0xa04c, 1303 .halt_check = BRANCH_HALT, 1304 .clkr = { 1305 .enable_reg = 0xa04c, 1306 .enable_mask = BIT(0), 1307 .hw.init = &(struct clk_init_data){ 1308 .name = "camcc_ife_1_csid_clk", 1309 .parent_hws = (const struct clk_hw*[]){ 1310 &camcc_ife_1_csid_clk_src.clkr.hw 1311 }, 1312 .num_parents = 1, 1313 .flags = CLK_SET_RATE_PARENT, 1314 .ops = &clk_branch2_ops, 1315 }, 1316 }, 1317 }; 1318 1319 static struct clk_branch camcc_ife_1_dsp_clk = { 1320 .halt_reg = 0xa030, 1321 .halt_check = BRANCH_HALT, 1322 .clkr = { 1323 .enable_reg = 0xa030, 1324 .enable_mask = BIT(0), 1325 .hw.init = &(struct clk_init_data){ 1326 .name = "camcc_ife_1_dsp_clk", 1327 .parent_hws = (const struct clk_hw*[]){ 1328 &camcc_ife_1_clk_src.clkr.hw 1329 }, 1330 .num_parents = 1, 1331 .flags = CLK_SET_RATE_PARENT, 1332 .ops = &clk_branch2_ops, 1333 }, 1334 }, 1335 }; 1336 1337 static struct clk_branch camcc_ife_2_axi_clk = { 1338 .halt_reg = 0xb054, 1339 .halt_check = BRANCH_HALT, 1340 .clkr = { 1341 .enable_reg = 0xb054, 1342 .enable_mask = BIT(0), 1343 .hw.init = &(struct clk_init_data){ 1344 .name = "camcc_ife_2_axi_clk", 1345 .ops = &clk_branch2_ops, 1346 }, 1347 }, 1348 }; 1349 1350 static struct clk_branch camcc_ife_2_clk = { 1351 .halt_reg = 0xb024, 1352 .halt_check = BRANCH_HALT, 1353 .clkr = { 1354 .enable_reg = 0xb024, 1355 .enable_mask = BIT(0), 1356 .hw.init = &(struct clk_init_data){ 1357 .name = "camcc_ife_2_clk", 1358 .parent_hws = (const struct clk_hw*[]){ 1359 &camcc_ife_2_clk_src.clkr.hw 1360 }, 1361 .num_parents = 1, 1362 .flags = CLK_SET_RATE_PARENT, 1363 .ops = &clk_branch2_ops, 1364 }, 1365 }, 1366 }; 1367 1368 static struct clk_branch camcc_ife_2_cphy_rx_clk = { 1369 .halt_reg = 0xb050, 1370 .halt_check = BRANCH_HALT, 1371 .clkr = { 1372 .enable_reg = 0xb050, 1373 .enable_mask = BIT(0), 1374 .hw.init = &(struct clk_init_data){ 1375 .name = "camcc_ife_2_cphy_rx_clk", 1376 .parent_hws = (const struct clk_hw*[]){ 1377 &camcc_cphy_rx_clk_src.clkr.hw 1378 }, 1379 .num_parents = 1, 1380 .flags = CLK_SET_RATE_PARENT, 1381 .ops = &clk_branch2_ops, 1382 }, 1383 }, 1384 }; 1385 1386 static struct clk_branch camcc_ife_2_csid_clk = { 1387 .halt_reg = 0xb048, 1388 .halt_check = BRANCH_HALT, 1389 .clkr = { 1390 .enable_reg = 0xb048, 1391 .enable_mask = BIT(0), 1392 .hw.init = &(struct clk_init_data){ 1393 .name = "camcc_ife_2_csid_clk", 1394 .parent_hws = (const struct clk_hw*[]){ 1395 &camcc_ife_2_csid_clk_src.clkr.hw 1396 }, 1397 .num_parents = 1, 1398 .flags = CLK_SET_RATE_PARENT, 1399 .ops = &clk_branch2_ops, 1400 }, 1401 }, 1402 }; 1403 1404 static struct clk_branch camcc_ife_2_dsp_clk = { 1405 .halt_reg = 0xb02c, 1406 .halt_check = BRANCH_HALT, 1407 .clkr = { 1408 .enable_reg = 0xb02c, 1409 .enable_mask = BIT(0), 1410 .hw.init = &(struct clk_init_data){ 1411 .name = "camcc_ife_2_dsp_clk", 1412 .parent_hws = (const struct clk_hw*[]){ 1413 &camcc_ife_2_clk_src.clkr.hw 1414 }, 1415 .num_parents = 1, 1416 .flags = CLK_SET_RATE_PARENT, 1417 .ops = &clk_branch2_ops, 1418 }, 1419 }, 1420 }; 1421 1422 static struct clk_branch camcc_ife_lite_clk = { 1423 .halt_reg = 0xc01c, 1424 .halt_check = BRANCH_HALT, 1425 .clkr = { 1426 .enable_reg = 0xc01c, 1427 .enable_mask = BIT(0), 1428 .hw.init = &(struct clk_init_data){ 1429 .name = "camcc_ife_lite_clk", 1430 .parent_hws = (const struct clk_hw*[]){ 1431 &camcc_ife_lite_clk_src.clkr.hw 1432 }, 1433 .num_parents = 1, 1434 .flags = CLK_SET_RATE_PARENT, 1435 .ops = &clk_branch2_ops, 1436 }, 1437 }, 1438 }; 1439 1440 static struct clk_branch camcc_ife_lite_cphy_rx_clk = { 1441 .halt_reg = 0xc044, 1442 .halt_check = BRANCH_HALT, 1443 .clkr = { 1444 .enable_reg = 0xc044, 1445 .enable_mask = BIT(0), 1446 .hw.init = &(struct clk_init_data){ 1447 .name = "camcc_ife_lite_cphy_rx_clk", 1448 .parent_hws = (const struct clk_hw*[]){ 1449 &camcc_cphy_rx_clk_src.clkr.hw 1450 }, 1451 .num_parents = 1, 1452 .flags = CLK_SET_RATE_PARENT, 1453 .ops = &clk_branch2_ops, 1454 }, 1455 }, 1456 }; 1457 1458 static struct clk_branch camcc_ife_lite_csid_clk = { 1459 .halt_reg = 0xc03c, 1460 .halt_check = BRANCH_HALT, 1461 .clkr = { 1462 .enable_reg = 0xc03c, 1463 .enable_mask = BIT(0), 1464 .hw.init = &(struct clk_init_data){ 1465 .name = "camcc_ife_lite_csid_clk", 1466 .parent_hws = (const struct clk_hw*[]){ 1467 &camcc_ife_lite_csid_clk_src.clkr.hw 1468 }, 1469 .num_parents = 1, 1470 .flags = CLK_SET_RATE_PARENT, 1471 .ops = &clk_branch2_ops, 1472 }, 1473 }, 1474 }; 1475 1476 static struct clk_branch camcc_ipe_0_ahb_clk = { 1477 .halt_reg = 0x7040, 1478 .halt_check = BRANCH_HALT, 1479 .clkr = { 1480 .enable_reg = 0x7040, 1481 .enable_mask = BIT(0), 1482 .hw.init = &(struct clk_init_data){ 1483 .name = "camcc_ipe_0_ahb_clk", 1484 .parent_hws = (const struct clk_hw*[]){ 1485 &camcc_slow_ahb_clk_src.clkr.hw 1486 }, 1487 .num_parents = 1, 1488 .flags = CLK_SET_RATE_PARENT, 1489 .ops = &clk_branch2_ops, 1490 }, 1491 }, 1492 }; 1493 1494 static struct clk_branch camcc_ipe_0_areg_clk = { 1495 .halt_reg = 0x703c, 1496 .halt_check = BRANCH_HALT, 1497 .clkr = { 1498 .enable_reg = 0x703c, 1499 .enable_mask = BIT(0), 1500 .hw.init = &(struct clk_init_data){ 1501 .name = "camcc_ipe_0_areg_clk", 1502 .parent_hws = (const struct clk_hw*[]){ 1503 &camcc_fast_ahb_clk_src.clkr.hw 1504 }, 1505 .num_parents = 1, 1506 .flags = CLK_SET_RATE_PARENT, 1507 .ops = &clk_branch2_ops, 1508 }, 1509 }, 1510 }; 1511 1512 static struct clk_branch camcc_ipe_0_axi_clk = { 1513 .halt_reg = 0x7038, 1514 .halt_check = BRANCH_HALT, 1515 .clkr = { 1516 .enable_reg = 0x7038, 1517 .enable_mask = BIT(0), 1518 .hw.init = &(struct clk_init_data){ 1519 .name = "camcc_ipe_0_axi_clk", 1520 .ops = &clk_branch2_ops, 1521 }, 1522 }, 1523 }; 1524 1525 static struct clk_branch camcc_ipe_0_clk = { 1526 .halt_reg = 0x7028, 1527 .halt_check = BRANCH_HALT, 1528 .clkr = { 1529 .enable_reg = 0x7028, 1530 .enable_mask = BIT(0), 1531 .hw.init = &(struct clk_init_data){ 1532 .name = "camcc_ipe_0_clk", 1533 .parent_hws = (const struct clk_hw*[]){ 1534 &camcc_ipe_0_clk_src.clkr.hw 1535 }, 1536 .num_parents = 1, 1537 .flags = CLK_SET_RATE_PARENT, 1538 .ops = &clk_branch2_ops, 1539 }, 1540 }, 1541 }; 1542 1543 static struct clk_branch camcc_jpeg_clk = { 1544 .halt_reg = 0xd01c, 1545 .halt_check = BRANCH_HALT, 1546 .clkr = { 1547 .enable_reg = 0xd01c, 1548 .enable_mask = BIT(0), 1549 .hw.init = &(struct clk_init_data){ 1550 .name = "camcc_jpeg_clk", 1551 .parent_hws = (const struct clk_hw*[]){ 1552 &camcc_jpeg_clk_src.clkr.hw 1553 }, 1554 .num_parents = 1, 1555 .flags = CLK_SET_RATE_PARENT, 1556 .ops = &clk_branch2_ops, 1557 }, 1558 }, 1559 }; 1560 1561 static struct clk_branch camcc_lrme_clk = { 1562 .halt_reg = 0x1101c, 1563 .halt_check = BRANCH_HALT, 1564 .clkr = { 1565 .enable_reg = 0x1101c, 1566 .enable_mask = BIT(0), 1567 .hw.init = &(struct clk_init_data){ 1568 .name = "camcc_lrme_clk", 1569 .parent_hws = (const struct clk_hw*[]){ 1570 &camcc_lrme_clk_src.clkr.hw 1571 }, 1572 .num_parents = 1, 1573 .flags = CLK_SET_RATE_PARENT, 1574 .ops = &clk_branch2_ops, 1575 }, 1576 }, 1577 }; 1578 1579 static struct clk_branch camcc_mclk0_clk = { 1580 .halt_reg = 0x401c, 1581 .halt_check = BRANCH_HALT, 1582 .clkr = { 1583 .enable_reg = 0x401c, 1584 .enable_mask = BIT(0), 1585 .hw.init = &(struct clk_init_data){ 1586 .name = "camcc_mclk0_clk", 1587 .parent_hws = (const struct clk_hw*[]){ 1588 &camcc_mclk0_clk_src.clkr.hw 1589 }, 1590 .num_parents = 1, 1591 .flags = CLK_SET_RATE_PARENT, 1592 .ops = &clk_branch2_ops, 1593 }, 1594 }, 1595 }; 1596 1597 static struct clk_branch camcc_mclk1_clk = { 1598 .halt_reg = 0x403c, 1599 .halt_check = BRANCH_HALT, 1600 .clkr = { 1601 .enable_reg = 0x403c, 1602 .enable_mask = BIT(0), 1603 .hw.init = &(struct clk_init_data){ 1604 .name = "camcc_mclk1_clk", 1605 .parent_hws = (const struct clk_hw*[]){ 1606 &camcc_mclk1_clk_src.clkr.hw 1607 }, 1608 .num_parents = 1, 1609 .flags = CLK_SET_RATE_PARENT, 1610 .ops = &clk_branch2_ops, 1611 }, 1612 }, 1613 }; 1614 1615 static struct clk_branch camcc_mclk2_clk = { 1616 .halt_reg = 0x405c, 1617 .halt_check = BRANCH_HALT, 1618 .clkr = { 1619 .enable_reg = 0x405c, 1620 .enable_mask = BIT(0), 1621 .hw.init = &(struct clk_init_data){ 1622 .name = "camcc_mclk2_clk", 1623 .parent_hws = (const struct clk_hw*[]){ 1624 &camcc_mclk2_clk_src.clkr.hw 1625 }, 1626 .num_parents = 1, 1627 .flags = CLK_SET_RATE_PARENT, 1628 .ops = &clk_branch2_ops, 1629 }, 1630 }, 1631 }; 1632 1633 static struct clk_branch camcc_mclk3_clk = { 1634 .halt_reg = 0x407c, 1635 .halt_check = BRANCH_HALT, 1636 .clkr = { 1637 .enable_reg = 0x407c, 1638 .enable_mask = BIT(0), 1639 .hw.init = &(struct clk_init_data){ 1640 .name = "camcc_mclk3_clk", 1641 .parent_hws = (const struct clk_hw*[]){ 1642 &camcc_mclk3_clk_src.clkr.hw 1643 }, 1644 .num_parents = 1, 1645 .flags = CLK_SET_RATE_PARENT, 1646 .ops = &clk_branch2_ops, 1647 }, 1648 }, 1649 }; 1650 1651 static struct clk_branch camcc_mclk4_clk = { 1652 .halt_reg = 0x409c, 1653 .halt_check = BRANCH_HALT, 1654 .clkr = { 1655 .enable_reg = 0x409c, 1656 .enable_mask = BIT(0), 1657 .hw.init = &(struct clk_init_data){ 1658 .name = "camcc_mclk4_clk", 1659 .parent_hws = (const struct clk_hw*[]){ 1660 &camcc_mclk4_clk_src.clkr.hw 1661 }, 1662 .num_parents = 1, 1663 .flags = CLK_SET_RATE_PARENT, 1664 .ops = &clk_branch2_ops, 1665 }, 1666 }, 1667 }; 1668 1669 static struct clk_branch camcc_soc_ahb_clk = { 1670 .halt_reg = 0x1400c, 1671 .halt_check = BRANCH_HALT, 1672 .clkr = { 1673 .enable_reg = 0x1400c, 1674 .enable_mask = BIT(0), 1675 .hw.init = &(struct clk_init_data){ 1676 .name = "camcc_soc_ahb_clk", 1677 .ops = &clk_branch2_ops, 1678 }, 1679 }, 1680 }; 1681 1682 static struct clk_branch camcc_sys_tmr_clk = { 1683 .halt_reg = 0xe034, 1684 .halt_check = BRANCH_HALT, 1685 .clkr = { 1686 .enable_reg = 0xe034, 1687 .enable_mask = BIT(0), 1688 .hw.init = &(struct clk_init_data){ 1689 .name = "camcc_sys_tmr_clk", 1690 .ops = &clk_branch2_ops, 1691 }, 1692 }, 1693 }; 1694 1695 static struct gdsc bps_gdsc = { 1696 .gdscr = 0x6004, 1697 .pd = { 1698 .name = "bps_gdsc", 1699 }, 1700 .pwrsts = PWRSTS_OFF_ON, 1701 .flags = VOTABLE, 1702 }; 1703 1704 static struct gdsc ipe_0_gdsc = { 1705 .gdscr = 0x7004, 1706 .pd = { 1707 .name = "ipe_0_gdsc", 1708 }, 1709 .pwrsts = PWRSTS_OFF_ON, 1710 .flags = VOTABLE, 1711 }; 1712 1713 static struct gdsc ife_0_gdsc = { 1714 .gdscr = 0x9004, 1715 .pd = { 1716 .name = "ife_0_gdsc", 1717 }, 1718 .pwrsts = PWRSTS_OFF_ON, 1719 }; 1720 1721 static struct gdsc ife_1_gdsc = { 1722 .gdscr = 0xa004, 1723 .pd = { 1724 .name = "ife_1_gdsc", 1725 }, 1726 .pwrsts = PWRSTS_OFF_ON, 1727 }; 1728 1729 static struct gdsc ife_2_gdsc = { 1730 .gdscr = 0xb004, 1731 .pd = { 1732 .name = "ife_2_gdsc", 1733 }, 1734 .pwrsts = PWRSTS_OFF_ON, 1735 }; 1736 1737 static struct gdsc titan_top_gdsc = { 1738 .gdscr = 0x14004, 1739 .pd = { 1740 .name = "titan_top_gdsc", 1741 }, 1742 .pwrsts = PWRSTS_OFF_ON, 1743 }; 1744 1745 static struct clk_hw *camcc_sm6350_hws[] = { 1746 [CAMCC_PLL2_OUT_EARLY] = &camcc_pll2_out_early.hw, 1747 }; 1748 1749 static struct clk_regmap *camcc_sm6350_clocks[] = { 1750 [CAMCC_BPS_AHB_CLK] = &camcc_bps_ahb_clk.clkr, 1751 [CAMCC_BPS_AREG_CLK] = &camcc_bps_areg_clk.clkr, 1752 [CAMCC_BPS_AXI_CLK] = &camcc_bps_axi_clk.clkr, 1753 [CAMCC_BPS_CLK] = &camcc_bps_clk.clkr, 1754 [CAMCC_BPS_CLK_SRC] = &camcc_bps_clk_src.clkr, 1755 [CAMCC_CAMNOC_AXI_CLK] = &camcc_camnoc_axi_clk.clkr, 1756 [CAMCC_CCI_0_CLK] = &camcc_cci_0_clk.clkr, 1757 [CAMCC_CCI_0_CLK_SRC] = &camcc_cci_0_clk_src.clkr, 1758 [CAMCC_CCI_1_CLK] = &camcc_cci_1_clk.clkr, 1759 [CAMCC_CCI_1_CLK_SRC] = &camcc_cci_1_clk_src.clkr, 1760 [CAMCC_CORE_AHB_CLK] = &camcc_core_ahb_clk.clkr, 1761 [CAMCC_CPAS_AHB_CLK] = &camcc_cpas_ahb_clk.clkr, 1762 [CAMCC_CPHY_RX_CLK_SRC] = &camcc_cphy_rx_clk_src.clkr, 1763 [CAMCC_CSI0PHYTIMER_CLK] = &camcc_csi0phytimer_clk.clkr, 1764 [CAMCC_CSI0PHYTIMER_CLK_SRC] = &camcc_csi0phytimer_clk_src.clkr, 1765 [CAMCC_CSI1PHYTIMER_CLK] = &camcc_csi1phytimer_clk.clkr, 1766 [CAMCC_CSI1PHYTIMER_CLK_SRC] = &camcc_csi1phytimer_clk_src.clkr, 1767 [CAMCC_CSI2PHYTIMER_CLK] = &camcc_csi2phytimer_clk.clkr, 1768 [CAMCC_CSI2PHYTIMER_CLK_SRC] = &camcc_csi2phytimer_clk_src.clkr, 1769 [CAMCC_CSI3PHYTIMER_CLK] = &camcc_csi3phytimer_clk.clkr, 1770 [CAMCC_CSI3PHYTIMER_CLK_SRC] = &camcc_csi3phytimer_clk_src.clkr, 1771 [CAMCC_CSIPHY0_CLK] = &camcc_csiphy0_clk.clkr, 1772 [CAMCC_CSIPHY1_CLK] = &camcc_csiphy1_clk.clkr, 1773 [CAMCC_CSIPHY2_CLK] = &camcc_csiphy2_clk.clkr, 1774 [CAMCC_CSIPHY3_CLK] = &camcc_csiphy3_clk.clkr, 1775 [CAMCC_FAST_AHB_CLK_SRC] = &camcc_fast_ahb_clk_src.clkr, 1776 [CAMCC_ICP_CLK] = &camcc_icp_clk.clkr, 1777 [CAMCC_ICP_CLK_SRC] = &camcc_icp_clk_src.clkr, 1778 [CAMCC_ICP_TS_CLK] = &camcc_icp_ts_clk.clkr, 1779 [CAMCC_IFE_0_AXI_CLK] = &camcc_ife_0_axi_clk.clkr, 1780 [CAMCC_IFE_0_CLK] = &camcc_ife_0_clk.clkr, 1781 [CAMCC_IFE_0_CLK_SRC] = &camcc_ife_0_clk_src.clkr, 1782 [CAMCC_IFE_0_CPHY_RX_CLK] = &camcc_ife_0_cphy_rx_clk.clkr, 1783 [CAMCC_IFE_0_CSID_CLK] = &camcc_ife_0_csid_clk.clkr, 1784 [CAMCC_IFE_0_CSID_CLK_SRC] = &camcc_ife_0_csid_clk_src.clkr, 1785 [CAMCC_IFE_0_DSP_CLK] = &camcc_ife_0_dsp_clk.clkr, 1786 [CAMCC_IFE_1_AXI_CLK] = &camcc_ife_1_axi_clk.clkr, 1787 [CAMCC_IFE_1_CLK] = &camcc_ife_1_clk.clkr, 1788 [CAMCC_IFE_1_CLK_SRC] = &camcc_ife_1_clk_src.clkr, 1789 [CAMCC_IFE_1_CPHY_RX_CLK] = &camcc_ife_1_cphy_rx_clk.clkr, 1790 [CAMCC_IFE_1_CSID_CLK] = &camcc_ife_1_csid_clk.clkr, 1791 [CAMCC_IFE_1_CSID_CLK_SRC] = &camcc_ife_1_csid_clk_src.clkr, 1792 [CAMCC_IFE_1_DSP_CLK] = &camcc_ife_1_dsp_clk.clkr, 1793 [CAMCC_IFE_2_AXI_CLK] = &camcc_ife_2_axi_clk.clkr, 1794 [CAMCC_IFE_2_CLK] = &camcc_ife_2_clk.clkr, 1795 [CAMCC_IFE_2_CLK_SRC] = &camcc_ife_2_clk_src.clkr, 1796 [CAMCC_IFE_2_CPHY_RX_CLK] = &camcc_ife_2_cphy_rx_clk.clkr, 1797 [CAMCC_IFE_2_CSID_CLK] = &camcc_ife_2_csid_clk.clkr, 1798 [CAMCC_IFE_2_CSID_CLK_SRC] = &camcc_ife_2_csid_clk_src.clkr, 1799 [CAMCC_IFE_2_DSP_CLK] = &camcc_ife_2_dsp_clk.clkr, 1800 [CAMCC_IFE_LITE_CLK] = &camcc_ife_lite_clk.clkr, 1801 [CAMCC_IFE_LITE_CLK_SRC] = &camcc_ife_lite_clk_src.clkr, 1802 [CAMCC_IFE_LITE_CPHY_RX_CLK] = &camcc_ife_lite_cphy_rx_clk.clkr, 1803 [CAMCC_IFE_LITE_CSID_CLK] = &camcc_ife_lite_csid_clk.clkr, 1804 [CAMCC_IFE_LITE_CSID_CLK_SRC] = &camcc_ife_lite_csid_clk_src.clkr, 1805 [CAMCC_IPE_0_AHB_CLK] = &camcc_ipe_0_ahb_clk.clkr, 1806 [CAMCC_IPE_0_AREG_CLK] = &camcc_ipe_0_areg_clk.clkr, 1807 [CAMCC_IPE_0_AXI_CLK] = &camcc_ipe_0_axi_clk.clkr, 1808 [CAMCC_IPE_0_CLK] = &camcc_ipe_0_clk.clkr, 1809 [CAMCC_IPE_0_CLK_SRC] = &camcc_ipe_0_clk_src.clkr, 1810 [CAMCC_JPEG_CLK] = &camcc_jpeg_clk.clkr, 1811 [CAMCC_JPEG_CLK_SRC] = &camcc_jpeg_clk_src.clkr, 1812 [CAMCC_LRME_CLK] = &camcc_lrme_clk.clkr, 1813 [CAMCC_LRME_CLK_SRC] = &camcc_lrme_clk_src.clkr, 1814 [CAMCC_MCLK0_CLK] = &camcc_mclk0_clk.clkr, 1815 [CAMCC_MCLK0_CLK_SRC] = &camcc_mclk0_clk_src.clkr, 1816 [CAMCC_MCLK1_CLK] = &camcc_mclk1_clk.clkr, 1817 [CAMCC_MCLK1_CLK_SRC] = &camcc_mclk1_clk_src.clkr, 1818 [CAMCC_MCLK2_CLK] = &camcc_mclk2_clk.clkr, 1819 [CAMCC_MCLK2_CLK_SRC] = &camcc_mclk2_clk_src.clkr, 1820 [CAMCC_MCLK3_CLK] = &camcc_mclk3_clk.clkr, 1821 [CAMCC_MCLK3_CLK_SRC] = &camcc_mclk3_clk_src.clkr, 1822 [CAMCC_MCLK4_CLK] = &camcc_mclk4_clk.clkr, 1823 [CAMCC_MCLK4_CLK_SRC] = &camcc_mclk4_clk_src.clkr, 1824 [CAMCC_PLL0] = &camcc_pll0.clkr, 1825 [CAMCC_PLL0_OUT_EVEN] = &camcc_pll0_out_even.clkr, 1826 [CAMCC_PLL1] = &camcc_pll1.clkr, 1827 [CAMCC_PLL1_OUT_EVEN] = &camcc_pll1_out_even.clkr, 1828 [CAMCC_PLL2] = &camcc_pll2.clkr, 1829 [CAMCC_PLL2_OUT_MAIN] = &camcc_pll2_out_main.clkr, 1830 [CAMCC_PLL3] = &camcc_pll3.clkr, 1831 [CAMCC_SLOW_AHB_CLK_SRC] = &camcc_slow_ahb_clk_src.clkr, 1832 [CAMCC_SOC_AHB_CLK] = &camcc_soc_ahb_clk.clkr, 1833 [CAMCC_SYS_TMR_CLK] = &camcc_sys_tmr_clk.clkr, 1834 }; 1835 1836 static struct gdsc *camcc_sm6350_gdscs[] = { 1837 [BPS_GDSC] = &bps_gdsc, 1838 [IPE_0_GDSC] = &ipe_0_gdsc, 1839 [IFE_0_GDSC] = &ife_0_gdsc, 1840 [IFE_1_GDSC] = &ife_1_gdsc, 1841 [IFE_2_GDSC] = &ife_2_gdsc, 1842 [TITAN_TOP_GDSC] = &titan_top_gdsc, 1843 }; 1844 1845 static const struct regmap_config camcc_sm6350_regmap_config = { 1846 .reg_bits = 32, 1847 .reg_stride = 4, 1848 .val_bits = 32, 1849 .max_register = 0x16000, 1850 .fast_io = true, 1851 }; 1852 1853 static const struct qcom_cc_desc camcc_sm6350_desc = { 1854 .config = &camcc_sm6350_regmap_config, 1855 .clk_hws = camcc_sm6350_hws, 1856 .num_clk_hws = ARRAY_SIZE(camcc_sm6350_hws), 1857 .clks = camcc_sm6350_clocks, 1858 .num_clks = ARRAY_SIZE(camcc_sm6350_clocks), 1859 .gdscs = camcc_sm6350_gdscs, 1860 .num_gdscs = ARRAY_SIZE(camcc_sm6350_gdscs), 1861 }; 1862 1863 static const struct of_device_id camcc_sm6350_match_table[] = { 1864 { .compatible = "qcom,sm6350-camcc" }, 1865 { } 1866 }; 1867 MODULE_DEVICE_TABLE(of, camcc_sm6350_match_table); 1868 1869 static int camcc_sm6350_probe(struct platform_device *pdev) 1870 { 1871 struct regmap *regmap; 1872 1873 regmap = qcom_cc_map(pdev, &camcc_sm6350_desc); 1874 if (IS_ERR(regmap)) 1875 return PTR_ERR(regmap); 1876 1877 clk_fabia_pll_configure(&camcc_pll0, regmap, &camcc_pll0_config); 1878 clk_fabia_pll_configure(&camcc_pll1, regmap, &camcc_pll1_config); 1879 clk_agera_pll_configure(&camcc_pll2, regmap, &camcc_pll2_config); 1880 clk_fabia_pll_configure(&camcc_pll3, regmap, &camcc_pll3_config); 1881 1882 return qcom_cc_really_probe(pdev, &camcc_sm6350_desc, regmap); 1883 } 1884 1885 static struct platform_driver camcc_sm6350_driver = { 1886 .probe = camcc_sm6350_probe, 1887 .driver = { 1888 .name = "sm6350-camcc", 1889 .of_match_table = camcc_sm6350_match_table, 1890 }, 1891 }; 1892 1893 static int __init camcc_sm6350_init(void) 1894 { 1895 return platform_driver_register(&camcc_sm6350_driver); 1896 } 1897 subsys_initcall(camcc_sm6350_init); 1898 1899 static void __exit camcc_sm6350_exit(void) 1900 { 1901 platform_driver_unregister(&camcc_sm6350_driver); 1902 } 1903 module_exit(camcc_sm6350_exit); 1904 1905 MODULE_DESCRIPTION("QTI CAMCC SM6350 Driver"); 1906 MODULE_LICENSE("GPL"); 1907