1 // SPDX-License-Identifier: GPL-2.0+ 2 /* 3 * Amlogic Meson-G12A Clock Controller Driver 4 * 5 * Copyright (c) 2016 Baylibre SAS. 6 * Author: Michael Turquette <mturquette@baylibre.com> 7 * 8 * Copyright (c) 2018 Amlogic, inc. 9 * Author: Qiufang Dai <qiufang.dai@amlogic.com> 10 * Author: Jian Hu <jian.hu@amlogic.com> 11 */ 12 13 #include <linux/clk-provider.h> 14 #include <linux/init.h> 15 #include <linux/of.h> 16 #include <linux/platform_device.h> 17 #include <linux/clk.h> 18 #include <linux/module.h> 19 20 #include "clk-mpll.h" 21 #include "clk-pll.h" 22 #include "clk-regmap.h" 23 #include "clk-cpu-dyndiv.h" 24 #include "vid-pll-div.h" 25 #include "meson-eeclk.h" 26 #include "g12a.h" 27 28 #include <dt-bindings/clock/g12a-clkc.h> 29 30 static DEFINE_SPINLOCK(meson_clk_lock); 31 32 static struct clk_regmap g12a_fixed_pll_dco = { 33 .data = &(struct meson_clk_pll_data){ 34 .en = { 35 .reg_off = HHI_FIX_PLL_CNTL0, 36 .shift = 28, 37 .width = 1, 38 }, 39 .m = { 40 .reg_off = HHI_FIX_PLL_CNTL0, 41 .shift = 0, 42 .width = 8, 43 }, 44 .n = { 45 .reg_off = HHI_FIX_PLL_CNTL0, 46 .shift = 10, 47 .width = 5, 48 }, 49 .frac = { 50 .reg_off = HHI_FIX_PLL_CNTL1, 51 .shift = 0, 52 .width = 17, 53 }, 54 .l = { 55 .reg_off = HHI_FIX_PLL_CNTL0, 56 .shift = 31, 57 .width = 1, 58 }, 59 .rst = { 60 .reg_off = HHI_FIX_PLL_CNTL0, 61 .shift = 29, 62 .width = 1, 63 }, 64 }, 65 .hw.init = &(struct clk_init_data){ 66 .name = "fixed_pll_dco", 67 .ops = &meson_clk_pll_ro_ops, 68 .parent_data = &(const struct clk_parent_data) { 69 .fw_name = "xtal", 70 }, 71 .num_parents = 1, 72 }, 73 }; 74 75 static struct clk_regmap g12a_fixed_pll = { 76 .data = &(struct clk_regmap_div_data){ 77 .offset = HHI_FIX_PLL_CNTL0, 78 .shift = 16, 79 .width = 2, 80 .flags = CLK_DIVIDER_POWER_OF_TWO, 81 }, 82 .hw.init = &(struct clk_init_data){ 83 .name = "fixed_pll", 84 .ops = &clk_regmap_divider_ro_ops, 85 .parent_hws = (const struct clk_hw *[]) { 86 &g12a_fixed_pll_dco.hw 87 }, 88 .num_parents = 1, 89 /* 90 * This clock won't ever change at runtime so 91 * CLK_SET_RATE_PARENT is not required 92 */ 93 }, 94 }; 95 96 static const struct pll_mult_range g12a_sys_pll_mult_range = { 97 .min = 128, 98 .max = 250, 99 }; 100 101 static struct clk_regmap g12a_sys_pll_dco = { 102 .data = &(struct meson_clk_pll_data){ 103 .en = { 104 .reg_off = HHI_SYS_PLL_CNTL0, 105 .shift = 28, 106 .width = 1, 107 }, 108 .m = { 109 .reg_off = HHI_SYS_PLL_CNTL0, 110 .shift = 0, 111 .width = 8, 112 }, 113 .n = { 114 .reg_off = HHI_SYS_PLL_CNTL0, 115 .shift = 10, 116 .width = 5, 117 }, 118 .l = { 119 .reg_off = HHI_SYS_PLL_CNTL0, 120 .shift = 31, 121 .width = 1, 122 }, 123 .rst = { 124 .reg_off = HHI_SYS_PLL_CNTL0, 125 .shift = 29, 126 .width = 1, 127 }, 128 .range = &g12a_sys_pll_mult_range, 129 }, 130 .hw.init = &(struct clk_init_data){ 131 .name = "sys_pll_dco", 132 .ops = &meson_clk_pll_ops, 133 .parent_data = &(const struct clk_parent_data) { 134 .fw_name = "xtal", 135 }, 136 .num_parents = 1, 137 /* This clock feeds the CPU, avoid disabling it */ 138 .flags = CLK_IS_CRITICAL, 139 }, 140 }; 141 142 static struct clk_regmap g12a_sys_pll = { 143 .data = &(struct clk_regmap_div_data){ 144 .offset = HHI_SYS_PLL_CNTL0, 145 .shift = 16, 146 .width = 3, 147 .flags = CLK_DIVIDER_POWER_OF_TWO, 148 }, 149 .hw.init = &(struct clk_init_data){ 150 .name = "sys_pll", 151 .ops = &clk_regmap_divider_ops, 152 .parent_hws = (const struct clk_hw *[]) { 153 &g12a_sys_pll_dco.hw 154 }, 155 .num_parents = 1, 156 .flags = CLK_SET_RATE_PARENT, 157 }, 158 }; 159 160 static struct clk_regmap g12b_sys1_pll_dco = { 161 .data = &(struct meson_clk_pll_data){ 162 .en = { 163 .reg_off = HHI_SYS1_PLL_CNTL0, 164 .shift = 28, 165 .width = 1, 166 }, 167 .m = { 168 .reg_off = HHI_SYS1_PLL_CNTL0, 169 .shift = 0, 170 .width = 8, 171 }, 172 .n = { 173 .reg_off = HHI_SYS1_PLL_CNTL0, 174 .shift = 10, 175 .width = 5, 176 }, 177 .l = { 178 .reg_off = HHI_SYS1_PLL_CNTL0, 179 .shift = 31, 180 .width = 1, 181 }, 182 .rst = { 183 .reg_off = HHI_SYS1_PLL_CNTL0, 184 .shift = 29, 185 .width = 1, 186 }, 187 .range = &g12a_sys_pll_mult_range, 188 }, 189 .hw.init = &(struct clk_init_data){ 190 .name = "sys1_pll_dco", 191 .ops = &meson_clk_pll_ops, 192 .parent_data = &(const struct clk_parent_data) { 193 .fw_name = "xtal", 194 }, 195 .num_parents = 1, 196 /* This clock feeds the CPU, avoid disabling it */ 197 .flags = CLK_IS_CRITICAL, 198 }, 199 }; 200 201 static struct clk_regmap g12b_sys1_pll = { 202 .data = &(struct clk_regmap_div_data){ 203 .offset = HHI_SYS1_PLL_CNTL0, 204 .shift = 16, 205 .width = 3, 206 .flags = CLK_DIVIDER_POWER_OF_TWO, 207 }, 208 .hw.init = &(struct clk_init_data){ 209 .name = "sys1_pll", 210 .ops = &clk_regmap_divider_ops, 211 .parent_hws = (const struct clk_hw *[]) { 212 &g12b_sys1_pll_dco.hw 213 }, 214 .num_parents = 1, 215 .flags = CLK_SET_RATE_PARENT, 216 }, 217 }; 218 219 static struct clk_regmap g12a_sys_pll_div16_en = { 220 .data = &(struct clk_regmap_gate_data){ 221 .offset = HHI_SYS_CPU_CLK_CNTL1, 222 .bit_idx = 24, 223 }, 224 .hw.init = &(struct clk_init_data) { 225 .name = "sys_pll_div16_en", 226 .ops = &clk_regmap_gate_ro_ops, 227 .parent_hws = (const struct clk_hw *[]) { &g12a_sys_pll.hw }, 228 .num_parents = 1, 229 /* 230 * This clock is used to debug the sys_pll range 231 * Linux should not change it at runtime 232 */ 233 }, 234 }; 235 236 static struct clk_regmap g12b_sys1_pll_div16_en = { 237 .data = &(struct clk_regmap_gate_data){ 238 .offset = HHI_SYS_CPUB_CLK_CNTL1, 239 .bit_idx = 24, 240 }, 241 .hw.init = &(struct clk_init_data) { 242 .name = "sys1_pll_div16_en", 243 .ops = &clk_regmap_gate_ro_ops, 244 .parent_hws = (const struct clk_hw *[]) { 245 &g12b_sys1_pll.hw 246 }, 247 .num_parents = 1, 248 /* 249 * This clock is used to debug the sys_pll range 250 * Linux should not change it at runtime 251 */ 252 }, 253 }; 254 255 static struct clk_fixed_factor g12a_sys_pll_div16 = { 256 .mult = 1, 257 .div = 16, 258 .hw.init = &(struct clk_init_data){ 259 .name = "sys_pll_div16", 260 .ops = &clk_fixed_factor_ops, 261 .parent_hws = (const struct clk_hw *[]) { 262 &g12a_sys_pll_div16_en.hw 263 }, 264 .num_parents = 1, 265 }, 266 }; 267 268 static struct clk_fixed_factor g12b_sys1_pll_div16 = { 269 .mult = 1, 270 .div = 16, 271 .hw.init = &(struct clk_init_data){ 272 .name = "sys1_pll_div16", 273 .ops = &clk_fixed_factor_ops, 274 .parent_hws = (const struct clk_hw *[]) { 275 &g12b_sys1_pll_div16_en.hw 276 }, 277 .num_parents = 1, 278 }, 279 }; 280 281 static struct clk_fixed_factor g12a_fclk_div2_div = { 282 .mult = 1, 283 .div = 2, 284 .hw.init = &(struct clk_init_data){ 285 .name = "fclk_div2_div", 286 .ops = &clk_fixed_factor_ops, 287 .parent_hws = (const struct clk_hw *[]) { &g12a_fixed_pll.hw }, 288 .num_parents = 1, 289 }, 290 }; 291 292 static struct clk_regmap g12a_fclk_div2 = { 293 .data = &(struct clk_regmap_gate_data){ 294 .offset = HHI_FIX_PLL_CNTL1, 295 .bit_idx = 24, 296 }, 297 .hw.init = &(struct clk_init_data){ 298 .name = "fclk_div2", 299 .ops = &clk_regmap_gate_ops, 300 .parent_hws = (const struct clk_hw *[]) { 301 &g12a_fclk_div2_div.hw 302 }, 303 .num_parents = 1, 304 /* 305 * Similar to fclk_div3, it seems that this clock is used by 306 * the resident firmware and is required by the platform to 307 * operate correctly. 308 * Until the following condition are met, we need this clock to 309 * be marked as critical: 310 * a) Mark the clock used by a firmware resource, if possible 311 * b) CCF has a clock hand-off mechanism to make the sure the 312 * clock stays on until the proper driver comes along 313 */ 314 .flags = CLK_IS_CRITICAL, 315 }, 316 }; 317 318 static struct clk_fixed_factor g12a_fclk_div3_div = { 319 .mult = 1, 320 .div = 3, 321 .hw.init = &(struct clk_init_data){ 322 .name = "fclk_div3_div", 323 .ops = &clk_fixed_factor_ops, 324 .parent_hws = (const struct clk_hw *[]) { &g12a_fixed_pll.hw }, 325 .num_parents = 1, 326 }, 327 }; 328 329 static struct clk_regmap g12a_fclk_div3 = { 330 .data = &(struct clk_regmap_gate_data){ 331 .offset = HHI_FIX_PLL_CNTL1, 332 .bit_idx = 20, 333 }, 334 .hw.init = &(struct clk_init_data){ 335 .name = "fclk_div3", 336 .ops = &clk_regmap_gate_ops, 337 .parent_hws = (const struct clk_hw *[]) { 338 &g12a_fclk_div3_div.hw 339 }, 340 .num_parents = 1, 341 /* 342 * This clock is used by the resident firmware and is required 343 * by the platform to operate correctly. 344 * Until the following condition are met, we need this clock to 345 * be marked as critical: 346 * a) Mark the clock used by a firmware resource, if possible 347 * b) CCF has a clock hand-off mechanism to make the sure the 348 * clock stays on until the proper driver comes along 349 */ 350 .flags = CLK_IS_CRITICAL, 351 }, 352 }; 353 354 /* Datasheet names this field as "premux0" */ 355 static struct clk_regmap g12a_cpu_clk_premux0 = { 356 .data = &(struct clk_regmap_mux_data){ 357 .offset = HHI_SYS_CPU_CLK_CNTL0, 358 .mask = 0x3, 359 .shift = 0, 360 .flags = CLK_MUX_ROUND_CLOSEST, 361 }, 362 .hw.init = &(struct clk_init_data){ 363 .name = "cpu_clk_dyn0_sel", 364 .ops = &clk_regmap_mux_ops, 365 .parent_data = (const struct clk_parent_data []) { 366 { .fw_name = "xtal", }, 367 { .hw = &g12a_fclk_div2.hw }, 368 { .hw = &g12a_fclk_div3.hw }, 369 }, 370 .num_parents = 3, 371 .flags = CLK_SET_RATE_PARENT, 372 }, 373 }; 374 375 /* Datasheet names this field as "premux1" */ 376 static struct clk_regmap g12a_cpu_clk_premux1 = { 377 .data = &(struct clk_regmap_mux_data){ 378 .offset = HHI_SYS_CPU_CLK_CNTL0, 379 .mask = 0x3, 380 .shift = 16, 381 }, 382 .hw.init = &(struct clk_init_data){ 383 .name = "cpu_clk_dyn1_sel", 384 .ops = &clk_regmap_mux_ops, 385 .parent_data = (const struct clk_parent_data []) { 386 { .fw_name = "xtal", }, 387 { .hw = &g12a_fclk_div2.hw }, 388 { .hw = &g12a_fclk_div3.hw }, 389 }, 390 .num_parents = 3, 391 /* This sub-tree is used a parking clock */ 392 .flags = CLK_SET_RATE_NO_REPARENT 393 }, 394 }; 395 396 /* Datasheet names this field as "mux0_divn_tcnt" */ 397 static struct clk_regmap g12a_cpu_clk_mux0_div = { 398 .data = &(struct meson_clk_cpu_dyndiv_data){ 399 .div = { 400 .reg_off = HHI_SYS_CPU_CLK_CNTL0, 401 .shift = 4, 402 .width = 6, 403 }, 404 .dyn = { 405 .reg_off = HHI_SYS_CPU_CLK_CNTL0, 406 .shift = 26, 407 .width = 1, 408 }, 409 }, 410 .hw.init = &(struct clk_init_data){ 411 .name = "cpu_clk_dyn0_div", 412 .ops = &meson_clk_cpu_dyndiv_ops, 413 .parent_hws = (const struct clk_hw *[]) { 414 &g12a_cpu_clk_premux0.hw 415 }, 416 .num_parents = 1, 417 .flags = CLK_SET_RATE_PARENT, 418 }, 419 }; 420 421 /* Datasheet names this field as "postmux0" */ 422 static struct clk_regmap g12a_cpu_clk_postmux0 = { 423 .data = &(struct clk_regmap_mux_data){ 424 .offset = HHI_SYS_CPU_CLK_CNTL0, 425 .mask = 0x1, 426 .shift = 2, 427 .flags = CLK_MUX_ROUND_CLOSEST, 428 }, 429 .hw.init = &(struct clk_init_data){ 430 .name = "cpu_clk_dyn0", 431 .ops = &clk_regmap_mux_ops, 432 .parent_hws = (const struct clk_hw *[]) { 433 &g12a_cpu_clk_premux0.hw, 434 &g12a_cpu_clk_mux0_div.hw, 435 }, 436 .num_parents = 2, 437 .flags = CLK_SET_RATE_PARENT, 438 }, 439 }; 440 441 /* Datasheet names this field as "Mux1_divn_tcnt" */ 442 static struct clk_regmap g12a_cpu_clk_mux1_div = { 443 .data = &(struct clk_regmap_div_data){ 444 .offset = HHI_SYS_CPU_CLK_CNTL0, 445 .shift = 20, 446 .width = 6, 447 }, 448 .hw.init = &(struct clk_init_data){ 449 .name = "cpu_clk_dyn1_div", 450 .ops = &clk_regmap_divider_ro_ops, 451 .parent_hws = (const struct clk_hw *[]) { 452 &g12a_cpu_clk_premux1.hw 453 }, 454 .num_parents = 1, 455 }, 456 }; 457 458 /* Datasheet names this field as "postmux1" */ 459 static struct clk_regmap g12a_cpu_clk_postmux1 = { 460 .data = &(struct clk_regmap_mux_data){ 461 .offset = HHI_SYS_CPU_CLK_CNTL0, 462 .mask = 0x1, 463 .shift = 18, 464 }, 465 .hw.init = &(struct clk_init_data){ 466 .name = "cpu_clk_dyn1", 467 .ops = &clk_regmap_mux_ops, 468 .parent_hws = (const struct clk_hw *[]) { 469 &g12a_cpu_clk_premux1.hw, 470 &g12a_cpu_clk_mux1_div.hw, 471 }, 472 .num_parents = 2, 473 /* This sub-tree is used a parking clock */ 474 .flags = CLK_SET_RATE_NO_REPARENT, 475 }, 476 }; 477 478 /* Datasheet names this field as "Final_dyn_mux_sel" */ 479 static struct clk_regmap g12a_cpu_clk_dyn = { 480 .data = &(struct clk_regmap_mux_data){ 481 .offset = HHI_SYS_CPU_CLK_CNTL0, 482 .mask = 0x1, 483 .shift = 10, 484 .flags = CLK_MUX_ROUND_CLOSEST, 485 }, 486 .hw.init = &(struct clk_init_data){ 487 .name = "cpu_clk_dyn", 488 .ops = &clk_regmap_mux_ops, 489 .parent_hws = (const struct clk_hw *[]) { 490 &g12a_cpu_clk_postmux0.hw, 491 &g12a_cpu_clk_postmux1.hw, 492 }, 493 .num_parents = 2, 494 .flags = CLK_SET_RATE_PARENT, 495 }, 496 }; 497 498 /* Datasheet names this field as "Final_mux_sel" */ 499 static struct clk_regmap g12a_cpu_clk = { 500 .data = &(struct clk_regmap_mux_data){ 501 .offset = HHI_SYS_CPU_CLK_CNTL0, 502 .mask = 0x1, 503 .shift = 11, 504 .flags = CLK_MUX_ROUND_CLOSEST, 505 }, 506 .hw.init = &(struct clk_init_data){ 507 .name = "cpu_clk", 508 .ops = &clk_regmap_mux_ops, 509 .parent_hws = (const struct clk_hw *[]) { 510 &g12a_cpu_clk_dyn.hw, 511 &g12a_sys_pll.hw, 512 }, 513 .num_parents = 2, 514 .flags = CLK_SET_RATE_PARENT, 515 }, 516 }; 517 518 /* Datasheet names this field as "Final_mux_sel" */ 519 static struct clk_regmap g12b_cpu_clk = { 520 .data = &(struct clk_regmap_mux_data){ 521 .offset = HHI_SYS_CPU_CLK_CNTL0, 522 .mask = 0x1, 523 .shift = 11, 524 .flags = CLK_MUX_ROUND_CLOSEST, 525 }, 526 .hw.init = &(struct clk_init_data){ 527 .name = "cpu_clk", 528 .ops = &clk_regmap_mux_ops, 529 .parent_hws = (const struct clk_hw *[]) { 530 &g12a_cpu_clk_dyn.hw, 531 &g12b_sys1_pll.hw 532 }, 533 .num_parents = 2, 534 .flags = CLK_SET_RATE_PARENT, 535 }, 536 }; 537 538 /* Datasheet names this field as "premux0" */ 539 static struct clk_regmap g12b_cpub_clk_premux0 = { 540 .data = &(struct clk_regmap_mux_data){ 541 .offset = HHI_SYS_CPUB_CLK_CNTL, 542 .mask = 0x3, 543 .shift = 0, 544 .flags = CLK_MUX_ROUND_CLOSEST, 545 }, 546 .hw.init = &(struct clk_init_data){ 547 .name = "cpub_clk_dyn0_sel", 548 .ops = &clk_regmap_mux_ops, 549 .parent_data = (const struct clk_parent_data []) { 550 { .fw_name = "xtal", }, 551 { .hw = &g12a_fclk_div2.hw }, 552 { .hw = &g12a_fclk_div3.hw }, 553 }, 554 .num_parents = 3, 555 .flags = CLK_SET_RATE_PARENT, 556 }, 557 }; 558 559 /* Datasheet names this field as "mux0_divn_tcnt" */ 560 static struct clk_regmap g12b_cpub_clk_mux0_div = { 561 .data = &(struct meson_clk_cpu_dyndiv_data){ 562 .div = { 563 .reg_off = HHI_SYS_CPUB_CLK_CNTL, 564 .shift = 4, 565 .width = 6, 566 }, 567 .dyn = { 568 .reg_off = HHI_SYS_CPUB_CLK_CNTL, 569 .shift = 26, 570 .width = 1, 571 }, 572 }, 573 .hw.init = &(struct clk_init_data){ 574 .name = "cpub_clk_dyn0_div", 575 .ops = &meson_clk_cpu_dyndiv_ops, 576 .parent_hws = (const struct clk_hw *[]) { 577 &g12b_cpub_clk_premux0.hw 578 }, 579 .num_parents = 1, 580 .flags = CLK_SET_RATE_PARENT, 581 }, 582 }; 583 584 /* Datasheet names this field as "postmux0" */ 585 static struct clk_regmap g12b_cpub_clk_postmux0 = { 586 .data = &(struct clk_regmap_mux_data){ 587 .offset = HHI_SYS_CPUB_CLK_CNTL, 588 .mask = 0x1, 589 .shift = 2, 590 .flags = CLK_MUX_ROUND_CLOSEST, 591 }, 592 .hw.init = &(struct clk_init_data){ 593 .name = "cpub_clk_dyn0", 594 .ops = &clk_regmap_mux_ops, 595 .parent_hws = (const struct clk_hw *[]) { 596 &g12b_cpub_clk_premux0.hw, 597 &g12b_cpub_clk_mux0_div.hw 598 }, 599 .num_parents = 2, 600 .flags = CLK_SET_RATE_PARENT, 601 }, 602 }; 603 604 /* Datasheet names this field as "premux1" */ 605 static struct clk_regmap g12b_cpub_clk_premux1 = { 606 .data = &(struct clk_regmap_mux_data){ 607 .offset = HHI_SYS_CPUB_CLK_CNTL, 608 .mask = 0x3, 609 .shift = 16, 610 }, 611 .hw.init = &(struct clk_init_data){ 612 .name = "cpub_clk_dyn1_sel", 613 .ops = &clk_regmap_mux_ops, 614 .parent_data = (const struct clk_parent_data []) { 615 { .fw_name = "xtal", }, 616 { .hw = &g12a_fclk_div2.hw }, 617 { .hw = &g12a_fclk_div3.hw }, 618 }, 619 .num_parents = 3, 620 /* This sub-tree is used a parking clock */ 621 .flags = CLK_SET_RATE_NO_REPARENT, 622 }, 623 }; 624 625 /* Datasheet names this field as "Mux1_divn_tcnt" */ 626 static struct clk_regmap g12b_cpub_clk_mux1_div = { 627 .data = &(struct clk_regmap_div_data){ 628 .offset = HHI_SYS_CPUB_CLK_CNTL, 629 .shift = 20, 630 .width = 6, 631 }, 632 .hw.init = &(struct clk_init_data){ 633 .name = "cpub_clk_dyn1_div", 634 .ops = &clk_regmap_divider_ro_ops, 635 .parent_hws = (const struct clk_hw *[]) { 636 &g12b_cpub_clk_premux1.hw 637 }, 638 .num_parents = 1, 639 }, 640 }; 641 642 /* Datasheet names this field as "postmux1" */ 643 static struct clk_regmap g12b_cpub_clk_postmux1 = { 644 .data = &(struct clk_regmap_mux_data){ 645 .offset = HHI_SYS_CPUB_CLK_CNTL, 646 .mask = 0x1, 647 .shift = 18, 648 }, 649 .hw.init = &(struct clk_init_data){ 650 .name = "cpub_clk_dyn1", 651 .ops = &clk_regmap_mux_ops, 652 .parent_hws = (const struct clk_hw *[]) { 653 &g12b_cpub_clk_premux1.hw, 654 &g12b_cpub_clk_mux1_div.hw 655 }, 656 .num_parents = 2, 657 /* This sub-tree is used a parking clock */ 658 .flags = CLK_SET_RATE_NO_REPARENT, 659 }, 660 }; 661 662 /* Datasheet names this field as "Final_dyn_mux_sel" */ 663 static struct clk_regmap g12b_cpub_clk_dyn = { 664 .data = &(struct clk_regmap_mux_data){ 665 .offset = HHI_SYS_CPUB_CLK_CNTL, 666 .mask = 0x1, 667 .shift = 10, 668 .flags = CLK_MUX_ROUND_CLOSEST, 669 }, 670 .hw.init = &(struct clk_init_data){ 671 .name = "cpub_clk_dyn", 672 .ops = &clk_regmap_mux_ops, 673 .parent_hws = (const struct clk_hw *[]) { 674 &g12b_cpub_clk_postmux0.hw, 675 &g12b_cpub_clk_postmux1.hw 676 }, 677 .num_parents = 2, 678 .flags = CLK_SET_RATE_PARENT, 679 }, 680 }; 681 682 /* Datasheet names this field as "Final_mux_sel" */ 683 static struct clk_regmap g12b_cpub_clk = { 684 .data = &(struct clk_regmap_mux_data){ 685 .offset = HHI_SYS_CPUB_CLK_CNTL, 686 .mask = 0x1, 687 .shift = 11, 688 .flags = CLK_MUX_ROUND_CLOSEST, 689 }, 690 .hw.init = &(struct clk_init_data){ 691 .name = "cpub_clk", 692 .ops = &clk_regmap_mux_ops, 693 .parent_hws = (const struct clk_hw *[]) { 694 &g12b_cpub_clk_dyn.hw, 695 &g12a_sys_pll.hw 696 }, 697 .num_parents = 2, 698 .flags = CLK_SET_RATE_PARENT, 699 }, 700 }; 701 702 static struct clk_regmap sm1_gp1_pll; 703 704 /* Datasheet names this field as "premux0" */ 705 static struct clk_regmap sm1_dsu_clk_premux0 = { 706 .data = &(struct clk_regmap_mux_data){ 707 .offset = HHI_SYS_CPU_CLK_CNTL5, 708 .mask = 0x3, 709 .shift = 0, 710 }, 711 .hw.init = &(struct clk_init_data){ 712 .name = "dsu_clk_dyn0_sel", 713 .ops = &clk_regmap_mux_ro_ops, 714 .parent_data = (const struct clk_parent_data []) { 715 { .fw_name = "xtal", }, 716 { .hw = &g12a_fclk_div2.hw }, 717 { .hw = &g12a_fclk_div3.hw }, 718 { .hw = &sm1_gp1_pll.hw }, 719 }, 720 .num_parents = 4, 721 }, 722 }; 723 724 /* Datasheet names this field as "premux1" */ 725 static struct clk_regmap sm1_dsu_clk_premux1 = { 726 .data = &(struct clk_regmap_mux_data){ 727 .offset = HHI_SYS_CPU_CLK_CNTL5, 728 .mask = 0x3, 729 .shift = 16, 730 }, 731 .hw.init = &(struct clk_init_data){ 732 .name = "dsu_clk_dyn1_sel", 733 .ops = &clk_regmap_mux_ro_ops, 734 .parent_data = (const struct clk_parent_data []) { 735 { .fw_name = "xtal", }, 736 { .hw = &g12a_fclk_div2.hw }, 737 { .hw = &g12a_fclk_div3.hw }, 738 { .hw = &sm1_gp1_pll.hw }, 739 }, 740 .num_parents = 4, 741 }, 742 }; 743 744 /* Datasheet names this field as "Mux0_divn_tcnt" */ 745 static struct clk_regmap sm1_dsu_clk_mux0_div = { 746 .data = &(struct clk_regmap_div_data){ 747 .offset = HHI_SYS_CPU_CLK_CNTL5, 748 .shift = 4, 749 .width = 6, 750 }, 751 .hw.init = &(struct clk_init_data){ 752 .name = "dsu_clk_dyn0_div", 753 .ops = &clk_regmap_divider_ro_ops, 754 .parent_hws = (const struct clk_hw *[]) { 755 &sm1_dsu_clk_premux0.hw 756 }, 757 .num_parents = 1, 758 }, 759 }; 760 761 /* Datasheet names this field as "postmux0" */ 762 static struct clk_regmap sm1_dsu_clk_postmux0 = { 763 .data = &(struct clk_regmap_mux_data){ 764 .offset = HHI_SYS_CPU_CLK_CNTL5, 765 .mask = 0x1, 766 .shift = 2, 767 }, 768 .hw.init = &(struct clk_init_data){ 769 .name = "dsu_clk_dyn0", 770 .ops = &clk_regmap_mux_ro_ops, 771 .parent_hws = (const struct clk_hw *[]) { 772 &sm1_dsu_clk_premux0.hw, 773 &sm1_dsu_clk_mux0_div.hw, 774 }, 775 .num_parents = 2, 776 }, 777 }; 778 779 /* Datasheet names this field as "Mux1_divn_tcnt" */ 780 static struct clk_regmap sm1_dsu_clk_mux1_div = { 781 .data = &(struct clk_regmap_div_data){ 782 .offset = HHI_SYS_CPU_CLK_CNTL5, 783 .shift = 20, 784 .width = 6, 785 }, 786 .hw.init = &(struct clk_init_data){ 787 .name = "dsu_clk_dyn1_div", 788 .ops = &clk_regmap_divider_ro_ops, 789 .parent_hws = (const struct clk_hw *[]) { 790 &sm1_dsu_clk_premux1.hw 791 }, 792 .num_parents = 1, 793 }, 794 }; 795 796 /* Datasheet names this field as "postmux1" */ 797 static struct clk_regmap sm1_dsu_clk_postmux1 = { 798 .data = &(struct clk_regmap_mux_data){ 799 .offset = HHI_SYS_CPU_CLK_CNTL5, 800 .mask = 0x1, 801 .shift = 18, 802 }, 803 .hw.init = &(struct clk_init_data){ 804 .name = "dsu_clk_dyn1", 805 .ops = &clk_regmap_mux_ro_ops, 806 .parent_hws = (const struct clk_hw *[]) { 807 &sm1_dsu_clk_premux1.hw, 808 &sm1_dsu_clk_mux1_div.hw, 809 }, 810 .num_parents = 2, 811 }, 812 }; 813 814 /* Datasheet names this field as "Final_dyn_mux_sel" */ 815 static struct clk_regmap sm1_dsu_clk_dyn = { 816 .data = &(struct clk_regmap_mux_data){ 817 .offset = HHI_SYS_CPU_CLK_CNTL5, 818 .mask = 0x1, 819 .shift = 10, 820 }, 821 .hw.init = &(struct clk_init_data){ 822 .name = "dsu_clk_dyn", 823 .ops = &clk_regmap_mux_ro_ops, 824 .parent_hws = (const struct clk_hw *[]) { 825 &sm1_dsu_clk_postmux0.hw, 826 &sm1_dsu_clk_postmux1.hw, 827 }, 828 .num_parents = 2, 829 }, 830 }; 831 832 /* Datasheet names this field as "Final_mux_sel" */ 833 static struct clk_regmap sm1_dsu_final_clk = { 834 .data = &(struct clk_regmap_mux_data){ 835 .offset = HHI_SYS_CPU_CLK_CNTL5, 836 .mask = 0x1, 837 .shift = 11, 838 }, 839 .hw.init = &(struct clk_init_data){ 840 .name = "dsu_clk_final", 841 .ops = &clk_regmap_mux_ro_ops, 842 .parent_hws = (const struct clk_hw *[]) { 843 &sm1_dsu_clk_dyn.hw, 844 &g12a_sys_pll.hw, 845 }, 846 .num_parents = 2, 847 }, 848 }; 849 850 /* Datasheet names this field as "Cpu_clk_sync_mux_sel" bit 0 */ 851 static struct clk_regmap sm1_cpu1_clk = { 852 .data = &(struct clk_regmap_mux_data){ 853 .offset = HHI_SYS_CPU_CLK_CNTL6, 854 .mask = 0x1, 855 .shift = 24, 856 }, 857 .hw.init = &(struct clk_init_data){ 858 .name = "cpu1_clk", 859 .ops = &clk_regmap_mux_ro_ops, 860 .parent_hws = (const struct clk_hw *[]) { 861 &g12a_cpu_clk.hw, 862 /* This CPU also have a dedicated clock tree */ 863 }, 864 .num_parents = 1, 865 }, 866 }; 867 868 /* Datasheet names this field as "Cpu_clk_sync_mux_sel" bit 1 */ 869 static struct clk_regmap sm1_cpu2_clk = { 870 .data = &(struct clk_regmap_mux_data){ 871 .offset = HHI_SYS_CPU_CLK_CNTL6, 872 .mask = 0x1, 873 .shift = 25, 874 }, 875 .hw.init = &(struct clk_init_data){ 876 .name = "cpu2_clk", 877 .ops = &clk_regmap_mux_ro_ops, 878 .parent_hws = (const struct clk_hw *[]) { 879 &g12a_cpu_clk.hw, 880 /* This CPU also have a dedicated clock tree */ 881 }, 882 .num_parents = 1, 883 }, 884 }; 885 886 /* Datasheet names this field as "Cpu_clk_sync_mux_sel" bit 2 */ 887 static struct clk_regmap sm1_cpu3_clk = { 888 .data = &(struct clk_regmap_mux_data){ 889 .offset = HHI_SYS_CPU_CLK_CNTL6, 890 .mask = 0x1, 891 .shift = 26, 892 }, 893 .hw.init = &(struct clk_init_data){ 894 .name = "cpu3_clk", 895 .ops = &clk_regmap_mux_ro_ops, 896 .parent_hws = (const struct clk_hw *[]) { 897 &g12a_cpu_clk.hw, 898 /* This CPU also have a dedicated clock tree */ 899 }, 900 .num_parents = 1, 901 }, 902 }; 903 904 /* Datasheet names this field as "Cpu_clk_sync_mux_sel" bit 4 */ 905 static struct clk_regmap sm1_dsu_clk = { 906 .data = &(struct clk_regmap_mux_data){ 907 .offset = HHI_SYS_CPU_CLK_CNTL6, 908 .mask = 0x1, 909 .shift = 27, 910 }, 911 .hw.init = &(struct clk_init_data){ 912 .name = "dsu_clk", 913 .ops = &clk_regmap_mux_ro_ops, 914 .parent_hws = (const struct clk_hw *[]) { 915 &g12a_cpu_clk.hw, 916 &sm1_dsu_final_clk.hw, 917 }, 918 .num_parents = 2, 919 }, 920 }; 921 922 static int g12a_cpu_clk_mux_notifier_cb(struct notifier_block *nb, 923 unsigned long event, void *data) 924 { 925 if (event == POST_RATE_CHANGE || event == PRE_RATE_CHANGE) { 926 /* Wait for clock propagation before/after changing the mux */ 927 udelay(100); 928 return NOTIFY_OK; 929 } 930 931 return NOTIFY_DONE; 932 } 933 934 static struct notifier_block g12a_cpu_clk_mux_nb = { 935 .notifier_call = g12a_cpu_clk_mux_notifier_cb, 936 }; 937 938 struct g12a_cpu_clk_postmux_nb_data { 939 struct notifier_block nb; 940 struct clk_hw *xtal; 941 struct clk_hw *cpu_clk_dyn; 942 struct clk_hw *cpu_clk_postmux0; 943 struct clk_hw *cpu_clk_postmux1; 944 struct clk_hw *cpu_clk_premux1; 945 }; 946 947 static int g12a_cpu_clk_postmux_notifier_cb(struct notifier_block *nb, 948 unsigned long event, void *data) 949 { 950 struct g12a_cpu_clk_postmux_nb_data *nb_data = 951 container_of(nb, struct g12a_cpu_clk_postmux_nb_data, nb); 952 953 switch (event) { 954 case PRE_RATE_CHANGE: 955 /* 956 * This notifier means cpu_clk_postmux0 clock will be changed 957 * to feed cpu_clk, this is the current path : 958 * cpu_clk 959 * \- cpu_clk_dyn 960 * \- cpu_clk_postmux0 961 * \- cpu_clk_muxX_div 962 * \- cpu_clk_premux0 963 * \- fclk_div3 or fclk_div2 964 * OR 965 * \- cpu_clk_premux0 966 * \- fclk_div3 or fclk_div2 967 */ 968 969 /* Setup cpu_clk_premux1 to xtal */ 970 clk_hw_set_parent(nb_data->cpu_clk_premux1, 971 nb_data->xtal); 972 973 /* Setup cpu_clk_postmux1 to bypass divider */ 974 clk_hw_set_parent(nb_data->cpu_clk_postmux1, 975 nb_data->cpu_clk_premux1); 976 977 /* Switch to parking clk on cpu_clk_postmux1 */ 978 clk_hw_set_parent(nb_data->cpu_clk_dyn, 979 nb_data->cpu_clk_postmux1); 980 981 /* 982 * Now, cpu_clk is 24MHz in the current path : 983 * cpu_clk 984 * \- cpu_clk_dyn 985 * \- cpu_clk_postmux1 986 * \- cpu_clk_premux1 987 * \- xtal 988 */ 989 990 udelay(100); 991 992 return NOTIFY_OK; 993 994 case POST_RATE_CHANGE: 995 /* 996 * The cpu_clk_postmux0 has ben updated, now switch back 997 * cpu_clk_dyn to cpu_clk_postmux0 and take the changes 998 * in account. 999 */ 1000 1001 /* Configure cpu_clk_dyn back to cpu_clk_postmux0 */ 1002 clk_hw_set_parent(nb_data->cpu_clk_dyn, 1003 nb_data->cpu_clk_postmux0); 1004 1005 /* 1006 * new path : 1007 * cpu_clk 1008 * \- cpu_clk_dyn 1009 * \- cpu_clk_postmux0 1010 * \- cpu_clk_muxX_div 1011 * \- cpu_clk_premux0 1012 * \- fclk_div3 or fclk_div2 1013 * OR 1014 * \- cpu_clk_premux0 1015 * \- fclk_div3 or fclk_div2 1016 */ 1017 1018 udelay(100); 1019 1020 return NOTIFY_OK; 1021 1022 default: 1023 return NOTIFY_DONE; 1024 } 1025 } 1026 1027 static struct g12a_cpu_clk_postmux_nb_data g12a_cpu_clk_postmux0_nb_data = { 1028 .cpu_clk_dyn = &g12a_cpu_clk_dyn.hw, 1029 .cpu_clk_postmux0 = &g12a_cpu_clk_postmux0.hw, 1030 .cpu_clk_postmux1 = &g12a_cpu_clk_postmux1.hw, 1031 .cpu_clk_premux1 = &g12a_cpu_clk_premux1.hw, 1032 .nb.notifier_call = g12a_cpu_clk_postmux_notifier_cb, 1033 }; 1034 1035 static struct g12a_cpu_clk_postmux_nb_data g12b_cpub_clk_postmux0_nb_data = { 1036 .cpu_clk_dyn = &g12b_cpub_clk_dyn.hw, 1037 .cpu_clk_postmux0 = &g12b_cpub_clk_postmux0.hw, 1038 .cpu_clk_postmux1 = &g12b_cpub_clk_postmux1.hw, 1039 .cpu_clk_premux1 = &g12b_cpub_clk_premux1.hw, 1040 .nb.notifier_call = g12a_cpu_clk_postmux_notifier_cb, 1041 }; 1042 1043 struct g12a_sys_pll_nb_data { 1044 struct notifier_block nb; 1045 struct clk_hw *sys_pll; 1046 struct clk_hw *cpu_clk; 1047 struct clk_hw *cpu_clk_dyn; 1048 }; 1049 1050 static int g12a_sys_pll_notifier_cb(struct notifier_block *nb, 1051 unsigned long event, void *data) 1052 { 1053 struct g12a_sys_pll_nb_data *nb_data = 1054 container_of(nb, struct g12a_sys_pll_nb_data, nb); 1055 1056 switch (event) { 1057 case PRE_RATE_CHANGE: 1058 /* 1059 * This notifier means sys_pll clock will be changed 1060 * to feed cpu_clk, this the current path : 1061 * cpu_clk 1062 * \- sys_pll 1063 * \- sys_pll_dco 1064 */ 1065 1066 /* Configure cpu_clk to use cpu_clk_dyn */ 1067 clk_hw_set_parent(nb_data->cpu_clk, 1068 nb_data->cpu_clk_dyn); 1069 1070 /* 1071 * Now, cpu_clk uses the dyn path 1072 * cpu_clk 1073 * \- cpu_clk_dyn 1074 * \- cpu_clk_dynX 1075 * \- cpu_clk_dynX_sel 1076 * \- cpu_clk_dynX_div 1077 * \- xtal/fclk_div2/fclk_div3 1078 * \- xtal/fclk_div2/fclk_div3 1079 */ 1080 1081 udelay(100); 1082 1083 return NOTIFY_OK; 1084 1085 case POST_RATE_CHANGE: 1086 /* 1087 * The sys_pll has ben updated, now switch back cpu_clk to 1088 * sys_pll 1089 */ 1090 1091 /* Configure cpu_clk to use sys_pll */ 1092 clk_hw_set_parent(nb_data->cpu_clk, 1093 nb_data->sys_pll); 1094 1095 udelay(100); 1096 1097 /* new path : 1098 * cpu_clk 1099 * \- sys_pll 1100 * \- sys_pll_dco 1101 */ 1102 1103 return NOTIFY_OK; 1104 1105 default: 1106 return NOTIFY_DONE; 1107 } 1108 } 1109 1110 static struct g12a_sys_pll_nb_data g12a_sys_pll_nb_data = { 1111 .sys_pll = &g12a_sys_pll.hw, 1112 .cpu_clk = &g12a_cpu_clk.hw, 1113 .cpu_clk_dyn = &g12a_cpu_clk_dyn.hw, 1114 .nb.notifier_call = g12a_sys_pll_notifier_cb, 1115 }; 1116 1117 /* G12B first CPU cluster uses sys1_pll */ 1118 static struct g12a_sys_pll_nb_data g12b_cpu_clk_sys1_pll_nb_data = { 1119 .sys_pll = &g12b_sys1_pll.hw, 1120 .cpu_clk = &g12b_cpu_clk.hw, 1121 .cpu_clk_dyn = &g12a_cpu_clk_dyn.hw, 1122 .nb.notifier_call = g12a_sys_pll_notifier_cb, 1123 }; 1124 1125 /* G12B second CPU cluster uses sys_pll */ 1126 static struct g12a_sys_pll_nb_data g12b_cpub_clk_sys_pll_nb_data = { 1127 .sys_pll = &g12a_sys_pll.hw, 1128 .cpu_clk = &g12b_cpub_clk.hw, 1129 .cpu_clk_dyn = &g12b_cpub_clk_dyn.hw, 1130 .nb.notifier_call = g12a_sys_pll_notifier_cb, 1131 }; 1132 1133 static struct clk_regmap g12a_cpu_clk_div16_en = { 1134 .data = &(struct clk_regmap_gate_data){ 1135 .offset = HHI_SYS_CPU_CLK_CNTL1, 1136 .bit_idx = 1, 1137 }, 1138 .hw.init = &(struct clk_init_data) { 1139 .name = "cpu_clk_div16_en", 1140 .ops = &clk_regmap_gate_ro_ops, 1141 .parent_hws = (const struct clk_hw *[]) { 1142 &g12a_cpu_clk.hw 1143 }, 1144 .num_parents = 1, 1145 /* 1146 * This clock is used to debug the cpu_clk range 1147 * Linux should not change it at runtime 1148 */ 1149 }, 1150 }; 1151 1152 static struct clk_regmap g12b_cpub_clk_div16_en = { 1153 .data = &(struct clk_regmap_gate_data){ 1154 .offset = HHI_SYS_CPUB_CLK_CNTL1, 1155 .bit_idx = 1, 1156 }, 1157 .hw.init = &(struct clk_init_data) { 1158 .name = "cpub_clk_div16_en", 1159 .ops = &clk_regmap_gate_ro_ops, 1160 .parent_hws = (const struct clk_hw *[]) { 1161 &g12b_cpub_clk.hw 1162 }, 1163 .num_parents = 1, 1164 /* 1165 * This clock is used to debug the cpu_clk range 1166 * Linux should not change it at runtime 1167 */ 1168 }, 1169 }; 1170 1171 static struct clk_fixed_factor g12a_cpu_clk_div16 = { 1172 .mult = 1, 1173 .div = 16, 1174 .hw.init = &(struct clk_init_data){ 1175 .name = "cpu_clk_div16", 1176 .ops = &clk_fixed_factor_ops, 1177 .parent_hws = (const struct clk_hw *[]) { 1178 &g12a_cpu_clk_div16_en.hw 1179 }, 1180 .num_parents = 1, 1181 }, 1182 }; 1183 1184 static struct clk_fixed_factor g12b_cpub_clk_div16 = { 1185 .mult = 1, 1186 .div = 16, 1187 .hw.init = &(struct clk_init_data){ 1188 .name = "cpub_clk_div16", 1189 .ops = &clk_fixed_factor_ops, 1190 .parent_hws = (const struct clk_hw *[]) { 1191 &g12b_cpub_clk_div16_en.hw 1192 }, 1193 .num_parents = 1, 1194 }, 1195 }; 1196 1197 static struct clk_regmap g12a_cpu_clk_apb_div = { 1198 .data = &(struct clk_regmap_div_data){ 1199 .offset = HHI_SYS_CPU_CLK_CNTL1, 1200 .shift = 3, 1201 .width = 3, 1202 .flags = CLK_DIVIDER_POWER_OF_TWO, 1203 }, 1204 .hw.init = &(struct clk_init_data){ 1205 .name = "cpu_clk_apb_div", 1206 .ops = &clk_regmap_divider_ro_ops, 1207 .parent_hws = (const struct clk_hw *[]) { &g12a_cpu_clk.hw }, 1208 .num_parents = 1, 1209 }, 1210 }; 1211 1212 static struct clk_regmap g12a_cpu_clk_apb = { 1213 .data = &(struct clk_regmap_gate_data){ 1214 .offset = HHI_SYS_CPU_CLK_CNTL1, 1215 .bit_idx = 1, 1216 }, 1217 .hw.init = &(struct clk_init_data) { 1218 .name = "cpu_clk_apb", 1219 .ops = &clk_regmap_gate_ro_ops, 1220 .parent_hws = (const struct clk_hw *[]) { 1221 &g12a_cpu_clk_apb_div.hw 1222 }, 1223 .num_parents = 1, 1224 /* 1225 * This clock is set by the ROM monitor code, 1226 * Linux should not change it at runtime 1227 */ 1228 }, 1229 }; 1230 1231 static struct clk_regmap g12a_cpu_clk_atb_div = { 1232 .data = &(struct clk_regmap_div_data){ 1233 .offset = HHI_SYS_CPU_CLK_CNTL1, 1234 .shift = 6, 1235 .width = 3, 1236 .flags = CLK_DIVIDER_POWER_OF_TWO, 1237 }, 1238 .hw.init = &(struct clk_init_data){ 1239 .name = "cpu_clk_atb_div", 1240 .ops = &clk_regmap_divider_ro_ops, 1241 .parent_hws = (const struct clk_hw *[]) { &g12a_cpu_clk.hw }, 1242 .num_parents = 1, 1243 }, 1244 }; 1245 1246 static struct clk_regmap g12a_cpu_clk_atb = { 1247 .data = &(struct clk_regmap_gate_data){ 1248 .offset = HHI_SYS_CPU_CLK_CNTL1, 1249 .bit_idx = 17, 1250 }, 1251 .hw.init = &(struct clk_init_data) { 1252 .name = "cpu_clk_atb", 1253 .ops = &clk_regmap_gate_ro_ops, 1254 .parent_hws = (const struct clk_hw *[]) { 1255 &g12a_cpu_clk_atb_div.hw 1256 }, 1257 .num_parents = 1, 1258 /* 1259 * This clock is set by the ROM monitor code, 1260 * Linux should not change it at runtime 1261 */ 1262 }, 1263 }; 1264 1265 static struct clk_regmap g12a_cpu_clk_axi_div = { 1266 .data = &(struct clk_regmap_div_data){ 1267 .offset = HHI_SYS_CPU_CLK_CNTL1, 1268 .shift = 9, 1269 .width = 3, 1270 .flags = CLK_DIVIDER_POWER_OF_TWO, 1271 }, 1272 .hw.init = &(struct clk_init_data){ 1273 .name = "cpu_clk_axi_div", 1274 .ops = &clk_regmap_divider_ro_ops, 1275 .parent_hws = (const struct clk_hw *[]) { &g12a_cpu_clk.hw }, 1276 .num_parents = 1, 1277 }, 1278 }; 1279 1280 static struct clk_regmap g12a_cpu_clk_axi = { 1281 .data = &(struct clk_regmap_gate_data){ 1282 .offset = HHI_SYS_CPU_CLK_CNTL1, 1283 .bit_idx = 18, 1284 }, 1285 .hw.init = &(struct clk_init_data) { 1286 .name = "cpu_clk_axi", 1287 .ops = &clk_regmap_gate_ro_ops, 1288 .parent_hws = (const struct clk_hw *[]) { 1289 &g12a_cpu_clk_axi_div.hw 1290 }, 1291 .num_parents = 1, 1292 /* 1293 * This clock is set by the ROM monitor code, 1294 * Linux should not change it at runtime 1295 */ 1296 }, 1297 }; 1298 1299 static struct clk_regmap g12a_cpu_clk_trace_div = { 1300 .data = &(struct clk_regmap_div_data){ 1301 .offset = HHI_SYS_CPU_CLK_CNTL1, 1302 .shift = 20, 1303 .width = 3, 1304 .flags = CLK_DIVIDER_POWER_OF_TWO, 1305 }, 1306 .hw.init = &(struct clk_init_data){ 1307 .name = "cpu_clk_trace_div", 1308 .ops = &clk_regmap_divider_ro_ops, 1309 .parent_data = &(const struct clk_parent_data) { 1310 /* 1311 * Note: 1312 * G12A and G12B have different cpu_clks (with 1313 * different struct clk_hw). We fallback to the global 1314 * naming string mechanism so cpu_clk_trace_div picks 1315 * up the appropriate one. 1316 */ 1317 .name = "cpu_clk", 1318 .index = -1, 1319 }, 1320 .num_parents = 1, 1321 }, 1322 }; 1323 1324 static struct clk_regmap g12a_cpu_clk_trace = { 1325 .data = &(struct clk_regmap_gate_data){ 1326 .offset = HHI_SYS_CPU_CLK_CNTL1, 1327 .bit_idx = 23, 1328 }, 1329 .hw.init = &(struct clk_init_data) { 1330 .name = "cpu_clk_trace", 1331 .ops = &clk_regmap_gate_ro_ops, 1332 .parent_hws = (const struct clk_hw *[]) { 1333 &g12a_cpu_clk_trace_div.hw 1334 }, 1335 .num_parents = 1, 1336 /* 1337 * This clock is set by the ROM monitor code, 1338 * Linux should not change it at runtime 1339 */ 1340 }, 1341 }; 1342 1343 static struct clk_fixed_factor g12b_cpub_clk_div2 = { 1344 .mult = 1, 1345 .div = 2, 1346 .hw.init = &(struct clk_init_data){ 1347 .name = "cpub_clk_div2", 1348 .ops = &clk_fixed_factor_ops, 1349 .parent_hws = (const struct clk_hw *[]) { 1350 &g12b_cpub_clk.hw 1351 }, 1352 .num_parents = 1, 1353 }, 1354 }; 1355 1356 static struct clk_fixed_factor g12b_cpub_clk_div3 = { 1357 .mult = 1, 1358 .div = 3, 1359 .hw.init = &(struct clk_init_data){ 1360 .name = "cpub_clk_div3", 1361 .ops = &clk_fixed_factor_ops, 1362 .parent_hws = (const struct clk_hw *[]) { 1363 &g12b_cpub_clk.hw 1364 }, 1365 .num_parents = 1, 1366 }, 1367 }; 1368 1369 static struct clk_fixed_factor g12b_cpub_clk_div4 = { 1370 .mult = 1, 1371 .div = 4, 1372 .hw.init = &(struct clk_init_data){ 1373 .name = "cpub_clk_div4", 1374 .ops = &clk_fixed_factor_ops, 1375 .parent_hws = (const struct clk_hw *[]) { 1376 &g12b_cpub_clk.hw 1377 }, 1378 .num_parents = 1, 1379 }, 1380 }; 1381 1382 static struct clk_fixed_factor g12b_cpub_clk_div5 = { 1383 .mult = 1, 1384 .div = 5, 1385 .hw.init = &(struct clk_init_data){ 1386 .name = "cpub_clk_div5", 1387 .ops = &clk_fixed_factor_ops, 1388 .parent_hws = (const struct clk_hw *[]) { 1389 &g12b_cpub_clk.hw 1390 }, 1391 .num_parents = 1, 1392 }, 1393 }; 1394 1395 static struct clk_fixed_factor g12b_cpub_clk_div6 = { 1396 .mult = 1, 1397 .div = 6, 1398 .hw.init = &(struct clk_init_data){ 1399 .name = "cpub_clk_div6", 1400 .ops = &clk_fixed_factor_ops, 1401 .parent_hws = (const struct clk_hw *[]) { 1402 &g12b_cpub_clk.hw 1403 }, 1404 .num_parents = 1, 1405 }, 1406 }; 1407 1408 static struct clk_fixed_factor g12b_cpub_clk_div7 = { 1409 .mult = 1, 1410 .div = 7, 1411 .hw.init = &(struct clk_init_data){ 1412 .name = "cpub_clk_div7", 1413 .ops = &clk_fixed_factor_ops, 1414 .parent_hws = (const struct clk_hw *[]) { 1415 &g12b_cpub_clk.hw 1416 }, 1417 .num_parents = 1, 1418 }, 1419 }; 1420 1421 static struct clk_fixed_factor g12b_cpub_clk_div8 = { 1422 .mult = 1, 1423 .div = 8, 1424 .hw.init = &(struct clk_init_data){ 1425 .name = "cpub_clk_div8", 1426 .ops = &clk_fixed_factor_ops, 1427 .parent_hws = (const struct clk_hw *[]) { 1428 &g12b_cpub_clk.hw 1429 }, 1430 .num_parents = 1, 1431 }, 1432 }; 1433 1434 static u32 mux_table_cpub[] = { 1, 2, 3, 4, 5, 6, 7 }; 1435 static struct clk_regmap g12b_cpub_clk_apb_sel = { 1436 .data = &(struct clk_regmap_mux_data){ 1437 .offset = HHI_SYS_CPUB_CLK_CNTL1, 1438 .mask = 7, 1439 .shift = 3, 1440 .table = mux_table_cpub, 1441 }, 1442 .hw.init = &(struct clk_init_data){ 1443 .name = "cpub_clk_apb_sel", 1444 .ops = &clk_regmap_mux_ro_ops, 1445 .parent_hws = (const struct clk_hw *[]) { 1446 &g12b_cpub_clk_div2.hw, 1447 &g12b_cpub_clk_div3.hw, 1448 &g12b_cpub_clk_div4.hw, 1449 &g12b_cpub_clk_div5.hw, 1450 &g12b_cpub_clk_div6.hw, 1451 &g12b_cpub_clk_div7.hw, 1452 &g12b_cpub_clk_div8.hw 1453 }, 1454 .num_parents = 7, 1455 }, 1456 }; 1457 1458 static struct clk_regmap g12b_cpub_clk_apb = { 1459 .data = &(struct clk_regmap_gate_data){ 1460 .offset = HHI_SYS_CPUB_CLK_CNTL1, 1461 .bit_idx = 16, 1462 .flags = CLK_GATE_SET_TO_DISABLE, 1463 }, 1464 .hw.init = &(struct clk_init_data) { 1465 .name = "cpub_clk_apb", 1466 .ops = &clk_regmap_gate_ro_ops, 1467 .parent_hws = (const struct clk_hw *[]) { 1468 &g12b_cpub_clk_apb_sel.hw 1469 }, 1470 .num_parents = 1, 1471 /* 1472 * This clock is set by the ROM monitor code, 1473 * Linux should not change it at runtime 1474 */ 1475 }, 1476 }; 1477 1478 static struct clk_regmap g12b_cpub_clk_atb_sel = { 1479 .data = &(struct clk_regmap_mux_data){ 1480 .offset = HHI_SYS_CPUB_CLK_CNTL1, 1481 .mask = 7, 1482 .shift = 6, 1483 .table = mux_table_cpub, 1484 }, 1485 .hw.init = &(struct clk_init_data){ 1486 .name = "cpub_clk_atb_sel", 1487 .ops = &clk_regmap_mux_ro_ops, 1488 .parent_hws = (const struct clk_hw *[]) { 1489 &g12b_cpub_clk_div2.hw, 1490 &g12b_cpub_clk_div3.hw, 1491 &g12b_cpub_clk_div4.hw, 1492 &g12b_cpub_clk_div5.hw, 1493 &g12b_cpub_clk_div6.hw, 1494 &g12b_cpub_clk_div7.hw, 1495 &g12b_cpub_clk_div8.hw 1496 }, 1497 .num_parents = 7, 1498 }, 1499 }; 1500 1501 static struct clk_regmap g12b_cpub_clk_atb = { 1502 .data = &(struct clk_regmap_gate_data){ 1503 .offset = HHI_SYS_CPUB_CLK_CNTL1, 1504 .bit_idx = 17, 1505 .flags = CLK_GATE_SET_TO_DISABLE, 1506 }, 1507 .hw.init = &(struct clk_init_data) { 1508 .name = "cpub_clk_atb", 1509 .ops = &clk_regmap_gate_ro_ops, 1510 .parent_hws = (const struct clk_hw *[]) { 1511 &g12b_cpub_clk_atb_sel.hw 1512 }, 1513 .num_parents = 1, 1514 /* 1515 * This clock is set by the ROM monitor code, 1516 * Linux should not change it at runtime 1517 */ 1518 }, 1519 }; 1520 1521 static struct clk_regmap g12b_cpub_clk_axi_sel = { 1522 .data = &(struct clk_regmap_mux_data){ 1523 .offset = HHI_SYS_CPUB_CLK_CNTL1, 1524 .mask = 7, 1525 .shift = 9, 1526 .table = mux_table_cpub, 1527 }, 1528 .hw.init = &(struct clk_init_data){ 1529 .name = "cpub_clk_axi_sel", 1530 .ops = &clk_regmap_mux_ro_ops, 1531 .parent_hws = (const struct clk_hw *[]) { 1532 &g12b_cpub_clk_div2.hw, 1533 &g12b_cpub_clk_div3.hw, 1534 &g12b_cpub_clk_div4.hw, 1535 &g12b_cpub_clk_div5.hw, 1536 &g12b_cpub_clk_div6.hw, 1537 &g12b_cpub_clk_div7.hw, 1538 &g12b_cpub_clk_div8.hw 1539 }, 1540 .num_parents = 7, 1541 }, 1542 }; 1543 1544 static struct clk_regmap g12b_cpub_clk_axi = { 1545 .data = &(struct clk_regmap_gate_data){ 1546 .offset = HHI_SYS_CPUB_CLK_CNTL1, 1547 .bit_idx = 18, 1548 .flags = CLK_GATE_SET_TO_DISABLE, 1549 }, 1550 .hw.init = &(struct clk_init_data) { 1551 .name = "cpub_clk_axi", 1552 .ops = &clk_regmap_gate_ro_ops, 1553 .parent_hws = (const struct clk_hw *[]) { 1554 &g12b_cpub_clk_axi_sel.hw 1555 }, 1556 .num_parents = 1, 1557 /* 1558 * This clock is set by the ROM monitor code, 1559 * Linux should not change it at runtime 1560 */ 1561 }, 1562 }; 1563 1564 static struct clk_regmap g12b_cpub_clk_trace_sel = { 1565 .data = &(struct clk_regmap_mux_data){ 1566 .offset = HHI_SYS_CPUB_CLK_CNTL1, 1567 .mask = 7, 1568 .shift = 20, 1569 .table = mux_table_cpub, 1570 }, 1571 .hw.init = &(struct clk_init_data){ 1572 .name = "cpub_clk_trace_sel", 1573 .ops = &clk_regmap_mux_ro_ops, 1574 .parent_hws = (const struct clk_hw *[]) { 1575 &g12b_cpub_clk_div2.hw, 1576 &g12b_cpub_clk_div3.hw, 1577 &g12b_cpub_clk_div4.hw, 1578 &g12b_cpub_clk_div5.hw, 1579 &g12b_cpub_clk_div6.hw, 1580 &g12b_cpub_clk_div7.hw, 1581 &g12b_cpub_clk_div8.hw 1582 }, 1583 .num_parents = 7, 1584 }, 1585 }; 1586 1587 static struct clk_regmap g12b_cpub_clk_trace = { 1588 .data = &(struct clk_regmap_gate_data){ 1589 .offset = HHI_SYS_CPUB_CLK_CNTL1, 1590 .bit_idx = 23, 1591 .flags = CLK_GATE_SET_TO_DISABLE, 1592 }, 1593 .hw.init = &(struct clk_init_data) { 1594 .name = "cpub_clk_trace", 1595 .ops = &clk_regmap_gate_ro_ops, 1596 .parent_hws = (const struct clk_hw *[]) { 1597 &g12b_cpub_clk_trace_sel.hw 1598 }, 1599 .num_parents = 1, 1600 /* 1601 * This clock is set by the ROM monitor code, 1602 * Linux should not change it at runtime 1603 */ 1604 }, 1605 }; 1606 1607 static const struct pll_mult_range g12a_gp0_pll_mult_range = { 1608 .min = 125, 1609 .max = 255, 1610 }; 1611 1612 /* 1613 * Internal gp0 pll emulation configuration parameters 1614 */ 1615 static const struct reg_sequence g12a_gp0_init_regs[] = { 1616 { .reg = HHI_GP0_PLL_CNTL1, .def = 0x00000000 }, 1617 { .reg = HHI_GP0_PLL_CNTL2, .def = 0x00000000 }, 1618 { .reg = HHI_GP0_PLL_CNTL3, .def = 0x48681c00 }, 1619 { .reg = HHI_GP0_PLL_CNTL4, .def = 0x33771290 }, 1620 { .reg = HHI_GP0_PLL_CNTL5, .def = 0x39272000 }, 1621 { .reg = HHI_GP0_PLL_CNTL6, .def = 0x56540000 }, 1622 }; 1623 1624 static struct clk_regmap g12a_gp0_pll_dco = { 1625 .data = &(struct meson_clk_pll_data){ 1626 .en = { 1627 .reg_off = HHI_GP0_PLL_CNTL0, 1628 .shift = 28, 1629 .width = 1, 1630 }, 1631 .m = { 1632 .reg_off = HHI_GP0_PLL_CNTL0, 1633 .shift = 0, 1634 .width = 8, 1635 }, 1636 .n = { 1637 .reg_off = HHI_GP0_PLL_CNTL0, 1638 .shift = 10, 1639 .width = 5, 1640 }, 1641 .frac = { 1642 .reg_off = HHI_GP0_PLL_CNTL1, 1643 .shift = 0, 1644 .width = 17, 1645 }, 1646 .l = { 1647 .reg_off = HHI_GP0_PLL_CNTL0, 1648 .shift = 31, 1649 .width = 1, 1650 }, 1651 .rst = { 1652 .reg_off = HHI_GP0_PLL_CNTL0, 1653 .shift = 29, 1654 .width = 1, 1655 }, 1656 .range = &g12a_gp0_pll_mult_range, 1657 .init_regs = g12a_gp0_init_regs, 1658 .init_count = ARRAY_SIZE(g12a_gp0_init_regs), 1659 }, 1660 .hw.init = &(struct clk_init_data){ 1661 .name = "gp0_pll_dco", 1662 .ops = &meson_clk_pll_ops, 1663 .parent_data = &(const struct clk_parent_data) { 1664 .fw_name = "xtal", 1665 }, 1666 .num_parents = 1, 1667 }, 1668 }; 1669 1670 static struct clk_regmap g12a_gp0_pll = { 1671 .data = &(struct clk_regmap_div_data){ 1672 .offset = HHI_GP0_PLL_CNTL0, 1673 .shift = 16, 1674 .width = 3, 1675 .flags = (CLK_DIVIDER_POWER_OF_TWO | 1676 CLK_DIVIDER_ROUND_CLOSEST), 1677 }, 1678 .hw.init = &(struct clk_init_data){ 1679 .name = "gp0_pll", 1680 .ops = &clk_regmap_divider_ops, 1681 .parent_hws = (const struct clk_hw *[]) { 1682 &g12a_gp0_pll_dco.hw 1683 }, 1684 .num_parents = 1, 1685 .flags = CLK_SET_RATE_PARENT, 1686 }, 1687 }; 1688 1689 static struct clk_regmap sm1_gp1_pll_dco = { 1690 .data = &(struct meson_clk_pll_data){ 1691 .en = { 1692 .reg_off = HHI_GP1_PLL_CNTL0, 1693 .shift = 28, 1694 .width = 1, 1695 }, 1696 .m = { 1697 .reg_off = HHI_GP1_PLL_CNTL0, 1698 .shift = 0, 1699 .width = 8, 1700 }, 1701 .n = { 1702 .reg_off = HHI_GP1_PLL_CNTL0, 1703 .shift = 10, 1704 .width = 5, 1705 }, 1706 .frac = { 1707 .reg_off = HHI_GP1_PLL_CNTL1, 1708 .shift = 0, 1709 .width = 17, 1710 }, 1711 .l = { 1712 .reg_off = HHI_GP1_PLL_CNTL0, 1713 .shift = 31, 1714 .width = 1, 1715 }, 1716 .rst = { 1717 .reg_off = HHI_GP1_PLL_CNTL0, 1718 .shift = 29, 1719 .width = 1, 1720 }, 1721 }, 1722 .hw.init = &(struct clk_init_data){ 1723 .name = "gp1_pll_dco", 1724 .ops = &meson_clk_pll_ro_ops, 1725 .parent_data = &(const struct clk_parent_data) { 1726 .fw_name = "xtal", 1727 }, 1728 .num_parents = 1, 1729 /* This clock feeds the DSU, avoid disabling it */ 1730 .flags = CLK_IS_CRITICAL, 1731 }, 1732 }; 1733 1734 static struct clk_regmap sm1_gp1_pll = { 1735 .data = &(struct clk_regmap_div_data){ 1736 .offset = HHI_GP1_PLL_CNTL0, 1737 .shift = 16, 1738 .width = 3, 1739 .flags = (CLK_DIVIDER_POWER_OF_TWO | 1740 CLK_DIVIDER_ROUND_CLOSEST), 1741 }, 1742 .hw.init = &(struct clk_init_data){ 1743 .name = "gp1_pll", 1744 .ops = &clk_regmap_divider_ro_ops, 1745 .parent_hws = (const struct clk_hw *[]) { 1746 &sm1_gp1_pll_dco.hw 1747 }, 1748 .num_parents = 1, 1749 }, 1750 }; 1751 1752 /* 1753 * Internal hifi pll emulation configuration parameters 1754 */ 1755 static const struct reg_sequence g12a_hifi_init_regs[] = { 1756 { .reg = HHI_HIFI_PLL_CNTL1, .def = 0x00000000 }, 1757 { .reg = HHI_HIFI_PLL_CNTL2, .def = 0x00000000 }, 1758 { .reg = HHI_HIFI_PLL_CNTL3, .def = 0x6a285c00 }, 1759 { .reg = HHI_HIFI_PLL_CNTL4, .def = 0x65771290 }, 1760 { .reg = HHI_HIFI_PLL_CNTL5, .def = 0x39272000 }, 1761 { .reg = HHI_HIFI_PLL_CNTL6, .def = 0x56540000 }, 1762 }; 1763 1764 static struct clk_regmap g12a_hifi_pll_dco = { 1765 .data = &(struct meson_clk_pll_data){ 1766 .en = { 1767 .reg_off = HHI_HIFI_PLL_CNTL0, 1768 .shift = 28, 1769 .width = 1, 1770 }, 1771 .m = { 1772 .reg_off = HHI_HIFI_PLL_CNTL0, 1773 .shift = 0, 1774 .width = 8, 1775 }, 1776 .n = { 1777 .reg_off = HHI_HIFI_PLL_CNTL0, 1778 .shift = 10, 1779 .width = 5, 1780 }, 1781 .frac = { 1782 .reg_off = HHI_HIFI_PLL_CNTL1, 1783 .shift = 0, 1784 .width = 17, 1785 }, 1786 .l = { 1787 .reg_off = HHI_HIFI_PLL_CNTL0, 1788 .shift = 31, 1789 .width = 1, 1790 }, 1791 .rst = { 1792 .reg_off = HHI_HIFI_PLL_CNTL0, 1793 .shift = 29, 1794 .width = 1, 1795 }, 1796 .range = &g12a_gp0_pll_mult_range, 1797 .init_regs = g12a_hifi_init_regs, 1798 .init_count = ARRAY_SIZE(g12a_hifi_init_regs), 1799 .flags = CLK_MESON_PLL_ROUND_CLOSEST, 1800 }, 1801 .hw.init = &(struct clk_init_data){ 1802 .name = "hifi_pll_dco", 1803 .ops = &meson_clk_pll_ops, 1804 .parent_data = &(const struct clk_parent_data) { 1805 .fw_name = "xtal", 1806 }, 1807 .num_parents = 1, 1808 }, 1809 }; 1810 1811 static struct clk_regmap g12a_hifi_pll = { 1812 .data = &(struct clk_regmap_div_data){ 1813 .offset = HHI_HIFI_PLL_CNTL0, 1814 .shift = 16, 1815 .width = 2, 1816 .flags = (CLK_DIVIDER_POWER_OF_TWO | 1817 CLK_DIVIDER_ROUND_CLOSEST), 1818 }, 1819 .hw.init = &(struct clk_init_data){ 1820 .name = "hifi_pll", 1821 .ops = &clk_regmap_divider_ops, 1822 .parent_hws = (const struct clk_hw *[]) { 1823 &g12a_hifi_pll_dco.hw 1824 }, 1825 .num_parents = 1, 1826 .flags = CLK_SET_RATE_PARENT, 1827 }, 1828 }; 1829 1830 /* 1831 * The Meson G12A PCIE PLL is fined tuned to deliver a very precise 1832 * 100MHz reference clock for the PCIe Analog PHY, and thus requires 1833 * a strict register sequence to enable the PLL. 1834 */ 1835 static const struct reg_sequence g12a_pcie_pll_init_regs[] = { 1836 { .reg = HHI_PCIE_PLL_CNTL0, .def = 0x20090496 }, 1837 { .reg = HHI_PCIE_PLL_CNTL0, .def = 0x30090496 }, 1838 { .reg = HHI_PCIE_PLL_CNTL1, .def = 0x00000000 }, 1839 { .reg = HHI_PCIE_PLL_CNTL2, .def = 0x00001100 }, 1840 { .reg = HHI_PCIE_PLL_CNTL3, .def = 0x10058e00 }, 1841 { .reg = HHI_PCIE_PLL_CNTL4, .def = 0x000100c0 }, 1842 { .reg = HHI_PCIE_PLL_CNTL5, .def = 0x68000048 }, 1843 { .reg = HHI_PCIE_PLL_CNTL5, .def = 0x68000068, .delay_us = 20 }, 1844 { .reg = HHI_PCIE_PLL_CNTL4, .def = 0x008100c0, .delay_us = 10 }, 1845 { .reg = HHI_PCIE_PLL_CNTL0, .def = 0x34090496 }, 1846 { .reg = HHI_PCIE_PLL_CNTL0, .def = 0x14090496, .delay_us = 10 }, 1847 { .reg = HHI_PCIE_PLL_CNTL2, .def = 0x00001000 }, 1848 }; 1849 1850 /* Keep a single entry table for recalc/round_rate() ops */ 1851 static const struct pll_params_table g12a_pcie_pll_table[] = { 1852 PLL_PARAMS(150, 1), 1853 {0, 0}, 1854 }; 1855 1856 static struct clk_regmap g12a_pcie_pll_dco = { 1857 .data = &(struct meson_clk_pll_data){ 1858 .en = { 1859 .reg_off = HHI_PCIE_PLL_CNTL0, 1860 .shift = 28, 1861 .width = 1, 1862 }, 1863 .m = { 1864 .reg_off = HHI_PCIE_PLL_CNTL0, 1865 .shift = 0, 1866 .width = 8, 1867 }, 1868 .n = { 1869 .reg_off = HHI_PCIE_PLL_CNTL0, 1870 .shift = 10, 1871 .width = 5, 1872 }, 1873 .frac = { 1874 .reg_off = HHI_PCIE_PLL_CNTL1, 1875 .shift = 0, 1876 .width = 12, 1877 }, 1878 .l = { 1879 .reg_off = HHI_PCIE_PLL_CNTL0, 1880 .shift = 31, 1881 .width = 1, 1882 }, 1883 .rst = { 1884 .reg_off = HHI_PCIE_PLL_CNTL0, 1885 .shift = 29, 1886 .width = 1, 1887 }, 1888 .table = g12a_pcie_pll_table, 1889 .init_regs = g12a_pcie_pll_init_regs, 1890 .init_count = ARRAY_SIZE(g12a_pcie_pll_init_regs), 1891 }, 1892 .hw.init = &(struct clk_init_data){ 1893 .name = "pcie_pll_dco", 1894 .ops = &meson_clk_pcie_pll_ops, 1895 .parent_data = &(const struct clk_parent_data) { 1896 .fw_name = "xtal", 1897 }, 1898 .num_parents = 1, 1899 }, 1900 }; 1901 1902 static struct clk_fixed_factor g12a_pcie_pll_dco_div2 = { 1903 .mult = 1, 1904 .div = 2, 1905 .hw.init = &(struct clk_init_data){ 1906 .name = "pcie_pll_dco_div2", 1907 .ops = &clk_fixed_factor_ops, 1908 .parent_hws = (const struct clk_hw *[]) { 1909 &g12a_pcie_pll_dco.hw 1910 }, 1911 .num_parents = 1, 1912 .flags = CLK_SET_RATE_PARENT, 1913 }, 1914 }; 1915 1916 static struct clk_regmap g12a_pcie_pll_od = { 1917 .data = &(struct clk_regmap_div_data){ 1918 .offset = HHI_PCIE_PLL_CNTL0, 1919 .shift = 16, 1920 .width = 5, 1921 .flags = CLK_DIVIDER_ROUND_CLOSEST | 1922 CLK_DIVIDER_ONE_BASED | 1923 CLK_DIVIDER_ALLOW_ZERO, 1924 }, 1925 .hw.init = &(struct clk_init_data){ 1926 .name = "pcie_pll_od", 1927 .ops = &clk_regmap_divider_ops, 1928 .parent_hws = (const struct clk_hw *[]) { 1929 &g12a_pcie_pll_dco_div2.hw 1930 }, 1931 .num_parents = 1, 1932 .flags = CLK_SET_RATE_PARENT, 1933 }, 1934 }; 1935 1936 static struct clk_fixed_factor g12a_pcie_pll = { 1937 .mult = 1, 1938 .div = 2, 1939 .hw.init = &(struct clk_init_data){ 1940 .name = "pcie_pll_pll", 1941 .ops = &clk_fixed_factor_ops, 1942 .parent_hws = (const struct clk_hw *[]) { 1943 &g12a_pcie_pll_od.hw 1944 }, 1945 .num_parents = 1, 1946 .flags = CLK_SET_RATE_PARENT, 1947 }, 1948 }; 1949 1950 static struct clk_regmap g12a_hdmi_pll_dco = { 1951 .data = &(struct meson_clk_pll_data){ 1952 .en = { 1953 .reg_off = HHI_HDMI_PLL_CNTL0, 1954 .shift = 28, 1955 .width = 1, 1956 }, 1957 .m = { 1958 .reg_off = HHI_HDMI_PLL_CNTL0, 1959 .shift = 0, 1960 .width = 8, 1961 }, 1962 .n = { 1963 .reg_off = HHI_HDMI_PLL_CNTL0, 1964 .shift = 10, 1965 .width = 5, 1966 }, 1967 .frac = { 1968 .reg_off = HHI_HDMI_PLL_CNTL1, 1969 .shift = 0, 1970 .width = 16, 1971 }, 1972 .l = { 1973 .reg_off = HHI_HDMI_PLL_CNTL0, 1974 .shift = 30, 1975 .width = 1, 1976 }, 1977 .rst = { 1978 .reg_off = HHI_HDMI_PLL_CNTL0, 1979 .shift = 29, 1980 .width = 1, 1981 }, 1982 }, 1983 .hw.init = &(struct clk_init_data){ 1984 .name = "hdmi_pll_dco", 1985 .ops = &meson_clk_pll_ro_ops, 1986 .parent_data = &(const struct clk_parent_data) { 1987 .fw_name = "xtal", 1988 }, 1989 .num_parents = 1, 1990 /* 1991 * Display directly handle hdmi pll registers ATM, we need 1992 * NOCACHE to keep our view of the clock as accurate as possible 1993 */ 1994 .flags = CLK_GET_RATE_NOCACHE, 1995 }, 1996 }; 1997 1998 static struct clk_regmap g12a_hdmi_pll_od = { 1999 .data = &(struct clk_regmap_div_data){ 2000 .offset = HHI_HDMI_PLL_CNTL0, 2001 .shift = 16, 2002 .width = 2, 2003 .flags = CLK_DIVIDER_POWER_OF_TWO, 2004 }, 2005 .hw.init = &(struct clk_init_data){ 2006 .name = "hdmi_pll_od", 2007 .ops = &clk_regmap_divider_ro_ops, 2008 .parent_hws = (const struct clk_hw *[]) { 2009 &g12a_hdmi_pll_dco.hw 2010 }, 2011 .num_parents = 1, 2012 .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT, 2013 }, 2014 }; 2015 2016 static struct clk_regmap g12a_hdmi_pll_od2 = { 2017 .data = &(struct clk_regmap_div_data){ 2018 .offset = HHI_HDMI_PLL_CNTL0, 2019 .shift = 18, 2020 .width = 2, 2021 .flags = CLK_DIVIDER_POWER_OF_TWO, 2022 }, 2023 .hw.init = &(struct clk_init_data){ 2024 .name = "hdmi_pll_od2", 2025 .ops = &clk_regmap_divider_ro_ops, 2026 .parent_hws = (const struct clk_hw *[]) { 2027 &g12a_hdmi_pll_od.hw 2028 }, 2029 .num_parents = 1, 2030 .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT, 2031 }, 2032 }; 2033 2034 static struct clk_regmap g12a_hdmi_pll = { 2035 .data = &(struct clk_regmap_div_data){ 2036 .offset = HHI_HDMI_PLL_CNTL0, 2037 .shift = 20, 2038 .width = 2, 2039 .flags = CLK_DIVIDER_POWER_OF_TWO, 2040 }, 2041 .hw.init = &(struct clk_init_data){ 2042 .name = "hdmi_pll", 2043 .ops = &clk_regmap_divider_ro_ops, 2044 .parent_hws = (const struct clk_hw *[]) { 2045 &g12a_hdmi_pll_od2.hw 2046 }, 2047 .num_parents = 1, 2048 .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT, 2049 }, 2050 }; 2051 2052 static struct clk_fixed_factor g12a_fclk_div4_div = { 2053 .mult = 1, 2054 .div = 4, 2055 .hw.init = &(struct clk_init_data){ 2056 .name = "fclk_div4_div", 2057 .ops = &clk_fixed_factor_ops, 2058 .parent_hws = (const struct clk_hw *[]) { &g12a_fixed_pll.hw }, 2059 .num_parents = 1, 2060 }, 2061 }; 2062 2063 static struct clk_regmap g12a_fclk_div4 = { 2064 .data = &(struct clk_regmap_gate_data){ 2065 .offset = HHI_FIX_PLL_CNTL1, 2066 .bit_idx = 21, 2067 }, 2068 .hw.init = &(struct clk_init_data){ 2069 .name = "fclk_div4", 2070 .ops = &clk_regmap_gate_ops, 2071 .parent_hws = (const struct clk_hw *[]) { 2072 &g12a_fclk_div4_div.hw 2073 }, 2074 .num_parents = 1, 2075 }, 2076 }; 2077 2078 static struct clk_fixed_factor g12a_fclk_div5_div = { 2079 .mult = 1, 2080 .div = 5, 2081 .hw.init = &(struct clk_init_data){ 2082 .name = "fclk_div5_div", 2083 .ops = &clk_fixed_factor_ops, 2084 .parent_hws = (const struct clk_hw *[]) { &g12a_fixed_pll.hw }, 2085 .num_parents = 1, 2086 }, 2087 }; 2088 2089 static struct clk_regmap g12a_fclk_div5 = { 2090 .data = &(struct clk_regmap_gate_data){ 2091 .offset = HHI_FIX_PLL_CNTL1, 2092 .bit_idx = 22, 2093 }, 2094 .hw.init = &(struct clk_init_data){ 2095 .name = "fclk_div5", 2096 .ops = &clk_regmap_gate_ops, 2097 .parent_hws = (const struct clk_hw *[]) { 2098 &g12a_fclk_div5_div.hw 2099 }, 2100 .num_parents = 1, 2101 }, 2102 }; 2103 2104 static struct clk_fixed_factor g12a_fclk_div7_div = { 2105 .mult = 1, 2106 .div = 7, 2107 .hw.init = &(struct clk_init_data){ 2108 .name = "fclk_div7_div", 2109 .ops = &clk_fixed_factor_ops, 2110 .parent_hws = (const struct clk_hw *[]) { &g12a_fixed_pll.hw }, 2111 .num_parents = 1, 2112 }, 2113 }; 2114 2115 static struct clk_regmap g12a_fclk_div7 = { 2116 .data = &(struct clk_regmap_gate_data){ 2117 .offset = HHI_FIX_PLL_CNTL1, 2118 .bit_idx = 23, 2119 }, 2120 .hw.init = &(struct clk_init_data){ 2121 .name = "fclk_div7", 2122 .ops = &clk_regmap_gate_ops, 2123 .parent_hws = (const struct clk_hw *[]) { 2124 &g12a_fclk_div7_div.hw 2125 }, 2126 .num_parents = 1, 2127 }, 2128 }; 2129 2130 static struct clk_fixed_factor g12a_fclk_div2p5_div = { 2131 .mult = 1, 2132 .div = 5, 2133 .hw.init = &(struct clk_init_data){ 2134 .name = "fclk_div2p5_div", 2135 .ops = &clk_fixed_factor_ops, 2136 .parent_hws = (const struct clk_hw *[]) { 2137 &g12a_fixed_pll_dco.hw 2138 }, 2139 .num_parents = 1, 2140 }, 2141 }; 2142 2143 static struct clk_regmap g12a_fclk_div2p5 = { 2144 .data = &(struct clk_regmap_gate_data){ 2145 .offset = HHI_FIX_PLL_CNTL1, 2146 .bit_idx = 25, 2147 }, 2148 .hw.init = &(struct clk_init_data){ 2149 .name = "fclk_div2p5", 2150 .ops = &clk_regmap_gate_ops, 2151 .parent_hws = (const struct clk_hw *[]) { 2152 &g12a_fclk_div2p5_div.hw 2153 }, 2154 .num_parents = 1, 2155 }, 2156 }; 2157 2158 static struct clk_fixed_factor g12a_mpll_50m_div = { 2159 .mult = 1, 2160 .div = 80, 2161 .hw.init = &(struct clk_init_data){ 2162 .name = "mpll_50m_div", 2163 .ops = &clk_fixed_factor_ops, 2164 .parent_hws = (const struct clk_hw *[]) { 2165 &g12a_fixed_pll_dco.hw 2166 }, 2167 .num_parents = 1, 2168 }, 2169 }; 2170 2171 static struct clk_regmap g12a_mpll_50m = { 2172 .data = &(struct clk_regmap_mux_data){ 2173 .offset = HHI_FIX_PLL_CNTL3, 2174 .mask = 0x1, 2175 .shift = 5, 2176 }, 2177 .hw.init = &(struct clk_init_data){ 2178 .name = "mpll_50m", 2179 .ops = &clk_regmap_mux_ro_ops, 2180 .parent_data = (const struct clk_parent_data []) { 2181 { .fw_name = "xtal", }, 2182 { .hw = &g12a_mpll_50m_div.hw }, 2183 }, 2184 .num_parents = 2, 2185 }, 2186 }; 2187 2188 static struct clk_fixed_factor g12a_mpll_prediv = { 2189 .mult = 1, 2190 .div = 2, 2191 .hw.init = &(struct clk_init_data){ 2192 .name = "mpll_prediv", 2193 .ops = &clk_fixed_factor_ops, 2194 .parent_hws = (const struct clk_hw *[]) { 2195 &g12a_fixed_pll_dco.hw 2196 }, 2197 .num_parents = 1, 2198 }, 2199 }; 2200 2201 static const struct reg_sequence g12a_mpll0_init_regs[] = { 2202 { .reg = HHI_MPLL_CNTL2, .def = 0x40000033 }, 2203 }; 2204 2205 static struct clk_regmap g12a_mpll0_div = { 2206 .data = &(struct meson_clk_mpll_data){ 2207 .sdm = { 2208 .reg_off = HHI_MPLL_CNTL1, 2209 .shift = 0, 2210 .width = 14, 2211 }, 2212 .sdm_en = { 2213 .reg_off = HHI_MPLL_CNTL1, 2214 .shift = 30, 2215 .width = 1, 2216 }, 2217 .n2 = { 2218 .reg_off = HHI_MPLL_CNTL1, 2219 .shift = 20, 2220 .width = 9, 2221 }, 2222 .ssen = { 2223 .reg_off = HHI_MPLL_CNTL1, 2224 .shift = 29, 2225 .width = 1, 2226 }, 2227 .lock = &meson_clk_lock, 2228 .init_regs = g12a_mpll0_init_regs, 2229 .init_count = ARRAY_SIZE(g12a_mpll0_init_regs), 2230 }, 2231 .hw.init = &(struct clk_init_data){ 2232 .name = "mpll0_div", 2233 .ops = &meson_clk_mpll_ops, 2234 .parent_hws = (const struct clk_hw *[]) { 2235 &g12a_mpll_prediv.hw 2236 }, 2237 .num_parents = 1, 2238 }, 2239 }; 2240 2241 static struct clk_regmap g12a_mpll0 = { 2242 .data = &(struct clk_regmap_gate_data){ 2243 .offset = HHI_MPLL_CNTL1, 2244 .bit_idx = 31, 2245 }, 2246 .hw.init = &(struct clk_init_data){ 2247 .name = "mpll0", 2248 .ops = &clk_regmap_gate_ops, 2249 .parent_hws = (const struct clk_hw *[]) { &g12a_mpll0_div.hw }, 2250 .num_parents = 1, 2251 .flags = CLK_SET_RATE_PARENT, 2252 }, 2253 }; 2254 2255 static const struct reg_sequence g12a_mpll1_init_regs[] = { 2256 { .reg = HHI_MPLL_CNTL4, .def = 0x40000033 }, 2257 }; 2258 2259 static struct clk_regmap g12a_mpll1_div = { 2260 .data = &(struct meson_clk_mpll_data){ 2261 .sdm = { 2262 .reg_off = HHI_MPLL_CNTL3, 2263 .shift = 0, 2264 .width = 14, 2265 }, 2266 .sdm_en = { 2267 .reg_off = HHI_MPLL_CNTL3, 2268 .shift = 30, 2269 .width = 1, 2270 }, 2271 .n2 = { 2272 .reg_off = HHI_MPLL_CNTL3, 2273 .shift = 20, 2274 .width = 9, 2275 }, 2276 .ssen = { 2277 .reg_off = HHI_MPLL_CNTL3, 2278 .shift = 29, 2279 .width = 1, 2280 }, 2281 .lock = &meson_clk_lock, 2282 .init_regs = g12a_mpll1_init_regs, 2283 .init_count = ARRAY_SIZE(g12a_mpll1_init_regs), 2284 }, 2285 .hw.init = &(struct clk_init_data){ 2286 .name = "mpll1_div", 2287 .ops = &meson_clk_mpll_ops, 2288 .parent_hws = (const struct clk_hw *[]) { 2289 &g12a_mpll_prediv.hw 2290 }, 2291 .num_parents = 1, 2292 }, 2293 }; 2294 2295 static struct clk_regmap g12a_mpll1 = { 2296 .data = &(struct clk_regmap_gate_data){ 2297 .offset = HHI_MPLL_CNTL3, 2298 .bit_idx = 31, 2299 }, 2300 .hw.init = &(struct clk_init_data){ 2301 .name = "mpll1", 2302 .ops = &clk_regmap_gate_ops, 2303 .parent_hws = (const struct clk_hw *[]) { &g12a_mpll1_div.hw }, 2304 .num_parents = 1, 2305 .flags = CLK_SET_RATE_PARENT, 2306 }, 2307 }; 2308 2309 static const struct reg_sequence g12a_mpll2_init_regs[] = { 2310 { .reg = HHI_MPLL_CNTL6, .def = 0x40000033 }, 2311 }; 2312 2313 static struct clk_regmap g12a_mpll2_div = { 2314 .data = &(struct meson_clk_mpll_data){ 2315 .sdm = { 2316 .reg_off = HHI_MPLL_CNTL5, 2317 .shift = 0, 2318 .width = 14, 2319 }, 2320 .sdm_en = { 2321 .reg_off = HHI_MPLL_CNTL5, 2322 .shift = 30, 2323 .width = 1, 2324 }, 2325 .n2 = { 2326 .reg_off = HHI_MPLL_CNTL5, 2327 .shift = 20, 2328 .width = 9, 2329 }, 2330 .ssen = { 2331 .reg_off = HHI_MPLL_CNTL5, 2332 .shift = 29, 2333 .width = 1, 2334 }, 2335 .lock = &meson_clk_lock, 2336 .init_regs = g12a_mpll2_init_regs, 2337 .init_count = ARRAY_SIZE(g12a_mpll2_init_regs), 2338 }, 2339 .hw.init = &(struct clk_init_data){ 2340 .name = "mpll2_div", 2341 .ops = &meson_clk_mpll_ops, 2342 .parent_hws = (const struct clk_hw *[]) { 2343 &g12a_mpll_prediv.hw 2344 }, 2345 .num_parents = 1, 2346 }, 2347 }; 2348 2349 static struct clk_regmap g12a_mpll2 = { 2350 .data = &(struct clk_regmap_gate_data){ 2351 .offset = HHI_MPLL_CNTL5, 2352 .bit_idx = 31, 2353 }, 2354 .hw.init = &(struct clk_init_data){ 2355 .name = "mpll2", 2356 .ops = &clk_regmap_gate_ops, 2357 .parent_hws = (const struct clk_hw *[]) { &g12a_mpll2_div.hw }, 2358 .num_parents = 1, 2359 .flags = CLK_SET_RATE_PARENT, 2360 }, 2361 }; 2362 2363 static const struct reg_sequence g12a_mpll3_init_regs[] = { 2364 { .reg = HHI_MPLL_CNTL8, .def = 0x40000033 }, 2365 }; 2366 2367 static struct clk_regmap g12a_mpll3_div = { 2368 .data = &(struct meson_clk_mpll_data){ 2369 .sdm = { 2370 .reg_off = HHI_MPLL_CNTL7, 2371 .shift = 0, 2372 .width = 14, 2373 }, 2374 .sdm_en = { 2375 .reg_off = HHI_MPLL_CNTL7, 2376 .shift = 30, 2377 .width = 1, 2378 }, 2379 .n2 = { 2380 .reg_off = HHI_MPLL_CNTL7, 2381 .shift = 20, 2382 .width = 9, 2383 }, 2384 .ssen = { 2385 .reg_off = HHI_MPLL_CNTL7, 2386 .shift = 29, 2387 .width = 1, 2388 }, 2389 .lock = &meson_clk_lock, 2390 .init_regs = g12a_mpll3_init_regs, 2391 .init_count = ARRAY_SIZE(g12a_mpll3_init_regs), 2392 }, 2393 .hw.init = &(struct clk_init_data){ 2394 .name = "mpll3_div", 2395 .ops = &meson_clk_mpll_ops, 2396 .parent_hws = (const struct clk_hw *[]) { 2397 &g12a_mpll_prediv.hw 2398 }, 2399 .num_parents = 1, 2400 }, 2401 }; 2402 2403 static struct clk_regmap g12a_mpll3 = { 2404 .data = &(struct clk_regmap_gate_data){ 2405 .offset = HHI_MPLL_CNTL7, 2406 .bit_idx = 31, 2407 }, 2408 .hw.init = &(struct clk_init_data){ 2409 .name = "mpll3", 2410 .ops = &clk_regmap_gate_ops, 2411 .parent_hws = (const struct clk_hw *[]) { &g12a_mpll3_div.hw }, 2412 .num_parents = 1, 2413 .flags = CLK_SET_RATE_PARENT, 2414 }, 2415 }; 2416 2417 static u32 mux_table_clk81[] = { 0, 2, 3, 4, 5, 6, 7 }; 2418 static const struct clk_parent_data clk81_parent_data[] = { 2419 { .fw_name = "xtal", }, 2420 { .hw = &g12a_fclk_div7.hw }, 2421 { .hw = &g12a_mpll1.hw }, 2422 { .hw = &g12a_mpll2.hw }, 2423 { .hw = &g12a_fclk_div4.hw }, 2424 { .hw = &g12a_fclk_div3.hw }, 2425 { .hw = &g12a_fclk_div5.hw }, 2426 }; 2427 2428 static struct clk_regmap g12a_mpeg_clk_sel = { 2429 .data = &(struct clk_regmap_mux_data){ 2430 .offset = HHI_MPEG_CLK_CNTL, 2431 .mask = 0x7, 2432 .shift = 12, 2433 .table = mux_table_clk81, 2434 }, 2435 .hw.init = &(struct clk_init_data){ 2436 .name = "mpeg_clk_sel", 2437 .ops = &clk_regmap_mux_ro_ops, 2438 .parent_data = clk81_parent_data, 2439 .num_parents = ARRAY_SIZE(clk81_parent_data), 2440 }, 2441 }; 2442 2443 static struct clk_regmap g12a_mpeg_clk_div = { 2444 .data = &(struct clk_regmap_div_data){ 2445 .offset = HHI_MPEG_CLK_CNTL, 2446 .shift = 0, 2447 .width = 7, 2448 }, 2449 .hw.init = &(struct clk_init_data){ 2450 .name = "mpeg_clk_div", 2451 .ops = &clk_regmap_divider_ops, 2452 .parent_hws = (const struct clk_hw *[]) { 2453 &g12a_mpeg_clk_sel.hw 2454 }, 2455 .num_parents = 1, 2456 .flags = CLK_SET_RATE_PARENT, 2457 }, 2458 }; 2459 2460 static struct clk_regmap g12a_clk81 = { 2461 .data = &(struct clk_regmap_gate_data){ 2462 .offset = HHI_MPEG_CLK_CNTL, 2463 .bit_idx = 7, 2464 }, 2465 .hw.init = &(struct clk_init_data){ 2466 .name = "clk81", 2467 .ops = &clk_regmap_gate_ops, 2468 .parent_hws = (const struct clk_hw *[]) { 2469 &g12a_mpeg_clk_div.hw 2470 }, 2471 .num_parents = 1, 2472 .flags = (CLK_SET_RATE_PARENT | CLK_IS_CRITICAL), 2473 }, 2474 }; 2475 2476 static const struct clk_parent_data g12a_sd_emmc_clk0_parent_data[] = { 2477 { .fw_name = "xtal", }, 2478 { .hw = &g12a_fclk_div2.hw }, 2479 { .hw = &g12a_fclk_div3.hw }, 2480 { .hw = &g12a_fclk_div5.hw }, 2481 { .hw = &g12a_fclk_div7.hw }, 2482 /* 2483 * Following these parent clocks, we should also have had mpll2, mpll3 2484 * and gp0_pll but these clocks are too precious to be used here. All 2485 * the necessary rates for MMC and NAND operation can be acheived using 2486 * g12a_ee_core or fclk_div clocks 2487 */ 2488 }; 2489 2490 /* SDIO clock */ 2491 static struct clk_regmap g12a_sd_emmc_a_clk0_sel = { 2492 .data = &(struct clk_regmap_mux_data){ 2493 .offset = HHI_SD_EMMC_CLK_CNTL, 2494 .mask = 0x7, 2495 .shift = 9, 2496 }, 2497 .hw.init = &(struct clk_init_data) { 2498 .name = "sd_emmc_a_clk0_sel", 2499 .ops = &clk_regmap_mux_ops, 2500 .parent_data = g12a_sd_emmc_clk0_parent_data, 2501 .num_parents = ARRAY_SIZE(g12a_sd_emmc_clk0_parent_data), 2502 .flags = CLK_SET_RATE_PARENT, 2503 }, 2504 }; 2505 2506 static struct clk_regmap g12a_sd_emmc_a_clk0_div = { 2507 .data = &(struct clk_regmap_div_data){ 2508 .offset = HHI_SD_EMMC_CLK_CNTL, 2509 .shift = 0, 2510 .width = 7, 2511 }, 2512 .hw.init = &(struct clk_init_data) { 2513 .name = "sd_emmc_a_clk0_div", 2514 .ops = &clk_regmap_divider_ops, 2515 .parent_hws = (const struct clk_hw *[]) { 2516 &g12a_sd_emmc_a_clk0_sel.hw 2517 }, 2518 .num_parents = 1, 2519 .flags = CLK_SET_RATE_PARENT, 2520 }, 2521 }; 2522 2523 static struct clk_regmap g12a_sd_emmc_a_clk0 = { 2524 .data = &(struct clk_regmap_gate_data){ 2525 .offset = HHI_SD_EMMC_CLK_CNTL, 2526 .bit_idx = 7, 2527 }, 2528 .hw.init = &(struct clk_init_data){ 2529 .name = "sd_emmc_a_clk0", 2530 .ops = &clk_regmap_gate_ops, 2531 .parent_hws = (const struct clk_hw *[]) { 2532 &g12a_sd_emmc_a_clk0_div.hw 2533 }, 2534 .num_parents = 1, 2535 .flags = CLK_SET_RATE_PARENT, 2536 }, 2537 }; 2538 2539 /* SDcard clock */ 2540 static struct clk_regmap g12a_sd_emmc_b_clk0_sel = { 2541 .data = &(struct clk_regmap_mux_data){ 2542 .offset = HHI_SD_EMMC_CLK_CNTL, 2543 .mask = 0x7, 2544 .shift = 25, 2545 }, 2546 .hw.init = &(struct clk_init_data) { 2547 .name = "sd_emmc_b_clk0_sel", 2548 .ops = &clk_regmap_mux_ops, 2549 .parent_data = g12a_sd_emmc_clk0_parent_data, 2550 .num_parents = ARRAY_SIZE(g12a_sd_emmc_clk0_parent_data), 2551 .flags = CLK_SET_RATE_PARENT, 2552 }, 2553 }; 2554 2555 static struct clk_regmap g12a_sd_emmc_b_clk0_div = { 2556 .data = &(struct clk_regmap_div_data){ 2557 .offset = HHI_SD_EMMC_CLK_CNTL, 2558 .shift = 16, 2559 .width = 7, 2560 }, 2561 .hw.init = &(struct clk_init_data) { 2562 .name = "sd_emmc_b_clk0_div", 2563 .ops = &clk_regmap_divider_ops, 2564 .parent_hws = (const struct clk_hw *[]) { 2565 &g12a_sd_emmc_b_clk0_sel.hw 2566 }, 2567 .num_parents = 1, 2568 .flags = CLK_SET_RATE_PARENT, 2569 }, 2570 }; 2571 2572 static struct clk_regmap g12a_sd_emmc_b_clk0 = { 2573 .data = &(struct clk_regmap_gate_data){ 2574 .offset = HHI_SD_EMMC_CLK_CNTL, 2575 .bit_idx = 23, 2576 }, 2577 .hw.init = &(struct clk_init_data){ 2578 .name = "sd_emmc_b_clk0", 2579 .ops = &clk_regmap_gate_ops, 2580 .parent_hws = (const struct clk_hw *[]) { 2581 &g12a_sd_emmc_b_clk0_div.hw 2582 }, 2583 .num_parents = 1, 2584 .flags = CLK_SET_RATE_PARENT, 2585 }, 2586 }; 2587 2588 /* EMMC/NAND clock */ 2589 static struct clk_regmap g12a_sd_emmc_c_clk0_sel = { 2590 .data = &(struct clk_regmap_mux_data){ 2591 .offset = HHI_NAND_CLK_CNTL, 2592 .mask = 0x7, 2593 .shift = 9, 2594 }, 2595 .hw.init = &(struct clk_init_data) { 2596 .name = "sd_emmc_c_clk0_sel", 2597 .ops = &clk_regmap_mux_ops, 2598 .parent_data = g12a_sd_emmc_clk0_parent_data, 2599 .num_parents = ARRAY_SIZE(g12a_sd_emmc_clk0_parent_data), 2600 .flags = CLK_SET_RATE_PARENT, 2601 }, 2602 }; 2603 2604 static struct clk_regmap g12a_sd_emmc_c_clk0_div = { 2605 .data = &(struct clk_regmap_div_data){ 2606 .offset = HHI_NAND_CLK_CNTL, 2607 .shift = 0, 2608 .width = 7, 2609 }, 2610 .hw.init = &(struct clk_init_data) { 2611 .name = "sd_emmc_c_clk0_div", 2612 .ops = &clk_regmap_divider_ops, 2613 .parent_hws = (const struct clk_hw *[]) { 2614 &g12a_sd_emmc_c_clk0_sel.hw 2615 }, 2616 .num_parents = 1, 2617 .flags = CLK_SET_RATE_PARENT, 2618 }, 2619 }; 2620 2621 static struct clk_regmap g12a_sd_emmc_c_clk0 = { 2622 .data = &(struct clk_regmap_gate_data){ 2623 .offset = HHI_NAND_CLK_CNTL, 2624 .bit_idx = 7, 2625 }, 2626 .hw.init = &(struct clk_init_data){ 2627 .name = "sd_emmc_c_clk0", 2628 .ops = &clk_regmap_gate_ops, 2629 .parent_hws = (const struct clk_hw *[]) { 2630 &g12a_sd_emmc_c_clk0_div.hw 2631 }, 2632 .num_parents = 1, 2633 .flags = CLK_SET_RATE_PARENT, 2634 }, 2635 }; 2636 2637 /* Video Clocks */ 2638 2639 static struct clk_regmap g12a_vid_pll_div = { 2640 .data = &(struct meson_vid_pll_div_data){ 2641 .val = { 2642 .reg_off = HHI_VID_PLL_CLK_DIV, 2643 .shift = 0, 2644 .width = 15, 2645 }, 2646 .sel = { 2647 .reg_off = HHI_VID_PLL_CLK_DIV, 2648 .shift = 16, 2649 .width = 2, 2650 }, 2651 }, 2652 .hw.init = &(struct clk_init_data) { 2653 .name = "vid_pll_div", 2654 .ops = &meson_vid_pll_div_ro_ops, 2655 .parent_hws = (const struct clk_hw *[]) { &g12a_hdmi_pll.hw }, 2656 .num_parents = 1, 2657 .flags = CLK_SET_RATE_PARENT | CLK_GET_RATE_NOCACHE, 2658 }, 2659 }; 2660 2661 static const struct clk_hw *g12a_vid_pll_parent_hws[] = { 2662 &g12a_vid_pll_div.hw, 2663 &g12a_hdmi_pll.hw, 2664 }; 2665 2666 static struct clk_regmap g12a_vid_pll_sel = { 2667 .data = &(struct clk_regmap_mux_data){ 2668 .offset = HHI_VID_PLL_CLK_DIV, 2669 .mask = 0x1, 2670 .shift = 18, 2671 }, 2672 .hw.init = &(struct clk_init_data){ 2673 .name = "vid_pll_sel", 2674 .ops = &clk_regmap_mux_ops, 2675 /* 2676 * bit 18 selects from 2 possible parents: 2677 * vid_pll_div or hdmi_pll 2678 */ 2679 .parent_hws = g12a_vid_pll_parent_hws, 2680 .num_parents = ARRAY_SIZE(g12a_vid_pll_parent_hws), 2681 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE, 2682 }, 2683 }; 2684 2685 static struct clk_regmap g12a_vid_pll = { 2686 .data = &(struct clk_regmap_gate_data){ 2687 .offset = HHI_VID_PLL_CLK_DIV, 2688 .bit_idx = 19, 2689 }, 2690 .hw.init = &(struct clk_init_data) { 2691 .name = "vid_pll", 2692 .ops = &clk_regmap_gate_ops, 2693 .parent_hws = (const struct clk_hw *[]) { 2694 &g12a_vid_pll_sel.hw 2695 }, 2696 .num_parents = 1, 2697 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 2698 }, 2699 }; 2700 2701 /* VPU Clock */ 2702 2703 static const struct clk_hw *g12a_vpu_parent_hws[] = { 2704 &g12a_fclk_div3.hw, 2705 &g12a_fclk_div4.hw, 2706 &g12a_fclk_div5.hw, 2707 &g12a_fclk_div7.hw, 2708 &g12a_mpll1.hw, 2709 &g12a_vid_pll.hw, 2710 &g12a_hifi_pll.hw, 2711 &g12a_gp0_pll.hw, 2712 }; 2713 2714 static struct clk_regmap g12a_vpu_0_sel = { 2715 .data = &(struct clk_regmap_mux_data){ 2716 .offset = HHI_VPU_CLK_CNTL, 2717 .mask = 0x7, 2718 .shift = 9, 2719 }, 2720 .hw.init = &(struct clk_init_data){ 2721 .name = "vpu_0_sel", 2722 .ops = &clk_regmap_mux_ops, 2723 .parent_hws = g12a_vpu_parent_hws, 2724 .num_parents = ARRAY_SIZE(g12a_vpu_parent_hws), 2725 .flags = CLK_SET_RATE_NO_REPARENT, 2726 }, 2727 }; 2728 2729 static struct clk_regmap g12a_vpu_0_div = { 2730 .data = &(struct clk_regmap_div_data){ 2731 .offset = HHI_VPU_CLK_CNTL, 2732 .shift = 0, 2733 .width = 7, 2734 }, 2735 .hw.init = &(struct clk_init_data){ 2736 .name = "vpu_0_div", 2737 .ops = &clk_regmap_divider_ops, 2738 .parent_hws = (const struct clk_hw *[]) { &g12a_vpu_0_sel.hw }, 2739 .num_parents = 1, 2740 .flags = CLK_SET_RATE_PARENT, 2741 }, 2742 }; 2743 2744 static struct clk_regmap g12a_vpu_0 = { 2745 .data = &(struct clk_regmap_gate_data){ 2746 .offset = HHI_VPU_CLK_CNTL, 2747 .bit_idx = 8, 2748 }, 2749 .hw.init = &(struct clk_init_data) { 2750 .name = "vpu_0", 2751 .ops = &clk_regmap_gate_ops, 2752 .parent_hws = (const struct clk_hw *[]) { &g12a_vpu_0_div.hw }, 2753 .num_parents = 1, 2754 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 2755 }, 2756 }; 2757 2758 static struct clk_regmap g12a_vpu_1_sel = { 2759 .data = &(struct clk_regmap_mux_data){ 2760 .offset = HHI_VPU_CLK_CNTL, 2761 .mask = 0x7, 2762 .shift = 25, 2763 }, 2764 .hw.init = &(struct clk_init_data){ 2765 .name = "vpu_1_sel", 2766 .ops = &clk_regmap_mux_ops, 2767 .parent_hws = g12a_vpu_parent_hws, 2768 .num_parents = ARRAY_SIZE(g12a_vpu_parent_hws), 2769 .flags = CLK_SET_RATE_NO_REPARENT, 2770 }, 2771 }; 2772 2773 static struct clk_regmap g12a_vpu_1_div = { 2774 .data = &(struct clk_regmap_div_data){ 2775 .offset = HHI_VPU_CLK_CNTL, 2776 .shift = 16, 2777 .width = 7, 2778 }, 2779 .hw.init = &(struct clk_init_data){ 2780 .name = "vpu_1_div", 2781 .ops = &clk_regmap_divider_ops, 2782 .parent_hws = (const struct clk_hw *[]) { &g12a_vpu_1_sel.hw }, 2783 .num_parents = 1, 2784 .flags = CLK_SET_RATE_PARENT, 2785 }, 2786 }; 2787 2788 static struct clk_regmap g12a_vpu_1 = { 2789 .data = &(struct clk_regmap_gate_data){ 2790 .offset = HHI_VPU_CLK_CNTL, 2791 .bit_idx = 24, 2792 }, 2793 .hw.init = &(struct clk_init_data) { 2794 .name = "vpu_1", 2795 .ops = &clk_regmap_gate_ops, 2796 .parent_hws = (const struct clk_hw *[]) { &g12a_vpu_1_div.hw }, 2797 .num_parents = 1, 2798 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 2799 }, 2800 }; 2801 2802 static struct clk_regmap g12a_vpu = { 2803 .data = &(struct clk_regmap_mux_data){ 2804 .offset = HHI_VPU_CLK_CNTL, 2805 .mask = 1, 2806 .shift = 31, 2807 }, 2808 .hw.init = &(struct clk_init_data){ 2809 .name = "vpu", 2810 .ops = &clk_regmap_mux_ops, 2811 /* 2812 * bit 31 selects from 2 possible parents: 2813 * vpu_0 or vpu_1 2814 */ 2815 .parent_hws = (const struct clk_hw *[]) { 2816 &g12a_vpu_0.hw, 2817 &g12a_vpu_1.hw, 2818 }, 2819 .num_parents = 2, 2820 .flags = CLK_SET_RATE_NO_REPARENT, 2821 }, 2822 }; 2823 2824 /* VDEC clocks */ 2825 2826 static const struct clk_hw *g12a_vdec_parent_hws[] = { 2827 &g12a_fclk_div2p5.hw, 2828 &g12a_fclk_div3.hw, 2829 &g12a_fclk_div4.hw, 2830 &g12a_fclk_div5.hw, 2831 &g12a_fclk_div7.hw, 2832 &g12a_hifi_pll.hw, 2833 &g12a_gp0_pll.hw, 2834 }; 2835 2836 static struct clk_regmap g12a_vdec_1_sel = { 2837 .data = &(struct clk_regmap_mux_data){ 2838 .offset = HHI_VDEC_CLK_CNTL, 2839 .mask = 0x7, 2840 .shift = 9, 2841 .flags = CLK_MUX_ROUND_CLOSEST, 2842 }, 2843 .hw.init = &(struct clk_init_data){ 2844 .name = "vdec_1_sel", 2845 .ops = &clk_regmap_mux_ops, 2846 .parent_hws = g12a_vdec_parent_hws, 2847 .num_parents = ARRAY_SIZE(g12a_vdec_parent_hws), 2848 .flags = CLK_SET_RATE_PARENT, 2849 }, 2850 }; 2851 2852 static struct clk_regmap g12a_vdec_1_div = { 2853 .data = &(struct clk_regmap_div_data){ 2854 .offset = HHI_VDEC_CLK_CNTL, 2855 .shift = 0, 2856 .width = 7, 2857 .flags = CLK_DIVIDER_ROUND_CLOSEST, 2858 }, 2859 .hw.init = &(struct clk_init_data){ 2860 .name = "vdec_1_div", 2861 .ops = &clk_regmap_divider_ops, 2862 .parent_hws = (const struct clk_hw *[]) { 2863 &g12a_vdec_1_sel.hw 2864 }, 2865 .num_parents = 1, 2866 .flags = CLK_SET_RATE_PARENT, 2867 }, 2868 }; 2869 2870 static struct clk_regmap g12a_vdec_1 = { 2871 .data = &(struct clk_regmap_gate_data){ 2872 .offset = HHI_VDEC_CLK_CNTL, 2873 .bit_idx = 8, 2874 }, 2875 .hw.init = &(struct clk_init_data) { 2876 .name = "vdec_1", 2877 .ops = &clk_regmap_gate_ops, 2878 .parent_hws = (const struct clk_hw *[]) { 2879 &g12a_vdec_1_div.hw 2880 }, 2881 .num_parents = 1, 2882 .flags = CLK_SET_RATE_PARENT, 2883 }, 2884 }; 2885 2886 static struct clk_regmap g12a_vdec_hevcf_sel = { 2887 .data = &(struct clk_regmap_mux_data){ 2888 .offset = HHI_VDEC2_CLK_CNTL, 2889 .mask = 0x7, 2890 .shift = 9, 2891 .flags = CLK_MUX_ROUND_CLOSEST, 2892 }, 2893 .hw.init = &(struct clk_init_data){ 2894 .name = "vdec_hevcf_sel", 2895 .ops = &clk_regmap_mux_ops, 2896 .parent_hws = g12a_vdec_parent_hws, 2897 .num_parents = ARRAY_SIZE(g12a_vdec_parent_hws), 2898 .flags = CLK_SET_RATE_PARENT, 2899 }, 2900 }; 2901 2902 static struct clk_regmap g12a_vdec_hevcf_div = { 2903 .data = &(struct clk_regmap_div_data){ 2904 .offset = HHI_VDEC2_CLK_CNTL, 2905 .shift = 0, 2906 .width = 7, 2907 .flags = CLK_DIVIDER_ROUND_CLOSEST, 2908 }, 2909 .hw.init = &(struct clk_init_data){ 2910 .name = "vdec_hevcf_div", 2911 .ops = &clk_regmap_divider_ops, 2912 .parent_hws = (const struct clk_hw *[]) { 2913 &g12a_vdec_hevcf_sel.hw 2914 }, 2915 .num_parents = 1, 2916 .flags = CLK_SET_RATE_PARENT, 2917 }, 2918 }; 2919 2920 static struct clk_regmap g12a_vdec_hevcf = { 2921 .data = &(struct clk_regmap_gate_data){ 2922 .offset = HHI_VDEC2_CLK_CNTL, 2923 .bit_idx = 8, 2924 }, 2925 .hw.init = &(struct clk_init_data) { 2926 .name = "vdec_hevcf", 2927 .ops = &clk_regmap_gate_ops, 2928 .parent_hws = (const struct clk_hw *[]) { 2929 &g12a_vdec_hevcf_div.hw 2930 }, 2931 .num_parents = 1, 2932 .flags = CLK_SET_RATE_PARENT, 2933 }, 2934 }; 2935 2936 static struct clk_regmap g12a_vdec_hevc_sel = { 2937 .data = &(struct clk_regmap_mux_data){ 2938 .offset = HHI_VDEC2_CLK_CNTL, 2939 .mask = 0x7, 2940 .shift = 25, 2941 .flags = CLK_MUX_ROUND_CLOSEST, 2942 }, 2943 .hw.init = &(struct clk_init_data){ 2944 .name = "vdec_hevc_sel", 2945 .ops = &clk_regmap_mux_ops, 2946 .parent_hws = g12a_vdec_parent_hws, 2947 .num_parents = ARRAY_SIZE(g12a_vdec_parent_hws), 2948 .flags = CLK_SET_RATE_PARENT, 2949 }, 2950 }; 2951 2952 static struct clk_regmap g12a_vdec_hevc_div = { 2953 .data = &(struct clk_regmap_div_data){ 2954 .offset = HHI_VDEC2_CLK_CNTL, 2955 .shift = 16, 2956 .width = 7, 2957 .flags = CLK_DIVIDER_ROUND_CLOSEST, 2958 }, 2959 .hw.init = &(struct clk_init_data){ 2960 .name = "vdec_hevc_div", 2961 .ops = &clk_regmap_divider_ops, 2962 .parent_hws = (const struct clk_hw *[]) { 2963 &g12a_vdec_hevc_sel.hw 2964 }, 2965 .num_parents = 1, 2966 .flags = CLK_SET_RATE_PARENT, 2967 }, 2968 }; 2969 2970 static struct clk_regmap g12a_vdec_hevc = { 2971 .data = &(struct clk_regmap_gate_data){ 2972 .offset = HHI_VDEC2_CLK_CNTL, 2973 .bit_idx = 24, 2974 }, 2975 .hw.init = &(struct clk_init_data) { 2976 .name = "vdec_hevc", 2977 .ops = &clk_regmap_gate_ops, 2978 .parent_hws = (const struct clk_hw *[]) { 2979 &g12a_vdec_hevc_div.hw 2980 }, 2981 .num_parents = 1, 2982 .flags = CLK_SET_RATE_PARENT, 2983 }, 2984 }; 2985 2986 /* VAPB Clock */ 2987 2988 static const struct clk_hw *g12a_vapb_parent_hws[] = { 2989 &g12a_fclk_div4.hw, 2990 &g12a_fclk_div3.hw, 2991 &g12a_fclk_div5.hw, 2992 &g12a_fclk_div7.hw, 2993 &g12a_mpll1.hw, 2994 &g12a_vid_pll.hw, 2995 &g12a_mpll2.hw, 2996 &g12a_fclk_div2p5.hw, 2997 }; 2998 2999 static struct clk_regmap g12a_vapb_0_sel = { 3000 .data = &(struct clk_regmap_mux_data){ 3001 .offset = HHI_VAPBCLK_CNTL, 3002 .mask = 0x3, 3003 .shift = 9, 3004 }, 3005 .hw.init = &(struct clk_init_data){ 3006 .name = "vapb_0_sel", 3007 .ops = &clk_regmap_mux_ops, 3008 .parent_hws = g12a_vapb_parent_hws, 3009 .num_parents = ARRAY_SIZE(g12a_vapb_parent_hws), 3010 .flags = CLK_SET_RATE_NO_REPARENT, 3011 }, 3012 }; 3013 3014 static struct clk_regmap g12a_vapb_0_div = { 3015 .data = &(struct clk_regmap_div_data){ 3016 .offset = HHI_VAPBCLK_CNTL, 3017 .shift = 0, 3018 .width = 7, 3019 }, 3020 .hw.init = &(struct clk_init_data){ 3021 .name = "vapb_0_div", 3022 .ops = &clk_regmap_divider_ops, 3023 .parent_hws = (const struct clk_hw *[]) { 3024 &g12a_vapb_0_sel.hw 3025 }, 3026 .num_parents = 1, 3027 .flags = CLK_SET_RATE_PARENT, 3028 }, 3029 }; 3030 3031 static struct clk_regmap g12a_vapb_0 = { 3032 .data = &(struct clk_regmap_gate_data){ 3033 .offset = HHI_VAPBCLK_CNTL, 3034 .bit_idx = 8, 3035 }, 3036 .hw.init = &(struct clk_init_data) { 3037 .name = "vapb_0", 3038 .ops = &clk_regmap_gate_ops, 3039 .parent_hws = (const struct clk_hw *[]) { 3040 &g12a_vapb_0_div.hw 3041 }, 3042 .num_parents = 1, 3043 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3044 }, 3045 }; 3046 3047 static struct clk_regmap g12a_vapb_1_sel = { 3048 .data = &(struct clk_regmap_mux_data){ 3049 .offset = HHI_VAPBCLK_CNTL, 3050 .mask = 0x3, 3051 .shift = 25, 3052 }, 3053 .hw.init = &(struct clk_init_data){ 3054 .name = "vapb_1_sel", 3055 .ops = &clk_regmap_mux_ops, 3056 .parent_hws = g12a_vapb_parent_hws, 3057 .num_parents = ARRAY_SIZE(g12a_vapb_parent_hws), 3058 .flags = CLK_SET_RATE_NO_REPARENT, 3059 }, 3060 }; 3061 3062 static struct clk_regmap g12a_vapb_1_div = { 3063 .data = &(struct clk_regmap_div_data){ 3064 .offset = HHI_VAPBCLK_CNTL, 3065 .shift = 16, 3066 .width = 7, 3067 }, 3068 .hw.init = &(struct clk_init_data){ 3069 .name = "vapb_1_div", 3070 .ops = &clk_regmap_divider_ops, 3071 .parent_hws = (const struct clk_hw *[]) { 3072 &g12a_vapb_1_sel.hw 3073 }, 3074 .num_parents = 1, 3075 .flags = CLK_SET_RATE_PARENT, 3076 }, 3077 }; 3078 3079 static struct clk_regmap g12a_vapb_1 = { 3080 .data = &(struct clk_regmap_gate_data){ 3081 .offset = HHI_VAPBCLK_CNTL, 3082 .bit_idx = 24, 3083 }, 3084 .hw.init = &(struct clk_init_data) { 3085 .name = "vapb_1", 3086 .ops = &clk_regmap_gate_ops, 3087 .parent_hws = (const struct clk_hw *[]) { 3088 &g12a_vapb_1_div.hw 3089 }, 3090 .num_parents = 1, 3091 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3092 }, 3093 }; 3094 3095 static struct clk_regmap g12a_vapb_sel = { 3096 .data = &(struct clk_regmap_mux_data){ 3097 .offset = HHI_VAPBCLK_CNTL, 3098 .mask = 1, 3099 .shift = 31, 3100 }, 3101 .hw.init = &(struct clk_init_data){ 3102 .name = "vapb_sel", 3103 .ops = &clk_regmap_mux_ops, 3104 /* 3105 * bit 31 selects from 2 possible parents: 3106 * vapb_0 or vapb_1 3107 */ 3108 .parent_hws = (const struct clk_hw *[]) { 3109 &g12a_vapb_0.hw, 3110 &g12a_vapb_1.hw, 3111 }, 3112 .num_parents = 2, 3113 .flags = CLK_SET_RATE_NO_REPARENT, 3114 }, 3115 }; 3116 3117 static struct clk_regmap g12a_vapb = { 3118 .data = &(struct clk_regmap_gate_data){ 3119 .offset = HHI_VAPBCLK_CNTL, 3120 .bit_idx = 30, 3121 }, 3122 .hw.init = &(struct clk_init_data) { 3123 .name = "vapb", 3124 .ops = &clk_regmap_gate_ops, 3125 .parent_hws = (const struct clk_hw *[]) { &g12a_vapb_sel.hw }, 3126 .num_parents = 1, 3127 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3128 }, 3129 }; 3130 3131 static const struct clk_hw *g12a_vclk_parent_hws[] = { 3132 &g12a_vid_pll.hw, 3133 &g12a_gp0_pll.hw, 3134 &g12a_hifi_pll.hw, 3135 &g12a_mpll1.hw, 3136 &g12a_fclk_div3.hw, 3137 &g12a_fclk_div4.hw, 3138 &g12a_fclk_div5.hw, 3139 &g12a_fclk_div7.hw, 3140 }; 3141 3142 static struct clk_regmap g12a_vclk_sel = { 3143 .data = &(struct clk_regmap_mux_data){ 3144 .offset = HHI_VID_CLK_CNTL, 3145 .mask = 0x7, 3146 .shift = 16, 3147 }, 3148 .hw.init = &(struct clk_init_data){ 3149 .name = "vclk_sel", 3150 .ops = &clk_regmap_mux_ops, 3151 .parent_hws = g12a_vclk_parent_hws, 3152 .num_parents = ARRAY_SIZE(g12a_vclk_parent_hws), 3153 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE, 3154 }, 3155 }; 3156 3157 static struct clk_regmap g12a_vclk2_sel = { 3158 .data = &(struct clk_regmap_mux_data){ 3159 .offset = HHI_VIID_CLK_CNTL, 3160 .mask = 0x7, 3161 .shift = 16, 3162 }, 3163 .hw.init = &(struct clk_init_data){ 3164 .name = "vclk2_sel", 3165 .ops = &clk_regmap_mux_ops, 3166 .parent_hws = g12a_vclk_parent_hws, 3167 .num_parents = ARRAY_SIZE(g12a_vclk_parent_hws), 3168 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE, 3169 }, 3170 }; 3171 3172 static struct clk_regmap g12a_vclk_input = { 3173 .data = &(struct clk_regmap_gate_data){ 3174 .offset = HHI_VID_CLK_DIV, 3175 .bit_idx = 16, 3176 }, 3177 .hw.init = &(struct clk_init_data) { 3178 .name = "vclk_input", 3179 .ops = &clk_regmap_gate_ops, 3180 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk_sel.hw }, 3181 .num_parents = 1, 3182 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3183 }, 3184 }; 3185 3186 static struct clk_regmap g12a_vclk2_input = { 3187 .data = &(struct clk_regmap_gate_data){ 3188 .offset = HHI_VIID_CLK_DIV, 3189 .bit_idx = 16, 3190 }, 3191 .hw.init = &(struct clk_init_data) { 3192 .name = "vclk2_input", 3193 .ops = &clk_regmap_gate_ops, 3194 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2_sel.hw }, 3195 .num_parents = 1, 3196 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3197 }, 3198 }; 3199 3200 static struct clk_regmap g12a_vclk_div = { 3201 .data = &(struct clk_regmap_div_data){ 3202 .offset = HHI_VID_CLK_DIV, 3203 .shift = 0, 3204 .width = 8, 3205 }, 3206 .hw.init = &(struct clk_init_data){ 3207 .name = "vclk_div", 3208 .ops = &clk_regmap_divider_ops, 3209 .parent_hws = (const struct clk_hw *[]) { 3210 &g12a_vclk_input.hw 3211 }, 3212 .num_parents = 1, 3213 .flags = CLK_GET_RATE_NOCACHE, 3214 }, 3215 }; 3216 3217 static struct clk_regmap g12a_vclk2_div = { 3218 .data = &(struct clk_regmap_div_data){ 3219 .offset = HHI_VIID_CLK_DIV, 3220 .shift = 0, 3221 .width = 8, 3222 }, 3223 .hw.init = &(struct clk_init_data){ 3224 .name = "vclk2_div", 3225 .ops = &clk_regmap_divider_ops, 3226 .parent_hws = (const struct clk_hw *[]) { 3227 &g12a_vclk2_input.hw 3228 }, 3229 .num_parents = 1, 3230 .flags = CLK_GET_RATE_NOCACHE, 3231 }, 3232 }; 3233 3234 static struct clk_regmap g12a_vclk = { 3235 .data = &(struct clk_regmap_gate_data){ 3236 .offset = HHI_VID_CLK_CNTL, 3237 .bit_idx = 19, 3238 }, 3239 .hw.init = &(struct clk_init_data) { 3240 .name = "vclk", 3241 .ops = &clk_regmap_gate_ops, 3242 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk_div.hw }, 3243 .num_parents = 1, 3244 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3245 }, 3246 }; 3247 3248 static struct clk_regmap g12a_vclk2 = { 3249 .data = &(struct clk_regmap_gate_data){ 3250 .offset = HHI_VIID_CLK_CNTL, 3251 .bit_idx = 19, 3252 }, 3253 .hw.init = &(struct clk_init_data) { 3254 .name = "vclk2", 3255 .ops = &clk_regmap_gate_ops, 3256 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2_div.hw }, 3257 .num_parents = 1, 3258 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3259 }, 3260 }; 3261 3262 static struct clk_regmap g12a_vclk_div1 = { 3263 .data = &(struct clk_regmap_gate_data){ 3264 .offset = HHI_VID_CLK_CNTL, 3265 .bit_idx = 0, 3266 }, 3267 .hw.init = &(struct clk_init_data) { 3268 .name = "vclk_div1", 3269 .ops = &clk_regmap_gate_ops, 3270 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk.hw }, 3271 .num_parents = 1, 3272 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3273 }, 3274 }; 3275 3276 static struct clk_regmap g12a_vclk_div2_en = { 3277 .data = &(struct clk_regmap_gate_data){ 3278 .offset = HHI_VID_CLK_CNTL, 3279 .bit_idx = 1, 3280 }, 3281 .hw.init = &(struct clk_init_data) { 3282 .name = "vclk_div2_en", 3283 .ops = &clk_regmap_gate_ops, 3284 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk.hw }, 3285 .num_parents = 1, 3286 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3287 }, 3288 }; 3289 3290 static struct clk_regmap g12a_vclk_div4_en = { 3291 .data = &(struct clk_regmap_gate_data){ 3292 .offset = HHI_VID_CLK_CNTL, 3293 .bit_idx = 2, 3294 }, 3295 .hw.init = &(struct clk_init_data) { 3296 .name = "vclk_div4_en", 3297 .ops = &clk_regmap_gate_ops, 3298 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk.hw }, 3299 .num_parents = 1, 3300 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3301 }, 3302 }; 3303 3304 static struct clk_regmap g12a_vclk_div6_en = { 3305 .data = &(struct clk_regmap_gate_data){ 3306 .offset = HHI_VID_CLK_CNTL, 3307 .bit_idx = 3, 3308 }, 3309 .hw.init = &(struct clk_init_data) { 3310 .name = "vclk_div6_en", 3311 .ops = &clk_regmap_gate_ops, 3312 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk.hw }, 3313 .num_parents = 1, 3314 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3315 }, 3316 }; 3317 3318 static struct clk_regmap g12a_vclk_div12_en = { 3319 .data = &(struct clk_regmap_gate_data){ 3320 .offset = HHI_VID_CLK_CNTL, 3321 .bit_idx = 4, 3322 }, 3323 .hw.init = &(struct clk_init_data) { 3324 .name = "vclk_div12_en", 3325 .ops = &clk_regmap_gate_ops, 3326 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk.hw }, 3327 .num_parents = 1, 3328 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3329 }, 3330 }; 3331 3332 static struct clk_regmap g12a_vclk2_div1 = { 3333 .data = &(struct clk_regmap_gate_data){ 3334 .offset = HHI_VIID_CLK_CNTL, 3335 .bit_idx = 0, 3336 }, 3337 .hw.init = &(struct clk_init_data) { 3338 .name = "vclk2_div1", 3339 .ops = &clk_regmap_gate_ops, 3340 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2.hw }, 3341 .num_parents = 1, 3342 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3343 }, 3344 }; 3345 3346 static struct clk_regmap g12a_vclk2_div2_en = { 3347 .data = &(struct clk_regmap_gate_data){ 3348 .offset = HHI_VIID_CLK_CNTL, 3349 .bit_idx = 1, 3350 }, 3351 .hw.init = &(struct clk_init_data) { 3352 .name = "vclk2_div2_en", 3353 .ops = &clk_regmap_gate_ops, 3354 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2.hw }, 3355 .num_parents = 1, 3356 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3357 }, 3358 }; 3359 3360 static struct clk_regmap g12a_vclk2_div4_en = { 3361 .data = &(struct clk_regmap_gate_data){ 3362 .offset = HHI_VIID_CLK_CNTL, 3363 .bit_idx = 2, 3364 }, 3365 .hw.init = &(struct clk_init_data) { 3366 .name = "vclk2_div4_en", 3367 .ops = &clk_regmap_gate_ops, 3368 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2.hw }, 3369 .num_parents = 1, 3370 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3371 }, 3372 }; 3373 3374 static struct clk_regmap g12a_vclk2_div6_en = { 3375 .data = &(struct clk_regmap_gate_data){ 3376 .offset = HHI_VIID_CLK_CNTL, 3377 .bit_idx = 3, 3378 }, 3379 .hw.init = &(struct clk_init_data) { 3380 .name = "vclk2_div6_en", 3381 .ops = &clk_regmap_gate_ops, 3382 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2.hw }, 3383 .num_parents = 1, 3384 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3385 }, 3386 }; 3387 3388 static struct clk_regmap g12a_vclk2_div12_en = { 3389 .data = &(struct clk_regmap_gate_data){ 3390 .offset = HHI_VIID_CLK_CNTL, 3391 .bit_idx = 4, 3392 }, 3393 .hw.init = &(struct clk_init_data) { 3394 .name = "vclk2_div12_en", 3395 .ops = &clk_regmap_gate_ops, 3396 .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2.hw }, 3397 .num_parents = 1, 3398 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3399 }, 3400 }; 3401 3402 static struct clk_fixed_factor g12a_vclk_div2 = { 3403 .mult = 1, 3404 .div = 2, 3405 .hw.init = &(struct clk_init_data){ 3406 .name = "vclk_div2", 3407 .ops = &clk_fixed_factor_ops, 3408 .parent_hws = (const struct clk_hw *[]) { 3409 &g12a_vclk_div2_en.hw 3410 }, 3411 .num_parents = 1, 3412 }, 3413 }; 3414 3415 static struct clk_fixed_factor g12a_vclk_div4 = { 3416 .mult = 1, 3417 .div = 4, 3418 .hw.init = &(struct clk_init_data){ 3419 .name = "vclk_div4", 3420 .ops = &clk_fixed_factor_ops, 3421 .parent_hws = (const struct clk_hw *[]) { 3422 &g12a_vclk_div4_en.hw 3423 }, 3424 .num_parents = 1, 3425 }, 3426 }; 3427 3428 static struct clk_fixed_factor g12a_vclk_div6 = { 3429 .mult = 1, 3430 .div = 6, 3431 .hw.init = &(struct clk_init_data){ 3432 .name = "vclk_div6", 3433 .ops = &clk_fixed_factor_ops, 3434 .parent_hws = (const struct clk_hw *[]) { 3435 &g12a_vclk_div6_en.hw 3436 }, 3437 .num_parents = 1, 3438 }, 3439 }; 3440 3441 static struct clk_fixed_factor g12a_vclk_div12 = { 3442 .mult = 1, 3443 .div = 12, 3444 .hw.init = &(struct clk_init_data){ 3445 .name = "vclk_div12", 3446 .ops = &clk_fixed_factor_ops, 3447 .parent_hws = (const struct clk_hw *[]) { 3448 &g12a_vclk_div12_en.hw 3449 }, 3450 .num_parents = 1, 3451 }, 3452 }; 3453 3454 static struct clk_fixed_factor g12a_vclk2_div2 = { 3455 .mult = 1, 3456 .div = 2, 3457 .hw.init = &(struct clk_init_data){ 3458 .name = "vclk2_div2", 3459 .ops = &clk_fixed_factor_ops, 3460 .parent_hws = (const struct clk_hw *[]) { 3461 &g12a_vclk2_div2_en.hw 3462 }, 3463 .num_parents = 1, 3464 }, 3465 }; 3466 3467 static struct clk_fixed_factor g12a_vclk2_div4 = { 3468 .mult = 1, 3469 .div = 4, 3470 .hw.init = &(struct clk_init_data){ 3471 .name = "vclk2_div4", 3472 .ops = &clk_fixed_factor_ops, 3473 .parent_hws = (const struct clk_hw *[]) { 3474 &g12a_vclk2_div4_en.hw 3475 }, 3476 .num_parents = 1, 3477 }, 3478 }; 3479 3480 static struct clk_fixed_factor g12a_vclk2_div6 = { 3481 .mult = 1, 3482 .div = 6, 3483 .hw.init = &(struct clk_init_data){ 3484 .name = "vclk2_div6", 3485 .ops = &clk_fixed_factor_ops, 3486 .parent_hws = (const struct clk_hw *[]) { 3487 &g12a_vclk2_div6_en.hw 3488 }, 3489 .num_parents = 1, 3490 }, 3491 }; 3492 3493 static struct clk_fixed_factor g12a_vclk2_div12 = { 3494 .mult = 1, 3495 .div = 12, 3496 .hw.init = &(struct clk_init_data){ 3497 .name = "vclk2_div12", 3498 .ops = &clk_fixed_factor_ops, 3499 .parent_hws = (const struct clk_hw *[]) { 3500 &g12a_vclk2_div12_en.hw 3501 }, 3502 .num_parents = 1, 3503 }, 3504 }; 3505 3506 static u32 mux_table_cts_sel[] = { 0, 1, 2, 3, 4, 8, 9, 10, 11, 12 }; 3507 static const struct clk_hw *g12a_cts_parent_hws[] = { 3508 &g12a_vclk_div1.hw, 3509 &g12a_vclk_div2.hw, 3510 &g12a_vclk_div4.hw, 3511 &g12a_vclk_div6.hw, 3512 &g12a_vclk_div12.hw, 3513 &g12a_vclk2_div1.hw, 3514 &g12a_vclk2_div2.hw, 3515 &g12a_vclk2_div4.hw, 3516 &g12a_vclk2_div6.hw, 3517 &g12a_vclk2_div12.hw, 3518 }; 3519 3520 static struct clk_regmap g12a_cts_enci_sel = { 3521 .data = &(struct clk_regmap_mux_data){ 3522 .offset = HHI_VID_CLK_DIV, 3523 .mask = 0xf, 3524 .shift = 28, 3525 .table = mux_table_cts_sel, 3526 }, 3527 .hw.init = &(struct clk_init_data){ 3528 .name = "cts_enci_sel", 3529 .ops = &clk_regmap_mux_ops, 3530 .parent_hws = g12a_cts_parent_hws, 3531 .num_parents = ARRAY_SIZE(g12a_cts_parent_hws), 3532 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE, 3533 }, 3534 }; 3535 3536 static struct clk_regmap g12a_cts_encp_sel = { 3537 .data = &(struct clk_regmap_mux_data){ 3538 .offset = HHI_VID_CLK_DIV, 3539 .mask = 0xf, 3540 .shift = 20, 3541 .table = mux_table_cts_sel, 3542 }, 3543 .hw.init = &(struct clk_init_data){ 3544 .name = "cts_encp_sel", 3545 .ops = &clk_regmap_mux_ops, 3546 .parent_hws = g12a_cts_parent_hws, 3547 .num_parents = ARRAY_SIZE(g12a_cts_parent_hws), 3548 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE, 3549 }, 3550 }; 3551 3552 static struct clk_regmap g12a_cts_encl_sel = { 3553 .data = &(struct clk_regmap_mux_data){ 3554 .offset = HHI_VIID_CLK_DIV, 3555 .mask = 0xf, 3556 .shift = 12, 3557 .table = mux_table_cts_sel, 3558 }, 3559 .hw.init = &(struct clk_init_data){ 3560 .name = "cts_encl_sel", 3561 .ops = &clk_regmap_mux_ops, 3562 .parent_hws = g12a_cts_parent_hws, 3563 .num_parents = ARRAY_SIZE(g12a_cts_parent_hws), 3564 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE, 3565 }, 3566 }; 3567 3568 static struct clk_regmap g12a_cts_vdac_sel = { 3569 .data = &(struct clk_regmap_mux_data){ 3570 .offset = HHI_VIID_CLK_DIV, 3571 .mask = 0xf, 3572 .shift = 28, 3573 .table = mux_table_cts_sel, 3574 }, 3575 .hw.init = &(struct clk_init_data){ 3576 .name = "cts_vdac_sel", 3577 .ops = &clk_regmap_mux_ops, 3578 .parent_hws = g12a_cts_parent_hws, 3579 .num_parents = ARRAY_SIZE(g12a_cts_parent_hws), 3580 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE, 3581 }, 3582 }; 3583 3584 /* TOFIX: add support for cts_tcon */ 3585 static u32 mux_table_hdmi_tx_sel[] = { 0, 1, 2, 3, 4, 8, 9, 10, 11, 12 }; 3586 static const struct clk_hw *g12a_cts_hdmi_tx_parent_hws[] = { 3587 &g12a_vclk_div1.hw, 3588 &g12a_vclk_div2.hw, 3589 &g12a_vclk_div4.hw, 3590 &g12a_vclk_div6.hw, 3591 &g12a_vclk_div12.hw, 3592 &g12a_vclk2_div1.hw, 3593 &g12a_vclk2_div2.hw, 3594 &g12a_vclk2_div4.hw, 3595 &g12a_vclk2_div6.hw, 3596 &g12a_vclk2_div12.hw, 3597 }; 3598 3599 static struct clk_regmap g12a_hdmi_tx_sel = { 3600 .data = &(struct clk_regmap_mux_data){ 3601 .offset = HHI_HDMI_CLK_CNTL, 3602 .mask = 0xf, 3603 .shift = 16, 3604 .table = mux_table_hdmi_tx_sel, 3605 }, 3606 .hw.init = &(struct clk_init_data){ 3607 .name = "hdmi_tx_sel", 3608 .ops = &clk_regmap_mux_ops, 3609 .parent_hws = g12a_cts_hdmi_tx_parent_hws, 3610 .num_parents = ARRAY_SIZE(g12a_cts_hdmi_tx_parent_hws), 3611 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE, 3612 }, 3613 }; 3614 3615 static struct clk_regmap g12a_cts_enci = { 3616 .data = &(struct clk_regmap_gate_data){ 3617 .offset = HHI_VID_CLK_CNTL2, 3618 .bit_idx = 0, 3619 }, 3620 .hw.init = &(struct clk_init_data) { 3621 .name = "cts_enci", 3622 .ops = &clk_regmap_gate_ops, 3623 .parent_hws = (const struct clk_hw *[]) { 3624 &g12a_cts_enci_sel.hw 3625 }, 3626 .num_parents = 1, 3627 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3628 }, 3629 }; 3630 3631 static struct clk_regmap g12a_cts_encp = { 3632 .data = &(struct clk_regmap_gate_data){ 3633 .offset = HHI_VID_CLK_CNTL2, 3634 .bit_idx = 2, 3635 }, 3636 .hw.init = &(struct clk_init_data) { 3637 .name = "cts_encp", 3638 .ops = &clk_regmap_gate_ops, 3639 .parent_hws = (const struct clk_hw *[]) { 3640 &g12a_cts_encp_sel.hw 3641 }, 3642 .num_parents = 1, 3643 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3644 }, 3645 }; 3646 3647 static struct clk_regmap g12a_cts_encl = { 3648 .data = &(struct clk_regmap_gate_data){ 3649 .offset = HHI_VID_CLK_CNTL2, 3650 .bit_idx = 3, 3651 }, 3652 .hw.init = &(struct clk_init_data) { 3653 .name = "cts_encl", 3654 .ops = &clk_regmap_gate_ops, 3655 .parent_hws = (const struct clk_hw *[]) { 3656 &g12a_cts_encl_sel.hw 3657 }, 3658 .num_parents = 1, 3659 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3660 }, 3661 }; 3662 3663 static struct clk_regmap g12a_cts_vdac = { 3664 .data = &(struct clk_regmap_gate_data){ 3665 .offset = HHI_VID_CLK_CNTL2, 3666 .bit_idx = 4, 3667 }, 3668 .hw.init = &(struct clk_init_data) { 3669 .name = "cts_vdac", 3670 .ops = &clk_regmap_gate_ops, 3671 .parent_hws = (const struct clk_hw *[]) { 3672 &g12a_cts_vdac_sel.hw 3673 }, 3674 .num_parents = 1, 3675 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3676 }, 3677 }; 3678 3679 static struct clk_regmap g12a_hdmi_tx = { 3680 .data = &(struct clk_regmap_gate_data){ 3681 .offset = HHI_VID_CLK_CNTL2, 3682 .bit_idx = 5, 3683 }, 3684 .hw.init = &(struct clk_init_data) { 3685 .name = "hdmi_tx", 3686 .ops = &clk_regmap_gate_ops, 3687 .parent_hws = (const struct clk_hw *[]) { 3688 &g12a_hdmi_tx_sel.hw 3689 }, 3690 .num_parents = 1, 3691 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3692 }, 3693 }; 3694 3695 /* MIPI DSI Host Clocks */ 3696 3697 static const struct clk_hw *g12a_mipi_dsi_pxclk_parent_hws[] = { 3698 &g12a_vid_pll.hw, 3699 &g12a_gp0_pll.hw, 3700 &g12a_hifi_pll.hw, 3701 &g12a_mpll1.hw, 3702 &g12a_fclk_div2.hw, 3703 &g12a_fclk_div2p5.hw, 3704 &g12a_fclk_div3.hw, 3705 &g12a_fclk_div7.hw, 3706 }; 3707 3708 static struct clk_regmap g12a_mipi_dsi_pxclk_sel = { 3709 .data = &(struct clk_regmap_mux_data){ 3710 .offset = HHI_MIPIDSI_PHY_CLK_CNTL, 3711 .mask = 0x7, 3712 .shift = 12, 3713 .flags = CLK_MUX_ROUND_CLOSEST, 3714 }, 3715 .hw.init = &(struct clk_init_data){ 3716 .name = "mipi_dsi_pxclk_sel", 3717 .ops = &clk_regmap_mux_ops, 3718 .parent_hws = g12a_mipi_dsi_pxclk_parent_hws, 3719 .num_parents = ARRAY_SIZE(g12a_mipi_dsi_pxclk_parent_hws), 3720 .flags = CLK_SET_RATE_NO_REPARENT, 3721 }, 3722 }; 3723 3724 static struct clk_regmap g12a_mipi_dsi_pxclk_div = { 3725 .data = &(struct clk_regmap_div_data){ 3726 .offset = HHI_MIPIDSI_PHY_CLK_CNTL, 3727 .shift = 0, 3728 .width = 7, 3729 }, 3730 .hw.init = &(struct clk_init_data){ 3731 .name = "mipi_dsi_pxclk_div", 3732 .ops = &clk_regmap_divider_ops, 3733 .parent_hws = (const struct clk_hw *[]) { 3734 &g12a_mipi_dsi_pxclk_sel.hw 3735 }, 3736 .num_parents = 1, 3737 .flags = CLK_SET_RATE_PARENT, 3738 }, 3739 }; 3740 3741 static struct clk_regmap g12a_mipi_dsi_pxclk = { 3742 .data = &(struct clk_regmap_gate_data){ 3743 .offset = HHI_MIPIDSI_PHY_CLK_CNTL, 3744 .bit_idx = 8, 3745 }, 3746 .hw.init = &(struct clk_init_data) { 3747 .name = "mipi_dsi_pxclk", 3748 .ops = &clk_regmap_gate_ops, 3749 .parent_hws = (const struct clk_hw *[]) { 3750 &g12a_mipi_dsi_pxclk_div.hw 3751 }, 3752 .num_parents = 1, 3753 .flags = CLK_SET_RATE_PARENT, 3754 }, 3755 }; 3756 3757 /* MIPI ISP Clocks */ 3758 3759 static const struct clk_parent_data g12b_mipi_isp_parent_data[] = { 3760 { .fw_name = "xtal", }, 3761 { .hw = &g12a_gp0_pll.hw }, 3762 { .hw = &g12a_hifi_pll.hw }, 3763 { .hw = &g12a_fclk_div2p5.hw }, 3764 { .hw = &g12a_fclk_div3.hw }, 3765 { .hw = &g12a_fclk_div4.hw }, 3766 { .hw = &g12a_fclk_div5.hw }, 3767 { .hw = &g12a_fclk_div7.hw }, 3768 }; 3769 3770 static struct clk_regmap g12b_mipi_isp_sel = { 3771 .data = &(struct clk_regmap_mux_data){ 3772 .offset = HHI_ISP_CLK_CNTL, 3773 .mask = 7, 3774 .shift = 9, 3775 }, 3776 .hw.init = &(struct clk_init_data){ 3777 .name = "mipi_isp_sel", 3778 .ops = &clk_regmap_mux_ops, 3779 .parent_data = g12b_mipi_isp_parent_data, 3780 .num_parents = ARRAY_SIZE(g12b_mipi_isp_parent_data), 3781 }, 3782 }; 3783 3784 static struct clk_regmap g12b_mipi_isp_div = { 3785 .data = &(struct clk_regmap_div_data){ 3786 .offset = HHI_ISP_CLK_CNTL, 3787 .shift = 0, 3788 .width = 7, 3789 }, 3790 .hw.init = &(struct clk_init_data){ 3791 .name = "mipi_isp_div", 3792 .ops = &clk_regmap_divider_ops, 3793 .parent_hws = (const struct clk_hw *[]) { 3794 &g12b_mipi_isp_sel.hw 3795 }, 3796 .num_parents = 1, 3797 .flags = CLK_SET_RATE_PARENT, 3798 }, 3799 }; 3800 3801 static struct clk_regmap g12b_mipi_isp = { 3802 .data = &(struct clk_regmap_gate_data){ 3803 .offset = HHI_ISP_CLK_CNTL, 3804 .bit_idx = 8, 3805 }, 3806 .hw.init = &(struct clk_init_data) { 3807 .name = "mipi_isp", 3808 .ops = &clk_regmap_gate_ops, 3809 .parent_hws = (const struct clk_hw *[]) { 3810 &g12b_mipi_isp_div.hw 3811 }, 3812 .num_parents = 1, 3813 .flags = CLK_SET_RATE_PARENT, 3814 }, 3815 }; 3816 3817 /* HDMI Clocks */ 3818 3819 static const struct clk_parent_data g12a_hdmi_parent_data[] = { 3820 { .fw_name = "xtal", }, 3821 { .hw = &g12a_fclk_div4.hw }, 3822 { .hw = &g12a_fclk_div3.hw }, 3823 { .hw = &g12a_fclk_div5.hw }, 3824 }; 3825 3826 static struct clk_regmap g12a_hdmi_sel = { 3827 .data = &(struct clk_regmap_mux_data){ 3828 .offset = HHI_HDMI_CLK_CNTL, 3829 .mask = 0x3, 3830 .shift = 9, 3831 .flags = CLK_MUX_ROUND_CLOSEST, 3832 }, 3833 .hw.init = &(struct clk_init_data){ 3834 .name = "hdmi_sel", 3835 .ops = &clk_regmap_mux_ops, 3836 .parent_data = g12a_hdmi_parent_data, 3837 .num_parents = ARRAY_SIZE(g12a_hdmi_parent_data), 3838 .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE, 3839 }, 3840 }; 3841 3842 static struct clk_regmap g12a_hdmi_div = { 3843 .data = &(struct clk_regmap_div_data){ 3844 .offset = HHI_HDMI_CLK_CNTL, 3845 .shift = 0, 3846 .width = 7, 3847 }, 3848 .hw.init = &(struct clk_init_data){ 3849 .name = "hdmi_div", 3850 .ops = &clk_regmap_divider_ops, 3851 .parent_hws = (const struct clk_hw *[]) { &g12a_hdmi_sel.hw }, 3852 .num_parents = 1, 3853 .flags = CLK_GET_RATE_NOCACHE, 3854 }, 3855 }; 3856 3857 static struct clk_regmap g12a_hdmi = { 3858 .data = &(struct clk_regmap_gate_data){ 3859 .offset = HHI_HDMI_CLK_CNTL, 3860 .bit_idx = 8, 3861 }, 3862 .hw.init = &(struct clk_init_data) { 3863 .name = "hdmi", 3864 .ops = &clk_regmap_gate_ops, 3865 .parent_hws = (const struct clk_hw *[]) { &g12a_hdmi_div.hw }, 3866 .num_parents = 1, 3867 .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED, 3868 }, 3869 }; 3870 3871 /* 3872 * The MALI IP is clocked by two identical clocks (mali_0 and mali_1) 3873 * muxed by a glitch-free switch. The CCF can manage this glitch-free 3874 * mux because it does top-to-bottom updates the each clock tree and 3875 * switches to the "inactive" one when CLK_SET_RATE_GATE is set. 3876 */ 3877 static const struct clk_parent_data g12a_mali_0_1_parent_data[] = { 3878 { .fw_name = "xtal", }, 3879 { .hw = &g12a_gp0_pll.hw }, 3880 { .hw = &g12a_hifi_pll.hw }, 3881 { .hw = &g12a_fclk_div2p5.hw }, 3882 { .hw = &g12a_fclk_div3.hw }, 3883 { .hw = &g12a_fclk_div4.hw }, 3884 { .hw = &g12a_fclk_div5.hw }, 3885 { .hw = &g12a_fclk_div7.hw }, 3886 }; 3887 3888 static struct clk_regmap g12a_mali_0_sel = { 3889 .data = &(struct clk_regmap_mux_data){ 3890 .offset = HHI_MALI_CLK_CNTL, 3891 .mask = 0x7, 3892 .shift = 9, 3893 }, 3894 .hw.init = &(struct clk_init_data){ 3895 .name = "mali_0_sel", 3896 .ops = &clk_regmap_mux_ops, 3897 .parent_data = g12a_mali_0_1_parent_data, 3898 .num_parents = 8, 3899 /* 3900 * Don't request the parent to change the rate because 3901 * all GPU frequencies can be derived from the fclk_* 3902 * clocks and one special GP0_PLL setting. This is 3903 * important because we need the MPLL clocks for audio. 3904 */ 3905 .flags = 0, 3906 }, 3907 }; 3908 3909 static struct clk_regmap g12a_mali_0_div = { 3910 .data = &(struct clk_regmap_div_data){ 3911 .offset = HHI_MALI_CLK_CNTL, 3912 .shift = 0, 3913 .width = 7, 3914 }, 3915 .hw.init = &(struct clk_init_data){ 3916 .name = "mali_0_div", 3917 .ops = &clk_regmap_divider_ops, 3918 .parent_hws = (const struct clk_hw *[]) { 3919 &g12a_mali_0_sel.hw 3920 }, 3921 .num_parents = 1, 3922 .flags = CLK_SET_RATE_PARENT, 3923 }, 3924 }; 3925 3926 static struct clk_regmap g12a_mali_0 = { 3927 .data = &(struct clk_regmap_gate_data){ 3928 .offset = HHI_MALI_CLK_CNTL, 3929 .bit_idx = 8, 3930 }, 3931 .hw.init = &(struct clk_init_data){ 3932 .name = "mali_0", 3933 .ops = &clk_regmap_gate_ops, 3934 .parent_hws = (const struct clk_hw *[]) { 3935 &g12a_mali_0_div.hw 3936 }, 3937 .num_parents = 1, 3938 .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT, 3939 }, 3940 }; 3941 3942 static struct clk_regmap g12a_mali_1_sel = { 3943 .data = &(struct clk_regmap_mux_data){ 3944 .offset = HHI_MALI_CLK_CNTL, 3945 .mask = 0x7, 3946 .shift = 25, 3947 }, 3948 .hw.init = &(struct clk_init_data){ 3949 .name = "mali_1_sel", 3950 .ops = &clk_regmap_mux_ops, 3951 .parent_data = g12a_mali_0_1_parent_data, 3952 .num_parents = 8, 3953 /* 3954 * Don't request the parent to change the rate because 3955 * all GPU frequencies can be derived from the fclk_* 3956 * clocks and one special GP0_PLL setting. This is 3957 * important because we need the MPLL clocks for audio. 3958 */ 3959 .flags = 0, 3960 }, 3961 }; 3962 3963 static struct clk_regmap g12a_mali_1_div = { 3964 .data = &(struct clk_regmap_div_data){ 3965 .offset = HHI_MALI_CLK_CNTL, 3966 .shift = 16, 3967 .width = 7, 3968 }, 3969 .hw.init = &(struct clk_init_data){ 3970 .name = "mali_1_div", 3971 .ops = &clk_regmap_divider_ops, 3972 .parent_hws = (const struct clk_hw *[]) { 3973 &g12a_mali_1_sel.hw 3974 }, 3975 .num_parents = 1, 3976 .flags = CLK_SET_RATE_PARENT, 3977 }, 3978 }; 3979 3980 static struct clk_regmap g12a_mali_1 = { 3981 .data = &(struct clk_regmap_gate_data){ 3982 .offset = HHI_MALI_CLK_CNTL, 3983 .bit_idx = 24, 3984 }, 3985 .hw.init = &(struct clk_init_data){ 3986 .name = "mali_1", 3987 .ops = &clk_regmap_gate_ops, 3988 .parent_hws = (const struct clk_hw *[]) { 3989 &g12a_mali_1_div.hw 3990 }, 3991 .num_parents = 1, 3992 .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT, 3993 }, 3994 }; 3995 3996 static const struct clk_hw *g12a_mali_parent_hws[] = { 3997 &g12a_mali_0.hw, 3998 &g12a_mali_1.hw, 3999 }; 4000 4001 static struct clk_regmap g12a_mali = { 4002 .data = &(struct clk_regmap_mux_data){ 4003 .offset = HHI_MALI_CLK_CNTL, 4004 .mask = 1, 4005 .shift = 31, 4006 }, 4007 .hw.init = &(struct clk_init_data){ 4008 .name = "mali", 4009 .ops = &clk_regmap_mux_ops, 4010 .parent_hws = g12a_mali_parent_hws, 4011 .num_parents = 2, 4012 .flags = CLK_SET_RATE_PARENT, 4013 }, 4014 }; 4015 4016 static struct clk_regmap g12a_ts_div = { 4017 .data = &(struct clk_regmap_div_data){ 4018 .offset = HHI_TS_CLK_CNTL, 4019 .shift = 0, 4020 .width = 8, 4021 }, 4022 .hw.init = &(struct clk_init_data){ 4023 .name = "ts_div", 4024 .ops = &clk_regmap_divider_ro_ops, 4025 .parent_data = &(const struct clk_parent_data) { 4026 .fw_name = "xtal", 4027 }, 4028 .num_parents = 1, 4029 }, 4030 }; 4031 4032 static struct clk_regmap g12a_ts = { 4033 .data = &(struct clk_regmap_gate_data){ 4034 .offset = HHI_TS_CLK_CNTL, 4035 .bit_idx = 8, 4036 }, 4037 .hw.init = &(struct clk_init_data){ 4038 .name = "ts", 4039 .ops = &clk_regmap_gate_ops, 4040 .parent_hws = (const struct clk_hw *[]) { 4041 &g12a_ts_div.hw 4042 }, 4043 .num_parents = 1, 4044 }, 4045 }; 4046 4047 /* SPICC SCLK source clock */ 4048 4049 static const struct clk_parent_data spicc_sclk_parent_data[] = { 4050 { .fw_name = "xtal", }, 4051 { .hw = &g12a_clk81.hw }, 4052 { .hw = &g12a_fclk_div4.hw }, 4053 { .hw = &g12a_fclk_div3.hw }, 4054 { .hw = &g12a_fclk_div5.hw }, 4055 { .hw = &g12a_fclk_div7.hw }, 4056 }; 4057 4058 static struct clk_regmap g12a_spicc0_sclk_sel = { 4059 .data = &(struct clk_regmap_mux_data){ 4060 .offset = HHI_SPICC_CLK_CNTL, 4061 .mask = 7, 4062 .shift = 7, 4063 }, 4064 .hw.init = &(struct clk_init_data){ 4065 .name = "spicc0_sclk_sel", 4066 .ops = &clk_regmap_mux_ops, 4067 .parent_data = spicc_sclk_parent_data, 4068 .num_parents = ARRAY_SIZE(spicc_sclk_parent_data), 4069 }, 4070 }; 4071 4072 static struct clk_regmap g12a_spicc0_sclk_div = { 4073 .data = &(struct clk_regmap_div_data){ 4074 .offset = HHI_SPICC_CLK_CNTL, 4075 .shift = 0, 4076 .width = 6, 4077 }, 4078 .hw.init = &(struct clk_init_data){ 4079 .name = "spicc0_sclk_div", 4080 .ops = &clk_regmap_divider_ops, 4081 .parent_hws = (const struct clk_hw *[]) { 4082 &g12a_spicc0_sclk_sel.hw 4083 }, 4084 .num_parents = 1, 4085 .flags = CLK_SET_RATE_PARENT, 4086 }, 4087 }; 4088 4089 static struct clk_regmap g12a_spicc0_sclk = { 4090 .data = &(struct clk_regmap_gate_data){ 4091 .offset = HHI_SPICC_CLK_CNTL, 4092 .bit_idx = 6, 4093 }, 4094 .hw.init = &(struct clk_init_data){ 4095 .name = "spicc0_sclk", 4096 .ops = &clk_regmap_gate_ops, 4097 .parent_hws = (const struct clk_hw *[]) { 4098 &g12a_spicc0_sclk_div.hw 4099 }, 4100 .num_parents = 1, 4101 .flags = CLK_SET_RATE_PARENT, 4102 }, 4103 }; 4104 4105 static struct clk_regmap g12a_spicc1_sclk_sel = { 4106 .data = &(struct clk_regmap_mux_data){ 4107 .offset = HHI_SPICC_CLK_CNTL, 4108 .mask = 7, 4109 .shift = 23, 4110 }, 4111 .hw.init = &(struct clk_init_data){ 4112 .name = "spicc1_sclk_sel", 4113 .ops = &clk_regmap_mux_ops, 4114 .parent_data = spicc_sclk_parent_data, 4115 .num_parents = ARRAY_SIZE(spicc_sclk_parent_data), 4116 }, 4117 }; 4118 4119 static struct clk_regmap g12a_spicc1_sclk_div = { 4120 .data = &(struct clk_regmap_div_data){ 4121 .offset = HHI_SPICC_CLK_CNTL, 4122 .shift = 16, 4123 .width = 6, 4124 }, 4125 .hw.init = &(struct clk_init_data){ 4126 .name = "spicc1_sclk_div", 4127 .ops = &clk_regmap_divider_ops, 4128 .parent_hws = (const struct clk_hw *[]) { 4129 &g12a_spicc1_sclk_sel.hw 4130 }, 4131 .num_parents = 1, 4132 .flags = CLK_SET_RATE_PARENT, 4133 }, 4134 }; 4135 4136 static struct clk_regmap g12a_spicc1_sclk = { 4137 .data = &(struct clk_regmap_gate_data){ 4138 .offset = HHI_SPICC_CLK_CNTL, 4139 .bit_idx = 22, 4140 }, 4141 .hw.init = &(struct clk_init_data){ 4142 .name = "spicc1_sclk", 4143 .ops = &clk_regmap_gate_ops, 4144 .parent_hws = (const struct clk_hw *[]) { 4145 &g12a_spicc1_sclk_div.hw 4146 }, 4147 .num_parents = 1, 4148 .flags = CLK_SET_RATE_PARENT, 4149 }, 4150 }; 4151 4152 /* Neural Network Accelerator source clock */ 4153 4154 static const struct clk_parent_data nna_clk_parent_data[] = { 4155 { .fw_name = "xtal", }, 4156 { .hw = &g12a_gp0_pll.hw, }, 4157 { .hw = &g12a_hifi_pll.hw, }, 4158 { .hw = &g12a_fclk_div2p5.hw, }, 4159 { .hw = &g12a_fclk_div3.hw, }, 4160 { .hw = &g12a_fclk_div4.hw, }, 4161 { .hw = &g12a_fclk_div5.hw, }, 4162 { .hw = &g12a_fclk_div7.hw }, 4163 }; 4164 4165 static struct clk_regmap sm1_nna_axi_clk_sel = { 4166 .data = &(struct clk_regmap_mux_data){ 4167 .offset = HHI_NNA_CLK_CNTL, 4168 .mask = 7, 4169 .shift = 9, 4170 }, 4171 .hw.init = &(struct clk_init_data){ 4172 .name = "nna_axi_clk_sel", 4173 .ops = &clk_regmap_mux_ops, 4174 .parent_data = nna_clk_parent_data, 4175 .num_parents = ARRAY_SIZE(nna_clk_parent_data), 4176 }, 4177 }; 4178 4179 static struct clk_regmap sm1_nna_axi_clk_div = { 4180 .data = &(struct clk_regmap_div_data){ 4181 .offset = HHI_NNA_CLK_CNTL, 4182 .shift = 0, 4183 .width = 7, 4184 }, 4185 .hw.init = &(struct clk_init_data){ 4186 .name = "nna_axi_clk_div", 4187 .ops = &clk_regmap_divider_ops, 4188 .parent_hws = (const struct clk_hw *[]) { 4189 &sm1_nna_axi_clk_sel.hw 4190 }, 4191 .num_parents = 1, 4192 .flags = CLK_SET_RATE_PARENT, 4193 }, 4194 }; 4195 4196 static struct clk_regmap sm1_nna_axi_clk = { 4197 .data = &(struct clk_regmap_gate_data){ 4198 .offset = HHI_NNA_CLK_CNTL, 4199 .bit_idx = 8, 4200 }, 4201 .hw.init = &(struct clk_init_data){ 4202 .name = "nna_axi_clk", 4203 .ops = &clk_regmap_gate_ops, 4204 .parent_hws = (const struct clk_hw *[]) { 4205 &sm1_nna_axi_clk_div.hw 4206 }, 4207 .num_parents = 1, 4208 .flags = CLK_SET_RATE_PARENT, 4209 }, 4210 }; 4211 4212 static struct clk_regmap sm1_nna_core_clk_sel = { 4213 .data = &(struct clk_regmap_mux_data){ 4214 .offset = HHI_NNA_CLK_CNTL, 4215 .mask = 7, 4216 .shift = 25, 4217 }, 4218 .hw.init = &(struct clk_init_data){ 4219 .name = "nna_core_clk_sel", 4220 .ops = &clk_regmap_mux_ops, 4221 .parent_data = nna_clk_parent_data, 4222 .num_parents = ARRAY_SIZE(nna_clk_parent_data), 4223 }, 4224 }; 4225 4226 static struct clk_regmap sm1_nna_core_clk_div = { 4227 .data = &(struct clk_regmap_div_data){ 4228 .offset = HHI_NNA_CLK_CNTL, 4229 .shift = 16, 4230 .width = 7, 4231 }, 4232 .hw.init = &(struct clk_init_data){ 4233 .name = "nna_core_clk_div", 4234 .ops = &clk_regmap_divider_ops, 4235 .parent_hws = (const struct clk_hw *[]) { 4236 &sm1_nna_core_clk_sel.hw 4237 }, 4238 .num_parents = 1, 4239 .flags = CLK_SET_RATE_PARENT, 4240 }, 4241 }; 4242 4243 static struct clk_regmap sm1_nna_core_clk = { 4244 .data = &(struct clk_regmap_gate_data){ 4245 .offset = HHI_NNA_CLK_CNTL, 4246 .bit_idx = 24, 4247 }, 4248 .hw.init = &(struct clk_init_data){ 4249 .name = "nna_core_clk", 4250 .ops = &clk_regmap_gate_ops, 4251 .parent_hws = (const struct clk_hw *[]) { 4252 &sm1_nna_core_clk_div.hw 4253 }, 4254 .num_parents = 1, 4255 .flags = CLK_SET_RATE_PARENT, 4256 }, 4257 }; 4258 4259 #define MESON_GATE(_name, _reg, _bit) \ 4260 MESON_PCLK(_name, _reg, _bit, &g12a_clk81.hw) 4261 4262 #define MESON_GATE_RO(_name, _reg, _bit) \ 4263 MESON_PCLK_RO(_name, _reg, _bit, &g12a_clk81.hw) 4264 4265 /* Everything Else (EE) domain gates */ 4266 static MESON_GATE(g12a_ddr, HHI_GCLK_MPEG0, 0); 4267 static MESON_GATE(g12a_dos, HHI_GCLK_MPEG0, 1); 4268 static MESON_GATE(g12a_audio_locker, HHI_GCLK_MPEG0, 2); 4269 static MESON_GATE(g12a_mipi_dsi_host, HHI_GCLK_MPEG0, 3); 4270 static MESON_GATE(g12a_eth_phy, HHI_GCLK_MPEG0, 4); 4271 static MESON_GATE(g12a_isa, HHI_GCLK_MPEG0, 5); 4272 static MESON_GATE(g12a_pl301, HHI_GCLK_MPEG0, 6); 4273 static MESON_GATE(g12a_periphs, HHI_GCLK_MPEG0, 7); 4274 static MESON_GATE(g12a_spicc_0, HHI_GCLK_MPEG0, 8); 4275 static MESON_GATE(g12a_i2c, HHI_GCLK_MPEG0, 9); 4276 static MESON_GATE(g12a_sana, HHI_GCLK_MPEG0, 10); 4277 static MESON_GATE(g12a_sd, HHI_GCLK_MPEG0, 11); 4278 static MESON_GATE(g12a_rng0, HHI_GCLK_MPEG0, 12); 4279 static MESON_GATE(g12a_uart0, HHI_GCLK_MPEG0, 13); 4280 static MESON_GATE(g12a_spicc_1, HHI_GCLK_MPEG0, 14); 4281 static MESON_GATE(g12a_hiu_reg, HHI_GCLK_MPEG0, 19); 4282 static MESON_GATE(g12a_mipi_dsi_phy, HHI_GCLK_MPEG0, 20); 4283 static MESON_GATE(g12a_assist_misc, HHI_GCLK_MPEG0, 23); 4284 static MESON_GATE(g12a_emmc_a, HHI_GCLK_MPEG0, 4); 4285 static MESON_GATE(g12a_emmc_b, HHI_GCLK_MPEG0, 25); 4286 static MESON_GATE(g12a_emmc_c, HHI_GCLK_MPEG0, 26); 4287 static MESON_GATE(g12a_audio_codec, HHI_GCLK_MPEG0, 28); 4288 4289 static MESON_GATE(g12a_audio, HHI_GCLK_MPEG1, 0); 4290 static MESON_GATE(g12a_eth_core, HHI_GCLK_MPEG1, 3); 4291 static MESON_GATE(g12a_demux, HHI_GCLK_MPEG1, 4); 4292 static MESON_GATE(g12a_audio_ififo, HHI_GCLK_MPEG1, 11); 4293 static MESON_GATE(g12a_adc, HHI_GCLK_MPEG1, 13); 4294 static MESON_GATE(g12a_uart1, HHI_GCLK_MPEG1, 16); 4295 static MESON_GATE(g12a_g2d, HHI_GCLK_MPEG1, 20); 4296 static MESON_GATE(g12a_reset, HHI_GCLK_MPEG1, 23); 4297 static MESON_GATE(g12a_pcie_comb, HHI_GCLK_MPEG1, 24); 4298 static MESON_GATE(g12a_parser, HHI_GCLK_MPEG1, 25); 4299 static MESON_GATE(g12a_usb_general, HHI_GCLK_MPEG1, 26); 4300 static MESON_GATE(g12a_pcie_phy, HHI_GCLK_MPEG1, 27); 4301 static MESON_GATE(g12a_ahb_arb0, HHI_GCLK_MPEG1, 29); 4302 4303 static MESON_GATE(g12a_ahb_data_bus, HHI_GCLK_MPEG2, 1); 4304 static MESON_GATE(g12a_ahb_ctrl_bus, HHI_GCLK_MPEG2, 2); 4305 static MESON_GATE(g12a_htx_hdcp22, HHI_GCLK_MPEG2, 3); 4306 static MESON_GATE(g12a_htx_pclk, HHI_GCLK_MPEG2, 4); 4307 static MESON_GATE(g12a_bt656, HHI_GCLK_MPEG2, 6); 4308 static MESON_GATE(g12a_usb1_to_ddr, HHI_GCLK_MPEG2, 8); 4309 static MESON_GATE(g12b_mipi_isp_gate, HHI_GCLK_MPEG2, 17); 4310 static MESON_GATE(g12a_mmc_pclk, HHI_GCLK_MPEG2, 11); 4311 static MESON_GATE(g12a_uart2, HHI_GCLK_MPEG2, 15); 4312 static MESON_GATE(g12a_vpu_intr, HHI_GCLK_MPEG2, 25); 4313 static MESON_GATE(g12b_csi_phy1, HHI_GCLK_MPEG2, 28); 4314 static MESON_GATE(g12b_csi_phy0, HHI_GCLK_MPEG2, 29); 4315 static MESON_GATE(g12a_gic, HHI_GCLK_MPEG2, 30); 4316 4317 static MESON_GATE(g12a_vclk2_venci0, HHI_GCLK_OTHER, 1); 4318 static MESON_GATE(g12a_vclk2_venci1, HHI_GCLK_OTHER, 2); 4319 static MESON_GATE(g12a_vclk2_vencp0, HHI_GCLK_OTHER, 3); 4320 static MESON_GATE(g12a_vclk2_vencp1, HHI_GCLK_OTHER, 4); 4321 static MESON_GATE(g12a_vclk2_venct0, HHI_GCLK_OTHER, 5); 4322 static MESON_GATE(g12a_vclk2_venct1, HHI_GCLK_OTHER, 6); 4323 static MESON_GATE(g12a_vclk2_other, HHI_GCLK_OTHER, 7); 4324 static MESON_GATE(g12a_vclk2_enci, HHI_GCLK_OTHER, 8); 4325 static MESON_GATE(g12a_vclk2_encp, HHI_GCLK_OTHER, 9); 4326 static MESON_GATE(g12a_dac_clk, HHI_GCLK_OTHER, 10); 4327 static MESON_GATE(g12a_aoclk_gate, HHI_GCLK_OTHER, 14); 4328 static MESON_GATE(g12a_iec958_gate, HHI_GCLK_OTHER, 16); 4329 static MESON_GATE(g12a_enc480p, HHI_GCLK_OTHER, 20); 4330 static MESON_GATE(g12a_rng1, HHI_GCLK_OTHER, 21); 4331 static MESON_GATE(g12a_vclk2_enct, HHI_GCLK_OTHER, 22); 4332 static MESON_GATE(g12a_vclk2_encl, HHI_GCLK_OTHER, 23); 4333 static MESON_GATE(g12a_vclk2_venclmmc, HHI_GCLK_OTHER, 24); 4334 static MESON_GATE(g12a_vclk2_vencl, HHI_GCLK_OTHER, 25); 4335 static MESON_GATE(g12a_vclk2_other1, HHI_GCLK_OTHER, 26); 4336 4337 static MESON_GATE_RO(g12a_dma, HHI_GCLK_OTHER2, 0); 4338 static MESON_GATE_RO(g12a_efuse, HHI_GCLK_OTHER2, 1); 4339 static MESON_GATE_RO(g12a_rom_boot, HHI_GCLK_OTHER2, 2); 4340 static MESON_GATE_RO(g12a_reset_sec, HHI_GCLK_OTHER2, 3); 4341 static MESON_GATE_RO(g12a_sec_ahb_apb3, HHI_GCLK_OTHER2, 4); 4342 4343 /* Array of all clocks provided by this provider */ 4344 static struct clk_hw *g12a_hw_clks[] = { 4345 [CLKID_SYS_PLL] = &g12a_sys_pll.hw, 4346 [CLKID_FIXED_PLL] = &g12a_fixed_pll.hw, 4347 [CLKID_FCLK_DIV2] = &g12a_fclk_div2.hw, 4348 [CLKID_FCLK_DIV3] = &g12a_fclk_div3.hw, 4349 [CLKID_FCLK_DIV4] = &g12a_fclk_div4.hw, 4350 [CLKID_FCLK_DIV5] = &g12a_fclk_div5.hw, 4351 [CLKID_FCLK_DIV7] = &g12a_fclk_div7.hw, 4352 [CLKID_FCLK_DIV2P5] = &g12a_fclk_div2p5.hw, 4353 [CLKID_GP0_PLL] = &g12a_gp0_pll.hw, 4354 [CLKID_MPEG_SEL] = &g12a_mpeg_clk_sel.hw, 4355 [CLKID_MPEG_DIV] = &g12a_mpeg_clk_div.hw, 4356 [CLKID_CLK81] = &g12a_clk81.hw, 4357 [CLKID_MPLL0] = &g12a_mpll0.hw, 4358 [CLKID_MPLL1] = &g12a_mpll1.hw, 4359 [CLKID_MPLL2] = &g12a_mpll2.hw, 4360 [CLKID_MPLL3] = &g12a_mpll3.hw, 4361 [CLKID_DDR] = &g12a_ddr.hw, 4362 [CLKID_DOS] = &g12a_dos.hw, 4363 [CLKID_AUDIO_LOCKER] = &g12a_audio_locker.hw, 4364 [CLKID_MIPI_DSI_HOST] = &g12a_mipi_dsi_host.hw, 4365 [CLKID_ETH_PHY] = &g12a_eth_phy.hw, 4366 [CLKID_ISA] = &g12a_isa.hw, 4367 [CLKID_PL301] = &g12a_pl301.hw, 4368 [CLKID_PERIPHS] = &g12a_periphs.hw, 4369 [CLKID_SPICC0] = &g12a_spicc_0.hw, 4370 [CLKID_I2C] = &g12a_i2c.hw, 4371 [CLKID_SANA] = &g12a_sana.hw, 4372 [CLKID_SD] = &g12a_sd.hw, 4373 [CLKID_RNG0] = &g12a_rng0.hw, 4374 [CLKID_UART0] = &g12a_uart0.hw, 4375 [CLKID_SPICC1] = &g12a_spicc_1.hw, 4376 [CLKID_HIU_IFACE] = &g12a_hiu_reg.hw, 4377 [CLKID_MIPI_DSI_PHY] = &g12a_mipi_dsi_phy.hw, 4378 [CLKID_ASSIST_MISC] = &g12a_assist_misc.hw, 4379 [CLKID_SD_EMMC_A] = &g12a_emmc_a.hw, 4380 [CLKID_SD_EMMC_B] = &g12a_emmc_b.hw, 4381 [CLKID_SD_EMMC_C] = &g12a_emmc_c.hw, 4382 [CLKID_AUDIO_CODEC] = &g12a_audio_codec.hw, 4383 [CLKID_AUDIO] = &g12a_audio.hw, 4384 [CLKID_ETH] = &g12a_eth_core.hw, 4385 [CLKID_DEMUX] = &g12a_demux.hw, 4386 [CLKID_AUDIO_IFIFO] = &g12a_audio_ififo.hw, 4387 [CLKID_ADC] = &g12a_adc.hw, 4388 [CLKID_UART1] = &g12a_uart1.hw, 4389 [CLKID_G2D] = &g12a_g2d.hw, 4390 [CLKID_RESET] = &g12a_reset.hw, 4391 [CLKID_PCIE_COMB] = &g12a_pcie_comb.hw, 4392 [CLKID_PARSER] = &g12a_parser.hw, 4393 [CLKID_USB] = &g12a_usb_general.hw, 4394 [CLKID_PCIE_PHY] = &g12a_pcie_phy.hw, 4395 [CLKID_AHB_ARB0] = &g12a_ahb_arb0.hw, 4396 [CLKID_AHB_DATA_BUS] = &g12a_ahb_data_bus.hw, 4397 [CLKID_AHB_CTRL_BUS] = &g12a_ahb_ctrl_bus.hw, 4398 [CLKID_HTX_HDCP22] = &g12a_htx_hdcp22.hw, 4399 [CLKID_HTX_PCLK] = &g12a_htx_pclk.hw, 4400 [CLKID_BT656] = &g12a_bt656.hw, 4401 [CLKID_USB1_DDR_BRIDGE] = &g12a_usb1_to_ddr.hw, 4402 [CLKID_MMC_PCLK] = &g12a_mmc_pclk.hw, 4403 [CLKID_UART2] = &g12a_uart2.hw, 4404 [CLKID_VPU_INTR] = &g12a_vpu_intr.hw, 4405 [CLKID_GIC] = &g12a_gic.hw, 4406 [CLKID_SD_EMMC_A_CLK0_SEL] = &g12a_sd_emmc_a_clk0_sel.hw, 4407 [CLKID_SD_EMMC_A_CLK0_DIV] = &g12a_sd_emmc_a_clk0_div.hw, 4408 [CLKID_SD_EMMC_A_CLK0] = &g12a_sd_emmc_a_clk0.hw, 4409 [CLKID_SD_EMMC_B_CLK0_SEL] = &g12a_sd_emmc_b_clk0_sel.hw, 4410 [CLKID_SD_EMMC_B_CLK0_DIV] = &g12a_sd_emmc_b_clk0_div.hw, 4411 [CLKID_SD_EMMC_B_CLK0] = &g12a_sd_emmc_b_clk0.hw, 4412 [CLKID_SD_EMMC_C_CLK0_SEL] = &g12a_sd_emmc_c_clk0_sel.hw, 4413 [CLKID_SD_EMMC_C_CLK0_DIV] = &g12a_sd_emmc_c_clk0_div.hw, 4414 [CLKID_SD_EMMC_C_CLK0] = &g12a_sd_emmc_c_clk0.hw, 4415 [CLKID_MPLL0_DIV] = &g12a_mpll0_div.hw, 4416 [CLKID_MPLL1_DIV] = &g12a_mpll1_div.hw, 4417 [CLKID_MPLL2_DIV] = &g12a_mpll2_div.hw, 4418 [CLKID_MPLL3_DIV] = &g12a_mpll3_div.hw, 4419 [CLKID_FCLK_DIV2_DIV] = &g12a_fclk_div2_div.hw, 4420 [CLKID_FCLK_DIV3_DIV] = &g12a_fclk_div3_div.hw, 4421 [CLKID_FCLK_DIV4_DIV] = &g12a_fclk_div4_div.hw, 4422 [CLKID_FCLK_DIV5_DIV] = &g12a_fclk_div5_div.hw, 4423 [CLKID_FCLK_DIV7_DIV] = &g12a_fclk_div7_div.hw, 4424 [CLKID_FCLK_DIV2P5_DIV] = &g12a_fclk_div2p5_div.hw, 4425 [CLKID_HIFI_PLL] = &g12a_hifi_pll.hw, 4426 [CLKID_VCLK2_VENCI0] = &g12a_vclk2_venci0.hw, 4427 [CLKID_VCLK2_VENCI1] = &g12a_vclk2_venci1.hw, 4428 [CLKID_VCLK2_VENCP0] = &g12a_vclk2_vencp0.hw, 4429 [CLKID_VCLK2_VENCP1] = &g12a_vclk2_vencp1.hw, 4430 [CLKID_VCLK2_VENCT0] = &g12a_vclk2_venct0.hw, 4431 [CLKID_VCLK2_VENCT1] = &g12a_vclk2_venct1.hw, 4432 [CLKID_VCLK2_OTHER] = &g12a_vclk2_other.hw, 4433 [CLKID_VCLK2_ENCI] = &g12a_vclk2_enci.hw, 4434 [CLKID_VCLK2_ENCP] = &g12a_vclk2_encp.hw, 4435 [CLKID_DAC_CLK] = &g12a_dac_clk.hw, 4436 [CLKID_AOCLK] = &g12a_aoclk_gate.hw, 4437 [CLKID_IEC958] = &g12a_iec958_gate.hw, 4438 [CLKID_ENC480P] = &g12a_enc480p.hw, 4439 [CLKID_RNG1] = &g12a_rng1.hw, 4440 [CLKID_VCLK2_ENCT] = &g12a_vclk2_enct.hw, 4441 [CLKID_VCLK2_ENCL] = &g12a_vclk2_encl.hw, 4442 [CLKID_VCLK2_VENCLMMC] = &g12a_vclk2_venclmmc.hw, 4443 [CLKID_VCLK2_VENCL] = &g12a_vclk2_vencl.hw, 4444 [CLKID_VCLK2_OTHER1] = &g12a_vclk2_other1.hw, 4445 [CLKID_FIXED_PLL_DCO] = &g12a_fixed_pll_dco.hw, 4446 [CLKID_SYS_PLL_DCO] = &g12a_sys_pll_dco.hw, 4447 [CLKID_GP0_PLL_DCO] = &g12a_gp0_pll_dco.hw, 4448 [CLKID_HIFI_PLL_DCO] = &g12a_hifi_pll_dco.hw, 4449 [CLKID_DMA] = &g12a_dma.hw, 4450 [CLKID_EFUSE] = &g12a_efuse.hw, 4451 [CLKID_ROM_BOOT] = &g12a_rom_boot.hw, 4452 [CLKID_RESET_SEC] = &g12a_reset_sec.hw, 4453 [CLKID_SEC_AHB_APB3] = &g12a_sec_ahb_apb3.hw, 4454 [CLKID_MPLL_PREDIV] = &g12a_mpll_prediv.hw, 4455 [CLKID_VPU_0_SEL] = &g12a_vpu_0_sel.hw, 4456 [CLKID_VPU_0_DIV] = &g12a_vpu_0_div.hw, 4457 [CLKID_VPU_0] = &g12a_vpu_0.hw, 4458 [CLKID_VPU_1_SEL] = &g12a_vpu_1_sel.hw, 4459 [CLKID_VPU_1_DIV] = &g12a_vpu_1_div.hw, 4460 [CLKID_VPU_1] = &g12a_vpu_1.hw, 4461 [CLKID_VPU] = &g12a_vpu.hw, 4462 [CLKID_VAPB_0_SEL] = &g12a_vapb_0_sel.hw, 4463 [CLKID_VAPB_0_DIV] = &g12a_vapb_0_div.hw, 4464 [CLKID_VAPB_0] = &g12a_vapb_0.hw, 4465 [CLKID_VAPB_1_SEL] = &g12a_vapb_1_sel.hw, 4466 [CLKID_VAPB_1_DIV] = &g12a_vapb_1_div.hw, 4467 [CLKID_VAPB_1] = &g12a_vapb_1.hw, 4468 [CLKID_VAPB_SEL] = &g12a_vapb_sel.hw, 4469 [CLKID_VAPB] = &g12a_vapb.hw, 4470 [CLKID_HDMI_PLL_DCO] = &g12a_hdmi_pll_dco.hw, 4471 [CLKID_HDMI_PLL_OD] = &g12a_hdmi_pll_od.hw, 4472 [CLKID_HDMI_PLL_OD2] = &g12a_hdmi_pll_od2.hw, 4473 [CLKID_HDMI_PLL] = &g12a_hdmi_pll.hw, 4474 [CLKID_VID_PLL] = &g12a_vid_pll_div.hw, 4475 [CLKID_VID_PLL_SEL] = &g12a_vid_pll_sel.hw, 4476 [CLKID_VID_PLL_DIV] = &g12a_vid_pll.hw, 4477 [CLKID_VCLK_SEL] = &g12a_vclk_sel.hw, 4478 [CLKID_VCLK2_SEL] = &g12a_vclk2_sel.hw, 4479 [CLKID_VCLK_INPUT] = &g12a_vclk_input.hw, 4480 [CLKID_VCLK2_INPUT] = &g12a_vclk2_input.hw, 4481 [CLKID_VCLK_DIV] = &g12a_vclk_div.hw, 4482 [CLKID_VCLK2_DIV] = &g12a_vclk2_div.hw, 4483 [CLKID_VCLK] = &g12a_vclk.hw, 4484 [CLKID_VCLK2] = &g12a_vclk2.hw, 4485 [CLKID_VCLK_DIV1] = &g12a_vclk_div1.hw, 4486 [CLKID_VCLK_DIV2_EN] = &g12a_vclk_div2_en.hw, 4487 [CLKID_VCLK_DIV4_EN] = &g12a_vclk_div4_en.hw, 4488 [CLKID_VCLK_DIV6_EN] = &g12a_vclk_div6_en.hw, 4489 [CLKID_VCLK_DIV12_EN] = &g12a_vclk_div12_en.hw, 4490 [CLKID_VCLK2_DIV1] = &g12a_vclk2_div1.hw, 4491 [CLKID_VCLK2_DIV2_EN] = &g12a_vclk2_div2_en.hw, 4492 [CLKID_VCLK2_DIV4_EN] = &g12a_vclk2_div4_en.hw, 4493 [CLKID_VCLK2_DIV6_EN] = &g12a_vclk2_div6_en.hw, 4494 [CLKID_VCLK2_DIV12_EN] = &g12a_vclk2_div12_en.hw, 4495 [CLKID_VCLK_DIV2] = &g12a_vclk_div2.hw, 4496 [CLKID_VCLK_DIV4] = &g12a_vclk_div4.hw, 4497 [CLKID_VCLK_DIV6] = &g12a_vclk_div6.hw, 4498 [CLKID_VCLK_DIV12] = &g12a_vclk_div12.hw, 4499 [CLKID_VCLK2_DIV2] = &g12a_vclk2_div2.hw, 4500 [CLKID_VCLK2_DIV4] = &g12a_vclk2_div4.hw, 4501 [CLKID_VCLK2_DIV6] = &g12a_vclk2_div6.hw, 4502 [CLKID_VCLK2_DIV12] = &g12a_vclk2_div12.hw, 4503 [CLKID_CTS_ENCI_SEL] = &g12a_cts_enci_sel.hw, 4504 [CLKID_CTS_ENCP_SEL] = &g12a_cts_encp_sel.hw, 4505 [CLKID_CTS_ENCL_SEL] = &g12a_cts_encl_sel.hw, 4506 [CLKID_CTS_VDAC_SEL] = &g12a_cts_vdac_sel.hw, 4507 [CLKID_HDMI_TX_SEL] = &g12a_hdmi_tx_sel.hw, 4508 [CLKID_CTS_ENCI] = &g12a_cts_enci.hw, 4509 [CLKID_CTS_ENCP] = &g12a_cts_encp.hw, 4510 [CLKID_CTS_ENCL] = &g12a_cts_encl.hw, 4511 [CLKID_CTS_VDAC] = &g12a_cts_vdac.hw, 4512 [CLKID_HDMI_TX] = &g12a_hdmi_tx.hw, 4513 [CLKID_HDMI_SEL] = &g12a_hdmi_sel.hw, 4514 [CLKID_HDMI_DIV] = &g12a_hdmi_div.hw, 4515 [CLKID_HDMI] = &g12a_hdmi.hw, 4516 [CLKID_MALI_0_SEL] = &g12a_mali_0_sel.hw, 4517 [CLKID_MALI_0_DIV] = &g12a_mali_0_div.hw, 4518 [CLKID_MALI_0] = &g12a_mali_0.hw, 4519 [CLKID_MALI_1_SEL] = &g12a_mali_1_sel.hw, 4520 [CLKID_MALI_1_DIV] = &g12a_mali_1_div.hw, 4521 [CLKID_MALI_1] = &g12a_mali_1.hw, 4522 [CLKID_MALI] = &g12a_mali.hw, 4523 [CLKID_MPLL_50M_DIV] = &g12a_mpll_50m_div.hw, 4524 [CLKID_MPLL_50M] = &g12a_mpll_50m.hw, 4525 [CLKID_SYS_PLL_DIV16_EN] = &g12a_sys_pll_div16_en.hw, 4526 [CLKID_SYS_PLL_DIV16] = &g12a_sys_pll_div16.hw, 4527 [CLKID_CPU_CLK_DYN0_SEL] = &g12a_cpu_clk_premux0.hw, 4528 [CLKID_CPU_CLK_DYN0_DIV] = &g12a_cpu_clk_mux0_div.hw, 4529 [CLKID_CPU_CLK_DYN0] = &g12a_cpu_clk_postmux0.hw, 4530 [CLKID_CPU_CLK_DYN1_SEL] = &g12a_cpu_clk_premux1.hw, 4531 [CLKID_CPU_CLK_DYN1_DIV] = &g12a_cpu_clk_mux1_div.hw, 4532 [CLKID_CPU_CLK_DYN1] = &g12a_cpu_clk_postmux1.hw, 4533 [CLKID_CPU_CLK_DYN] = &g12a_cpu_clk_dyn.hw, 4534 [CLKID_CPU_CLK] = &g12a_cpu_clk.hw, 4535 [CLKID_CPU_CLK_DIV16_EN] = &g12a_cpu_clk_div16_en.hw, 4536 [CLKID_CPU_CLK_DIV16] = &g12a_cpu_clk_div16.hw, 4537 [CLKID_CPU_CLK_APB_DIV] = &g12a_cpu_clk_apb_div.hw, 4538 [CLKID_CPU_CLK_APB] = &g12a_cpu_clk_apb.hw, 4539 [CLKID_CPU_CLK_ATB_DIV] = &g12a_cpu_clk_atb_div.hw, 4540 [CLKID_CPU_CLK_ATB] = &g12a_cpu_clk_atb.hw, 4541 [CLKID_CPU_CLK_AXI_DIV] = &g12a_cpu_clk_axi_div.hw, 4542 [CLKID_CPU_CLK_AXI] = &g12a_cpu_clk_axi.hw, 4543 [CLKID_CPU_CLK_TRACE_DIV] = &g12a_cpu_clk_trace_div.hw, 4544 [CLKID_CPU_CLK_TRACE] = &g12a_cpu_clk_trace.hw, 4545 [CLKID_PCIE_PLL_DCO] = &g12a_pcie_pll_dco.hw, 4546 [CLKID_PCIE_PLL_DCO_DIV2] = &g12a_pcie_pll_dco_div2.hw, 4547 [CLKID_PCIE_PLL_OD] = &g12a_pcie_pll_od.hw, 4548 [CLKID_PCIE_PLL] = &g12a_pcie_pll.hw, 4549 [CLKID_VDEC_1_SEL] = &g12a_vdec_1_sel.hw, 4550 [CLKID_VDEC_1_DIV] = &g12a_vdec_1_div.hw, 4551 [CLKID_VDEC_1] = &g12a_vdec_1.hw, 4552 [CLKID_VDEC_HEVC_SEL] = &g12a_vdec_hevc_sel.hw, 4553 [CLKID_VDEC_HEVC_DIV] = &g12a_vdec_hevc_div.hw, 4554 [CLKID_VDEC_HEVC] = &g12a_vdec_hevc.hw, 4555 [CLKID_VDEC_HEVCF_SEL] = &g12a_vdec_hevcf_sel.hw, 4556 [CLKID_VDEC_HEVCF_DIV] = &g12a_vdec_hevcf_div.hw, 4557 [CLKID_VDEC_HEVCF] = &g12a_vdec_hevcf.hw, 4558 [CLKID_TS_DIV] = &g12a_ts_div.hw, 4559 [CLKID_TS] = &g12a_ts.hw, 4560 [CLKID_SPICC0_SCLK_SEL] = &g12a_spicc0_sclk_sel.hw, 4561 [CLKID_SPICC0_SCLK_DIV] = &g12a_spicc0_sclk_div.hw, 4562 [CLKID_SPICC0_SCLK] = &g12a_spicc0_sclk.hw, 4563 [CLKID_SPICC1_SCLK_SEL] = &g12a_spicc1_sclk_sel.hw, 4564 [CLKID_SPICC1_SCLK_DIV] = &g12a_spicc1_sclk_div.hw, 4565 [CLKID_SPICC1_SCLK] = &g12a_spicc1_sclk.hw, 4566 [CLKID_MIPI_DSI_PXCLK_SEL] = &g12a_mipi_dsi_pxclk_sel.hw, 4567 [CLKID_MIPI_DSI_PXCLK_DIV] = &g12a_mipi_dsi_pxclk_div.hw, 4568 [CLKID_MIPI_DSI_PXCLK] = &g12a_mipi_dsi_pxclk.hw, 4569 }; 4570 4571 static struct clk_hw *g12b_hw_clks[] = { 4572 [CLKID_SYS_PLL] = &g12a_sys_pll.hw, 4573 [CLKID_FIXED_PLL] = &g12a_fixed_pll.hw, 4574 [CLKID_FCLK_DIV2] = &g12a_fclk_div2.hw, 4575 [CLKID_FCLK_DIV3] = &g12a_fclk_div3.hw, 4576 [CLKID_FCLK_DIV4] = &g12a_fclk_div4.hw, 4577 [CLKID_FCLK_DIV5] = &g12a_fclk_div5.hw, 4578 [CLKID_FCLK_DIV7] = &g12a_fclk_div7.hw, 4579 [CLKID_FCLK_DIV2P5] = &g12a_fclk_div2p5.hw, 4580 [CLKID_GP0_PLL] = &g12a_gp0_pll.hw, 4581 [CLKID_MPEG_SEL] = &g12a_mpeg_clk_sel.hw, 4582 [CLKID_MPEG_DIV] = &g12a_mpeg_clk_div.hw, 4583 [CLKID_CLK81] = &g12a_clk81.hw, 4584 [CLKID_MPLL0] = &g12a_mpll0.hw, 4585 [CLKID_MPLL1] = &g12a_mpll1.hw, 4586 [CLKID_MPLL2] = &g12a_mpll2.hw, 4587 [CLKID_MPLL3] = &g12a_mpll3.hw, 4588 [CLKID_DDR] = &g12a_ddr.hw, 4589 [CLKID_DOS] = &g12a_dos.hw, 4590 [CLKID_AUDIO_LOCKER] = &g12a_audio_locker.hw, 4591 [CLKID_MIPI_DSI_HOST] = &g12a_mipi_dsi_host.hw, 4592 [CLKID_ETH_PHY] = &g12a_eth_phy.hw, 4593 [CLKID_ISA] = &g12a_isa.hw, 4594 [CLKID_PL301] = &g12a_pl301.hw, 4595 [CLKID_PERIPHS] = &g12a_periphs.hw, 4596 [CLKID_SPICC0] = &g12a_spicc_0.hw, 4597 [CLKID_I2C] = &g12a_i2c.hw, 4598 [CLKID_SANA] = &g12a_sana.hw, 4599 [CLKID_SD] = &g12a_sd.hw, 4600 [CLKID_RNG0] = &g12a_rng0.hw, 4601 [CLKID_UART0] = &g12a_uart0.hw, 4602 [CLKID_SPICC1] = &g12a_spicc_1.hw, 4603 [CLKID_HIU_IFACE] = &g12a_hiu_reg.hw, 4604 [CLKID_MIPI_DSI_PHY] = &g12a_mipi_dsi_phy.hw, 4605 [CLKID_ASSIST_MISC] = &g12a_assist_misc.hw, 4606 [CLKID_SD_EMMC_A] = &g12a_emmc_a.hw, 4607 [CLKID_SD_EMMC_B] = &g12a_emmc_b.hw, 4608 [CLKID_SD_EMMC_C] = &g12a_emmc_c.hw, 4609 [CLKID_AUDIO_CODEC] = &g12a_audio_codec.hw, 4610 [CLKID_AUDIO] = &g12a_audio.hw, 4611 [CLKID_ETH] = &g12a_eth_core.hw, 4612 [CLKID_DEMUX] = &g12a_demux.hw, 4613 [CLKID_AUDIO_IFIFO] = &g12a_audio_ififo.hw, 4614 [CLKID_ADC] = &g12a_adc.hw, 4615 [CLKID_UART1] = &g12a_uart1.hw, 4616 [CLKID_G2D] = &g12a_g2d.hw, 4617 [CLKID_RESET] = &g12a_reset.hw, 4618 [CLKID_PCIE_COMB] = &g12a_pcie_comb.hw, 4619 [CLKID_PARSER] = &g12a_parser.hw, 4620 [CLKID_USB] = &g12a_usb_general.hw, 4621 [CLKID_PCIE_PHY] = &g12a_pcie_phy.hw, 4622 [CLKID_AHB_ARB0] = &g12a_ahb_arb0.hw, 4623 [CLKID_AHB_DATA_BUS] = &g12a_ahb_data_bus.hw, 4624 [CLKID_AHB_CTRL_BUS] = &g12a_ahb_ctrl_bus.hw, 4625 [CLKID_HTX_HDCP22] = &g12a_htx_hdcp22.hw, 4626 [CLKID_HTX_PCLK] = &g12a_htx_pclk.hw, 4627 [CLKID_BT656] = &g12a_bt656.hw, 4628 [CLKID_USB1_DDR_BRIDGE] = &g12a_usb1_to_ddr.hw, 4629 [CLKID_MMC_PCLK] = &g12a_mmc_pclk.hw, 4630 [CLKID_UART2] = &g12a_uart2.hw, 4631 [CLKID_VPU_INTR] = &g12a_vpu_intr.hw, 4632 [CLKID_GIC] = &g12a_gic.hw, 4633 [CLKID_SD_EMMC_A_CLK0_SEL] = &g12a_sd_emmc_a_clk0_sel.hw, 4634 [CLKID_SD_EMMC_A_CLK0_DIV] = &g12a_sd_emmc_a_clk0_div.hw, 4635 [CLKID_SD_EMMC_A_CLK0] = &g12a_sd_emmc_a_clk0.hw, 4636 [CLKID_SD_EMMC_B_CLK0_SEL] = &g12a_sd_emmc_b_clk0_sel.hw, 4637 [CLKID_SD_EMMC_B_CLK0_DIV] = &g12a_sd_emmc_b_clk0_div.hw, 4638 [CLKID_SD_EMMC_B_CLK0] = &g12a_sd_emmc_b_clk0.hw, 4639 [CLKID_SD_EMMC_C_CLK0_SEL] = &g12a_sd_emmc_c_clk0_sel.hw, 4640 [CLKID_SD_EMMC_C_CLK0_DIV] = &g12a_sd_emmc_c_clk0_div.hw, 4641 [CLKID_SD_EMMC_C_CLK0] = &g12a_sd_emmc_c_clk0.hw, 4642 [CLKID_MPLL0_DIV] = &g12a_mpll0_div.hw, 4643 [CLKID_MPLL1_DIV] = &g12a_mpll1_div.hw, 4644 [CLKID_MPLL2_DIV] = &g12a_mpll2_div.hw, 4645 [CLKID_MPLL3_DIV] = &g12a_mpll3_div.hw, 4646 [CLKID_FCLK_DIV2_DIV] = &g12a_fclk_div2_div.hw, 4647 [CLKID_FCLK_DIV3_DIV] = &g12a_fclk_div3_div.hw, 4648 [CLKID_FCLK_DIV4_DIV] = &g12a_fclk_div4_div.hw, 4649 [CLKID_FCLK_DIV5_DIV] = &g12a_fclk_div5_div.hw, 4650 [CLKID_FCLK_DIV7_DIV] = &g12a_fclk_div7_div.hw, 4651 [CLKID_FCLK_DIV2P5_DIV] = &g12a_fclk_div2p5_div.hw, 4652 [CLKID_HIFI_PLL] = &g12a_hifi_pll.hw, 4653 [CLKID_VCLK2_VENCI0] = &g12a_vclk2_venci0.hw, 4654 [CLKID_VCLK2_VENCI1] = &g12a_vclk2_venci1.hw, 4655 [CLKID_VCLK2_VENCP0] = &g12a_vclk2_vencp0.hw, 4656 [CLKID_VCLK2_VENCP1] = &g12a_vclk2_vencp1.hw, 4657 [CLKID_VCLK2_VENCT0] = &g12a_vclk2_venct0.hw, 4658 [CLKID_VCLK2_VENCT1] = &g12a_vclk2_venct1.hw, 4659 [CLKID_VCLK2_OTHER] = &g12a_vclk2_other.hw, 4660 [CLKID_VCLK2_ENCI] = &g12a_vclk2_enci.hw, 4661 [CLKID_VCLK2_ENCP] = &g12a_vclk2_encp.hw, 4662 [CLKID_DAC_CLK] = &g12a_dac_clk.hw, 4663 [CLKID_AOCLK] = &g12a_aoclk_gate.hw, 4664 [CLKID_IEC958] = &g12a_iec958_gate.hw, 4665 [CLKID_ENC480P] = &g12a_enc480p.hw, 4666 [CLKID_RNG1] = &g12a_rng1.hw, 4667 [CLKID_VCLK2_ENCT] = &g12a_vclk2_enct.hw, 4668 [CLKID_VCLK2_ENCL] = &g12a_vclk2_encl.hw, 4669 [CLKID_VCLK2_VENCLMMC] = &g12a_vclk2_venclmmc.hw, 4670 [CLKID_VCLK2_VENCL] = &g12a_vclk2_vencl.hw, 4671 [CLKID_VCLK2_OTHER1] = &g12a_vclk2_other1.hw, 4672 [CLKID_FIXED_PLL_DCO] = &g12a_fixed_pll_dco.hw, 4673 [CLKID_SYS_PLL_DCO] = &g12a_sys_pll_dco.hw, 4674 [CLKID_GP0_PLL_DCO] = &g12a_gp0_pll_dco.hw, 4675 [CLKID_HIFI_PLL_DCO] = &g12a_hifi_pll_dco.hw, 4676 [CLKID_DMA] = &g12a_dma.hw, 4677 [CLKID_EFUSE] = &g12a_efuse.hw, 4678 [CLKID_ROM_BOOT] = &g12a_rom_boot.hw, 4679 [CLKID_RESET_SEC] = &g12a_reset_sec.hw, 4680 [CLKID_SEC_AHB_APB3] = &g12a_sec_ahb_apb3.hw, 4681 [CLKID_MPLL_PREDIV] = &g12a_mpll_prediv.hw, 4682 [CLKID_VPU_0_SEL] = &g12a_vpu_0_sel.hw, 4683 [CLKID_VPU_0_DIV] = &g12a_vpu_0_div.hw, 4684 [CLKID_VPU_0] = &g12a_vpu_0.hw, 4685 [CLKID_VPU_1_SEL] = &g12a_vpu_1_sel.hw, 4686 [CLKID_VPU_1_DIV] = &g12a_vpu_1_div.hw, 4687 [CLKID_VPU_1] = &g12a_vpu_1.hw, 4688 [CLKID_VPU] = &g12a_vpu.hw, 4689 [CLKID_VAPB_0_SEL] = &g12a_vapb_0_sel.hw, 4690 [CLKID_VAPB_0_DIV] = &g12a_vapb_0_div.hw, 4691 [CLKID_VAPB_0] = &g12a_vapb_0.hw, 4692 [CLKID_VAPB_1_SEL] = &g12a_vapb_1_sel.hw, 4693 [CLKID_VAPB_1_DIV] = &g12a_vapb_1_div.hw, 4694 [CLKID_VAPB_1] = &g12a_vapb_1.hw, 4695 [CLKID_VAPB_SEL] = &g12a_vapb_sel.hw, 4696 [CLKID_VAPB] = &g12a_vapb.hw, 4697 [CLKID_HDMI_PLL_DCO] = &g12a_hdmi_pll_dco.hw, 4698 [CLKID_HDMI_PLL_OD] = &g12a_hdmi_pll_od.hw, 4699 [CLKID_HDMI_PLL_OD2] = &g12a_hdmi_pll_od2.hw, 4700 [CLKID_HDMI_PLL] = &g12a_hdmi_pll.hw, 4701 [CLKID_VID_PLL] = &g12a_vid_pll_div.hw, 4702 [CLKID_VID_PLL_SEL] = &g12a_vid_pll_sel.hw, 4703 [CLKID_VID_PLL_DIV] = &g12a_vid_pll.hw, 4704 [CLKID_VCLK_SEL] = &g12a_vclk_sel.hw, 4705 [CLKID_VCLK2_SEL] = &g12a_vclk2_sel.hw, 4706 [CLKID_VCLK_INPUT] = &g12a_vclk_input.hw, 4707 [CLKID_VCLK2_INPUT] = &g12a_vclk2_input.hw, 4708 [CLKID_VCLK_DIV] = &g12a_vclk_div.hw, 4709 [CLKID_VCLK2_DIV] = &g12a_vclk2_div.hw, 4710 [CLKID_VCLK] = &g12a_vclk.hw, 4711 [CLKID_VCLK2] = &g12a_vclk2.hw, 4712 [CLKID_VCLK_DIV1] = &g12a_vclk_div1.hw, 4713 [CLKID_VCLK_DIV2_EN] = &g12a_vclk_div2_en.hw, 4714 [CLKID_VCLK_DIV4_EN] = &g12a_vclk_div4_en.hw, 4715 [CLKID_VCLK_DIV6_EN] = &g12a_vclk_div6_en.hw, 4716 [CLKID_VCLK_DIV12_EN] = &g12a_vclk_div12_en.hw, 4717 [CLKID_VCLK2_DIV1] = &g12a_vclk2_div1.hw, 4718 [CLKID_VCLK2_DIV2_EN] = &g12a_vclk2_div2_en.hw, 4719 [CLKID_VCLK2_DIV4_EN] = &g12a_vclk2_div4_en.hw, 4720 [CLKID_VCLK2_DIV6_EN] = &g12a_vclk2_div6_en.hw, 4721 [CLKID_VCLK2_DIV12_EN] = &g12a_vclk2_div12_en.hw, 4722 [CLKID_VCLK_DIV2] = &g12a_vclk_div2.hw, 4723 [CLKID_VCLK_DIV4] = &g12a_vclk_div4.hw, 4724 [CLKID_VCLK_DIV6] = &g12a_vclk_div6.hw, 4725 [CLKID_VCLK_DIV12] = &g12a_vclk_div12.hw, 4726 [CLKID_VCLK2_DIV2] = &g12a_vclk2_div2.hw, 4727 [CLKID_VCLK2_DIV4] = &g12a_vclk2_div4.hw, 4728 [CLKID_VCLK2_DIV6] = &g12a_vclk2_div6.hw, 4729 [CLKID_VCLK2_DIV12] = &g12a_vclk2_div12.hw, 4730 [CLKID_CTS_ENCI_SEL] = &g12a_cts_enci_sel.hw, 4731 [CLKID_CTS_ENCP_SEL] = &g12a_cts_encp_sel.hw, 4732 [CLKID_CTS_ENCL_SEL] = &g12a_cts_encl_sel.hw, 4733 [CLKID_CTS_VDAC_SEL] = &g12a_cts_vdac_sel.hw, 4734 [CLKID_HDMI_TX_SEL] = &g12a_hdmi_tx_sel.hw, 4735 [CLKID_CTS_ENCI] = &g12a_cts_enci.hw, 4736 [CLKID_CTS_ENCP] = &g12a_cts_encp.hw, 4737 [CLKID_CTS_ENCL] = &g12a_cts_encl.hw, 4738 [CLKID_CTS_VDAC] = &g12a_cts_vdac.hw, 4739 [CLKID_HDMI_TX] = &g12a_hdmi_tx.hw, 4740 [CLKID_HDMI_SEL] = &g12a_hdmi_sel.hw, 4741 [CLKID_HDMI_DIV] = &g12a_hdmi_div.hw, 4742 [CLKID_HDMI] = &g12a_hdmi.hw, 4743 [CLKID_MALI_0_SEL] = &g12a_mali_0_sel.hw, 4744 [CLKID_MALI_0_DIV] = &g12a_mali_0_div.hw, 4745 [CLKID_MALI_0] = &g12a_mali_0.hw, 4746 [CLKID_MALI_1_SEL] = &g12a_mali_1_sel.hw, 4747 [CLKID_MALI_1_DIV] = &g12a_mali_1_div.hw, 4748 [CLKID_MALI_1] = &g12a_mali_1.hw, 4749 [CLKID_MALI] = &g12a_mali.hw, 4750 [CLKID_MPLL_50M_DIV] = &g12a_mpll_50m_div.hw, 4751 [CLKID_MPLL_50M] = &g12a_mpll_50m.hw, 4752 [CLKID_SYS_PLL_DIV16_EN] = &g12a_sys_pll_div16_en.hw, 4753 [CLKID_SYS_PLL_DIV16] = &g12a_sys_pll_div16.hw, 4754 [CLKID_CPU_CLK_DYN0_SEL] = &g12a_cpu_clk_premux0.hw, 4755 [CLKID_CPU_CLK_DYN0_DIV] = &g12a_cpu_clk_mux0_div.hw, 4756 [CLKID_CPU_CLK_DYN0] = &g12a_cpu_clk_postmux0.hw, 4757 [CLKID_CPU_CLK_DYN1_SEL] = &g12a_cpu_clk_premux1.hw, 4758 [CLKID_CPU_CLK_DYN1_DIV] = &g12a_cpu_clk_mux1_div.hw, 4759 [CLKID_CPU_CLK_DYN1] = &g12a_cpu_clk_postmux1.hw, 4760 [CLKID_CPU_CLK_DYN] = &g12a_cpu_clk_dyn.hw, 4761 [CLKID_CPU_CLK] = &g12b_cpu_clk.hw, 4762 [CLKID_CPU_CLK_DIV16_EN] = &g12a_cpu_clk_div16_en.hw, 4763 [CLKID_CPU_CLK_DIV16] = &g12a_cpu_clk_div16.hw, 4764 [CLKID_CPU_CLK_APB_DIV] = &g12a_cpu_clk_apb_div.hw, 4765 [CLKID_CPU_CLK_APB] = &g12a_cpu_clk_apb.hw, 4766 [CLKID_CPU_CLK_ATB_DIV] = &g12a_cpu_clk_atb_div.hw, 4767 [CLKID_CPU_CLK_ATB] = &g12a_cpu_clk_atb.hw, 4768 [CLKID_CPU_CLK_AXI_DIV] = &g12a_cpu_clk_axi_div.hw, 4769 [CLKID_CPU_CLK_AXI] = &g12a_cpu_clk_axi.hw, 4770 [CLKID_CPU_CLK_TRACE_DIV] = &g12a_cpu_clk_trace_div.hw, 4771 [CLKID_CPU_CLK_TRACE] = &g12a_cpu_clk_trace.hw, 4772 [CLKID_PCIE_PLL_DCO] = &g12a_pcie_pll_dco.hw, 4773 [CLKID_PCIE_PLL_DCO_DIV2] = &g12a_pcie_pll_dco_div2.hw, 4774 [CLKID_PCIE_PLL_OD] = &g12a_pcie_pll_od.hw, 4775 [CLKID_PCIE_PLL] = &g12a_pcie_pll.hw, 4776 [CLKID_VDEC_1_SEL] = &g12a_vdec_1_sel.hw, 4777 [CLKID_VDEC_1_DIV] = &g12a_vdec_1_div.hw, 4778 [CLKID_VDEC_1] = &g12a_vdec_1.hw, 4779 [CLKID_VDEC_HEVC_SEL] = &g12a_vdec_hevc_sel.hw, 4780 [CLKID_VDEC_HEVC_DIV] = &g12a_vdec_hevc_div.hw, 4781 [CLKID_VDEC_HEVC] = &g12a_vdec_hevc.hw, 4782 [CLKID_VDEC_HEVCF_SEL] = &g12a_vdec_hevcf_sel.hw, 4783 [CLKID_VDEC_HEVCF_DIV] = &g12a_vdec_hevcf_div.hw, 4784 [CLKID_VDEC_HEVCF] = &g12a_vdec_hevcf.hw, 4785 [CLKID_TS_DIV] = &g12a_ts_div.hw, 4786 [CLKID_TS] = &g12a_ts.hw, 4787 [CLKID_SYS1_PLL_DCO] = &g12b_sys1_pll_dco.hw, 4788 [CLKID_SYS1_PLL] = &g12b_sys1_pll.hw, 4789 [CLKID_SYS1_PLL_DIV16_EN] = &g12b_sys1_pll_div16_en.hw, 4790 [CLKID_SYS1_PLL_DIV16] = &g12b_sys1_pll_div16.hw, 4791 [CLKID_CPUB_CLK_DYN0_SEL] = &g12b_cpub_clk_premux0.hw, 4792 [CLKID_CPUB_CLK_DYN0_DIV] = &g12b_cpub_clk_mux0_div.hw, 4793 [CLKID_CPUB_CLK_DYN0] = &g12b_cpub_clk_postmux0.hw, 4794 [CLKID_CPUB_CLK_DYN1_SEL] = &g12b_cpub_clk_premux1.hw, 4795 [CLKID_CPUB_CLK_DYN1_DIV] = &g12b_cpub_clk_mux1_div.hw, 4796 [CLKID_CPUB_CLK_DYN1] = &g12b_cpub_clk_postmux1.hw, 4797 [CLKID_CPUB_CLK_DYN] = &g12b_cpub_clk_dyn.hw, 4798 [CLKID_CPUB_CLK] = &g12b_cpub_clk.hw, 4799 [CLKID_CPUB_CLK_DIV16_EN] = &g12b_cpub_clk_div16_en.hw, 4800 [CLKID_CPUB_CLK_DIV16] = &g12b_cpub_clk_div16.hw, 4801 [CLKID_CPUB_CLK_DIV2] = &g12b_cpub_clk_div2.hw, 4802 [CLKID_CPUB_CLK_DIV3] = &g12b_cpub_clk_div3.hw, 4803 [CLKID_CPUB_CLK_DIV4] = &g12b_cpub_clk_div4.hw, 4804 [CLKID_CPUB_CLK_DIV5] = &g12b_cpub_clk_div5.hw, 4805 [CLKID_CPUB_CLK_DIV6] = &g12b_cpub_clk_div6.hw, 4806 [CLKID_CPUB_CLK_DIV7] = &g12b_cpub_clk_div7.hw, 4807 [CLKID_CPUB_CLK_DIV8] = &g12b_cpub_clk_div8.hw, 4808 [CLKID_CPUB_CLK_APB_SEL] = &g12b_cpub_clk_apb_sel.hw, 4809 [CLKID_CPUB_CLK_APB] = &g12b_cpub_clk_apb.hw, 4810 [CLKID_CPUB_CLK_ATB_SEL] = &g12b_cpub_clk_atb_sel.hw, 4811 [CLKID_CPUB_CLK_ATB] = &g12b_cpub_clk_atb.hw, 4812 [CLKID_CPUB_CLK_AXI_SEL] = &g12b_cpub_clk_axi_sel.hw, 4813 [CLKID_CPUB_CLK_AXI] = &g12b_cpub_clk_axi.hw, 4814 [CLKID_CPUB_CLK_TRACE_SEL] = &g12b_cpub_clk_trace_sel.hw, 4815 [CLKID_CPUB_CLK_TRACE] = &g12b_cpub_clk_trace.hw, 4816 [CLKID_SPICC0_SCLK_SEL] = &g12a_spicc0_sclk_sel.hw, 4817 [CLKID_SPICC0_SCLK_DIV] = &g12a_spicc0_sclk_div.hw, 4818 [CLKID_SPICC0_SCLK] = &g12a_spicc0_sclk.hw, 4819 [CLKID_SPICC1_SCLK_SEL] = &g12a_spicc1_sclk_sel.hw, 4820 [CLKID_SPICC1_SCLK_DIV] = &g12a_spicc1_sclk_div.hw, 4821 [CLKID_SPICC1_SCLK] = &g12a_spicc1_sclk.hw, 4822 [CLKID_NNA_AXI_CLK_SEL] = &sm1_nna_axi_clk_sel.hw, 4823 [CLKID_NNA_AXI_CLK_DIV] = &sm1_nna_axi_clk_div.hw, 4824 [CLKID_NNA_AXI_CLK] = &sm1_nna_axi_clk.hw, 4825 [CLKID_NNA_CORE_CLK_SEL] = &sm1_nna_core_clk_sel.hw, 4826 [CLKID_NNA_CORE_CLK_DIV] = &sm1_nna_core_clk_div.hw, 4827 [CLKID_NNA_CORE_CLK] = &sm1_nna_core_clk.hw, 4828 [CLKID_MIPI_DSI_PXCLK_SEL] = &g12a_mipi_dsi_pxclk_sel.hw, 4829 [CLKID_MIPI_DSI_PXCLK_DIV] = &g12a_mipi_dsi_pxclk_div.hw, 4830 [CLKID_MIPI_DSI_PXCLK] = &g12a_mipi_dsi_pxclk.hw, 4831 [CLKID_MIPI_ISP_SEL] = &g12b_mipi_isp_sel.hw, 4832 [CLKID_MIPI_ISP_DIV] = &g12b_mipi_isp_div.hw, 4833 [CLKID_MIPI_ISP] = &g12b_mipi_isp.hw, 4834 [CLKID_MIPI_ISP_GATE] = &g12b_mipi_isp_gate.hw, 4835 [CLKID_MIPI_ISP_CSI_PHY0] = &g12b_csi_phy0.hw, 4836 [CLKID_MIPI_ISP_CSI_PHY1] = &g12b_csi_phy1.hw, 4837 }; 4838 4839 static struct clk_hw *sm1_hw_clks[] = { 4840 [CLKID_SYS_PLL] = &g12a_sys_pll.hw, 4841 [CLKID_FIXED_PLL] = &g12a_fixed_pll.hw, 4842 [CLKID_FCLK_DIV2] = &g12a_fclk_div2.hw, 4843 [CLKID_FCLK_DIV3] = &g12a_fclk_div3.hw, 4844 [CLKID_FCLK_DIV4] = &g12a_fclk_div4.hw, 4845 [CLKID_FCLK_DIV5] = &g12a_fclk_div5.hw, 4846 [CLKID_FCLK_DIV7] = &g12a_fclk_div7.hw, 4847 [CLKID_FCLK_DIV2P5] = &g12a_fclk_div2p5.hw, 4848 [CLKID_GP0_PLL] = &g12a_gp0_pll.hw, 4849 [CLKID_MPEG_SEL] = &g12a_mpeg_clk_sel.hw, 4850 [CLKID_MPEG_DIV] = &g12a_mpeg_clk_div.hw, 4851 [CLKID_CLK81] = &g12a_clk81.hw, 4852 [CLKID_MPLL0] = &g12a_mpll0.hw, 4853 [CLKID_MPLL1] = &g12a_mpll1.hw, 4854 [CLKID_MPLL2] = &g12a_mpll2.hw, 4855 [CLKID_MPLL3] = &g12a_mpll3.hw, 4856 [CLKID_DDR] = &g12a_ddr.hw, 4857 [CLKID_DOS] = &g12a_dos.hw, 4858 [CLKID_AUDIO_LOCKER] = &g12a_audio_locker.hw, 4859 [CLKID_MIPI_DSI_HOST] = &g12a_mipi_dsi_host.hw, 4860 [CLKID_ETH_PHY] = &g12a_eth_phy.hw, 4861 [CLKID_ISA] = &g12a_isa.hw, 4862 [CLKID_PL301] = &g12a_pl301.hw, 4863 [CLKID_PERIPHS] = &g12a_periphs.hw, 4864 [CLKID_SPICC0] = &g12a_spicc_0.hw, 4865 [CLKID_I2C] = &g12a_i2c.hw, 4866 [CLKID_SANA] = &g12a_sana.hw, 4867 [CLKID_SD] = &g12a_sd.hw, 4868 [CLKID_RNG0] = &g12a_rng0.hw, 4869 [CLKID_UART0] = &g12a_uart0.hw, 4870 [CLKID_SPICC1] = &g12a_spicc_1.hw, 4871 [CLKID_HIU_IFACE] = &g12a_hiu_reg.hw, 4872 [CLKID_MIPI_DSI_PHY] = &g12a_mipi_dsi_phy.hw, 4873 [CLKID_ASSIST_MISC] = &g12a_assist_misc.hw, 4874 [CLKID_SD_EMMC_A] = &g12a_emmc_a.hw, 4875 [CLKID_SD_EMMC_B] = &g12a_emmc_b.hw, 4876 [CLKID_SD_EMMC_C] = &g12a_emmc_c.hw, 4877 [CLKID_AUDIO_CODEC] = &g12a_audio_codec.hw, 4878 [CLKID_AUDIO] = &g12a_audio.hw, 4879 [CLKID_ETH] = &g12a_eth_core.hw, 4880 [CLKID_DEMUX] = &g12a_demux.hw, 4881 [CLKID_AUDIO_IFIFO] = &g12a_audio_ififo.hw, 4882 [CLKID_ADC] = &g12a_adc.hw, 4883 [CLKID_UART1] = &g12a_uart1.hw, 4884 [CLKID_G2D] = &g12a_g2d.hw, 4885 [CLKID_RESET] = &g12a_reset.hw, 4886 [CLKID_PCIE_COMB] = &g12a_pcie_comb.hw, 4887 [CLKID_PARSER] = &g12a_parser.hw, 4888 [CLKID_USB] = &g12a_usb_general.hw, 4889 [CLKID_PCIE_PHY] = &g12a_pcie_phy.hw, 4890 [CLKID_AHB_ARB0] = &g12a_ahb_arb0.hw, 4891 [CLKID_AHB_DATA_BUS] = &g12a_ahb_data_bus.hw, 4892 [CLKID_AHB_CTRL_BUS] = &g12a_ahb_ctrl_bus.hw, 4893 [CLKID_HTX_HDCP22] = &g12a_htx_hdcp22.hw, 4894 [CLKID_HTX_PCLK] = &g12a_htx_pclk.hw, 4895 [CLKID_BT656] = &g12a_bt656.hw, 4896 [CLKID_USB1_DDR_BRIDGE] = &g12a_usb1_to_ddr.hw, 4897 [CLKID_MMC_PCLK] = &g12a_mmc_pclk.hw, 4898 [CLKID_UART2] = &g12a_uart2.hw, 4899 [CLKID_VPU_INTR] = &g12a_vpu_intr.hw, 4900 [CLKID_GIC] = &g12a_gic.hw, 4901 [CLKID_SD_EMMC_A_CLK0_SEL] = &g12a_sd_emmc_a_clk0_sel.hw, 4902 [CLKID_SD_EMMC_A_CLK0_DIV] = &g12a_sd_emmc_a_clk0_div.hw, 4903 [CLKID_SD_EMMC_A_CLK0] = &g12a_sd_emmc_a_clk0.hw, 4904 [CLKID_SD_EMMC_B_CLK0_SEL] = &g12a_sd_emmc_b_clk0_sel.hw, 4905 [CLKID_SD_EMMC_B_CLK0_DIV] = &g12a_sd_emmc_b_clk0_div.hw, 4906 [CLKID_SD_EMMC_B_CLK0] = &g12a_sd_emmc_b_clk0.hw, 4907 [CLKID_SD_EMMC_C_CLK0_SEL] = &g12a_sd_emmc_c_clk0_sel.hw, 4908 [CLKID_SD_EMMC_C_CLK0_DIV] = &g12a_sd_emmc_c_clk0_div.hw, 4909 [CLKID_SD_EMMC_C_CLK0] = &g12a_sd_emmc_c_clk0.hw, 4910 [CLKID_MPLL0_DIV] = &g12a_mpll0_div.hw, 4911 [CLKID_MPLL1_DIV] = &g12a_mpll1_div.hw, 4912 [CLKID_MPLL2_DIV] = &g12a_mpll2_div.hw, 4913 [CLKID_MPLL3_DIV] = &g12a_mpll3_div.hw, 4914 [CLKID_FCLK_DIV2_DIV] = &g12a_fclk_div2_div.hw, 4915 [CLKID_FCLK_DIV3_DIV] = &g12a_fclk_div3_div.hw, 4916 [CLKID_FCLK_DIV4_DIV] = &g12a_fclk_div4_div.hw, 4917 [CLKID_FCLK_DIV5_DIV] = &g12a_fclk_div5_div.hw, 4918 [CLKID_FCLK_DIV7_DIV] = &g12a_fclk_div7_div.hw, 4919 [CLKID_FCLK_DIV2P5_DIV] = &g12a_fclk_div2p5_div.hw, 4920 [CLKID_HIFI_PLL] = &g12a_hifi_pll.hw, 4921 [CLKID_VCLK2_VENCI0] = &g12a_vclk2_venci0.hw, 4922 [CLKID_VCLK2_VENCI1] = &g12a_vclk2_venci1.hw, 4923 [CLKID_VCLK2_VENCP0] = &g12a_vclk2_vencp0.hw, 4924 [CLKID_VCLK2_VENCP1] = &g12a_vclk2_vencp1.hw, 4925 [CLKID_VCLK2_VENCT0] = &g12a_vclk2_venct0.hw, 4926 [CLKID_VCLK2_VENCT1] = &g12a_vclk2_venct1.hw, 4927 [CLKID_VCLK2_OTHER] = &g12a_vclk2_other.hw, 4928 [CLKID_VCLK2_ENCI] = &g12a_vclk2_enci.hw, 4929 [CLKID_VCLK2_ENCP] = &g12a_vclk2_encp.hw, 4930 [CLKID_DAC_CLK] = &g12a_dac_clk.hw, 4931 [CLKID_AOCLK] = &g12a_aoclk_gate.hw, 4932 [CLKID_IEC958] = &g12a_iec958_gate.hw, 4933 [CLKID_ENC480P] = &g12a_enc480p.hw, 4934 [CLKID_RNG1] = &g12a_rng1.hw, 4935 [CLKID_VCLK2_ENCT] = &g12a_vclk2_enct.hw, 4936 [CLKID_VCLK2_ENCL] = &g12a_vclk2_encl.hw, 4937 [CLKID_VCLK2_VENCLMMC] = &g12a_vclk2_venclmmc.hw, 4938 [CLKID_VCLK2_VENCL] = &g12a_vclk2_vencl.hw, 4939 [CLKID_VCLK2_OTHER1] = &g12a_vclk2_other1.hw, 4940 [CLKID_FIXED_PLL_DCO] = &g12a_fixed_pll_dco.hw, 4941 [CLKID_SYS_PLL_DCO] = &g12a_sys_pll_dco.hw, 4942 [CLKID_GP0_PLL_DCO] = &g12a_gp0_pll_dco.hw, 4943 [CLKID_HIFI_PLL_DCO] = &g12a_hifi_pll_dco.hw, 4944 [CLKID_DMA] = &g12a_dma.hw, 4945 [CLKID_EFUSE] = &g12a_efuse.hw, 4946 [CLKID_ROM_BOOT] = &g12a_rom_boot.hw, 4947 [CLKID_RESET_SEC] = &g12a_reset_sec.hw, 4948 [CLKID_SEC_AHB_APB3] = &g12a_sec_ahb_apb3.hw, 4949 [CLKID_MPLL_PREDIV] = &g12a_mpll_prediv.hw, 4950 [CLKID_VPU_0_SEL] = &g12a_vpu_0_sel.hw, 4951 [CLKID_VPU_0_DIV] = &g12a_vpu_0_div.hw, 4952 [CLKID_VPU_0] = &g12a_vpu_0.hw, 4953 [CLKID_VPU_1_SEL] = &g12a_vpu_1_sel.hw, 4954 [CLKID_VPU_1_DIV] = &g12a_vpu_1_div.hw, 4955 [CLKID_VPU_1] = &g12a_vpu_1.hw, 4956 [CLKID_VPU] = &g12a_vpu.hw, 4957 [CLKID_VAPB_0_SEL] = &g12a_vapb_0_sel.hw, 4958 [CLKID_VAPB_0_DIV] = &g12a_vapb_0_div.hw, 4959 [CLKID_VAPB_0] = &g12a_vapb_0.hw, 4960 [CLKID_VAPB_1_SEL] = &g12a_vapb_1_sel.hw, 4961 [CLKID_VAPB_1_DIV] = &g12a_vapb_1_div.hw, 4962 [CLKID_VAPB_1] = &g12a_vapb_1.hw, 4963 [CLKID_VAPB_SEL] = &g12a_vapb_sel.hw, 4964 [CLKID_VAPB] = &g12a_vapb.hw, 4965 [CLKID_HDMI_PLL_DCO] = &g12a_hdmi_pll_dco.hw, 4966 [CLKID_HDMI_PLL_OD] = &g12a_hdmi_pll_od.hw, 4967 [CLKID_HDMI_PLL_OD2] = &g12a_hdmi_pll_od2.hw, 4968 [CLKID_HDMI_PLL] = &g12a_hdmi_pll.hw, 4969 [CLKID_VID_PLL] = &g12a_vid_pll_div.hw, 4970 [CLKID_VID_PLL_SEL] = &g12a_vid_pll_sel.hw, 4971 [CLKID_VID_PLL_DIV] = &g12a_vid_pll.hw, 4972 [CLKID_VCLK_SEL] = &g12a_vclk_sel.hw, 4973 [CLKID_VCLK2_SEL] = &g12a_vclk2_sel.hw, 4974 [CLKID_VCLK_INPUT] = &g12a_vclk_input.hw, 4975 [CLKID_VCLK2_INPUT] = &g12a_vclk2_input.hw, 4976 [CLKID_VCLK_DIV] = &g12a_vclk_div.hw, 4977 [CLKID_VCLK2_DIV] = &g12a_vclk2_div.hw, 4978 [CLKID_VCLK] = &g12a_vclk.hw, 4979 [CLKID_VCLK2] = &g12a_vclk2.hw, 4980 [CLKID_VCLK_DIV1] = &g12a_vclk_div1.hw, 4981 [CLKID_VCLK_DIV2_EN] = &g12a_vclk_div2_en.hw, 4982 [CLKID_VCLK_DIV4_EN] = &g12a_vclk_div4_en.hw, 4983 [CLKID_VCLK_DIV6_EN] = &g12a_vclk_div6_en.hw, 4984 [CLKID_VCLK_DIV12_EN] = &g12a_vclk_div12_en.hw, 4985 [CLKID_VCLK2_DIV1] = &g12a_vclk2_div1.hw, 4986 [CLKID_VCLK2_DIV2_EN] = &g12a_vclk2_div2_en.hw, 4987 [CLKID_VCLK2_DIV4_EN] = &g12a_vclk2_div4_en.hw, 4988 [CLKID_VCLK2_DIV6_EN] = &g12a_vclk2_div6_en.hw, 4989 [CLKID_VCLK2_DIV12_EN] = &g12a_vclk2_div12_en.hw, 4990 [CLKID_VCLK_DIV2] = &g12a_vclk_div2.hw, 4991 [CLKID_VCLK_DIV4] = &g12a_vclk_div4.hw, 4992 [CLKID_VCLK_DIV6] = &g12a_vclk_div6.hw, 4993 [CLKID_VCLK_DIV12] = &g12a_vclk_div12.hw, 4994 [CLKID_VCLK2_DIV2] = &g12a_vclk2_div2.hw, 4995 [CLKID_VCLK2_DIV4] = &g12a_vclk2_div4.hw, 4996 [CLKID_VCLK2_DIV6] = &g12a_vclk2_div6.hw, 4997 [CLKID_VCLK2_DIV12] = &g12a_vclk2_div12.hw, 4998 [CLKID_CTS_ENCI_SEL] = &g12a_cts_enci_sel.hw, 4999 [CLKID_CTS_ENCP_SEL] = &g12a_cts_encp_sel.hw, 5000 [CLKID_CTS_ENCL_SEL] = &g12a_cts_encl_sel.hw, 5001 [CLKID_CTS_VDAC_SEL] = &g12a_cts_vdac_sel.hw, 5002 [CLKID_HDMI_TX_SEL] = &g12a_hdmi_tx_sel.hw, 5003 [CLKID_CTS_ENCI] = &g12a_cts_enci.hw, 5004 [CLKID_CTS_ENCP] = &g12a_cts_encp.hw, 5005 [CLKID_CTS_ENCL] = &g12a_cts_encl.hw, 5006 [CLKID_CTS_VDAC] = &g12a_cts_vdac.hw, 5007 [CLKID_HDMI_TX] = &g12a_hdmi_tx.hw, 5008 [CLKID_HDMI_SEL] = &g12a_hdmi_sel.hw, 5009 [CLKID_HDMI_DIV] = &g12a_hdmi_div.hw, 5010 [CLKID_HDMI] = &g12a_hdmi.hw, 5011 [CLKID_MALI_0_SEL] = &g12a_mali_0_sel.hw, 5012 [CLKID_MALI_0_DIV] = &g12a_mali_0_div.hw, 5013 [CLKID_MALI_0] = &g12a_mali_0.hw, 5014 [CLKID_MALI_1_SEL] = &g12a_mali_1_sel.hw, 5015 [CLKID_MALI_1_DIV] = &g12a_mali_1_div.hw, 5016 [CLKID_MALI_1] = &g12a_mali_1.hw, 5017 [CLKID_MALI] = &g12a_mali.hw, 5018 [CLKID_MPLL_50M_DIV] = &g12a_mpll_50m_div.hw, 5019 [CLKID_MPLL_50M] = &g12a_mpll_50m.hw, 5020 [CLKID_SYS_PLL_DIV16_EN] = &g12a_sys_pll_div16_en.hw, 5021 [CLKID_SYS_PLL_DIV16] = &g12a_sys_pll_div16.hw, 5022 [CLKID_CPU_CLK_DYN0_SEL] = &g12a_cpu_clk_premux0.hw, 5023 [CLKID_CPU_CLK_DYN0_DIV] = &g12a_cpu_clk_mux0_div.hw, 5024 [CLKID_CPU_CLK_DYN0] = &g12a_cpu_clk_postmux0.hw, 5025 [CLKID_CPU_CLK_DYN1_SEL] = &g12a_cpu_clk_premux1.hw, 5026 [CLKID_CPU_CLK_DYN1_DIV] = &g12a_cpu_clk_mux1_div.hw, 5027 [CLKID_CPU_CLK_DYN1] = &g12a_cpu_clk_postmux1.hw, 5028 [CLKID_CPU_CLK_DYN] = &g12a_cpu_clk_dyn.hw, 5029 [CLKID_CPU_CLK] = &g12a_cpu_clk.hw, 5030 [CLKID_CPU_CLK_DIV16_EN] = &g12a_cpu_clk_div16_en.hw, 5031 [CLKID_CPU_CLK_DIV16] = &g12a_cpu_clk_div16.hw, 5032 [CLKID_CPU_CLK_APB_DIV] = &g12a_cpu_clk_apb_div.hw, 5033 [CLKID_CPU_CLK_APB] = &g12a_cpu_clk_apb.hw, 5034 [CLKID_CPU_CLK_ATB_DIV] = &g12a_cpu_clk_atb_div.hw, 5035 [CLKID_CPU_CLK_ATB] = &g12a_cpu_clk_atb.hw, 5036 [CLKID_CPU_CLK_AXI_DIV] = &g12a_cpu_clk_axi_div.hw, 5037 [CLKID_CPU_CLK_AXI] = &g12a_cpu_clk_axi.hw, 5038 [CLKID_CPU_CLK_TRACE_DIV] = &g12a_cpu_clk_trace_div.hw, 5039 [CLKID_CPU_CLK_TRACE] = &g12a_cpu_clk_trace.hw, 5040 [CLKID_PCIE_PLL_DCO] = &g12a_pcie_pll_dco.hw, 5041 [CLKID_PCIE_PLL_DCO_DIV2] = &g12a_pcie_pll_dco_div2.hw, 5042 [CLKID_PCIE_PLL_OD] = &g12a_pcie_pll_od.hw, 5043 [CLKID_PCIE_PLL] = &g12a_pcie_pll.hw, 5044 [CLKID_VDEC_1_SEL] = &g12a_vdec_1_sel.hw, 5045 [CLKID_VDEC_1_DIV] = &g12a_vdec_1_div.hw, 5046 [CLKID_VDEC_1] = &g12a_vdec_1.hw, 5047 [CLKID_VDEC_HEVC_SEL] = &g12a_vdec_hevc_sel.hw, 5048 [CLKID_VDEC_HEVC_DIV] = &g12a_vdec_hevc_div.hw, 5049 [CLKID_VDEC_HEVC] = &g12a_vdec_hevc.hw, 5050 [CLKID_VDEC_HEVCF_SEL] = &g12a_vdec_hevcf_sel.hw, 5051 [CLKID_VDEC_HEVCF_DIV] = &g12a_vdec_hevcf_div.hw, 5052 [CLKID_VDEC_HEVCF] = &g12a_vdec_hevcf.hw, 5053 [CLKID_TS_DIV] = &g12a_ts_div.hw, 5054 [CLKID_TS] = &g12a_ts.hw, 5055 [CLKID_GP1_PLL_DCO] = &sm1_gp1_pll_dco.hw, 5056 [CLKID_GP1_PLL] = &sm1_gp1_pll.hw, 5057 [CLKID_DSU_CLK_DYN0_SEL] = &sm1_dsu_clk_premux0.hw, 5058 [CLKID_DSU_CLK_DYN0_DIV] = &sm1_dsu_clk_premux1.hw, 5059 [CLKID_DSU_CLK_DYN0] = &sm1_dsu_clk_mux0_div.hw, 5060 [CLKID_DSU_CLK_DYN1_SEL] = &sm1_dsu_clk_postmux0.hw, 5061 [CLKID_DSU_CLK_DYN1_DIV] = &sm1_dsu_clk_mux1_div.hw, 5062 [CLKID_DSU_CLK_DYN1] = &sm1_dsu_clk_postmux1.hw, 5063 [CLKID_DSU_CLK_DYN] = &sm1_dsu_clk_dyn.hw, 5064 [CLKID_DSU_CLK_FINAL] = &sm1_dsu_final_clk.hw, 5065 [CLKID_DSU_CLK] = &sm1_dsu_clk.hw, 5066 [CLKID_CPU1_CLK] = &sm1_cpu1_clk.hw, 5067 [CLKID_CPU2_CLK] = &sm1_cpu2_clk.hw, 5068 [CLKID_CPU3_CLK] = &sm1_cpu3_clk.hw, 5069 [CLKID_SPICC0_SCLK_SEL] = &g12a_spicc0_sclk_sel.hw, 5070 [CLKID_SPICC0_SCLK_DIV] = &g12a_spicc0_sclk_div.hw, 5071 [CLKID_SPICC0_SCLK] = &g12a_spicc0_sclk.hw, 5072 [CLKID_SPICC1_SCLK_SEL] = &g12a_spicc1_sclk_sel.hw, 5073 [CLKID_SPICC1_SCLK_DIV] = &g12a_spicc1_sclk_div.hw, 5074 [CLKID_SPICC1_SCLK] = &g12a_spicc1_sclk.hw, 5075 [CLKID_NNA_AXI_CLK_SEL] = &sm1_nna_axi_clk_sel.hw, 5076 [CLKID_NNA_AXI_CLK_DIV] = &sm1_nna_axi_clk_div.hw, 5077 [CLKID_NNA_AXI_CLK] = &sm1_nna_axi_clk.hw, 5078 [CLKID_NNA_CORE_CLK_SEL] = &sm1_nna_core_clk_sel.hw, 5079 [CLKID_NNA_CORE_CLK_DIV] = &sm1_nna_core_clk_div.hw, 5080 [CLKID_NNA_CORE_CLK] = &sm1_nna_core_clk.hw, 5081 [CLKID_MIPI_DSI_PXCLK_SEL] = &g12a_mipi_dsi_pxclk_sel.hw, 5082 [CLKID_MIPI_DSI_PXCLK_DIV] = &g12a_mipi_dsi_pxclk_div.hw, 5083 [CLKID_MIPI_DSI_PXCLK] = &g12a_mipi_dsi_pxclk.hw, 5084 }; 5085 5086 /* Convenience table to populate regmap in .probe */ 5087 static struct clk_regmap *const g12a_clk_regmaps[] = { 5088 &g12a_clk81, 5089 &g12a_dos, 5090 &g12a_ddr, 5091 &g12a_audio_locker, 5092 &g12a_mipi_dsi_host, 5093 &g12a_eth_phy, 5094 &g12a_isa, 5095 &g12a_pl301, 5096 &g12a_periphs, 5097 &g12a_spicc_0, 5098 &g12a_i2c, 5099 &g12a_sana, 5100 &g12a_sd, 5101 &g12a_rng0, 5102 &g12a_uart0, 5103 &g12a_spicc_1, 5104 &g12a_hiu_reg, 5105 &g12a_mipi_dsi_phy, 5106 &g12a_assist_misc, 5107 &g12a_emmc_a, 5108 &g12a_emmc_b, 5109 &g12a_emmc_c, 5110 &g12a_audio_codec, 5111 &g12a_audio, 5112 &g12a_eth_core, 5113 &g12a_demux, 5114 &g12a_audio_ififo, 5115 &g12a_adc, 5116 &g12a_uart1, 5117 &g12a_g2d, 5118 &g12a_reset, 5119 &g12a_pcie_comb, 5120 &g12a_parser, 5121 &g12a_usb_general, 5122 &g12a_pcie_phy, 5123 &g12a_ahb_arb0, 5124 &g12a_ahb_data_bus, 5125 &g12a_ahb_ctrl_bus, 5126 &g12a_htx_hdcp22, 5127 &g12a_htx_pclk, 5128 &g12a_bt656, 5129 &g12a_usb1_to_ddr, 5130 &g12a_mmc_pclk, 5131 &g12a_uart2, 5132 &g12a_vpu_intr, 5133 &g12a_gic, 5134 &g12a_sd_emmc_a_clk0, 5135 &g12a_sd_emmc_b_clk0, 5136 &g12a_sd_emmc_c_clk0, 5137 &g12a_mpeg_clk_div, 5138 &g12a_sd_emmc_a_clk0_div, 5139 &g12a_sd_emmc_b_clk0_div, 5140 &g12a_sd_emmc_c_clk0_div, 5141 &g12a_mpeg_clk_sel, 5142 &g12a_sd_emmc_a_clk0_sel, 5143 &g12a_sd_emmc_b_clk0_sel, 5144 &g12a_sd_emmc_c_clk0_sel, 5145 &g12a_mpll0, 5146 &g12a_mpll1, 5147 &g12a_mpll2, 5148 &g12a_mpll3, 5149 &g12a_mpll0_div, 5150 &g12a_mpll1_div, 5151 &g12a_mpll2_div, 5152 &g12a_mpll3_div, 5153 &g12a_fixed_pll, 5154 &g12a_sys_pll, 5155 &g12a_gp0_pll, 5156 &g12a_hifi_pll, 5157 &g12a_vclk2_venci0, 5158 &g12a_vclk2_venci1, 5159 &g12a_vclk2_vencp0, 5160 &g12a_vclk2_vencp1, 5161 &g12a_vclk2_venct0, 5162 &g12a_vclk2_venct1, 5163 &g12a_vclk2_other, 5164 &g12a_vclk2_enci, 5165 &g12a_vclk2_encp, 5166 &g12a_dac_clk, 5167 &g12a_aoclk_gate, 5168 &g12a_iec958_gate, 5169 &g12a_enc480p, 5170 &g12a_rng1, 5171 &g12a_vclk2_enct, 5172 &g12a_vclk2_encl, 5173 &g12a_vclk2_venclmmc, 5174 &g12a_vclk2_vencl, 5175 &g12a_vclk2_other1, 5176 &g12a_fixed_pll_dco, 5177 &g12a_sys_pll_dco, 5178 &g12a_gp0_pll_dco, 5179 &g12a_hifi_pll_dco, 5180 &g12a_fclk_div2, 5181 &g12a_fclk_div3, 5182 &g12a_fclk_div4, 5183 &g12a_fclk_div5, 5184 &g12a_fclk_div7, 5185 &g12a_fclk_div2p5, 5186 &g12a_dma, 5187 &g12a_efuse, 5188 &g12a_rom_boot, 5189 &g12a_reset_sec, 5190 &g12a_sec_ahb_apb3, 5191 &g12a_vpu_0_sel, 5192 &g12a_vpu_0_div, 5193 &g12a_vpu_0, 5194 &g12a_vpu_1_sel, 5195 &g12a_vpu_1_div, 5196 &g12a_vpu_1, 5197 &g12a_vpu, 5198 &g12a_vapb_0_sel, 5199 &g12a_vapb_0_div, 5200 &g12a_vapb_0, 5201 &g12a_vapb_1_sel, 5202 &g12a_vapb_1_div, 5203 &g12a_vapb_1, 5204 &g12a_vapb_sel, 5205 &g12a_vapb, 5206 &g12a_hdmi_pll_dco, 5207 &g12a_hdmi_pll_od, 5208 &g12a_hdmi_pll_od2, 5209 &g12a_hdmi_pll, 5210 &g12a_vid_pll_div, 5211 &g12a_vid_pll_sel, 5212 &g12a_vid_pll, 5213 &g12a_vclk_sel, 5214 &g12a_vclk2_sel, 5215 &g12a_vclk_input, 5216 &g12a_vclk2_input, 5217 &g12a_vclk_div, 5218 &g12a_vclk2_div, 5219 &g12a_vclk, 5220 &g12a_vclk2, 5221 &g12a_vclk_div1, 5222 &g12a_vclk_div2_en, 5223 &g12a_vclk_div4_en, 5224 &g12a_vclk_div6_en, 5225 &g12a_vclk_div12_en, 5226 &g12a_vclk2_div1, 5227 &g12a_vclk2_div2_en, 5228 &g12a_vclk2_div4_en, 5229 &g12a_vclk2_div6_en, 5230 &g12a_vclk2_div12_en, 5231 &g12a_cts_enci_sel, 5232 &g12a_cts_encp_sel, 5233 &g12a_cts_encl_sel, 5234 &g12a_cts_vdac_sel, 5235 &g12a_hdmi_tx_sel, 5236 &g12a_cts_enci, 5237 &g12a_cts_encp, 5238 &g12a_cts_encl, 5239 &g12a_cts_vdac, 5240 &g12a_hdmi_tx, 5241 &g12a_hdmi_sel, 5242 &g12a_hdmi_div, 5243 &g12a_hdmi, 5244 &g12a_mali_0_sel, 5245 &g12a_mali_0_div, 5246 &g12a_mali_0, 5247 &g12a_mali_1_sel, 5248 &g12a_mali_1_div, 5249 &g12a_mali_1, 5250 &g12a_mali, 5251 &g12a_mpll_50m, 5252 &g12a_sys_pll_div16_en, 5253 &g12a_cpu_clk_premux0, 5254 &g12a_cpu_clk_mux0_div, 5255 &g12a_cpu_clk_postmux0, 5256 &g12a_cpu_clk_premux1, 5257 &g12a_cpu_clk_mux1_div, 5258 &g12a_cpu_clk_postmux1, 5259 &g12a_cpu_clk_dyn, 5260 &g12a_cpu_clk, 5261 &g12a_cpu_clk_div16_en, 5262 &g12a_cpu_clk_apb_div, 5263 &g12a_cpu_clk_apb, 5264 &g12a_cpu_clk_atb_div, 5265 &g12a_cpu_clk_atb, 5266 &g12a_cpu_clk_axi_div, 5267 &g12a_cpu_clk_axi, 5268 &g12a_cpu_clk_trace_div, 5269 &g12a_cpu_clk_trace, 5270 &g12a_pcie_pll_od, 5271 &g12a_pcie_pll_dco, 5272 &g12a_vdec_1_sel, 5273 &g12a_vdec_1_div, 5274 &g12a_vdec_1, 5275 &g12a_vdec_hevc_sel, 5276 &g12a_vdec_hevc_div, 5277 &g12a_vdec_hevc, 5278 &g12a_vdec_hevcf_sel, 5279 &g12a_vdec_hevcf_div, 5280 &g12a_vdec_hevcf, 5281 &g12a_ts_div, 5282 &g12a_ts, 5283 &g12b_cpu_clk, 5284 &g12b_sys1_pll_dco, 5285 &g12b_sys1_pll, 5286 &g12b_sys1_pll_div16_en, 5287 &g12b_cpub_clk_premux0, 5288 &g12b_cpub_clk_mux0_div, 5289 &g12b_cpub_clk_postmux0, 5290 &g12b_cpub_clk_premux1, 5291 &g12b_cpub_clk_mux1_div, 5292 &g12b_cpub_clk_postmux1, 5293 &g12b_cpub_clk_dyn, 5294 &g12b_cpub_clk, 5295 &g12b_cpub_clk_div16_en, 5296 &g12b_cpub_clk_apb_sel, 5297 &g12b_cpub_clk_apb, 5298 &g12b_cpub_clk_atb_sel, 5299 &g12b_cpub_clk_atb, 5300 &g12b_cpub_clk_axi_sel, 5301 &g12b_cpub_clk_axi, 5302 &g12b_cpub_clk_trace_sel, 5303 &g12b_cpub_clk_trace, 5304 &sm1_gp1_pll_dco, 5305 &sm1_gp1_pll, 5306 &sm1_dsu_clk_premux0, 5307 &sm1_dsu_clk_premux1, 5308 &sm1_dsu_clk_mux0_div, 5309 &sm1_dsu_clk_postmux0, 5310 &sm1_dsu_clk_mux1_div, 5311 &sm1_dsu_clk_postmux1, 5312 &sm1_dsu_clk_dyn, 5313 &sm1_dsu_final_clk, 5314 &sm1_dsu_clk, 5315 &sm1_cpu1_clk, 5316 &sm1_cpu2_clk, 5317 &sm1_cpu3_clk, 5318 &g12a_spicc0_sclk_sel, 5319 &g12a_spicc0_sclk_div, 5320 &g12a_spicc0_sclk, 5321 &g12a_spicc1_sclk_sel, 5322 &g12a_spicc1_sclk_div, 5323 &g12a_spicc1_sclk, 5324 &sm1_nna_axi_clk_sel, 5325 &sm1_nna_axi_clk_div, 5326 &sm1_nna_axi_clk, 5327 &sm1_nna_core_clk_sel, 5328 &sm1_nna_core_clk_div, 5329 &sm1_nna_core_clk, 5330 &g12a_mipi_dsi_pxclk_sel, 5331 &g12a_mipi_dsi_pxclk_div, 5332 &g12a_mipi_dsi_pxclk, 5333 &g12b_mipi_isp_sel, 5334 &g12b_mipi_isp_div, 5335 &g12b_mipi_isp, 5336 &g12b_mipi_isp_gate, 5337 &g12b_csi_phy1, 5338 &g12b_csi_phy0, 5339 }; 5340 5341 static const struct reg_sequence g12a_init_regs[] = { 5342 { .reg = HHI_MPLL_CNTL0, .def = 0x00000543 }, 5343 }; 5344 5345 #define DVFS_CON_ID "dvfs" 5346 5347 static int meson_g12a_dvfs_setup_common(struct device *dev, 5348 struct clk_hw **hws) 5349 { 5350 struct clk *notifier_clk; 5351 struct clk_hw *xtal; 5352 int ret; 5353 5354 xtal = clk_hw_get_parent_by_index(hws[CLKID_CPU_CLK_DYN1_SEL], 0); 5355 5356 /* Setup clock notifier for cpu_clk_postmux0 */ 5357 g12a_cpu_clk_postmux0_nb_data.xtal = xtal; 5358 notifier_clk = devm_clk_hw_get_clk(dev, &g12a_cpu_clk_postmux0.hw, 5359 DVFS_CON_ID); 5360 ret = devm_clk_notifier_register(dev, notifier_clk, 5361 &g12a_cpu_clk_postmux0_nb_data.nb); 5362 if (ret) { 5363 dev_err(dev, "failed to register the cpu_clk_postmux0 notifier\n"); 5364 return ret; 5365 } 5366 5367 /* Setup clock notifier for cpu_clk_dyn mux */ 5368 notifier_clk = devm_clk_hw_get_clk(dev, &g12a_cpu_clk_dyn.hw, 5369 DVFS_CON_ID); 5370 ret = devm_clk_notifier_register(dev, notifier_clk, 5371 &g12a_cpu_clk_mux_nb); 5372 if (ret) { 5373 dev_err(dev, "failed to register the cpu_clk_dyn notifier\n"); 5374 return ret; 5375 } 5376 5377 return 0; 5378 } 5379 5380 static int meson_g12b_dvfs_setup(struct platform_device *pdev) 5381 { 5382 struct clk_hw **hws = g12b_hw_clks; 5383 struct device *dev = &pdev->dev; 5384 struct clk *notifier_clk; 5385 struct clk_hw *xtal; 5386 int ret; 5387 5388 ret = meson_g12a_dvfs_setup_common(dev, hws); 5389 if (ret) 5390 return ret; 5391 5392 xtal = clk_hw_get_parent_by_index(hws[CLKID_CPU_CLK_DYN1_SEL], 0); 5393 5394 /* Setup clock notifier for cpu_clk mux */ 5395 notifier_clk = devm_clk_hw_get_clk(dev, &g12b_cpu_clk.hw, 5396 DVFS_CON_ID); 5397 ret = devm_clk_notifier_register(dev, notifier_clk, 5398 &g12a_cpu_clk_mux_nb); 5399 if (ret) { 5400 dev_err(dev, "failed to register the cpu_clk notifier\n"); 5401 return ret; 5402 } 5403 5404 /* Setup clock notifier for sys1_pll */ 5405 notifier_clk = devm_clk_hw_get_clk(dev, &g12b_sys1_pll.hw, 5406 DVFS_CON_ID); 5407 ret = devm_clk_notifier_register(dev, notifier_clk, 5408 &g12b_cpu_clk_sys1_pll_nb_data.nb); 5409 if (ret) { 5410 dev_err(dev, "failed to register the sys1_pll notifier\n"); 5411 return ret; 5412 } 5413 5414 /* Add notifiers for the second CPU cluster */ 5415 5416 /* Setup clock notifier for cpub_clk_postmux0 */ 5417 g12b_cpub_clk_postmux0_nb_data.xtal = xtal; 5418 notifier_clk = devm_clk_hw_get_clk(dev, &g12b_cpub_clk_postmux0.hw, 5419 DVFS_CON_ID); 5420 ret = devm_clk_notifier_register(dev, notifier_clk, 5421 &g12b_cpub_clk_postmux0_nb_data.nb); 5422 if (ret) { 5423 dev_err(dev, "failed to register the cpub_clk_postmux0 notifier\n"); 5424 return ret; 5425 } 5426 5427 /* Setup clock notifier for cpub_clk_dyn mux */ 5428 notifier_clk = devm_clk_hw_get_clk(dev, &g12b_cpub_clk_dyn.hw, "dvfs"); 5429 ret = devm_clk_notifier_register(dev, notifier_clk, 5430 &g12a_cpu_clk_mux_nb); 5431 if (ret) { 5432 dev_err(dev, "failed to register the cpub_clk_dyn notifier\n"); 5433 return ret; 5434 } 5435 5436 /* Setup clock notifier for cpub_clk mux */ 5437 notifier_clk = devm_clk_hw_get_clk(dev, &g12b_cpub_clk.hw, DVFS_CON_ID); 5438 ret = devm_clk_notifier_register(dev, notifier_clk, 5439 &g12a_cpu_clk_mux_nb); 5440 if (ret) { 5441 dev_err(dev, "failed to register the cpub_clk notifier\n"); 5442 return ret; 5443 } 5444 5445 /* Setup clock notifier for sys_pll */ 5446 notifier_clk = devm_clk_hw_get_clk(dev, &g12a_sys_pll.hw, DVFS_CON_ID); 5447 ret = devm_clk_notifier_register(dev, notifier_clk, 5448 &g12b_cpub_clk_sys_pll_nb_data.nb); 5449 if (ret) { 5450 dev_err(dev, "failed to register the sys_pll notifier\n"); 5451 return ret; 5452 } 5453 5454 return 0; 5455 } 5456 5457 static int meson_g12a_dvfs_setup(struct platform_device *pdev) 5458 { 5459 struct clk_hw **hws = g12a_hw_clks; 5460 struct device *dev = &pdev->dev; 5461 struct clk *notifier_clk; 5462 int ret; 5463 5464 ret = meson_g12a_dvfs_setup_common(dev, hws); 5465 if (ret) 5466 return ret; 5467 5468 /* Setup clock notifier for cpu_clk mux */ 5469 notifier_clk = devm_clk_hw_get_clk(dev, &g12a_cpu_clk.hw, DVFS_CON_ID); 5470 ret = devm_clk_notifier_register(dev, notifier_clk, 5471 &g12a_cpu_clk_mux_nb); 5472 if (ret) { 5473 dev_err(dev, "failed to register the cpu_clk notifier\n"); 5474 return ret; 5475 } 5476 5477 /* Setup clock notifier for sys_pll */ 5478 notifier_clk = devm_clk_hw_get_clk(dev, &g12a_sys_pll.hw, DVFS_CON_ID); 5479 ret = devm_clk_notifier_register(dev, notifier_clk, 5480 &g12a_sys_pll_nb_data.nb); 5481 if (ret) { 5482 dev_err(dev, "failed to register the sys_pll notifier\n"); 5483 return ret; 5484 } 5485 5486 return 0; 5487 } 5488 5489 struct meson_g12a_data { 5490 const struct meson_eeclkc_data eeclkc_data; 5491 int (*dvfs_setup)(struct platform_device *pdev); 5492 }; 5493 5494 static int meson_g12a_probe(struct platform_device *pdev) 5495 { 5496 const struct meson_eeclkc_data *eeclkc_data; 5497 const struct meson_g12a_data *g12a_data; 5498 int ret; 5499 5500 eeclkc_data = of_device_get_match_data(&pdev->dev); 5501 if (!eeclkc_data) 5502 return -EINVAL; 5503 5504 ret = meson_eeclkc_probe(pdev); 5505 if (ret) 5506 return ret; 5507 5508 g12a_data = container_of(eeclkc_data, struct meson_g12a_data, 5509 eeclkc_data); 5510 5511 if (g12a_data->dvfs_setup) 5512 return g12a_data->dvfs_setup(pdev); 5513 5514 return 0; 5515 } 5516 5517 static const struct meson_g12a_data g12a_clkc_data = { 5518 .eeclkc_data = { 5519 .regmap_clks = g12a_clk_regmaps, 5520 .regmap_clk_num = ARRAY_SIZE(g12a_clk_regmaps), 5521 .hw_clks = { 5522 .hws = g12a_hw_clks, 5523 .num = ARRAY_SIZE(g12a_hw_clks), 5524 }, 5525 .init_regs = g12a_init_regs, 5526 .init_count = ARRAY_SIZE(g12a_init_regs), 5527 }, 5528 .dvfs_setup = meson_g12a_dvfs_setup, 5529 }; 5530 5531 static const struct meson_g12a_data g12b_clkc_data = { 5532 .eeclkc_data = { 5533 .regmap_clks = g12a_clk_regmaps, 5534 .regmap_clk_num = ARRAY_SIZE(g12a_clk_regmaps), 5535 .hw_clks = { 5536 .hws = g12b_hw_clks, 5537 .num = ARRAY_SIZE(g12b_hw_clks), 5538 }, 5539 }, 5540 .dvfs_setup = meson_g12b_dvfs_setup, 5541 }; 5542 5543 static const struct meson_g12a_data sm1_clkc_data = { 5544 .eeclkc_data = { 5545 .regmap_clks = g12a_clk_regmaps, 5546 .regmap_clk_num = ARRAY_SIZE(g12a_clk_regmaps), 5547 .hw_clks = { 5548 .hws = sm1_hw_clks, 5549 .num = ARRAY_SIZE(sm1_hw_clks), 5550 }, 5551 }, 5552 .dvfs_setup = meson_g12a_dvfs_setup, 5553 }; 5554 5555 static const struct of_device_id clkc_match_table[] = { 5556 { 5557 .compatible = "amlogic,g12a-clkc", 5558 .data = &g12a_clkc_data.eeclkc_data 5559 }, 5560 { 5561 .compatible = "amlogic,g12b-clkc", 5562 .data = &g12b_clkc_data.eeclkc_data 5563 }, 5564 { 5565 .compatible = "amlogic,sm1-clkc", 5566 .data = &sm1_clkc_data.eeclkc_data 5567 }, 5568 {} 5569 }; 5570 MODULE_DEVICE_TABLE(of, clkc_match_table); 5571 5572 static struct platform_driver g12a_driver = { 5573 .probe = meson_g12a_probe, 5574 .driver = { 5575 .name = "g12a-clkc", 5576 .of_match_table = clkc_match_table, 5577 }, 5578 }; 5579 5580 module_platform_driver(g12a_driver); 5581 MODULE_LICENSE("GPL v2"); 5582