1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * Copyright (c) 2013-2014, The Linux Foundation. All rights reserved. 4 */ 5 6 #include <linux/kernel.h> 7 #include <linux/bitops.h> 8 #include <linux/err.h> 9 #include <linux/platform_device.h> 10 #include <linux/property.h> 11 #include <linux/module.h> 12 #include <linux/of.h> 13 #include <linux/of_platform.h> 14 #include <linux/clk-provider.h> 15 #include <linux/regmap.h> 16 #include <linux/reset-controller.h> 17 18 #include <dt-bindings/clock/qcom,gcc-msm8960.h> 19 #include <dt-bindings/reset/qcom,gcc-msm8960.h> 20 21 #include "common.h" 22 #include "clk-regmap.h" 23 #include "clk-pll.h" 24 #include "clk-rcg.h" 25 #include "clk-branch.h" 26 #include "clk-hfpll.h" 27 #include "reset.h" 28 29 static struct clk_pll pll3 = { 30 .l_reg = 0x3164, 31 .m_reg = 0x3168, 32 .n_reg = 0x316c, 33 .config_reg = 0x3174, 34 .mode_reg = 0x3160, 35 .status_reg = 0x3178, 36 .status_bit = 16, 37 .clkr.hw.init = &(struct clk_init_data){ 38 .name = "pll3", 39 .parent_data = &(const struct clk_parent_data){ 40 .fw_name = "pxo", .name = "pxo_board", 41 }, 42 .num_parents = 1, 43 .ops = &clk_pll_ops, 44 }, 45 }; 46 47 static struct clk_regmap pll4_vote = { 48 .enable_reg = 0x34c0, 49 .enable_mask = BIT(4), 50 .hw.init = &(struct clk_init_data){ 51 .name = "pll4_vote", 52 .parent_data = &(const struct clk_parent_data){ 53 .fw_name = "pll4", .name = "pll4", 54 }, 55 .num_parents = 1, 56 .ops = &clk_pll_vote_ops, 57 }, 58 }; 59 60 static struct clk_pll pll8 = { 61 .l_reg = 0x3144, 62 .m_reg = 0x3148, 63 .n_reg = 0x314c, 64 .config_reg = 0x3154, 65 .mode_reg = 0x3140, 66 .status_reg = 0x3158, 67 .status_bit = 16, 68 .clkr.hw.init = &(struct clk_init_data){ 69 .name = "pll8", 70 .parent_data = &(const struct clk_parent_data){ 71 .fw_name = "pxo", .name = "pxo_board", 72 }, 73 .num_parents = 1, 74 .ops = &clk_pll_ops, 75 }, 76 }; 77 78 static struct clk_regmap pll8_vote = { 79 .enable_reg = 0x34c0, 80 .enable_mask = BIT(8), 81 .hw.init = &(struct clk_init_data){ 82 .name = "pll8_vote", 83 .parent_hws = (const struct clk_hw*[]){ 84 &pll8.clkr.hw 85 }, 86 .num_parents = 1, 87 .ops = &clk_pll_vote_ops, 88 }, 89 }; 90 91 static struct hfpll_data hfpll0_data = { 92 .mode_reg = 0x3200, 93 .l_reg = 0x3208, 94 .m_reg = 0x320c, 95 .n_reg = 0x3210, 96 .config_reg = 0x3204, 97 .status_reg = 0x321c, 98 .config_val = 0x7845c665, 99 .droop_reg = 0x3214, 100 .droop_val = 0x0108c000, 101 .min_rate = 600000000UL, 102 .max_rate = 1800000000UL, 103 }; 104 105 static struct clk_hfpll hfpll0 = { 106 .d = &hfpll0_data, 107 .clkr.hw.init = &(struct clk_init_data){ 108 .parent_data = &(const struct clk_parent_data){ 109 .fw_name = "pxo", .name = "pxo_board", 110 }, 111 .num_parents = 1, 112 .name = "hfpll0", 113 .ops = &clk_ops_hfpll, 114 .flags = CLK_IGNORE_UNUSED, 115 }, 116 .lock = __SPIN_LOCK_UNLOCKED(hfpll0.lock), 117 }; 118 119 static struct hfpll_data hfpll1_8064_data = { 120 .mode_reg = 0x3240, 121 .l_reg = 0x3248, 122 .m_reg = 0x324c, 123 .n_reg = 0x3250, 124 .config_reg = 0x3244, 125 .status_reg = 0x325c, 126 .config_val = 0x7845c665, 127 .droop_reg = 0x3254, 128 .droop_val = 0x0108c000, 129 .min_rate = 600000000UL, 130 .max_rate = 1800000000UL, 131 }; 132 133 static struct hfpll_data hfpll1_data = { 134 .mode_reg = 0x3300, 135 .l_reg = 0x3308, 136 .m_reg = 0x330c, 137 .n_reg = 0x3310, 138 .config_reg = 0x3304, 139 .status_reg = 0x331c, 140 .config_val = 0x7845c665, 141 .droop_reg = 0x3314, 142 .droop_val = 0x0108c000, 143 .min_rate = 600000000UL, 144 .max_rate = 1800000000UL, 145 }; 146 147 static struct clk_hfpll hfpll1 = { 148 .d = &hfpll1_data, 149 .clkr.hw.init = &(struct clk_init_data){ 150 .parent_data = &(const struct clk_parent_data){ 151 .fw_name = "pxo", .name = "pxo_board", 152 }, 153 .num_parents = 1, 154 .name = "hfpll1", 155 .ops = &clk_ops_hfpll, 156 .flags = CLK_IGNORE_UNUSED, 157 }, 158 .lock = __SPIN_LOCK_UNLOCKED(hfpll1.lock), 159 }; 160 161 static struct hfpll_data hfpll2_data = { 162 .mode_reg = 0x3280, 163 .l_reg = 0x3288, 164 .m_reg = 0x328c, 165 .n_reg = 0x3290, 166 .config_reg = 0x3284, 167 .status_reg = 0x329c, 168 .config_val = 0x7845c665, 169 .droop_reg = 0x3294, 170 .droop_val = 0x0108c000, 171 .min_rate = 600000000UL, 172 .max_rate = 1800000000UL, 173 }; 174 175 static struct clk_hfpll hfpll2 = { 176 .d = &hfpll2_data, 177 .clkr.hw.init = &(struct clk_init_data){ 178 .parent_data = &(const struct clk_parent_data){ 179 .fw_name = "pxo", .name = "pxo_board", 180 }, 181 .num_parents = 1, 182 .name = "hfpll2", 183 .ops = &clk_ops_hfpll, 184 .flags = CLK_IGNORE_UNUSED, 185 }, 186 .lock = __SPIN_LOCK_UNLOCKED(hfpll2.lock), 187 }; 188 189 static struct hfpll_data hfpll3_data = { 190 .mode_reg = 0x32c0, 191 .l_reg = 0x32c8, 192 .m_reg = 0x32cc, 193 .n_reg = 0x32d0, 194 .config_reg = 0x32c4, 195 .status_reg = 0x32dc, 196 .config_val = 0x7845c665, 197 .droop_reg = 0x32d4, 198 .droop_val = 0x0108c000, 199 .min_rate = 600000000UL, 200 .max_rate = 1800000000UL, 201 }; 202 203 static struct clk_hfpll hfpll3 = { 204 .d = &hfpll3_data, 205 .clkr.hw.init = &(struct clk_init_data){ 206 .parent_data = &(const struct clk_parent_data){ 207 .fw_name = "pxo", .name = "pxo_board", 208 }, 209 .num_parents = 1, 210 .name = "hfpll3", 211 .ops = &clk_ops_hfpll, 212 .flags = CLK_IGNORE_UNUSED, 213 }, 214 .lock = __SPIN_LOCK_UNLOCKED(hfpll3.lock), 215 }; 216 217 static struct hfpll_data hfpll_l2_8064_data = { 218 .mode_reg = 0x3300, 219 .l_reg = 0x3308, 220 .m_reg = 0x330c, 221 .n_reg = 0x3310, 222 .config_reg = 0x3304, 223 .status_reg = 0x331c, 224 .config_val = 0x7845c665, 225 .droop_reg = 0x3314, 226 .droop_val = 0x0108c000, 227 .min_rate = 600000000UL, 228 .max_rate = 1800000000UL, 229 }; 230 231 static struct hfpll_data hfpll_l2_data = { 232 .mode_reg = 0x3400, 233 .l_reg = 0x3408, 234 .m_reg = 0x340c, 235 .n_reg = 0x3410, 236 .config_reg = 0x3404, 237 .status_reg = 0x341c, 238 .config_val = 0x7845c665, 239 .droop_reg = 0x3414, 240 .droop_val = 0x0108c000, 241 .min_rate = 600000000UL, 242 .max_rate = 1800000000UL, 243 }; 244 245 static struct clk_hfpll hfpll_l2 = { 246 .d = &hfpll_l2_data, 247 .clkr.hw.init = &(struct clk_init_data){ 248 .parent_data = &(const struct clk_parent_data){ 249 .fw_name = "pxo", .name = "pxo_board", 250 }, 251 .num_parents = 1, 252 .name = "hfpll_l2", 253 .ops = &clk_ops_hfpll, 254 .flags = CLK_IGNORE_UNUSED, 255 }, 256 .lock = __SPIN_LOCK_UNLOCKED(hfpll_l2.lock), 257 }; 258 259 static struct clk_pll pll14 = { 260 .l_reg = 0x31c4, 261 .m_reg = 0x31c8, 262 .n_reg = 0x31cc, 263 .config_reg = 0x31d4, 264 .mode_reg = 0x31c0, 265 .status_reg = 0x31d8, 266 .status_bit = 16, 267 .clkr.hw.init = &(struct clk_init_data){ 268 .name = "pll14", 269 .parent_data = &(const struct clk_parent_data){ 270 .fw_name = "pxo", .name = "pxo_board", 271 }, 272 .num_parents = 1, 273 .ops = &clk_pll_ops, 274 }, 275 }; 276 277 static struct clk_regmap pll14_vote = { 278 .enable_reg = 0x34c0, 279 .enable_mask = BIT(14), 280 .hw.init = &(struct clk_init_data){ 281 .name = "pll14_vote", 282 .parent_hws = (const struct clk_hw*[]){ 283 &pll14.clkr.hw 284 }, 285 .num_parents = 1, 286 .ops = &clk_pll_vote_ops, 287 }, 288 }; 289 290 enum { 291 P_PXO, 292 P_PLL8, 293 P_PLL3, 294 P_CXO, 295 }; 296 297 static const struct parent_map gcc_pxo_pll8_map[] = { 298 { P_PXO, 0 }, 299 { P_PLL8, 3 } 300 }; 301 302 static const struct clk_parent_data gcc_pxo_pll8[] = { 303 { .fw_name = "pxo", .name = "pxo_board" }, 304 { .hw = &pll8_vote.hw }, 305 }; 306 307 static const struct parent_map gcc_pxo_pll8_cxo_map[] = { 308 { P_PXO, 0 }, 309 { P_PLL8, 3 }, 310 { P_CXO, 5 } 311 }; 312 313 static const struct clk_parent_data gcc_pxo_pll8_cxo[] = { 314 { .fw_name = "pxo", .name = "pxo_board" }, 315 { .hw = &pll8_vote.hw }, 316 { .fw_name = "cxo", .name = "cxo_board" }, 317 }; 318 319 static const struct parent_map gcc_pxo_pll8_pll3_map[] = { 320 { P_PXO, 0 }, 321 { P_PLL8, 3 }, 322 { P_PLL3, 6 } 323 }; 324 325 static const struct clk_parent_data gcc_pxo_pll8_pll3[] = { 326 { .fw_name = "pxo", .name = "pxo_board" }, 327 { .hw = &pll8_vote.hw }, 328 { .hw = &pll3.clkr.hw }, 329 }; 330 331 static const struct freq_tbl clk_tbl_gsbi_uart[] = { 332 { 1843200, P_PLL8, 2, 6, 625 }, 333 { 3686400, P_PLL8, 2, 12, 625 }, 334 { 7372800, P_PLL8, 2, 24, 625 }, 335 { 14745600, P_PLL8, 2, 48, 625 }, 336 { 16000000, P_PLL8, 4, 1, 6 }, 337 { 24000000, P_PLL8, 4, 1, 4 }, 338 { 32000000, P_PLL8, 4, 1, 3 }, 339 { 40000000, P_PLL8, 1, 5, 48 }, 340 { 46400000, P_PLL8, 1, 29, 240 }, 341 { 48000000, P_PLL8, 4, 1, 2 }, 342 { 51200000, P_PLL8, 1, 2, 15 }, 343 { 56000000, P_PLL8, 1, 7, 48 }, 344 { 58982400, P_PLL8, 1, 96, 625 }, 345 { 64000000, P_PLL8, 2, 1, 3 }, 346 { } 347 }; 348 349 static struct clk_rcg gsbi1_uart_src = { 350 .ns_reg = 0x29d4, 351 .md_reg = 0x29d0, 352 .mn = { 353 .mnctr_en_bit = 8, 354 .mnctr_reset_bit = 7, 355 .mnctr_mode_shift = 5, 356 .n_val_shift = 16, 357 .m_val_shift = 16, 358 .width = 16, 359 }, 360 .p = { 361 .pre_div_shift = 3, 362 .pre_div_width = 2, 363 }, 364 .s = { 365 .src_sel_shift = 0, 366 .parent_map = gcc_pxo_pll8_map, 367 }, 368 .freq_tbl = clk_tbl_gsbi_uart, 369 .clkr = { 370 .enable_reg = 0x29d4, 371 .enable_mask = BIT(11), 372 .hw.init = &(struct clk_init_data){ 373 .name = "gsbi1_uart_src", 374 .parent_data = gcc_pxo_pll8, 375 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 376 .ops = &clk_rcg_ops, 377 .flags = CLK_SET_PARENT_GATE, 378 }, 379 }, 380 }; 381 382 static struct clk_branch gsbi1_uart_clk = { 383 .halt_reg = 0x2fcc, 384 .halt_bit = 10, 385 .clkr = { 386 .enable_reg = 0x29d4, 387 .enable_mask = BIT(9), 388 .hw.init = &(struct clk_init_data){ 389 .name = "gsbi1_uart_clk", 390 .parent_hws = (const struct clk_hw*[]){ 391 &gsbi1_uart_src.clkr.hw 392 }, 393 .num_parents = 1, 394 .ops = &clk_branch_ops, 395 .flags = CLK_SET_RATE_PARENT, 396 }, 397 }, 398 }; 399 400 static struct clk_rcg gsbi2_uart_src = { 401 .ns_reg = 0x29f4, 402 .md_reg = 0x29f0, 403 .mn = { 404 .mnctr_en_bit = 8, 405 .mnctr_reset_bit = 7, 406 .mnctr_mode_shift = 5, 407 .n_val_shift = 16, 408 .m_val_shift = 16, 409 .width = 16, 410 }, 411 .p = { 412 .pre_div_shift = 3, 413 .pre_div_width = 2, 414 }, 415 .s = { 416 .src_sel_shift = 0, 417 .parent_map = gcc_pxo_pll8_map, 418 }, 419 .freq_tbl = clk_tbl_gsbi_uart, 420 .clkr = { 421 .enable_reg = 0x29f4, 422 .enable_mask = BIT(11), 423 .hw.init = &(struct clk_init_data){ 424 .name = "gsbi2_uart_src", 425 .parent_data = gcc_pxo_pll8, 426 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 427 .ops = &clk_rcg_ops, 428 .flags = CLK_SET_PARENT_GATE, 429 }, 430 }, 431 }; 432 433 static struct clk_branch gsbi2_uart_clk = { 434 .halt_reg = 0x2fcc, 435 .halt_bit = 6, 436 .clkr = { 437 .enable_reg = 0x29f4, 438 .enable_mask = BIT(9), 439 .hw.init = &(struct clk_init_data){ 440 .name = "gsbi2_uart_clk", 441 .parent_hws = (const struct clk_hw*[]){ 442 &gsbi2_uart_src.clkr.hw 443 }, 444 .num_parents = 1, 445 .ops = &clk_branch_ops, 446 .flags = CLK_SET_RATE_PARENT, 447 }, 448 }, 449 }; 450 451 static struct clk_rcg gsbi3_uart_src = { 452 .ns_reg = 0x2a14, 453 .md_reg = 0x2a10, 454 .mn = { 455 .mnctr_en_bit = 8, 456 .mnctr_reset_bit = 7, 457 .mnctr_mode_shift = 5, 458 .n_val_shift = 16, 459 .m_val_shift = 16, 460 .width = 16, 461 }, 462 .p = { 463 .pre_div_shift = 3, 464 .pre_div_width = 2, 465 }, 466 .s = { 467 .src_sel_shift = 0, 468 .parent_map = gcc_pxo_pll8_map, 469 }, 470 .freq_tbl = clk_tbl_gsbi_uart, 471 .clkr = { 472 .enable_reg = 0x2a14, 473 .enable_mask = BIT(11), 474 .hw.init = &(struct clk_init_data){ 475 .name = "gsbi3_uart_src", 476 .parent_data = gcc_pxo_pll8, 477 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 478 .ops = &clk_rcg_ops, 479 .flags = CLK_SET_PARENT_GATE, 480 }, 481 }, 482 }; 483 484 static struct clk_branch gsbi3_uart_clk = { 485 .halt_reg = 0x2fcc, 486 .halt_bit = 2, 487 .clkr = { 488 .enable_reg = 0x2a14, 489 .enable_mask = BIT(9), 490 .hw.init = &(struct clk_init_data){ 491 .name = "gsbi3_uart_clk", 492 .parent_hws = (const struct clk_hw*[]){ 493 &gsbi3_uart_src.clkr.hw 494 }, 495 .num_parents = 1, 496 .ops = &clk_branch_ops, 497 .flags = CLK_SET_RATE_PARENT, 498 }, 499 }, 500 }; 501 502 static struct clk_rcg gsbi4_uart_src = { 503 .ns_reg = 0x2a34, 504 .md_reg = 0x2a30, 505 .mn = { 506 .mnctr_en_bit = 8, 507 .mnctr_reset_bit = 7, 508 .mnctr_mode_shift = 5, 509 .n_val_shift = 16, 510 .m_val_shift = 16, 511 .width = 16, 512 }, 513 .p = { 514 .pre_div_shift = 3, 515 .pre_div_width = 2, 516 }, 517 .s = { 518 .src_sel_shift = 0, 519 .parent_map = gcc_pxo_pll8_map, 520 }, 521 .freq_tbl = clk_tbl_gsbi_uart, 522 .clkr = { 523 .enable_reg = 0x2a34, 524 .enable_mask = BIT(11), 525 .hw.init = &(struct clk_init_data){ 526 .name = "gsbi4_uart_src", 527 .parent_data = gcc_pxo_pll8, 528 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 529 .ops = &clk_rcg_ops, 530 .flags = CLK_SET_PARENT_GATE, 531 }, 532 }, 533 }; 534 535 static struct clk_branch gsbi4_uart_clk = { 536 .halt_reg = 0x2fd0, 537 .halt_bit = 26, 538 .clkr = { 539 .enable_reg = 0x2a34, 540 .enable_mask = BIT(9), 541 .hw.init = &(struct clk_init_data){ 542 .name = "gsbi4_uart_clk", 543 .parent_hws = (const struct clk_hw*[]){ 544 &gsbi4_uart_src.clkr.hw 545 }, 546 .num_parents = 1, 547 .ops = &clk_branch_ops, 548 .flags = CLK_SET_RATE_PARENT, 549 }, 550 }, 551 }; 552 553 static struct clk_rcg gsbi5_uart_src = { 554 .ns_reg = 0x2a54, 555 .md_reg = 0x2a50, 556 .mn = { 557 .mnctr_en_bit = 8, 558 .mnctr_reset_bit = 7, 559 .mnctr_mode_shift = 5, 560 .n_val_shift = 16, 561 .m_val_shift = 16, 562 .width = 16, 563 }, 564 .p = { 565 .pre_div_shift = 3, 566 .pre_div_width = 2, 567 }, 568 .s = { 569 .src_sel_shift = 0, 570 .parent_map = gcc_pxo_pll8_map, 571 }, 572 .freq_tbl = clk_tbl_gsbi_uart, 573 .clkr = { 574 .enable_reg = 0x2a54, 575 .enable_mask = BIT(11), 576 .hw.init = &(struct clk_init_data){ 577 .name = "gsbi5_uart_src", 578 .parent_data = gcc_pxo_pll8, 579 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 580 .ops = &clk_rcg_ops, 581 .flags = CLK_SET_PARENT_GATE, 582 }, 583 }, 584 }; 585 586 static struct clk_branch gsbi5_uart_clk = { 587 .halt_reg = 0x2fd0, 588 .halt_bit = 22, 589 .clkr = { 590 .enable_reg = 0x2a54, 591 .enable_mask = BIT(9), 592 .hw.init = &(struct clk_init_data){ 593 .name = "gsbi5_uart_clk", 594 .parent_hws = (const struct clk_hw*[]){ 595 &gsbi5_uart_src.clkr.hw 596 }, 597 .num_parents = 1, 598 .ops = &clk_branch_ops, 599 .flags = CLK_SET_RATE_PARENT, 600 }, 601 }, 602 }; 603 604 static struct clk_rcg gsbi6_uart_src = { 605 .ns_reg = 0x2a74, 606 .md_reg = 0x2a70, 607 .mn = { 608 .mnctr_en_bit = 8, 609 .mnctr_reset_bit = 7, 610 .mnctr_mode_shift = 5, 611 .n_val_shift = 16, 612 .m_val_shift = 16, 613 .width = 16, 614 }, 615 .p = { 616 .pre_div_shift = 3, 617 .pre_div_width = 2, 618 }, 619 .s = { 620 .src_sel_shift = 0, 621 .parent_map = gcc_pxo_pll8_map, 622 }, 623 .freq_tbl = clk_tbl_gsbi_uart, 624 .clkr = { 625 .enable_reg = 0x2a74, 626 .enable_mask = BIT(11), 627 .hw.init = &(struct clk_init_data){ 628 .name = "gsbi6_uart_src", 629 .parent_data = gcc_pxo_pll8, 630 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 631 .ops = &clk_rcg_ops, 632 .flags = CLK_SET_PARENT_GATE, 633 }, 634 }, 635 }; 636 637 static struct clk_branch gsbi6_uart_clk = { 638 .halt_reg = 0x2fd0, 639 .halt_bit = 18, 640 .clkr = { 641 .enable_reg = 0x2a74, 642 .enable_mask = BIT(9), 643 .hw.init = &(struct clk_init_data){ 644 .name = "gsbi6_uart_clk", 645 .parent_hws = (const struct clk_hw*[]){ 646 &gsbi6_uart_src.clkr.hw 647 }, 648 .num_parents = 1, 649 .ops = &clk_branch_ops, 650 .flags = CLK_SET_RATE_PARENT, 651 }, 652 }, 653 }; 654 655 static struct clk_rcg gsbi7_uart_src = { 656 .ns_reg = 0x2a94, 657 .md_reg = 0x2a90, 658 .mn = { 659 .mnctr_en_bit = 8, 660 .mnctr_reset_bit = 7, 661 .mnctr_mode_shift = 5, 662 .n_val_shift = 16, 663 .m_val_shift = 16, 664 .width = 16, 665 }, 666 .p = { 667 .pre_div_shift = 3, 668 .pre_div_width = 2, 669 }, 670 .s = { 671 .src_sel_shift = 0, 672 .parent_map = gcc_pxo_pll8_map, 673 }, 674 .freq_tbl = clk_tbl_gsbi_uart, 675 .clkr = { 676 .enable_reg = 0x2a94, 677 .enable_mask = BIT(11), 678 .hw.init = &(struct clk_init_data){ 679 .name = "gsbi7_uart_src", 680 .parent_data = gcc_pxo_pll8, 681 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 682 .ops = &clk_rcg_ops, 683 .flags = CLK_SET_PARENT_GATE, 684 }, 685 }, 686 }; 687 688 static struct clk_branch gsbi7_uart_clk = { 689 .halt_reg = 0x2fd0, 690 .halt_bit = 14, 691 .clkr = { 692 .enable_reg = 0x2a94, 693 .enable_mask = BIT(9), 694 .hw.init = &(struct clk_init_data){ 695 .name = "gsbi7_uart_clk", 696 .parent_hws = (const struct clk_hw*[]){ 697 &gsbi7_uart_src.clkr.hw 698 }, 699 .num_parents = 1, 700 .ops = &clk_branch_ops, 701 .flags = CLK_SET_RATE_PARENT, 702 }, 703 }, 704 }; 705 706 static struct clk_rcg gsbi8_uart_src = { 707 .ns_reg = 0x2ab4, 708 .md_reg = 0x2ab0, 709 .mn = { 710 .mnctr_en_bit = 8, 711 .mnctr_reset_bit = 7, 712 .mnctr_mode_shift = 5, 713 .n_val_shift = 16, 714 .m_val_shift = 16, 715 .width = 16, 716 }, 717 .p = { 718 .pre_div_shift = 3, 719 .pre_div_width = 2, 720 }, 721 .s = { 722 .src_sel_shift = 0, 723 .parent_map = gcc_pxo_pll8_map, 724 }, 725 .freq_tbl = clk_tbl_gsbi_uart, 726 .clkr = { 727 .enable_reg = 0x2ab4, 728 .enable_mask = BIT(11), 729 .hw.init = &(struct clk_init_data){ 730 .name = "gsbi8_uart_src", 731 .parent_data = gcc_pxo_pll8, 732 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 733 .ops = &clk_rcg_ops, 734 .flags = CLK_SET_PARENT_GATE, 735 }, 736 }, 737 }; 738 739 static struct clk_branch gsbi8_uart_clk = { 740 .halt_reg = 0x2fd0, 741 .halt_bit = 10, 742 .clkr = { 743 .enable_reg = 0x2ab4, 744 .enable_mask = BIT(9), 745 .hw.init = &(struct clk_init_data){ 746 .name = "gsbi8_uart_clk", 747 .parent_hws = (const struct clk_hw*[]){ 748 &gsbi8_uart_src.clkr.hw 749 }, 750 .num_parents = 1, 751 .ops = &clk_branch_ops, 752 .flags = CLK_SET_RATE_PARENT, 753 }, 754 }, 755 }; 756 757 static struct clk_rcg gsbi9_uart_src = { 758 .ns_reg = 0x2ad4, 759 .md_reg = 0x2ad0, 760 .mn = { 761 .mnctr_en_bit = 8, 762 .mnctr_reset_bit = 7, 763 .mnctr_mode_shift = 5, 764 .n_val_shift = 16, 765 .m_val_shift = 16, 766 .width = 16, 767 }, 768 .p = { 769 .pre_div_shift = 3, 770 .pre_div_width = 2, 771 }, 772 .s = { 773 .src_sel_shift = 0, 774 .parent_map = gcc_pxo_pll8_map, 775 }, 776 .freq_tbl = clk_tbl_gsbi_uart, 777 .clkr = { 778 .enable_reg = 0x2ad4, 779 .enable_mask = BIT(11), 780 .hw.init = &(struct clk_init_data){ 781 .name = "gsbi9_uart_src", 782 .parent_data = gcc_pxo_pll8, 783 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 784 .ops = &clk_rcg_ops, 785 .flags = CLK_SET_PARENT_GATE, 786 }, 787 }, 788 }; 789 790 static struct clk_branch gsbi9_uart_clk = { 791 .halt_reg = 0x2fd0, 792 .halt_bit = 6, 793 .clkr = { 794 .enable_reg = 0x2ad4, 795 .enable_mask = BIT(9), 796 .hw.init = &(struct clk_init_data){ 797 .name = "gsbi9_uart_clk", 798 .parent_hws = (const struct clk_hw*[]){ 799 &gsbi9_uart_src.clkr.hw 800 }, 801 .num_parents = 1, 802 .ops = &clk_branch_ops, 803 .flags = CLK_SET_RATE_PARENT, 804 }, 805 }, 806 }; 807 808 static struct clk_rcg gsbi10_uart_src = { 809 .ns_reg = 0x2af4, 810 .md_reg = 0x2af0, 811 .mn = { 812 .mnctr_en_bit = 8, 813 .mnctr_reset_bit = 7, 814 .mnctr_mode_shift = 5, 815 .n_val_shift = 16, 816 .m_val_shift = 16, 817 .width = 16, 818 }, 819 .p = { 820 .pre_div_shift = 3, 821 .pre_div_width = 2, 822 }, 823 .s = { 824 .src_sel_shift = 0, 825 .parent_map = gcc_pxo_pll8_map, 826 }, 827 .freq_tbl = clk_tbl_gsbi_uart, 828 .clkr = { 829 .enable_reg = 0x2af4, 830 .enable_mask = BIT(11), 831 .hw.init = &(struct clk_init_data){ 832 .name = "gsbi10_uart_src", 833 .parent_data = gcc_pxo_pll8, 834 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 835 .ops = &clk_rcg_ops, 836 .flags = CLK_SET_PARENT_GATE, 837 }, 838 }, 839 }; 840 841 static struct clk_branch gsbi10_uart_clk = { 842 .halt_reg = 0x2fd0, 843 .halt_bit = 2, 844 .clkr = { 845 .enable_reg = 0x2af4, 846 .enable_mask = BIT(9), 847 .hw.init = &(struct clk_init_data){ 848 .name = "gsbi10_uart_clk", 849 .parent_hws = (const struct clk_hw*[]){ 850 &gsbi10_uart_src.clkr.hw 851 }, 852 .num_parents = 1, 853 .ops = &clk_branch_ops, 854 .flags = CLK_SET_RATE_PARENT, 855 }, 856 }, 857 }; 858 859 static struct clk_rcg gsbi11_uart_src = { 860 .ns_reg = 0x2b14, 861 .md_reg = 0x2b10, 862 .mn = { 863 .mnctr_en_bit = 8, 864 .mnctr_reset_bit = 7, 865 .mnctr_mode_shift = 5, 866 .n_val_shift = 16, 867 .m_val_shift = 16, 868 .width = 16, 869 }, 870 .p = { 871 .pre_div_shift = 3, 872 .pre_div_width = 2, 873 }, 874 .s = { 875 .src_sel_shift = 0, 876 .parent_map = gcc_pxo_pll8_map, 877 }, 878 .freq_tbl = clk_tbl_gsbi_uart, 879 .clkr = { 880 .enable_reg = 0x2b14, 881 .enable_mask = BIT(11), 882 .hw.init = &(struct clk_init_data){ 883 .name = "gsbi11_uart_src", 884 .parent_data = gcc_pxo_pll8, 885 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 886 .ops = &clk_rcg_ops, 887 .flags = CLK_SET_PARENT_GATE, 888 }, 889 }, 890 }; 891 892 static struct clk_branch gsbi11_uart_clk = { 893 .halt_reg = 0x2fd4, 894 .halt_bit = 17, 895 .clkr = { 896 .enable_reg = 0x2b14, 897 .enable_mask = BIT(9), 898 .hw.init = &(struct clk_init_data){ 899 .name = "gsbi11_uart_clk", 900 .parent_hws = (const struct clk_hw*[]){ 901 &gsbi11_uart_src.clkr.hw 902 }, 903 .num_parents = 1, 904 .ops = &clk_branch_ops, 905 .flags = CLK_SET_RATE_PARENT, 906 }, 907 }, 908 }; 909 910 static struct clk_rcg gsbi12_uart_src = { 911 .ns_reg = 0x2b34, 912 .md_reg = 0x2b30, 913 .mn = { 914 .mnctr_en_bit = 8, 915 .mnctr_reset_bit = 7, 916 .mnctr_mode_shift = 5, 917 .n_val_shift = 16, 918 .m_val_shift = 16, 919 .width = 16, 920 }, 921 .p = { 922 .pre_div_shift = 3, 923 .pre_div_width = 2, 924 }, 925 .s = { 926 .src_sel_shift = 0, 927 .parent_map = gcc_pxo_pll8_map, 928 }, 929 .freq_tbl = clk_tbl_gsbi_uart, 930 .clkr = { 931 .enable_reg = 0x2b34, 932 .enable_mask = BIT(11), 933 .hw.init = &(struct clk_init_data){ 934 .name = "gsbi12_uart_src", 935 .parent_data = gcc_pxo_pll8, 936 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 937 .ops = &clk_rcg_ops, 938 .flags = CLK_SET_PARENT_GATE, 939 }, 940 }, 941 }; 942 943 static struct clk_branch gsbi12_uart_clk = { 944 .halt_reg = 0x2fd4, 945 .halt_bit = 13, 946 .clkr = { 947 .enable_reg = 0x2b34, 948 .enable_mask = BIT(9), 949 .hw.init = &(struct clk_init_data){ 950 .name = "gsbi12_uart_clk", 951 .parent_hws = (const struct clk_hw*[]){ 952 &gsbi12_uart_src.clkr.hw 953 }, 954 .num_parents = 1, 955 .ops = &clk_branch_ops, 956 .flags = CLK_SET_RATE_PARENT, 957 }, 958 }, 959 }; 960 961 static const struct freq_tbl clk_tbl_gsbi_qup[] = { 962 { 1100000, P_PXO, 1, 2, 49 }, 963 { 5400000, P_PXO, 1, 1, 5 }, 964 { 10800000, P_PXO, 1, 2, 5 }, 965 { 15060000, P_PLL8, 1, 2, 51 }, 966 { 24000000, P_PLL8, 4, 1, 4 }, 967 { 25600000, P_PLL8, 1, 1, 15 }, 968 { 27000000, P_PXO, 1, 0, 0 }, 969 { 48000000, P_PLL8, 4, 1, 2 }, 970 { 51200000, P_PLL8, 1, 2, 15 }, 971 { } 972 }; 973 974 static struct clk_rcg gsbi1_qup_src = { 975 .ns_reg = 0x29cc, 976 .md_reg = 0x29c8, 977 .mn = { 978 .mnctr_en_bit = 8, 979 .mnctr_reset_bit = 7, 980 .mnctr_mode_shift = 5, 981 .n_val_shift = 16, 982 .m_val_shift = 16, 983 .width = 8, 984 }, 985 .p = { 986 .pre_div_shift = 3, 987 .pre_div_width = 2, 988 }, 989 .s = { 990 .src_sel_shift = 0, 991 .parent_map = gcc_pxo_pll8_map, 992 }, 993 .freq_tbl = clk_tbl_gsbi_qup, 994 .clkr = { 995 .enable_reg = 0x29cc, 996 .enable_mask = BIT(11), 997 .hw.init = &(struct clk_init_data){ 998 .name = "gsbi1_qup_src", 999 .parent_data = gcc_pxo_pll8, 1000 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1001 .ops = &clk_rcg_ops, 1002 .flags = CLK_SET_PARENT_GATE, 1003 }, 1004 }, 1005 }; 1006 1007 static struct clk_branch gsbi1_qup_clk = { 1008 .halt_reg = 0x2fcc, 1009 .halt_bit = 9, 1010 .clkr = { 1011 .enable_reg = 0x29cc, 1012 .enable_mask = BIT(9), 1013 .hw.init = &(struct clk_init_data){ 1014 .name = "gsbi1_qup_clk", 1015 .parent_hws = (const struct clk_hw*[]){ 1016 &gsbi1_qup_src.clkr.hw 1017 }, 1018 .num_parents = 1, 1019 .ops = &clk_branch_ops, 1020 .flags = CLK_SET_RATE_PARENT, 1021 }, 1022 }, 1023 }; 1024 1025 static struct clk_rcg gsbi2_qup_src = { 1026 .ns_reg = 0x29ec, 1027 .md_reg = 0x29e8, 1028 .mn = { 1029 .mnctr_en_bit = 8, 1030 .mnctr_reset_bit = 7, 1031 .mnctr_mode_shift = 5, 1032 .n_val_shift = 16, 1033 .m_val_shift = 16, 1034 .width = 8, 1035 }, 1036 .p = { 1037 .pre_div_shift = 3, 1038 .pre_div_width = 2, 1039 }, 1040 .s = { 1041 .src_sel_shift = 0, 1042 .parent_map = gcc_pxo_pll8_map, 1043 }, 1044 .freq_tbl = clk_tbl_gsbi_qup, 1045 .clkr = { 1046 .enable_reg = 0x29ec, 1047 .enable_mask = BIT(11), 1048 .hw.init = &(struct clk_init_data){ 1049 .name = "gsbi2_qup_src", 1050 .parent_data = gcc_pxo_pll8, 1051 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1052 .ops = &clk_rcg_ops, 1053 .flags = CLK_SET_PARENT_GATE, 1054 }, 1055 }, 1056 }; 1057 1058 static struct clk_branch gsbi2_qup_clk = { 1059 .halt_reg = 0x2fcc, 1060 .halt_bit = 4, 1061 .clkr = { 1062 .enable_reg = 0x29ec, 1063 .enable_mask = BIT(9), 1064 .hw.init = &(struct clk_init_data){ 1065 .name = "gsbi2_qup_clk", 1066 .parent_hws = (const struct clk_hw*[]){ 1067 &gsbi2_qup_src.clkr.hw 1068 }, 1069 .num_parents = 1, 1070 .ops = &clk_branch_ops, 1071 .flags = CLK_SET_RATE_PARENT, 1072 }, 1073 }, 1074 }; 1075 1076 static struct clk_rcg gsbi3_qup_src = { 1077 .ns_reg = 0x2a0c, 1078 .md_reg = 0x2a08, 1079 .mn = { 1080 .mnctr_en_bit = 8, 1081 .mnctr_reset_bit = 7, 1082 .mnctr_mode_shift = 5, 1083 .n_val_shift = 16, 1084 .m_val_shift = 16, 1085 .width = 8, 1086 }, 1087 .p = { 1088 .pre_div_shift = 3, 1089 .pre_div_width = 2, 1090 }, 1091 .s = { 1092 .src_sel_shift = 0, 1093 .parent_map = gcc_pxo_pll8_map, 1094 }, 1095 .freq_tbl = clk_tbl_gsbi_qup, 1096 .clkr = { 1097 .enable_reg = 0x2a0c, 1098 .enable_mask = BIT(11), 1099 .hw.init = &(struct clk_init_data){ 1100 .name = "gsbi3_qup_src", 1101 .parent_data = gcc_pxo_pll8, 1102 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1103 .ops = &clk_rcg_ops, 1104 .flags = CLK_SET_PARENT_GATE, 1105 }, 1106 }, 1107 }; 1108 1109 static struct clk_branch gsbi3_qup_clk = { 1110 .halt_reg = 0x2fcc, 1111 .halt_bit = 0, 1112 .clkr = { 1113 .enable_reg = 0x2a0c, 1114 .enable_mask = BIT(9), 1115 .hw.init = &(struct clk_init_data){ 1116 .name = "gsbi3_qup_clk", 1117 .parent_hws = (const struct clk_hw*[]){ 1118 &gsbi3_qup_src.clkr.hw 1119 }, 1120 .num_parents = 1, 1121 .ops = &clk_branch_ops, 1122 .flags = CLK_SET_RATE_PARENT, 1123 }, 1124 }, 1125 }; 1126 1127 static struct clk_rcg gsbi4_qup_src = { 1128 .ns_reg = 0x2a2c, 1129 .md_reg = 0x2a28, 1130 .mn = { 1131 .mnctr_en_bit = 8, 1132 .mnctr_reset_bit = 7, 1133 .mnctr_mode_shift = 5, 1134 .n_val_shift = 16, 1135 .m_val_shift = 16, 1136 .width = 8, 1137 }, 1138 .p = { 1139 .pre_div_shift = 3, 1140 .pre_div_width = 2, 1141 }, 1142 .s = { 1143 .src_sel_shift = 0, 1144 .parent_map = gcc_pxo_pll8_map, 1145 }, 1146 .freq_tbl = clk_tbl_gsbi_qup, 1147 .clkr = { 1148 .enable_reg = 0x2a2c, 1149 .enable_mask = BIT(11), 1150 .hw.init = &(struct clk_init_data){ 1151 .name = "gsbi4_qup_src", 1152 .parent_data = gcc_pxo_pll8, 1153 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1154 .ops = &clk_rcg_ops, 1155 .flags = CLK_SET_PARENT_GATE, 1156 }, 1157 }, 1158 }; 1159 1160 static struct clk_branch gsbi4_qup_clk = { 1161 .halt_reg = 0x2fd0, 1162 .halt_bit = 24, 1163 .clkr = { 1164 .enable_reg = 0x2a2c, 1165 .enable_mask = BIT(9), 1166 .hw.init = &(struct clk_init_data){ 1167 .name = "gsbi4_qup_clk", 1168 .parent_hws = (const struct clk_hw*[]){ 1169 &gsbi4_qup_src.clkr.hw 1170 }, 1171 .num_parents = 1, 1172 .ops = &clk_branch_ops, 1173 .flags = CLK_SET_RATE_PARENT, 1174 }, 1175 }, 1176 }; 1177 1178 static struct clk_rcg gsbi5_qup_src = { 1179 .ns_reg = 0x2a4c, 1180 .md_reg = 0x2a48, 1181 .mn = { 1182 .mnctr_en_bit = 8, 1183 .mnctr_reset_bit = 7, 1184 .mnctr_mode_shift = 5, 1185 .n_val_shift = 16, 1186 .m_val_shift = 16, 1187 .width = 8, 1188 }, 1189 .p = { 1190 .pre_div_shift = 3, 1191 .pre_div_width = 2, 1192 }, 1193 .s = { 1194 .src_sel_shift = 0, 1195 .parent_map = gcc_pxo_pll8_map, 1196 }, 1197 .freq_tbl = clk_tbl_gsbi_qup, 1198 .clkr = { 1199 .enable_reg = 0x2a4c, 1200 .enable_mask = BIT(11), 1201 .hw.init = &(struct clk_init_data){ 1202 .name = "gsbi5_qup_src", 1203 .parent_data = gcc_pxo_pll8, 1204 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1205 .ops = &clk_rcg_ops, 1206 .flags = CLK_SET_PARENT_GATE, 1207 }, 1208 }, 1209 }; 1210 1211 static struct clk_branch gsbi5_qup_clk = { 1212 .halt_reg = 0x2fd0, 1213 .halt_bit = 20, 1214 .clkr = { 1215 .enable_reg = 0x2a4c, 1216 .enable_mask = BIT(9), 1217 .hw.init = &(struct clk_init_data){ 1218 .name = "gsbi5_qup_clk", 1219 .parent_hws = (const struct clk_hw*[]){ 1220 &gsbi5_qup_src.clkr.hw 1221 }, 1222 .num_parents = 1, 1223 .ops = &clk_branch_ops, 1224 .flags = CLK_SET_RATE_PARENT, 1225 }, 1226 }, 1227 }; 1228 1229 static struct clk_rcg gsbi6_qup_src = { 1230 .ns_reg = 0x2a6c, 1231 .md_reg = 0x2a68, 1232 .mn = { 1233 .mnctr_en_bit = 8, 1234 .mnctr_reset_bit = 7, 1235 .mnctr_mode_shift = 5, 1236 .n_val_shift = 16, 1237 .m_val_shift = 16, 1238 .width = 8, 1239 }, 1240 .p = { 1241 .pre_div_shift = 3, 1242 .pre_div_width = 2, 1243 }, 1244 .s = { 1245 .src_sel_shift = 0, 1246 .parent_map = gcc_pxo_pll8_map, 1247 }, 1248 .freq_tbl = clk_tbl_gsbi_qup, 1249 .clkr = { 1250 .enable_reg = 0x2a6c, 1251 .enable_mask = BIT(11), 1252 .hw.init = &(struct clk_init_data){ 1253 .name = "gsbi6_qup_src", 1254 .parent_data = gcc_pxo_pll8, 1255 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1256 .ops = &clk_rcg_ops, 1257 .flags = CLK_SET_PARENT_GATE, 1258 }, 1259 }, 1260 }; 1261 1262 static struct clk_branch gsbi6_qup_clk = { 1263 .halt_reg = 0x2fd0, 1264 .halt_bit = 16, 1265 .clkr = { 1266 .enable_reg = 0x2a6c, 1267 .enable_mask = BIT(9), 1268 .hw.init = &(struct clk_init_data){ 1269 .name = "gsbi6_qup_clk", 1270 .parent_hws = (const struct clk_hw*[]){ 1271 &gsbi6_qup_src.clkr.hw 1272 }, 1273 .num_parents = 1, 1274 .ops = &clk_branch_ops, 1275 .flags = CLK_SET_RATE_PARENT, 1276 }, 1277 }, 1278 }; 1279 1280 static struct clk_rcg gsbi7_qup_src = { 1281 .ns_reg = 0x2a8c, 1282 .md_reg = 0x2a88, 1283 .mn = { 1284 .mnctr_en_bit = 8, 1285 .mnctr_reset_bit = 7, 1286 .mnctr_mode_shift = 5, 1287 .n_val_shift = 16, 1288 .m_val_shift = 16, 1289 .width = 8, 1290 }, 1291 .p = { 1292 .pre_div_shift = 3, 1293 .pre_div_width = 2, 1294 }, 1295 .s = { 1296 .src_sel_shift = 0, 1297 .parent_map = gcc_pxo_pll8_map, 1298 }, 1299 .freq_tbl = clk_tbl_gsbi_qup, 1300 .clkr = { 1301 .enable_reg = 0x2a8c, 1302 .enable_mask = BIT(11), 1303 .hw.init = &(struct clk_init_data){ 1304 .name = "gsbi7_qup_src", 1305 .parent_data = gcc_pxo_pll8, 1306 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1307 .ops = &clk_rcg_ops, 1308 .flags = CLK_SET_PARENT_GATE, 1309 }, 1310 }, 1311 }; 1312 1313 static struct clk_branch gsbi7_qup_clk = { 1314 .halt_reg = 0x2fd0, 1315 .halt_bit = 12, 1316 .clkr = { 1317 .enable_reg = 0x2a8c, 1318 .enable_mask = BIT(9), 1319 .hw.init = &(struct clk_init_data){ 1320 .name = "gsbi7_qup_clk", 1321 .parent_hws = (const struct clk_hw*[]){ 1322 &gsbi7_qup_src.clkr.hw 1323 }, 1324 .num_parents = 1, 1325 .ops = &clk_branch_ops, 1326 .flags = CLK_SET_RATE_PARENT, 1327 }, 1328 }, 1329 }; 1330 1331 static struct clk_rcg gsbi8_qup_src = { 1332 .ns_reg = 0x2aac, 1333 .md_reg = 0x2aa8, 1334 .mn = { 1335 .mnctr_en_bit = 8, 1336 .mnctr_reset_bit = 7, 1337 .mnctr_mode_shift = 5, 1338 .n_val_shift = 16, 1339 .m_val_shift = 16, 1340 .width = 8, 1341 }, 1342 .p = { 1343 .pre_div_shift = 3, 1344 .pre_div_width = 2, 1345 }, 1346 .s = { 1347 .src_sel_shift = 0, 1348 .parent_map = gcc_pxo_pll8_map, 1349 }, 1350 .freq_tbl = clk_tbl_gsbi_qup, 1351 .clkr = { 1352 .enable_reg = 0x2aac, 1353 .enable_mask = BIT(11), 1354 .hw.init = &(struct clk_init_data){ 1355 .name = "gsbi8_qup_src", 1356 .parent_data = gcc_pxo_pll8, 1357 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1358 .ops = &clk_rcg_ops, 1359 .flags = CLK_SET_PARENT_GATE, 1360 }, 1361 }, 1362 }; 1363 1364 static struct clk_branch gsbi8_qup_clk = { 1365 .halt_reg = 0x2fd0, 1366 .halt_bit = 8, 1367 .clkr = { 1368 .enable_reg = 0x2aac, 1369 .enable_mask = BIT(9), 1370 .hw.init = &(struct clk_init_data){ 1371 .name = "gsbi8_qup_clk", 1372 .parent_hws = (const struct clk_hw*[]){ 1373 &gsbi8_qup_src.clkr.hw 1374 }, 1375 .num_parents = 1, 1376 .ops = &clk_branch_ops, 1377 .flags = CLK_SET_RATE_PARENT, 1378 }, 1379 }, 1380 }; 1381 1382 static struct clk_rcg gsbi9_qup_src = { 1383 .ns_reg = 0x2acc, 1384 .md_reg = 0x2ac8, 1385 .mn = { 1386 .mnctr_en_bit = 8, 1387 .mnctr_reset_bit = 7, 1388 .mnctr_mode_shift = 5, 1389 .n_val_shift = 16, 1390 .m_val_shift = 16, 1391 .width = 8, 1392 }, 1393 .p = { 1394 .pre_div_shift = 3, 1395 .pre_div_width = 2, 1396 }, 1397 .s = { 1398 .src_sel_shift = 0, 1399 .parent_map = gcc_pxo_pll8_map, 1400 }, 1401 .freq_tbl = clk_tbl_gsbi_qup, 1402 .clkr = { 1403 .enable_reg = 0x2acc, 1404 .enable_mask = BIT(11), 1405 .hw.init = &(struct clk_init_data){ 1406 .name = "gsbi9_qup_src", 1407 .parent_data = gcc_pxo_pll8, 1408 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1409 .ops = &clk_rcg_ops, 1410 .flags = CLK_SET_PARENT_GATE, 1411 }, 1412 }, 1413 }; 1414 1415 static struct clk_branch gsbi9_qup_clk = { 1416 .halt_reg = 0x2fd0, 1417 .halt_bit = 4, 1418 .clkr = { 1419 .enable_reg = 0x2acc, 1420 .enable_mask = BIT(9), 1421 .hw.init = &(struct clk_init_data){ 1422 .name = "gsbi9_qup_clk", 1423 .parent_hws = (const struct clk_hw*[]){ 1424 &gsbi9_qup_src.clkr.hw 1425 }, 1426 .num_parents = 1, 1427 .ops = &clk_branch_ops, 1428 .flags = CLK_SET_RATE_PARENT, 1429 }, 1430 }, 1431 }; 1432 1433 static struct clk_rcg gsbi10_qup_src = { 1434 .ns_reg = 0x2aec, 1435 .md_reg = 0x2ae8, 1436 .mn = { 1437 .mnctr_en_bit = 8, 1438 .mnctr_reset_bit = 7, 1439 .mnctr_mode_shift = 5, 1440 .n_val_shift = 16, 1441 .m_val_shift = 16, 1442 .width = 8, 1443 }, 1444 .p = { 1445 .pre_div_shift = 3, 1446 .pre_div_width = 2, 1447 }, 1448 .s = { 1449 .src_sel_shift = 0, 1450 .parent_map = gcc_pxo_pll8_map, 1451 }, 1452 .freq_tbl = clk_tbl_gsbi_qup, 1453 .clkr = { 1454 .enable_reg = 0x2aec, 1455 .enable_mask = BIT(11), 1456 .hw.init = &(struct clk_init_data){ 1457 .name = "gsbi10_qup_src", 1458 .parent_data = gcc_pxo_pll8, 1459 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1460 .ops = &clk_rcg_ops, 1461 .flags = CLK_SET_PARENT_GATE, 1462 }, 1463 }, 1464 }; 1465 1466 static struct clk_branch gsbi10_qup_clk = { 1467 .halt_reg = 0x2fd0, 1468 .halt_bit = 0, 1469 .clkr = { 1470 .enable_reg = 0x2aec, 1471 .enable_mask = BIT(9), 1472 .hw.init = &(struct clk_init_data){ 1473 .name = "gsbi10_qup_clk", 1474 .parent_hws = (const struct clk_hw*[]){ 1475 &gsbi10_qup_src.clkr.hw 1476 }, 1477 .num_parents = 1, 1478 .ops = &clk_branch_ops, 1479 .flags = CLK_SET_RATE_PARENT, 1480 }, 1481 }, 1482 }; 1483 1484 static struct clk_rcg gsbi11_qup_src = { 1485 .ns_reg = 0x2b0c, 1486 .md_reg = 0x2b08, 1487 .mn = { 1488 .mnctr_en_bit = 8, 1489 .mnctr_reset_bit = 7, 1490 .mnctr_mode_shift = 5, 1491 .n_val_shift = 16, 1492 .m_val_shift = 16, 1493 .width = 8, 1494 }, 1495 .p = { 1496 .pre_div_shift = 3, 1497 .pre_div_width = 2, 1498 }, 1499 .s = { 1500 .src_sel_shift = 0, 1501 .parent_map = gcc_pxo_pll8_map, 1502 }, 1503 .freq_tbl = clk_tbl_gsbi_qup, 1504 .clkr = { 1505 .enable_reg = 0x2b0c, 1506 .enable_mask = BIT(11), 1507 .hw.init = &(struct clk_init_data){ 1508 .name = "gsbi11_qup_src", 1509 .parent_data = gcc_pxo_pll8, 1510 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1511 .ops = &clk_rcg_ops, 1512 .flags = CLK_SET_PARENT_GATE, 1513 }, 1514 }, 1515 }; 1516 1517 static struct clk_branch gsbi11_qup_clk = { 1518 .halt_reg = 0x2fd4, 1519 .halt_bit = 15, 1520 .clkr = { 1521 .enable_reg = 0x2b0c, 1522 .enable_mask = BIT(9), 1523 .hw.init = &(struct clk_init_data){ 1524 .name = "gsbi11_qup_clk", 1525 .parent_hws = (const struct clk_hw*[]){ 1526 &gsbi11_qup_src.clkr.hw 1527 }, 1528 .num_parents = 1, 1529 .ops = &clk_branch_ops, 1530 .flags = CLK_SET_RATE_PARENT, 1531 }, 1532 }, 1533 }; 1534 1535 static struct clk_rcg gsbi12_qup_src = { 1536 .ns_reg = 0x2b2c, 1537 .md_reg = 0x2b28, 1538 .mn = { 1539 .mnctr_en_bit = 8, 1540 .mnctr_reset_bit = 7, 1541 .mnctr_mode_shift = 5, 1542 .n_val_shift = 16, 1543 .m_val_shift = 16, 1544 .width = 8, 1545 }, 1546 .p = { 1547 .pre_div_shift = 3, 1548 .pre_div_width = 2, 1549 }, 1550 .s = { 1551 .src_sel_shift = 0, 1552 .parent_map = gcc_pxo_pll8_map, 1553 }, 1554 .freq_tbl = clk_tbl_gsbi_qup, 1555 .clkr = { 1556 .enable_reg = 0x2b2c, 1557 .enable_mask = BIT(11), 1558 .hw.init = &(struct clk_init_data){ 1559 .name = "gsbi12_qup_src", 1560 .parent_data = gcc_pxo_pll8, 1561 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1562 .ops = &clk_rcg_ops, 1563 .flags = CLK_SET_PARENT_GATE, 1564 }, 1565 }, 1566 }; 1567 1568 static struct clk_branch gsbi12_qup_clk = { 1569 .halt_reg = 0x2fd4, 1570 .halt_bit = 11, 1571 .clkr = { 1572 .enable_reg = 0x2b2c, 1573 .enable_mask = BIT(9), 1574 .hw.init = &(struct clk_init_data){ 1575 .name = "gsbi12_qup_clk", 1576 .parent_hws = (const struct clk_hw*[]){ 1577 &gsbi12_qup_src.clkr.hw 1578 }, 1579 .num_parents = 1, 1580 .ops = &clk_branch_ops, 1581 .flags = CLK_SET_RATE_PARENT, 1582 }, 1583 }, 1584 }; 1585 1586 static const struct freq_tbl clk_tbl_gp[] = { 1587 { 9600000, P_CXO, 2, 0, 0 }, 1588 { 13500000, P_PXO, 2, 0, 0 }, 1589 { 19200000, P_CXO, 1, 0, 0 }, 1590 { 27000000, P_PXO, 1, 0, 0 }, 1591 { 64000000, P_PLL8, 2, 1, 3 }, 1592 { 76800000, P_PLL8, 1, 1, 5 }, 1593 { 96000000, P_PLL8, 4, 0, 0 }, 1594 { 128000000, P_PLL8, 3, 0, 0 }, 1595 { 192000000, P_PLL8, 2, 0, 0 }, 1596 { } 1597 }; 1598 1599 static struct clk_rcg gp0_src = { 1600 .ns_reg = 0x2d24, 1601 .md_reg = 0x2d00, 1602 .mn = { 1603 .mnctr_en_bit = 8, 1604 .mnctr_reset_bit = 7, 1605 .mnctr_mode_shift = 5, 1606 .n_val_shift = 16, 1607 .m_val_shift = 16, 1608 .width = 8, 1609 }, 1610 .p = { 1611 .pre_div_shift = 3, 1612 .pre_div_width = 2, 1613 }, 1614 .s = { 1615 .src_sel_shift = 0, 1616 .parent_map = gcc_pxo_pll8_cxo_map, 1617 }, 1618 .freq_tbl = clk_tbl_gp, 1619 .clkr = { 1620 .enable_reg = 0x2d24, 1621 .enable_mask = BIT(11), 1622 .hw.init = &(struct clk_init_data){ 1623 .name = "gp0_src", 1624 .parent_data = gcc_pxo_pll8_cxo, 1625 .num_parents = ARRAY_SIZE(gcc_pxo_pll8_cxo), 1626 .ops = &clk_rcg_ops, 1627 .flags = CLK_SET_PARENT_GATE, 1628 }, 1629 } 1630 }; 1631 1632 static struct clk_branch gp0_clk = { 1633 .halt_reg = 0x2fd8, 1634 .halt_bit = 7, 1635 .clkr = { 1636 .enable_reg = 0x2d24, 1637 .enable_mask = BIT(9), 1638 .hw.init = &(struct clk_init_data){ 1639 .name = "gp0_clk", 1640 .parent_hws = (const struct clk_hw*[]){ 1641 &gp0_src.clkr.hw 1642 }, 1643 .num_parents = 1, 1644 .ops = &clk_branch_ops, 1645 .flags = CLK_SET_RATE_PARENT, 1646 }, 1647 }, 1648 }; 1649 1650 static struct clk_rcg gp1_src = { 1651 .ns_reg = 0x2d44, 1652 .md_reg = 0x2d40, 1653 .mn = { 1654 .mnctr_en_bit = 8, 1655 .mnctr_reset_bit = 7, 1656 .mnctr_mode_shift = 5, 1657 .n_val_shift = 16, 1658 .m_val_shift = 16, 1659 .width = 8, 1660 }, 1661 .p = { 1662 .pre_div_shift = 3, 1663 .pre_div_width = 2, 1664 }, 1665 .s = { 1666 .src_sel_shift = 0, 1667 .parent_map = gcc_pxo_pll8_cxo_map, 1668 }, 1669 .freq_tbl = clk_tbl_gp, 1670 .clkr = { 1671 .enable_reg = 0x2d44, 1672 .enable_mask = BIT(11), 1673 .hw.init = &(struct clk_init_data){ 1674 .name = "gp1_src", 1675 .parent_data = gcc_pxo_pll8_cxo, 1676 .num_parents = ARRAY_SIZE(gcc_pxo_pll8_cxo), 1677 .ops = &clk_rcg_ops, 1678 .flags = CLK_SET_RATE_GATE, 1679 }, 1680 } 1681 }; 1682 1683 static struct clk_branch gp1_clk = { 1684 .halt_reg = 0x2fd8, 1685 .halt_bit = 6, 1686 .clkr = { 1687 .enable_reg = 0x2d44, 1688 .enable_mask = BIT(9), 1689 .hw.init = &(struct clk_init_data){ 1690 .name = "gp1_clk", 1691 .parent_hws = (const struct clk_hw*[]){ 1692 &gp1_src.clkr.hw 1693 }, 1694 .num_parents = 1, 1695 .ops = &clk_branch_ops, 1696 .flags = CLK_SET_RATE_PARENT, 1697 }, 1698 }, 1699 }; 1700 1701 static struct clk_rcg gp2_src = { 1702 .ns_reg = 0x2d64, 1703 .md_reg = 0x2d60, 1704 .mn = { 1705 .mnctr_en_bit = 8, 1706 .mnctr_reset_bit = 7, 1707 .mnctr_mode_shift = 5, 1708 .n_val_shift = 16, 1709 .m_val_shift = 16, 1710 .width = 8, 1711 }, 1712 .p = { 1713 .pre_div_shift = 3, 1714 .pre_div_width = 2, 1715 }, 1716 .s = { 1717 .src_sel_shift = 0, 1718 .parent_map = gcc_pxo_pll8_cxo_map, 1719 }, 1720 .freq_tbl = clk_tbl_gp, 1721 .clkr = { 1722 .enable_reg = 0x2d64, 1723 .enable_mask = BIT(11), 1724 .hw.init = &(struct clk_init_data){ 1725 .name = "gp2_src", 1726 .parent_data = gcc_pxo_pll8_cxo, 1727 .num_parents = ARRAY_SIZE(gcc_pxo_pll8_cxo), 1728 .ops = &clk_rcg_ops, 1729 .flags = CLK_SET_RATE_GATE, 1730 }, 1731 } 1732 }; 1733 1734 static struct clk_branch gp2_clk = { 1735 .halt_reg = 0x2fd8, 1736 .halt_bit = 5, 1737 .clkr = { 1738 .enable_reg = 0x2d64, 1739 .enable_mask = BIT(9), 1740 .hw.init = &(struct clk_init_data){ 1741 .name = "gp2_clk", 1742 .parent_hws = (const struct clk_hw*[]){ 1743 &gp2_src.clkr.hw 1744 }, 1745 .num_parents = 1, 1746 .ops = &clk_branch_ops, 1747 .flags = CLK_SET_RATE_PARENT, 1748 }, 1749 }, 1750 }; 1751 1752 static struct clk_branch pmem_clk = { 1753 .hwcg_reg = 0x25a0, 1754 .hwcg_bit = 6, 1755 .halt_reg = 0x2fc8, 1756 .halt_bit = 20, 1757 .clkr = { 1758 .enable_reg = 0x25a0, 1759 .enable_mask = BIT(4), 1760 .hw.init = &(struct clk_init_data){ 1761 .name = "pmem_clk", 1762 .ops = &clk_branch_ops, 1763 }, 1764 }, 1765 }; 1766 1767 static struct clk_rcg prng_src = { 1768 .ns_reg = 0x2e80, 1769 .p = { 1770 .pre_div_shift = 3, 1771 .pre_div_width = 4, 1772 }, 1773 .s = { 1774 .src_sel_shift = 0, 1775 .parent_map = gcc_pxo_pll8_map, 1776 }, 1777 .clkr = { 1778 .hw.init = &(struct clk_init_data){ 1779 .name = "prng_src", 1780 .parent_data = gcc_pxo_pll8, 1781 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1782 .ops = &clk_rcg_ops, 1783 }, 1784 }, 1785 }; 1786 1787 static struct clk_branch prng_clk = { 1788 .halt_reg = 0x2fd8, 1789 .halt_check = BRANCH_HALT_VOTED, 1790 .halt_bit = 10, 1791 .clkr = { 1792 .enable_reg = 0x3080, 1793 .enable_mask = BIT(10), 1794 .hw.init = &(struct clk_init_data){ 1795 .name = "prng_clk", 1796 .parent_hws = (const struct clk_hw*[]){ 1797 &prng_src.clkr.hw 1798 }, 1799 .num_parents = 1, 1800 .ops = &clk_branch_ops, 1801 }, 1802 }, 1803 }; 1804 1805 static const struct freq_tbl clk_tbl_sdc[] = { 1806 { 144000, P_PXO, 3, 2, 125 }, 1807 { 400000, P_PLL8, 4, 1, 240 }, 1808 { 16000000, P_PLL8, 4, 1, 6 }, 1809 { 17070000, P_PLL8, 1, 2, 45 }, 1810 { 20210000, P_PLL8, 1, 1, 19 }, 1811 { 24000000, P_PLL8, 4, 1, 4 }, 1812 { 48000000, P_PLL8, 4, 1, 2 }, 1813 { 64000000, P_PLL8, 3, 1, 2 }, 1814 { 96000000, P_PLL8, 4, 0, 0 }, 1815 { 192000000, P_PLL8, 2, 0, 0 }, 1816 { } 1817 }; 1818 1819 static struct clk_rcg sdc1_src = { 1820 .ns_reg = 0x282c, 1821 .md_reg = 0x2828, 1822 .mn = { 1823 .mnctr_en_bit = 8, 1824 .mnctr_reset_bit = 7, 1825 .mnctr_mode_shift = 5, 1826 .n_val_shift = 16, 1827 .m_val_shift = 16, 1828 .width = 8, 1829 }, 1830 .p = { 1831 .pre_div_shift = 3, 1832 .pre_div_width = 2, 1833 }, 1834 .s = { 1835 .src_sel_shift = 0, 1836 .parent_map = gcc_pxo_pll8_map, 1837 }, 1838 .freq_tbl = clk_tbl_sdc, 1839 .clkr = { 1840 .enable_reg = 0x282c, 1841 .enable_mask = BIT(11), 1842 .hw.init = &(struct clk_init_data){ 1843 .name = "sdc1_src", 1844 .parent_data = gcc_pxo_pll8, 1845 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1846 .ops = &clk_rcg_ops, 1847 }, 1848 } 1849 }; 1850 1851 static struct clk_branch sdc1_clk = { 1852 .halt_reg = 0x2fc8, 1853 .halt_bit = 6, 1854 .clkr = { 1855 .enable_reg = 0x282c, 1856 .enable_mask = BIT(9), 1857 .hw.init = &(struct clk_init_data){ 1858 .name = "sdc1_clk", 1859 .parent_hws = (const struct clk_hw*[]){ 1860 &sdc1_src.clkr.hw 1861 }, 1862 .num_parents = 1, 1863 .ops = &clk_branch_ops, 1864 .flags = CLK_SET_RATE_PARENT, 1865 }, 1866 }, 1867 }; 1868 1869 static struct clk_rcg sdc2_src = { 1870 .ns_reg = 0x284c, 1871 .md_reg = 0x2848, 1872 .mn = { 1873 .mnctr_en_bit = 8, 1874 .mnctr_reset_bit = 7, 1875 .mnctr_mode_shift = 5, 1876 .n_val_shift = 16, 1877 .m_val_shift = 16, 1878 .width = 8, 1879 }, 1880 .p = { 1881 .pre_div_shift = 3, 1882 .pre_div_width = 2, 1883 }, 1884 .s = { 1885 .src_sel_shift = 0, 1886 .parent_map = gcc_pxo_pll8_map, 1887 }, 1888 .freq_tbl = clk_tbl_sdc, 1889 .clkr = { 1890 .enable_reg = 0x284c, 1891 .enable_mask = BIT(11), 1892 .hw.init = &(struct clk_init_data){ 1893 .name = "sdc2_src", 1894 .parent_data = gcc_pxo_pll8, 1895 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1896 .ops = &clk_rcg_ops, 1897 }, 1898 } 1899 }; 1900 1901 static struct clk_branch sdc2_clk = { 1902 .halt_reg = 0x2fc8, 1903 .halt_bit = 5, 1904 .clkr = { 1905 .enable_reg = 0x284c, 1906 .enable_mask = BIT(9), 1907 .hw.init = &(struct clk_init_data){ 1908 .name = "sdc2_clk", 1909 .parent_hws = (const struct clk_hw*[]){ 1910 &sdc2_src.clkr.hw 1911 }, 1912 .num_parents = 1, 1913 .ops = &clk_branch_ops, 1914 .flags = CLK_SET_RATE_PARENT, 1915 }, 1916 }, 1917 }; 1918 1919 static struct clk_rcg sdc3_src = { 1920 .ns_reg = 0x286c, 1921 .md_reg = 0x2868, 1922 .mn = { 1923 .mnctr_en_bit = 8, 1924 .mnctr_reset_bit = 7, 1925 .mnctr_mode_shift = 5, 1926 .n_val_shift = 16, 1927 .m_val_shift = 16, 1928 .width = 8, 1929 }, 1930 .p = { 1931 .pre_div_shift = 3, 1932 .pre_div_width = 2, 1933 }, 1934 .s = { 1935 .src_sel_shift = 0, 1936 .parent_map = gcc_pxo_pll8_map, 1937 }, 1938 .freq_tbl = clk_tbl_sdc, 1939 .clkr = { 1940 .enable_reg = 0x286c, 1941 .enable_mask = BIT(11), 1942 .hw.init = &(struct clk_init_data){ 1943 .name = "sdc3_src", 1944 .parent_data = gcc_pxo_pll8, 1945 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1946 .ops = &clk_rcg_ops, 1947 }, 1948 } 1949 }; 1950 1951 static struct clk_branch sdc3_clk = { 1952 .halt_reg = 0x2fc8, 1953 .halt_bit = 4, 1954 .clkr = { 1955 .enable_reg = 0x286c, 1956 .enable_mask = BIT(9), 1957 .hw.init = &(struct clk_init_data){ 1958 .name = "sdc3_clk", 1959 .parent_hws = (const struct clk_hw*[]){ 1960 &sdc3_src.clkr.hw 1961 }, 1962 .num_parents = 1, 1963 .ops = &clk_branch_ops, 1964 .flags = CLK_SET_RATE_PARENT, 1965 }, 1966 }, 1967 }; 1968 1969 static struct clk_rcg sdc4_src = { 1970 .ns_reg = 0x288c, 1971 .md_reg = 0x2888, 1972 .mn = { 1973 .mnctr_en_bit = 8, 1974 .mnctr_reset_bit = 7, 1975 .mnctr_mode_shift = 5, 1976 .n_val_shift = 16, 1977 .m_val_shift = 16, 1978 .width = 8, 1979 }, 1980 .p = { 1981 .pre_div_shift = 3, 1982 .pre_div_width = 2, 1983 }, 1984 .s = { 1985 .src_sel_shift = 0, 1986 .parent_map = gcc_pxo_pll8_map, 1987 }, 1988 .freq_tbl = clk_tbl_sdc, 1989 .clkr = { 1990 .enable_reg = 0x288c, 1991 .enable_mask = BIT(11), 1992 .hw.init = &(struct clk_init_data){ 1993 .name = "sdc4_src", 1994 .parent_data = gcc_pxo_pll8, 1995 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 1996 .ops = &clk_rcg_ops, 1997 }, 1998 } 1999 }; 2000 2001 static struct clk_branch sdc4_clk = { 2002 .halt_reg = 0x2fc8, 2003 .halt_bit = 3, 2004 .clkr = { 2005 .enable_reg = 0x288c, 2006 .enable_mask = BIT(9), 2007 .hw.init = &(struct clk_init_data){ 2008 .name = "sdc4_clk", 2009 .parent_hws = (const struct clk_hw*[]){ 2010 &sdc4_src.clkr.hw 2011 }, 2012 .num_parents = 1, 2013 .ops = &clk_branch_ops, 2014 .flags = CLK_SET_RATE_PARENT, 2015 }, 2016 }, 2017 }; 2018 2019 static struct clk_rcg sdc5_src = { 2020 .ns_reg = 0x28ac, 2021 .md_reg = 0x28a8, 2022 .mn = { 2023 .mnctr_en_bit = 8, 2024 .mnctr_reset_bit = 7, 2025 .mnctr_mode_shift = 5, 2026 .n_val_shift = 16, 2027 .m_val_shift = 16, 2028 .width = 8, 2029 }, 2030 .p = { 2031 .pre_div_shift = 3, 2032 .pre_div_width = 2, 2033 }, 2034 .s = { 2035 .src_sel_shift = 0, 2036 .parent_map = gcc_pxo_pll8_map, 2037 }, 2038 .freq_tbl = clk_tbl_sdc, 2039 .clkr = { 2040 .enable_reg = 0x28ac, 2041 .enable_mask = BIT(11), 2042 .hw.init = &(struct clk_init_data){ 2043 .name = "sdc5_src", 2044 .parent_data = gcc_pxo_pll8, 2045 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 2046 .ops = &clk_rcg_ops, 2047 }, 2048 } 2049 }; 2050 2051 static struct clk_branch sdc5_clk = { 2052 .halt_reg = 0x2fc8, 2053 .halt_bit = 2, 2054 .clkr = { 2055 .enable_reg = 0x28ac, 2056 .enable_mask = BIT(9), 2057 .hw.init = &(struct clk_init_data){ 2058 .name = "sdc5_clk", 2059 .parent_hws = (const struct clk_hw*[]){ 2060 &sdc5_src.clkr.hw 2061 }, 2062 .num_parents = 1, 2063 .ops = &clk_branch_ops, 2064 .flags = CLK_SET_RATE_PARENT, 2065 }, 2066 }, 2067 }; 2068 2069 static const struct freq_tbl clk_tbl_tsif_ref[] = { 2070 { 105000, P_PXO, 1, 1, 256 }, 2071 { } 2072 }; 2073 2074 static struct clk_rcg tsif_ref_src = { 2075 .ns_reg = 0x2710, 2076 .md_reg = 0x270c, 2077 .mn = { 2078 .mnctr_en_bit = 8, 2079 .mnctr_reset_bit = 7, 2080 .mnctr_mode_shift = 5, 2081 .n_val_shift = 16, 2082 .m_val_shift = 16, 2083 .width = 16, 2084 }, 2085 .p = { 2086 .pre_div_shift = 3, 2087 .pre_div_width = 2, 2088 }, 2089 .s = { 2090 .src_sel_shift = 0, 2091 .parent_map = gcc_pxo_pll8_map, 2092 }, 2093 .freq_tbl = clk_tbl_tsif_ref, 2094 .clkr = { 2095 .enable_reg = 0x2710, 2096 .enable_mask = BIT(11), 2097 .hw.init = &(struct clk_init_data){ 2098 .name = "tsif_ref_src", 2099 .parent_data = gcc_pxo_pll8, 2100 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 2101 .ops = &clk_rcg_ops, 2102 .flags = CLK_SET_RATE_GATE, 2103 }, 2104 } 2105 }; 2106 2107 static struct clk_branch tsif_ref_clk = { 2108 .halt_reg = 0x2fd4, 2109 .halt_bit = 5, 2110 .clkr = { 2111 .enable_reg = 0x2710, 2112 .enable_mask = BIT(9), 2113 .hw.init = &(struct clk_init_data){ 2114 .name = "tsif_ref_clk", 2115 .parent_hws = (const struct clk_hw*[]){ 2116 &tsif_ref_src.clkr.hw 2117 }, 2118 .num_parents = 1, 2119 .ops = &clk_branch_ops, 2120 .flags = CLK_SET_RATE_PARENT, 2121 }, 2122 }, 2123 }; 2124 2125 static const struct freq_tbl clk_tbl_usb[] = { 2126 { 60000000, P_PLL8, 1, 5, 32 }, 2127 { } 2128 }; 2129 2130 static struct clk_rcg usb_hs1_xcvr_src = { 2131 .ns_reg = 0x290c, 2132 .md_reg = 0x2908, 2133 .mn = { 2134 .mnctr_en_bit = 8, 2135 .mnctr_reset_bit = 7, 2136 .mnctr_mode_shift = 5, 2137 .n_val_shift = 16, 2138 .m_val_shift = 16, 2139 .width = 8, 2140 }, 2141 .p = { 2142 .pre_div_shift = 3, 2143 .pre_div_width = 2, 2144 }, 2145 .s = { 2146 .src_sel_shift = 0, 2147 .parent_map = gcc_pxo_pll8_map, 2148 }, 2149 .freq_tbl = clk_tbl_usb, 2150 .clkr = { 2151 .enable_reg = 0x290c, 2152 .enable_mask = BIT(11), 2153 .hw.init = &(struct clk_init_data){ 2154 .name = "usb_hs1_xcvr_src", 2155 .parent_data = gcc_pxo_pll8, 2156 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 2157 .ops = &clk_rcg_ops, 2158 .flags = CLK_SET_RATE_GATE, 2159 }, 2160 } 2161 }; 2162 2163 static struct clk_branch usb_hs1_xcvr_clk = { 2164 .halt_reg = 0x2fc8, 2165 .halt_bit = 0, 2166 .clkr = { 2167 .enable_reg = 0x290c, 2168 .enable_mask = BIT(9), 2169 .hw.init = &(struct clk_init_data){ 2170 .name = "usb_hs1_xcvr_clk", 2171 .parent_hws = (const struct clk_hw*[]){ 2172 &usb_hs1_xcvr_src.clkr.hw 2173 }, 2174 .num_parents = 1, 2175 .ops = &clk_branch_ops, 2176 .flags = CLK_SET_RATE_PARENT, 2177 }, 2178 }, 2179 }; 2180 2181 static struct clk_rcg usb_hs3_xcvr_src = { 2182 .ns_reg = 0x370c, 2183 .md_reg = 0x3708, 2184 .mn = { 2185 .mnctr_en_bit = 8, 2186 .mnctr_reset_bit = 7, 2187 .mnctr_mode_shift = 5, 2188 .n_val_shift = 16, 2189 .m_val_shift = 16, 2190 .width = 8, 2191 }, 2192 .p = { 2193 .pre_div_shift = 3, 2194 .pre_div_width = 2, 2195 }, 2196 .s = { 2197 .src_sel_shift = 0, 2198 .parent_map = gcc_pxo_pll8_map, 2199 }, 2200 .freq_tbl = clk_tbl_usb, 2201 .clkr = { 2202 .enable_reg = 0x370c, 2203 .enable_mask = BIT(11), 2204 .hw.init = &(struct clk_init_data){ 2205 .name = "usb_hs3_xcvr_src", 2206 .parent_data = gcc_pxo_pll8, 2207 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 2208 .ops = &clk_rcg_ops, 2209 .flags = CLK_SET_RATE_GATE, 2210 }, 2211 } 2212 }; 2213 2214 static struct clk_branch usb_hs3_xcvr_clk = { 2215 .halt_reg = 0x2fc8, 2216 .halt_bit = 30, 2217 .clkr = { 2218 .enable_reg = 0x370c, 2219 .enable_mask = BIT(9), 2220 .hw.init = &(struct clk_init_data){ 2221 .name = "usb_hs3_xcvr_clk", 2222 .parent_hws = (const struct clk_hw*[]){ 2223 &usb_hs3_xcvr_src.clkr.hw 2224 }, 2225 .num_parents = 1, 2226 .ops = &clk_branch_ops, 2227 .flags = CLK_SET_RATE_PARENT, 2228 }, 2229 }, 2230 }; 2231 2232 static struct clk_rcg usb_hs4_xcvr_src = { 2233 .ns_reg = 0x372c, 2234 .md_reg = 0x3728, 2235 .mn = { 2236 .mnctr_en_bit = 8, 2237 .mnctr_reset_bit = 7, 2238 .mnctr_mode_shift = 5, 2239 .n_val_shift = 16, 2240 .m_val_shift = 16, 2241 .width = 8, 2242 }, 2243 .p = { 2244 .pre_div_shift = 3, 2245 .pre_div_width = 2, 2246 }, 2247 .s = { 2248 .src_sel_shift = 0, 2249 .parent_map = gcc_pxo_pll8_map, 2250 }, 2251 .freq_tbl = clk_tbl_usb, 2252 .clkr = { 2253 .enable_reg = 0x372c, 2254 .enable_mask = BIT(11), 2255 .hw.init = &(struct clk_init_data){ 2256 .name = "usb_hs4_xcvr_src", 2257 .parent_data = gcc_pxo_pll8, 2258 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 2259 .ops = &clk_rcg_ops, 2260 .flags = CLK_SET_RATE_GATE, 2261 }, 2262 } 2263 }; 2264 2265 static struct clk_branch usb_hs4_xcvr_clk = { 2266 .halt_reg = 0x2fc8, 2267 .halt_bit = 2, 2268 .clkr = { 2269 .enable_reg = 0x372c, 2270 .enable_mask = BIT(9), 2271 .hw.init = &(struct clk_init_data){ 2272 .name = "usb_hs4_xcvr_clk", 2273 .parent_hws = (const struct clk_hw*[]){ 2274 &usb_hs4_xcvr_src.clkr.hw 2275 }, 2276 .num_parents = 1, 2277 .ops = &clk_branch_ops, 2278 .flags = CLK_SET_RATE_PARENT, 2279 }, 2280 }, 2281 }; 2282 2283 static struct clk_rcg usb_hsic_xcvr_fs_src = { 2284 .ns_reg = 0x2928, 2285 .md_reg = 0x2924, 2286 .mn = { 2287 .mnctr_en_bit = 8, 2288 .mnctr_reset_bit = 7, 2289 .mnctr_mode_shift = 5, 2290 .n_val_shift = 16, 2291 .m_val_shift = 16, 2292 .width = 8, 2293 }, 2294 .p = { 2295 .pre_div_shift = 3, 2296 .pre_div_width = 2, 2297 }, 2298 .s = { 2299 .src_sel_shift = 0, 2300 .parent_map = gcc_pxo_pll8_map, 2301 }, 2302 .freq_tbl = clk_tbl_usb, 2303 .clkr = { 2304 .enable_reg = 0x2928, 2305 .enable_mask = BIT(11), 2306 .hw.init = &(struct clk_init_data){ 2307 .name = "usb_hsic_xcvr_fs_src", 2308 .parent_data = gcc_pxo_pll8, 2309 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 2310 .ops = &clk_rcg_ops, 2311 .flags = CLK_SET_RATE_GATE, 2312 }, 2313 } 2314 }; 2315 2316 static struct clk_branch usb_hsic_xcvr_fs_clk = { 2317 .halt_reg = 0x2fc8, 2318 .halt_bit = 2, 2319 .clkr = { 2320 .enable_reg = 0x2928, 2321 .enable_mask = BIT(9), 2322 .hw.init = &(struct clk_init_data){ 2323 .name = "usb_hsic_xcvr_fs_clk", 2324 .parent_hws = (const struct clk_hw*[]){ 2325 &usb_hsic_xcvr_fs_src.clkr.hw, 2326 }, 2327 .num_parents = 1, 2328 .ops = &clk_branch_ops, 2329 .flags = CLK_SET_RATE_PARENT, 2330 }, 2331 }, 2332 }; 2333 2334 static struct clk_branch usb_hsic_system_clk = { 2335 .halt_reg = 0x2fcc, 2336 .halt_bit = 24, 2337 .clkr = { 2338 .enable_reg = 0x292c, 2339 .enable_mask = BIT(4), 2340 .hw.init = &(struct clk_init_data){ 2341 .parent_hws = (const struct clk_hw*[]){ 2342 &usb_hsic_xcvr_fs_src.clkr.hw, 2343 }, 2344 .num_parents = 1, 2345 .name = "usb_hsic_system_clk", 2346 .ops = &clk_branch_ops, 2347 .flags = CLK_SET_RATE_PARENT, 2348 }, 2349 }, 2350 }; 2351 2352 static struct clk_branch usb_hsic_hsic_clk = { 2353 .halt_reg = 0x2fcc, 2354 .halt_bit = 19, 2355 .clkr = { 2356 .enable_reg = 0x2b44, 2357 .enable_mask = BIT(0), 2358 .hw.init = &(struct clk_init_data){ 2359 .parent_hws = (const struct clk_hw*[]){ 2360 &pll14_vote.hw 2361 }, 2362 .num_parents = 1, 2363 .name = "usb_hsic_hsic_clk", 2364 .ops = &clk_branch_ops, 2365 }, 2366 }, 2367 }; 2368 2369 static struct clk_branch usb_hsic_hsio_cal_clk = { 2370 .halt_reg = 0x2fcc, 2371 .halt_bit = 23, 2372 .clkr = { 2373 .enable_reg = 0x2b48, 2374 .enable_mask = BIT(0), 2375 .hw.init = &(struct clk_init_data){ 2376 .name = "usb_hsic_hsio_cal_clk", 2377 .ops = &clk_branch_ops, 2378 }, 2379 }, 2380 }; 2381 2382 static struct clk_rcg usb_fs1_xcvr_fs_src = { 2383 .ns_reg = 0x2968, 2384 .md_reg = 0x2964, 2385 .mn = { 2386 .mnctr_en_bit = 8, 2387 .mnctr_reset_bit = 7, 2388 .mnctr_mode_shift = 5, 2389 .n_val_shift = 16, 2390 .m_val_shift = 16, 2391 .width = 8, 2392 }, 2393 .p = { 2394 .pre_div_shift = 3, 2395 .pre_div_width = 2, 2396 }, 2397 .s = { 2398 .src_sel_shift = 0, 2399 .parent_map = gcc_pxo_pll8_map, 2400 }, 2401 .freq_tbl = clk_tbl_usb, 2402 .clkr = { 2403 .enable_reg = 0x2968, 2404 .enable_mask = BIT(11), 2405 .hw.init = &(struct clk_init_data){ 2406 .name = "usb_fs1_xcvr_fs_src", 2407 .parent_data = gcc_pxo_pll8, 2408 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 2409 .ops = &clk_rcg_ops, 2410 .flags = CLK_SET_RATE_GATE, 2411 }, 2412 } 2413 }; 2414 2415 static struct clk_branch usb_fs1_xcvr_fs_clk = { 2416 .halt_reg = 0x2fcc, 2417 .halt_bit = 15, 2418 .clkr = { 2419 .enable_reg = 0x2968, 2420 .enable_mask = BIT(9), 2421 .hw.init = &(struct clk_init_data){ 2422 .name = "usb_fs1_xcvr_fs_clk", 2423 .parent_hws = (const struct clk_hw*[]){ 2424 &usb_fs1_xcvr_fs_src.clkr.hw, 2425 }, 2426 .num_parents = 1, 2427 .ops = &clk_branch_ops, 2428 .flags = CLK_SET_RATE_PARENT, 2429 }, 2430 }, 2431 }; 2432 2433 static struct clk_branch usb_fs1_system_clk = { 2434 .halt_reg = 0x2fcc, 2435 .halt_bit = 16, 2436 .clkr = { 2437 .enable_reg = 0x296c, 2438 .enable_mask = BIT(4), 2439 .hw.init = &(struct clk_init_data){ 2440 .parent_hws = (const struct clk_hw*[]){ 2441 &usb_fs1_xcvr_fs_src.clkr.hw, 2442 }, 2443 .num_parents = 1, 2444 .name = "usb_fs1_system_clk", 2445 .ops = &clk_branch_ops, 2446 .flags = CLK_SET_RATE_PARENT, 2447 }, 2448 }, 2449 }; 2450 2451 static struct clk_rcg usb_fs2_xcvr_fs_src = { 2452 .ns_reg = 0x2988, 2453 .md_reg = 0x2984, 2454 .mn = { 2455 .mnctr_en_bit = 8, 2456 .mnctr_reset_bit = 7, 2457 .mnctr_mode_shift = 5, 2458 .n_val_shift = 16, 2459 .m_val_shift = 16, 2460 .width = 8, 2461 }, 2462 .p = { 2463 .pre_div_shift = 3, 2464 .pre_div_width = 2, 2465 }, 2466 .s = { 2467 .src_sel_shift = 0, 2468 .parent_map = gcc_pxo_pll8_map, 2469 }, 2470 .freq_tbl = clk_tbl_usb, 2471 .clkr = { 2472 .enable_reg = 0x2988, 2473 .enable_mask = BIT(11), 2474 .hw.init = &(struct clk_init_data){ 2475 .name = "usb_fs2_xcvr_fs_src", 2476 .parent_data = gcc_pxo_pll8, 2477 .num_parents = ARRAY_SIZE(gcc_pxo_pll8), 2478 .ops = &clk_rcg_ops, 2479 .flags = CLK_SET_RATE_GATE, 2480 }, 2481 } 2482 }; 2483 2484 static struct clk_branch usb_fs2_xcvr_fs_clk = { 2485 .halt_reg = 0x2fcc, 2486 .halt_bit = 12, 2487 .clkr = { 2488 .enable_reg = 0x2988, 2489 .enable_mask = BIT(9), 2490 .hw.init = &(struct clk_init_data){ 2491 .name = "usb_fs2_xcvr_fs_clk", 2492 .parent_hws = (const struct clk_hw*[]){ 2493 &usb_fs2_xcvr_fs_src.clkr.hw, 2494 }, 2495 .num_parents = 1, 2496 .ops = &clk_branch_ops, 2497 .flags = CLK_SET_RATE_PARENT, 2498 }, 2499 }, 2500 }; 2501 2502 static struct clk_branch usb_fs2_system_clk = { 2503 .halt_reg = 0x2fcc, 2504 .halt_bit = 13, 2505 .clkr = { 2506 .enable_reg = 0x298c, 2507 .enable_mask = BIT(4), 2508 .hw.init = &(struct clk_init_data){ 2509 .name = "usb_fs2_system_clk", 2510 .parent_hws = (const struct clk_hw*[]){ 2511 &usb_fs2_xcvr_fs_src.clkr.hw, 2512 }, 2513 .num_parents = 1, 2514 .ops = &clk_branch_ops, 2515 .flags = CLK_SET_RATE_PARENT, 2516 }, 2517 }, 2518 }; 2519 2520 static struct clk_branch ce1_core_clk = { 2521 .hwcg_reg = 0x2724, 2522 .hwcg_bit = 6, 2523 .halt_reg = 0x2fd4, 2524 .halt_bit = 27, 2525 .clkr = { 2526 .enable_reg = 0x2724, 2527 .enable_mask = BIT(4), 2528 .hw.init = &(struct clk_init_data){ 2529 .name = "ce1_core_clk", 2530 .ops = &clk_branch_ops, 2531 }, 2532 }, 2533 }; 2534 2535 static struct clk_branch ce1_h_clk = { 2536 .halt_reg = 0x2fd4, 2537 .halt_bit = 1, 2538 .clkr = { 2539 .enable_reg = 0x2720, 2540 .enable_mask = BIT(4), 2541 .hw.init = &(struct clk_init_data){ 2542 .name = "ce1_h_clk", 2543 .ops = &clk_branch_ops, 2544 }, 2545 }, 2546 }; 2547 2548 static struct clk_branch dma_bam_h_clk = { 2549 .hwcg_reg = 0x25c0, 2550 .hwcg_bit = 6, 2551 .halt_reg = 0x2fc8, 2552 .halt_bit = 12, 2553 .clkr = { 2554 .enable_reg = 0x25c0, 2555 .enable_mask = BIT(4), 2556 .hw.init = &(struct clk_init_data){ 2557 .name = "dma_bam_h_clk", 2558 .ops = &clk_branch_ops, 2559 }, 2560 }, 2561 }; 2562 2563 static struct clk_branch gsbi1_h_clk = { 2564 .hwcg_reg = 0x29c0, 2565 .hwcg_bit = 6, 2566 .halt_reg = 0x2fcc, 2567 .halt_bit = 11, 2568 .clkr = { 2569 .enable_reg = 0x29c0, 2570 .enable_mask = BIT(4), 2571 .hw.init = &(struct clk_init_data){ 2572 .name = "gsbi1_h_clk", 2573 .ops = &clk_branch_ops, 2574 }, 2575 }, 2576 }; 2577 2578 static struct clk_branch gsbi2_h_clk = { 2579 .hwcg_reg = 0x29e0, 2580 .hwcg_bit = 6, 2581 .halt_reg = 0x2fcc, 2582 .halt_bit = 7, 2583 .clkr = { 2584 .enable_reg = 0x29e0, 2585 .enable_mask = BIT(4), 2586 .hw.init = &(struct clk_init_data){ 2587 .name = "gsbi2_h_clk", 2588 .ops = &clk_branch_ops, 2589 }, 2590 }, 2591 }; 2592 2593 static struct clk_branch gsbi3_h_clk = { 2594 .hwcg_reg = 0x2a00, 2595 .hwcg_bit = 6, 2596 .halt_reg = 0x2fcc, 2597 .halt_bit = 3, 2598 .clkr = { 2599 .enable_reg = 0x2a00, 2600 .enable_mask = BIT(4), 2601 .hw.init = &(struct clk_init_data){ 2602 .name = "gsbi3_h_clk", 2603 .ops = &clk_branch_ops, 2604 }, 2605 }, 2606 }; 2607 2608 static struct clk_branch gsbi4_h_clk = { 2609 .hwcg_reg = 0x2a20, 2610 .hwcg_bit = 6, 2611 .halt_reg = 0x2fd0, 2612 .halt_bit = 27, 2613 .clkr = { 2614 .enable_reg = 0x2a20, 2615 .enable_mask = BIT(4), 2616 .hw.init = &(struct clk_init_data){ 2617 .name = "gsbi4_h_clk", 2618 .ops = &clk_branch_ops, 2619 }, 2620 }, 2621 }; 2622 2623 static struct clk_branch gsbi5_h_clk = { 2624 .hwcg_reg = 0x2a40, 2625 .hwcg_bit = 6, 2626 .halt_reg = 0x2fd0, 2627 .halt_bit = 23, 2628 .clkr = { 2629 .enable_reg = 0x2a40, 2630 .enable_mask = BIT(4), 2631 .hw.init = &(struct clk_init_data){ 2632 .name = "gsbi5_h_clk", 2633 .ops = &clk_branch_ops, 2634 }, 2635 }, 2636 }; 2637 2638 static struct clk_branch gsbi6_h_clk = { 2639 .hwcg_reg = 0x2a60, 2640 .hwcg_bit = 6, 2641 .halt_reg = 0x2fd0, 2642 .halt_bit = 19, 2643 .clkr = { 2644 .enable_reg = 0x2a60, 2645 .enable_mask = BIT(4), 2646 .hw.init = &(struct clk_init_data){ 2647 .name = "gsbi6_h_clk", 2648 .ops = &clk_branch_ops, 2649 }, 2650 }, 2651 }; 2652 2653 static struct clk_branch gsbi7_h_clk = { 2654 .hwcg_reg = 0x2a80, 2655 .hwcg_bit = 6, 2656 .halt_reg = 0x2fd0, 2657 .halt_bit = 15, 2658 .clkr = { 2659 .enable_reg = 0x2a80, 2660 .enable_mask = BIT(4), 2661 .hw.init = &(struct clk_init_data){ 2662 .name = "gsbi7_h_clk", 2663 .ops = &clk_branch_ops, 2664 }, 2665 }, 2666 }; 2667 2668 static struct clk_branch gsbi8_h_clk = { 2669 .hwcg_reg = 0x2aa0, 2670 .hwcg_bit = 6, 2671 .halt_reg = 0x2fd0, 2672 .halt_bit = 11, 2673 .clkr = { 2674 .enable_reg = 0x2aa0, 2675 .enable_mask = BIT(4), 2676 .hw.init = &(struct clk_init_data){ 2677 .name = "gsbi8_h_clk", 2678 .ops = &clk_branch_ops, 2679 }, 2680 }, 2681 }; 2682 2683 static struct clk_branch gsbi9_h_clk = { 2684 .hwcg_reg = 0x2ac0, 2685 .hwcg_bit = 6, 2686 .halt_reg = 0x2fd0, 2687 .halt_bit = 7, 2688 .clkr = { 2689 .enable_reg = 0x2ac0, 2690 .enable_mask = BIT(4), 2691 .hw.init = &(struct clk_init_data){ 2692 .name = "gsbi9_h_clk", 2693 .ops = &clk_branch_ops, 2694 }, 2695 }, 2696 }; 2697 2698 static struct clk_branch gsbi10_h_clk = { 2699 .hwcg_reg = 0x2ae0, 2700 .hwcg_bit = 6, 2701 .halt_reg = 0x2fd0, 2702 .halt_bit = 3, 2703 .clkr = { 2704 .enable_reg = 0x2ae0, 2705 .enable_mask = BIT(4), 2706 .hw.init = &(struct clk_init_data){ 2707 .name = "gsbi10_h_clk", 2708 .ops = &clk_branch_ops, 2709 }, 2710 }, 2711 }; 2712 2713 static struct clk_branch gsbi11_h_clk = { 2714 .hwcg_reg = 0x2b00, 2715 .hwcg_bit = 6, 2716 .halt_reg = 0x2fd4, 2717 .halt_bit = 18, 2718 .clkr = { 2719 .enable_reg = 0x2b00, 2720 .enable_mask = BIT(4), 2721 .hw.init = &(struct clk_init_data){ 2722 .name = "gsbi11_h_clk", 2723 .ops = &clk_branch_ops, 2724 }, 2725 }, 2726 }; 2727 2728 static struct clk_branch gsbi12_h_clk = { 2729 .hwcg_reg = 0x2b20, 2730 .hwcg_bit = 6, 2731 .halt_reg = 0x2fd4, 2732 .halt_bit = 14, 2733 .clkr = { 2734 .enable_reg = 0x2b20, 2735 .enable_mask = BIT(4), 2736 .hw.init = &(struct clk_init_data){ 2737 .name = "gsbi12_h_clk", 2738 .ops = &clk_branch_ops, 2739 }, 2740 }, 2741 }; 2742 2743 static struct clk_branch tsif_h_clk = { 2744 .hwcg_reg = 0x2700, 2745 .hwcg_bit = 6, 2746 .halt_reg = 0x2fd4, 2747 .halt_bit = 7, 2748 .clkr = { 2749 .enable_reg = 0x2700, 2750 .enable_mask = BIT(4), 2751 .hw.init = &(struct clk_init_data){ 2752 .name = "tsif_h_clk", 2753 .ops = &clk_branch_ops, 2754 }, 2755 }, 2756 }; 2757 2758 static struct clk_branch usb_fs1_h_clk = { 2759 .halt_reg = 0x2fcc, 2760 .halt_bit = 17, 2761 .clkr = { 2762 .enable_reg = 0x2960, 2763 .enable_mask = BIT(4), 2764 .hw.init = &(struct clk_init_data){ 2765 .name = "usb_fs1_h_clk", 2766 .ops = &clk_branch_ops, 2767 }, 2768 }, 2769 }; 2770 2771 static struct clk_branch usb_fs2_h_clk = { 2772 .halt_reg = 0x2fcc, 2773 .halt_bit = 14, 2774 .clkr = { 2775 .enable_reg = 0x2980, 2776 .enable_mask = BIT(4), 2777 .hw.init = &(struct clk_init_data){ 2778 .name = "usb_fs2_h_clk", 2779 .ops = &clk_branch_ops, 2780 }, 2781 }, 2782 }; 2783 2784 static struct clk_branch usb_hs1_h_clk = { 2785 .hwcg_reg = 0x2900, 2786 .hwcg_bit = 6, 2787 .halt_reg = 0x2fc8, 2788 .halt_bit = 1, 2789 .clkr = { 2790 .enable_reg = 0x2900, 2791 .enable_mask = BIT(4), 2792 .hw.init = &(struct clk_init_data){ 2793 .name = "usb_hs1_h_clk", 2794 .ops = &clk_branch_ops, 2795 }, 2796 }, 2797 }; 2798 2799 static struct clk_branch usb_hs3_h_clk = { 2800 .halt_reg = 0x2fc8, 2801 .halt_bit = 31, 2802 .clkr = { 2803 .enable_reg = 0x3700, 2804 .enable_mask = BIT(4), 2805 .hw.init = &(struct clk_init_data){ 2806 .name = "usb_hs3_h_clk", 2807 .ops = &clk_branch_ops, 2808 }, 2809 }, 2810 }; 2811 2812 static struct clk_branch usb_hs4_h_clk = { 2813 .halt_reg = 0x2fc8, 2814 .halt_bit = 7, 2815 .clkr = { 2816 .enable_reg = 0x3720, 2817 .enable_mask = BIT(4), 2818 .hw.init = &(struct clk_init_data){ 2819 .name = "usb_hs4_h_clk", 2820 .ops = &clk_branch_ops, 2821 }, 2822 }, 2823 }; 2824 2825 static struct clk_branch usb_hsic_h_clk = { 2826 .halt_reg = 0x2fcc, 2827 .halt_bit = 28, 2828 .clkr = { 2829 .enable_reg = 0x2920, 2830 .enable_mask = BIT(4), 2831 .hw.init = &(struct clk_init_data){ 2832 .name = "usb_hsic_h_clk", 2833 .ops = &clk_branch_ops, 2834 }, 2835 }, 2836 }; 2837 2838 static struct clk_branch sdc1_h_clk = { 2839 .hwcg_reg = 0x2820, 2840 .hwcg_bit = 6, 2841 .halt_reg = 0x2fc8, 2842 .halt_bit = 11, 2843 .clkr = { 2844 .enable_reg = 0x2820, 2845 .enable_mask = BIT(4), 2846 .hw.init = &(struct clk_init_data){ 2847 .name = "sdc1_h_clk", 2848 .ops = &clk_branch_ops, 2849 }, 2850 }, 2851 }; 2852 2853 static struct clk_branch sdc2_h_clk = { 2854 .hwcg_reg = 0x2840, 2855 .hwcg_bit = 6, 2856 .halt_reg = 0x2fc8, 2857 .halt_bit = 10, 2858 .clkr = { 2859 .enable_reg = 0x2840, 2860 .enable_mask = BIT(4), 2861 .hw.init = &(struct clk_init_data){ 2862 .name = "sdc2_h_clk", 2863 .ops = &clk_branch_ops, 2864 }, 2865 }, 2866 }; 2867 2868 static struct clk_branch sdc3_h_clk = { 2869 .hwcg_reg = 0x2860, 2870 .hwcg_bit = 6, 2871 .halt_reg = 0x2fc8, 2872 .halt_bit = 9, 2873 .clkr = { 2874 .enable_reg = 0x2860, 2875 .enable_mask = BIT(4), 2876 .hw.init = &(struct clk_init_data){ 2877 .name = "sdc3_h_clk", 2878 .ops = &clk_branch_ops, 2879 }, 2880 }, 2881 }; 2882 2883 static struct clk_branch sdc4_h_clk = { 2884 .hwcg_reg = 0x2880, 2885 .hwcg_bit = 6, 2886 .halt_reg = 0x2fc8, 2887 .halt_bit = 8, 2888 .clkr = { 2889 .enable_reg = 0x2880, 2890 .enable_mask = BIT(4), 2891 .hw.init = &(struct clk_init_data){ 2892 .name = "sdc4_h_clk", 2893 .ops = &clk_branch_ops, 2894 }, 2895 }, 2896 }; 2897 2898 static struct clk_branch sdc5_h_clk = { 2899 .hwcg_reg = 0x28a0, 2900 .hwcg_bit = 6, 2901 .halt_reg = 0x2fc8, 2902 .halt_bit = 7, 2903 .clkr = { 2904 .enable_reg = 0x28a0, 2905 .enable_mask = BIT(4), 2906 .hw.init = &(struct clk_init_data){ 2907 .name = "sdc5_h_clk", 2908 .ops = &clk_branch_ops, 2909 }, 2910 }, 2911 }; 2912 2913 static struct clk_branch adm0_clk = { 2914 .halt_reg = 0x2fdc, 2915 .halt_check = BRANCH_HALT_VOTED, 2916 .halt_bit = 14, 2917 .clkr = { 2918 .enable_reg = 0x3080, 2919 .enable_mask = BIT(2), 2920 .hw.init = &(struct clk_init_data){ 2921 .name = "adm0_clk", 2922 .ops = &clk_branch_ops, 2923 }, 2924 }, 2925 }; 2926 2927 static struct clk_branch adm0_pbus_clk = { 2928 .hwcg_reg = 0x2208, 2929 .hwcg_bit = 6, 2930 .halt_reg = 0x2fdc, 2931 .halt_check = BRANCH_HALT_VOTED, 2932 .halt_bit = 13, 2933 .clkr = { 2934 .enable_reg = 0x3080, 2935 .enable_mask = BIT(3), 2936 .hw.init = &(struct clk_init_data){ 2937 .name = "adm0_pbus_clk", 2938 .ops = &clk_branch_ops, 2939 }, 2940 }, 2941 }; 2942 2943 static const struct freq_tbl clk_tbl_ce3[] = { 2944 { 48000000, P_PLL8, 8 }, 2945 { 100000000, P_PLL3, 12 }, 2946 { 120000000, P_PLL3, 10 }, 2947 { } 2948 }; 2949 2950 static struct clk_rcg ce3_src = { 2951 .ns_reg = 0x36c0, 2952 .p = { 2953 .pre_div_shift = 3, 2954 .pre_div_width = 4, 2955 }, 2956 .s = { 2957 .src_sel_shift = 0, 2958 .parent_map = gcc_pxo_pll8_pll3_map, 2959 }, 2960 .freq_tbl = clk_tbl_ce3, 2961 .clkr = { 2962 .enable_reg = 0x36c0, 2963 .enable_mask = BIT(7), 2964 .hw.init = &(struct clk_init_data){ 2965 .name = "ce3_src", 2966 .parent_data = gcc_pxo_pll8_pll3, 2967 .num_parents = ARRAY_SIZE(gcc_pxo_pll8_pll3), 2968 .ops = &clk_rcg_ops, 2969 .flags = CLK_SET_RATE_GATE, 2970 }, 2971 }, 2972 }; 2973 2974 static struct clk_branch ce3_core_clk = { 2975 .halt_reg = 0x2fdc, 2976 .halt_bit = 5, 2977 .clkr = { 2978 .enable_reg = 0x36cc, 2979 .enable_mask = BIT(4), 2980 .hw.init = &(struct clk_init_data){ 2981 .name = "ce3_core_clk", 2982 .parent_hws = (const struct clk_hw*[]){ 2983 &ce3_src.clkr.hw 2984 }, 2985 .num_parents = 1, 2986 .ops = &clk_branch_ops, 2987 .flags = CLK_SET_RATE_PARENT, 2988 }, 2989 }, 2990 }; 2991 2992 static struct clk_branch ce3_h_clk = { 2993 .halt_reg = 0x2fc4, 2994 .halt_bit = 16, 2995 .clkr = { 2996 .enable_reg = 0x36c4, 2997 .enable_mask = BIT(4), 2998 .hw.init = &(struct clk_init_data){ 2999 .name = "ce3_h_clk", 3000 .parent_hws = (const struct clk_hw*[]){ 3001 &ce3_src.clkr.hw 3002 }, 3003 .num_parents = 1, 3004 .ops = &clk_branch_ops, 3005 .flags = CLK_SET_RATE_PARENT, 3006 }, 3007 }, 3008 }; 3009 3010 static const struct freq_tbl clk_tbl_sata_ref[] = { 3011 { 48000000, P_PLL8, 8, 0, 0 }, 3012 { 100000000, P_PLL3, 12, 0, 0 }, 3013 { } 3014 }; 3015 3016 static struct clk_rcg sata_clk_src = { 3017 .ns_reg = 0x2c08, 3018 .p = { 3019 .pre_div_shift = 3, 3020 .pre_div_width = 4, 3021 }, 3022 .s = { 3023 .src_sel_shift = 0, 3024 .parent_map = gcc_pxo_pll8_pll3_map, 3025 }, 3026 .freq_tbl = clk_tbl_sata_ref, 3027 .clkr = { 3028 .enable_reg = 0x2c08, 3029 .enable_mask = BIT(7), 3030 .hw.init = &(struct clk_init_data){ 3031 .name = "sata_clk_src", 3032 .parent_data = gcc_pxo_pll8_pll3, 3033 .num_parents = ARRAY_SIZE(gcc_pxo_pll8_pll3), 3034 .ops = &clk_rcg_ops, 3035 .flags = CLK_SET_RATE_GATE, 3036 }, 3037 }, 3038 }; 3039 3040 static struct clk_branch sata_rxoob_clk = { 3041 .halt_reg = 0x2fdc, 3042 .halt_bit = 26, 3043 .clkr = { 3044 .enable_reg = 0x2c0c, 3045 .enable_mask = BIT(4), 3046 .hw.init = &(struct clk_init_data){ 3047 .name = "sata_rxoob_clk", 3048 .parent_hws = (const struct clk_hw*[]){ 3049 &sata_clk_src.clkr.hw, 3050 }, 3051 .num_parents = 1, 3052 .ops = &clk_branch_ops, 3053 .flags = CLK_SET_RATE_PARENT, 3054 }, 3055 }, 3056 }; 3057 3058 static struct clk_branch sata_pmalive_clk = { 3059 .halt_reg = 0x2fdc, 3060 .halt_bit = 25, 3061 .clkr = { 3062 .enable_reg = 0x2c10, 3063 .enable_mask = BIT(4), 3064 .hw.init = &(struct clk_init_data){ 3065 .name = "sata_pmalive_clk", 3066 .parent_hws = (const struct clk_hw*[]){ 3067 &sata_clk_src.clkr.hw, 3068 }, 3069 .num_parents = 1, 3070 .ops = &clk_branch_ops, 3071 .flags = CLK_SET_RATE_PARENT, 3072 }, 3073 }, 3074 }; 3075 3076 static struct clk_branch sata_phy_ref_clk = { 3077 .halt_reg = 0x2fdc, 3078 .halt_bit = 24, 3079 .clkr = { 3080 .enable_reg = 0x2c14, 3081 .enable_mask = BIT(4), 3082 .hw.init = &(struct clk_init_data){ 3083 .name = "sata_phy_ref_clk", 3084 .parent_data = &(const struct clk_parent_data){ 3085 .fw_name = "pxo", .name = "pxo_board", 3086 }, 3087 .num_parents = 1, 3088 .ops = &clk_branch_ops, 3089 }, 3090 }, 3091 }; 3092 3093 static struct clk_branch sata_a_clk = { 3094 .halt_reg = 0x2fc0, 3095 .halt_bit = 12, 3096 .clkr = { 3097 .enable_reg = 0x2c20, 3098 .enable_mask = BIT(4), 3099 .hw.init = &(struct clk_init_data){ 3100 .name = "sata_a_clk", 3101 .ops = &clk_branch_ops, 3102 }, 3103 }, 3104 }; 3105 3106 static struct clk_branch sata_h_clk = { 3107 .halt_reg = 0x2fdc, 3108 .halt_bit = 27, 3109 .clkr = { 3110 .enable_reg = 0x2c00, 3111 .enable_mask = BIT(4), 3112 .hw.init = &(struct clk_init_data){ 3113 .name = "sata_h_clk", 3114 .ops = &clk_branch_ops, 3115 }, 3116 }, 3117 }; 3118 3119 static struct clk_branch sfab_sata_s_h_clk = { 3120 .halt_reg = 0x2fc4, 3121 .halt_bit = 14, 3122 .clkr = { 3123 .enable_reg = 0x2480, 3124 .enable_mask = BIT(4), 3125 .hw.init = &(struct clk_init_data){ 3126 .name = "sfab_sata_s_h_clk", 3127 .ops = &clk_branch_ops, 3128 }, 3129 }, 3130 }; 3131 3132 static struct clk_branch sata_phy_cfg_clk = { 3133 .halt_reg = 0x2fcc, 3134 .halt_bit = 12, 3135 .clkr = { 3136 .enable_reg = 0x2c40, 3137 .enable_mask = BIT(4), 3138 .hw.init = &(struct clk_init_data){ 3139 .name = "sata_phy_cfg_clk", 3140 .ops = &clk_branch_ops, 3141 }, 3142 }, 3143 }; 3144 3145 static struct clk_branch pcie_phy_ref_clk = { 3146 .halt_reg = 0x2fdc, 3147 .halt_bit = 29, 3148 .clkr = { 3149 .enable_reg = 0x22d0, 3150 .enable_mask = BIT(4), 3151 .hw.init = &(struct clk_init_data){ 3152 .name = "pcie_phy_ref_clk", 3153 .ops = &clk_branch_ops, 3154 }, 3155 }, 3156 }; 3157 3158 static struct clk_branch pcie_h_clk = { 3159 .halt_reg = 0x2fd4, 3160 .halt_bit = 8, 3161 .clkr = { 3162 .enable_reg = 0x22cc, 3163 .enable_mask = BIT(4), 3164 .hw.init = &(struct clk_init_data){ 3165 .name = "pcie_h_clk", 3166 .ops = &clk_branch_ops, 3167 }, 3168 }, 3169 }; 3170 3171 static struct clk_branch pcie_a_clk = { 3172 .halt_reg = 0x2fc0, 3173 .halt_bit = 13, 3174 .clkr = { 3175 .enable_reg = 0x22c0, 3176 .enable_mask = BIT(4), 3177 .hw.init = &(struct clk_init_data){ 3178 .name = "pcie_a_clk", 3179 .ops = &clk_branch_ops, 3180 }, 3181 }, 3182 }; 3183 3184 static struct clk_branch pmic_arb0_h_clk = { 3185 .halt_reg = 0x2fd8, 3186 .halt_check = BRANCH_HALT_VOTED, 3187 .halt_bit = 22, 3188 .clkr = { 3189 .enable_reg = 0x3080, 3190 .enable_mask = BIT(8), 3191 .hw.init = &(struct clk_init_data){ 3192 .name = "pmic_arb0_h_clk", 3193 .ops = &clk_branch_ops, 3194 }, 3195 }, 3196 }; 3197 3198 static struct clk_branch pmic_arb1_h_clk = { 3199 .halt_reg = 0x2fd8, 3200 .halt_check = BRANCH_HALT_VOTED, 3201 .halt_bit = 21, 3202 .clkr = { 3203 .enable_reg = 0x3080, 3204 .enable_mask = BIT(9), 3205 .hw.init = &(struct clk_init_data){ 3206 .name = "pmic_arb1_h_clk", 3207 .ops = &clk_branch_ops, 3208 }, 3209 }, 3210 }; 3211 3212 static struct clk_branch pmic_ssbi2_clk = { 3213 .halt_reg = 0x2fd8, 3214 .halt_check = BRANCH_HALT_VOTED, 3215 .halt_bit = 23, 3216 .clkr = { 3217 .enable_reg = 0x3080, 3218 .enable_mask = BIT(7), 3219 .hw.init = &(struct clk_init_data){ 3220 .name = "pmic_ssbi2_clk", 3221 .ops = &clk_branch_ops, 3222 }, 3223 }, 3224 }; 3225 3226 static struct clk_branch rpm_msg_ram_h_clk = { 3227 .hwcg_reg = 0x27e0, 3228 .hwcg_bit = 6, 3229 .halt_reg = 0x2fd8, 3230 .halt_check = BRANCH_HALT_VOTED, 3231 .halt_bit = 12, 3232 .clkr = { 3233 .enable_reg = 0x3080, 3234 .enable_mask = BIT(6), 3235 .hw.init = &(struct clk_init_data){ 3236 .name = "rpm_msg_ram_h_clk", 3237 .ops = &clk_branch_ops, 3238 }, 3239 }, 3240 }; 3241 3242 static struct clk_regmap *gcc_msm8960_clks[] = { 3243 [PLL3] = &pll3.clkr, 3244 [PLL4_VOTE] = &pll4_vote, 3245 [PLL8] = &pll8.clkr, 3246 [PLL8_VOTE] = &pll8_vote, 3247 [PLL14] = &pll14.clkr, 3248 [PLL14_VOTE] = &pll14_vote, 3249 [GSBI1_UART_SRC] = &gsbi1_uart_src.clkr, 3250 [GSBI1_UART_CLK] = &gsbi1_uart_clk.clkr, 3251 [GSBI2_UART_SRC] = &gsbi2_uart_src.clkr, 3252 [GSBI2_UART_CLK] = &gsbi2_uart_clk.clkr, 3253 [GSBI3_UART_SRC] = &gsbi3_uart_src.clkr, 3254 [GSBI3_UART_CLK] = &gsbi3_uart_clk.clkr, 3255 [GSBI4_UART_SRC] = &gsbi4_uart_src.clkr, 3256 [GSBI4_UART_CLK] = &gsbi4_uart_clk.clkr, 3257 [GSBI5_UART_SRC] = &gsbi5_uart_src.clkr, 3258 [GSBI5_UART_CLK] = &gsbi5_uart_clk.clkr, 3259 [GSBI6_UART_SRC] = &gsbi6_uart_src.clkr, 3260 [GSBI6_UART_CLK] = &gsbi6_uart_clk.clkr, 3261 [GSBI7_UART_SRC] = &gsbi7_uart_src.clkr, 3262 [GSBI7_UART_CLK] = &gsbi7_uart_clk.clkr, 3263 [GSBI8_UART_SRC] = &gsbi8_uart_src.clkr, 3264 [GSBI8_UART_CLK] = &gsbi8_uart_clk.clkr, 3265 [GSBI9_UART_SRC] = &gsbi9_uart_src.clkr, 3266 [GSBI9_UART_CLK] = &gsbi9_uart_clk.clkr, 3267 [GSBI10_UART_SRC] = &gsbi10_uart_src.clkr, 3268 [GSBI10_UART_CLK] = &gsbi10_uart_clk.clkr, 3269 [GSBI11_UART_SRC] = &gsbi11_uart_src.clkr, 3270 [GSBI11_UART_CLK] = &gsbi11_uart_clk.clkr, 3271 [GSBI12_UART_SRC] = &gsbi12_uart_src.clkr, 3272 [GSBI12_UART_CLK] = &gsbi12_uart_clk.clkr, 3273 [GSBI1_QUP_SRC] = &gsbi1_qup_src.clkr, 3274 [GSBI1_QUP_CLK] = &gsbi1_qup_clk.clkr, 3275 [GSBI2_QUP_SRC] = &gsbi2_qup_src.clkr, 3276 [GSBI2_QUP_CLK] = &gsbi2_qup_clk.clkr, 3277 [GSBI3_QUP_SRC] = &gsbi3_qup_src.clkr, 3278 [GSBI3_QUP_CLK] = &gsbi3_qup_clk.clkr, 3279 [GSBI4_QUP_SRC] = &gsbi4_qup_src.clkr, 3280 [GSBI4_QUP_CLK] = &gsbi4_qup_clk.clkr, 3281 [GSBI5_QUP_SRC] = &gsbi5_qup_src.clkr, 3282 [GSBI5_QUP_CLK] = &gsbi5_qup_clk.clkr, 3283 [GSBI6_QUP_SRC] = &gsbi6_qup_src.clkr, 3284 [GSBI6_QUP_CLK] = &gsbi6_qup_clk.clkr, 3285 [GSBI7_QUP_SRC] = &gsbi7_qup_src.clkr, 3286 [GSBI7_QUP_CLK] = &gsbi7_qup_clk.clkr, 3287 [GSBI8_QUP_SRC] = &gsbi8_qup_src.clkr, 3288 [GSBI8_QUP_CLK] = &gsbi8_qup_clk.clkr, 3289 [GSBI9_QUP_SRC] = &gsbi9_qup_src.clkr, 3290 [GSBI9_QUP_CLK] = &gsbi9_qup_clk.clkr, 3291 [GSBI10_QUP_SRC] = &gsbi10_qup_src.clkr, 3292 [GSBI10_QUP_CLK] = &gsbi10_qup_clk.clkr, 3293 [GSBI11_QUP_SRC] = &gsbi11_qup_src.clkr, 3294 [GSBI11_QUP_CLK] = &gsbi11_qup_clk.clkr, 3295 [GSBI12_QUP_SRC] = &gsbi12_qup_src.clkr, 3296 [GSBI12_QUP_CLK] = &gsbi12_qup_clk.clkr, 3297 [GP0_SRC] = &gp0_src.clkr, 3298 [GP0_CLK] = &gp0_clk.clkr, 3299 [GP1_SRC] = &gp1_src.clkr, 3300 [GP1_CLK] = &gp1_clk.clkr, 3301 [GP2_SRC] = &gp2_src.clkr, 3302 [GP2_CLK] = &gp2_clk.clkr, 3303 [PMEM_A_CLK] = &pmem_clk.clkr, 3304 [PRNG_SRC] = &prng_src.clkr, 3305 [PRNG_CLK] = &prng_clk.clkr, 3306 [SDC1_SRC] = &sdc1_src.clkr, 3307 [SDC1_CLK] = &sdc1_clk.clkr, 3308 [SDC2_SRC] = &sdc2_src.clkr, 3309 [SDC2_CLK] = &sdc2_clk.clkr, 3310 [SDC3_SRC] = &sdc3_src.clkr, 3311 [SDC3_CLK] = &sdc3_clk.clkr, 3312 [SDC4_SRC] = &sdc4_src.clkr, 3313 [SDC4_CLK] = &sdc4_clk.clkr, 3314 [SDC5_SRC] = &sdc5_src.clkr, 3315 [SDC5_CLK] = &sdc5_clk.clkr, 3316 [TSIF_REF_SRC] = &tsif_ref_src.clkr, 3317 [TSIF_REF_CLK] = &tsif_ref_clk.clkr, 3318 [USB_HS1_XCVR_SRC] = &usb_hs1_xcvr_src.clkr, 3319 [USB_HS1_XCVR_CLK] = &usb_hs1_xcvr_clk.clkr, 3320 [USB_HSIC_XCVR_FS_SRC] = &usb_hsic_xcvr_fs_src.clkr, 3321 [USB_HSIC_XCVR_FS_CLK] = &usb_hsic_xcvr_fs_clk.clkr, 3322 [USB_HSIC_SYSTEM_CLK] = &usb_hsic_system_clk.clkr, 3323 [USB_HSIC_HSIC_CLK] = &usb_hsic_hsic_clk.clkr, 3324 [USB_HSIC_HSIO_CAL_CLK] = &usb_hsic_hsio_cal_clk.clkr, 3325 [USB_FS1_XCVR_FS_SRC] = &usb_fs1_xcvr_fs_src.clkr, 3326 [USB_FS1_XCVR_FS_CLK] = &usb_fs1_xcvr_fs_clk.clkr, 3327 [USB_FS1_SYSTEM_CLK] = &usb_fs1_system_clk.clkr, 3328 [USB_FS2_XCVR_FS_SRC] = &usb_fs2_xcvr_fs_src.clkr, 3329 [USB_FS2_XCVR_FS_CLK] = &usb_fs2_xcvr_fs_clk.clkr, 3330 [USB_FS2_SYSTEM_CLK] = &usb_fs2_system_clk.clkr, 3331 [CE1_CORE_CLK] = &ce1_core_clk.clkr, 3332 [CE1_H_CLK] = &ce1_h_clk.clkr, 3333 [DMA_BAM_H_CLK] = &dma_bam_h_clk.clkr, 3334 [GSBI1_H_CLK] = &gsbi1_h_clk.clkr, 3335 [GSBI2_H_CLK] = &gsbi2_h_clk.clkr, 3336 [GSBI3_H_CLK] = &gsbi3_h_clk.clkr, 3337 [GSBI4_H_CLK] = &gsbi4_h_clk.clkr, 3338 [GSBI5_H_CLK] = &gsbi5_h_clk.clkr, 3339 [GSBI6_H_CLK] = &gsbi6_h_clk.clkr, 3340 [GSBI7_H_CLK] = &gsbi7_h_clk.clkr, 3341 [GSBI8_H_CLK] = &gsbi8_h_clk.clkr, 3342 [GSBI9_H_CLK] = &gsbi9_h_clk.clkr, 3343 [GSBI10_H_CLK] = &gsbi10_h_clk.clkr, 3344 [GSBI11_H_CLK] = &gsbi11_h_clk.clkr, 3345 [GSBI12_H_CLK] = &gsbi12_h_clk.clkr, 3346 [TSIF_H_CLK] = &tsif_h_clk.clkr, 3347 [USB_FS1_H_CLK] = &usb_fs1_h_clk.clkr, 3348 [USB_FS2_H_CLK] = &usb_fs2_h_clk.clkr, 3349 [USB_HS1_H_CLK] = &usb_hs1_h_clk.clkr, 3350 [USB_HSIC_H_CLK] = &usb_hsic_h_clk.clkr, 3351 [SDC1_H_CLK] = &sdc1_h_clk.clkr, 3352 [SDC2_H_CLK] = &sdc2_h_clk.clkr, 3353 [SDC3_H_CLK] = &sdc3_h_clk.clkr, 3354 [SDC4_H_CLK] = &sdc4_h_clk.clkr, 3355 [SDC5_H_CLK] = &sdc5_h_clk.clkr, 3356 [ADM0_CLK] = &adm0_clk.clkr, 3357 [ADM0_PBUS_CLK] = &adm0_pbus_clk.clkr, 3358 [PMIC_ARB0_H_CLK] = &pmic_arb0_h_clk.clkr, 3359 [PMIC_ARB1_H_CLK] = &pmic_arb1_h_clk.clkr, 3360 [PMIC_SSBI2_CLK] = &pmic_ssbi2_clk.clkr, 3361 [RPM_MSG_RAM_H_CLK] = &rpm_msg_ram_h_clk.clkr, 3362 [PLL9] = &hfpll0.clkr, 3363 [PLL10] = &hfpll1.clkr, 3364 [PLL12] = &hfpll_l2.clkr, 3365 }; 3366 3367 static const struct qcom_reset_map gcc_msm8960_resets[] = { 3368 [SFAB_MSS_Q6_SW_RESET] = { 0x2040, 7 }, 3369 [SFAB_MSS_Q6_FW_RESET] = { 0x2044, 7 }, 3370 [QDSS_STM_RESET] = { 0x2060, 6 }, 3371 [AFAB_SMPSS_S_RESET] = { 0x20b8, 2 }, 3372 [AFAB_SMPSS_M1_RESET] = { 0x20b8, 1 }, 3373 [AFAB_SMPSS_M0_RESET] = { 0x20b8 }, 3374 [AFAB_EBI1_CH0_RESET] = { 0x20c0, 7 }, 3375 [AFAB_EBI1_CH1_RESET] = { 0x20c4, 7}, 3376 [SFAB_ADM0_M0_RESET] = { 0x21e0, 7 }, 3377 [SFAB_ADM0_M1_RESET] = { 0x21e4, 7 }, 3378 [SFAB_ADM0_M2_RESET] = { 0x21e8, 7 }, 3379 [ADM0_C2_RESET] = { 0x220c, 4}, 3380 [ADM0_C1_RESET] = { 0x220c, 3}, 3381 [ADM0_C0_RESET] = { 0x220c, 2}, 3382 [ADM0_PBUS_RESET] = { 0x220c, 1 }, 3383 [ADM0_RESET] = { 0x220c }, 3384 [QDSS_CLKS_SW_RESET] = { 0x2260, 5 }, 3385 [QDSS_POR_RESET] = { 0x2260, 4 }, 3386 [QDSS_TSCTR_RESET] = { 0x2260, 3 }, 3387 [QDSS_HRESET_RESET] = { 0x2260, 2 }, 3388 [QDSS_AXI_RESET] = { 0x2260, 1 }, 3389 [QDSS_DBG_RESET] = { 0x2260 }, 3390 [PCIE_A_RESET] = { 0x22c0, 7 }, 3391 [PCIE_AUX_RESET] = { 0x22c8, 7 }, 3392 [PCIE_H_RESET] = { 0x22d0, 7 }, 3393 [SFAB_PCIE_M_RESET] = { 0x22d4, 1 }, 3394 [SFAB_PCIE_S_RESET] = { 0x22d4 }, 3395 [SFAB_MSS_M_RESET] = { 0x2340, 7 }, 3396 [SFAB_USB3_M_RESET] = { 0x2360, 7 }, 3397 [SFAB_RIVA_M_RESET] = { 0x2380, 7 }, 3398 [SFAB_LPASS_RESET] = { 0x23a0, 7 }, 3399 [SFAB_AFAB_M_RESET] = { 0x23e0, 7 }, 3400 [AFAB_SFAB_M0_RESET] = { 0x2420, 7 }, 3401 [AFAB_SFAB_M1_RESET] = { 0x2424, 7 }, 3402 [SFAB_SATA_S_RESET] = { 0x2480, 7 }, 3403 [SFAB_DFAB_M_RESET] = { 0x2500, 7 }, 3404 [DFAB_SFAB_M_RESET] = { 0x2520, 7 }, 3405 [DFAB_SWAY0_RESET] = { 0x2540, 7 }, 3406 [DFAB_SWAY1_RESET] = { 0x2544, 7 }, 3407 [DFAB_ARB0_RESET] = { 0x2560, 7 }, 3408 [DFAB_ARB1_RESET] = { 0x2564, 7 }, 3409 [PPSS_PROC_RESET] = { 0x2594, 1 }, 3410 [PPSS_RESET] = { 0x2594}, 3411 [DMA_BAM_RESET] = { 0x25c0, 7 }, 3412 [SPS_TIC_H_RESET] = { 0x2600, 7 }, 3413 [SLIMBUS_H_RESET] = { 0x2620, 7 }, 3414 [SFAB_CFPB_M_RESET] = { 0x2680, 7 }, 3415 [SFAB_CFPB_S_RESET] = { 0x26c0, 7 }, 3416 [TSIF_H_RESET] = { 0x2700, 7 }, 3417 [CE1_H_RESET] = { 0x2720, 7 }, 3418 [CE1_CORE_RESET] = { 0x2724, 7 }, 3419 [CE1_SLEEP_RESET] = { 0x2728, 7 }, 3420 [CE2_H_RESET] = { 0x2740, 7 }, 3421 [CE2_CORE_RESET] = { 0x2744, 7 }, 3422 [SFAB_SFPB_M_RESET] = { 0x2780, 7 }, 3423 [SFAB_SFPB_S_RESET] = { 0x27a0, 7 }, 3424 [RPM_PROC_RESET] = { 0x27c0, 7 }, 3425 [PMIC_SSBI2_RESET] = { 0x280c, 12 }, 3426 [SDC1_RESET] = { 0x2830 }, 3427 [SDC2_RESET] = { 0x2850 }, 3428 [SDC3_RESET] = { 0x2870 }, 3429 [SDC4_RESET] = { 0x2890 }, 3430 [SDC5_RESET] = { 0x28b0 }, 3431 [DFAB_A2_RESET] = { 0x28c0, 7 }, 3432 [USB_HS1_RESET] = { 0x2910 }, 3433 [USB_HSIC_RESET] = { 0x2934 }, 3434 [USB_FS1_XCVR_RESET] = { 0x2974, 1 }, 3435 [USB_FS1_RESET] = { 0x2974 }, 3436 [USB_FS2_XCVR_RESET] = { 0x2994, 1 }, 3437 [USB_FS2_RESET] = { 0x2994 }, 3438 [GSBI1_RESET] = { 0x29dc }, 3439 [GSBI2_RESET] = { 0x29fc }, 3440 [GSBI3_RESET] = { 0x2a1c }, 3441 [GSBI4_RESET] = { 0x2a3c }, 3442 [GSBI5_RESET] = { 0x2a5c }, 3443 [GSBI6_RESET] = { 0x2a7c }, 3444 [GSBI7_RESET] = { 0x2a9c }, 3445 [GSBI8_RESET] = { 0x2abc }, 3446 [GSBI9_RESET] = { 0x2adc }, 3447 [GSBI10_RESET] = { 0x2afc }, 3448 [GSBI11_RESET] = { 0x2b1c }, 3449 [GSBI12_RESET] = { 0x2b3c }, 3450 [SPDM_RESET] = { 0x2b6c }, 3451 [TLMM_H_RESET] = { 0x2ba0, 7 }, 3452 [SFAB_MSS_S_RESET] = { 0x2c00, 7 }, 3453 [MSS_SLP_RESET] = { 0x2c60, 7 }, 3454 [MSS_Q6SW_JTAG_RESET] = { 0x2c68, 7 }, 3455 [MSS_Q6FW_JTAG_RESET] = { 0x2c6c, 7 }, 3456 [MSS_RESET] = { 0x2c64 }, 3457 [SATA_H_RESET] = { 0x2c80, 7 }, 3458 [SATA_RXOOB_RESE] = { 0x2c8c, 7 }, 3459 [SATA_PMALIVE_RESET] = { 0x2c90, 7 }, 3460 [SATA_SFAB_M_RESET] = { 0x2c98, 7 }, 3461 [TSSC_RESET] = { 0x2ca0, 7 }, 3462 [PDM_RESET] = { 0x2cc0, 12 }, 3463 [MPM_H_RESET] = { 0x2da0, 7 }, 3464 [MPM_RESET] = { 0x2da4 }, 3465 [SFAB_SMPSS_S_RESET] = { 0x2e00, 7 }, 3466 [PRNG_RESET] = { 0x2e80, 12 }, 3467 [RIVA_RESET] = { 0x35e0 }, 3468 }; 3469 3470 static struct clk_regmap *gcc_apq8064_clks[] = { 3471 [PLL3] = &pll3.clkr, 3472 [PLL4_VOTE] = &pll4_vote, 3473 [PLL8] = &pll8.clkr, 3474 [PLL8_VOTE] = &pll8_vote, 3475 [PLL14] = &pll14.clkr, 3476 [PLL14_VOTE] = &pll14_vote, 3477 [GSBI1_UART_SRC] = &gsbi1_uart_src.clkr, 3478 [GSBI1_UART_CLK] = &gsbi1_uart_clk.clkr, 3479 [GSBI2_UART_SRC] = &gsbi2_uart_src.clkr, 3480 [GSBI2_UART_CLK] = &gsbi2_uart_clk.clkr, 3481 [GSBI3_UART_SRC] = &gsbi3_uart_src.clkr, 3482 [GSBI3_UART_CLK] = &gsbi3_uart_clk.clkr, 3483 [GSBI4_UART_SRC] = &gsbi4_uart_src.clkr, 3484 [GSBI4_UART_CLK] = &gsbi4_uart_clk.clkr, 3485 [GSBI5_UART_SRC] = &gsbi5_uart_src.clkr, 3486 [GSBI5_UART_CLK] = &gsbi5_uart_clk.clkr, 3487 [GSBI6_UART_SRC] = &gsbi6_uart_src.clkr, 3488 [GSBI6_UART_CLK] = &gsbi6_uart_clk.clkr, 3489 [GSBI7_UART_SRC] = &gsbi7_uart_src.clkr, 3490 [GSBI7_UART_CLK] = &gsbi7_uart_clk.clkr, 3491 [GSBI1_QUP_SRC] = &gsbi1_qup_src.clkr, 3492 [GSBI1_QUP_CLK] = &gsbi1_qup_clk.clkr, 3493 [GSBI2_QUP_SRC] = &gsbi2_qup_src.clkr, 3494 [GSBI2_QUP_CLK] = &gsbi2_qup_clk.clkr, 3495 [GSBI3_QUP_SRC] = &gsbi3_qup_src.clkr, 3496 [GSBI3_QUP_CLK] = &gsbi3_qup_clk.clkr, 3497 [GSBI4_QUP_SRC] = &gsbi4_qup_src.clkr, 3498 [GSBI4_QUP_CLK] = &gsbi4_qup_clk.clkr, 3499 [GSBI5_QUP_SRC] = &gsbi5_qup_src.clkr, 3500 [GSBI5_QUP_CLK] = &gsbi5_qup_clk.clkr, 3501 [GSBI6_QUP_SRC] = &gsbi6_qup_src.clkr, 3502 [GSBI6_QUP_CLK] = &gsbi6_qup_clk.clkr, 3503 [GSBI7_QUP_SRC] = &gsbi7_qup_src.clkr, 3504 [GSBI7_QUP_CLK] = &gsbi7_qup_clk.clkr, 3505 [GP0_SRC] = &gp0_src.clkr, 3506 [GP0_CLK] = &gp0_clk.clkr, 3507 [GP1_SRC] = &gp1_src.clkr, 3508 [GP1_CLK] = &gp1_clk.clkr, 3509 [GP2_SRC] = &gp2_src.clkr, 3510 [GP2_CLK] = &gp2_clk.clkr, 3511 [PMEM_A_CLK] = &pmem_clk.clkr, 3512 [PRNG_SRC] = &prng_src.clkr, 3513 [PRNG_CLK] = &prng_clk.clkr, 3514 [SDC1_SRC] = &sdc1_src.clkr, 3515 [SDC1_CLK] = &sdc1_clk.clkr, 3516 [SDC2_SRC] = &sdc2_src.clkr, 3517 [SDC2_CLK] = &sdc2_clk.clkr, 3518 [SDC3_SRC] = &sdc3_src.clkr, 3519 [SDC3_CLK] = &sdc3_clk.clkr, 3520 [SDC4_SRC] = &sdc4_src.clkr, 3521 [SDC4_CLK] = &sdc4_clk.clkr, 3522 [TSIF_REF_SRC] = &tsif_ref_src.clkr, 3523 [TSIF_REF_CLK] = &tsif_ref_clk.clkr, 3524 [USB_HS1_XCVR_SRC] = &usb_hs1_xcvr_src.clkr, 3525 [USB_HS1_XCVR_CLK] = &usb_hs1_xcvr_clk.clkr, 3526 [USB_HS3_XCVR_SRC] = &usb_hs3_xcvr_src.clkr, 3527 [USB_HS3_XCVR_CLK] = &usb_hs3_xcvr_clk.clkr, 3528 [USB_HS4_XCVR_SRC] = &usb_hs4_xcvr_src.clkr, 3529 [USB_HS4_XCVR_CLK] = &usb_hs4_xcvr_clk.clkr, 3530 [USB_HSIC_XCVR_FS_SRC] = &usb_hsic_xcvr_fs_src.clkr, 3531 [USB_HSIC_XCVR_FS_CLK] = &usb_hsic_xcvr_fs_clk.clkr, 3532 [USB_HSIC_SYSTEM_CLK] = &usb_hsic_system_clk.clkr, 3533 [USB_HSIC_HSIC_CLK] = &usb_hsic_hsic_clk.clkr, 3534 [USB_HSIC_HSIO_CAL_CLK] = &usb_hsic_hsio_cal_clk.clkr, 3535 [USB_FS1_XCVR_FS_SRC] = &usb_fs1_xcvr_fs_src.clkr, 3536 [USB_FS1_XCVR_FS_CLK] = &usb_fs1_xcvr_fs_clk.clkr, 3537 [USB_FS1_SYSTEM_CLK] = &usb_fs1_system_clk.clkr, 3538 [SATA_H_CLK] = &sata_h_clk.clkr, 3539 [SATA_CLK_SRC] = &sata_clk_src.clkr, 3540 [SATA_RXOOB_CLK] = &sata_rxoob_clk.clkr, 3541 [SATA_PMALIVE_CLK] = &sata_pmalive_clk.clkr, 3542 [SATA_PHY_REF_CLK] = &sata_phy_ref_clk.clkr, 3543 [SATA_PHY_CFG_CLK] = &sata_phy_cfg_clk.clkr, 3544 [SATA_A_CLK] = &sata_a_clk.clkr, 3545 [SFAB_SATA_S_H_CLK] = &sfab_sata_s_h_clk.clkr, 3546 [CE3_SRC] = &ce3_src.clkr, 3547 [CE3_CORE_CLK] = &ce3_core_clk.clkr, 3548 [CE3_H_CLK] = &ce3_h_clk.clkr, 3549 [DMA_BAM_H_CLK] = &dma_bam_h_clk.clkr, 3550 [GSBI1_H_CLK] = &gsbi1_h_clk.clkr, 3551 [GSBI2_H_CLK] = &gsbi2_h_clk.clkr, 3552 [GSBI3_H_CLK] = &gsbi3_h_clk.clkr, 3553 [GSBI4_H_CLK] = &gsbi4_h_clk.clkr, 3554 [GSBI5_H_CLK] = &gsbi5_h_clk.clkr, 3555 [GSBI6_H_CLK] = &gsbi6_h_clk.clkr, 3556 [GSBI7_H_CLK] = &gsbi7_h_clk.clkr, 3557 [TSIF_H_CLK] = &tsif_h_clk.clkr, 3558 [USB_FS1_H_CLK] = &usb_fs1_h_clk.clkr, 3559 [USB_HS1_H_CLK] = &usb_hs1_h_clk.clkr, 3560 [USB_HSIC_H_CLK] = &usb_hsic_h_clk.clkr, 3561 [USB_HS3_H_CLK] = &usb_hs3_h_clk.clkr, 3562 [USB_HS4_H_CLK] = &usb_hs4_h_clk.clkr, 3563 [SDC1_H_CLK] = &sdc1_h_clk.clkr, 3564 [SDC2_H_CLK] = &sdc2_h_clk.clkr, 3565 [SDC3_H_CLK] = &sdc3_h_clk.clkr, 3566 [SDC4_H_CLK] = &sdc4_h_clk.clkr, 3567 [ADM0_CLK] = &adm0_clk.clkr, 3568 [ADM0_PBUS_CLK] = &adm0_pbus_clk.clkr, 3569 [PCIE_A_CLK] = &pcie_a_clk.clkr, 3570 [PCIE_PHY_REF_CLK] = &pcie_phy_ref_clk.clkr, 3571 [PCIE_H_CLK] = &pcie_h_clk.clkr, 3572 [PMIC_ARB0_H_CLK] = &pmic_arb0_h_clk.clkr, 3573 [PMIC_ARB1_H_CLK] = &pmic_arb1_h_clk.clkr, 3574 [PMIC_SSBI2_CLK] = &pmic_ssbi2_clk.clkr, 3575 [RPM_MSG_RAM_H_CLK] = &rpm_msg_ram_h_clk.clkr, 3576 [PLL9] = &hfpll0.clkr, 3577 [PLL10] = &hfpll1.clkr, 3578 [PLL12] = &hfpll_l2.clkr, 3579 [PLL16] = &hfpll2.clkr, 3580 [PLL17] = &hfpll3.clkr, 3581 }; 3582 3583 static const struct qcom_reset_map gcc_apq8064_resets[] = { 3584 [QDSS_STM_RESET] = { 0x2060, 6 }, 3585 [AFAB_SMPSS_S_RESET] = { 0x20b8, 2 }, 3586 [AFAB_SMPSS_M1_RESET] = { 0x20b8, 1 }, 3587 [AFAB_SMPSS_M0_RESET] = { 0x20b8 }, 3588 [AFAB_EBI1_CH0_RESET] = { 0x20c0, 7 }, 3589 [AFAB_EBI1_CH1_RESET] = { 0x20c4, 7}, 3590 [SFAB_ADM0_M0_RESET] = { 0x21e0, 7 }, 3591 [SFAB_ADM0_M1_RESET] = { 0x21e4, 7 }, 3592 [SFAB_ADM0_M2_RESET] = { 0x21e8, 7 }, 3593 [ADM0_C2_RESET] = { 0x220c, 4}, 3594 [ADM0_C1_RESET] = { 0x220c, 3}, 3595 [ADM0_C0_RESET] = { 0x220c, 2}, 3596 [ADM0_PBUS_RESET] = { 0x220c, 1 }, 3597 [ADM0_RESET] = { 0x220c }, 3598 [QDSS_CLKS_SW_RESET] = { 0x2260, 5 }, 3599 [QDSS_POR_RESET] = { 0x2260, 4 }, 3600 [QDSS_TSCTR_RESET] = { 0x2260, 3 }, 3601 [QDSS_HRESET_RESET] = { 0x2260, 2 }, 3602 [QDSS_AXI_RESET] = { 0x2260, 1 }, 3603 [QDSS_DBG_RESET] = { 0x2260 }, 3604 [SFAB_PCIE_M_RESET] = { 0x22d8, 1 }, 3605 [SFAB_PCIE_S_RESET] = { 0x22d8 }, 3606 [PCIE_EXT_PCI_RESET] = { 0x22dc, 6 }, 3607 [PCIE_PHY_RESET] = { 0x22dc, 5 }, 3608 [PCIE_PCI_RESET] = { 0x22dc, 4 }, 3609 [PCIE_POR_RESET] = { 0x22dc, 3 }, 3610 [PCIE_HCLK_RESET] = { 0x22dc, 2 }, 3611 [PCIE_ACLK_RESET] = { 0x22dc }, 3612 [SFAB_USB3_M_RESET] = { 0x2360, 7 }, 3613 [SFAB_RIVA_M_RESET] = { 0x2380, 7 }, 3614 [SFAB_LPASS_RESET] = { 0x23a0, 7 }, 3615 [SFAB_AFAB_M_RESET] = { 0x23e0, 7 }, 3616 [AFAB_SFAB_M0_RESET] = { 0x2420, 7 }, 3617 [AFAB_SFAB_M1_RESET] = { 0x2424, 7 }, 3618 [SFAB_SATA_S_RESET] = { 0x2480, 7 }, 3619 [SFAB_DFAB_M_RESET] = { 0x2500, 7 }, 3620 [DFAB_SFAB_M_RESET] = { 0x2520, 7 }, 3621 [DFAB_SWAY0_RESET] = { 0x2540, 7 }, 3622 [DFAB_SWAY1_RESET] = { 0x2544, 7 }, 3623 [DFAB_ARB0_RESET] = { 0x2560, 7 }, 3624 [DFAB_ARB1_RESET] = { 0x2564, 7 }, 3625 [PPSS_PROC_RESET] = { 0x2594, 1 }, 3626 [PPSS_RESET] = { 0x2594}, 3627 [DMA_BAM_RESET] = { 0x25c0, 7 }, 3628 [SPS_TIC_H_RESET] = { 0x2600, 7 }, 3629 [SFAB_CFPB_M_RESET] = { 0x2680, 7 }, 3630 [SFAB_CFPB_S_RESET] = { 0x26c0, 7 }, 3631 [TSIF_H_RESET] = { 0x2700, 7 }, 3632 [CE1_H_RESET] = { 0x2720, 7 }, 3633 [CE1_CORE_RESET] = { 0x2724, 7 }, 3634 [CE1_SLEEP_RESET] = { 0x2728, 7 }, 3635 [CE2_H_RESET] = { 0x2740, 7 }, 3636 [CE2_CORE_RESET] = { 0x2744, 7 }, 3637 [SFAB_SFPB_M_RESET] = { 0x2780, 7 }, 3638 [SFAB_SFPB_S_RESET] = { 0x27a0, 7 }, 3639 [RPM_PROC_RESET] = { 0x27c0, 7 }, 3640 [PMIC_SSBI2_RESET] = { 0x280c, 12 }, 3641 [SDC1_RESET] = { 0x2830 }, 3642 [SDC2_RESET] = { 0x2850 }, 3643 [SDC3_RESET] = { 0x2870 }, 3644 [SDC4_RESET] = { 0x2890 }, 3645 [USB_HS1_RESET] = { 0x2910 }, 3646 [USB_HSIC_RESET] = { 0x2934 }, 3647 [USB_FS1_XCVR_RESET] = { 0x2974, 1 }, 3648 [USB_FS1_RESET] = { 0x2974 }, 3649 [GSBI1_RESET] = { 0x29dc }, 3650 [GSBI2_RESET] = { 0x29fc }, 3651 [GSBI3_RESET] = { 0x2a1c }, 3652 [GSBI4_RESET] = { 0x2a3c }, 3653 [GSBI5_RESET] = { 0x2a5c }, 3654 [GSBI6_RESET] = { 0x2a7c }, 3655 [GSBI7_RESET] = { 0x2a9c }, 3656 [SPDM_RESET] = { 0x2b6c }, 3657 [TLMM_H_RESET] = { 0x2ba0, 7 }, 3658 [SATA_SFAB_M_RESET] = { 0x2c18 }, 3659 [SATA_RESET] = { 0x2c1c }, 3660 [GSS_SLP_RESET] = { 0x2c60, 7 }, 3661 [GSS_RESET] = { 0x2c64 }, 3662 [TSSC_RESET] = { 0x2ca0, 7 }, 3663 [PDM_RESET] = { 0x2cc0, 12 }, 3664 [MPM_H_RESET] = { 0x2da0, 7 }, 3665 [MPM_RESET] = { 0x2da4 }, 3666 [SFAB_SMPSS_S_RESET] = { 0x2e00, 7 }, 3667 [PRNG_RESET] = { 0x2e80, 12 }, 3668 [RIVA_RESET] = { 0x35e0 }, 3669 [CE3_H_RESET] = { 0x36c4, 7 }, 3670 [SFAB_CE3_M_RESET] = { 0x36c8, 1 }, 3671 [SFAB_CE3_S_RESET] = { 0x36c8 }, 3672 [CE3_RESET] = { 0x36cc, 7 }, 3673 [CE3_SLEEP_RESET] = { 0x36d0, 7 }, 3674 [USB_HS3_RESET] = { 0x3710 }, 3675 [USB_HS4_RESET] = { 0x3730 }, 3676 }; 3677 3678 static const struct regmap_config gcc_msm8960_regmap_config = { 3679 .reg_bits = 32, 3680 .reg_stride = 4, 3681 .val_bits = 32, 3682 .max_register = 0x3660, 3683 .fast_io = true, 3684 }; 3685 3686 static const struct regmap_config gcc_apq8064_regmap_config = { 3687 .reg_bits = 32, 3688 .reg_stride = 4, 3689 .val_bits = 32, 3690 .max_register = 0x3880, 3691 .fast_io = true, 3692 }; 3693 3694 static const struct qcom_cc_desc gcc_msm8960_desc = { 3695 .config = &gcc_msm8960_regmap_config, 3696 .clks = gcc_msm8960_clks, 3697 .num_clks = ARRAY_SIZE(gcc_msm8960_clks), 3698 .resets = gcc_msm8960_resets, 3699 .num_resets = ARRAY_SIZE(gcc_msm8960_resets), 3700 }; 3701 3702 static const struct qcom_cc_desc gcc_apq8064_desc = { 3703 .config = &gcc_apq8064_regmap_config, 3704 .clks = gcc_apq8064_clks, 3705 .num_clks = ARRAY_SIZE(gcc_apq8064_clks), 3706 .resets = gcc_apq8064_resets, 3707 .num_resets = ARRAY_SIZE(gcc_apq8064_resets), 3708 }; 3709 3710 static const struct of_device_id gcc_msm8960_match_table[] = { 3711 { .compatible = "qcom,gcc-msm8960", .data = &gcc_msm8960_desc }, 3712 { .compatible = "qcom,gcc-apq8064", .data = &gcc_apq8064_desc }, 3713 { } 3714 }; 3715 MODULE_DEVICE_TABLE(of, gcc_msm8960_match_table); 3716 3717 static int gcc_msm8960_probe(struct platform_device *pdev) 3718 { 3719 struct device *dev = &pdev->dev; 3720 struct platform_device *tsens; 3721 const struct qcom_cc_desc *desc = device_get_match_data(dev); 3722 int ret; 3723 3724 ret = qcom_cc_register_board_clk(dev, "cxo_board", "cxo", 19200000); 3725 if (ret) 3726 return ret; 3727 3728 ret = qcom_cc_register_board_clk(dev, "pxo_board", "pxo", 27000000); 3729 if (ret) 3730 return ret; 3731 3732 ret = qcom_cc_probe(pdev, desc); 3733 if (ret) 3734 return ret; 3735 3736 if (desc == &gcc_apq8064_desc) { 3737 hfpll1.d = &hfpll1_8064_data; 3738 hfpll_l2.d = &hfpll_l2_8064_data; 3739 } 3740 3741 if (of_get_available_child_count(pdev->dev.of_node) != 0) 3742 return devm_of_platform_populate(&pdev->dev); 3743 3744 tsens = platform_device_register_data(&pdev->dev, "qcom-tsens", -1, 3745 NULL, 0); 3746 if (IS_ERR(tsens)) 3747 return PTR_ERR(tsens); 3748 3749 platform_set_drvdata(pdev, tsens); 3750 3751 return 0; 3752 } 3753 3754 static void gcc_msm8960_remove(struct platform_device *pdev) 3755 { 3756 struct platform_device *tsens = platform_get_drvdata(pdev); 3757 3758 if (tsens) 3759 platform_device_unregister(tsens); 3760 } 3761 3762 static struct platform_driver gcc_msm8960_driver = { 3763 .probe = gcc_msm8960_probe, 3764 .remove = gcc_msm8960_remove, 3765 .driver = { 3766 .name = "gcc-msm8960", 3767 .of_match_table = gcc_msm8960_match_table, 3768 }, 3769 }; 3770 3771 static int __init gcc_msm8960_init(void) 3772 { 3773 return platform_driver_register(&gcc_msm8960_driver); 3774 } 3775 core_initcall(gcc_msm8960_init); 3776 3777 static void __exit gcc_msm8960_exit(void) 3778 { 3779 platform_driver_unregister(&gcc_msm8960_driver); 3780 } 3781 module_exit(gcc_msm8960_exit); 3782 3783 MODULE_DESCRIPTION("QCOM GCC MSM8960 Driver"); 3784 MODULE_LICENSE("GPL v2"); 3785 MODULE_ALIAS("platform:gcc-msm8960"); 3786